/* ============================================================
   HAUS OF MOMENTS — studio (admin) · builds on styles.css tokens
   ============================================================ */
body{overflow-x:hidden}
.admin{display:grid;grid-template-columns:252px 1fr;min-height:100vh}

/* ---------- sidebar ---------- */
.a-side{position:sticky;top:0;height:100vh;background:var(--bg-inv);color:var(--fg-inv);
  display:flex;flex-direction:column;padding:26px 20px;border-right:1px solid var(--line-inv);transition:background-color .9s ease,color .9s ease}
.a-brand{font-family:var(--serif);font-weight:500;font-size:30px;letter-spacing:.12em;color:var(--fg-inv);
  text-decoration:none;display:flex;align-items:center;gap:8px;padding:6px 10px 22px}
.a-brand .tw-svg{width:13px;height:13px;color:var(--rose)}
.a-brand small{font-family:var(--sans);font-size:9px;letter-spacing:.34em;text-transform:uppercase;color:var(--muted-inv);margin-left:2px;align-self:flex-end;margin-bottom:9px}
.a-nav{display:flex;flex-direction:column;gap:3px;margin-top:8px}
.a-nav button{display:flex;align-items:center;gap:13px;width:100%;text-align:left;background:none;border:none;
  cursor:pointer;font-family:var(--sans);font-size:13px;letter-spacing:.04em;color:var(--muted-inv);
  padding:13px 14px;border-radius:8px;transition:.35s}
.a-nav button .ic{width:17px;height:17px;flex:none;opacity:.85}
.a-nav button:hover{background:rgba(200,162,156,.12);color:var(--fg-inv)}
.a-nav button.active{background:var(--rose);color:var(--ink)}
.a-nav button.active .ic{opacity:1}
.a-side__foot{margin-top:auto;border-top:1px solid var(--line-inv);padding-top:16px;display:flex;align-items:center;gap:12px}
.a-avatar{width:38px;height:38px;border-radius:50%;background:var(--rose);color:var(--ink);display:grid;place-items:center;font-family:var(--serif);font-size:16px;flex:none}
.a-side__foot .who{font-size:12.5px;line-height:1.3}.a-side__foot .who span{display:block;color:var(--muted-inv);font-size:10.5px}
.a-side__foot a{margin-left:auto;color:var(--muted-inv);font-size:11px;text-decoration:none}
.a-side__foot a:hover{color:var(--rose)}

/* ---------- main ---------- */
.a-main{min-width:0;background:var(--bg);transition:background-color .9s ease}
.a-top{position:sticky;top:0;z-index:30;display:flex;align-items:center;gap:18px;padding:18px clamp(20px,3vw,40px);
  background:color-mix(in srgb,var(--bg) 86%,transparent);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.a-top h1{font-family:var(--serif);font-weight:400;font-size:27px;line-height:1}
.a-top .sub{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-top:3px}
.a-spacer{margin-left:auto}
.a-search{display:flex;align-items:center;gap:9px;background:var(--card);border:1px solid var(--line);border-radius:30px;padding:9px 16px;width:230px;max-width:34vw}
.a-search input{border:none;background:none;outline:none;font-family:var(--sans);font-size:13px;color:var(--fg);width:100%}
.a-search .ic{width:15px;height:15px;color:var(--muted);flex:none}
.a-content{padding:clamp(20px,3vw,38px)}
.a-sec{display:none;animation:afade .5s ease}
.a-sec.active{display:block}
@keyframes afade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.a-row{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;flex-wrap:wrap;margin:0 0 20px}
.a-row h2{font-family:var(--serif);font-weight:400;font-size:24px}
.a-muted{color:var(--muted);font-size:13px}

/* ---------- kpi ---------- */
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:26px}
@media(max-width:1080px){.kpis{grid-template-columns:repeat(2,1fr)}}
.kpi{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:22px 24px}
.kpi .l{font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);display:flex;align-items:center;gap:7px}
.kpi .l .tw-svg{width:11px;height:11px;color:var(--rose)}
.kpi b{font-family:var(--serif);font-weight:400;font-size:42px;line-height:1.05;display:block;margin-top:10px}
.kpi .d{font-size:11.5px;margin-top:6px;color:var(--sage)}
.kpi .d.flat{color:var(--muted)}

/* ---------- cards / charts ---------- */
.cards2{display:grid;grid-template-columns:1.5fr 1fr;gap:16px;margin-bottom:26px}
@media(max-width:1080px){.cards2{grid-template-columns:1fr}}
.card{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:22px 24px}
.card h3{font-family:var(--serif);font-weight:400;font-size:19px;margin-bottom:4px}
.card .cap{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:18px}
canvas{display:block;width:100%}
.legend{display:flex;gap:16px;flex-wrap:wrap;margin-top:14px;font-size:11.5px;color:var(--muted)}
.legend i{display:inline-block;width:10px;height:10px;border-radius:3px;margin-right:6px;vertical-align:-1px}

