/* ============================================================
   Atkinson Proposals — admin UI
   Token-driven theme system. html[data-theme="dark"|"light"]
   ============================================================ */

:root{
  /* type */
  --font-ui:'Inter',system-ui,-apple-system,sans-serif;
  --font-display:'Archivo',var(--font-ui);
  --fs-0:.6875rem;   /* 11px labels */
  --fs-1:.8125rem;   /* 13px body   */
  --fs-2:.875rem;    /* 14px        */
  --fs-3:1rem;
  --fs-4:1.125rem;   /* 18px h1     */
  /* shape + motion */
  --r-s:6px; --r-m:8px; --r-l:12px;
  --t-fast:130ms cubic-bezier(.4,0,.2,1);
  --t-med:200ms cubic-bezier(.4,0,.2,1);
}

html[data-theme="dark"]{
  color-scheme:dark;
  --bg:#131416;            /* app canvas        */
  --bg-raised:#1B1D20;     /* cards             */
  --bg-sunken:#0E0F11;     /* topbar, wells     */
  --bg-overlay:#202327;    /* modals, popovers  */
  --field:#101214;         /* input rest        */
  --field-hover:#15171A;
  --field-focus:#0C0D0F;
  --hover:rgba(233,234,236,.045);
  --text:#E9EAEC;
  --text-2:#9BA0A7;
  --text-3:#61656C;
  --accent:#C7CDD4;        /* brand steel       */
  --accent-hover:#DDE1E6;
  --accent-ink:#15161A;
  --border:rgba(233,234,236,.07);
  --border-strong:rgba(233,234,236,.16);
  --ring:rgba(199,205,212,.22);
  --ok:#79B38D; --ok-bg:rgba(121,179,141,.1);
  --warn:#C9A86A;
  --danger:#CE8484; --danger-strong:#A75454; --danger-bg:rgba(206,132,132,.09);
  --shadow-card:0 1px 2px rgba(0,0,0,.25);
  --shadow-pop:0 4px 12px rgba(0,0,0,.35),0 24px 64px -12px rgba(0,0,0,.5);
  --shadow-lift:0 6px 16px -6px rgba(0,0,0,.45);
  --shine:rgba(255,255,255,.22);
  --scrim:rgba(8,9,10,.72);
}
html[data-theme="light"]{
  color-scheme:light;
  --bg:#F4F4F3;
  --bg-raised:#FFFFFF;
  --bg-sunken:#ECECEB;
  --bg-overlay:#FFFFFF;
  --field:#F0F0EF;
  --field-hover:#EAEAE8;
  --field-focus:#FFFFFF;
  --hover:rgba(28,30,34,.04);
  --text:#1C1E22;
  --text-2:#5D6269;
  --text-3:#9AA0A7;
  --accent:#26292E;        /* graphite — dark fills on light  */
  --accent-hover:#3A3E45;
  --accent-ink:#F6F6F5;
  --border:rgba(28,30,34,.1);
  --border-strong:rgba(28,30,34,.22);
  --ring:rgba(38,41,46,.14);
  --ok:#3E7E55; --ok-bg:rgba(62,126,85,.08);
  --warn:#8A6F35;
  --danger:#A14A4A; --danger-strong:#8A3B3B; --danger-bg:rgba(161,74,74,.07);
  --shadow-card:0 1px 2px rgba(20,22,26,.05),0 1px 1px rgba(20,22,26,.03);
  --shadow-pop:0 4px 16px rgba(20,22,26,.1),0 24px 64px -12px rgba(20,22,26,.18);
  --shadow-lift:0 6px 16px -8px rgba(20,22,26,.25);
  --shine:rgba(255,255,255,.5);
  --scrim:rgba(28,30,34,.45);
}

/* legacy aliases still referenced by older markup */
:root{--midnight:var(--bg);--bronze:var(--accent);--ivory:var(--text);--mist:var(--text-2);--onyx:var(--bg-sunken);--ember:var(--bg-raised)}

/* ---------------- base ---------------- */
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:var(--font-ui); font-size:var(--fs-1); line-height:1.55;
  background:var(--bg); color:var(--text);
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  min-height:100vh;
  transition:background-color var(--t-med),color var(--t-med);
}
h1{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.07em;font-weight:600;font-size:var(--fs-4);margin:0}
h2{font-size:var(--fs-3);margin:0 0 .5rem}
a{color:var(--text);text-decoration:none;transition:color var(--t-fast)}
a:hover{color:var(--accent)}
html[data-theme="light"] a:hover{color:var(--accent-hover)}
code{background:var(--field);border:1px solid var(--border);border-radius:4px;padding:.1em .4em;font-size:.85em}
.muted{color:var(--text-2)}
.small{font-size:var(--fs-1)}
.num,.it-cost,.ms-pct,.ct-input,.tl-start,.tl-len{font-variant-numeric:tabular-nums}
::selection{background:var(--ring)}
:focus{outline:none}
:focus-visible{outline:2px solid var(--border-strong);outline-offset:2px;border-radius:4px}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{transition-duration:.01ms!important;animation-duration:.01ms!important}}
*{scrollbar-width:thin;scrollbar-color:var(--border-strong) transparent}
*::-webkit-scrollbar{width:10px;height:10px}
*::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:8px;border:3px solid transparent;background-clip:content-box}
*::-webkit-scrollbar-track{background:transparent}

/* ---------------- top bar ---------------- */
.topbar{
  position:sticky;top:0;z-index:40;
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
  height:52px;padding:0 1.25rem;
  background:color-mix(in srgb,var(--bg-sunken) 88%,transparent);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid var(--border);
}
.bar-left{display:flex;align-items:center;gap:1.75rem;min-width:0}
.brand,.brand-lg{font-family:var(--font-display);letter-spacing:.22em;font-weight:600;color:var(--text)}
.brand{font-size:.85rem;white-space:nowrap}
.brand span,.brand-lg span{color:var(--text-2)}
.brand:hover{color:var(--text)}
.mainnav{display:flex;gap:.25rem}
.mainnav a{
  color:var(--text-2);font-size:var(--fs-0);text-transform:uppercase;letter-spacing:.11em;
  padding:.45rem .7rem;border-radius:var(--r-s);transition:color var(--t-fast),background var(--t-fast);
}
.mainnav a:hover{color:var(--text);background:var(--hover);text-decoration:none}
.bar-right{display:flex;align-items:center;gap:.85rem}
.who{color:var(--text-3);font-size:var(--fs-0);text-transform:uppercase;letter-spacing:.1em;white-space:nowrap}

