/* Loft · shared tokens & primitives · v0.2 */

:root, [data-theme="light"] {
  /* ----- Drive shell (warm cream) ----- */
  --bg:#FAF7F2; --bg-panel:#FFFFFF; --bg-elev:#F2ECE2; --bg-sunken:#ECE4D6;

  /* ----- Ink (agent-native) ----- */
  --ink:#1A1714; --ink-elev:#23201C; --ink-fg:#E8E3D8; --ink-fg-muted:#8C857A; --ink-border:#2E2A24;

  /* ----- Text ----- */
  --fg:#1A1714; --fg-muted:#6E665B; --fg-subtle:#9A9082;

  /* ----- Borders ----- */
  --border:#E5DED3; --border-sub:#EFE9DD; --border-strong:#D5CCBC;

  /* ----- Accent (ember) ·  -strong for text · -fill for buttons (AA passing) ----- */
  --accent:#E26534;          /* brand · decorative · gradients, dots, icons */
  --accent-soft:#FBE9DF;     /* tinted background for badges, selected rows */
  --accent-strong:#A84218;   /* text-on-light: links, badge labels (6.07:1 on white) */
  --accent-fill:#B84A20;     /* button fill (5.20:1 white-on-fill, AA pass) */
  --accent-fill-hov:#9A3D1A; /* button hover (8.10:1 white-on-hover) */
  --accent-fg:#FFFFFF;

  /* ----- Agent-context on ink ----- */
  --spectral:#6FDDE5;        /* highlights on ink (11.18:1) */
  --machine:#B6F36E;         /* machine signal on ink (13.63:1) */

  /* ----- Semantic ----- */
  --info:#2D6CFF;            --info-bg:#E4ECFF;   --info-strong:#0050D6;
  --warn:#C78400;            --warn-bg:#FFF1D1;   --warn-strong:#8F5F00;
  --danger:#CC2E2E;          --danger-bg:#FBE3E0; --danger-strong:#A82020;
  --success:#0F7A4D;         --success-bg:#DFF3E8;

  /* ----- Kind hues (decorative) ----- */
  --k-md:#2D6CFF; --k-code:#7A4FE0; --k-image:#0F7A4D; --k-video:#A0700B;
  --k-dataset:#B43E8F; --k-skill:#A84218; --k-bundle:#4A4A4A; --k-folder:#8F5F00;

  /* ----- Avatar palette (deterministic by hash) ----- */
  --av-1:#A84218; --av-2:#0F7A4D; --av-3:#0050D6; --av-4:#7A4FE0;
  --av-5:#B43E8F; --av-6:#8F5F00; --av-7:#4A4A4A; --av-8:#1A1714;

  /* ----- Radius ----- */
  --r-sm:4px; --r-md:6px; --r-lg:10px; --r-xl:16px;

  /* ----- Shadow ----- */
  --sh-1:0 1px 0 rgba(26,23,20,.04), 0 1px 2px rgba(26,23,20,.04);
  --sh-2:0 2px 8px rgba(26,23,20,.06), 0 12px 32px rgba(26,23,20,.06);
  --sh-pop:0 24px 48px -16px rgba(26,23,20,.18), 0 4px 12px rgba(26,23,20,.06);

  /* ----- Focus ----- */
  --focus-ring:0 0 0 3px rgba(226,101,52,0.30);

  /* ----- Type ----- */
  --f-ui:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",system-ui,sans-serif;
  --f-mono:"JetBrains Mono","SF Mono",ui-monospace,Menlo,monospace;
}

/* ====== DARK MODE ====== */
[data-theme="dark"] {
  --bg:#13110E; --bg-panel:#1A1714; --bg-elev:#221F1B; --bg-sunken:#0D0B09;
  --ink:#0A0907; --ink-elev:#13110E; --ink-fg:#E8E3D8; --ink-fg-muted:#8C857A; --ink-border:#221F1B;
  --fg:#ECE6D9; --fg-muted:#A8A092; --fg-subtle:#6E665B;
  --border:#2E2A24; --border-sub:#25221E; --border-strong:#3A352E;

  --accent:#F08055;          /* lighter ember for dark surfaces */
  --accent-soft:#3A1B0E;
  --accent-strong:#F5A07E;
  --accent-fill:#E26534;
  --accent-fill-hov:#F08055;
  --accent-fg:#13110E;

  --info:#79B4FF; --info-bg:#0F2046; --info-strong:#A6CCFF;
  --warn:#E4A82F; --warn-bg:#2E1F00; --warn-strong:#F2C257;
  --danger:#FF6B6B; --danger-bg:#2E1010; --danger-strong:#FF9292;
  --success:#5AC68A; --success-bg:#0B2418;

  --k-md:#79B4FF; --k-code:#A989F0; --k-image:#5AC68A; --k-video:#E4A82F;
  --k-dataset:#E07AC3; --k-skill:#F08055; --k-bundle:#9A9082; --k-folder:#E4A82F;

  --sh-1:0 1px 0 rgba(0,0,0,.4), 0 1px 2px rgba(0,0,0,.3);
  --sh-2:0 2px 8px rgba(0,0,0,.4), 0 12px 32px rgba(0,0,0,.5);
  --sh-pop:0 24px 48px -16px rgba(0,0,0,.6), 0 4px 12px rgba(0,0,0,.4);

  --focus-ring:0 0 0 3px rgba(240,128,85,0.45);
}

/* Respect system preference unless user has chosen explicitly */
@media (prefers-color-scheme: dark) {
  :root:not([data-theme="light"]):not([data-theme="dark"]) {
    --bg:#13110E; --bg-panel:#1A1714; --bg-elev:#221F1B; --bg-sunken:#0D0B09;
    --fg:#ECE6D9; --fg-muted:#A8A092; --fg-subtle:#6E665B;
    --border:#2E2A24; --border-sub:#25221E; --border-strong:#3A352E;
    --accent:#F08055; --accent-soft:#3A1B0E; --accent-strong:#F5A07E;
    --accent-fill:#E26534; --accent-fill-hov:#F08055; --accent-fg:#13110E;
  }
}

/* ====== BASE ====== */
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{background:var(--bg);color:var(--fg);font-family:var(--f-ui);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}
a{color:var(--accent-strong);text-decoration:none}
a:hover{text-decoration:underline}
code{font-family:var(--f-mono)}

/* Focus-visible: always show a clear ring on keyboard focus */
:focus{outline:none}
:focus-visible{outline:2px solid var(--accent);outline-offset:2px;box-shadow:var(--focus-ring);border-radius:var(--r-sm)}
button:focus-visible,a:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline-offset:2px}

/* Reduced motion: kill pulse, fade transitions to 0.01s */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:0.01ms !important;animation-iteration-count:1 !important;transition-duration:0.01ms !important}
}

/* ====== LAYOUT — no-sidebar (login, check_email, danger) ====== */
.wrap{max-width:720px;margin:0 auto;padding:32px 16px 64px}
.wrap.wide{max-width:1080px}
.loft-footer{text-align:center;color:var(--fg-subtle);font-size:11px;margin-top:32px;padding:16px;font-family:var(--f-mono)}

/* ====== APP SHELL ====== */
.app{display:grid;grid-template-columns:240px 1fr;min-height:100vh}
.app.with-rail{grid-template-columns:240px 1fr 320px}
@media (max-width:1180px){.app.with-rail{grid-template-columns:240px 1fr}.app.with-rail .rail{display:none}}
@media (max-width:760px){
  .app,.app.with-rail{grid-template-columns:1fr}
  .side{position:fixed;left:0;top:0;bottom:0;width:280px;transform:translateX(-100%);transition:transform .2s ease;z-index:50;box-shadow:var(--sh-pop)}
  .side.open{transform:translateX(0)}
  .mobile-bar{display:flex !important}
  .main{padding:16px !important}
}

/* ====== SIDEBAR ====== */
.side{background:var(--bg-panel);border-right:1px solid var(--border);padding:20px 14px;display:flex;flex-direction:column;gap:24px;position:sticky;top:0;height:100vh}
.lockup{display:flex;align-items:center;gap:8px;font-family:var(--f-mono);font-weight:700;font-size:18px;letter-spacing:-0.02em;color:var(--fg);padding:4px 8px}
.lockup svg{flex-shrink:0}
.nav{display:flex;flex-direction:column;gap:2px;flex:1}
.nav-group{font-family:var(--f-mono);font-size:10px;color:var(--fg-subtle);text-transform:uppercase;letter-spacing:.08em;padding:12px 8px 4px}
.nav a{display:flex;align-items:center;gap:10px;padding:7px 10px;border-radius:var(--r-md);color:var(--fg-muted);text-decoration:none;font-size:13px;font-weight:500}
.nav a:hover{background:var(--bg-elev);color:var(--fg);text-decoration:none}
.nav a.active{background:var(--bg-elev);color:var(--fg);box-shadow:inset 2px 0 0 var(--accent);padding-left:8px}
.nav a svg{width:16px;height:16px;flex-shrink:0;opacity:.85}
.nav .count{margin-left:auto;font-family:var(--f-mono);font-size:11px;color:var(--fg-subtle)}
/* `is-soon` items are surfaces the v0 backend doesn't yet support — see
   src/agentdrive/features.py. Dimmed so visitors immediately see what's
   real vs roadmap; still clickable so they can browse the design preview. */
.nav a.is-soon{opacity:.55}
.nav a.is-soon:hover{opacity:.85;background:var(--bg-elev);color:var(--fg-muted)}
.nav .soon-badge{margin-left:auto;font-family:var(--f-mono);font-size:9px;font-weight:600;color:var(--fg-subtle);background:var(--bg-elev);border:1px solid var(--border-sub);border-radius:3px;padding:1px 6px;text-transform:uppercase;letter-spacing:.05em}
/* Page-level dimming for soon surfaces. Everything in <main> drops to
   60% opacity; the preview banner (`.alert.mock-banner` or any other
   `.alert`) stays fully visible so visitors don't miss the "ships in v1"
   message. JS no-op interceptor in base.html prevents button / form /
   btn-link clicks from acting. The cursor change here is the visual cue
   that the button is intentionally inert. */
