/* ── INVITATIONS TABLE PAGE ── */
.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.page-title-wrap{}
.page-title{font-size:20px;font-weight:700;color:var(--text-1)}
.page-subtitle{font-size:12px;color:var(--text-3);margin-top:3px}

.filter-bar{
  display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap;
}
.filter-input{
  background:var(--bg-2);border:1px solid var(--border);
  color:var(--text-1);padding:7px 12px;border-radius:7px;
  font-size:12px;font-family:'Inter',sans-serif;outline:none;
  transition:border-color .15s;
}
.filter-input:focus{border-color:var(--gold-mid)}
.filter-input::placeholder{color:var(--text-3)}
.filter-select{
  background:var(--bg-2);border:1px solid var(--border);
  color:var(--text-2);padding:7px 10px;border-radius:7px;
  font-size:12px;font-family:'Inter',sans-serif;outline:none;cursor:pointer;
}

.table-wrap{
  background:var(--bg-2);border:1px solid var(--border);
  border-radius:var(--radius);overflow:hidden;
}
.data-table{width:100%;border-collapse:collapse}
.data-table th{
  font-size:10px;letter-spacing:.08em;text-transform:uppercase;
  color:var(--text-3);padding:11px 16px;text-align:left;
  border-bottom:1px solid var(--border);font-weight:500;
  background:rgba(255,255,255,.02);
}
.data-table td{
  padding:13px 16px;font-size:12px;color:var(--text-2);
  border-bottom:1px solid var(--border);vertical-align:middle;
}
.data-table tr:last-child td{border-bottom:none}
.data-table tr:hover td{background:rgba(255,255,255,.02)}

.couple-cell{display:flex;align-items:center;gap:10px}
.couple-thumb{
  width:36px;height:36px;border-radius:7px;object-fit:cover;
  background:var(--bg-4);flex-shrink:0;border:1px solid var(--border);
}
.couple-names{font-weight:500;color:var(--text-1);font-size:13px}
.couple-slug{font-size:11px;color:var(--text-3);margin-top:1px}

.action-btns{display:flex;gap:5px}
.action-btn{
  width:28px;height:28px;border-radius:6px;border:1px solid var(--border);
  background:transparent;color:var(--text-3);cursor:pointer;
  display:flex;align-items:center;justify-content:center;transition:all .15s;
}
.action-btn:hover{background:var(--bg-3);color:var(--text-1)}
.action-btn.del:hover{border-color:rgba(239,68,68,.3);color:var(--red);background:rgba(239,68,68,.05)}
.action-btn svg{width:13px;height:13px}

/* ── FORM / EDIT PAGE ── */
.form-layout{display:grid;grid-template-columns:1fr 320px;gap:16px;align-items:start}
.form-main{display:flex;flex-direction:column;gap:14px}
.form-sidebar-wrap{display:flex;flex-direction:column;gap:14px}

.form-card{
  background:var(--bg-2);border:1px solid var(--border);
  border-radius:var(--radius);overflow:hidden;
}
.form-card-head{
  padding:13px 18px;border-bottom:1px solid var(--border);
  display:flex;align-items:center;gap:8px;
}
.form-card-icon{
  width:24px;height:24px;border-radius:5px;
  display:flex;align-items:center;justify-content:center;
  background:var(--gold-dim);
}
.form-card-icon svg{width:12px;height:12px;color:var(--gold)}
.form-card-title{font-size:12px;font-weight:600;color:var(--text-1)}
.form-card-body{padding:18px}