/* theme toggle */
.theme-toggle{
  display:inline-flex;align-items:center;justify-content:center;
  width:30px;height:30px;border-radius:var(--r-s);
  background:transparent;border:1px solid transparent;color:var(--text-2);cursor:pointer;
  transition:color var(--t-fast),background var(--t-fast),border-color var(--t-fast);
}
.theme-toggle:hover{color:var(--text);background:var(--hover);border-color:var(--border)}
.theme-toggle svg{width:15px;height:15px;display:block}
html[data-theme="dark"] .tt-sun{display:none}
html[data-theme="light"] .tt-moon{display:none}

/* ---------------- layout ---------------- */
main.wrap{max-width:1020px;margin:0 auto;padding:2.25rem 1.5rem 4rem}
main.center{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1.5rem}
.head,.page-head{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem;flex-wrap:wrap}
.head h1,.page-head h1{margin-right:auto}
.head p,.page-head p{flex-basis:100%;margin:0;max-width:60ch}
.flash{
  max-width:1020px;margin:1rem auto -.75rem;padding:.6rem .9rem;
  display:flex;align-items:center;gap:.5rem;
  background:var(--ok-bg);border:1px solid color-mix(in srgb,var(--ok) 35%,transparent);
  border-radius:var(--r-m);color:var(--text);font-size:var(--fs-1);
  animation:flash-in var(--t-med) both;
}
@keyframes flash-in{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}

/* ---------------- buttons ---------------- */
.btn,button[type=submit]{
  display:inline-flex;align-items:center;gap:.4rem;
  background:var(--accent);color:var(--accent-ink);
  font-family:var(--font-display);text-transform:uppercase;letter-spacing:.1em;
  font-weight:600;font-size:var(--fs-0);
  height:34px;padding:0 1rem;border:0;border-radius:var(--r-s);
  cursor:pointer;white-space:nowrap;
  transition:background var(--t-fast),transform var(--t-fast),box-shadow var(--t-fast);
}
.btn:hover,button[type=submit]:hover{background:var(--accent-hover);color:var(--accent-ink);text-decoration:none}
.btn:active,button[type=submit]:active{transform:translateY(1px)}
.btn-soft{
  display:inline-flex;align-items:center;gap:.4rem;
  background:transparent;color:var(--text);
  border:1px solid var(--border-strong);border-radius:var(--r-s);
  height:32px;padding:0 .85rem;
  font-family:var(--font-ui);font-size:var(--fs-1);font-weight:500;letter-spacing:0;text-transform:none;
  cursor:pointer;white-space:nowrap;
  transition:background var(--t-fast),border-color var(--t-fast),color var(--t-fast);
}
.btn-soft:hover{background:var(--hover);border-color:var(--text-3)}
.btn-soft.small{height:27px;padding:0 .65rem;font-size:var(--fs-0)}
.btn-ghost{
  display:inline-flex;align-items:center;background:none;border:0;cursor:pointer;
  color:var(--text-2);font-size:var(--fs-0);text-transform:uppercase;letter-spacing:.11em;
  padding:.4rem .55rem;border-radius:var(--r-s);
  transition:color var(--t-fast),background var(--t-fast);
}
.btn-ghost:hover{color:var(--text);background:var(--hover);text-decoration:none}
.link,.row-actions a{
  background:none;border:0;cursor:pointer;padding:0;
  color:var(--text-2);font-size:var(--fs-1);font-family:var(--font-ui);
  transition:color var(--t-fast);
}
.link:hover,.row-actions a:hover{color:var(--text);text-decoration:none}
.link-danger{background:none;border:0;color:var(--danger);cursor:pointer;font-size:var(--fs-0);
  text-transform:uppercase;letter-spacing:.09em;padding:.2rem .3rem;border-radius:4px;
  transition:color var(--t-fast),background var(--t-fast)}
