/* ============================================================
   Iterate design system - bundle (drop-in).
   One <link>/import for any service: tokens + base + components.
   Dark-first aubergine; set data-theme="light" for the light theme.
   Fonts are co-located (fonts/ next to this file). Tokens live in
   tokens.css (imported below) - the single source of colour values.
   ============================================================ */
@import "tokens.css";

@font-face{font-family:"Geist";font-style:normal;font-weight:100 900;font-display:swap;src:url("fonts/Geist-Variable.woff2") format("woff2")}
@font-face{font-family:"Geist Mono";font-style:normal;font-weight:100 900;font-display:swap;src:url("fonts/GeistMono-Variable.woff2") format("woff2")}

/* ---------- base ---------- */
*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{font-family:var(--sans);background:var(--bg);color:var(--text);line-height:1.55;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;min-height:100vh}
a{color:var(--accent);text-decoration:none}
button{font-family:inherit}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(16px,4vw,32px)}
.mono{font-family:var(--mono)}
h1,h2,h3{font-weight:600;letter-spacing:-.02em;line-height:1.1;color:var(--text)}
h1{font-size:clamp(2.2rem,5vw,3.6rem)} h2{font-size:clamp(1.7rem,3.4vw,2.6rem)} h3{font-size:1.25rem}
.lead{font-size:clamp(1.05rem,1.6vw,1.22rem);color:var(--muted);max-width:60ch}