/* fill bars (signups by event) */
.fills{display:flex;flex-direction:column;gap:14px}
.fill .t{display:flex;justify-content:space-between;font-size:13px;margin-bottom:7px}
.fill .t span:last-child{color:var(--muted);font-size:12px}
.fill .track{height:7px;border-radius:6px;background:var(--bg-2);overflow:hidden}
.fill .bar{height:100%;border-radius:6px;background:var(--rose);width:0;transition:width 1.1s cubic-bezier(.22,.61,.36,1)}

/* ---------- table ---------- */
.tbl-wrap{background:var(--card);border:1px solid var(--line);border-radius:12px;overflow-x:auto}
.tbl{width:100%;border-collapse:collapse;font-size:13.5px}
.tbl th{text-align:left;font-family:var(--sans);font-weight:400;font-size:10px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--muted);padding:15px 18px;border-bottom:1px solid var(--line);white-space:nowrap}
.tbl td{padding:15px 18px;border-bottom:1px solid var(--line);vertical-align:middle}
.tbl tr:last-child td{border-bottom:none}
.tbl tbody tr{transition:background .3s;cursor:default}
.tbl tbody tr:hover{background:var(--bg-2)}
.tbl .name{font-family:var(--serif);font-size:16px}
.tbl .sub{color:var(--muted);font-size:12px}
.tbl .num{font-variant-numeric:tabular-nums;font-family:var(--sans)}
.row-click{cursor:pointer}
.tbl-foot{display:flex;justify-content:space-between;align-items:center;padding:14px 18px;font-size:12px;color:var(--muted)}

/* pills */
.pill{display:inline-flex;align-items:center;gap:6px;font-family:var(--sans);font-size:10.5px;letter-spacing:.08em;
  text-transform:uppercase;padding:5px 11px;border-radius:30px;white-space:nowrap}
.pill--ok{background:var(--sage);color:#1d2415}
.pill--rose{background:var(--rose);color:var(--ink)}
.pill--muted{background:var(--taupe);color:#2c2620}
.pill--warn{background:#d8a45e;color:#3a2a12}
.pill--bad{background:#cf938b;color:#3c1714}
.pill--ink{background:var(--ink);color:var(--cream)}
.src{font-size:11.5px;color:var(--muted);display:inline-flex;align-items:center;gap:6px}
.dot{width:7px;height:7px;border-radius:50%;display:inline-block}

/* segmented toggle */
.seg{display:inline-flex;background:var(--bg-2);border-radius:30px;padding:4px;gap:3px}
.seg button{font-family:var(--sans);font-size:11.5px;letter-spacing:.08em;border:none;background:none;color:var(--muted);
  padding:9px 18px;border-radius:30px;cursor:pointer;transition:.35s}
.seg button.active{background:var(--fg);color:var(--bg)}
.a-select{font-family:var(--sans);font-size:13px;color:var(--fg);background:var(--card);border:1px solid var(--line);
  border-radius:30px;padding:9px 16px;cursor:pointer;appearance:none}

/* ---------- kanban ---------- */
.kb-meta{font-size:12.5px;color:var(--muted);margin:0 0 16px}
.kb-wrap{display:flex;gap:14px;overflow-x:auto;padding:4px 4px 18px}
.kb-col{flex:0 0 274px;background:var(--bg-2);border:1px solid var(--line);border-radius:12px;display:flex;flex-direction:column;max-height:74vh}
.kb-col.drag-over{border-color:var(--rose);background:color-mix(in srgb,var(--rose) 12%,var(--bg-2))}
.kb-col__head{display:flex;align-items:center;justify-content:space-between;padding:15px 16px 10px}
.kb-col__head .h{font-family:var(--sans);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--fg);display:flex;align-items:center;gap:8px}
.kb-col__head .ct{font-size:11px;color:var(--muted);background:var(--card);border:1px solid var(--line);border-radius:20px;padding:2px 9px}
.kb-col__body{padding:6px 12px 14px;overflow-y:auto;display:flex;flex-direction:column;gap:10px;flex:1}
.kb-card{background:var(--card);border:1px solid var(--line);border-radius:10px;padding:14px;cursor:grab;
  transition:box-shadow .3s,transform .3s,border-color .3s}
.kb-card:hover{border-color:var(--rose);box-shadow:0 14px 30px -22px rgba(34,30,26,.5)}
.kb-card.dragging{opacity:.45;cursor:grabbing}
.kb-card .nm{font-family:var(--serif);font-size:17px;line-height:1.1}
.kb-card .em{font-size:11.5px;color:var(--muted);margin-top:2px;word-break:break-all}
.kb-card .ev{font-size:12px;margin-top:9px;color:var(--fg)}
.kb-card .ev b{color:var(--rose);font-weight:400}
.kb-card .ft{display:flex;align-items:center;justify-content:space-between;margin-top:11px}
.kb-card .val{font-family:var(--serif);font-size:15px}

/* ---------- modal / drawer ---------- */
.amodal{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;padding:22px;
  opacity:0;visibility:hidden;transition:.45s}
.amodal.open{opacity:1;visibility:visible}
.amodal__scrim{position:absolute;inset:0;background:rgba(20,17,14,.55);backdrop-filter:blur(5px)}
.amodal__card{position:relative;width:min(680px,96vw);max-height:92vh;overflow:auto;background:var(--bg);
  border:1px solid var(--line);border-radius:14px;padding:clamp(24px,3vw,38px);transform:translateY(20px) scale(.98);transition:.5s cubic-bezier(.22,.61,.36,1)}
.amodal.open .amodal__card{transform:none}
.amodal__card h2{font-family:var(--serif);font-weight:400;font-size:30px;margin-bottom:4px}
.amodal__card .cap{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:24px}

.drawer{position:fixed;inset:0 0 0 auto;width:min(440px,94vw);z-index:200;background:var(--bg);border-left:1px solid var(--line);
  transform:translateX(100%);transition:transform .55s cubic-bezier(.22,.61,.36,1);overflow-y:auto;padding:30px clamp(22px,2.4vw,32px)}
.drawer.open{transform:none;box-shadow:-30px 0 80px -50px rgba(34,30,26,.6)}
.drawer__scrim{position:fixed;inset:0;background:rgba(20,17,14,.4);z-index:199;opacity:0;visibility:hidden;transition:.45s}
.drawer__scrim.open{opacity:1;visibility:visible}
.drawer__close{position:absolute;top:18px;right:18px;width:36px;height:36px;border-radius:50%;border:1px solid var(--line);
  background:none;color:var(--fg);cursor:pointer;transition:.4s}
.drawer__close:hover{border-color:var(--rose);color:var(--rose);transform:rotate(90deg)}
.drawer .big{width:64px;height:64px;border-radius:50%;background:var(--rose);color:var(--ink);display:grid;place-items:center;font-family:var(--serif);font-size:26px;margin-bottom:16px}
.drawer h2{font-family:var(--serif);font-weight:400;font-size:28px}
.drawer .deet{display:flex;justify-content:space-between;gap:14px;padding:13px 0;border-bottom:1px solid var(--line);font-size:13.5px}
.drawer .deet .k{color:var(--muted);font-size:11px;letter-spacing:.14em;text-transform:uppercase}
.drawer__stage{margin-top:22px}
.drawer__stage label{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);display:block;margin-bottom:10px}

.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:560px){.form-grid{grid-template-columns:1fr}}
.full{grid-column:1/-1}

/* ---------- gate ---------- */
.gate{position:fixed;inset:0;z-index:500;display:flex;align-items:center;justify-content:center;padding:24px;
  background:var(--bg)}
.gate__card{width:min(400px,100%);text-align:center}
.gate__mark{font-family:var(--serif);font-weight:500;font-size:54px;letter-spacing:.1em;display:inline-flex;align-items:center;gap:8px}
.gate__mark .tw-svg{width:18px;height:18px;color:var(--rose)}
.gate__card .cap{font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--muted);margin:8px 0 30px}
.gate__card .input{margin-bottom:14px;text-align:center}