.link-danger:hover{color:var(--danger-strong);background:var(--danger-bg)}
html[data-theme="dark"] .link-danger:hover{color:#E0A1A1}
.btn-danger{
  background:transparent;border:1px solid color-mix(in srgb,var(--danger) 50%,transparent);
  color:var(--danger);border-radius:var(--r-s);height:32px;padding:0 .9rem;
  display:inline-flex;align-items:center;font-size:var(--fs-0);text-transform:uppercase;letter-spacing:.09em;
  cursor:pointer;transition:background var(--t-fast),color var(--t-fast),border-color var(--t-fast);
}
.btn-danger:hover{background:var(--danger-strong);border-color:var(--danger-strong);color:#fff}
.btn-danger.small{height:27px;padding:0 .65rem}
.icon-btn{
  display:inline-flex;align-items:center;justify-content:center;
  width:27px;height:27px;flex:0 0 27px;
  background:transparent;border:1px solid transparent;border-radius:var(--r-s);
  color:var(--text-3);cursor:pointer;font-size:.95rem;line-height:1;
  transition:color var(--t-fast),background var(--t-fast),border-color var(--t-fast);
}
.icon-btn:hover{color:var(--danger);background:var(--danger-bg);border-color:transparent}

/* ---------------- fields ---------------- */
label{font-size:var(--fs-0)}
input,textarea,select{
  font-family:var(--font-ui);font-size:var(--fs-2);color:var(--text);
  background:var(--field);border:1px solid transparent;border-radius:var(--r-s);
  padding:.5rem .65rem;
  transition:background var(--t-fast),border-color var(--t-fast),box-shadow var(--t-fast);
}
input:hover,textarea:hover,select:hover{background:var(--field-hover)}
input:focus,textarea:focus,select:focus{
  background:var(--field-focus);border-color:var(--border-strong);
  box-shadow:0 0 0 3px var(--ring);outline:none;
}
input::placeholder,textarea::placeholder{color:var(--text-3)}
textarea{resize:vertical;line-height:1.5}
select{cursor:pointer;appearance:none;-webkit-appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' fill='none' stroke='%23898E95' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right .6rem center;padding-right:1.8rem}

/* generic stacked label+field */
.form label,.module-card label,.ed-card label,.invite-form label,.ai-card label,.card.login label{
  display:flex;flex-direction:column;gap:.35rem;margin-bottom:1rem;
  font-size:var(--fs-0);font-weight:500;text-transform:uppercase;letter-spacing:.09em;color:var(--text-2);
}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:0 1.25rem}
.grid3{display:grid;grid-template-columns:1.4fr 1.4fr .8fr;gap:0 1.25rem}
.grid2>*,.grid3>*{min-width:0}
.grid2 input,.grid2 select,.grid2 textarea,
.grid3 input,.grid3 select,.grid3 textarea{width:100%;min-width:0}
.ed-card input,.ed-card select,.ed-card textarea,
.module-card input,.module-card select,.module-card textarea{max-width:100%}

/* ---------------- cards ---------------- */
.card,.ed-card,.module-card,.empty,.ai-card{
  background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--r-l);
  box-shadow:var(--shadow-card);
}
.card.form{max-width:540px;padding:1.75rem}
.empty{padding:3.5rem 2rem;text-align:center}
.empty p{margin:.25rem 0}

/* ---------------- dashboard table ---------------- */
table.list{
  width:100%;border-collapse:separate;border-spacing:0;
  background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--r-l);
  overflow:hidden;box-shadow:var(--shadow-card);
}
table.list th,table.list td{text-align:left;padding:.7rem 1rem;font-size:var(--fs-1)}
table.list th{
  font-family:var(--font-ui);font-weight:500;text-transform:uppercase;letter-spacing:.09em;
  font-size:var(--fs-0);color:var(--text-3);
  background:var(--bg-sunken);border-bottom:1px solid var(--border);
}
table.list td{border-bottom:1px solid var(--border)}
table.list tbody tr{transition:background var(--t-fast)}
table.list tbody tr:hover{background:var(--hover)}
table.list tr:last-child td{border-bottom:0}
table.list td:first-child a{font-weight:500}
.row-actions{display:flex;align-items:center;gap:.9rem;justify-content:flex-end;white-space:nowrap}
.row-actions a,.row-actions .link{font-size:var(--fs-1);opacity:.75;transition:opacity var(--t-fast),color var(--t-fast)}
table.list tr:hover .row-actions a,table.list tr:hover .row-actions .link{opacity:1}
.inline-form{display:inline;margin:0}
.pill{
  display:inline-flex;align-items:center;gap:.35rem;
  font-size:.62rem;font-weight:500;text-transform:uppercase;letter-spacing:.08em;
  padding:.18rem .55rem;border-radius:99px;border:1px solid var(--border-strong);color:var(--text-2);
}
.pill::before{content:"";width:5px;height:5px;border-radius:50%;background:currentColor;opacity:.8}
.pill-published{color:var(--ok);border-color:color-mix(in srgb,var(--ok) 45%,transparent);background:var(--ok-bg)}
.pill-archived{color:var(--text-3)}

/* ---------------- login ---------------- */
.card.login{width:100%;max-width:370px;padding:2.5rem 2.25rem;text-align:center}
.brand-lg{font-size:1.25rem}
.card.login .muted{margin:.45rem 0 2rem;font-size:var(--fs-0);text-transform:uppercase;letter-spacing:.25em;color:var(--text-3)}
.card.login form{display:flex;flex-direction:column;gap:.25rem;text-align:left}
.card.login button{margin-top:.75rem;justify-content:center;height:38px}
.alert{
  background:var(--danger-bg);border:1px solid color-mix(in srgb,var(--danger) 40%,transparent);
  color:var(--text);padding:.65rem .8rem;border-radius:var(--r-m);font-size:var(--fs-1);
  margin-bottom:1.25rem;text-align:left;
}
.or-sep{display:flex;align-items:center;gap:.85rem;margin:1.5rem 0;color:var(--text-3);
  font-size:var(--fs-0);text-transform:uppercase;letter-spacing:.15em}
.or-sep::before,.or-sep::after{content:"";flex:1;height:1px;background:var(--border)}
.btn-google{
  display:flex;align-items:center;justify-content:center;gap:.6rem;
  height:38px;border:1px solid var(--border-strong);border-radius:var(--r-s);
  color:var(--text);font-size:var(--fs-1);font-weight:500;
  transition:background var(--t-fast),border-color var(--t-fast);
}
.btn-google:hover{background:var(--hover);border-color:var(--text-3);text-decoration:none;color:var(--text)}
.g-mark{
  display:inline-flex;align-items:center;justify-content:center;
  width:20px;height:20px;border-radius:50%;
  background:var(--accent);color:var(--accent-ink);
  font-family:var(--font-display);font-weight:700;font-size:.72rem;
}

/* ============================================================
   EDITOR
   ============================================================ */
.editor-bar{
  position:sticky;top:52px;z-index:30;
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
  margin:-2.25rem -1.5rem 1.75rem;padding:.65rem 1.5rem;
  background:color-mix(in srgb,var(--bg) 86%,transparent);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid var(--border);
}
.eb-left{display:flex;align-items:center;gap:1rem;min-width:0}
.back{color:var(--text-2);font-size:var(--fs-0);text-transform:uppercase;letter-spacing:.11em;white-space:nowrap}
.back:hover{color:var(--text)}
.eb-title{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.05em;font-size:var(--fs-2);
  font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.eb-right{display:flex;align-items:center;gap:.6rem}

/* save status pill */
.save-status{
  display:inline-flex;align-items:center;gap:.45rem;
  font-size:var(--fs-0);font-weight:500;letter-spacing:.04em;
  padding:.28rem .7rem;border-radius:99px;
  border:1px solid var(--border);background:var(--bg-raised);color:var(--text-2);
  transition:color var(--t-med),border-color var(--t-med),background var(--t-med);
  white-space:nowrap;
}
.save-status::before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor;flex:0 0 6px}
.save-status.saved{color:var(--ok);border-color:color-mix(in srgb,var(--ok) 35%,transparent);background:var(--ok-bg)}
.save-status.dirty{color:var(--text-2)}
.save-status.saving{color:var(--warn)}
.save-status.saving::before{animation:pulse 1s ease-in-out infinite}
.save-status.error{color:var(--danger);border-color:color-mix(in srgb,var(--danger) 40%,transparent);background:var(--danger-bg)}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}

