:root{
  --paper:#F4F1E9; --paper-2:#ECE7DB; --paper-3:#E3DDCD;
  --ink:#211F1A; --ink-soft:#6E685A; --line:#DCD6C7;
  --film:#1B1A16; --film-2:#272520; --on-film:#ECE6D8;
  --gold:#C8A24C; --sage:#8A9A86; --clay:#9A3B32;
  --display:'Fraunces',Georgia,'Times New Roman',serif;
  --mono:'Space Mono',ui-monospace,SFMono-Regular,Menlo,monospace;
  --body:system-ui,-apple-system,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
  --r:14px; --maxw:1080px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{background:var(--paper);color:var(--ink);font-family:var(--body);-webkit-font-smoothing:antialiased;line-height:1.5;min-height:100svh}
.eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-soft);margin:0}
.filmstrip{height:13px;border-radius:3px;background-color:var(--film);background-image:linear-gradient(to right,transparent 0 6px,var(--paper) 6px 12px,transparent 12px 18px);background-size:18px 6px;background-position:center;background-repeat:repeat-x;margin-bottom:18px}

/* ---------------- Buttons + fields ---------------- */
.btn{font-family:var(--mono);font-size:13px;letter-spacing:.07em;text-transform:uppercase;border-radius:999px;border:1px solid transparent;padding:13px 20px;cursor:pointer;transition:transform .12s ease,background-color .2s ease,opacity .2s ease}
.btn:active{transform:translateY(1px)}
.btn--primary{background:var(--ink);color:var(--paper)}
.btn--primary:hover{background:#000}
.btn--ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn--ghost:hover{border-color:var(--ink-soft)}
.btn--sm{padding:9px 15px;font-size:12px}
.btn:focus-visible{outline:3px solid var(--gold);outline-offset:2px}
.btn:disabled{opacity:.5;cursor:default}

.field{display:grid;gap:6px}
.field__label{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft)}
.field__hint{font-size:12px;color:var(--ink-soft)}
.field__input{font-size:16px;padding:13px 14px;border:1px solid var(--line);border-radius:11px;background:var(--paper);color:var(--ink);font-family:var(--body);width:100%}
.field__input:focus-visible{outline:3px solid var(--gold);outline-offset:1px;border-color:var(--gold)}
.field__input--hex{font-family:var(--mono);text-transform:lowercase}
.field__input--code{font-family:var(--mono);letter-spacing:.18em;text-transform:uppercase}
.form-error{color:var(--clay);font-size:13px;font-family:var(--mono);margin:0}

/* ---------------- Sign in ---------------- */
.login{min-height:100svh;display:grid;place-items:center;padding:24px}
.login__card{width:100%;max-width:380px;background:var(--paper-2);border:1px solid var(--line);border-radius:20px;padding:30px 26px}
.login__title{font-family:var(--display);font-weight:500;font-size:26px;margin:8px 0 22px}
.login__form{display:grid;gap:16px}