/* mobile */
@media(max-width:900px){
  .admin{grid-template-columns:1fr}
  .a-side{position:static;height:auto;flex-direction:row;align-items:center;gap:10px;overflow-x:auto;padding:14px}
  .a-brand{padding:0 8px 0 4px;font-size:24px}.a-brand small{display:none}
  .a-nav{flex-direction:row;margin-top:0;gap:4px}
  .a-nav button{padding:10px 13px;white-space:nowrap;font-size:12px}.a-nav button .ic{display:none}
  .a-side__foot{display:none}
  .a-search{display:none}
  .tbl{min-width:560px}
}


/* ---------- marketing studio ---------- */
.mkt{display:grid;grid-template-columns:360px 1fr;gap:28px;align-items:start}
.mkt__controls{display:flex;flex-direction:column;gap:18px}
.mkt__preview{position:sticky;top:24px;display:flex;justify-content:center;padding:20px;background:var(--card,#fff);border:1px solid rgba(140,124,105,.18);border-radius:18px}
.mk-field{display:flex;flex-direction:column;gap:8px}
.mk-label{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted,#8c7c69)}
.mk-seg{display:flex;gap:6px}
.mk-seg button{flex:1}
.mk-photo{display:flex;gap:12px;align-items:flex-start}
.mk-thumb{width:62px;height:62px;border-radius:10px;background:#E8DFD0 center/cover no-repeat;border:1px solid rgba(140,124,105,.25);flex:none}
.mk-hint{font-size:11px;color:var(--muted,#8c7c69);margin-top:7px}
.mk-actions{margin-top:2px}
.mk-copyhead{display:flex;justify-content:space-between;align-items:center}
.mk-copy{background:none;border:none;color:var(--rose,#C8A29C);font-family:inherit;font-size:11px;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;padding:4px}
.mk-text{font-family:ui-monospace,Menlo,Consolas,monospace;font-size:12px;line-height:1.5;white-space:pre-wrap;resize:vertical}
.mk-stagewrap{display:flex;justify-content:center;min-height:320px;align-items:center}
.mk-loading{color:var(--muted,#8c7c69);font-size:13px}
@media(max-width:900px){.mkt{grid-template-columns:1fr}.mkt__preview{position:static;order:-1}}