/* split preview */
.edit-split{display:block}
.ed-pane{min-width:0}
/* when split is active, the page uses the full viewport */
main.wrap:has(.edit-split.split){max-width:none;padding-left:1.5rem;padding-right:1.5rem}
.edit-split.split{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:1.5rem;align-items:start}
@media(min-width:1700px){
  .edit-split.split{grid-template-columns:minmax(0,860px) minmax(0,1fr);justify-content:center}
}
.preview-pane{position:sticky;top:118px;height:calc(100vh - 134px);
  border:1px solid var(--border);border-radius:var(--r-l);overflow:hidden;
  background:var(--bg-sunken);box-shadow:var(--shadow-card)}
.preview-pane iframe{width:100%;height:100%;border:0;display:block;background:#131720}

/* editor cards */
.ed-card{padding:1.4rem 1.6rem;margin-bottom:1.1rem}
.ed-head{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;margin-bottom:1.1rem}
.ed-h{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.08em;
  font-size:var(--fs-1);font-weight:600;margin:0;color:var(--text)}
.ed-sub{font-family:var(--font-ui);text-transform:uppercase;letter-spacing:.1em;font-weight:500;
  font-size:var(--fs-0);color:var(--text-3);margin:1.6rem 0 .85rem}
.ed-card label,.module-card label{margin-bottom:.85rem}

/* module list */
.module-list{display:flex;flex-direction:column;gap:1rem}
.module-card{padding:1.25rem 1.5rem;transition:border-color var(--t-fast),box-shadow var(--t-fast),opacity var(--t-med)}
.module-card.dragging{opacity:.45;border-style:dashed}
.module-card.drag-over{border-color:var(--border-strong)}
.module-card.mod-hidden{opacity:.55;border-style:dashed}
.module-card.mod-hidden .ed-h::after{content:"Hidden";margin-left:.6rem;font-family:var(--font-ui);
  font-size:.6rem;letter-spacing:.08em;color:var(--text-3);border:1px solid var(--border-strong);
  border-radius:99px;padding:.1rem .45rem;vertical-align:1px}
.mc-head{display:flex;align-items:center;gap:.7rem;margin-bottom:1.1rem;padding-bottom:.8rem;border-bottom:1px solid var(--border)}
.mc-head .ed-h{flex:1;margin:0;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.mc-remove{opacity:0;transition:opacity var(--t-fast)}
.module-card:hover .mc-remove,.module-card:focus-within .mc-remove{opacity:1}
@media(hover:none){.mc-remove{opacity:1}}

/* drag handle: CSS dot grip, glyph hidden */
.drag-handle{
  width:16px;height:24px;flex:0 0 16px;cursor:grab;user-select:none;
  font-size:0;color:transparent;border-radius:4px;
  background-image:radial-gradient(circle,var(--text-3) 1.2px,transparent 1.4px);
  background-size:7px 7px;background-position:1px 2px;background-repeat:repeat;
  opacity:.55;transition:opacity var(--t-fast),background-color var(--t-fast);
}
.drag-handle:hover{opacity:1;background-color:var(--hover)}
.drag-handle:active{cursor:grabbing}

/* visibility switch */
.vis-pick{display:inline-flex}
.vis-toggle{
  display:inline-flex;align-items:center;gap:.45rem;
  background:transparent;border:1px solid var(--border-strong);border-radius:99px;
  color:var(--text-3);font-size:var(--fs-0);font-weight:500;letter-spacing:.03em;
  height:26px;padding:0 .7rem 0 .4rem;cursor:pointer;
  transition:color var(--t-fast),border-color var(--t-fast),background var(--t-fast);
}
.vis-toggle::before{
  content:"";width:12px;height:12px;border-radius:50%;
  background:var(--text-3);transition:background var(--t-fast),transform var(--t-fast);
  transform:scale(.66);
}
.vis-toggle.on{color:var(--ok);border-color:color-mix(in srgb,var(--ok) 45%,transparent);background:var(--ok-bg)}
.vis-toggle.on::before{background:var(--ok);transform:scale(.8)}
.vis-toggle:hover{border-color:var(--text-3)}
.vis-toggle.on:hover{border-color:var(--ok)}

/* background segmented control */
.bg-pick{display:inline-flex;align-items:center;gap:.5rem;
  font-size:var(--fs-0);text-transform:uppercase;letter-spacing:.08em;color:var(--text-3)}
.bg-seg{display:inline-flex;background:var(--field);border:1px solid var(--border);border-radius:var(--r-s);padding:2px;gap:2px}
.bg-seg button{
  background:transparent;border:0;border-radius:4px;cursor:pointer;
  color:var(--text-3);font-size:var(--fs-0);font-weight:500;letter-spacing:.02em;
  height:22px;padding:0 .6rem;
  transition:color var(--t-fast),background var(--t-fast),box-shadow var(--t-fast);
}
.bg-seg button:hover{color:var(--text)}
.bg-seg button.on{background:var(--bg-raised);color:var(--text);box-shadow:var(--shadow-card)}

/* add section row */
.add-section{display:flex;gap:.6rem;align-items:center;margin:1.4rem 0}
.add-section select{min-width:220px}
.empty-modules{text-align:center;padding:2.5rem 2rem}

/* ---------------- financials ---------------- */
.fin-cat{background:var(--field);border:1px solid var(--border);border-radius:var(--r-m);
  padding:1rem 1.1rem;margin-bottom:.85rem}
.fin-cat-head{display:flex;gap:.5rem;align-items:center;margin-bottom:.7rem}
.cat-name{flex:1;font-weight:600;font-size:var(--fs-2)!important;text-transform:none!important;letter-spacing:0!important;
  background:transparent;border-color:transparent}
.cat-name:hover{background:var(--hover)}
.fin-cols{display:grid;grid-template-columns:1fr 150px 27px;gap:.6rem;padding:0 0 .4rem;
  font-size:.62rem;font-weight:500;text-transform:uppercase;letter-spacing:.1em;color:var(--text-3)}
.fin-cols span:nth-child(2){text-align:right;padding-right:.2rem}
.fin-item{display:grid;grid-template-columns:1fr 150px 27px;gap:.6rem;margin-bottom:.4rem;align-items:center}
.fin-item input{background:transparent;border-color:transparent}
.fin-item input:hover{background:var(--hover)}
.fin-item input:focus{background:var(--field-focus);border-color:var(--border-strong)}
.cost-wrap{position:relative;display:flex;align-items:center}
.cost-wrap .dollar{position:absolute;left:.6rem;color:var(--text-3);font-size:var(--fs-1);pointer-events:none}
.it-cost{width:100%;padding-left:1.5rem!important;text-align:right}
.it-cost::-webkit-outer-spin-button,.it-cost::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.it-cost{-moz-appearance:textfield;appearance:textfield}
.fin-cat-sub{display:flex;justify-content:space-between;margin-top:.6rem;padding-top:.6rem;
  border-top:1px solid var(--border);font-size:var(--fs-0);font-weight:500;
  text-transform:uppercase;letter-spacing:.08em;color:var(--text-3)}
.cat-sub{color:var(--text);font-weight:600;font-variant-numeric:tabular-nums}
.fin-contingency{display:flex;align-items:center;gap:.6rem;margin:1.2rem 0}
.fin-contingency label{margin:0;font-size:var(--fs-0);text-transform:uppercase;letter-spacing:.1em;color:var(--text-2)}
.ct-input{width:80px;text-align:right}
.fin-contingency .pct{color:var(--text-3)}
.fin-totals{margin-top:1.2rem;border-top:1px solid var(--border-strong);padding-top:1rem}
.fin-total-row{display:flex;justify-content:space-between;padding:.3rem 0;font-size:var(--fs-2)}
.fin-total-row span:last-child{font-variant-numeric:tabular-nums}
.fin-total-row.muted{color:var(--text-2);font-size:var(--fs-1)}
.fin-total-row.grand{margin-top:.55rem;padding-top:.7rem;border-top:1px solid var(--border-strong);
  font-family:var(--font-display);text-transform:uppercase;letter-spacing:.05em;font-weight:600;font-size:var(--fs-3)}

/* ---------------- repeater rows (scope, payment, terms, timeline, grid) ---------------- */
.repeater-rows,.gallery-rows,.grid-rows{display:flex;flex-direction:column;gap:.65rem;margin-bottom:.9rem}
.scope-row,.term-row,.gallery-row,.grid-row{
  background:var(--field);border:1px solid var(--border);border-radius:var(--r-m);padding:.8rem .9rem;
  transition:border-color var(--t-fast);
}
.scope-row:focus-within,.term-row:focus-within,.gallery-row:focus-within,.grid-row:focus-within{border-color:var(--border-strong)}
.scope-row input,.scope-row textarea,.term-row input,.term-row textarea,
.gallery-row input,.grid-row input,.pay-row-ed input{background:transparent;border-color:transparent}
.scope-row input:hover,.scope-row textarea:hover,.term-row input:hover,.term-row textarea:hover,
.gallery-row input:hover,.grid-row input:hover,.pay-row-ed input:hover{background:var(--hover)}
.scope-row input:focus,.scope-row textarea:focus,.term-row input:focus,.term-row textarea:focus,
.gallery-row input:focus,.grid-row input:focus,.pay-row-ed input:focus{background:var(--field-focus);border-color:var(--border-strong)}
.scope-row-top{display:grid;grid-template-columns:1fr 200px 27px;gap:.6rem;align-items:center;margin-bottom:.45rem}
.ph-items,.tm-body{width:100%}
.pay-cols,.pay-row-ed{display:grid;grid-template-columns:1.4fr 1.4fr 100px 27px;gap:.6rem;align-items:center}
.pay-cols{font-size:.62rem;font-weight:500;text-transform:uppercase;letter-spacing:.1em;color:var(--text-3);margin-bottom:.45rem;padding:0 .15rem}
.pay-row-ed{background:var(--field);border:1px solid var(--border);border-radius:var(--r-m);padding:.5rem .6rem}
.ms-pct{text-align:right}
.pay-tally{margin-top:.35rem}
.term-row-top{display:grid;grid-template-columns:1fr 27px;gap:.6rem;align-items:center;margin-bottom:.45rem}
.tl-cols,.tl-row{display:grid;grid-template-columns:1fr 90px 90px 27px;gap:.6rem;align-items:center}
.tl-cols{font-size:.62rem;font-weight:500;text-transform:uppercase;letter-spacing:.1em;color:var(--text-3);margin-bottom:.45rem;padding:0 .15rem}
.tl-row{background:var(--field);border:1px solid var(--border);border-radius:var(--r-m);padding:.5rem .6rem;transition:border-color var(--t-fast)}
.tl-row:focus-within{border-color:var(--border-strong)}
.tl-row input{background:transparent;border-color:transparent}
.tl-row input:hover{background:var(--hover)}
.tl-row input:focus{background:var(--field-focus);border-color:var(--border-strong)}
.tl-start,.tl-len{text-align:right}
.grid-row{display:grid;grid-template-columns:auto 1fr 27px;gap:.9rem;align-items:start}
.grid-row .gr-fields{display:grid;gap:.45rem;align-self:center}
.grid-row .image-field{margin:0}
.grid-row .if-preview{width:108px;height:76px}
.grid-row .if-label{display:none}

/* ---------------- image field ---------------- */
.image-field{margin:1.1rem 0 .4rem}
.if-label{display:block;font-size:var(--fs-0);font-weight:500;text-transform:uppercase;letter-spacing:.09em;color:var(--text-2);margin-bottom:.45rem}
.if-preview{width:190px;height:114px;border:1px solid var(--border);border-radius:var(--r-m);overflow:hidden;
  background:var(--field);display:flex;align-items:center;justify-content:center;transition:border-color var(--t-fast)}
.if-preview:hover{border-color:var(--border-strong)}
.if-preview img{width:100%;height:100%;object-fit:cover}
.img-empty{color:var(--text-3);font-size:var(--fs-0)}
.if-actions{display:flex;gap:.6rem;align-items:center;margin-top:.55rem}

/* gallery rows */
.gallery-row{display:grid;grid-template-columns:auto 1fr 27px;gap:.9rem;align-items:center}
.gallery-row .image-field{margin:0}
.gallery-row .if-preview{width:108px;height:72px}
.gallery-row .if-label{display:none}

/* ---------------- image picker modal ---------------- */
.img-picker{position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center}
.img-picker[hidden]{display:none}
.ip-backdrop{position:absolute;inset:0;background:var(--scrim);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}
.ip-modal{position:relative;width:min(780px,92vw);max-height:84vh;display:flex;flex-direction:column;
  background:var(--bg-overlay);border:1px solid var(--border);border-radius:var(--r-l);
  padding:1.4rem;overflow:hidden;box-shadow:var(--shadow-pop);
  animation:modal-in var(--t-med) both}
@keyframes modal-in{from{opacity:0;transform:translateY(8px) scale(.985)}to{opacity:1;transform:none}}
.ip-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}
.ip-head h3{margin:0;font-family:var(--font-display);text-transform:uppercase;letter-spacing:.07em;font-size:var(--fs-2)}
.ip-close{background:none;border:0;color:var(--text-3);font-size:1.35rem;cursor:pointer;line-height:1;
  width:30px;height:30px;border-radius:var(--r-s);transition:color var(--t-fast),background var(--t-fast)}
.ip-close:hover{color:var(--text);background:var(--hover)}
.ip-upload{display:block;text-align:center;border:1.5px dashed var(--border-strong);border-radius:var(--r-m);
  padding:.85rem;margin-bottom:1rem;cursor:pointer;color:var(--text-2);
  font-size:var(--fs-0);text-transform:uppercase;letter-spacing:.1em;font-weight:500;
  transition:border-color var(--t-fast),background var(--t-fast),color var(--t-fast)}
.ip-upload:hover{border-color:var(--text-3);background:var(--hover);color:var(--text)}
.ip-status{margin:0 0 .75rem;font-size:var(--fs-1);color:var(--text-2)}
.ip-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.7rem;overflow-y:auto;padding:.25rem}
.ip-tile{position:relative;aspect-ratio:4/3;border:2px solid transparent;border-radius:var(--r-m);overflow:hidden;
  cursor:pointer;background:var(--field);transition:border-color var(--t-fast),transform var(--t-fast)}