/* ---------------- Rail + tabs ---------------- */
.rail{background:var(--film);color:var(--on-film);display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px clamp(16px,5vw,32px);padding-top:max(14px,env(safe-area-inset-top))}
.rail__brand{display:flex;align-items:center;gap:10px}
.rail__strip{width:34px;height:11px;border-radius:2px;background-color:#000;background-image:linear-gradient(to right,transparent 0 5px,var(--on-film) 5px 10px,transparent 10px 15px);background-size:15px 5px;background-position:center;background-repeat:repeat-x;opacity:.8}
.rail__mark{font-family:var(--mono);font-weight:700;font-size:13px;letter-spacing:.28em}
.rail__event{display:flex;align-items:center;gap:16px;min-width:0}
.rail__name{font-family:var(--display);font-size:18px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rail__signout{background:transparent;border:1px solid rgba(236,230,216,.3);color:var(--on-film);font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;padding:7px 12px;border-radius:999px;cursor:pointer}
.rail__signout:hover{border-color:var(--on-film)}

.tabs{display:flex;gap:2px;overflow-x:auto;background:var(--film-2);padding:0 clamp(8px,4vw,24px);position:sticky;top:0;z-index:20;scrollbar-width:none}
.tabs::-webkit-scrollbar{display:none}
.tab{flex:0 0 auto;background:transparent;border:0;border-bottom:2px solid transparent;color:rgba(236,230,216,.6);font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;padding:14px 14px;cursor:pointer;white-space:nowrap}
.tab:hover{color:var(--on-film)}
.tab.is-active{color:var(--gold);border-bottom-color:var(--gold)}
.tab:focus-visible{outline:2px solid var(--gold);outline-offset:-2px}

.content{max-width:var(--maxw);margin:0 auto;padding:clamp(20px,5vw,34px) clamp(16px,5vw,24px) 60px}
.panel{display:none}
.panel.is-active{display:block;animation:fade .3s ease}
@keyframes fade{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}

/* ---------------- Overview ---------------- */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px}
.stat{background:var(--paper-2);border:1px solid var(--line);border-radius:var(--r);padding:18px}
.stat__num{font-family:var(--mono);font-weight:700;font-size:30px;line-height:1;color:var(--ink)}
.stat__num em{font-style:normal;color:var(--gold)}
.stat__label{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);margin-top:8px}
.stat__sub{font-size:12px;color:var(--ink-soft);margin-top:3px}
.stat--accent{background:var(--film);color:var(--on-film)}
.stat--accent .stat__num{color:var(--on-film)} .stat--accent .stat__label{color:rgba(236,230,216,.6)} .stat--accent .stat__sub{color:rgba(236,230,216,.55)}
.board{margin-top:26px}
.board__head{margin-bottom:10px}
.tables{list-style:none;margin:0;padding:0;display:grid;gap:6px}
.tables li{display:flex;align-items:center;justify-content:space-between;background:var(--paper-2);border:1px solid var(--line);border-radius:10px;padding:11px 14px;font-size:14px}
.tables .n{font-family:var(--mono);color:var(--gold);font-weight:700}

/* ---------------- Toolbar / segmented ---------------- */
.toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:18px}
.seg{display:inline-flex;background:var(--paper-2);border:1px solid var(--line);border-radius:999px;padding:3px}
.seg__btn{background:transparent;border:0;font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);padding:8px 14px;border-radius:999px;cursor:pointer}
.seg__btn.is-active{background:var(--ink);color:var(--paper)}
.seg__btn:focus-visible{outline:2px solid var(--gold);outline-offset:1px}