/* ---------- ambient orbs (optional hero/background glow) ---------- */
.orb{position:fixed;border-radius:50%;filter:blur(70px);pointer-events:none;z-index:0;opacity:.30}
.orb.plum{width:520px;height:520px;top:-160px;right:-120px;background:radial-gradient(circle at 40% 40%,#7a4f93,transparent 70%)}
.orb.apri{width:420px;height:420px;bottom:-180px;left:-140px;background:radial-gradient(circle at 50% 50%,var(--accent),transparent 68%)}

/* ---------- brand mark ---------- */
.brandmark{height:1.45em;width:1.45em;flex:none}
.brandmark .a{stroke:var(--accent)} .brandmark .b{stroke:var(--text)}
.brand{display:flex;align-items:center;gap:.5em;font-weight:600;font-size:1.15rem;letter-spacing:-.02em;color:var(--text)}
.brand small{font-weight:400;color:var(--muted);letter-spacing:0}

/* ---------- header ---------- */
header.bar{position:sticky;top:0;z-index:30;background:color-mix(in srgb,var(--bg) 82%,transparent);
  backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
header.bar .in{display:flex;align-items:center;gap:1rem;height:62px}
header.bar .spacer{flex:1}
.pill{font-family:var(--mono);background:var(--primary);color:#fff;font-size:.66rem;padding:.18rem .5rem;
  border-radius:999px;text-transform:uppercase;letter-spacing:.06em;white-space:nowrap}

/* ---------- eyebrow ---------- */
.eyebrow{font-family:var(--mono);font-size:.72rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;
  color:var(--accent);display:flex;align-items:center;gap:.5rem;margin:1.4rem 0 .5rem}
.eyebrow .dot{width:6px;height:6px;border-radius:50%;background:var(--accent)}

/* ---------- tabs ---------- */
.tabs{display:flex;gap:.4rem;flex-wrap:wrap;margin:.3rem 0 1rem}
.tab{padding:.5rem .95rem;border:1px solid var(--line-2);border-radius:999px;background:transparent;
  color:var(--muted);cursor:pointer;font-weight:500;font-size:.9rem;white-space:nowrap;transition:.15s}
.tab:hover{color:var(--text);border-color:var(--primary-300)}
.tab.active{background:var(--accent);color:var(--on-accent);border-color:var(--accent);font-weight:600}

/* ---------- panel / card ---------- */
.panel,.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:1rem 1.1rem;margin:.7rem 0}

/* ---------- form fields ---------- */
input[type=text],input[type=email],input[type=password],input[type=search],textarea,select,.field{
  font-family:inherit;font-size:.92rem;padding:.55rem .7rem;border-radius:10px;background:var(--surface-2);
  color:var(--text);border:1px solid var(--line-2);width:100%}
input:focus,textarea:focus,select:focus,.field:focus{outline:none;border-color:var(--accent);
  box-shadow:0 0 0 3px rgba(230,161,92,.30)}

/* ---------- buttons ---------- */
.btn{padding:.6rem 1.1rem;border-radius:11px;border:1px solid transparent;font-weight:600;font-size:.92rem;
  font-family:inherit;cursor:pointer;display:inline-flex;align-items:center;gap:.45rem;transition:.15s;white-space:nowrap}
.btn--primary{background:var(--accent);color:var(--on-accent)}
.btn--primary:hover{background:var(--accent-deep)}
.btn--aubergine{background:var(--primary);color:#fff}
.btn--aubergine:hover{background:var(--primary-600)}
.btn--ghost{background:transparent;color:var(--text);border-color:var(--line-2)}
.btn--ghost:hover{border-color:var(--text)}
.btn--sm{padding:.42rem .8rem;font-size:.85rem}
.btn:disabled{opacity:.45;cursor:default}

/* ---------- list rows (reflow, mobile-safe) ---------- */
.list{display:flex;flex-direction:column}
.row-item{display:flex;align-items:center;gap:.7rem;padding:.55rem .2rem;border-bottom:1px solid var(--line)}
.row-item:hover{background:rgba(246,242,238,.04)}
.row-item .meta{flex:1;min-width:0}
.row-item .name{font-weight:600;color:var(--text);word-break:break-word;line-height:1.3}
.row-item .sub{color:var(--muted);font-size:.78rem;word-break:break-word;margin-top:.1rem}
.tag{display:inline-block;font-family:var(--mono);font-size:.62rem;padding:.08rem .4rem;border-radius:6px;
  background:var(--surface-2);color:var(--accent);letter-spacing:.03em}

/* ---------- pagination ---------- */
.pager{display:flex;align-items:center;justify-content:space-between;gap:.6rem;margin-top:.8rem;flex-wrap:wrap}
.pager .info{font-size:.8rem;color:var(--muted)}
.pager button{padding:.35rem .7rem;border-radius:8px;border:1px solid var(--line-2);background:transparent;
  color:var(--text);cursor:pointer;font-size:.82rem}
.pager button:disabled{opacity:.4;cursor:default}

/* ---------- states ---------- */
.empty,.spin{color:var(--muted);padding:1.6rem .4rem;text-align:center}
.spin::before{content:"";display:inline-block;width:15px;height:15px;margin-right:.5rem;vertical-align:-2px;
  border:2px solid var(--line-2);border-top-color:var(--accent);border-radius:50%;animation:it-spin .7s linear infinite}
@keyframes it-spin{to{transform:rotate(360deg)}}
.err{color:var(--danger);font-size:.85rem;margin:.5rem 0}
.footnote{font-size:.8rem;color:var(--muted-2);margin:.8rem 0 2rem;max-width:64ch}

/* ---------- modal ---------- */
.modal-bg{position:fixed;inset:0;z-index:60;background:rgba(16,9,20,.72);backdrop-filter:blur(4px);
  display:none;align-items:center;justify-content:center;padding:1.2rem}
.modal-bg.show{display:flex}
.modal{background:var(--dark-2);border:1px solid var(--line-2);border-radius:var(--radius);
  padding:1.8rem 1.7rem;max-width:26rem;width:100%;text-align:center;box-shadow:0 30px 80px -30px #000}

/* ---------- login card ---------- */
.login{max-width:25rem;margin:14vh auto;padding:2rem 1.9rem;background:var(--surface);
  border:1px solid var(--line);border-radius:var(--radius);text-align:center;position:relative;z-index:1}
.login .brand{justify-content:center;font-size:1.35rem;margin-bottom:.3rem}
.login p.sub{color:var(--muted);margin:.2rem 0 1.5rem;font-size:.95rem}