.ip-tile img{width:100%;height:100%;object-fit:cover}
.ip-tile:hover{border-color:var(--accent);transform:translateY(-1px)}

/* ---------------- share + danger ---------------- */
.share-row{display:flex;gap:.6rem;align-items:center;margin-top:.75rem}
.share-url{flex:1;font-size:var(--fs-1);color:var(--text-2);font-variant-numeric:tabular-nums}
.share-actions{margin-top:.9rem}
.danger-zone{margin-top:2.5rem;padding-top:1.4rem;border-top:1px solid var(--border)}

/* ============================================================
   IMAGE LIBRARY
   ============================================================ */
.lib-head{align-items:baseline}
.lib-tools{display:flex;align-items:center;gap:.6rem;margin-left:auto}
.dropzone{border:1.5px dashed var(--border-strong);border-radius:var(--r-l);padding:2.25rem;text-align:center;
  background:var(--bg-raised);margin-bottom:1.75rem;transition:border-color var(--t-fast),background var(--t-fast)}
.dropzone.drag{border-color:var(--accent);background:var(--hover)}
.dropzone p{margin:.4rem 0}
.asset-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(168px,1fr));gap:.9rem}
.asset{position:relative;margin:0;background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--r-m);
  overflow:hidden;cursor:zoom-in;box-shadow:var(--shadow-card);
  transition:transform var(--t-fast),border-color var(--t-fast),box-shadow var(--t-fast)}