.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-group{display:flex;flex-direction:column;gap:5px}
.form-group.full{grid-column:span 2}
.form-label{font-size:11px;font-weight:500;color:var(--text-2);letter-spacing:.02em}
.form-label .req{color:var(--red)}
.form-input,.form-select,.form-textarea{
  background:var(--bg-3);border:1px solid var(--border);
  color:var(--text-1);padding:8px 11px;border-radius:7px;
  font-size:12px;font-family:'Inter',sans-serif;outline:none;
  transition:border-color .15s;width:100%;
}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--gold-mid)}
.form-input::placeholder,.form-textarea::placeholder{color:var(--text-3)}
.form-textarea{resize:vertical;min-height:72px;line-height:1.6}
.form-select option{background:#1e2130}
.form-hint{font-size:10px;color:var(--text-3);margin-top:2px}

/* Tabs */
.tabs{display:flex;gap:0;border-bottom:1px solid var(--border);margin-bottom:0;overflow-x:auto}
.tabs::-webkit-scrollbar{height:0}
.tab-btn{
  padding:11px 16px;font-size:12px;font-weight:500;color:var(--text-3);
  cursor:pointer;border-bottom:2px solid transparent;white-space:nowrap;
  transition:all .15s;background:none;border-top:none;border-left:none;border-right:none;
  font-family:'Inter',sans-serif;
}
.tab-btn:hover{color:var(--text-1)}
.tab-btn.active{color:var(--gold);border-bottom-color:var(--gold)}
.tab-content{display:none;padding:18px}
.tab-content.active{display:block}

/* Toggle switch */
.toggle-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--border)}
.toggle-row:last-child{border-bottom:none}
.toggle-info{}
.toggle-label{font-size:12px;font-weight:500;color:var(--text-1)}
.toggle-desc{font-size:11px;color:var(--text-3);margin-top:2px}
.toggle{position:relative;width:36px;height:20px;flex-shrink:0}
.toggle input{opacity:0;width:0;height:0}
.toggle-slider{
  position:absolute;inset:0;background:var(--bg-4);border-radius:10px;
  cursor:pointer;transition:.2s;border:1px solid var(--border);
}
.toggle-slider::before{
  content:'';position:absolute;width:14px;height:14px;
  left:2px;top:2px;background:var(--text-3);border-radius:50%;transition:.2s;
}
.toggle input:checked + .toggle-slider{background:var(--gold-dim);border-color:var(--gold-mid)}
.toggle input:checked + .toggle-slider::before{transform:translateX(16px);background:var(--gold)}

/* Select pills */
.pill-select{display:flex;flex-wrap:wrap;gap:6px}
.pill{
  padding:5px 12px;border-radius:20px;font-size:11px;font-weight:500;
  border:1px solid var(--border);color:var(--text-3);cursor:pointer;transition:all .15s;
}
.pill:hover{border-color:var(--gold-mid);color:var(--text-1)}
.pill.selected{background:var(--gold-dim);border-color:var(--gold);color:var(--gold)}

/* Photo upload */
.photo-upload-area{
  border:2px dashed var(--border);border-radius:var(--radius);
  padding:24px;text-align:center;cursor:pointer;transition:border-color .2s;
}
.photo-upload-area:hover{border-color:var(--gold-mid)}
.photo-upload-icon{color:var(--text-3);margin:0 auto 8px}
.photo-upload-icon svg{width:28px;height:28px}
.photo-upload-text{font-size:12px;color:var(--text-2);font-weight:500}
.photo-upload-hint{font-size:10px;color:var(--text-3);margin-top:3px}

.photo-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-top:12px}
.photo-thumb{
  aspect-ratio:1;border-radius:7px;overflow:hidden;
  position:relative;background:var(--bg-4);cursor:grab;
}
.photo-thumb img{width:100%;height:100%;object-fit:cover}
.photo-thumb-overlay{
  position:absolute;inset:0;background:rgba(0,0,0,0);
  display:flex;align-items:center;justify-content:center;transition:.2s;
}
.photo-thumb:hover .photo-thumb-overlay{background:rgba(0,0,0,.5)}
.photo-thumb-overlay svg{color:#fff;width:16px;height:16px;opacity:0;transition:.2s}
.photo-thumb:hover .photo-thumb-overlay svg{opacity:1}
.photo-cover-badge{
  position:absolute;top:4px;left:4px;
  background:var(--gold);color:#1a0e06;
  font-size:9px;font-weight:700;padding:2px 5px;border-radius:3px;
}

/* Color picker row */
.color-row{display:flex;gap:8px;align-items:center}
.color-swatch{
  width:28px;height:28px;border-radius:6px;border:1px solid var(--border);
  cursor:pointer;flex-shrink:0;
}
.color-input-text{
  background:var(--bg-3);border:1px solid var(--border);
  color:var(--text-1);padding:5px 8px;border-radius:5px;
  font-size:11px;font-family:monospace;width:90px;outline:none;
}

/* Font preview */
.font-preview{
  margin-top:6px;padding:8px 11px;background:var(--bg-3);
  border-radius:6px;font-size:18px;color:var(--text-1);
  min-height:38px;
}

/* Event repeater */
.repeater-item{
  background:var(--bg-3);border:1px solid var(--border);
  border-radius:var(--radius);margin-bottom:10px;overflow:hidden;
}
.repeater-head{
  display:flex;align-items:center;gap:10px;padding:11px 14px;
  cursor:pointer;border-bottom:1px solid var(--border);
}
.repeater-drag{color:var(--text-3);cursor:grab}
.repeater-drag svg{width:14px;height:14px}
.repeater-title{font-size:12px;font-weight:500;color:var(--text-1);flex:1}
.repeater-del{color:var(--text-3);background:none;border:none;cursor:pointer;padding:2px}
.repeater-del:hover{color:var(--red)}
.repeater-del svg{width:13px;height:13px}
.repeater-body{padding:14px;display:grid;grid-template-columns:1fr 1fr;gap:10px}

/* ── RSVP PAGE ── */
.rsvp-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:16px}
.rsvp-stat{
  background:var(--bg-2);border:1px solid var(--border);
  border-radius:var(--radius);padding:16px;text-align:center;
}
.rsvp-stat-num{font-size:32px;font-weight:700;color:var(--text-1);line-height:1}
.rsvp-stat-label{font-size:11px;color:var(--text-3);margin-top:4px}