/* ---------------- Contact sheet (signature) ---------------- */
.sheet{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:14px}
.frame{position:relative;background:var(--film);border-radius:6px;padding:13px 8px 8px}
.frame::before,.frame::after{content:"";position:absolute;left:8px;right:8px;height:7px;background-image:radial-gradient(circle,var(--paper) 0 1.6px,transparent 2.2px);background-size:11px 7px;background-repeat:repeat-x;opacity:.85}
.frame::before{top:3px}.frame::after{bottom:42px}
.frame__num{position:absolute;top:13px;left:12px;font-family:var(--mono);font-size:10px;font-weight:700;color:var(--gold);background:rgba(0,0,0,.45);padding:1px 5px;border-radius:4px;z-index:2}
.frame__imgwrap{position:relative;border-radius:3px;overflow:hidden;background:var(--film-2)}
.frame__img{display:block;width:100%;aspect-ratio:1;object-fit:cover;cursor:zoom-in}
.frame__cap{display:flex;flex-direction:column;gap:1px;padding:7px 4px 2px;min-height:30px}
.frame__group{font-family:var(--mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--gold);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.frame__name{font-size:12px;color:var(--on-film);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.frame__acts{display:flex;gap:10px;padding:2px 4px 0}
.frame__act{background:none;border:0;padding:2px 0;font-family:var(--mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:rgba(236,230,216,.7);cursor:pointer}
.frame__act:hover{color:var(--on-film)}
.frame__act--danger:hover{color:var(--clay)}
.frame__act:focus-visible{outline:2px solid var(--gold);outline-offset:2px}
/* grease-pencil mark on hidden/flagged frames */
.frame__mark{position:absolute;inset:13px 8px 42px;pointer-events:none;z-index:3;display:none}
.frame__mark path{stroke:var(--clay);stroke-width:7;stroke-linecap:round;fill:none;opacity:.9;stroke-dasharray:240;stroke-dashoffset:240;animation:scratch .45s ease forwards}
@keyframes scratch{to{stroke-dashoffset:0}}
.frame.is-hidden .frame__img{filter:grayscale(1) brightness(.6)}
.frame.is-hidden .frame__mark{display:block}
.frame.is-flagged .frame__mark{display:block}
.frame.is-flagged .frame__mark path{stroke:var(--gold)}
.frame__badge{position:absolute;top:13px;right:12px;z-index:3;font-family:var(--mono);font-size:9px;letter-spacing:.08em;text-transform:uppercase;padding:2px 6px;border-radius:4px;background:var(--gold);color:var(--film)}

.empty{color:var(--ink-soft);text-align:center;font-size:14px;padding:40px 16px}
.btn--ghost.btn{margin:18px auto 0;display:block}

/* ---------------- Forms / cards ---------------- */
.form-card{max-width:560px;background:var(--paper-2);border:1px solid var(--line);border-radius:18px;padding:24px 22px;display:grid;gap:16px}
.card__title{font-family:var(--display);font-weight:500;font-size:24px;margin:2px 0 0}
.card__lead{font-size:14px;color:var(--ink-soft);margin:0}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.colorpick{display:flex;align-items:center;gap:8px}
.colorpick input[type=color]{width:46px;height:42px;border:1px solid var(--line);border-radius:10px;background:var(--paper);padding:3px;cursor:pointer}
.features__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:8px;margin-top:8px}
.feature{display:flex;align-items:center;gap:9px;background:var(--paper);border:1px solid var(--line);border-radius:10px;padding:10px 12px;font-size:13px;cursor:pointer}
.feature input{width:17px;height:17px;accent-color:var(--sage)}
.logo-row{display:flex;align-items:center;gap:14px}
.logo-preview{max-height:48px;max-width:120px;object-fit:contain;background:var(--paper);border:1px solid var(--line);border-radius:8px;padding:4px}
.file{font-family:var(--mono);font-size:12px}
.form-card__foot{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-top:4px}
.preview{display:inline-flex;gap:6px}
.preview__sw{width:26px;height:26px;border-radius:7px;border:1px solid rgba(0,0,0,.15)}

/* ---------------- Access + QR ---------------- */
.access-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;align-items:start}
.qr-card{text-align:center;justify-items:center}
.qr{width:200px;height:200px;background:#fff;border:1px solid var(--line);border-radius:12px;padding:12px;margin:4px auto}
.qr svg{width:100%;height:100%;display:block}
.qr__url{font-family:var(--mono);font-size:12px;word-break:break-all;color:var(--ink);margin:0}
.qr__code{font-family:var(--mono);font-size:15px;letter-spacing:.2em;text-transform:uppercase;color:var(--clay);margin:0}

/* ---------------- Activity ---------------- */
.feed{list-style:none;margin:0;padding:0;display:grid;gap:2px;max-width:620px}
.feed li{display:flex;align-items:baseline;gap:14px;padding:12px 4px;border-bottom:1px solid var(--line)}
.feed__dot{flex:0 0 auto;width:8px;height:8px;border-radius:50%;background:var(--sage);transform:translateY(-1px)}
.feed__dot--gold{background:var(--gold)} .feed__dot--clay{background:var(--clay)}
.feed__txt{flex:1;font-size:14px}
.feed__time{font-family:var(--mono);font-size:11px;color:var(--ink-soft);white-space:nowrap}

/* ---------------- Guestbook ---------------- */
.gblist{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}
.gbcard{background:var(--paper-2);border:1px solid var(--line);border-radius:14px;padding:14px;display:grid;gap:10px}
.gbcard.is-hidden{opacity:.6}
.gbcard.is-flagged{border-color:var(--gold)}
.gbcard__top{display:flex;align-items:center;gap:8px}
.gbcard__kind{font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft)}
.gbcard__badge{font-family:var(--mono);font-size:9px;letter-spacing:.08em;text-transform:uppercase;padding:2px 6px;border-radius:4px;background:var(--gold);color:var(--film)}
.gbcard__badge--muted{background:var(--line);color:var(--ink-soft)}
.gbcard__time{margin-left:auto;font-family:var(--mono);font-size:11px;color:var(--ink-soft)}
.gbcard__media{width:100%;display:block;border-radius:8px;background:var(--film)}
.gbcard__media--audio{height:42px}
.gbcard video.gbcard__media{aspect-ratio:16/9;object-fit:cover}
.gbcard__foot{display:flex;align-items:flex-end;justify-content:space-between;gap:10px}
.gbcard__who{display:flex;flex-direction:column;gap:1px;min-width:0}
.gbcard__group{font-family:var(--mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--gold);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.gbcard__name{font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.gbcard__acts{display:flex;gap:10px;flex:0 0 auto}
.gbcard__act{background:none;border:0;padding:2px 0;font-family:var(--mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-soft);cursor:pointer}
.gbcard__act:hover{color:var(--ink)}
.gbcard__act--danger:hover{color:var(--clay)}
.gbcard__act:focus-visible{outline:2px solid var(--gold);outline-offset:2px}

.lightbox{position:fixed;inset:0;background:rgba(15,14,12,.95);z-index:60;display:grid;place-items:center;padding:20px}
.lightbox__img{max-width:100%;max-height:88vh;border-radius:8px;object-fit:contain}
.lightbox__close{position:absolute;top:14px;right:14px;width:42px;height:42px;border-radius:50%;border:0;background:rgba(255,255,255,.12);color:#fff;font-size:18px;cursor:pointer}
.lightbox__close:focus-visible{outline:3px solid var(--gold)}
.toast{position:fixed;left:50%;transform:translateX(-50%);bottom:max(20px,env(safe-area-inset-bottom));background:var(--ink);color:var(--paper);font-family:var(--mono);font-size:12px;letter-spacing:.02em;padding:12px 18px;border-radius:999px;box-shadow:0 12px 30px -12px rgba(0,0,0,.5);z-index:80;transition:opacity .25s ease;max-width:88vw;text-align:center}
.toast--err{background:var(--clay)}

@media (max-width:720px){
  .row2,.access-grid{grid-template-columns:1fr}
}
@media print{
  body{background:#fff}
  body *{visibility:hidden}
  #qrCard,#qrCard *{visibility:visible}
  #qrCard{position:absolute;inset:0;border:0;background:#fff}
  .no-print{display:none}
}
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important}
}

/* ---- Photo challenges (scavenger hunt) editor ---- */
.card__lead{color:var(--ink-soft);font-size:14px;margin:0 0 16px;line-height:1.5}
.muted{color:var(--ink-soft);font-family:var(--mono);font-size:12px}
.toggle{display:flex;align-items:center;gap:10px;margin:2px 0 16px;font-size:14px;cursor:pointer}
.toggle input{width:18px;height:18px;accent-color:var(--gold);flex:none}
.promptlist{display:flex;flex-direction:column;gap:8px;margin:8px 0 12px}
.promptrow{display:flex;align-items:center;gap:8px}
.promptrow__text{flex:1;min-width:0}
.promptrow__count{flex:none;min-width:26px;height:26px;padding:0 7px;border-radius:999px;background:var(--gold);color:#1B1A16;font-family:var(--mono);font-size:12px;font-weight:700;display:inline-flex;align-items:center;justify-content:center}
.promptrow__del{flex:none;width:30px;height:30px;border-radius:8px;border:1px solid var(--line);background:var(--paper);color:var(--ink-soft);font-size:18px;line-height:1;cursor:pointer}
.promptrow__del:hover{border-color:var(--clay);color:var(--clay)}

/* ---- Guests (RSVP + seating) ---- */
.rsvpstats{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:16px}
@media(min-width:560px){.rsvpstats{grid-template-columns:repeat(4,1fr)}}
.seg--full{display:flex;width:100%;margin-bottom:16px}
.seg--full .seg__btn{flex:1;text-align:center}
.addrow{display:flex;gap:8px;align-items:center;margin-bottom:14px;flex-wrap:wrap}
.addrow #gaName{flex:1 1 160px}
.addrow__party{width:64px;flex:none;text-align:center}
.addrow__table{width:96px;flex:none}
.toolbar--rsvp{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:14px}
.rsvp-search{flex:1 1 160px}
.guestlist{display:flex;flex-direction:column;gap:10px}
.guest{border:1px solid var(--line);border-radius:14px;background:var(--paper-2);padding:12px;transition:box-shadow .3s ease,border-color .3s ease}
.guest--saved{border-color:var(--gold);box-shadow:0 0 0 2px rgba(200,162,76,.25)}
.guest__top{display:flex;gap:8px;align-items:center;margin-bottom:8px}
.guest__name{flex:1;font-weight:600}
.guest__del{flex:none;width:32px;height:32px;border-radius:8px;border:1px solid var(--line);background:var(--paper);color:var(--ink-soft);font-size:18px;line-height:1;cursor:pointer}
.guest__del:hover{border-color:var(--clay);color:var(--clay)}
.guest__row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.seg--mini{display:inline-flex;flex:1 1 auto}
.seg--mini .seg__btn{padding:8px 10px;font-size:11px;flex:1;text-align:center}
.guest__party{width:60px;flex:none;text-align:center}
.guest__table{width:96px;flex:none}
.seating{display:grid;grid-template-columns:1fr;gap:12px}
@media(min-width:560px){.seating{grid-template-columns:repeat(2,1fr)}}
.seatcard{border:1px solid var(--line);border-radius:14px;background:var(--paper-2);padding:14px}
.seatcard--un{background:var(--paper-3);border-style:dashed}
.seatcard__head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:8px}
.seatcard__label{font-family:var(--display);font-weight:600;font-size:17px}
.seatcard__count{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft)}
.seatcard__guests{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:5px}
.seatcard__guests li{font-size:14px;color:var(--ink);padding-left:14px;position:relative}
.seatcard__guests li::before{content:"";position:absolute;left:0;top:8px;width:5px;height:5px;border-radius:50%;background:var(--gold)}

/* ---- Planning (tasks + vendors) ---- */
.planstats{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:16px}
@media(min-width:560px){.planstats{grid-template-columns:repeat(4,1fr)}}
.addrow__cat{width:120px;flex:none}
.addrow__due{width:150px;flex:none}
.tasklist,.vendorlist{display:flex;flex-direction:column;gap:10px;margin-top:4px}
.task,.vendor{border:1px solid var(--line);border-radius:14px;background:var(--paper-2);padding:12px;transition:box-shadow .3s ease,border-color .3s ease}
.row--saved{border-color:var(--gold);box-shadow:0 0 0 2px rgba(200,162,76,.25)}
.task--done{opacity:.6}
.task--done .task__desc{text-decoration:line-through}
.task__top,.vendor__top{display:flex;gap:8px;align-items:center;margin-bottom:8px}
.task__desc,.vendor__name{flex:1;font-weight:600}
.rowdel{flex:none;width:32px;height:32px;border-radius:8px;border:1px solid var(--line);background:var(--paper);color:var(--ink-soft);font-size:18px;line-height:1;cursor:pointer}
.rowdel:hover{border-color:var(--clay);color:var(--clay)}
.task__row,.vendor__row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.task__status{width:108px;flex:none}
.task__cat{flex:1 1 100px;min-width:90px}
.task__due{width:150px;flex:none}
.task__due.is-overdue{border-color:var(--clay);color:var(--clay);font-weight:600}
.task__vendor{flex:1 1 130px;min-width:120px}
.vendor__type{width:130px;flex:none}
.vendor__email{flex:1 1 160px;min-width:140px}
.vendor__phone{width:130px;flex:none}
select.field__input{appearance:auto;-webkit-appearance:menulist;background:var(--paper);cursor:pointer}