.asset:hover{transform:translateY(-2px);border-color:var(--border-strong)}
.asset img{width:100%;height:128px;object-fit:cover;display:block}
.asset figcaption{padding:.45rem .6rem;font-size:var(--fs-0);color:var(--text-2);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.asset-del{position:absolute;top:.4rem;right:.4rem;width:24px;height:24px;border-radius:50%;border:0;
  background:var(--scrim);color:#fff;cursor:pointer;font-size:.95rem;line-height:1;
  opacity:0;transition:opacity var(--t-fast),background var(--t-fast)}
.asset:hover .asset-del{opacity:1}
@media(hover:none){.asset-del{opacity:1}}
.asset-del:hover{background:var(--danger-strong)}
/* select mode */
.asset-grid.selecting .asset{cursor:pointer}
.asset-grid.selecting .asset-del{display:none}
.asset-grid.selecting .asset::after{
  content:"";position:absolute;top:.45rem;left:.45rem;width:18px;height:18px;border-radius:50%;
  border:2px solid #fff;background:var(--scrim);box-shadow:0 0 0 1px rgba(0,0,0,.2);
  transition:background var(--t-fast)}
.asset-grid.selecting .asset.selected{border-color:var(--accent)}
.asset-grid.selecting .asset.selected::after{
  background:var(--accent);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='8' viewBox='0 0 10 8'%3E%3Cpath d='M1 4l2.5 2.5L9 1' fill='none' stroke='%2315161A' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:center}
.asset-grid.selecting .asset.selected img{opacity:.8}
.lib-sentinel{display:flex;justify-content:center;padding:1.5rem 0}
.lib-sentinel[hidden]{display:none}

/* lightbox */
.lightbox{position:fixed;inset:0;z-index:110;display:flex;align-items:center;justify-content:center}
.lightbox[hidden]{display:none}
.lb-backdrop{position:absolute;inset:0;background:var(--scrim);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}
.lb-figure{position:relative;margin:0;max-width:min(1080px,86vw);max-height:86vh;display:flex;flex-direction:column;
  animation:modal-in var(--t-med) both}
.lb-figure img{max-width:100%;max-height:calc(86vh - 56px);object-fit:contain;border-radius:var(--r-m);
  box-shadow:var(--shadow-pop);background:var(--bg-sunken)}
.lb-meta{display:flex;align-items:center;gap:.9rem;padding:.7rem .25rem 0;font-size:var(--fs-1);color:#fff}
html[data-theme="light"] .lb-meta{color:var(--text)}
.lb-meta .muted{opacity:.7}
.lb-badge{font-size:.6rem;font-weight:500;text-transform:uppercase;letter-spacing:.08em;
  border:1px solid currentColor;border-radius:99px;padding:.12rem .5rem;opacity:.85}
.lb-meta .link-danger{margin-left:auto}
.lb-nav{position:relative;z-index:1;width:42px;height:42px;border-radius:50%;border:1px solid var(--border-strong);
  background:var(--bg-overlay);color:var(--text);font-size:1.3rem;line-height:1;cursor:pointer;margin:0 1rem;
  transition:background var(--t-fast),transform var(--t-fast)}
.lb-nav:hover{background:var(--hover);transform:scale(1.06)}
.lb-close{position:absolute;top:1.1rem;right:1.25rem;z-index:1;width:36px;height:36px;border-radius:50%;
  border:1px solid var(--border-strong);background:var(--bg-overlay);color:var(--text);
  font-size:1.2rem;line-height:1;cursor:pointer;transition:background var(--t-fast)}
.lb-close:hover{background:var(--hover)}

/* ============================================================
   USERS
   ============================================================ */
.invite-form{display:flex;gap:1rem;align-items:flex-end;flex-wrap:wrap;
  background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--r-l);
  padding:1.25rem 1.4rem;margin-bottom:1.5rem;box-shadow:var(--shadow-card)}
.invite-form label{margin:0;flex:1;min-width:200px}
.invite-form .btn,.invite-form button[type=submit]{margin-bottom:1px}
.users-table{width:100%;border-collapse:separate;border-spacing:0;background:var(--bg-raised);
  border:1px solid var(--border);border-radius:var(--r-l);overflow:hidden;box-shadow:var(--shadow-card)}
.users-table th,.users-table td{text-align:left;padding:.7rem 1rem;font-size:var(--fs-1);border-bottom:1px solid var(--border)}
.users-table th{font-weight:500;text-transform:uppercase;letter-spacing:.09em;font-size:var(--fs-0);
  color:var(--text-3);background:var(--bg-sunken)}
.users-table tr:last-child td{border-bottom:0}
.users-table tbody tr{transition:background var(--t-fast)}
.users-table tbody tr:hover{background:var(--hover)}
.users-table tr.inactive td{opacity:.5}
.u-avatar{width:44px}
.u-avatar img,.u-initial{width:30px;height:30px;border-radius:50%;display:block;object-fit:cover}
.u-initial{display:flex;align-items:center;justify-content:center;background:var(--field);
  border:1px solid var(--border);color:var(--text-2);font-size:var(--fs-0);font-weight:600}
.u-name{font-weight:500}
.u-badge{font-size:.62rem;font-weight:500;text-transform:uppercase;letter-spacing:.08em;
  border:1px solid var(--border-strong);border-radius:99px;padding:.15rem .55rem;color:var(--text-2)}
.u-badge.root{color:var(--accent);border-color:color-mix(in srgb,var(--accent) 55%,transparent)}
html[data-theme="light"] .u-badge.root{color:var(--text);border-color:var(--border-strong);background:var(--field)}
.u-actions{white-space:nowrap}
.u-actions form{display:inline-block;margin-right:.75rem}
.ok{color:var(--ok);font-weight:500}
.bad{color:var(--danger);font-weight:600}

/* ============================================================
   AI DRAFT + DIAGNOSTICS
   ============================================================ */
.ai-card{padding:1.6rem 1.75rem;max-width:720px}
.ai-card textarea{min-height:180px}
.ai-hint{color:var(--text-2);font-size:var(--fs-1);margin:.25rem 0 1.1rem}
.ai-actions{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}
.ai-meta{color:var(--text-3);font-size:var(--fs-0)}
.ai-status{display:none;margin-top:1.1rem;padding:.7rem .9rem;border-radius:var(--r-m);
  background:var(--field);border:1px solid var(--border);font-size:var(--fs-1);color:var(--text-2)}
.ai-status.on{display:flex;align-items:center;gap:.3rem;flex-wrap:wrap}
.ai-status.err{border-color:color-mix(in srgb,var(--danger) 40%,transparent);background:var(--danger-bg);color:var(--text)}
.ai-dot{width:5px;height:5px;border-radius:50%;background:var(--text-2);display:inline-block;animation:pulse 1.2s ease-in-out infinite}
.ai-dot:nth-child(2){animation-delay:.2s}
.ai-dot:nth-child(3){animation-delay:.4s;margin-right:.35rem}
.ai-msg{flex:1;min-width:200px}
.ai-clock{color:var(--text-3);font-variant-numeric:tabular-nums}
table.diag{width:100%;border-collapse:separate;border-spacing:0;background:var(--bg-raised);
  border:1px solid var(--border);border-radius:var(--r-l);overflow:hidden;box-shadow:var(--shadow-card)}
table.diag td{padding:.6rem 1rem;font-size:var(--fs-1);border-bottom:1px solid var(--border)}
table.diag tr:last-child td{border-bottom:0}
table.diag td:first-child{color:var(--text-2);width:280px}
table.diag td:nth-child(2){font-variant-numeric:tabular-nums;word-break:break-all}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:960px){
  .edit-split.split{grid-template-columns:1fr}
  .preview-pane{position:static;height:60vh}
}
@media(max-width:720px){
  .grid2,.grid3{grid-template-columns:1fr}
  .mainnav{gap:0}
  .who{display:none}
  .editor-bar{flex-wrap:wrap}
  .mc-head{flex-wrap:wrap}
  .bg-pick{flex-basis:100%;justify-content:flex-start}
  .fin-item,.fin-cols{grid-template-columns:1fr 110px 27px}
  .pay-cols,.pay-row-ed{grid-template-columns:1.2fr 1.2fr 70px 27px}
  .scope-row-top{grid-template-columns:1fr 130px 27px}
  .invite-form{flex-direction:column;align-items:stretch}
  .row-actions{flex-wrap:wrap;justify-content:flex-start}
}