/* Progress bar */
.progress-wrap{margin-top:14px;padding:14px 18px;border-top:1px solid var(--border)}
.progress-label{display:flex;justify-content:space-between;font-size:11px;margin-bottom:6px}
.progress-label span:first-child{color:var(--text-2)}
.progress-label span:last-child{color:var(--text-3)}
.progress-bar{height:4px;background:var(--bg-4);border-radius:2px;overflow:hidden}
.progress-fill{height:100%;border-radius:2px;background:var(--gold)}
.progress-fill.green{background:var(--green)}
.progress-fill.red{background:var(--red)}

/* Notification banner */
.notif-banner{
  display:flex;align-items:center;gap:12px;
  padding:12px 16px;border-radius:var(--radius);margin-bottom:16px;
  border:1px solid;font-size:12px;
}
.notif-banner.success{background:rgba(34,197,94,.08);border-color:rgba(34,197,94,.2);color:var(--green)}
.notif-banner.info{background:rgba(59,130,246,.08);border-color:rgba(59,130,246,.2);color:var(--blue)}
.notif-banner svg{width:15px;height:15px;flex-shrink:0}

/* Empty state */
.empty-state{text-align:center;padding:48px 24px}
.empty-icon{color:var(--text-3);margin:0 auto 12px}
.empty-icon svg{width:36px;height:36px}
.empty-title{font-size:14px;font-weight:500;color:var(--text-2);margin-bottom:6px}
.empty-desc{font-size:12px;color:var(--text-3);line-height:1.6}

/* Pagination */
.pagination{display:flex;align-items:center;justify-content:between;padding:12px 16px;border-top:1px solid var(--border)}
.pagination-info{font-size:11px;color:var(--text-3)}
.pagination-btns{display:flex;gap:4px;margin-left:auto}
.page-btn{
  width:28px;height:28px;border-radius:5px;border:1px solid var(--border);
  background:transparent;color:var(--text-3);font-size:11px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;transition:all .15s;
}
.page-btn:hover{background:var(--bg-3);color:var(--text-1)}
.page-btn.active{background:var(--gold-dim);border-color:var(--gold);color:var(--gold)}

/* Tooltip */
.tooltip-wrap{position:relative}
.tooltip{
  position:absolute;bottom:calc(100% + 6px);left:50%;transform:translateX(-50%);
  background:#0a0c12;border:1px solid var(--border);
  color:var(--text-2);font-size:10px;padding:4px 8px;border-radius:5px;
  white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .15s;
}
.tooltip-wrap:hover .tooltip{opacity:1}

/* Scrollbar global */
::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--bg-4);border-radius:4px}

/* ── LOGIN SCREEN ── */
#loginScreen{position:fixed;inset:0;background:var(--bg-1);display:flex;align-items:center;justify-content:center;z-index:999}
.login-card{width:340px;background:var(--bg-2);border:1px solid var(--border);border-radius:12px;padding:32px}
.login-brand{display:flex;align-items:center;gap:10px;margin-bottom:24px}
.login-title{font-size:16px;font-weight:600;color:var(--text-1);margin-bottom:4px}
.login-sub{font-size:12px;color:var(--text-2);margin-bottom:20px}
.login-error{font-size:12px;color:var(--red);margin-top:10px;min-height:14px}
.login-btn{width:100%;margin-top:14px;justify-content:center}
#appShell{display:none}
#appShell.visible{display:flex}