.main.is-soon-page > *{opacity:.6}
.main.is-soon-page > .alert{opacity:1}
.main.is-soon-page button:not([disabled]),
.main.is-soon-page a.btn,
.main.is-soon-page a[class*=" btn-"],
.main.is-soon-page a[class^="btn-"]{cursor:not-allowed}
.userblock{font-size:12px;color:var(--fg-muted);border-top:1px solid var(--border);padding-top:12px;display:flex;align-items:center;gap:8px;min-width:0}
.userblock .email{font-family:var(--f-mono);font-size:11px;color:var(--fg-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0}
.userblock .user-meta{line-height:1.3;flex:1;min-width:0;overflow:hidden}
.userblock .user-meta .name{color:var(--fg);font-size:12px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.userblock .user-meta .addr{font-family:var(--f-mono);font-size:11px;color:var(--fg-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.avatar{width:24px;height:24px;border-radius:50%;background:var(--accent-fill);color:var(--accent-fg);display:inline-flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;flex-shrink:0;font-family:var(--f-mono)}

/* Drive card pinned to bottom of the sidebar nav */
.drive-card{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--r-md);padding:10px 12px;font-size:12px}
.drive-card .label{font-family:var(--f-mono);font-size:10px;color:var(--fg-subtle);text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px}
.drive-card .id{font-family:var(--f-mono);font-size:12px;color:var(--fg);margin-bottom:8px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.drive-card .bar{height:4px;background:var(--bg-sunken);border-radius:2px;overflow:hidden}
.drive-card .fill{height:100%;background:var(--accent);border-radius:2px}
.drive-card .usage{display:flex;justify-content:space-between;margin-top:6px;font-family:var(--f-mono);font-size:10px;color:var(--fg-muted)}

/* Sidebar action row (theme toggle, sign out) — sits below userblock */
.side-actions{display:flex;gap:6px;border-top:1px solid var(--border);padding-top:10px;margin-top:-12px}
.side-actions form{margin:0;flex:1;display:flex}
.side-actions .btn{flex:1;justify-content:center;font-family:var(--f-mono);font-size:11px;padding:5px 8px;color:var(--fg-muted)}
.side-actions .btn:hover{color:var(--fg)}

/* Mobile bar (hidden by default, shown <760px) */
.mobile-bar{display:none;align-items:center;gap:10px;padding:10px 16px;background:var(--bg-panel);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:40}
.mobile-bar .ham{background:transparent;border:1px solid var(--border-strong);border-radius:var(--r-md);width:34px;height:34px;display:inline-flex;align-items:center;justify-content:center;color:var(--fg);cursor:pointer}
.mobile-bar .grow{flex:1}

/* ====== MAIN ====== */
.main{padding:24px 32px 64px;min-width:0;overflow:hidden}
.main.wide{padding:0}

/* ====== TOPBAR ====== */
.topbar{display:flex;align-items:center;gap:12px;margin-bottom:24px;flex-wrap:wrap}
.breadcrumb{font-family:var(--f-mono);font-size:13px;color:var(--fg-muted);display:flex;align-items:center;gap:6px;min-width:0;overflow:hidden}
.breadcrumb a{color:var(--fg-muted);text-decoration:none}
.breadcrumb a:hover{color:var(--fg)}
.breadcrumb .crumb-current{color:var(--fg);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.breadcrumb .sep{color:var(--fg-subtle);flex-shrink:0}
.topbar .grow{flex:1}
.search{position:relative;width:340px;max-width:100%}
.search input{width:100%;padding:7px 12px 7px 32px;font-family:var(--f-ui);font-size:13px;border:1px solid var(--border-strong);border-radius:var(--r-md);background:var(--bg-panel);color:var(--fg)}
.search svg{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--fg-subtle)}
.search .hint{position:absolute;right:10px;top:50%;transform:translateY(-50%);font-family:var(--f-mono);font-size:10px;color:var(--fg-subtle);background:var(--bg-elev);padding:2px 5px;border-radius:3px;border:1px solid var(--border)}

/* ====== PAGE HEAD (h1 + sub-meta row) ====== */
.head{margin-bottom:20px}
.h-title{font-size:22px;font-weight:700;letter-spacing:-0.01em;margin:0 0 4px;display:flex;align-items:center;gap:8px}
.h-sub{color:var(--fg-muted);font-size:13px;margin:0;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.h-sub .dot{width:3px;height:3px;background:var(--fg-subtle);border-radius:50%;flex-shrink:0}
.h-sub .mono{font-family:var(--f-mono);font-size:12px}
.h-sub a{color:var(--fg-muted)}
.h-sub a:hover{color:var(--accent-strong)}

/* Section heading for stacked .card-pad blocks */
.card-pad h2{font-size:15px;font-weight:600;margin:0 0 4px;letter-spacing:-0.005em}
.card-pad .sub{color:var(--fg-muted);font-size:13px;margin:0 0 14px}

/* Inline action row inside cards (rotate + delete pair, etc.) */
.row-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center}

/* Folder-row prefix glyph (kept lightweight; pairs the .kind chip with text) */
.tbl tr.row-folder td.path a{font-weight:600;color:var(--fg)}
.tbl tr.row-folder td.path a:hover{color:var(--accent-strong)}

/* Path cell — mono, link is fg, hover ember */
.tbl td.path a{color:var(--fg);text-decoration:none;font-family:var(--f-mono)}
.tbl td.path a:hover{color:var(--accent-strong)}
.tbl td.size,.tbl td.updated{color:var(--fg-muted);font-family:var(--f-mono);font-size:12px}

/* Search-result snippet cell — highlight emphasized matches */
.tbl td.snippet{font-size:12px;color:var(--fg-muted);font-family:var(--f-mono);max-width:360px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.tbl td.snippet b,.tbl td.snippet mark{background:var(--accent-soft);color:var(--accent-strong);font-weight:600;padding:0 2px;border-radius:2px}

/* Mono inline code inside body text */
.inline-code{font-family:var(--f-mono);font-size:12px;background:var(--bg-elev);padding:1px 6px;border-radius:3px;color:var(--fg)}

/* Auth hero (login + check-email) — small lockup mark above card */
.auth-hero{max-width:380px;margin:64px auto 24px;text-align:center}
.auth-hero .mark{width:48px;height:48px;margin:0 auto 16px;background:var(--accent-soft);border-radius:var(--r-lg);display:inline-flex;align-items:center;justify-content:center;color:var(--accent-strong)}
.auth-hero h1{font-size:22px;font-weight:700;letter-spacing:-0.01em;margin:0 0 6px}
.auth-hero p{color:var(--fg-muted);font-size:13px;margin:0}
.auth-card{max-width:380px;margin:0 auto}
.auth-card form{display:flex;flex-direction:column;gap:12px}
.auth-card label{font-family:var(--f-mono);font-size:11px;color:var(--fg-muted);text-transform:uppercase;letter-spacing:.06em}
.auth-card .input{width:100%;min-width:0}
.auth-card .btn{width:100%;justify-content:center}

/* ====== BUTTONS ====== */
.btn{font-family:var(--f-ui);font-size:13px;font-weight:500;padding:7px 14px;border-radius:var(--r-md);border:1px solid transparent;cursor:pointer;display:inline-flex;align-items:center;gap:6px;text-decoration:none;line-height:1.4}
.btn:disabled,.btn[aria-disabled="true"]{opacity:.5;cursor:not-allowed}
.btn-primary{background:var(--accent-fill);color:var(--accent-fg);border-color:var(--accent-fill)}
.btn-primary:hover:not(:disabled){background:var(--accent-fill-hov);border-color:var(--accent-fill-hov)}
.btn-secondary{background:var(--bg-panel);color:var(--fg);border-color:var(--border-strong)}
.btn-secondary:hover:not(:disabled){background:var(--bg-elev)}
.btn-ghost{background:transparent;color:var(--fg)}
.btn-ghost:hover:not(:disabled){background:var(--bg-elev)}
.btn-danger{background:var(--bg-panel);color:var(--danger-strong);border-color:var(--border-strong)}
.btn-danger:hover:not(:disabled){background:var(--danger-bg);border-color:var(--danger);color:var(--danger-strong)}
.btn-ink{background:var(--ink);color:var(--ink-fg);border-color:var(--ink)}
.btn-ink:hover:not(:disabled){background:var(--ink-elev)}
.btn-mono{font-family:var(--f-mono);font-size:12px}
.btn-sm{padding:4px 10px;font-size:12px}
.btn-lg{padding:10px 18px;font-size:14px}

/* ====== INPUTS ====== */
.input{font-family:var(--f-ui);font-size:13px;padding:8px 12px;border-radius:var(--r-md);border:1px solid var(--border-strong);background:var(--bg-panel);color:var(--fg);min-width:240px}
.input:focus-visible{outline:none;border-color:var(--accent);box-shadow:var(--focus-ring)}
.input.mono{font-family:var(--f-mono)}
.input[aria-invalid="true"]{border-color:var(--danger);box-shadow:0 0 0 3px var(--danger-bg)}

/* ====== BADGE ====== */
.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 7px;font-size:11px;font-family:var(--f-mono);border-radius:999px;border:1px solid var(--border);background:var(--bg-panel);color:var(--fg-muted);letter-spacing:.02em}
.badge.solid-accent{background:var(--accent-soft);color:var(--accent-strong);border-color:transparent}
.badge.solid-info{background:var(--info-bg);color:var(--info-strong);border-color:transparent}
.badge.solid-warn{background:var(--warn-bg);color:var(--warn-strong);border-color:transparent}
.badge.solid-danger{background:var(--danger-bg);color:var(--danger-strong);border-color:transparent}
.badge.solid-success{background:var(--success-bg);color:var(--success);border-color:transparent}
.badge.dot::before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor}

/* ====== KIND CHIP ====== */
.kind{display:inline-flex;align-items:center;gap:5px;padding:2px 7px 2px 5px;font-size:11px;font-family:var(--f-mono);border-radius:4px;background:var(--bg-elev);color:var(--fg-muted);border:1px solid var(--border-sub);font-weight:600}
.kind[data-k="md"]{color:var(--k-md)}
.kind[data-k="code"]{color:var(--k-code)}
.kind[data-k="image"]{color:var(--k-image)}
.kind[data-k="video"]{color:var(--k-video)}
.kind[data-k="dataset"]{color:var(--k-dataset)}
.kind[data-k="skill"]{color:var(--k-skill)}
.kind[data-k="bundle"]{color:var(--k-bundle)}
.kind[data-k="folder"]{color:var(--k-folder)}

/* ====== VIS PILL ====== */
.vis{display:inline-flex;align-items:center;gap:4px;font-family:var(--f-mono);font-size:11px;padding:2px 7px;border-radius:999px;border:1px solid var(--border-sub)}
.vis.public{color:var(--accent-strong);background:var(--accent-soft);border-color:transparent}
.vis.private{color:var(--fg-muted);background:var(--bg-elev)}
.vis.unlisted{color:var(--info-strong);background:var(--info-bg);border-color:transparent}
.vis::before{content:"";width:5px;height:5px;background:currentColor;border-radius:50%}

/* ====== AGENT TAG ====== */
.agent-tag{display:inline-flex;align-items:center;gap:6px;font-family:var(--f-mono);font-size:11px;color:var(--fg-muted)}
.agent-tag::before{content:"";width:6px;height:6px;background:var(--accent);border-radius:50%;display:inline-block;flex-shrink:0}
.agent-tag.user::before{background:var(--fg-subtle)}
.agent-tag.gpt::before{background:var(--info)}
.agent-tag.claude::before{background:var(--accent)}

/* ====== TABLE ====== */
.tbl{width:100%;border-collapse:collapse;background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden;table-layout:auto}
.tbl th,.tbl td{padding:9px 14px;text-align:left;border-bottom:1px solid var(--border-sub);font-size:13px}
.tbl th{background:var(--bg-elev);font-size:10px;font-weight:600;color:var(--fg-muted);text-transform:uppercase;letter-spacing:.04em}
.tbl tr:last-child td{border-bottom:0}
.tbl tr:hover td{background:var(--bg-elev)}
.tbl tr.selected td{background:var(--accent-soft)}
.tbl tr.selected:hover td{background:var(--accent-soft)}
.tbl td.mono,.tbl td .mono{font-family:var(--f-mono)}

/* Long-data table: makes columns truncate with ellipsis */
.tbl-trunc{table-layout:fixed}
.tbl-trunc td{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:0}

/* ====== CONSOLE ====== */
.console{background:var(--ink);color:var(--ink-fg);border-radius:var(--r-md);padding:16px;font-family:var(--f-mono);font-size:12px;line-height:1.7;overflow-x:auto;white-space:pre}
.console .c-prompt{color:var(--machine)}
.console .c-comment{color:var(--ink-fg-muted)}
.console .c-string{color:var(--spectral)}
.console .c-key{color:var(--accent)}

/* ====== CARD ====== */
.card{background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden}
.card-pad{padding:20px}

/* ====== KV ====== */
.kv{display:grid;grid-template-columns:100px 1fr;gap:8px 14px}
.kv dt{font-family:var(--f-mono);font-size:11px;color:var(--fg-muted);letter-spacing:.02em}
.kv dd{margin:0;font-family:var(--f-mono);font-size:12px;color:var(--fg);overflow:hidden;text-overflow:ellipsis}

/* ====== AGENT ACTIVITY FEED (rail + standalone page) ====== */
.feed{display:flex;flex-direction:column;gap:0;position:relative}
.feed::before{content:"";position:absolute;left:7px;top:8px;bottom:8px;width:1px;background:var(--border-strong)}
.ev{display:grid;grid-template-columns:16px 1fr;gap:10px;padding:8px 0;font-size:12px}
.ev .marker{width:8px;height:8px;border-radius:50%;background:var(--accent);margin-top:5px;border:2px solid var(--bg-panel);position:relative;z-index:1;justify-self:center}
.ev .marker.user{background:var(--fg-subtle)}
.ev .marker.share{background:var(--info)}
.ev .marker.delete{background:var(--danger)}
.ev .when{font-family:var(--f-mono);font-size:10px;color:var(--fg-subtle);margin-bottom:2px}
.ev .who{font-family:var(--f-mono);font-size:11px;color:var(--fg-muted)}
.ev .what{color:var(--fg);margin-top:2px;line-height:1.4}
.ev .what code{font-family:var(--f-mono);font-size:11px;background:var(--bg-elev);padding:1px 5px;border-radius:3px;color:var(--fg)}
.feed-sub{font-size:12px;color:var(--fg-muted);margin:0 0 16px;display:flex;align-items:center;gap:6px}

/* ====== PULSE ====== */
.pulse{width:8px;height:8px;border-radius:50%;background:var(--accent);position:relative;display:inline-block;flex-shrink:0}
.pulse::after{content:"";position:absolute;inset:-4px;border-radius:50%;border:2px solid var(--accent);opacity:.3;animation:pulse 1.6s ease-out infinite}
@keyframes pulse{0%{transform:scale(.6);opacity:.6}100%{transform:scale(1.6);opacity:0}}

/* ====== PILL FILTER ====== */
.pill{display:inline-flex;align-items:center;gap:5px;font-family:var(--f-mono);font-size:11px;padding:5px 10px;border-radius:999px;background:var(--bg-panel);border:1px solid var(--border-strong);color:var(--fg-muted);cursor:pointer;text-decoration:none}
.pill:hover{color:var(--fg);background:var(--bg-elev);text-decoration:none}
.pill.active{background:var(--fg);color:var(--bg);border-color:var(--fg)}
.pill .count{opacity:.55;font-size:10px}

/* ====== MODAL ====== */
.scrim{position:fixed;inset:0;background:rgba(26,23,20,.42);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:100}
.modal{background:var(--bg-panel);border-radius:var(--r-xl);box-shadow:var(--sh-pop);width:520px;max-width:calc(100vw - 32px);overflow:hidden}
.modal-head{padding:18px 22px 14px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--border-sub)}
.modal-head .ttl{font-size:15px;font-weight:600;margin:0;flex:1}
.modal-head .close{background:transparent;border:0;color:var(--fg-muted);cursor:pointer;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px}
.modal-head .close:hover{background:var(--bg-elev);color:var(--fg)}
.modal-body{padding:18px 22px}
.modal-foot{padding:14px 22px;border-top:1px solid var(--border-sub);display:flex;justify-content:flex-end;gap:8px;background:var(--bg-elev)}

/* ====== SKELETON ====== */
.skeleton{background:linear-gradient(90deg,var(--bg-elev) 0%,var(--bg-sunken) 50%,var(--bg-elev) 100%);background-size:200% 100%;animation:skel 1.4s ease-in-out infinite;border-radius:var(--r-sm)}
.skeleton.line{height:12px;margin:6px 0}
.skeleton.line.short{width:40%}
.skeleton.line.med{width:65%}
.skeleton.line.long{width:88%}
.skeleton.title{height:22px;width:55%;margin:0 0 12px}
.skeleton.avatar{width:32px;height:32px;border-radius:50%}
.skeleton.thumb{aspect-ratio:4/3;border-radius:var(--r-md)}
.skeleton.btn{width:120px;height:28px;border-radius:var(--r-md)}
@keyframes skel{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* ====== EMPTY STATE ====== */
.empty{text-align:center;padding:48px 24px;color:var(--fg-muted)}
.empty .ico{width:48px;height:48px;border-radius:var(--r-lg);background:var(--bg-elev);display:inline-flex;align-items:center;justify-content:center;color:var(--fg-subtle);margin-bottom:14px}
.empty h3{font-size:15px;color:var(--fg);margin:0 0 4px;font-weight:600}
.empty p{font-size:13px;margin:0 0 14px;max-width:340px;margin-left:auto;margin-right:auto;line-height:1.5}
.empty .actions{display:inline-flex;gap:8px;flex-wrap:wrap;justify-content:center}

/* ====== PAGE-LEVEL EMPTY / ERROR (pagebox) ====== */
.pagebox{background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--r-lg);min-height:340px;display:flex;align-items:center;justify-content:center;flex-direction:column;padding:32px;text-align:center}
.pagebox h2{font-size:20px;font-weight:700;letter-spacing:-0.01em;margin:0 0 6px}
.pagebox p{color:var(--fg-muted);font-size:14px;margin:0 0 18px;max-width:420px;line-height:1.55}
.pagebox .code{font-family:var(--f-mono);font-size:10px;color:var(--fg-subtle);margin-top:14px}
.pagebox .ico-lg{width:56px;height:56px;border-radius:var(--r-xl);display:inline-flex;align-items:center;justify-content:center;margin-bottom:18px}
.pagebox .ico-lg.info{background:var(--accent-soft);color:var(--accent-strong)}
.pagebox .ico-lg.warn{background:var(--warn-bg);color:var(--warn-strong)}
.pagebox .ico-lg.danger{background:var(--danger-bg);color:var(--danger-strong)}

/* ====== INLINE ERROR / ALERT ====== */
.alert{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;border-radius:var(--r-md);border:1px solid;font-size:13px;line-height:1.45}
.alert .ico{flex-shrink:0;margin-top:1px}
.alert-info{background:var(--info-bg);color:var(--info-strong);border-color:transparent}
.alert-warn{background:var(--warn-bg);color:var(--warn-strong);border-color:transparent}
.alert-danger{background:var(--danger-bg);color:var(--danger-strong);border-color:transparent}
.alert-success{background:var(--success-bg);color:var(--success);border-color:transparent}
.alert strong{font-weight:600}

/* ====== PROGRESS ====== */
.progress{width:200px;height:6px;background:var(--bg-elev);border-radius:3px;overflow:hidden}
.progress .bar{height:100%;background:var(--accent-fill);border-radius:3px;width:62%}
.progress.indeterminate .bar{width:35%;animation:indet 1.4s ease-in-out infinite}
@keyframes indet{0%{margin-left:-35%}100%{margin-left:100%}}

/* ====== SPINNER ====== */
.spinner{width:14px;height:14px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;display:inline-block;animation:spin .8s linear infinite;vertical-align:-2px}
@keyframes spin{to{transform:rotate(360deg)}}

/* ====== AVATAR (deterministic palette) ======
   Add data-h="0".."7" to assign a stable color from the avatar palette.
   In code: pick (hash(handle) % 8) and set data-h.
*/
.av{display:inline-flex;align-items:center;justify-content:center;background:var(--av-1);color:#fff;font-weight:700;font-family:var(--f-mono);width:32px;height:32px;border-radius:50%;font-size:12px;flex-shrink:0}
.av.sq{border-radius:6px}
.av.lg{width:48px;height:48px;font-size:16px;border-radius:8px}
.av.xl{width:88px;height:88px;font-size:36px;border-radius:var(--r-xl)}
.av.sm{width:20px;height:20px;font-size:10px}
.av[data-h="0"]{background:var(--av-1)}
.av[data-h="1"]{background:var(--av-2)}
.av[data-h="2"]{background:var(--av-3)}
.av[data-h="3"]{background:var(--av-4)}
.av[data-h="4"]{background:var(--av-5)}
.av[data-h="5"]{background:var(--av-6)}
.av[data-h="6"]{background:var(--av-7)}
.av[data-h="7"]{background:var(--av-8)}

/* ====== TRUNCATION ====== */
.trunc{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}
.clamp-2{display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.clamp-3{display:-webkit-box;-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.path-trunc{font-family:var(--f-mono);direction:rtl;text-align:left;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.path-trunc>span{direction:ltr;unicode-bidi:bidi-override}

/* ====== TOAST ====== */
.toast{background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--r-md);padding:10px 14px 10px 12px;box-shadow:var(--sh-2);display:inline-flex;align-items:center;gap:10px;font-size:13px;max-width:380px}
.toast .toast-ico{width:24px;height:24px;border-radius:50%;background:var(--accent-soft);color:var(--accent-strong);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.toast.success .toast-ico{background:var(--success-bg);color:var(--success)}
.toast.danger .toast-ico{background:var(--danger-bg);color:var(--danger-strong)}
.toast .toast-ttl{font-weight:600;font-size:13px;margin:0}
.toast .toast-sub{color:var(--fg-muted);font-size:11px;margin:1px 0 0;font-family:var(--f-mono)}

/* ====== TABS / SEGMENTED ====== */
.tabs{display:inline-flex;background:var(--bg-panel);border:1px solid var(--border-strong);border-radius:var(--r-md);padding:3px;font-family:var(--f-mono);font-size:11px}
.tabs button{background:transparent;border:0;color:var(--fg-muted);padding:5px 12px;border-radius:4px;cursor:pointer;font-family:var(--f-mono);font-size:11px}
.tabs button.active{background:var(--ink);color:var(--ink-fg)}
.seg{display:inline-flex;border:1px solid var(--border-strong);border-radius:var(--r-md);overflow:hidden;background:var(--bg-panel)}
.seg button{background:transparent;border:0;padding:6px 12px;font-family:var(--f-mono);font-size:11px;color:var(--fg-muted);cursor:pointer;border-right:1px solid var(--border-strong)}
.seg button:last-child{border-right:0}
.seg button.active{background:var(--bg-elev);color:var(--fg)}

/* ====== CHECK / RADIO / TOGGLE ====== */
.check{display:inline-flex;align-items:center;gap:8px;font-size:13px;cursor:pointer}
.check input{appearance:none;-webkit-appearance:none;width:16px;height:16px;border-radius:4px;border:1.5px solid var(--border-strong);background:var(--bg-panel);position:relative;cursor:pointer;margin:0}
.check input:checked{background:var(--accent-fill);border-color:var(--accent-fill)}
.check input:checked::after{content:"";position:absolute;left:4px;top:1px;width:5px;height:9px;border-right:2px solid #fff;border-bottom:2px solid #fff;transform:rotate(45deg)}
.radio{display:inline-flex;align-items:center;gap:8px;font-size:13px;cursor:pointer}
.radio input{appearance:none;-webkit-appearance:none;width:16px;height:16px;border-radius:50%;border:1.5px solid var(--border-strong);background:var(--bg-panel);position:relative;cursor:pointer;margin:0}
.radio input:checked{border-color:var(--accent)}
.radio input:checked::after{content:"";position:absolute;inset:3px;background:var(--accent);border-radius:50%}
.toggle{position:relative;display:inline-block;width:36px;height:20px}
.toggle input{opacity:0;width:0;height:0}
.toggle .slider{position:absolute;cursor:pointer;inset:0;background:var(--border-strong);border-radius:999px;transition:.2s}
.toggle .slider::before{position:absolute;content:"";height:16px;width:16px;left:2px;top:2px;background:#fff;border-radius:50%;transition:.2s;box-shadow:0 1px 2px rgba(0,0,0,.15)}
.toggle input:checked + .slider{background:var(--accent-fill)}
.toggle input:checked + .slider::before{transform:translateX(16px)}

/* ====== KBD chip (keyboard-shortcut hint) ====== */
kbd.k-hint{font-family:var(--f-mono);font-size:10px;color:var(--fg-subtle);background:var(--bg-elev);padding:2px 6px;border-radius:3px;border:1px solid var(--border);line-height:1}

/* ====== INLINE ROW ACTIONS (used on dashboard topbar) ====== */
.tbl-actions{display:flex;align-items:center;gap:8px;margin-bottom:14px;flex-wrap:wrap}
.tbl-actions .grow{flex:1}
.tbl-actions .btn-mono{font-family:var(--f-mono);font-size:12px}

/* ====== MOCK BANNER (preview-mode strip across the top of mock surfaces) ====== */
.mock-banner{margin:0;border-radius:0;padding:8px 24px;justify-content:center;font-family:var(--f-mono);font-size:11px;border-left:0;border-right:0;border-top:0}

/* ====== FIELD LABEL (mono-uppercase form-label style, used on danger/auth) ====== */
.field-label{font-family:var(--f-mono);font-size:11px;color:var(--fg-muted);text-transform:uppercase;letter-spacing:.06em}

/* ============================================================================
   PUBLIC FILE VIEWER (rendered by src/agentdrive/render/*)
   No app shell — viewer is the public-URL chrome served at /{drive_id}/{path}.
   Two variants: owner (adds .owner-banner) and visitor (plain bar).
   Ports design/07-viewer-owner.html and design/08-viewer-visitor.html.
   ============================================================================ */

/* Sticky top bar shared by both variants */
.viewer-bar{position:sticky;top:0;background:var(--bg-panel);border-bottom:1px solid var(--border);padding:10px 24px;display:flex;align-items:center;gap:12px;z-index:10;box-shadow:var(--sh-1)}
.viewer-bar .grow{flex:1}
.viewer-bar .bar-sep{width:1px;height:18px;background:var(--border);flex-shrink:0}
.viewer-bar .lockup-sm{display:flex;align-items:center;gap:6px;font-family:var(--f-mono);font-weight:700;font-size:14px;color:var(--fg);text-decoration:none;flex-shrink:0}
.viewer-bar .lockup-sm svg{flex-shrink:0}
.viewer-bar .lockup-sm:hover{color:var(--accent-strong);text-decoration:none}

/* Path display (owner): kind chip + mono path with filename bold */
.viewer-bar .path-display{font-family:var(--f-mono);font-size:12px;color:var(--fg-muted);display:flex;align-items:center;gap:6px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0;flex:1}
.viewer-bar .path-display strong{color:var(--fg);font-weight:600}
.viewer-bar .path-display .kind{flex-shrink:0}
.viewer-bar .path-display .path-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}

/* Theme-toggle button in the viewer bar */
.viewer-bar .bar-theme{background:transparent;border:1px solid var(--border-strong);color:var(--fg-muted);padding:4px 10px;border-radius:var(--r-md);cursor:pointer;font-family:var(--f-mono);font-size:11px}
.viewer-bar .bar-theme:hover{background:var(--bg-elev);color:var(--fg)}

/* Owner banner — shown when the requester owns this drive */
.owner-banner{background:var(--accent-soft);color:var(--accent-strong);font-family:var(--f-mono);font-size:11px;padding:8px 24px;text-align:center;display:flex;align-items:center;justify-content:center;gap:8px}
.owner-banner svg{flex-shrink:0}
.owner-banner a{color:var(--accent-strong);text-decoration:underline;font-weight:600}

/* Viewer layout — single column, centered, generous reading width */
.viewer-layout{max-width:760px;margin:0 auto;padding:48px 32px 80px}

/* Article typography — replaces github-markdown-css with Loft-native styles.
   Used by markdown.html viewer; mirrors design/08-viewer-visitor.html. */
.viewer-article{color:var(--fg)}
.viewer-article .hero-meta{display:flex;align-items:center;gap:10px;color:var(--fg-muted);font-size:13px;margin-bottom:20px;flex-wrap:wrap;font-family:var(--f-mono)}
.viewer-article .hero-meta .dot{width:3px;height:3px;background:var(--fg-subtle);border-radius:50%;flex-shrink:0}
.viewer-article h1{font-size:34px;font-weight:700;letter-spacing:-0.02em;margin:0 0 16px;line-height:1.15}
.viewer-article h2{font-size:22px;font-weight:600;margin:36px 0 12px;padding-bottom:8px;border-bottom:1px solid var(--border-sub)}
.viewer-article h3{font-size:18px;font-weight:600;margin:28px 0 10px}
.viewer-article h4{font-size:15px;font-weight:600;margin:20px 0 8px}
.viewer-article p{font-size:16px;line-height:1.75;margin:0 0 16px}
.viewer-article ul,.viewer-article ol{font-size:16px;line-height:1.75;margin:0 0 16px;padding-left:24px}
.viewer-article ul li,.viewer-article ol li{margin-bottom:4px}
.viewer-article ul li::marker{color:var(--accent-strong)}
.viewer-article blockquote{margin:0 0 16px;padding:8px 16px;border-left:3px solid var(--accent);background:var(--bg-elev);color:var(--fg-muted);font-style:italic}
.viewer-article a{color:var(--accent-strong)}
.viewer-article a:hover{color:var(--accent-fill-hov)}
.viewer-article code{background:var(--bg-elev);padding:1px 6px;border-radius:3px;font-size:.92em;font-family:var(--f-mono);color:var(--fg)}
.viewer-article pre{background:var(--ink);color:var(--ink-fg);padding:16px 20px;border-radius:var(--r-md);font-family:var(--f-mono);font-size:13px;line-height:1.6;overflow-x:auto;margin:0 0 16px}
.viewer-article pre code{background:transparent;padding:0;color:inherit;font-size:inherit}
.viewer-article table{border-collapse:collapse;margin:16px 0;font-size:14px;width:100%}
.viewer-article th,.viewer-article td{border:1px solid var(--border);padding:8px 12px;text-align:left}
.viewer-article th{background:var(--bg-elev);font-weight:600}
.viewer-article hr{border:0;border-top:1px solid var(--border);margin:32px 0}
.viewer-article img{max-width:100%;height:auto;border-radius:var(--r-md)}
.viewer-article .task-list-item{list-style:none}
.viewer-article .task-list-item input{margin-right:6px}

/* Code viewer body — ink panel for syntax-highlighted source files */
.viewer-code{background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden}
.viewer-code pre{margin:0;padding:18px 22px;font-family:var(--f-mono);font-size:13px;line-height:1.6;color:var(--fg);overflow-x:auto}
.viewer-code .codehilite{background:transparent}

/* Image viewer body — centered with subtle panel */
.viewer-image{background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--r-lg);padding:32px;text-align:center}
.viewer-image img{max-width:100%;height:auto;border-radius:var(--r-md);box-shadow:var(--sh-1)}

/* PDF / HTML embed body */
.viewer-embed{background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;height:80vh}
.viewer-embed embed,.viewer-embed iframe{width:100%;height:100%;border:0;display:block;background:#fff}

/* Download fallback (binaries, archives) */
.viewer-download{background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--r-lg);padding:64px 32px;text-align:center}
.viewer-download h2{font-family:var(--f-mono);font-size:20px;font-weight:600;margin:0 0 8px;word-break:break-all;color:var(--fg)}
.viewer-download p{color:var(--fg-muted);font-size:13px;margin:0 0 24px;font-family:var(--f-mono)}

/* Machine-strip footer (visitor pattern, design/08): provenance for the
   reading agent — agent + tool + sha + raw/api links. */
.machine-strip{margin-top:48px;padding:14px 18px;background:var(--bg-elev);border-radius:var(--r-md);font-family:var(--f-mono);font-size:11px;color:var(--fg-muted);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px}
.machine-strip a{color:var(--fg)}
.machine-strip a:hover{color:var(--accent-strong)}
.machine-strip strong{color:var(--fg);font-weight:600}

/* Wiki banner (LLM-extracted summary + entity chips above the article).
   Three states: indexed (summary + chips), pending (spinner pulse), empty (hidden).
   Originally added in PR #5 with GitHub-style tokens; ported to Loft here. */
.wiki-banner{background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--r-md);padding:14px 16px;margin-bottom:20px;font-size:14px;color:var(--fg)}
.wiki-banner .label{font-family:var(--f-mono);font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--fg-subtle);margin-bottom:6px;font-weight:600}
.wiki-banner .summary{line-height:1.55;color:var(--fg)}
.wiki-banner .chips{margin-top:10px;display:flex;flex-wrap:wrap;gap:6px}
.wiki-banner .chip{display:inline-block;padding:3px 10px;border-radius:999px;background:var(--bg-elev);border:1px solid var(--border-sub);color:var(--accent-strong);text-decoration:none;font-size:12px;line-height:1.6;font-family:var(--f-mono)}
.wiki-banner .chip:hover{background:var(--bg);text-decoration:none}
.wiki-banner .chip.concept{font-style:italic}
.wiki-banner .pending{display:inline-flex;align-items:center;gap:8px;color:var(--fg-muted)}
.wiki-banner .pending .dot{width:8px;height:8px;border-radius:50%;background:var(--accent);animation:wiki-pulse 1.4s ease-in-out infinite}
@keyframes wiki-pulse{0%,100%{opacity:.35;transform:scale(.9)}50%{opacity:1;transform:scale(1.15)}}

/* Mobile: viewer-bar collapses padding; lockup stays */
@media (max-width:760px){
  .viewer-bar{padding:10px 14px}
  .viewer-layout{padding:24px 16px 64px}
  .viewer-article h1{font-size:26px}
  .owner-banner{padding:8px 14px;font-size:10px}
}

/* ====== SR-ONLY ====== */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* ====== WIDE MAIN (no padding — for hero/sticky-tabs layouts) ====== */
.main.wide{padding:0}

/* ====== HERO (light cream gradient, used on marketplace + detail) ====== */
.hero-section{padding:56px 48px 40px;background:linear-gradient(180deg,var(--bg-elev) 0%,var(--bg) 100%);border-bottom:1px solid var(--border-sub);position:relative;overflow:hidden}
.hero-section::before{content:"";position:absolute;top:-80px;right:-80px;width:340px;height:340px;background:radial-gradient(circle,var(--accent-soft) 0%,transparent 70%);pointer-events:none}
.hero-section-inner{max-width:980px;position:relative}
.hero-eyebrow{font-family:var(--f-mono);font-size:11px;color:var(--accent-strong);text-transform:uppercase;letter-spacing:.1em;margin-bottom:12px;display:flex;align-items:center;gap:8px}
.hero-section h1{font-size:38px;line-height:1.1;font-weight:700;letter-spacing:-0.025em;margin:0 0 12px;max-width:680px}
.hero-section h1 em{font-style:normal;color:var(--accent-strong)}
.hero-section .lede{color:var(--fg-muted);font-size:16px;line-height:1.55;margin:0 0 28px;max-width:560px}
.hero-search{position:relative;max-width:560px}
.hero-search input{width:100%;padding:14px 16px 14px 48px;font-family:var(--f-ui);font-size:15px;border:1px solid var(--border-strong);border-radius:var(--r-lg);background:var(--bg-panel);color:var(--fg);box-shadow:var(--sh-1)}
.hero-search input:focus-visible{outline:none;border-color:var(--accent);box-shadow:var(--focus-ring)}
.hero-search svg{position:absolute;left:18px;top:50%;transform:translateY(-50%);color:var(--fg-subtle)}
.hero-stats{display:flex;gap:32px;margin-top:32px;font-family:var(--f-mono);font-size:12px;color:var(--fg-muted);flex-wrap:wrap}
.hero-stats .stat{display:flex;flex-direction:column;gap:2px}
.hero-stats .num{font-family:var(--f-ui);font-size:22px;font-weight:700;letter-spacing:-0.01em;color:var(--fg)}
.hero-stats .lbl{font-size:11px;text-transform:uppercase;letter-spacing:.06em}

/* ====== KIND NAV (sticky filter row, used on marketplace) ====== */
.kind-nav{padding:20px 48px;background:var(--bg-panel);border-bottom:1px solid var(--border-sub);position:sticky;top:0;z-index:5;display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.kind-nav .grow{flex:1}
.kind-nav .pill .glyph{width:12px;height:12px;display:inline-flex;align-items:center;justify-content:center}
.sort-btn{font-family:var(--f-mono);font-size:11px;color:var(--fg-muted);background:transparent;border:0;cursor:pointer;display:inline-flex;align-items:center;gap:4px}
.sort-btn:hover{color:var(--fg)}

/* ====== SECTIONS (numbered headers used on marketplace + publisher) ====== */
.section{padding:36px 48px}
.section-head{display:flex;align-items:baseline;gap:12px;margin-bottom:18px}
.section-num{font-family:var(--f-mono);font-size:11px;color:var(--fg-subtle);letter-spacing:.08em;text-transform:uppercase}
.section-title{font-size:20px;font-weight:700;letter-spacing:-0.01em;margin:0}
.section-sub{color:var(--fg-muted);font-size:13px;margin:0 0 0 auto}
.section-link{color:var(--accent-strong);font-size:12px;text-decoration:none;font-weight:500}
.section-link:hover{text-decoration:underline}

/* ====== ARTIFACT CARDS (grid + featured variants) ====== */
.featured{display:grid;grid-template-columns:2fr 1fr 1fr;gap:16px}
.feat{background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--r-xl);overflow:hidden;display:flex;flex-direction:column;text-decoration:none;color:inherit;transition:transform .12s ease,box-shadow .12s ease}
.feat:hover{transform:translateY(-1px);box-shadow:var(--sh-2);text-decoration:none}
.feat .cover{aspect-ratio:16/9;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;color:#fff;font-family:var(--f-mono);font-size:13px;text-align:center}
.feat .cover .badge-tl{position:absolute;top:12px;left:12px;background:rgba(26,23,20,.6);color:#fff;font-family:var(--f-mono);font-size:10px;padding:3px 8px;border-radius:999px;backdrop-filter:blur(8px);letter-spacing:.04em;text-transform:uppercase}
.feat .body{padding:16px;display:flex;flex-direction:column;gap:6px;flex:1}
.feat .by{font-family:var(--f-mono);font-size:11px;color:var(--fg-muted);display:flex;align-items:center;gap:6px}
.feat .by .av{width:14px;height:14px;border-radius:50%;background:var(--fg-subtle);font-size:0}
.feat .ttl{font-size:15px;font-weight:600;letter-spacing:-0.01em;line-height:1.3;margin:0;color:var(--fg)}
.feat .desc{font-size:13px;color:var(--fg-muted);line-height:1.45;margin:4px 0 0;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.feat .meta{display:flex;align-items:center;gap:8px;margin-top:auto;padding-top:10px;font-family:var(--f-mono);font-size:11px;color:var(--fg-muted);flex-wrap:wrap}
.feat .meta .dot{width:3px;height:3px;background:var(--fg-subtle);border-radius:50%;flex-shrink:0}
.feat .meta .live{color:var(--accent-strong);display:inline-flex;align-items:center;gap:4px}
.feat .meta .live::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--accent)}

.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}
.acard{background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;display:flex;flex-direction:column;text-decoration:none;color:inherit;transition:transform .12s ease,box-shadow .12s ease}
.acard:hover{transform:translateY(-1px);box-shadow:var(--sh-2);text-decoration:none}
.acard .cover{aspect-ratio:4/3;background:var(--bg-elev);position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;color:#fff;font-family:var(--f-mono);font-size:11px;text-align:center;padding:0 12px;line-height:1.25}
.acard .save{position:absolute;top:8px;right:8px;background:rgba(255,255,255,.92);border:1px solid var(--border-strong);width:28px;height:28px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;color:var(--fg);font-family:var(--f-mono);font-size:14px;cursor:pointer;backdrop-filter:blur(8px)}
.acard .save:hover{background:#fff;color:var(--accent-strong)}
.acard .body{padding:12px 14px;display:flex;flex-direction:column;gap:4px;flex:1}
.acard .ttl{font-size:13px;font-weight:600;letter-spacing:-0.005em;line-height:1.35;margin:0;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;color:var(--fg)}
.acard .by{font-family:var(--f-mono);font-size:10px;color:var(--fg-muted)}
.acard .meta{display:flex;align-items:center;gap:6px;margin-top:8px;font-family:var(--f-mono);font-size:10px;color:var(--fg-muted)}

/* ====== RECENT LIST (just-published rows on marketplace) ====== */
.recent-list{background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden}
.recent-row{display:grid;grid-template-columns:40px 1fr 120px 100px 80px;gap:14px;padding:12px 16px;align-items:center;border-bottom:1px solid var(--border-sub);text-decoration:none;color:inherit}
.recent-row:last-child{border-bottom:0}
.recent-row:hover{background:var(--bg-elev);text-decoration:none}
.recent-row .thumb{width:40px;height:40px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;color:#fff;font-family:var(--f-mono);font-size:10px;font-weight:700}
.recent-row .name{font-weight:600;font-size:13px;margin:0 0 2px;color:var(--fg)}
.recent-row .by{font-family:var(--f-mono);font-size:11px;color:var(--fg-muted)}
.recent-row .stat{font-family:var(--f-mono);font-size:11px;color:var(--fg-muted);text-align:right}
.recent-row .when{font-family:var(--f-mono);font-size:11px;color:var(--fg-subtle);text-align:right}

/* ====== PUBLISHER MINI-CARDS (marketplace section 04) ====== */
.publishers{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}
.pub{background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--r-lg);padding:14px;display:flex;align-items:center;gap:12px;text-decoration:none;color:inherit}
.pub:hover{background:var(--bg-elev);text-decoration:none}
.pub .h{font-family:var(--f-mono);font-size:12px;font-weight:600;color:var(--fg);line-height:1.3}
.pub .s{font-family:var(--f-mono);font-size:10px;color:var(--fg-muted);margin-top:2px}

/* ====== CONSOLE BANNER (ink-surface CTA on marketplace) ====== */
.console-banner{background:var(--ink);color:var(--ink-fg);border-radius:var(--r-lg);margin:0 48px;padding:24px 28px;display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
.console-banner .lhs h3{font-size:16px;font-weight:600;margin:0 0 4px;color:var(--ink-fg)}
.console-banner .lhs p{font-size:12px;color:var(--ink-fg-muted);margin:0;font-family:var(--f-mono)}
.console-banner pre{margin:0;background:var(--ink-elev);padding:12px 16px;border-radius:var(--r-md);font-family:var(--f-mono);font-size:11px;line-height:1.7;color:var(--ink-fg);border:1px solid var(--ink-border)}

/* ====== TAB ROW (used on marketplace-detail + publisher) ====== */
.tab-row{padding:0 48px;border-bottom:1px solid var(--border);background:var(--bg-panel);display:flex;gap:0;flex-wrap:wrap}
.tab-row a{padding:14px 18px;color:var(--fg-muted);font-size:13px;font-weight:500;text-decoration:none;border-bottom:2px solid transparent;display:flex;align-items:center;gap:6px}
.tab-row a:hover{color:var(--fg);text-decoration:none}
.tab-row a.active{color:var(--fg);border-bottom-color:var(--accent)}
.tab-row a .count{font-family:var(--f-mono);font-size:10px;color:var(--fg-subtle);background:var(--bg-elev);padding:1px 6px;border-radius:999px}

/* ====== MARKETPLACE DETAIL (hero + install card + content layout) ====== */
.detail-hero{padding:36px 48px 0;background:linear-gradient(180deg,var(--bg-elev) 0%,var(--bg) 100%);border-bottom:1px solid var(--border-sub);position:relative;overflow:hidden}
.detail-hero::before{content:"";position:absolute;top:-100px;right:-100px;width:380px;height:380px;background:radial-gradient(circle,var(--accent-soft) 0%,transparent 70%);pointer-events:none}
.detail-hero-inner{display:grid;grid-template-columns:1fr 360px;gap:32px;align-items:start;position:relative;padding-bottom:32px}
.detail-hero .breadcrumb{margin-bottom:16px}
.detail-htitle{display:flex;align-items:center;gap:12px;margin:0 0 8px;flex-wrap:wrap}
.detail-htitle h1{font-size:32px;font-weight:700;letter-spacing:-0.02em;margin:0;line-height:1.15}
.h-publisher{display:flex;align-items:center;gap:8px;font-family:var(--f-mono);font-size:13px;color:var(--fg-muted);margin-bottom:16px;flex-wrap:wrap}
.h-publisher a{color:var(--fg);font-weight:600;text-decoration:none}
.h-publisher a:hover{color:var(--accent-strong)}
.h-publisher .verified{color:var(--info-strong)}
.h-desc{font-size:16px;color:var(--fg);line-height:1.6;margin:0 0 24px;max-width:640px}
.h-stats{display:flex;gap:24px;flex-wrap:wrap;margin-bottom:24px}
.h-stats .s{font-family:var(--f-mono);display:flex;flex-direction:column;gap:1px}
.h-stats .num{font-family:var(--f-ui);font-size:18px;font-weight:700;color:var(--fg)}
.h-stats .lbl{font-size:11px;color:var(--fg-subtle);text-transform:uppercase;letter-spacing:.06em}

.install-card{background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-2)}
.install-card .cover{aspect-ratio:16/9;display:flex;align-items:center;justify-content:center;color:#fff;font-family:var(--f-mono);font-size:14px;font-weight:600;text-align:center;padding:0 16px}
.install-card .body{padding:18px}
.install-card .save-row{display:flex;gap:8px;margin-bottom:12px}
.install-card .save-row .btn{flex:1;justify-content:center}
.install-card .ident{font-family:var(--f-mono);font-size:11px;color:var(--fg-muted);display:flex;flex-direction:column;gap:6px;padding-top:12px;border-top:1px solid var(--border-sub)}
.install-card .ident .row{display:flex;justify-content:space-between;gap:8px}

.detail-content{padding:36px 48px;display:grid;grid-template-columns:1fr 320px;gap:32px;align-items:start}
.readme h2{font-size:20px;font-weight:600;margin:24px 0 12px;padding-bottom:6px;border-bottom:1px solid var(--border-sub)}
.readme h2:first-child{margin-top:0}
.readme p{font-size:15px;line-height:1.7;margin:0 0 14px}
.readme code{background:var(--bg-elev);padding:1px 6px;border-radius:3px;font-size:.92em;font-family:var(--f-mono)}
.readme pre{background:var(--ink);color:var(--ink-fg);padding:14px 16px;border-radius:var(--r-md);font-family:var(--f-mono);font-size:12px;overflow-x:auto;line-height:1.7;margin:0 0 16px}
.readme pre .k{color:var(--accent)}
.readme pre .s{color:var(--spectral)}
.readme pre .c{color:var(--ink-fg-muted)}
.readme ul{padding-left:20px;margin:0 0 14px}
.readme ul li{margin-bottom:4px;font-size:15px;line-height:1.6}

.file-tree{background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--r-md);font-family:var(--f-mono);font-size:12px;overflow:hidden}
.file-tree .ft-head{padding:8px 14px;background:var(--bg-elev);border-bottom:1px solid var(--border);font-size:10px;color:var(--fg-subtle);text-transform:uppercase;letter-spacing:.08em;display:flex;justify-content:space-between}
.file-tree .ft-row{display:grid;grid-template-columns:1fr auto auto;gap:14px;padding:6px 14px;border-bottom:1px solid var(--border-sub);align-items:center}
.file-tree .ft-row:last-child{border-bottom:0}
.file-tree .ft-row:hover{background:var(--bg-elev)}
.file-tree .ft-name{display:flex;align-items:center;gap:6px;color:var(--fg)}
.file-tree .ft-name .indent{display:inline-block;width:14px}
.file-tree .ft-size{color:var(--fg-muted);font-size:11px}
.file-tree .ft-when{color:var(--fg-subtle);font-size:11px}

.side-rail{display:flex;flex-direction:column;gap:14px;position:sticky;top:24px}
.panel{background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--r-lg);padding:16px 18px}
.panel h3{font-family:var(--f-mono);font-size:10px;color:var(--fg-subtle);text-transform:uppercase;letter-spacing:.08em;margin:0 0 12px;font-weight:600}

.changelog{display:flex;flex-direction:column;gap:0;font-size:12px}
.clog{padding:8px 0;border-bottom:1px solid var(--border-sub)}
.clog:last-child{border-bottom:0}
.clog .v{font-family:var(--f-mono);font-size:11px;color:var(--accent-strong);font-weight:600}
.clog .when{font-family:var(--f-mono);font-size:10px;color:var(--fg-subtle);margin-left:6px}
.clog .note{color:var(--fg-muted);margin-top:2px;line-height:1.4;font-size:12px}

.related{display:flex;flex-direction:column;gap:6px}
.related a{display:grid;grid-template-columns:32px 1fr;gap:10px;padding:8px 4px;border-radius:var(--r-md);text-decoration:none;color:inherit;align-items:center}
.related a:hover{background:var(--bg-elev);text-decoration:none}
.related .th{width:32px;height:32px;border-radius:var(--r-sm);font-family:var(--f-mono);font-size:9px;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600}
.related .h{font-size:12px;font-weight:600;line-height:1.3;color:var(--fg)}
.related .s{font-family:var(--f-mono);font-size:10px;color:var(--fg-muted)}

/* ====== PUBLISHER PROFILE ====== */
.profile-head{padding:40px 48px 24px;border-bottom:1px solid var(--border);background:var(--bg-panel);position:relative}
.profile-head::before{content:"";position:absolute;left:0;right:0;top:0;height:120px;background:linear-gradient(180deg,var(--bg-elev) 0%,transparent 100%);pointer-events:none}
.profile-head .inner{display:grid;grid-template-columns:auto 1fr auto;gap:24px;align-items:flex-end;position:relative}
.avatar-xl{width:88px;height:88px;border-radius:var(--r-xl);color:#fff;font-family:var(--f-mono);font-weight:700;font-size:36px;display:flex;align-items:center;justify-content:center;flex-shrink:0;border:4px solid var(--bg-panel);box-shadow:var(--sh-2)}
.p-handle{display:flex;align-items:center;gap:8px;font-family:var(--f-mono);font-size:14px;color:var(--fg-muted);margin-bottom:4px}
.p-name{font-size:26px;font-weight:700;letter-spacing:-0.02em;margin:0;line-height:1.15;display:flex;align-items:center;gap:10px}
.p-name .verified{color:var(--info-strong)}
.p-bio{color:var(--fg-muted);font-size:14px;line-height:1.55;margin:8px 0 12px;max-width:560px}
.p-meta{display:flex;align-items:center;gap:16px;font-family:var(--f-mono);font-size:12px;color:var(--fg-muted);flex-wrap:wrap}
.p-meta a{color:var(--fg);text-decoration:none}
.p-meta a:hover{color:var(--accent-strong)}
.p-meta .dot{width:3px;height:3px;background:var(--fg-subtle);border-radius:50%}
.p-actions{display:flex;gap:8px;flex-wrap:wrap}

.stats-bar{display:grid;grid-template-columns:repeat(5,1fr);gap:1px;background:var(--border);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.stats-bar .stat{background:var(--bg-panel);padding:18px 24px;text-align:center}
.stats-bar .stat .num{font-size:22px;font-weight:700;letter-spacing:-0.01em;color:var(--fg);font-family:var(--f-ui)}
.stats-bar .stat .lbl{font-family:var(--f-mono);font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--fg-subtle);margin-top:4px}

.fleet{padding:24px 48px;border-bottom:1px solid var(--border);background:var(--bg-panel)}
.fleet h3{font-family:var(--f-mono);font-size:11px;color:var(--fg-subtle);text-transform:uppercase;letter-spacing:.08em;margin:0 0 12px;font-weight:600}
.fleet-row{display:flex;gap:8px;flex-wrap:wrap}
.ag-chip{display:inline-flex;align-items:center;gap:8px;padding:6px 12px 6px 8px;background:var(--bg);border:1px solid var(--border);border-radius:var(--r-md);font-family:var(--f-mono);font-size:11px;color:var(--fg)}
.ag-chip .av{width:18px;height:18px;border-radius:4px;background:var(--ink);color:#fff;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700}
.ag-chip .pct{color:var(--fg-muted);font-size:10px}

.filter-row{padding:18px 48px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.filter-row .grow{flex:1}
.grid-wrap{padding:0 48px 64px}

/* ====== COLLECTION (ink hero + ordered list) ====== */
.col-hero{padding:48px 48px 36px;background:var(--ink);color:var(--ink-fg);position:relative;overflow:hidden}
.col-hero::before{content:"";position:absolute;top:-100px;right:-50px;width:380px;height:380px;background:radial-gradient(circle,rgba(226,101,52,.16) 0%,transparent 70%);pointer-events:none}
.col-hero::after{content:"";position:absolute;bottom:-80px;left:-80px;width:280px;height:280px;background:radial-gradient(circle,rgba(111,221,229,.10) 0%,transparent 70%);pointer-events:none}
.col-hero .inner{position:relative;max-width:980px}
.col-eyebrow{font-family:var(--f-mono);font-size:11px;color:var(--accent);text-transform:uppercase;letter-spacing:.1em;margin-bottom:14px;display:flex;align-items:center;gap:8px}
.col-eyebrow .glyph{display:inline-flex;color:var(--accent)}
.col-hero .breadcrumb{font-family:var(--f-mono);font-size:12px;color:var(--ink-fg-muted);margin-bottom:18px}
.col-hero .breadcrumb a{color:var(--ink-fg-muted);text-decoration:none}
.col-hero .breadcrumb a:hover{color:var(--ink-fg)}
.col-hero h1{font-size:42px;line-height:1.1;font-weight:700;letter-spacing:-0.025em;margin:0 0 12px;color:#fff}
.col-hero .lede{color:var(--ink-fg-muted);font-size:16px;line-height:1.6;margin:0 0 28px;max-width:600px}
.col-pub{display:flex;align-items:center;gap:10px;font-family:var(--f-mono);font-size:12px;color:var(--ink-fg);margin-bottom:24px;flex-wrap:wrap}
.col-pub a{color:#fff;font-weight:600;text-decoration:none}
.col-stats{display:flex;gap:32px;flex-wrap:wrap;font-family:var(--f-mono);font-size:11px;color:var(--ink-fg-muted)}
.col-stats .s{display:flex;flex-direction:column;gap:2px}
.col-stats .n{font-family:var(--f-ui);font-size:18px;font-weight:700;color:var(--ink-fg)}
.col-cta{display:flex;gap:8px;margin-top:24px;flex-wrap:wrap}
.btn-on-ink{background:transparent;color:var(--ink-fg);border:1px solid var(--ink-border)}
.btn-on-ink:hover:not(:disabled){background:var(--ink-elev);color:var(--ink-fg)}

.list-wrap{padding:40px 48px 64px;max-width:1080px;margin:0 auto}
.list-head{display:flex;align-items:baseline;gap:12px;margin-bottom:18px;flex-wrap:wrap}
.list-head h2{font-size:20px;font-weight:700;letter-spacing:-0.01em;margin:0}
.list-head .sub{color:var(--fg-muted);font-size:13px;margin:0 0 0 auto;font-family:var(--f-mono)}

.col-list{background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden}
.col-item{display:grid;grid-template-columns:36px 64px 1fr auto;gap:18px;padding:18px 22px;border-bottom:1px solid var(--border-sub);align-items:center;text-decoration:none;color:inherit}
.col-item:last-child{border-bottom:0}
.col-item:hover{background:var(--bg-elev);text-decoration:none}
.col-item .idx{font-family:var(--f-mono);font-size:14px;color:var(--fg-subtle);font-weight:600;text-align:center}
.col-item .thumb{width:64px;height:48px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;color:#fff;font-family:var(--f-mono);font-size:10px;font-weight:600}
.col-item .body h3{font-size:14px;font-weight:600;margin:0 0 4px;color:var(--fg)}
.col-item .body .desc{color:var(--fg-muted);font-size:13px;line-height:1.45;margin:0 0 6px;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.col-item .meta{display:flex;align-items:center;gap:8px;font-family:var(--f-mono);font-size:11px;color:var(--fg-muted);flex-wrap:wrap}
.col-item .right{text-align:right;display:flex;flex-direction:column;align-items:flex-end;gap:6px}
.col-item .stat{font-family:var(--f-mono);font-size:11px;color:var(--fg-muted)}
.col-item .stat strong{color:var(--fg);font-weight:600}
.col-item.optional{background:repeating-linear-gradient(45deg,var(--bg-panel),var(--bg-panel) 8px,var(--bg) 8px,var(--bg) 16px)}
.col-item.optional .body h3::after{content:" · optional";color:var(--fg-subtle);font-weight:400;font-family:var(--f-mono);font-size:11px}

.info-block{padding:36px 48px 0;display:grid;grid-template-columns:1fr 1fr 1fr;gap:18px;max-width:1080px;margin:0 auto;border-top:1px solid var(--border)}
.info-card{background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--r-lg);padding:18px}
.info-card h4{font-family:var(--f-mono);font-size:10px;color:var(--fg-subtle);text-transform:uppercase;letter-spacing:.08em;margin:0 0 10px;font-weight:600}
.info-card .big{font-family:var(--f-ui);font-size:18px;font-weight:700;color:var(--fg);margin:0 0 4px}
.info-card .small{font-family:var(--f-mono);font-size:11px;color:var(--fg-muted);line-height:1.5}
.ag-pills{display:flex;flex-wrap:wrap;gap:4px}
.ag-pills span{font-family:var(--f-mono);font-size:10px;background:var(--bg-elev);color:var(--fg-muted);padding:2px 6px;border-radius:3px;border:1px solid var(--border-sub)}

/* ====== ARTIFACT DETAIL PREVIEW (file viewer + sidebar panels) ====== */
.detail-layout{display:grid;grid-template-columns:1fr 340px;gap:24px;align-items:start}
.preview-card{background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden}
.preview-head{padding:12px 18px;border-bottom:1px solid var(--border-sub);display:flex;align-items:center;gap:10px;background:var(--bg-elev);flex-wrap:wrap}
.preview-head .path{font-family:var(--f-mono);font-size:12px;color:var(--fg-muted);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}
.preview-head .path strong{color:var(--fg);font-weight:600}
.preview-body{padding:36px 48px;min-height:480px}
.preview-body h1{font-size:28px;font-weight:700;letter-spacing:-0.02em;margin:0 0 8px}
.preview-body h2{font-size:18px;font-weight:600;margin:32px 0 12px;padding-bottom:6px;border-bottom:1px solid var(--border-sub)}
.preview-body p{color:var(--fg);font-size:15px;line-height:1.7;margin:0 0 14px}
.preview-body table{border-collapse:collapse;margin:14px 0;font-size:14px;width:100%}
.preview-body th,.preview-body td{border:1px solid var(--border);padding:6px 10px;text-align:left}
.preview-body th{background:var(--bg-elev)}
.preview-body .meta-strip{color:var(--fg-muted);font-size:13px;display:flex;align-items:center;gap:8px;margin-bottom:24px;flex-wrap:wrap}

.ver-list{display:flex;flex-direction:column;gap:0}
.ver{display:grid;grid-template-columns:40px 1fr auto;gap:10px;padding:8px 0;border-bottom:1px solid var(--border-sub);font-family:var(--f-mono);font-size:11px}
.ver:last-child{border-bottom:0}
.ver .v{color:var(--accent-strong);font-weight:600}
.ver .meta{color:var(--fg-muted);line-height:1.4}
.ver .meta .who{color:var(--fg)}
.ver .when{color:var(--fg-subtle);text-align:right;align-self:start}
.ver.current .v{background:var(--accent-soft);padding:2px 6px;border-radius:3px}

.access-list{display:flex;flex-direction:column;gap:6px}
.acc{display:grid;grid-template-columns:14px 1fr auto;gap:8px;align-items:center;font-family:var(--f-mono);font-size:11px}
.acc .marker{width:8px;height:8px;border-radius:50%;justify-self:center}
.acc .marker.info{background:var(--info)}
.acc .marker.accent{background:var(--accent)}
.acc .when{color:var(--fg-subtle);text-align:right}
.acc .who{color:var(--fg);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}
.acc .who span{color:var(--fg-muted)}

.embed{background:var(--ink);color:var(--ink-fg);border-radius:var(--r-md);padding:12px 14px;font-family:var(--f-mono);font-size:11px;line-height:1.7;position:relative;overflow:hidden}
.embed .copy{position:absolute;right:8px;top:8px;background:transparent;color:var(--ink-fg-muted);border:1px solid var(--ink-border);padding:2px 8px;font-family:var(--f-mono);font-size:10px;border-radius:3px;cursor:pointer}
.embed .copy:hover{color:var(--ink-fg)}
.embed .s{color:var(--spectral)}
.embed .k{color:var(--accent)}

.head-actions{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px;align-items:center}

/* ====== SHARE-BUTTON (hover-revealed action on dashboard file rows) ====== */
.share-btn{margin-left:8px;background:transparent;border:1px solid var(--border-strong);border-radius:var(--r-sm);padding:0 6px;font-family:var(--f-mono);font-size:10px;color:var(--fg-subtle);cursor:pointer;height:18px;line-height:1;opacity:0;transition:opacity .12s ease}
.share-btn:hover{color:var(--accent-strong);border-color:var(--accent)}
.tbl tr:hover .share-btn,.tbl tr:focus-within .share-btn,.share-btn:focus-visible{opacity:1}
.scrim[hidden]{display:none}

/* ====== SHARE SHEET MODAL ====== */
.modal-wide{width:580px}
.modal-wide .modal-head .ttl{font-weight:600;font-size:14px}
.modal-wide .modal-body{padding:0}

.opt-list{display:flex;flex-direction:column;border-bottom:1px solid var(--border-sub)}
.opt{display:grid;grid-template-columns:36px 1fr auto;gap:14px;padding:14px 24px;border-bottom:1px solid var(--border-sub);cursor:pointer;align-items:center}
.opt:last-child{border-bottom:0}
.opt:hover{background:var(--bg-elev)}
.opt.selected{background:var(--accent-soft)}
.opt-icon{width:36px;height:36px;border-radius:var(--r-md);background:var(--bg-elev);display:flex;align-items:center;justify-content:center;color:var(--fg-muted)}
.opt.selected .opt-icon{background:var(--accent-fill);color:var(--accent-fg)}
.opt-title{font-size:13px;font-weight:600;margin:0 0 2px;color:var(--fg)}
.opt-desc{color:var(--fg-muted);font-size:12px;margin:0;line-height:1.4}
.opt-radio{width:18px;height:18px;border-radius:50%;border:1.5px solid var(--border-strong);background:var(--bg-panel);position:relative;flex-shrink:0}
.opt.selected .opt-radio{border-color:var(--accent);background:var(--accent)}
.opt.selected .opt-radio::after{content:"";position:absolute;inset:4px;background:#fff;border-radius:50%}

.url-block{padding:18px 24px;background:var(--bg);border-bottom:1px solid var(--border-sub)}
.url-label{font-family:var(--f-mono);font-size:10px;color:var(--fg-subtle);text-transform:uppercase;letter-spacing:.08em;margin-bottom:6px}
.url-row{display:flex;gap:6px;flex-wrap:wrap}
.url-row input{flex:1;min-width:200px;font-family:var(--f-mono);font-size:12px;padding:9px 12px;border:1px solid var(--border-strong);border-radius:var(--r-md);background:var(--bg-panel);color:var(--fg)}

.config-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;padding:18px 24px;border-bottom:1px solid var(--border-sub)}
.config-label{font-family:var(--f-mono);font-size:10px;color:var(--fg-subtle);text-transform:uppercase;letter-spacing:.08em;margin-bottom:6px}
.select{font-family:var(--f-mono);font-size:12px;padding:7px 10px;border:1px solid var(--border-strong);border-radius:var(--r-md);background:var(--bg-panel);color:var(--fg);width:100%;cursor:pointer}

.acc-block{padding:18px 24px}
.acc-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.acc-head h4{font-family:var(--f-mono);font-size:10px;color:var(--fg-subtle);text-transform:uppercase;letter-spacing:.08em;margin:0;font-weight:600}
.acc-list{display:flex;flex-direction:column;gap:0;font-family:var(--f-mono);font-size:11px}
.acc-row{display:grid;grid-template-columns:80px 1fr 70px;gap:12px;padding:7px 0;border-bottom:1px solid var(--border-sub);align-items:center}
.acc-row:last-child{border-bottom:0}
.acc-row .when{color:var(--fg-subtle)}
.acc-row .who{color:var(--fg);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.acc-row .who span{color:var(--fg-muted)}
.acc-row .vtype{color:var(--fg-muted);text-align:right}

.summary{padding:14px 24px;background:var(--bg-elev);border-top:1px solid var(--border-sub);display:flex;align-items:center;justify-content:space-between;font-family:var(--f-mono);font-size:11px;color:var(--fg-muted);gap:12px;flex-wrap:wrap}
.summary strong{color:var(--fg);font-family:var(--f-mono)}

/* ====== EMPTY-STATE FIRST-UPLOAD HERO (dashboard zero state) ====== */
.first-hero{max-width:780px;margin:24px auto 0;text-align:center;padding:0 24px}
.first-hero .mark-lg{width:64px;height:64px;margin:0 auto 24px;background:var(--accent-soft);border-radius:var(--r-xl);display:inline-flex;align-items:center;justify-content:center;color:var(--accent-strong)}
.first-hero h1{font-size:32px;font-weight:700;letter-spacing:-0.02em;margin:0 0 12px;line-height:1.15}
.first-hero h1 em{font-style:normal;color:var(--accent-strong)}
.first-hero p{font-size:16px;color:var(--fg-muted);line-height:1.55;max-width:560px;margin:0 auto 32px}
.first-tabs{display:inline-flex;background:var(--bg-panel);border:1px solid var(--border-strong);border-radius:var(--r-md);padding:3px;margin-bottom:16px;font-family:var(--f-mono);font-size:12px}
.first-tabs button{background:transparent;border:0;color:var(--fg-muted);padding:6px 14px;border-radius:4px;cursor:pointer;font-family:var(--f-mono);font-size:12px}
.first-tabs button.active{background:var(--ink);color:var(--ink-fg)}
.first-console{max-width:720px;margin:0 auto;text-align:left;font-size:13px;position:relative}
.first-console .copy-btn{position:absolute;right:14px;top:14px;background:transparent;color:var(--ink-fg-muted);border:1px solid var(--ink-border);padding:4px 10px;font-family:var(--f-mono);font-size:10px;border-radius:4px;cursor:pointer}

.first-steps{max-width:720px;margin:48px auto;text-align:left;display:flex;flex-direction:column;gap:0;border-left:1px dashed var(--border-strong);padding-left:32px;position:relative}
.first-step{padding:14px 0;display:flex;gap:14px;align-items:flex-start;position:relative}
.first-step::before{content:"";position:absolute;left:-37px;top:18px;width:10px;height:10px;border-radius:50%;background:var(--bg);border:2px solid var(--border-strong)}
.first-step.done::before{background:var(--accent);border-color:var(--accent)}
.first-step.active::before{background:var(--bg);border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}
.first-step .num{font-family:var(--f-mono);font-size:11px;color:var(--fg-subtle);min-width:18px}
.first-step .body{flex:1}
.first-step .title{font-weight:600;margin:0 0 4px;font-size:14px;color:var(--fg)}
.first-step .desc{color:var(--fg-muted);font-size:13px;margin:0;line-height:1.55}
.first-step .desc code{background:var(--bg-elev);padding:1px 6px;border-radius:3px;font-size:12px;font-family:var(--f-mono)}
.first-step.done .title{color:var(--fg-muted)}
.first-step.done .title::after{content:" \2713";color:var(--accent-strong)}

.agents-row{display:flex;justify-content:center;gap:8px;margin-top:24px;flex-wrap:wrap}
.ag-pill{display:flex;align-items:center;gap:6px;padding:6px 12px;background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--r-md);font-family:var(--f-mono);font-size:11px;color:var(--fg-muted);text-decoration:none}
.ag-pill:hover{background:var(--bg-elev);color:var(--fg);text-decoration:none}
.ag-pill .av{width:14px;height:14px;border-radius:3px;background:var(--ink);color:#fff;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;font-family:var(--f-mono)}

/* ====== MARKETING LANDING (loft.run root) ====== */
.mhead{position:sticky;top:0;z-index:20;background:rgba(250,247,242,.85);backdrop-filter:saturate(120%) blur(8px);border-bottom:1px solid var(--border-sub)}
[data-theme="dark"] .mhead{background:rgba(19,17,14,.85)}
.mhead-inner{max-width:1180px;margin:0 auto;padding:14px 32px;display:flex;align-items:center;gap:32px}
.mhead .lockup{font-size:18px}
.mhead nav{display:flex;gap:6px;flex:1;justify-content:center}
.mhead nav a{padding:6px 12px;color:var(--fg-muted);font-size:13px;font-weight:500;text-decoration:none;border-radius:var(--r-md)}
.mhead nav a:hover{color:var(--fg);background:var(--bg-elev);text-decoration:none}
.mhead-cta{display:flex;gap:8px;align-items:center}

.m-hero{padding:88px 32px 64px;max-width:1180px;margin:0 auto;position:relative;overflow:hidden}
.m-hero::before{content:"";position:absolute;top:-180px;right:-180px;width:520px;height:520px;background:radial-gradient(circle,var(--accent-soft) 0%,transparent 60%);pointer-events:none}
.m-hero::after{content:"";position:absolute;bottom:-200px;left:-80px;width:380px;height:380px;background:radial-gradient(circle,rgba(111,221,229,.10) 0%,transparent 60%);pointer-events:none}
.m-hero-inner{position:relative;max-width:780px}
.m-hero .eyebrow{font-family:var(--f-mono);font-size:11px;color:var(--accent-strong);text-transform:uppercase;letter-spacing:.1em;margin-bottom:18px;display:flex;align-items:center;gap:8px}
.m-hero h1{font-size:clamp(36px,5.5vw,68px);line-height:1.05;font-weight:700;letter-spacing:-0.03em;margin:0 0 18px;color:var(--fg)}
.m-hero h1 em{font-style:normal;color:var(--accent-strong)}
.m-hero .lede{font-size:18px;line-height:1.55;color:var(--fg-muted);margin:0 0 28px;max-width:600px}
.m-hero-cta{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:36px}
.m-hero-cta .btn-lg{font-size:15px;padding:11px 20px}
.m-hero-tagline{font-family:var(--f-mono);font-size:11px;color:var(--fg-subtle);display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.m-hero-tagline .dot{width:3px;height:3px;background:var(--fg-subtle);border-radius:50%}

.m-demo{display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:center;margin-top:48px;padding:0 32px;max-width:1180px;margin-left:auto;margin-right:auto}
.m-demo .console{font-size:13px;line-height:1.8;border-radius:var(--r-lg)}
.m-demo .copy h3{font-size:24px;font-weight:700;letter-spacing:-0.015em;margin:0 0 10px;line-height:1.2}
.m-demo .copy p{color:var(--fg-muted);font-size:15px;line-height:1.55;margin:0 0 16px;max-width:420px}
.m-demo .copy ul{padding-left:18px;margin:0;color:var(--fg-muted);font-size:14px;line-height:1.7}
.m-demo .copy ul li::marker{color:var(--accent-strong)}

.m-lines{padding:96px 32px;max-width:1180px;margin:0 auto}
.m-lines-head{text-align:center;margin-bottom:48px}
.m-lines-head .eyebrow{font-family:var(--f-mono);font-size:11px;color:var(--accent-strong);text-transform:uppercase;letter-spacing:.1em;margin-bottom:12px}
.m-lines-head h2{font-size:36px;font-weight:700;letter-spacing:-0.02em;margin:0 0 12px;line-height:1.1}
.m-lines-head p{color:var(--fg-muted);font-size:16px;max-width:580px;margin:0 auto;line-height:1.55}
.m-line-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.m-line{background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--r-xl);padding:32px 28px;display:flex;flex-direction:column;gap:18px;text-decoration:none;color:inherit;transition:transform .15s ease, box-shadow .15s ease}
.m-line:hover{transform:translateY(-2px);box-shadow:var(--sh-2);text-decoration:none}
.m-line .num{font-family:var(--f-mono);font-size:11px;color:var(--accent-strong);letter-spacing:.08em;font-weight:600}
.m-line h3{font-size:22px;font-weight:700;letter-spacing:-0.015em;margin:0;line-height:1.2;color:var(--fg)}
.m-line p{color:var(--fg-muted);font-size:14px;line-height:1.55;margin:0;flex:1}
.m-line .preview{aspect-ratio:16/10;border-radius:var(--r-md);overflow:hidden;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-family:var(--f-mono);font-size:11px;color:var(--fg-muted);text-align:center}
.m-line .more{font-family:var(--f-mono);font-size:11px;color:var(--accent-strong);align-self:flex-start;margin-top:6px}

.m-strip{background:var(--ink);color:var(--ink-fg);padding:64px 32px;border-top:1px solid var(--border)}
.m-strip-inner{max-width:1180px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:32px}
.m-strip .s{text-align:center;font-family:var(--f-mono)}
.m-strip .n{font-family:var(--f-ui);font-size:48px;font-weight:700;letter-spacing:-0.03em;color:var(--ink-fg)}
.m-strip .n em{font-style:normal;color:var(--accent)}
.m-strip .l{font-size:11px;color:var(--ink-fg-muted);text-transform:uppercase;letter-spacing:.08em;margin-top:4px}

.m-teaser{padding:96px 32px;max-width:1180px;margin:0 auto}
.m-teaser-grid{display:grid;grid-template-columns:1fr 2fr;gap:48px;align-items:center}
.m-teaser .copy h2{font-size:36px;font-weight:700;letter-spacing:-0.02em;margin:0 0 14px;line-height:1.1}
.m-teaser .copy p{color:var(--fg-muted);font-size:16px;line-height:1.55;margin:0 0 24px}
.m-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.m-card{background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--r-lg);padding:14px;display:flex;gap:12px;align-items:center;text-decoration:none;color:inherit}
.m-card:hover{background:var(--bg-elev);text-decoration:none}
.m-card .th{width:48px;height:48px;border-radius:var(--r-md);flex-shrink:0;display:flex;align-items:center;justify-content:center;color:#fff;font-family:var(--f-mono);font-size:11px;font-weight:600;text-align:center;line-height:1.1}
.m-card .h{font-size:13px;font-weight:600;margin:0 0 2px;color:var(--fg)}
.m-card .s{font-family:var(--f-mono);font-size:10px;color:var(--fg-muted)}

.m-compat{background:var(--bg-elev);padding:64px 32px;border-top:1px solid var(--border)}
.m-compat-inner{max-width:1180px;margin:0 auto;text-align:center}
.m-compat h2{font-size:14px;font-family:var(--f-mono);text-transform:uppercase;letter-spacing:.08em;color:var(--fg-subtle);font-weight:600;margin:0 0 24px}
.m-compat-row{display:flex;gap:24px;justify-content:center;align-items:center;flex-wrap:wrap}
.m-compat-row .item{display:flex;align-items:center;gap:8px;padding:8px 16px;background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--r-md);font-family:var(--f-mono);font-size:12px;color:var(--fg)}
.m-compat-row .item .ix{width:18px;height:18px;border-radius:4px;background:var(--ink);color:#fff;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700}

.m-cta{padding:96px 32px;text-align:center}
.m-cta-inner{max-width:680px;margin:0 auto}
.m-cta h2{font-size:42px;font-weight:700;letter-spacing:-0.025em;margin:0 0 16px;line-height:1.1}
.m-cta p{color:var(--fg-muted);font-size:16px;margin:0 0 28px;line-height:1.55}

.m-foot{padding:48px 32px 32px;border-top:1px solid var(--border);background:var(--bg-panel)}
.m-foot-inner{max-width:1180px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:32px}
.m-foot h4{font-family:var(--f-mono);font-size:10px;color:var(--fg-subtle);text-transform:uppercase;letter-spacing:.08em;margin:0 0 12px;font-weight:600}
.m-foot a{display:block;color:var(--fg-muted);font-size:13px;padding:4px 0;text-decoration:none}
.m-foot a:hover{color:var(--fg);text-decoration:none}
.m-foot .pitch{font-size:13px;color:var(--fg-muted);line-height:1.55;max-width:380px}
.m-foot-bottom{max-width:1180px;margin:32px auto 0;padding-top:24px;border-top:1px solid var(--border-sub);display:flex;justify-content:space-between;font-family:var(--f-mono);font-size:11px;color:var(--fg-subtle);gap:12px;flex-wrap:wrap}

/* ====== CONNECTORS (mock — Google Drive / Notion / etc. as virtual folders) ====== */
.conn-summary{display:flex;gap:18px;flex-wrap:wrap;font-family:var(--f-mono);font-size:11px;color:var(--fg-muted);margin:8px 0 24px}
.conn-summary .s{display:inline-flex;align-items:center;gap:6px}
.conn-summary .s::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--fg-subtle)}
.conn-summary .s.on::before{background:var(--success)}
.conn-summary .s.sync::before{background:var(--info);animation:pulse 1.6s ease-out infinite}
.conn-summary .s.err::before{background:var(--danger)}
.conn-summary .s.avail::before{background:var(--fg-subtle);background:var(--border-strong)}

.conn-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px}
.conn-card{background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--r-lg);padding:18px;display:flex;flex-direction:column;gap:14px;transition:border-color .15s ease, box-shadow .15s ease}
.conn-card.is-available{border-style:dashed;background:transparent}
.conn-card.is-coming-soon{opacity:.62}
.conn-card.is-error{border-color:var(--danger);box-shadow:0 0 0 1px var(--danger) inset}

.conn-head{display:flex;align-items:flex-start;gap:12px}
.conn-logo{width:40px;height:40px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;color:#fff;font-family:var(--f-mono);font-weight:700;font-size:14px;flex-shrink:0;letter-spacing:-0.02em}
.conn-title{flex:1;min-width:0}
.conn-title h3{font-size:15px;font-weight:600;margin:0 0 2px;color:var(--fg);letter-spacing:-0.01em}
.conn-title .sub{font-size:12px;color:var(--fg-muted);line-height:1.4;margin:0}
.conn-status{font-family:var(--f-mono);font-size:10px;padding:3px 8px;border-radius:999px;text-transform:uppercase;letter-spacing:.05em;font-weight:600;white-space:nowrap;flex-shrink:0}
.conn-status.connected{background:var(--success-bg);color:var(--success)}
.conn-status.syncing{background:var(--info-bg);color:var(--info-strong);display:inline-flex;align-items:center;gap:5px}
.conn-status.syncing::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--info);animation:pulse 1.6s ease-out infinite}
.conn-status.error{background:var(--danger-bg);color:var(--danger-strong)}
.conn-status.available{background:var(--bg-elev);color:var(--fg-muted)}
.conn-status.coming-soon{background:var(--bg-elev);color:var(--fg-subtle)}

.conn-account{font-family:var(--f-mono);font-size:11px;color:var(--fg-muted);display:flex;align-items:center;gap:6px}
.conn-account::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--success);flex-shrink:0}

.conn-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--border-sub);border-bottom:1px solid var(--border-sub);padding:12px 0}
.conn-stats .stat{text-align:left;padding:0 4px;border-right:1px solid var(--border-sub)}
.conn-stats .stat:last-child{border-right:none}
.conn-stats .n{font-family:var(--f-ui);font-size:18px;font-weight:700;letter-spacing:-0.02em;color:var(--fg);line-height:1.1}
.conn-stats .l{font-family:var(--f-mono);font-size:10px;color:var(--fg-subtle);text-transform:uppercase;letter-spacing:.05em;margin-top:3px}

.conn-folder{display:inline-flex;align-items:center;gap:6px;font-family:var(--f-mono);font-size:11px;color:var(--accent-strong);text-decoration:none;padding:5px 8px;border-radius:var(--r-sm);background:var(--accent-soft);align-self:flex-start}
.conn-folder:hover{background:var(--accent-soft);color:var(--accent-fill-hov);text-decoration:none}

.conn-error{display:flex;gap:8px;align-items:flex-start;padding:10px 12px;background:var(--danger-bg);border-radius:var(--r-md);color:var(--danger-strong);font-size:12px;line-height:1.4}
.conn-error svg{flex-shrink:0;margin-top:2px}

.conn-actions{display:flex;gap:6px;margin-top:auto}
.conn-actions .btn{flex:1;justify-content:center}

.conn-progress{height:3px;background:var(--bg-elev);border-radius:999px;overflow:hidden}
.conn-progress .bar{height:100%;background:linear-gradient(90deg,var(--info) 0%,var(--accent) 100%);border-radius:999px;animation:conn-pulse 2.4s ease-in-out infinite}
@keyframes conn-pulse{0%,100%{opacity:.6}50%{opacity:1}}

.conn-explainer{background:var(--bg-elev);border:1px solid var(--border-sub);border-radius:var(--r-lg);padding:18px 20px;display:flex;gap:16px;align-items:flex-start;margin-bottom:24px}
.conn-explainer .ico{width:32px;height:32px;border-radius:var(--r-md);background:var(--accent-soft);color:var(--accent-strong);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.conn-explainer h2{font-size:14px;font-weight:600;margin:0 0 4px;color:var(--fg);letter-spacing:-0.005em}
.conn-explainer p{font-size:13px;color:var(--fg-muted);margin:0;line-height:1.5}
.conn-explainer code{font-family:var(--f-mono);font-size:11px;background:var(--bg-panel);padding:1px 5px;border-radius:3px;border:1px solid var(--border-sub);color:var(--fg)}

@media (max-width:760px){
  .mhead nav{display:none}
  .m-demo,.m-line-grid,.m-teaser-grid,.m-strip-inner,.m-foot-inner{grid-template-columns:1fr;gap:32px}
  .m-strip-inner{gap:24px}
  .m-cta h2{font-size:32px}
  .hero-section,.section,.kind-nav,.tab-row,.filter-row,.grid-wrap{padding-left:20px;padding-right:20px}
  .detail-hero-inner,.detail-content,.profile-head .inner,.stats-bar{grid-template-columns:1fr}
  .detail-hero{padding-left:20px;padding-right:20px}
  .detail-content{padding:24px 20px}
  .col-hero{padding:32px 20px 24px}
  .col-hero h1{font-size:32px}
  .list-wrap,.info-block{padding-left:20px;padding-right:20px}
  .console-banner{margin:0 20px}
  .modal-wide{width:auto}
  .stats-bar{grid-template-columns:repeat(2,1fr)}
  .featured{grid-template-columns:1fr}
}

/* SVG defaults */
svg{vertical-align:middle}