/* ============================================================
   MOTION LAYER
   1 shine · 2 lift · 3 squish · 4 ripple · 5 border draw
   6 icon slide · 7 save morph · 8 check draw · 9 card zoom
   10 spring switch · 11 error shake · 12 staggered reveal
   ============================================================ */

/* 1+4 require a clipping context on primary buttons */
.btn,button[type=submit]{position:relative;overflow:hidden}

/* 1 — shine sweep (primary buttons) */
.btn::after,button[type=submit]::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(105deg,transparent 40%,var(--shine) 50%,transparent 60%);
  transform:translateX(-130%);
}
.btn:hover::after,button[type=submit]:hover::after{transform:translateX(130%);transition:transform .55s ease}

/* 2 — lift + glow */
.btn:hover,button[type=submit]:hover{transform:translateY(-1px);box-shadow:var(--shadow-lift)}
.btn-soft:hover{transform:translateY(-1px);box-shadow:var(--shadow-card)}

/* 3 — press squish (overrides the plain active rule above) */
.btn:active,button[type=submit]:active{transform:translateY(0) scale(.97);box-shadow:none;transition-duration:60ms}
.btn-soft:active{transform:translateY(0) scale(.97);box-shadow:none;transition-duration:60ms}
.btn-danger:active,.theme-toggle:active{transform:scale(.95);transition-duration:60ms}
.icon-btn:active{transform:scale(.88);transition-duration:60ms}
.vis-toggle:active,.bg-seg button:active{transform:scale(.96);transition-duration:60ms}

/* 4 — click ripple (span injected by builder.js) */
.btn .rip,button[type=submit] .rip{
  position:absolute;border-radius:50%;background:var(--shine);
  transform:scale(0);animation:rip .5s ease-out forwards;pointer-events:none;
}
@keyframes rip{to{transform:scale(3.2);opacity:0}}

/* 5 — border draw (secondary buttons) */
.btn-soft{position:relative}
.btn-soft::before{
  content:"";position:absolute;inset:-1px;border-radius:inherit;pointer-events:none;
  border:1px solid var(--accent);clip-path:inset(0 100% 0 0);
  transition:clip-path .35s ease;
}
.btn-soft:hover::before{clip-path:inset(0 0 0 0)}
html[data-theme="light"] .btn-soft::before{border-color:var(--accent)}

/* 6 — icon slide-in on outbound links */
.row-actions a[target="_blank"]::after,.share-row .btn-ghost[target="_blank"]::after{
  content:"\2192";display:inline-block;width:0;opacity:0;overflow:hidden;
  transform:translateX(-4px);vertical-align:-1px;
  transition:width .18s ease,opacity .18s ease,transform .18s ease,margin-left .18s ease;
}
.row-actions a[target="_blank"]:hover::after,.share-row .btn-ghost[target="_blank"]:hover::after{
  width:.85em;opacity:1;transform:none;margin-left:.3em;
}

/* 7 — save morph: spinner while saving, check pop when saved */
.save-status.saving::before{
  width:9px;height:9px;border-radius:50%;background:transparent;
  border:1.5px solid currentColor;border-top-color:transparent;
  animation:spin .7s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg)}}
.save-status.saved::before{animation:check-pop .35s cubic-bezier(.34,1.56,.64,1)}
@keyframes check-pop{0%{transform:scale(.3)}60%{transform:scale(1.35)}100%{transform:scale(1)}}

/* 8 — checkmark pop in library select mode */
@keyframes check-in{0%{transform:scale(.4)}60%{transform:scale(1.18)}100%{transform:scale(1)}}
.asset-grid.selecting .asset.selected::after{animation:check-in .28s cubic-bezier(.34,1.56,.64,1)}

/* 9 — card hover zoom (library, picker) */
.asset{cursor:zoom-in}
.asset img{transition:transform .35s ease}
.asset:hover{box-shadow:var(--shadow-pop)}
.asset:hover img{transform:scale(1.06)}
.asset-grid.selecting .asset:hover img{transform:none}
.ip-tile img{transition:transform .3s ease}
.ip-tile:hover img{transform:scale(1.05)}

/* 10 — spring on the visibility switch dot (after initial load only) */
@keyframes dot-spring{0%{transform:scale(.4)}55%{transform:scale(1.25)}100%{transform:scale(.8)}}
.module-list.settled .vis-toggle.on::before{animation:dot-spring .3s cubic-bezier(.34,1.56,.64,1) forwards}
@keyframes dot-spring-off{0%{transform:scale(1.1)}100%{transform:scale(.66)}}
.module-list.settled .vis-toggle:not(.on)::before{animation:dot-spring-off .2s ease forwards}
.bg-seg button.on{animation:seg-pop .22s cubic-bezier(.34,1.4,.64,1)}
@keyframes seg-pop{0%{transform:scale(.92)}100%{transform:scale(1)}}

/* 11 — error shake */
@keyframes shake{20%{transform:translateX(-5px)}40%{transform:translateX(5px)}60%{transform:translateX(-3px)}80%{transform:translateX(3px)}}
.save-status.error{animation:shake .4s ease}
.alert{animation:shake .45s ease .15s backwards}
.ai-status.err{animation:shake .4s ease}

/* 12 — staggered reveal on page load */
@keyframes rise-in{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.module-list:not(.settled) .module-card{animation:rise-in .4s cubic-bezier(.22,1,.36,1) backwards}
.module-list:not(.settled) .module-card:nth-child(1){animation-delay:.03s}
.module-list:not(.settled) .module-card:nth-child(2){animation-delay:.09s}
.module-list:not(.settled) .module-card:nth-child(3){animation-delay:.15s}
.module-list:not(.settled) .module-card:nth-child(4){animation-delay:.21s}
.module-list:not(.settled) .module-card:nth-child(5){animation-delay:.27s}
.module-list:not(.settled) .module-card:nth-child(6){animation-delay:.33s}
.module-list:not(.settled) .module-card:nth-child(n+7){animation-delay:.38s}
table.list tbody tr,.users-table tbody tr{animation:rise-in .35s cubic-bezier(.22,1,.36,1) backwards}
table.list tbody tr:nth-child(1),.users-table tbody tr:nth-child(1){animation-delay:.02s}
table.list tbody tr:nth-child(2),.users-table tbody tr:nth-child(2){animation-delay:.06s}
table.list tbody tr:nth-child(3),.users-table tbody tr:nth-child(3){animation-delay:.1s}
table.list tbody tr:nth-child(4),.users-table tbody tr:nth-child(4){animation-delay:.14s}
table.list tbody tr:nth-child(5),.users-table tbody tr:nth-child(5){animation-delay:.18s}
table.list tbody tr:nth-child(n+6),.users-table tbody tr:nth-child(n+6){animation-delay:.22s}
.asset{animation:rise-in .3s ease backwards}

/* bonus — copied tooltip on the share button */
#copy-share{position:relative}
#copy-share::after{
  content:attr(data-tip);position:absolute;left:50%;bottom:calc(100% + 8px);
  transform:translateX(-50%) translateY(4px) scale(.92);
  background:var(--accent);color:var(--accent-ink);
  font-family:var(--font-display);font-weight:600;font-size:.62rem;
  text-transform:uppercase;letter-spacing:.08em;
  padding:.3rem .55rem;border-radius:5px;white-space:nowrap;
  opacity:0;pointer-events:none;
  transition:opacity .18s,transform .18s cubic-bezier(.34,1.56,.64,1);
}
#copy-share.show::after{opacity:1;transform:translateX(-50%) translateY(0) scale(1)}
