:root{
  --bg:#0a0d16;
  --bg-2:#0f1422;
  --surface:#141a2c;
  --surface-2:#1b2238;
  --line:rgba(255,255,255,.08);
  --line-2:rgba(255,255,255,.16);
  --text:#eef1f8;
  --muted:#8a93a8;
  --primary:#ffffff;
  --primary-2:#ffffff;
  --accent:#ffffff;
  --ok:#10b981;
  --err:#ef4444;
  --r:14px;
  --r-lg:22px;
  --shadow: 0 16px 40px -16px rgba(0,0,0,.6), 0 2px 8px -2px rgba(0,0,0,.4);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
html,body{max-width:100%;overflow-x:hidden}
body{
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  background:var(--bg);
  color:var(--text);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  min-height:100vh;
}
img,svg,video{max-width:100%}
h1,h2,h3,h4,p{overflow-wrap:break-word;word-wrap:break-word}
h1 .grad,h1 span{overflow-wrap:break-word}
[v-cloak]{display:none}
.wrap{max-width:1180px;margin:0 auto;padding:0 20px}
a{color:inherit;text-decoration:none}
button{font-family:inherit}
h1,h2,h3,h4{margin:0 0 .4em;letter-spacing:-.02em;line-height:1.15}
h1{font-size:clamp(34px,5.6vw,60px);font-weight:800}
h2{font-size:clamp(26px,3.4vw,36px);font-weight:700}
h3{font-size:18px;font-weight:600}
.muted{color:var(--muted)}
.grad{color:var(--text)}

/* TOPBAR */
.topbar{position:sticky;top:0;z-index:50;backdrop-filter:blur(14px);background:rgba(10,13,22,.85);border-bottom:1px solid var(--line)}
.topbar-inner{display:flex;align-items:center;justify-content:space-between;height:64px}
.logo{display:flex;align-items:center;gap:10px;font-weight:700;font-size:18px;text-decoration:none;color:var(--text)}
.logo-mark{
  display:inline-block;
  width:160px;height:38px;
  background:url('../img/logo.png?v=1') left center/contain no-repeat;
  text-indent:-9999px;overflow:hidden;white-space:nowrap;
  flex-shrink:0;
}
.logo-text{display:none}
.topnav{display:flex;gap:6px}
.topnav a{padding:8px 14px;border-radius:10px;font-size:14px;color:var(--muted);transition:.2s}
.topnav a:hover{color:var(--text);background:var(--surface)}
/* Use cases — toggle in topnav */
.topnav-item-sub{position:static}
.topnav-sub-toggle{
  background:transparent;border:0;padding:8px 14px;border-radius:10px;color:var(--muted);
  font-size:14px;font-family:inherit;cursor:pointer;transition:.15s;
  display:inline-flex;align-items:center;gap:6px;
}
.topnav-sub-toggle:hover,.topnav-sub-toggle.active{color:var(--text);background:var(--surface)}
.topnav-sub-toggle .caret{font-size:10px;opacity:.7;transition:transform .18s}
.topnav-item-sub.open .topnav-sub-toggle .caret{transform:rotate(180deg)}

/* USE CASES MODAL — rendered outside the topbar so position:fixed works */
.usecases-modal{
  position:fixed;inset:0;z-index:200;
  background:rgba(6,9,18,.82);
  -webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);
  padding:7vh 4vw 5vh;overflow-y:auto;
  animation:modalFade .22s ease;
}
.usecases-modal[hidden]{display:none}
@keyframes modalFade{from{opacity:0}to{opacity:1}}
.usecases-close{
  position:fixed;top:18px;right:24px;z-index:210;
  width:44px;height:44px;border-radius:50%;border:1px solid var(--line-2);
  background:rgba(20,26,44,.92);color:#fff;font-size:24px;cursor:pointer;line-height:1;
  display:grid;place-items:center;transition:.15s;
}
.usecases-close:hover{background:rgba(255,255,255,.12);border-color:#fff}
.usecases-inner{
  max-width:1180px;margin:0 auto;
  animation:modalRise .28s ease;
}
@keyframes modalRise{from{transform:translateY(8px);opacity:0}to{transform:translateY(0);opacity:1}}
.usecases-title{
  font-size:clamp(22px,3vw,32px);font-weight:700;letter-spacing:-.02em;
  color:#fff;margin:0 0 22px;
}
.usecases-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;
}
.usecase-card{
  display:flex;flex-direction:column;
  background:var(--surface);border:1px solid var(--line-2);border-radius:14px;
  overflow:hidden;color:var(--text);text-decoration:none;
  transition:transform .18s, border-color .18s, box-shadow .18s;
}
.usecase-card:hover{transform:translateY(-2px);border-color:#fff;box-shadow:0 18px 40px -14px rgba(0,0,0,.6)}
.usecase-thumb{
  position:relative;width:100%;aspect-ratio:4/3;background:var(--surface-2);
  overflow:hidden;display:grid;place-items:center;
}
.usecase-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.usecase-emoji{font-size:48px;opacity:.9}
.usecase-badge{
  position:absolute;top:10px;left:10px;width:34px;height:34px;border-radius:9px;
  background:rgba(10,13,22,.82);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);
  display:grid;place-items:center;font-size:18px;border:1px solid rgba(255,255,255,.14);
}
.usecase-meta{padding:12px 14px;display:flex;flex-direction:column;gap:3px}
.usecase-meta b{font-size:14px;font-weight:600;line-height:1.3}
.usecase-meta small{font-size:12px;color:var(--muted);font-weight:400;line-height:1.4;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

@media (max-width:560px){
  .usecases-modal{padding:5vh 4vw}
  .usecases-grid{grid-template-columns:repeat(2,1fr);gap:10px}
  .usecase-emoji{font-size:36px}
  .usecase-meta b{font-size:13px}
  .usecase-meta small{font-size:11.5px}
}

.mobile-sub{padding-left:24px !important;font-size:13px !important;color:var(--muted) !important}

/* Admin queue — XML import UI */
.xml-import-actions{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:12px;margin-bottom:20px;
}
.xml-action-card{
  display:flex;align-items:center;gap:14px;
  padding:14px 18px;border-radius:14px;
  background:var(--surface);border:1px solid var(--line-2);
  text-decoration:none;color:var(--text);transition:transform .15s,border-color .15s,background .15s;
}
.xml-action-card:hover{transform:translateY(-1px);border-color:#fff;background:var(--surface-2)}
.xml-action-icon{font-size:24px;flex-shrink:0;line-height:1}
.xml-action-body{display:flex;flex-direction:column;gap:2px;min-width:0}
.xml-action-body b{font-size:14px;font-weight:600;line-height:1.3}
.xml-action-body small{font-size:12px;color:var(--muted);line-height:1.4}

.xml-dropzone{
  display:flex;align-items:center;gap:18px;
  padding:22px 24px;border-radius:14px;cursor:pointer;
  background:rgba(255,255,255,.03);
  border:1.5px dashed rgba(255,255,255,.18);
  transition:.15s;outline:none;
}
.xml-dropzone:hover,.xml-dropzone:focus,.xml-dropzone.drag{
  background:rgba(255,255,255,.06);border-color:#fff;
}
.xml-dropzone.has-file{
  background:rgba(16,185,129,.08);border-color:#10b981;border-style:solid;
}
.xml-dropzone input[type="file"]{
  position:absolute !important;width:1px;height:1px;padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;
}
.xml-dropzone-icon{font-size:34px;line-height:1;flex-shrink:0}
.xml-dropzone-text{display:flex;flex-direction:column;gap:3px;min-width:0;flex:1}
.xml-dropzone-text b{font-size:15px;font-weight:600}
.xml-dropzone-text small{font-size:12.5px;color:var(--muted)}

/* Docs page — endpoint comparison table */
.docs-table{width:100%;border-collapse:collapse;margin:12px 0;font-size:13.5px}
.docs-table th,.docs-table td{padding:10px 12px;text-align:left;border-bottom:1px solid var(--line);vertical-align:top}
.docs-table th{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);background:rgba(255,255,255,.02)}
.docs-table tr:hover td{background:rgba(255,255,255,.02)}
.docs-table code{background:rgba(255,255,255,.06);padding:1px 6px;border-radius:5px;font-size:12px}

/* HOMEPAGE — suggested-niche CTA banner (analyzer detected a specialized intent) */
.niche-suggest{
  display:flex;align-items:center;gap:14px;
  margin:14px 0 0;padding:14px 18px;
  background:#fff;color:#0a0d16;border:1px solid #fff;border-radius:14px;
  text-decoration:none;
  box-shadow:0 14px 36px -12px rgba(255,255,255,.18), 0 4px 12px -4px rgba(0,0,0,.4);
  transition:transform .18s;
}
.niche-suggest:hover{transform:translateY(-2px)}
.niche-suggest-icon{font-size:28px;flex-shrink:0;line-height:1}
.niche-suggest-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}
.niche-suggest-body small{font-size:10.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#5a5e6a}
.niche-suggest-body b{font-size:15px;font-weight:700;line-height:1.3;color:#0a0d16}
.niche-suggest-note{font-size:12px;color:#5a5e6a;margin-top:2px}

/* NICHE PAGE — "from your homepage brief" carry-over banner */
.brief-carry{
  display:flex;align-items:flex-start;gap:12px;
  padding:12px 16px;background:rgba(255,255,255,.03);
  border:1px solid var(--line-2);border-radius:12px;margin-bottom:14px;
}
.brief-carry-icon{font-size:20px;flex-shrink:0;line-height:1.2}
.brief-carry > div{flex:1;min-width:0}
.brief-carry small{font-size:10.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);opacity:.7}
.brief-carry p{margin:2px 0 0;font-size:13.5px;color:var(--text);line-height:1.45}

/* NICHE PAGE — minimalist mini hero (form should be the focal point) */
.niche-hero-mini{padding:18px 0 4px}
.niche-back{display:inline-block;color:var(--muted);font-size:13px;margin-bottom:10px;text-decoration:none;transition:.15s}
.niche-back:hover{color:var(--text)}
.niche-hero-mini-row{display:flex;align-items:flex-start;gap:14px;flex-wrap:wrap}
.niche-hero-mini-row > div{flex:1;min-width:280px}
.niche-hero-mini h1{font-size:clamp(22px,2.6vw,30px);line-height:1.18;letter-spacing:-.02em;margin:0 0 4px;color:var(--text);font-weight:700}
.niche-hero-mini .lead{font-size:14px;color:var(--muted);margin:0;line-height:1.5;max-width:640px}

/* NICHE PAGE — hero header (legacy big version, kept for fallback only) */
.niche-hero{padding:28px 0 18px;position:relative}
.niche-back{display:inline-block;color:var(--muted);font-size:13px;margin-bottom:14px;text-decoration:none;transition:.15s}
.niche-back:hover{color:var(--text)}
.niche-hero-grid{
  display:grid;grid-template-columns:minmax(0,1.2fr) minmax(0,.8fr);gap:32px;align-items:center;
}
.niche-hero-pill{
  display:inline-flex;align-items:center;gap:8px;
  padding:6px 12px;border-radius:999px;background:var(--surface);
  border:1px solid var(--line-2);color:var(--muted);font-size:12.5px;font-weight:600;
  margin-bottom:14px;letter-spacing:.005em;
}
.niche-hero-copy h1{font-size:clamp(28px,3.4vw,40px);line-height:1.15;letter-spacing:-.02em;margin:0 0 10px;color:var(--text);font-weight:700;max-width:680px}
.niche-hero-copy .lead{font-size:15px;color:var(--muted);max-width:620px;margin:0;line-height:1.55}
.niche-hero-art{
  position:relative;aspect-ratio:4/3;border-radius:18px;overflow:hidden;
  background:var(--surface);border:1px solid var(--line-2);
  box-shadow:0 24px 60px -20px rgba(0,0,0,.7);
}
.niche-hero-art img{width:100%;height:100%;object-fit:cover;display:block}
.niche-hero-art-empty{display:grid;place-items:center;font-size:96px;opacity:.7}
@media (max-width:900px){
  .niche-hero-grid{grid-template-columns:1fr;gap:18px}
  .niche-hero-art{order:-1;aspect-ratio:16/10;max-width:100%}
}

/* Niche tools index — card grid */
.niche-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}
.niche-card{
  display:flex;flex-direction:column;
  background:var(--surface);border:1px solid var(--line-2);border-radius:16px;overflow:hidden;
  text-decoration:none;color:var(--text);transition:transform .18s, border-color .18s, box-shadow .18s;
}
.niche-card:hover{transform:translateY(-3px);border-color:#fff;box-shadow:0 18px 40px -14px rgba(0,0,0,.55)}
.niche-card-art{
  position:relative;width:100%;aspect-ratio:4/3;background:var(--surface-2);
  display:grid;place-items:center;overflow:hidden;
}
.niche-card-art img{width:100%;height:100%;object-fit:cover;display:block}
.niche-card-emoji{font-size:54px;opacity:.85}
.niche-card-badge{
  position:absolute;top:10px;left:10px;width:36px;height:36px;border-radius:9px;
  background:rgba(10,13,22,.8);backdrop-filter:blur(6px);
  display:grid;place-items:center;font-size:20px;border:1px solid rgba(255,255,255,.14);
}
.niche-card-body{padding:14px 16px;display:flex;flex-direction:column;gap:4px}
.niche-card-body b{font-size:14.5px;font-weight:600;line-height:1.3}
.niche-card-body small{font-size:12.5px;color:var(--muted);line-height:1.45;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

/* Niche form — calmer, theme-integrated inputs (no bright paper-white) */
.niche-form input[type="url"],
.niche-form input[type="text"],
.niche-form input[type="email"],
.niche-form input[type="number"],
.niche-form textarea,
.niche-form select{
  background-color:rgba(255,255,255,.04);
  background-image:none;
  border:1.5px solid var(--line-2);
  color:var(--text);
  box-shadow:none;
  padding:11px 14px;font-size:14.5px;
  color-scheme:dark;
}
.niche-form input:hover,.niche-form select:hover,.niche-form textarea:hover{
  background-color:rgba(255,255,255,.07);border-color:rgba(255,255,255,.28);
}
.niche-form input:focus,.niche-form select:focus,.niche-form textarea:focus{
  background-color:rgba(255,255,255,.08);border-color:#fff;
  box-shadow:0 0 0 3px rgba(255,255,255,.12);
}
.niche-form select{
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path fill='%238a93a8' d='M6 8L0 0h12z'/></svg>");
  background-repeat:no-repeat;
  background-position:right 14px center;
  background-size:12px 8px;
  padding-right:38px;
}
/* Force dark dropdown panel — color-scheme isn't reliable across OS themes */
.niche-form select option{
  background-color:#0f1422;
  color:var(--text);
}
.niche-form input::placeholder,.niche-form textarea::placeholder{color:var(--muted)}
.niche-form input[type="file"]{
  background-color:rgba(255,255,255,.04);background-image:none;
  border:1.5px dashed var(--line-2);color:var(--text);
  padding:11px 14px;font-size:13.5px;
}
.niche-form input[type="file"]:hover{background-color:rgba(255,255,255,.07);border-color:rgba(255,255,255,.32)}
.niche-form input[type="file"]::file-selector-button{
  background:#fff;color:#0a0d16;border:0;border-radius:7px;
  padding:6px 12px;margin-right:12px;font-weight:600;font-size:12.5px;cursor:pointer;
  font-family:inherit;
}

/* Niche form layout — sectioned, with primary fields prominent and secondary compact */
.niche-form .field-section{margin-bottom:18px}
.niche-form .field-section-title{
  font-size:10.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  color:var(--muted);margin:0 0 8px;opacity:.7;
  display:flex;align-items:center;gap:10px;
}
.random-image-btn{
  margin-left:auto;opacity:1;
  background:rgba(255,255,255,.06);border:1px solid var(--line-2);color:var(--text);
  font-family:inherit;font-size:11.5px;font-weight:600;letter-spacing:.02em;text-transform:none;
  padding:5px 10px;border-radius:8px;cursor:pointer;transition:.15s;
}
.random-image-btn:hover{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.3)}
.random-image-preview{
  display:flex;align-items:center;gap:12px;margin-top:10px;
  padding:10px;background:rgba(255,255,255,.03);border:1px solid var(--line-2);border-radius:10px;
}
.random-image-preview[hidden]{display:none}
.random-image-preview img{width:56px;height:56px;border-radius:8px;object-fit:cover;flex-shrink:0;background:var(--surface-2)}
.random-image-meta{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}
.random-image-meta b{font-size:13px;font-weight:600}
.random-image-meta small{font-size:11.5px;color:var(--muted)}
.random-image-clear{
  flex-shrink:0;width:28px;height:28px;border-radius:7px;
  background:transparent;border:1px solid var(--line);color:var(--muted);
  font-size:18px;line-height:1;cursor:pointer;transition:.15s;
}
.random-image-clear:hover{background:rgba(239,68,68,.15);border-color:#ef4444;color:#fca5a5}
.niche-form .field-row{display:grid;gap:10px}
.niche-form .field{margin-bottom:0}
.niche-form .field > label{font-size:13px;margin-bottom:6px}
.niche-form .field-row-2{grid-template-columns:1fr 1fr}
.niche-form .field-row-3{grid-template-columns:repeat(3,1fr)}
.niche-form .field-row-4{grid-template-columns:repeat(4,1fr)}
.niche-form .field-row .field{margin-bottom:0}
.niche-form .field-wide{grid-column:1/-1}

/* Compact field — smaller padding, smaller font, muted label */
.niche-form .field-compact > label{font-size:11.5px;color:var(--muted);font-weight:600;margin-bottom:5px;letter-spacing:.01em}
.niche-form .field-compact > label .muted{font-size:11px}
.niche-form .field-compact input,
.niche-form .field-compact select,
.niche-form .field-compact textarea{
  padding:9px 12px;font-size:13.5px;border-radius:10px;border-width:1.5px;
  box-shadow:0 2px 6px -2px rgba(0,0,0,.3);
}
.niche-form .field-compact select{padding-right:34px;background-position:right 12px center}

@media (max-width:960px){
  .niche-form .field-row-4{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:720px){
  .niche-form .field-row-3,.niche-form .field-row-4{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:480px){
  .niche-form .field-row-2,.niche-form .field-row-3,.niche-form .field-row-4{grid-template-columns:1fr}
}

/* Range slider — calm, dark-theme integrated, no shine */
.range-control{
  background:transparent;border:1px solid var(--line-2);border-radius:10px;
  padding:10px 14px 8px;box-shadow:none;
}
.range-control input[type="range"]{
  width:100%;-webkit-appearance:none;appearance:none;background:transparent;
  margin:0;padding:0;border:0;height:18px;cursor:pointer;color-scheme:dark;
}
.range-control input[type="range"]::-webkit-slider-runnable-track{
  height:4px;background:linear-gradient(90deg,#fff,#fff) no-repeat,rgba(255,255,255,.12);
  background-size:var(--fill,50%) 100%;border-radius:999px;
}
.range-control input[type="range"]::-moz-range-track{height:4px;background:rgba(255,255,255,.12);border-radius:999px}
.range-control input[type="range"]::-moz-range-progress{height:4px;background:#fff;border-radius:999px}
.range-control input[type="range"]::-webkit-slider-thumb{
  -webkit-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;
  background:#fff;border:0;margin-top:-6px;cursor:pointer;
  box-shadow:0 2px 6px -1px rgba(0,0,0,.5);
}
.range-control input[type="range"]::-moz-range-thumb{
  width:16px;height:16px;border-radius:50%;background:#fff;border:0;cursor:pointer;
  box-shadow:0 2px 6px -1px rgba(0,0,0,.5);
}
.range-readout{
  display:flex;justify-content:space-between;margin-top:4px;
  font-size:11.5px;font-weight:500;color:var(--muted);font-variant-numeric:tabular-nums;
}
.range-readout b,.range-readout em{font-weight:700;font-style:normal;color:var(--text)}

/* Inline button spinner + full-screen generation overlay */
.btn-spinner{
  display:inline-block;width:14px;height:14px;
  border:2px solid rgba(255,255,255,.35);border-top-color:currentColor;
  border-radius:50%;animation:spin .9s linear infinite;
  margin-left:8px;vertical-align:-2px;
}
.btn-spinner[hidden]{display:none}
.btn-cta .btn-spinner{border-color:rgba(0,0,0,.2);border-top-color:#0a0d16}
.gen-overlay{
  position:fixed;inset:0;z-index:300;
  background:rgba(6,9,18,.85);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);
  display:flex;align-items:center;justify-content:center;padding:20px;
  animation:modalFade .22s ease;
}
.gen-overlay[hidden]{display:none}
.gen-overlay-card{
  background:var(--surface);border:1px solid var(--line-2);border-radius:18px;
  padding:36px 40px;text-align:center;max-width:420px;
  box-shadow:0 30px 80px -20px rgba(0,0,0,.7);
}
.big-spinner{
  width:48px;height:48px;border:3px solid var(--line-2);border-top-color:#fff;
  border-radius:50%;margin:0 auto 18px;animation:spin .9s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg)}}

/* Photo detail — "Remix this photo" CTA grid */
.photo-remix{margin-top:24px;padding-top:22px;border-top:1px solid var(--line)}
.photo-remix-title{font-size:18px;font-weight:700;margin:0 0 4px;letter-spacing:-.01em}
.photo-remix-sub{margin:0 0 14px;color:var(--muted);font-size:13.5px;max-width:680px}
.photo-remix-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px}
.photo-remix-card{
  display:flex;align-items:center;gap:10px;
  padding:12px 14px;border-radius:12px;
  background:var(--surface);border:1px solid var(--line-2);
  text-decoration:none;color:var(--text);transition:.15s;
}
.photo-remix-card:hover{transform:translateY(-1px);border-color:#fff;background:var(--surface-2)}
.photo-remix-emoji{font-size:24px;flex-shrink:0}
.photo-remix-label{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}
.photo-remix-label b{font-size:13.5px;font-weight:600;line-height:1.25}
.photo-remix-label small{font-size:11.5px;color:var(--muted)}
.photo-remix-arrow{font-size:18px;color:var(--muted);transition:.15s}
.photo-remix-card:hover .photo-remix-arrow{color:var(--text);transform:translateX(3px)}

/* Primary remix card — the niche this photo was originally generated by */
.photo-remix-card-primary{
  background:#fff;color:#0a0d16;border:1px solid #fff;padding:16px 20px;gap:14px;margin-bottom:14px;
  box-shadow:0 10px 28px -10px rgba(255,255,255,.25), 0 4px 12px -4px rgba(0,0,0,.4);
}
.photo-remix-card-primary:hover{background:#f3f5fa;border-color:#f3f5fa;transform:translateY(-2px)}
.photo-remix-card-primary .photo-remix-emoji{font-size:30px}
.photo-remix-card-primary .photo-remix-label b{font-size:16px;color:#0a0d16}
.photo-remix-card-primary .photo-remix-arrow{color:#0a0d16;font-size:22px}
.photo-remix-kicker{
  font-size:10.5px !important;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:#5a5e6a !important;
}
.photo-remix-altlabel{
  margin:18px 0 8px;font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  color:var(--muted);opacity:.8;
}

/* Niche page — floating "source" mini thumbnail, bottom-right */
.source-floater{
  position:fixed;right:18px;bottom:18px;z-index:80;
  display:flex;align-items:center;gap:8px;
  padding:6px 10px 6px 6px;
  background:rgba(10,13,22,.88);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);
  border:1px solid var(--line-2);border-radius:14px;
  text-decoration:none;color:var(--text);
  box-shadow:0 12px 32px -10px rgba(0,0,0,.7);
  transition:transform .18s,border-color .18s;
}
.source-floater[hidden]{display:none}
.source-floater:hover{transform:translateY(-2px);border-color:#fff}
.source-floater img{width:48px;height:48px;border-radius:9px;object-fit:cover;display:block;background:var(--surface-2)}
.source-floater-label{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
@media (max-width:560px){
  .source-floater{right:10px;bottom:10px}
  .source-floater img{width:40px;height:40px}
}

/* Photo detail — prev/next sibling navigation */
.photo-figure-wrap{position:relative}
.photo-nav-arrow{
  position:absolute;top:50%;transform:translateY(-50%);z-index:5;
  width:48px;height:48px;border-radius:50%;
  background:rgba(10,13,22,.78);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.16);
  color:#fff;font-size:30px;font-weight:300;line-height:1;
  display:grid;place-items:center;text-decoration:none;cursor:pointer;
  transition:.15s;opacity:.85;
}
.photo-nav-arrow:hover{opacity:1;background:rgba(255,255,255,.14);border-color:#fff;transform:translateY(-50%) scale(1.05)}
.photo-nav-prev{left:-12px}
.photo-nav-next{right:-12px}
@media (max-width:720px){
  .photo-nav-arrow{width:40px;height:40px;font-size:24px}
  .photo-nav-prev{left:8px}
  .photo-nav-next{right:8px}
}

/* Photo detail — clickable image + fullscreen lightbox */
.photo-zoom{
  position:relative;display:block;width:100%;padding:0;border:0;background:transparent;
  cursor:zoom-in;border-radius:inherit;overflow:hidden;
}
.photo-zoom img{display:block;width:100%;height:auto;border-radius:inherit;transition:transform .35s ease}
.photo-zoom:hover img{transform:scale(1.01)}
.photo-zoom-hint{
  position:absolute;top:14px;right:14px;
  padding:6px 12px;border-radius:999px;
  background:rgba(10,13,22,.75);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.16);
  color:#fff;font-size:12px;font-weight:600;letter-spacing:.005em;
  opacity:0;transform:translateY(-4px);transition:.18s;pointer-events:none;
}
.photo-zoom:hover .photo-zoom-hint,.photo-zoom:focus .photo-zoom-hint{opacity:1;transform:translateY(0)}

.photo-lightbox{
  position:fixed;inset:0;z-index:300;
  background:rgba(2,4,10,.94);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);
  display:flex;align-items:center;justify-content:center;padding:24px;
  animation:modalFade .2s ease;cursor:zoom-out;
}
.photo-lightbox[hidden]{display:none}
.photo-lightbox img{
  max-width:100%;max-height:100%;width:auto;height:auto;
  border-radius:8px;box-shadow:0 30px 80px -20px rgba(0,0,0,.8);
  cursor:default;
}
.photo-lightbox-close{
  position:fixed;top:18px;right:24px;z-index:310;
  width:44px;height:44px;border-radius:50%;border:1px solid rgba(255,255,255,.18);
  background:rgba(20,26,44,.92);color:#fff;font-size:24px;cursor:pointer;line-height:1;
  display:grid;place-items:center;transition:.15s;
}
.photo-lightbox-close:hover{background:rgba(255,255,255,.14);border-color:#fff}
.photo-lightbox-newtab{
  position:fixed;top:24px;left:24px;z-index:310;
  padding:8px 14px;border-radius:10px;
  background:rgba(20,26,44,.92);color:#fff;text-decoration:none;
  border:1px solid rgba(255,255,255,.18);
  font-size:13px;font-weight:600;transition:.15s;
}
.photo-lightbox-newtab:hover{background:rgba(255,255,255,.14);border-color:#fff}
@media (max-width:560px){
  .photo-lightbox{padding:12px}
  .photo-lightbox-close{top:10px;right:10px}
  .photo-lightbox-newtab{top:14px;left:10px;font-size:12px;padding:6px 10px}
}

/* Niche page — async job status card */
.job-status{padding:18px 20px}
.job-status-row{display:flex;align-items:center;gap:14px}
.job-status-pct{font-size:18px;font-weight:700;font-variant-numeric:tabular-nums;color:var(--text)}
.job-status-bar{margin-top:14px;height:6px;background:rgba(255,255,255,.08);border-radius:999px;overflow:hidden}
.job-status-fill{height:100%;background:#fff;border-radius:999px;transition:width .35s ease}
.job-status-failed{border-color:#ef4444 !important}
.job-status-failed .job-status-fill{background:#ef4444}

/* SEO helper — keep caption text in the DOM but invisible */
.visually-hidden{
  position:absolute !important;width:1px;height:1px;padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;
}
.niche-result-card figure{margin:0;width:100%;height:100%}
.niche-results-sentinel{
  display:flex;align-items:center;gap:8px;
  margin-top:18px;justify-content:center;
}
.niche-results-sentinel[hidden]{display:none}

/* Niche page — generated/recent results gallery */
.niche-results{margin-top:32px}
.niche-results-title{font-size:20px;font-weight:700;letter-spacing:-.01em;margin:0 0 4px}
.niche-results-sub{margin:0 0 14px;font-size:13.5px}
.niche-results-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;
}
.niche-result-card{
  position:relative;display:block;aspect-ratio:1/1;
  border-radius:14px;overflow:hidden;background:var(--surface-2);
  border:1px solid var(--line-2);transition:transform .18s,border-color .18s,box-shadow .18s;
}
.niche-result-card:hover{transform:translateY(-2px);border-color:#fff;box-shadow:0 18px 40px -14px rgba(0,0,0,.6)}
.niche-result-card img{width:100%;height:100%;object-fit:cover;display:block}
.niche-result-badge{
  position:absolute;top:10px;left:10px;
  background:#fff;color:#0a0d16;font-size:11px;font-weight:700;letter-spacing:.04em;
  padding:4px 10px;border-radius:999px;
}

.menu-toggle{display:none;background:rgba(255,255,255,.04);border:1px solid var(--line);width:40px;height:40px;border-radius:10px;flex-direction:column;justify-content:center;align-items:center;gap:5px;cursor:pointer;transition:.15s}
.menu-toggle:hover{background:var(--surface-2);border-color:var(--line-2)}
.menu-toggle span{display:block;width:20px;height:2px;background:var(--text);border-radius:2px;transition:.2s}
.mobile-nav{flex-direction:column;padding:10px 16px 16px;gap:4px;border-bottom:1px solid var(--line);background:rgba(10,13,22,.97);backdrop-filter:blur(14px)}
.mobile-nav[hidden]{display:none !important}
.mobile-nav a{display:block;padding:12px 14px;border-radius:10px;color:var(--muted);text-decoration:none;font-size:14px;font-weight:500}
.mobile-nav a:hover{background:var(--surface);color:var(--text)}

/* HERO — calm + compact, form is the anchor */
.hero{padding:28px 0 6px;position:relative;max-width:100vw}
.hero-bg{display:none}
.grid-overlay,.orb,.orb-1,.orb-2,.orb-3{display:none}
@keyframes float{50%{transform:translateY(0)}}

.hero .wrap{position:relative;z-index:1}
.hero-grid{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(0,.95fr);gap:32px;align-items:center}
@media (max-width:900px){.hero-grid{grid-template-columns:1fr;gap:18px}}
.pill{display:inline-flex;align-items:center;gap:8px;padding:5px 11px;border-radius:999px;font-size:11.5px;font-weight:500;
  background:rgba(255,255,255,.04);color:#9aa6c7;border:1px solid var(--line);margin-bottom:12px;letter-spacing:.01em;
}
.pill-dot{width:6px;height:6px;border-radius:50%;background:#22d3ee;opacity:.7;animation:pulse 2.4s infinite}
@keyframes pulse{0%,100%{opacity:.7;transform:scale(1)}50%{opacity:.35;transform:scale(1.2)}}
.hero h1{font-size:clamp(26px,3.2vw,38px);line-height:1.2;letter-spacing:-.02em;margin-bottom:10px;max-width:820px;font-weight:700;color:var(--text)}
.hero h1 br{display:none}
.hero h1 .grad{
  background:none;color:var(--text);-webkit-text-fill-color:var(--text);
  -webkit-background-clip:initial;background-clip:initial;font-weight:700;
}
.lead{font-size:14.5px;color:#8b98ba;max-width:740px;line-height:1.55;margin:0;font-weight:400}
.hero-cta{display:none}
.logo-img{max-height:34px;width:auto;display:block}
.report-modal{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;padding:24px}
.report-modal[hidden]{display:none}
.report-modal-backdrop{position:absolute;inset:0;background:rgba(8,11,20,.72);backdrop-filter:blur(4px)}
.report-modal-card{position:relative;background:var(--card,#0f1626);border:1px solid var(--line);border-radius:14px;padding:24px 22px;width:100%;max-width:520px;box-shadow:0 30px 80px rgba(0,0,0,.6)}
.ai-disclaimer{max-width:920px;margin:14px auto 0;padding:14px 16px;font-size:12.5px;line-height:1.55;color:#7a8497;border-top:1px solid var(--line);text-align:center}
.ai-disclaimer a{color:#9fb0d2;text-decoration:underline}
.hero-cta-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:22px}
.hero-cta-row .btn{white-space:nowrap}
@media (max-width: 540px){ .hero-cta-row .btn{flex:1;min-width:140px;justify-content:center} }
.btn-primary .arrow{transition:transform .25s}
.btn-primary:hover .arrow{transform:translateX(4px)}
.badges{display:none}
.hero-stats{display:none}

/* Hide the broken hero-art — was causing the empty right column */
.hero-art{display:none}

/* hero art — photo card stack */
.hero-art{position:relative;aspect-ratio:1/1;max-width:520px;margin-left:auto}
.art-glow{position:absolute;inset:10%;background:radial-gradient(circle, rgba(124,92,255,.4), transparent 60%);filter:blur(40px);animation:float 10s ease-in-out infinite}
.art-stack{position:relative;width:100%;height:100%}
.art-card{position:absolute;width:62%;aspect-ratio:3/4;border-radius:22px;overflow:hidden;background:var(--surface);border:1px solid var(--line-2);box-shadow:0 30px 60px -15px rgba(0,0,0,.6), 0 0 0 1px rgba(255,255,255,.05) inset;transition:transform .4s ease;animation:cardFloat 6s ease-in-out infinite}
.art-card:hover{transform:translateY(-6px)}
.art-card-1{top:8%;left:2%;transform:rotate(-8deg);z-index:2;animation-delay:0s}
.art-card-2{top:0%;left:50%;transform:translateX(-50%) rotate(2deg);z-index:3;animation-delay:-2s}
.art-card-3{top:8%;right:2%;transform:rotate(8deg);z-index:2;animation-delay:-4s}
@keyframes cardFloat{50%{transform:var(--t,translateY(-10px))}}
.art-card-1{--t:rotate(-8deg) translateY(-10px)}
.art-card-2{--t:translateX(-50%) rotate(2deg) translateY(-14px)}
.art-card-3{--t:rotate(8deg) translateY(-10px)}
.art-img{height:78%;background:linear-gradient(135deg, var(--g1, #7c5cff), var(--g2, #22d3ee));display:grid;place-items:center;position:relative;overflow:hidden}
.art-img img{width:100%;height:100%;object-fit:cover;display:block;position:relative;z-index:1}
.art-img::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 30% 20%, rgba(255,255,255,.25), transparent 50%)}
.art-emoji{font-size:54px;filter:drop-shadow(0 6px 18px rgba(0,0,0,.4));position:relative;z-index:1}
.art-meta{height:22%;padding:0 14px;display:flex;align-items:center;gap:8px;font-size:11px;color:var(--muted);font-weight:600;letter-spacing:.04em;text-transform:uppercase}
.art-dot{width:6px;height:6px;border-radius:50%;background:#10b981;box-shadow:0 0 6px #10b981}
.art-badge{position:absolute;background:rgba(15,23,42,.85);backdrop-filter:blur(14px);border:1px solid var(--line-2);border-radius:14px;padding:10px 14px;display:flex;align-items:center;gap:10px;font-size:12px;box-shadow:0 12px 30px -8px rgba(0,0,0,.5);z-index:5}
.art-badge b{display:block;font-size:13px;font-weight:600;color:var(--text)}
.art-badge span{font-size:11px;color:var(--muted)}
.art-badge-tl{top:-6%;left:-4%;animation:cardFloat 7s ease-in-out infinite}
.art-badge-br{bottom:-2%;right:-4%;animation:cardFloat 8s ease-in-out infinite -3s}
.art-badge-tl{--t:translateY(-6px)}
.art-badge-br{--t:translateY(-8px)}
.art-spinner{width:18px;height:18px;border:2px solid rgba(124,92,255,.3);border-top-color:#7c5cff;border-radius:50%;animation:spin 1s linear infinite}
.art-check{display:grid;place-items:center;width:22px;height:22px;border-radius:50%;background:linear-gradient(135deg,#10b981,#22d3ee);color:#022;font-weight:800;font-size:13px}

/* TRUST BAR — barely there */
.trust{padding:8px 0;background:transparent;border:0}
.trust-label{display:none}
.trust-row{display:flex;justify-content:center;align-items:center;gap:12px;flex-wrap:wrap;color:#6c7896;font-size:11.5px;font-weight:500}
.trust-item{display:inline-flex;align-items:center;gap:5px;opacity:.8}
.trust-sep{width:3px;height:3px;border-radius:50%;background:#3a4566}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 20px;border-radius:12px;border:1px solid transparent;font-weight:600;font-size:15px;cursor:pointer;transition:.18s;background:transparent;color:var(--text);text-decoration:none;line-height:1.2}
.btn:disabled{opacity:.45;cursor:not-allowed}

/* Primary CTA — solid white on dark, max contrast */
.btn-primary{
  background:#fff;color:#0a0d16;font-weight:700;letter-spacing:.005em;
  border:1px solid #fff;
  box-shadow:0 6px 18px -6px rgba(0,0,0,.5);
}
.btn-primary:hover:not(:disabled){
  transform:translateY(-1px);
  background:#f3f5fa;border-color:#f3f5fa;
  box-shadow:0 10px 24px -8px rgba(0,0,0,.55);
}
.btn-primary:active:not(:disabled){transform:translateY(0)}

/* Ghost (secondary) */
.btn-ghost{background:transparent;border-color:var(--line-2);color:var(--text)}
.btn-ghost:hover:not(:disabled){background:var(--surface);border-color:rgba(255,255,255,.28)}

.btn-sm{padding:7px 12px;font-size:13px;border-radius:9px}
.btn-lg{padding:14px 24px;font-size:15.5px;border-radius:13px}

/* Hero CTA — same DNA as btn-primary, bigger, the unmistakable next-step button */
.btn-cta{
  padding:16px 28px;font-size:16px;font-weight:700;letter-spacing:.005em;border-radius:12px;
  background:#fff;color:#0a0d16;border:1px solid #fff;
  box-shadow:0 10px 28px -10px rgba(0,0,0,.55), 0 2px 6px -2px rgba(0,0,0,.3);
}
.btn-cta:hover:not(:disabled){
  transform:translateY(-1px);
  background:#f3f5fa;border-color:#f3f5fa;
  box-shadow:0 16px 36px -10px rgba(0,0,0,.6);
}
.btn-cta:active:not(:disabled){transform:translateY(0);box-shadow:0 4px 12px -4px rgba(0,0,0,.4)}
.btn-cta:disabled{background:var(--surface-2);border-color:var(--line-2);color:var(--muted);cursor:not-allowed;box-shadow:none}

/* SECTION */
.section{padding:30px 0}
#start.section{padding-top:14px;padding-bottom:36px;position:relative}
#start.section::before{display:none}
#start .wrap{position:relative;z-index:1}
.section-alt{background:rgba(255,255,255,.02);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.section-title{text-align:center;margin-bottom:8px}
.section-sub{text-align:center;color:var(--muted);max-width:600px;margin:0 auto 36px}

/* STEP RAIL — clean, monochrome, only active step shows label */
.step-rail{
  position:sticky;top:64px;z-index:30;
  display:flex;align-items:center;gap:6px;
  padding:10px 14px;background:rgba(15,20,34,.95);backdrop-filter:blur(12px);
  border:1px solid var(--line);border-radius:12px;margin-bottom:14px;
}
.step-dot{
  display:inline-flex;align-items:center;gap:8px;
  padding:4px 6px;border-radius:999px;font-size:13px;color:var(--muted);
  white-space:nowrap;transition:.18s;cursor:pointer;flex-shrink:0;
  background:transparent;
}
.step-dot b{
  display:grid;place-items:center;width:26px;height:26px;border-radius:50%;
  background:transparent;border:1.5px solid var(--line-2);color:var(--muted);
  font-size:12px;font-weight:700;flex-shrink:0;transition:.18s;font-variant-numeric:tabular-nums;
}
.step-dot span{display:none}
.step-dot.active{padding:4px 14px 4px 4px;color:var(--text)}
.step-dot.active span{display:inline;font-size:13px;font-weight:600;letter-spacing:-.005em}
.step-dot.active b{background:#fff;color:#0a0d16;border-color:#fff}
.step-dot.done b{background:transparent;color:var(--text);border-color:var(--text)}
.step-dot.done b::before{content:"✓";font-size:13px}
.step-dot.done b{font-size:0}
.step-line{flex:1;height:1.5px;background:var(--line);border-radius:2px;min-width:8px;max-width:60px}
.step-line.done{background:var(--text)}

/* PANEL — clean focal surface, no animated glow */
.panel{
  position:relative;background:var(--surface);
  border:1px solid var(--line-2);border-radius:16px;padding:26px 28px;
  box-shadow:0 12px 36px -16px rgba(0,0,0,.5);
}
@keyframes panelGlow{0%,100%{box-shadow:0 12px 36px -16px rgba(0,0,0,.5)}}
.panel h2{margin-bottom:6px;font-size:22px}
.panel > p.muted:first-of-type{margin-top:0;margin-bottom:18px;font-size:14px}
.panel-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;flex-wrap:wrap;margin-bottom:18px}
.head-actions{display:flex;gap:10px;flex-wrap:wrap}

/* TABS */
.tabs{display:inline-flex;background:var(--bg-2);border:1px solid var(--line);border-radius:12px;padding:4px;margin:8px 0 18px}
.tabs button{background:transparent;border:0;color:var(--muted);padding:8px 16px;border-radius:9px;cursor:pointer;font-weight:600;font-size:14px}
.tabs button.active{background:var(--surface-2);color:var(--text)}

/* FIELDS */
.field{margin-bottom:18px}
.field label{display:block;font-size:14px;font-weight:600;margin-bottom:8px;color:var(--muted)}
/* Form fields — paper-card on dark, maximum contrast so users see the input */
input[type="url"],input[type="text"],input[type="password"],input[type="email"],input[type="number"],textarea,select{
  width:100%;
  background:#f5f7fb;                 /* near-white "paper" */
  border:2px solid #c9d1e6;
  border-radius:12px;
  padding:14px 16px;
  color:#0e1430;                      /* dark text on light field */
  font-family:inherit;font-size:15px;line-height:1.55;font-weight:500;
  transition:.18s;outline:none;color-scheme:light;
  box-shadow:0 4px 12px -4px rgba(0,0,0,.4);
}
input[type="url"]:hover,input[type="text"]:hover,input[type="password"]:hover,input[type="email"]:hover,input[type="number"]:hover,textarea:hover,select:hover{
  background:#fff;border-color:#a3afd0;
}
/* Native select arrow */
select{
  appearance:none;-webkit-appearance:none;-moz-appearance:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path fill='%230e1430' d='M6 8L0 0h12z'/></svg>");
  background-repeat:no-repeat;background-position:right 16px center;background-size:12px 8px;
  padding-right:42px;cursor:pointer;
}
/* File input — make it look like our paper button */
input[type="file"]{
  width:100%;background:#f5f7fb;border:2px dashed #c9d1e6;border-radius:12px;
  padding:14px 16px;color:#0e1430;font-family:inherit;font-size:14px;font-weight:500;
  cursor:pointer;transition:.18s;
}
input[type="file"]:hover{background:#fff;border-color:#a3afd0}
input[type="file"]::file-selector-button{
  background:#0a0d16;color:#fff;border:0;border-radius:8px;
  padding:8px 14px;margin-right:14px;font-weight:600;font-size:13px;cursor:pointer;
  font-family:inherit;transition:.15s;
}
input[type="file"]::file-selector-button:hover{background:#1b2238}
input::placeholder,textarea::placeholder{color:#7c8aaa;font-weight:400}
textarea{min-height:130px;resize:vertical}
.field-brief textarea{min-height:170px}
@media (max-width:560px){
  .field-brief textarea{min-height:230px;font-size:14.5px}
}
/* Field labels — visible and clearly attached to their input */
.field{margin-bottom:18px}
.field > label{
  display:flex;align-items:baseline;gap:8px;
  font-size:13.5px;font-weight:600;color:#dee5f8;
  margin-bottom:8px;letter-spacing:.005em;
}
.field > label .req{color:#fb7185;font-weight:700}
.field > label .muted{font-weight:400;font-size:12.5px}
/* Override browser autofill ugly yellow */
input:-webkit-autofill,input:-webkit-autofill:hover,input:-webkit-autofill:focus{
  -webkit-text-fill-color:var(--text);
  -webkit-box-shadow:0 0 0 30px var(--bg-2) inset !important;
  caret-color:var(--text);
}
textarea{resize:vertical;line-height:1.5}
input:focus,textarea:focus{
  border-color:#0a0d16;background:#fff;
  box-shadow:0 0 0 3px rgba(255,255,255,.35), 0 8px 24px -8px rgba(0,0,0,.5);
}
.url-row{display:flex;gap:10px}
.url-row input{flex:1}
.url-row .btn{white-space:nowrap}
.hint{font-size:13px;color:var(--muted);margin:8px 0 0}

.actions{display:flex;justify-content:space-between;align-items:center;margin-top:24px;gap:10px;flex-wrap:wrap}
.actions-right{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
@media (max-width:560px){
  .actions-step5{flex-direction:column-reverse;align-items:stretch}
  .actions-step5 .actions-right{flex-direction:column-reverse;align-items:stretch}
  .actions-step5 .btn{width:100%;justify-content:center}
}

/* PURPOSES */
.purpose-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;margin-top:16px}
.purpose{background:var(--bg-2);border:1px solid var(--line-2);border-radius:14px;padding:18px;text-align:left;cursor:pointer;color:var(--text);transition:.18s;display:flex;flex-direction:column;gap:6px}
.purpose:hover{border-color:rgba(255,255,255,.32);transform:translateY(-1px)}
.purpose.active{border-color:#fff;background:var(--surface-2);box-shadow:0 0 0 1px #fff inset}
.purpose .emoji{font-size:24px}
.purpose b{font-size:15px}
.purpose small{color:var(--muted);font-size:12px}

/* COUNT */
.count-grid{display:flex;gap:10px;flex-wrap:wrap;margin-top:16px}
.count{flex:1;min-width:80px;background:var(--bg-2);border:1px solid var(--line-2);border-radius:14px;padding:18px;cursor:pointer;color:var(--text);transition:.18s;display:flex;flex-direction:column;align-items:center;gap:2px}
.count:hover{border-color:rgba(255,255,255,.32)}
.count.active{border-color:#fff;background:var(--surface-2);box-shadow:0 0 0 1px #fff inset}
.count b{font-size:24px}
.count small{color:var(--muted);font-size:12px}

/* THUMB GRID — scraped images & inspiration uploads */
.thumb-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:10px;margin-top:6px}
.thumb{position:relative;aspect-ratio:1/1;border-radius:12px;overflow:hidden;cursor:pointer;background:var(--bg-2);border:1px solid var(--line);padding:0;transition:.18s}
.thumb img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .25s ease}
.thumb:hover img{transform:scale(1.05)}
.thumb.active{border-color:#fff;box-shadow:0 0 0 2px #fff}
.thumb.active::after{content:"";position:absolute;inset:0;background:rgba(0,0,0,.35)}
.thumb-check{position:absolute;top:6px;right:6px;width:22px;height:22px;border-radius:50%;background:#fff;color:#0a0d16;display:none;place-items:center;font-weight:800;font-size:12px;z-index:2}
.thumb.active .thumb-check{display:grid}
.thumb-static{cursor:default}
.thumb-x{position:absolute;top:4px;right:4px;width:22px;height:22px;border-radius:50%;background:rgba(0,0,0,.7);border:1px solid var(--line-2);color:#fff;font-size:14px;cursor:pointer;line-height:1;display:grid;place-items:center;z-index:2;transition:.15s}
.thumb-x:hover{background:#ef4444}

/* DROPZONE — unified, compact, full-width */
.dz{
  display:flex;align-items:center;gap:16px;
  padding:16px 18px;border:1.5px dashed var(--line-2);border-radius:14px;
  background:var(--bg-2);cursor:pointer;transition:.18s;outline:none;width:100%;
}
.dz:hover,.dz.drag,.dz:focus{border-color:rgba(255,255,255,.4);background:var(--surface)}
.dz:focus{box-shadow:0 0 0 3px rgba(255,255,255,.12)}
.dz.busy{opacity:.7;pointer-events:none}
.dz-glyph{font-size:28px;flex-shrink:0;line-height:1}
.dz-text{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}
.dz-text b{font-size:14.5px;color:var(--text);line-height:1.3}
.dz-text small{color:var(--muted);font-size:12px;line-height:1.45}
.dz-text kbd{display:inline-block;background:var(--bg);border:1px solid var(--line-2);border-bottom-width:2px;border-radius:4px;padding:0 5px;font-family:'JetBrains Mono','SF Mono',Consolas,monospace;font-size:10.5px;color:var(--text);line-height:1.5}
.dz-paste-btn{
  flex-shrink:0;background:var(--surface);border:1px solid var(--line-2);border-radius:10px;
  padding:8px 14px;color:var(--text);font-weight:600;font-size:13px;cursor:pointer;
  font-family:inherit;transition:.15s;display:inline-flex;align-items:center;gap:6px;
}
.dz-paste-btn:hover:not(:disabled){border-color:#7c5cff;background:rgba(124,92,255,.1)}
.dz-paste-btn:disabled{opacity:.5;cursor:not-allowed}

.dz-sm{padding:12px 16px}
.dz-sm .dz-glyph{font-size:24px}
.dz-sm .dz-text b{font-size:14px}

@media (max-width:560px){
  .dz{flex-wrap:wrap}
  .dz-paste-btn{width:100%;justify-content:center}
}

/* Logo loaded state — compact preview row */
.logo-loaded{
  display:flex;align-items:center;gap:14px;
  padding:12px 14px;background:var(--bg-2);border:1px solid rgba(16,185,129,.4);
  border-radius:14px;
}
.logo-thumb{
  width:54px;height:54px;border-radius:10px;background:#fff;flex-shrink:0;
  display:grid;place-items:center;padding:6px;
}
.logo-thumb img{max-width:100%;max-height:100%;object-fit:contain;display:block}
.logo-side{flex:1;min-width:0;display:flex;flex-direction:column;gap:6px}
.logo-name{font-size:13px;color:#a7f3d0;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.logo-side input[type="text"]{padding:8px 12px;font-size:13px;border-radius:9px}
.logo-remove{
  flex-shrink:0;width:36px;height:36px;font-size:18px;padding:0;
  border-radius:50%;background:transparent;border:1px solid var(--line);color:var(--muted);
}
.logo-remove:hover{background:rgba(239,68,68,.15);border-color:#ef4444;color:#fca5a5}

/* LOGO ROW */
.logo-row{display:grid;grid-template-columns:140px 1fr;gap:14px;align-items:start}
.logo-drop{aspect-ratio:1/1;border:2px dashed var(--line-2);border-radius:14px;background:var(--bg-2);display:grid;place-items:center;cursor:pointer;overflow:hidden;transition:.18s;position:relative}
.logo-drop:hover,.logo-drop.drag{border-color:#7c5cff;background:rgba(124,92,255,.08)}
.logo-drop.has{border-style:solid;background:#fff;padding:10px}
.logo-drop img{max-width:100%;max-height:100%;object-fit:contain;display:block}
.logo-empty{display:flex;flex-direction:column;align-items:center;gap:6px;color:var(--muted)}
.logo-empty span{font-size:32px}
.logo-empty small{font-size:11.5px}
.logo-meta{display:flex;flex-direction:column;gap:8px}
.logo-meta input[type="text"]{width:100%}
@media (max-width:560px){
  .logo-row{grid-template-columns:1fr}
  .logo-drop{max-width:160px;margin:0 auto}
}

/* SUBJECTS (multi-select) */
.subject-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:10px;margin-top:16px}
.subject{position:relative;background:var(--bg-2);border:1px solid var(--line-2);border-radius:14px;padding:14px 14px;text-align:left;cursor:pointer;color:var(--text);transition:.18s;display:flex;flex-direction:column;gap:4px}
.subject:hover{border-color:rgba(255,255,255,.32);transform:translateY(-1px)}
.subject.active{border-color:#fff;background:var(--surface-2);box-shadow:0 0 0 1px #fff inset}
.subject .emoji{font-size:22px}
.subject b{font-size:14px}
.subject small{color:var(--muted);font-size:12px}
.subject-check{position:absolute;top:8px;right:8px;width:22px;height:22px;border-radius:50%;background:#fff;color:#0a0d16;display:grid;place-items:center;font-weight:800;font-size:12px}

/* PROMPT REVIEW */
.review-meta{display:flex;flex-wrap:wrap;gap:8px;margin:8px 0 24px;padding:14px 16px;background:linear-gradient(135deg, rgba(124,92,255,.08), rgba(34,211,238,.04));border:1px solid var(--line);border-radius:14px}
.review-chip{display:flex;flex-direction:column;padding:6px 14px;background:var(--surface);border:1px solid var(--line);border-radius:10px;gap:1px;min-width:0}
.review-chip span{font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:600}
.review-chip b{font-size:13px;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:280px}

.prompts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(380px,1fr));gap:14px}
.pcard{position:relative;background:var(--bg-2);border:1px solid var(--line);border-radius:16px;padding:0;overflow:hidden;transition:.18s;display:flex;flex-direction:column}
.pcard::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:linear-gradient(180deg,#7c5cff,#22d3ee);opacity:.6;transition:.18s}
.pcard:hover{border-color:var(--line-2);transform:translateY(-2px);box-shadow:0 12px 28px -12px rgba(0,0,0,.5)}
.pcard:hover::before{opacity:1;width:4px}
.pcard:focus-within{border-color:#7c5cff;box-shadow:0 0 0 3px rgba(124,92,255,.18)}
.pcard:focus-within::before{opacity:1;width:5px}
.pcard.loading{opacity:.55}
.pcard.loading::before{background:linear-gradient(180deg,#7c5cff,#22d3ee,#7c5cff);background-size:100% 200%;animation:slidev 1.4s linear infinite}
@keyframes slidev{from{background-position:0 0}to{background-position:0 -200%}}

.pcard-head{display:flex;align-items:center;gap:12px;padding:14px 16px 8px;border-bottom:1px solid var(--line)}
.pcard-num{display:grid;place-items:center;min-width:38px;height:38px;border-radius:10px;background:linear-gradient(135deg, rgba(124,92,255,.18), rgba(34,211,238,.1));border:1px solid rgba(124,92,255,.35);color:#cdd5f0;font-weight:800;font-size:13px;font-variant-numeric:tabular-nums;letter-spacing:-.02em}
.pcard-title{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}
.pcard-title b{font-size:14px;color:var(--text)}
.pcard-words{font-size:11.5px;color:var(--muted);font-variant-numeric:tabular-nums}
.pcard-tools{display:flex;gap:4px}
.icon-btn{width:34px;height:34px;border-radius:9px;background:transparent;border:1px solid var(--line);color:var(--muted);cursor:pointer;display:grid;place-items:center;font-size:15px;transition:.15s}
.icon-btn:hover:not(:disabled){background:var(--surface-2);border-color:var(--line-2);color:var(--text)}
.icon-btn:disabled{opacity:.4;cursor:not-allowed}
.icon-btn-danger:hover:not(:disabled){background:rgba(239,68,68,.15);border-color:#ef4444;color:#fca5a5}

.pcard textarea{
  width:100%;border:0;border-radius:0;background:transparent;
  padding:14px 16px;font-size:13.5px;line-height:1.6;color:var(--text);
  font-family:inherit;resize:none;min-height:130px;
  transition:none;
}
.pcard textarea:focus{outline:none;background:rgba(124,92,255,.04);box-shadow:none;border:0}

.pcard-foot{display:flex;flex-wrap:wrap;gap:6px;padding:10px 14px 14px;border-top:1px solid var(--line);background:rgba(0,0,0,.15)}
.pcard-tag{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;background:var(--surface);border:1px solid var(--line);border-radius:999px;font-size:11px;color:var(--muted);font-weight:500}

.add-shot-row{margin-top:14px;text-align:center}
.btn-add-shot{border:1px dashed var(--line-2);background:transparent;color:var(--muted);padding:14px 24px;width:100%;justify-content:center;font-weight:500}
.btn-add-shot:hover{color:var(--text);border-color:#7c5cff;border-style:solid;background:rgba(124,92,255,.05)}

.actions-sticky{margin-top:24px;padding-top:20px;border-top:1px solid var(--line);position:sticky;bottom:0;background:linear-gradient(to top, var(--surface) 70%, transparent);padding-bottom:8px;z-index:5}

@media (max-width:560px){
  .prompts-grid{grid-template-columns:1fr}
  .review-chip b{max-width:140px}
}

/* STEP RAIL — clickable */
.step-rail .step-dot{cursor:pointer}
.step-rail .step-dot:hover b{filter:brightness(1.1)}

/* Step 1 brief status chips */
.brief-status{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}
.brief-chip{
  display:inline-flex;align-items:center;gap:6px;
  padding:6px 12px;border-radius:999px;font-size:12.5px;font-weight:500;
  background:rgba(255,255,255,.04);border:1px solid var(--line);color:var(--muted);
}
.brief-chip b{color:var(--text);font-weight:600;font-family:'JetBrains Mono','SF Mono',Consolas,monospace;font-size:11.5px}
.brief-chip-action{cursor:pointer;background:linear-gradient(135deg,rgba(124,92,255,.15),rgba(34,211,238,.08));border-color:rgba(124,92,255,.4);color:#dcd5ff;transition:.15s}
.brief-chip-action:hover{background:rgba(124,92,255,.25);border-color:#7c5cff;color:var(--text);transform:translateY(-1px)}
.brief-chip-ok{background:rgba(16,185,129,.1);border-color:rgba(16,185,129,.35);color:#a7f3d0}

/* RECOMMENDED / OTHER section labels */
.reco-label{display:flex;align-items:center;gap:8px;margin:18px 0 10px}
.reco-label::after{content:"";flex:1;height:1px;background:linear-gradient(90deg, var(--line), transparent)}
.reco-tag{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;border-radius:999px;font-size:11.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;
  background:linear-gradient(135deg,rgba(124,92,255,.2),rgba(34,211,238,.12));color:#dcd5ff;border:1px solid rgba(124,92,255,.4)}
.reco-tag-other{background:transparent;border-color:var(--line);color:var(--muted)}

/* "Show more" link button */
.show-more-btn{margin:14px 0 4px;width:100%;justify-content:center;border:1px dashed var(--line-2);background:transparent;color:var(--muted);font-weight:500;padding:10px 14px}
.show-more-btn:hover{color:var(--text);border-color:#7c5cff;background:rgba(124,92,255,.05)}

/* "Other" tier — slight dim */
.style-grid.dim,.purpose-grid.dim,.subject-grid.dim{opacity:.78}
.style-grid.dim:hover,.purpose-grid.dim:hover,.subject-grid.dim:hover{opacity:1;transition:opacity .15s}

/* STYLE PICKER */
.style-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;margin-top:18px}
.style-card{position:relative;background:var(--bg-2);border:1px solid var(--line-2);border-radius:18px;padding:0;cursor:pointer;color:var(--text);transition:.22s;overflow:hidden;text-align:left;display:flex;flex-direction:column}
.style-card:hover{border-color:#7c5cff;transform:translateY(-3px);box-shadow:0 14px 30px -10px rgba(124,92,255,.4)}
.style-card.active{border-color:#7c5cff;box-shadow:0 0 0 3px rgba(124,92,255,.3), 0 14px 30px -10px rgba(124,92,255,.45)}
.style-preview{aspect-ratio:16/9;display:grid;place-items:center;position:relative;overflow:hidden}
.style-preview::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 30% 25%, rgba(255,255,255,.25), transparent 55%)}
.style-icon{font-size:38px;filter:drop-shadow(0 4px 14px rgba(0,0,0,.3));position:relative;z-index:1}
.style-text{padding:14px 16px}
.style-text b{display:block;font-size:15px;margin-bottom:3px}
.style-text small{display:block;color:var(--muted);font-size:12.5px;line-height:1.45}
.style-check{position:absolute;top:10px;right:10px;width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,#7c5cff,#22d3ee);color:#0b1020;display:grid;place-items:center;font-weight:800;font-size:14px;box-shadow:0 4px 12px rgba(124,92,255,.5);z-index:2}

/* SUB-LABEL */
.sub-label{display:block;font-size:13px;font-weight:600;color:var(--muted);margin:8px 0 8px;text-transform:uppercase;letter-spacing:.06em}

/* FORMAT */
.format-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px;margin-top:8px}
.fmt{background:var(--bg-2);border:1px solid var(--line-2);border-radius:14px;padding:14px 12px;cursor:pointer;color:var(--text);transition:.18s;display:flex;flex-direction:column;align-items:center;gap:6px;text-align:center}
.fmt:hover{border-color:#7c5cff;transform:translateY(-2px)}
.fmt.active{border-color:#7c5cff;background:linear-gradient(135deg,rgba(124,92,255,.18),rgba(34,211,238,.08));box-shadow:0 0 0 3px rgba(124,92,255,.25)}
.fmt b{font-size:14px}
.fmt small{color:var(--muted);font-size:11px;line-height:1.3}
.fmt-shape{display:block;background:linear-gradient(135deg,rgba(124,92,255,.4),rgba(34,211,238,.4));border:1px solid var(--line-2);border-radius:6px;margin-bottom:4px}
.fmt-shape[data-ratio="1:1"]{width:42px;height:42px}
.fmt-shape[data-ratio="2:3"]{width:32px;height:48px}
.fmt-shape[data-ratio="3:2"]{width:48px;height:32px}
.fmt-shape[data-ratio="16:9"]{width:54px;height:30px}
.fmt-shape[data-ratio="9:16"]{width:30px;height:54px}

/* SUMMARY */
.summary{margin-top:22px;display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;padding:16px;background:var(--bg-2);border-radius:14px;border:1px solid var(--line)}
.summary > div{display:flex;flex-direction:column;gap:2px;font-size:14px}
.summary span{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.05em}
.summary b{font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* GALLERY */
.gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:18px;margin-top:8px}
.gcard{background:var(--bg-2);border:1px solid var(--line);border-radius:16px;overflow:hidden;display:flex;flex-direction:column;transition:.18s}
.gcard:hover{border-color:var(--line-2)}
.gcard-img{position:relative;aspect-ratio:1/1;background:#0a0f22;display:grid;place-items:center;overflow:hidden}
.gcard-img.clickable{cursor:zoom-in}
.gcard-img.clickable:hover img{transform:scale(1.04)}
.gcard-img img{transition:transform .35s ease}
.zoom-hint{position:absolute;bottom:8px;right:8px;background:rgba(0,0,0,.65);backdrop-filter:blur(6px);padding:4px 10px;border-radius:999px;font-size:11px;font-weight:600;color:#fff;opacity:0;transition:.2s;pointer-events:none}
.gcard-img.clickable:hover .zoom-hint{opacity:1}
.gcard-img img{width:100%;height:100%;object-fit:cover;display:block}
.gnum{position:absolute;top:8px;left:8px;background:rgba(0,0,0,.6);backdrop-filter:blur(6px);padding:3px 10px;border-radius:999px;font-size:12px;font-weight:600}
.ph-empty,.ph-loader{color:var(--muted);font-size:13px;display:flex;flex-direction:column;gap:10px;align-items:center}
.ph-empty span{font-size:36px;opacity:.4}
.ph-loader .bar{width:60%;height:3px;background:var(--line);border-radius:3px;overflow:hidden;position:relative}
.ph-loader .bar::after{content:"";position:absolute;inset:0;width:40%;background:linear-gradient(90deg,#7c5cff,#22d3ee);animation:slide 1.4s infinite}
@keyframes slide{0%{transform:translateX(-100%)}100%{transform:translateX(250%)}}
.gcard-img.loading{background:linear-gradient(135deg,#16213d,#0f172a)}
.prompt-edit{padding:10px 14px;border-top:1px solid var(--line)}
.prompt-edit summary{cursor:pointer;font-size:13px;color:var(--muted);font-weight:600;list-style:none;padding:4px 0}
.prompt-edit summary::-webkit-details-marker{display:none}
.prompt-edit summary::before{content:"▸ ";display:inline-block;transition:.2s}
.prompt-edit[open] summary::before{transform:rotate(90deg)}
.prompt-edit textarea{margin-top:8px;font-size:13px;background:var(--bg)}
.gcard-actions{padding:10px 14px;display:flex;gap:8px;justify-content:space-between;border-top:1px solid var(--line)}
.gcard-actions .btn{flex:1;justify-content:center}
.bulk-bar{margin-top:24px;display:flex;justify-content:center;gap:10px;flex-wrap:wrap}
.bulk-bar .btn{min-width:200px;justify-content:center}

/* ============================================================
   DOCS PAGE
   ============================================================ */
.docs{display:grid;grid-template-columns:240px 1fr;gap:36px;max-width:1240px;margin:0 auto;padding:30px 24px 60px;align-items:start}
.docs-side{position:sticky;top:84px;display:flex;flex-direction:column;gap:1px;font-size:14px}
.docs-side h4{font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);font-weight:700;margin:18px 0 6px}
.docs-side h4:first-child{margin-top:0}
.docs-side a{padding:6px 10px;border-radius:8px;color:var(--muted);text-decoration:none;transition:.12s;font-weight:500}
.docs-side a:hover{background:var(--surface);color:var(--text)}
.docs-main{min-width:0}
.docs-hero{padding:14px 0 28px;border-bottom:1px solid var(--line);margin-bottom:30px}
.docs-hero h1{font-size:clamp(34px,4.5vw,52px);line-height:1.05;margin:14px 0 14px;letter-spacing:-.02em}
.docs-hero .lead{font-size:17px;max-width:680px;margin:0 0 22px}
.docs-block{margin:48px 0;padding-top:6px}
.docs-block h2{font-size:24px;margin-bottom:14px;display:flex;align-items:center;gap:10px;padding-bottom:8px;border-bottom:1px solid var(--line)}
.docs-block h4{font-size:13px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin:18px 0 8px;font-weight:700}
.docs-block p{font-size:15px;line-height:1.65;color:#cdd5f0}
.docs-block code{background:var(--surface);padding:2px 7px;border-radius:5px;font-size:13px;color:#c2b6ff;border:1px solid var(--line);font-family:'JetBrains Mono',monospace}

/* HTTP method pills */
.m{display:inline-block;padding:3px 9px;border-radius:6px;font-size:11px;font-weight:800;letter-spacing:.04em;font-family:'JetBrains Mono',monospace;text-transform:uppercase;line-height:1.4}
.m-get{background:rgba(34,211,238,.18);color:#67e8f9;border:1px solid rgba(34,211,238,.4)}
.m-post{background:rgba(16,185,129,.18);color:#6ee7b7;border:1px solid rgba(16,185,129,.4)}
.m-del{background:rgba(239,68,68,.18);color:#fca5a5;border:1px solid rgba(239,68,68,.4)}

/* Code blocks */
.code{background:#0a0f22;border:1px solid var(--line);border-radius:12px;padding:16px 18px;font-family:'JetBrains Mono',monospace;font-size:13px;line-height:1.6;color:#cdd5f0;overflow-x:auto;white-space:pre;margin:8px 0;tab-size:2}
.code .c{color:#64748b;font-style:italic}
.code .j{color:#a5f3fc}
.code .x{color:#fde68a}

/* Tabs (docs) */
.docs-tabs{display:inline-flex;gap:2px;background:var(--bg-2);border:1px solid var(--line);border-radius:10px;padding:3px;margin-bottom:8px}
.docs-tabs button{background:transparent;border:0;color:var(--muted);padding:6px 14px;border-radius:7px;font-weight:600;font-size:13px;cursor:pointer;font-family:inherit}
.docs-tabs button.active{background:var(--surface-2);color:var(--text);box-shadow:0 0 0 1px var(--line-2) inset}
.docs-main [data-pane]{display:none}
.docs-main [data-pane].active{display:block}

/* API sub-nav — desktop pill row, mobile dropdown */
.api-subnav{position:relative;margin:18px 0 10px;width:fit-content}
.api-subnav-current{display:none}
.api-subnav-list{display:flex;flex-wrap:wrap;gap:6px;padding:6px;background:rgba(255,255,255,.03);border:1px solid var(--line);border-radius:12px}
.api-subnav-list a{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:8px;font-size:13px;font-weight:600;color:var(--muted);text-decoration:none;transition:.12s}
.api-subnav-list a:hover{color:var(--text);background:var(--surface)}
.api-subnav-list a.active{background:linear-gradient(135deg,#7c5cff,#22d3ee);color:#0b1020}

@media (max-width:640px){
  .api-subnav{width:100%}
  .api-subnav-current{
    display:flex;justify-content:space-between;align-items:center;width:100%;gap:8px;
    padding:10px 14px;border:1px solid var(--line);border-radius:12px;
    background:linear-gradient(135deg,#7c5cff,#22d3ee);color:#0b1020;
    font-family:inherit;font-size:14px;font-weight:700;cursor:pointer;
    box-shadow:0 6px 14px -6px rgba(124,92,255,.5);
  }
  .api-subnav-current .chev{font-size:14px;transition:transform .2s}
  .api-subnav.open .api-subnav-current .chev{transform:rotate(180deg)}

  .api-subnav-list{
    display:none;flex-direction:column;gap:2px;
    position:absolute;top:calc(100% + 6px);left:0;right:0;z-index:30;
    background:rgba(17,26,51,.96);backdrop-filter:blur(14px);
    box-shadow:0 16px 40px -8px rgba(0,0,0,.6);
  }
  .api-subnav.open .api-subnav-list{display:flex}
  .api-subnav-list a{padding:11px 14px;border-radius:9px;color:var(--text);font-size:13.5px}
  .api-subnav-list a:hover{background:var(--surface-2)}
  .api-subnav-list a.active{background:rgba(124,92,255,.18);color:#dcd5ff}
}

/* Param table */
.param-table{width:100%;border-collapse:collapse;font-size:13.5px;background:var(--surface);border:1px solid var(--line);border-radius:12px;overflow:hidden;margin:10px 0}
.param-table th,.param-table td{padding:10px 14px;text-align:left;vertical-align:top;border-bottom:1px solid var(--line)}
.param-table th{background:var(--surface-2);font-weight:600;font-size:11.5px;text-transform:uppercase;letter-spacing:.04em;color:var(--text)}
.param-table tr:last-child td{border-bottom:0}
.param-table td{color:var(--muted)}
.param-table td:first-child{color:var(--text)}
.param-table code{font-size:12.5px}

.flow-steps{padding-left:0;list-style:none;counter-reset:step;display:flex;flex-direction:column;gap:14px}
.flow-steps li{position:relative;padding:14px 16px 14px 56px;background:var(--surface);border:1px solid var(--line);border-radius:12px;font-size:14.5px;line-height:1.6;color:#cdd5f0}
.flow-steps li::before{counter-increment:step;content:counter(step);position:absolute;left:14px;top:50%;transform:translateY(-50%);width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,#7c5cff,#22d3ee);color:#0b1020;font-weight:800;display:grid;place-items:center;font-size:13px}

.style-pills{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}
.style-pills span{padding:6px 12px;background:var(--bg-2);border:1px solid var(--line);border-radius:999px;font-size:13px;color:var(--text);font-weight:500}

/* User API key entry on docs */
.key-input-card{margin-top:24px;padding:18px 20px;background:rgba(255,255,255,.03);border:1px solid var(--line);border-radius:14px}
.key-input-card label{display:block;font-size:13.5px;margin-bottom:10px}
.key-input-card label b{color:var(--text)}
.key-input-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.key-input-row input{flex:1;min-width:220px;font-family:'JetBrains Mono','SF Mono',Consolas,monospace;font-size:13px}
#keyStatus code{font-family:'JetBrains Mono',monospace;font-size:11.5px}

.agentic-block{padding:24px;border:1px solid rgba(124,92,255,.4);background:linear-gradient(135deg, rgba(124,92,255,.08), rgba(34,211,238,.04));border-radius:18px;margin-top:60px}
.agentic-block h2{border-bottom:none}
.agentic-code{font-size:12.5px;line-height:1.55;max-height:520px;overflow:auto}

@media (max-width:920px){
  .docs{grid-template-columns:1fr}
  .docs-side{position:static;display:none}
}

/* ============================================================
   PLAYGROUND
   ============================================================ */
.pg-header{margin-bottom:30px}
.pg-header h1{font-size:clamp(30px,4vw,46px);margin-bottom:8px}
.pg-shell{display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:start}
@media (max-width:920px){ .pg-shell{grid-template-columns:1fr} }

.pg-form{background:var(--surface);border:1px solid var(--line);border-radius:18px;padding:24px}
.pg-form h3{font-size:13px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:700;margin:0 0 18px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.pg-form input[type="text"],
.pg-form input[type="number"],
.pg-form select,
.pg-form textarea{
  width:100%;background:var(--bg-2);border:1px solid var(--line-2);border-radius:12px;
  padding:12px 14px;color:var(--text);font-family:inherit;font-size:14px;outline:none;
  transition:.15s;color-scheme:dark;
}
.pg-form select{
  cursor:pointer;appearance:none;-webkit-appearance:none;-moz-appearance:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path fill='%239aa6c7' d='M6 8L0 0h12z'/></svg>");
  background-repeat:no-repeat;background-position:right 14px center;padding-right:36px;
}
.pg-form input:focus,.pg-form select:focus,.pg-form textarea:focus{border-color:#7c5cff;box-shadow:0 0 0 3px rgba(124,92,255,.18)}
.pg-form input[type="number"]{font-variant-numeric:tabular-nums}
/* Hide native number spinner — use clean look */
.pg-form input[type="number"]::-webkit-outer-spin-button,
.pg-form input[type="number"]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}

.pg-code{background:#0a0f22;border:1px solid var(--line);border-radius:18px;padding:14px;display:flex;flex-direction:column;gap:8px;min-height:520px;max-height:780px;overflow:hidden;min-width:0}
.pg-tabs{display:flex;gap:2px;background:var(--bg-2);border:1px solid var(--line);border-radius:10px;padding:3px;width:fit-content;flex-shrink:0}
.pg-tabs button{background:transparent;border:0;color:var(--muted);padding:6px 14px;border-radius:7px;font-weight:600;font-size:12.5px;cursor:pointer;font-family:inherit}
.pg-tabs button.active{background:var(--surface-2);color:var(--text)}
.pg-code [data-pane]{
  display:none;background:transparent;border:0;padding:4px 2px;margin:0;flex:1;overflow:auto;min-width:0;
  font-family:'JetBrains Mono','SF Mono',Consolas,monospace;font-size:12.5px;line-height:1.6;color:#cdd5f0;
  white-space:pre-wrap;word-break:break-word;overflow-wrap:anywhere;
}
.pg-code [data-pane].active{display:block}

.pg-status{margin-top:30px;padding:18px 20px;background:linear-gradient(135deg,rgba(124,92,255,.1),rgba(34,211,238,.05));border:1px solid rgba(124,92,255,.35);border-radius:14px}
.pg-status-row{display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap}
.pg-status-label{font-size:11px;text-transform:uppercase;color:var(--muted);letter-spacing:.08em;font-weight:600;display:block;margin-bottom:2px}
#statusVal{font-size:16px;text-transform:uppercase;letter-spacing:.05em}
.pg-progress-wrap{flex:1;max-width:300px;height:8px;background:var(--bg-2);border-radius:999px;overflow:hidden}
.pg-progress{height:100%;background:linear-gradient(90deg,#7c5cff,#22d3ee);transition:width .4s;width:0}

.pg-results{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;margin-top:24px}
.pg-card{background:var(--surface);border:1px solid var(--line);border-radius:14px;overflow:hidden;animation:fadeIn .4s ease}
@keyframes fadeIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.pg-card-img{display:block;aspect-ratio:1/1;overflow:hidden;background:#0a0f22}
.pg-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.pg-card:hover img{transform:scale(1.05)}
.pg-card-body{padding:12px 14px}
.pg-card-body h4{font-size:13px;margin:0 0 4px;line-height:1.35}
.pg-card-body p{margin:0 0 8px;font-size:12px;line-height:1.45}

/* AGENTIC HANDOFF */
.agentic{margin-top:32px;padding:24px;border-radius:18px;background:linear-gradient(135deg,rgba(124,92,255,.12),rgba(34,211,238,.08));border:1px solid rgba(124,92,255,.35);box-shadow:0 0 0 1px rgba(124,92,255,.15) inset, 0 12px 40px -12px rgba(124,92,255,.4)}
.agentic-head{display:flex;justify-content:space-between;align-items:flex-start;gap:18px;flex-wrap:wrap;margin-bottom:16px}
.agentic-head h3{font-size:18px;margin-bottom:4px}
.agentic-head p{margin:0;font-size:14px;max-width:560px}
.bundle-meta{display:flex;flex-direction:column;align-items:flex-end;gap:6px}
.bundle-info{font-size:12px;color:var(--muted);font-variant-numeric:tabular-nums}
.agentic-body{position:relative}
.agentic-ta{width:100%;min-height:280px;font-family:'JetBrains Mono','SF Mono',Consolas,monospace;font-size:13px;line-height:1.55;background:rgba(8,12,28,.85);border:1px solid var(--line-2);border-radius:14px;padding:16px 18px;color:#cdd5f0;resize:vertical;cursor:pointer}
.agentic-ta:focus{border-color:#7c5cff;box-shadow:0 0 0 3px rgba(124,92,255,.2)}
.copy-btn{position:absolute;top:12px;right:12px;z-index:2}
@media (max-width:600px){
  .copy-btn{position:static;width:100%;margin-top:10px;justify-content:center}
}

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

/* ERROR */
.errbox{margin-top:18px;padding:14px 18px;background:rgba(239,68,68,.12);border:1px solid rgba(239,68,68,.4);border-radius:12px;color:#fecaca;display:flex;justify-content:space-between;align-items:center;gap:12px}
.errbox button{background:none;border:0;color:inherit;font-size:22px;cursor:pointer;line-height:1}

/* HOW */
.how-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px}
.how-card{padding:24px;background:var(--surface);border:1px solid var(--line);border-radius:18px;position:relative;transition:.18s}
.how-card:hover{transform:translateY(-3px);border-color:var(--line-2)}
.how-card span{display:block;font-size:13px;font-weight:700;color:#7c5cff;margin-bottom:12px;letter-spacing:.1em}
.how-card p{color:var(--muted);font-size:14px;margin:6px 0 0}

/* PRICING */
.price-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px}
.price-card{position:relative;padding:28px;background:var(--surface);border:1px solid var(--line);border-radius:20px;transition:.18s}
.price-card:hover{transform:translateY(-3px)}
.price-card.hl{border-color:#7c5cff;box-shadow:0 0 0 1px #7c5cff inset, var(--shadow)}
.ribbon{position:absolute;top:-10px;right:18px;background:linear-gradient(135deg,#7c5cff,#22d3ee);color:#0b1020;padding:4px 12px;border-radius:999px;font-size:11px;font-weight:700}
.price{font-size:32px;font-weight:800;margin:14px 0;background:linear-gradient(90deg,#7c5cff,#22d3ee);-webkit-background-clip:text;background-clip:text;color:transparent}
.price small{font-size:14px;font-weight:500;color:var(--muted);background:none;-webkit-text-fill-color:var(--muted)}
.price-card ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}
.price-card li{padding-left:20px;position:relative;font-size:14px;color:var(--muted)}
.price-card li::before{content:"✓";position:absolute;left:0;color:#10b981;font-weight:700}

/* LEGAL */
.legal{max-width:780px;margin:0 auto;padding:20px 0 40px}
.legal .back{display:inline-block;margin-bottom:24px;font-size:14px;color:var(--muted);transition:.15s}
.legal .back:hover{color:var(--text)}
.legal h1{font-size:clamp(28px,4vw,42px);margin-bottom:8px}
.legal h2{font-size:20px;margin:36px 0 12px;padding-bottom:8px;border-bottom:1px solid var(--line)}
.legal p,.legal li{color:#cbd2eb;font-size:15px;line-height:1.7}
.legal ul{padding-left:20px}
.legal li{margin:6px 0}
.legal a{color:#22d3ee;text-decoration:underline;text-underline-offset:3px}
.legal a:hover{color:#7c5cff}
.legal code{background:var(--surface);padding:2px 7px;border-radius:5px;font-size:13px;color:#c2b6ff;border:1px solid var(--line)}
.legal .callout{margin:20px 0 28px;padding:18px 20px;border-radius:14px;background:linear-gradient(135deg,rgba(124,92,255,.12),rgba(34,211,238,.08));border:1px solid rgba(124,92,255,.3);color:var(--text);font-size:15px;line-height:1.6}
.legal-table{width:100%;border-collapse:collapse;margin:14px 0;font-size:14px;background:var(--surface);border:1px solid var(--line);border-radius:12px;overflow:hidden}
.legal-table th,.legal-table td{padding:12px 14px;text-align:left;vertical-align:top;border-bottom:1px solid var(--line)}
.legal-table th{background:var(--surface-2);font-weight:600;color:var(--text);font-size:13px;text-transform:uppercase;letter-spacing:.04em}
.legal-table tr:last-child td{border-bottom:0}
.legal-table td{color:var(--muted)}
.legal-table td:first-child{color:var(--text);font-weight:500}
@media (max-width:600px){
  .legal-table thead{display:none}
  .legal-table tr{display:block;padding:12px 14px;border-bottom:1px solid var(--line)}
  .legal-table tr:last-child{border-bottom:0}
  .legal-table td{display:block;padding:4px 0;border:0}
  .legal-table td:first-child{font-weight:700;margin-bottom:4px}
}

/* FOOTER */
.footer{margin-top:60px;padding:60px 0 30px;background:rgba(0,0,0,.25);border-top:1px solid var(--line)}
.footer-grid{display:grid;grid-template-columns:1.5fr repeat(3,1fr);gap:40px;margin-bottom:40px}
.footer h4{margin-bottom:12px;font-size:14px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}
.footer a{display:block;padding:4px 0;color:var(--muted);font-size:14px;transition:.15s}
.footer a:hover{color:var(--text)}
.copy{padding-top:20px;border-top:1px solid var(--line);color:var(--muted);font-size:13px;text-align:center}
.copy a{display:inline !important;padding:0 !important;color:var(--muted);text-decoration:none;transition:.15s}
.copy a:hover{color:var(--text)}

/* LIGHTBOX */
.lightbox{position:fixed;inset:0;z-index:100;background:rgba(5,8,20,.92);backdrop-filter:blur(20px);display:grid;grid-template-rows:1fr auto;padding:24px;gap:16px}
.lb-stage{display:grid;place-items:center;overflow:hidden;min-height:0}
.lb-stage img{max-width:100%;max-height:100%;width:auto;height:auto;border-radius:16px;box-shadow:0 30px 80px -20px rgba(0,0,0,.8), 0 0 0 1px var(--line-2);object-fit:contain}
.lb-meta{max-width:900px;margin:0 auto;width:100%;background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:14px 18px}
.lb-row{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}
.lb-counter{font-size:13px;font-weight:600;color:var(--muted);font-variant-numeric:tabular-nums}
.lb-actions{display:flex;gap:8px;flex-wrap:wrap}
.lb-prompt{margin-top:10px}
.lb-prompt summary{cursor:pointer;font-size:13px;font-weight:600;color:var(--muted);list-style:none;padding:4px 0}
.lb-prompt summary::-webkit-details-marker{display:none}
.lb-prompt summary::before{content:"▸ ";display:inline-block;transition:.2s}
.lb-prompt[open] summary::before{transform:rotate(90deg)}
.lb-prompt textarea{margin-top:8px;font-size:13px}
.lb-close{position:absolute;top:18px;right:18px;width:44px;height:44px;border-radius:50%;background:var(--surface);border:1px solid var(--line-2);color:var(--text);font-size:28px;cursor:pointer;display:grid;place-items:center;line-height:1;transition:.18s;z-index:2}
.lb-close:hover{background:var(--surface-2);transform:rotate(90deg)}
.lb-nav{position:absolute;top:50%;transform:translateY(-50%);width:52px;height:52px;border-radius:50%;background:rgba(255,255,255,.08);border:1px solid var(--line-2);color:var(--text);font-size:34px;cursor:pointer;backdrop-filter:blur(10px);display:grid;place-items:center;line-height:1;transition:.18s;z-index:2}
.lb-nav:hover{background:rgba(124,92,255,.4);border-color:#7c5cff}
.lb-prev{left:18px}.lb-next{right:18px}
.lb-enter-active,.lb-leave-active{transition:opacity .25s ease}
.lb-enter-from,.lb-leave-to{opacity:0}
.lb-enter-active .lb-stage img,.lb-leave-active .lb-stage img{transition:transform .25s ease}
.lb-enter-from .lb-stage img{transform:scale(.95)}

/* ============================================================
   LOGIN
   ============================================================ */
.login-shell{min-height:100vh;display:grid;place-items:center;padding:24px;position:relative;overflow:hidden;
  background:var(--bg)}
.login-bg{position:absolute;inset:0;pointer-events:none}
.login-bg .orb{opacity:.4}
.login-card{position:relative;z-index:1;background:rgba(17,26,51,.85);backdrop-filter:blur(20px);border:1px solid var(--line-2);border-radius:22px;padding:40px 36px;width:100%;max-width:420px;
  box-shadow:0 40px 80px -20px rgba(0,0,0,.6), 0 0 0 1px rgba(124,92,255,.15)}

/* ============================================================
   PAGE HERO (catalog public page)
   ============================================================ */
.page-hero{position:relative;padding:70px 0 40px;overflow:hidden}
.page-hero-bg{position:absolute;inset:0;pointer-events:none;z-index:0}
.page-hero-inner{position:relative;z-index:1;text-align:center;max-width:780px;margin:0 auto}
.page-hero h1{font-size:clamp(34px,5vw,54px);line-height:1.05;letter-spacing:-.03em;margin:18px 0 16px}
.page-hero .lead{margin:0 auto;max-width:620px}
.page-hero .pill{margin-bottom:0}

/* SEARCH BAR — single flat dark surface, no double borders */
.search-bar{
  display:flex;align-items:center;gap:6px;
  background:var(--surface);
  border:1px solid var(--line-2);
  border-radius:12px;
  padding:6px 6px 6px 14px;
  margin:30px auto 0;max-width:680px;
  transition:border-color .15s;
}
.search-bar:focus-within{border-color:#fff}
.sb-icon{display:grid;place-items:center;width:24px;height:24px;font-size:16px;flex-shrink:0;opacity:.55;color:var(--muted)}
.search-bar input,
.search-bar input[type="text"]{
  flex:1;min-width:0;
  background:transparent !important;
  border:0 !important;
  padding:10px 6px !important;
  font-size:15px;color:var(--text);
  outline:none;box-shadow:none !important;
  border-radius:0 !important;
}
.search-bar input::placeholder{color:var(--muted)}
.search-bar .btn{flex-shrink:0;padding:10px 18px;font-size:14px;border-radius:8px}

.facet-row{display:flex;justify-content:center;align-items:center;gap:8px;flex-wrap:wrap;margin-top:22px}
.facet-label{font-size:12px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.08em;margin-right:6px}
.facet-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:var(--surface);border:1px solid var(--line-2);border-radius:999px;font-size:13px;color:var(--text);text-decoration:none;transition:.15s;font-weight:500}
.facet-chip:hover{border-color:#fff;background:var(--surface-2)}
.facet-chip span{font-size:11px;color:var(--muted);background:rgba(255,255,255,.06);padding:1px 8px;border-radius:999px;font-weight:600}

/* RESULT BAR */
.section-catalog{padding-top:30px}
.result-bar{margin-bottom:22px;padding:14px 18px;background:rgba(255,255,255,.03);border:1px solid var(--line);border-radius:12px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px}
.result-bar em{font-style:normal;color:var(--text);font-weight:600}

/* ============================================================
   MASONRY CATALOG GRID
   ============================================================ */
/* Catalog grid — uniform 4:3 thumbnails, same shape as niche/detail pages */
.masonry{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.masonry-card{position:relative;border-radius:14px;overflow:hidden;text-decoration:none;color:inherit;display:block;background:var(--surface-2);
  border:1px solid var(--line-2);aspect-ratio:4/3;
  transition:transform .18s, border-color .18s, box-shadow .18s;}
.masonry-card:hover{transform:translateY(-2px);border-color:#fff;
  box-shadow:0 18px 40px -14px rgba(0,0,0,.6)}
/* legacy orientation modifiers — no-op now, kept so old markup still works */
.masonry-sq,.masonry-tall,.masonry-wide{aspect-ratio:4/3}
.mc-img{position:relative;width:100%;height:100%;display:block}
.mc-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .45s cubic-bezier(.2,.7,.2,1)}
.masonry-card:hover .mc-img img{transform:scale(1.04)}
.mc-overlay{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:14px 14px 12px;
  background:linear-gradient(180deg, transparent 45%, rgba(0,0,0,.85) 100%);
  opacity:0;transform:translateY(6px);transition:.2s}
.masonry-card:hover .mc-overlay{opacity:1;transform:none}
.mc-overlay h3{font-size:14px;margin:0 0 3px;color:#fff;line-height:1.3;font-weight:600}
.mc-overlay p{margin:0;font-size:11.5px;color:rgba(255,255,255,.78);line-height:1.45;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.mc-meta{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px;font-size:11px;color:rgba(255,255,255,.65)}

@media (max-width:1080px){ .masonry{grid-template-columns:repeat(3,1fr)} }
@media (max-width:760px) { .masonry{grid-template-columns:repeat(2,1fr)} }
@media (max-width:460px) { .masonry{grid-template-columns:1fr}
  .mc-overlay{opacity:1;transform:none} }

/* ============================================================
   EMPTY STATE
   ============================================================ */
.empty-state{text-align:center;padding:80px 24px;background:rgba(255,255,255,.02);border:1px dashed var(--line-2);border-radius:22px;margin-top:14px}
.empty-icon{font-size:64px;margin-bottom:14px;filter:grayscale(.4) opacity(.85)}
.empty-state h3{font-size:22px;margin:0 0 6px}

/* ============================================================
   PAGER
   ============================================================ */
.pager{display:flex;justify-content:center;gap:6px;margin-top:36px;flex-wrap:wrap;align-items:center}
.pg{padding:9px 14px;background:rgba(255,255,255,.03);border:1px solid var(--line);border-radius:10px;font-size:13px;font-weight:600;color:var(--muted);text-decoration:none;transition:.15s;min-width:40px;text-align:center}
.pg:hover{color:var(--text);border-color:var(--line-2);background:var(--surface)}
.pg.active{background:linear-gradient(135deg,#7c5cff,#22d3ee);color:#0b1020;border-color:transparent;box-shadow:0 6px 16px -6px rgba(124,92,255,.6)}
.pg-arrow{padding:9px 16px}
.pg-dots{padding:9px 6px;color:var(--muted)}

/* ============================================================
   ADMIN — TOPBAR
   ============================================================ */
.admin-body{background:var(--bg)}
.admin-bar{position:sticky;top:0;z-index:50;backdrop-filter:blur(14px);background:rgba(11,16,32,.85);border-bottom:1px solid var(--line)}
.admin-bar-inner{display:flex;align-items:center;justify-content:space-between;height:64px}
.admin-tag{display:inline-block;background:linear-gradient(135deg,#ef4444,#f59e0b);color:#1a0a00;padding:3px 8px;border-radius:6px;font-size:10px;font-weight:800;letter-spacing:.08em;margin-left:8px;vertical-align:middle}
.admin-nav{display:flex;align-items:center;gap:18px}
.admin-nav a{color:var(--muted);font-size:14px;text-decoration:none;font-weight:500;transition:.15s}
.admin-nav a:hover{color:var(--text)}
.admin-nav .who{font-size:13px;color:var(--muted);padding:6px 12px;background:var(--surface);border:1px solid var(--line);border-radius:999px}
.admin-nav .who b{color:var(--text)}
@media (max-width:760px){
  .admin-nav .who{display:none}
  .admin-nav{gap:10px}
  .admin-nav a{font-size:13px}
}

/* ============================================================
   ADMIN — LAYOUT (full width, no wrap constraint)
   ============================================================ */
.admin-bar .wrap,
.section-admin .wrap{max-width:none !important;padding:0 28px}
.section-admin{padding:24px 0 60px}
.admin-shell{display:grid;grid-template-columns:260px 1fr;gap:24px;align-items:start;width:100%}
@media (max-width:1024px){
  .admin-shell{grid-template-columns:1fr}
  .admin-bar .wrap,.section-admin .wrap{padding:0 18px}
}

/* SIDEBAR */
.admin-side{position:sticky;top:88px;display:flex;flex-direction:column;gap:14px}
@media (max-width:1024px){ .admin-side{position:static} }
.dash-card{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:18px}
.dash-title{font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);font-weight:700;margin:0 0 14px}

.dash-stats{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.dash-stat{display:flex;flex-direction:column;gap:1px;padding:10px 12px;background:var(--bg-2);border:1px solid var(--line);border-radius:10px}
.dash-stat span{font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:600}
.dash-stat b{font-size:20px;font-weight:800;font-variant-numeric:tabular-nums;color:var(--text)}
.dash-stat-wide{grid-column:1 / -1}

.dash-filter{display:flex;flex-direction:column;gap:4px}
.dash-filter a{display:flex;justify-content:space-between;align-items:center;padding:9px 12px;border-radius:9px;color:var(--muted);text-decoration:none;font-size:14px;font-weight:500;transition:.15s}
.dash-filter a:hover{background:var(--bg-2);color:var(--text)}
.dash-filter a.active{background:linear-gradient(135deg, rgba(124,92,255,.18), rgba(34,211,238,.08));color:var(--text);border:1px solid rgba(124,92,255,.4)}
.dash-filter span{font-size:11px;background:var(--bg-2);padding:2px 8px;border-radius:999px;color:var(--muted);font-weight:700}
.dash-filter a.active span{background:rgba(124,92,255,.3);color:#dcd5ff}

.dash-meta{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}
.dash-meta li{display:flex;justify-content:space-between;align-items:center;font-size:13px;padding:7px 0;border-bottom:1px dashed var(--line)}
.dash-meta li:last-child{border-bottom:0}
.dash-meta span{color:var(--muted)}
.dash-meta b{color:var(--text);font-weight:600}
.pill-on{display:inline-block;padding:2px 10px;border-radius:999px;background:rgba(16,185,129,.2);color:#a7f3d0;font-size:11px;font-weight:700;letter-spacing:.05em}
.pill-off{display:inline-block;padding:2px 10px;border-radius:999px;background:rgba(239,68,68,.2);color:#fca5a5;font-size:11px;font-weight:700;letter-spacing:.05em}

/* MAIN COLUMN */
.admin-main{min-width:0}
.admin-head h1{font-size:clamp(28px,3.4vw,38px);margin:0 0 6px}
.admin-head p{margin:0;max-width:580px}

/* ROW CARDS */
.ad-grid{display:flex;flex-direction:column;gap:14px;margin-top:8px}
.ad-row{display:grid;grid-template-columns:160px 1fr auto;gap:18px;background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:14px;transition:.2s;align-items:start}
.ad-row:hover{border-color:var(--line-2);box-shadow:0 14px 30px -16px rgba(0,0,0,.5)}
.ad-row-img{position:relative;width:160px;height:160px;border-radius:12px;overflow:hidden;background:#0a0f22;display:block;flex-shrink:0;align-self:start}
.ad-row-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s ease}
.ad-row:hover .ad-row-img img{transform:scale(1.05)}
.ad-row-badges{position:absolute;top:8px;left:8px;right:8px;display:flex;justify-content:space-between;align-items:flex-start;pointer-events:none;gap:6px}

.ad-badge{backdrop-filter:blur(8px);padding:3px 9px;border-radius:999px;font-size:11px;font-weight:600;border:1px solid rgba(255,255,255,.12);white-space:nowrap}
.ad-badge-pub{background:rgba(16,185,129,.25);color:#a7f3d0}
.ad-badge-hid{background:rgba(239,68,68,.25);color:#fecaca}
.ad-badge-s3{background:rgba(124,92,255,.3);color:#dcd5ff}

.ad-row-body{display:flex;flex-direction:column;gap:8px;min-width:0}
.ad-row-top{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}
.ad-row-top h3{font-size:16px;line-height:1.3;margin:0}
.ad-row-id{font-size:11px;color:var(--muted);font-variant-numeric:tabular-nums;background:var(--bg-2);padding:2px 8px;border-radius:999px;flex-shrink:0}
.ad-row-desc{margin:0;color:var(--muted);font-size:13.5px;line-height:1.55;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.ad-tags{display:flex;flex-wrap:wrap;gap:5px}
.ad-tag{padding:3px 9px;background:var(--bg-2);border:1px solid var(--line);border-radius:999px;font-size:11px;color:var(--muted);text-decoration:none;font-weight:500}
a.ad-tag:hover{color:var(--text);border-color:#7c5cff}
.ad-row-meta{display:flex;flex-wrap:wrap;gap:14px;font-size:11.5px;color:var(--muted);margin-top:auto;padding-top:6px}
.ad-row-meta span{display:inline-flex;align-items:center;gap:4px}

.ad-row-tools{display:flex;flex-direction:column;gap:6px;align-items:stretch;min-width:120px}
.ad-row-tools .btn{justify-content:center;font-size:12.5px;padding:7px 12px}
.btn-danger{background:rgba(239,68,68,.12) !important;color:#fca5a5 !important;border:1px solid rgba(239,68,68,.4) !important}
.btn-danger:hover{background:rgba(239,68,68,.22) !important;border-color:#ef4444 !important;color:#fff !important}

@media (max-width:760px){
  .ad-row{grid-template-columns:120px 1fr;grid-template-areas:"img body" "tools tools";gap:12px}
  .ad-row-img{grid-area:img}
  .ad-row-body{grid-area:body}
  .ad-row-tools{grid-area:tools;flex-direction:row;flex-wrap:wrap;min-width:0}
  .ad-row-tools .btn{flex:1;min-width:90px}
}

/* ============================================================
   AUTH (login, signup, forgot, reset)
   ============================================================ */
.auth-shell{min-height:calc(100vh - 80px);display:grid;place-items:center;padding:40px 16px}
.auth-card{
  width:100%;max-width:420px;background:rgba(17,26,51,.85);backdrop-filter:blur(14px);
  border:1px solid var(--line-2);border-radius:20px;padding:32px 28px;
  box-shadow:0 0 60px -10px rgba(124,92,255,.4), 0 24px 60px -20px rgba(0,0,0,.5);
}
.auth-card h1{font-size:24px;margin:0 0 6px}
.auth-card .muted{margin:0 0 20px;font-size:13.5px}
.auth-alt{margin:18px 0 0;text-align:center;font-size:13.5px;color:var(--muted)}
.auth-alt a{color:#22d3ee;text-decoration:none;font-weight:600}
.auth-alt a:hover{color:#7c5cff}

/* Flash messages */
.flash{padding:12px 16px;border-radius:11px;font-size:13.5px;margin-bottom:14px;border:1px solid}
.flash-ok{background:rgba(16,185,129,.1);border-color:rgba(16,185,129,.4);color:#a7f3d0}
.flash-err{background:rgba(239,68,68,.1);border-color:rgba(239,68,68,.4);color:#fca5a5}
.flash-warn{background:rgba(245,158,11,.1);border-color:rgba(245,158,11,.4);color:#fcd34d}

/* Topbar actions (auth icon + hamburger) */
.topbar-actions{display:flex;align-items:center;gap:8px}

/* Auth icon + dropdown */
.auth-menu{position:relative}
.auth-btn{
  display:inline-flex;align-items:center;justify-content:center;
  width:40px;height:40px;border-radius:10px;
  background:rgba(255,255,255,.04);border:1px solid var(--line);color:var(--text);
  cursor:pointer;transition:.15s;padding:0;
}
.auth-btn:hover{background:var(--surface-2);border-color:var(--line-2)}
.auth-btn[aria-expanded="true"]{background:var(--surface-2);border-color:#7c5cff;box-shadow:0 0 0 3px rgba(124,92,255,.18)}
.auth-btn .topnav-avatar{width:26px;height:26px;font-size:12px}
.auth-drop{
  position:absolute;top:calc(100% + 8px);right:0;min-width:240px;
  background:rgba(17,26,51,.96);backdrop-filter:blur(16px);
  border:1px solid var(--line-2);border-radius:14px;
  padding:6px;z-index:60;
  box-shadow:0 20px 50px -10px rgba(0,0,0,.6), 0 0 0 1px rgba(124,92,255,.15);
}
.auth-drop[hidden]{display:none !important}
.auth-drop a{
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 12px;border-radius:9px;color:var(--text);
  text-decoration:none;font-size:13.5px;font-weight:500;transition:.12s;
}
.auth-drop a:hover{background:var(--surface-2)}
.auth-drop a em{font-style:normal;font-size:11.5px;color:var(--muted);font-variant-numeric:tabular-nums;background:rgba(124,92,255,.15);padding:2px 8px;border-radius:999px}
.auth-drop hr{border:0;border-top:1px solid var(--line);margin:6px 0}
.auth-drop-head{display:flex;align-items:center;gap:10px;padding:12px 12px 10px;border-bottom:1px solid var(--line);margin-bottom:6px}
.auth-drop-head b{display:block;font-size:13.5px;color:var(--text)}
.auth-drop-head small{display:block;font-size:11.5px;color:var(--muted);margin-top:1px}

/* Topbar credit pill + user avatar */
.topnav-credit{display:inline-flex;align-items:center;gap:5px;padding:5px 12px;border-radius:999px;background:linear-gradient(135deg,rgba(124,92,255,.18),rgba(34,211,238,.1));border:1px solid rgba(124,92,255,.4);font-size:13px;color:var(--text);font-weight:500}
.topnav-credit b{font-weight:800;font-variant-numeric:tabular-nums;background:linear-gradient(135deg,#7c5cff,#22d3ee);-webkit-background-clip:text;background-clip:text;color:transparent}
.topnav-user{display:inline-flex;align-items:center;gap:8px;padding:5px 12px 5px 5px;border-radius:999px;background:var(--surface);border:1px solid var(--line);font-size:13px;color:var(--text)}
.topnav-user:hover{border-color:var(--line-2);background:var(--surface-2)}
.topnav-avatar{display:inline-grid;place-items:center;width:26px;height:26px;border-radius:50%;background:linear-gradient(135deg,#7c5cff,#22d3ee);color:#0b1020;font-weight:800;font-size:12px}
.topnav-email{max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* ============================================================
   DASHBOARD
   ============================================================ */
.dash-hero{display:flex;justify-content:space-between;align-items:flex-start;gap:18px;flex-wrap:wrap;margin-bottom:22px}
.dash-hero h1{font-size:clamp(28px,4vw,38px);margin:6px 0 4px}
.dash-hero p{margin:0}
.dash-hero-actions{display:flex;gap:8px;flex-wrap:wrap}

.dash-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;margin:14px 0 26px}
.dash-stat-card{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:18px 20px;display:flex;flex-direction:column;gap:3px}
.dash-stat-card span{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:700}
.dash-stat-card b{font-size:34px;font-weight:800;font-variant-numeric:tabular-nums;line-height:1.1;color:var(--text)}
.dash-stat-card small{color:var(--muted);font-size:12px}

.dash-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:24px;align-items:start}
@media (max-width:880px){ .dash-grid{grid-template-columns:1fr} }

/* ============================================================
   PRICING
   ============================================================ */
.plan-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px;margin-top:14px}
.plan-card{position:relative;background:var(--surface);border:1px solid var(--line);border-radius:20px;padding:24px;display:flex;flex-direction:column;transition:.18s}
.plan-card:hover{transform:translateY(-3px);border-color:var(--line-2)}
.plan-featured{border-color:rgba(124,92,255,.6);box-shadow:0 0 0 1px rgba(124,92,255,.4) inset, 0 20px 60px -20px rgba(124,92,255,.5)}
.plan-current{border-color:rgba(16,185,129,.5);box-shadow:0 0 0 1px rgba(16,185,129,.3) inset}
.plan-ribbon{position:absolute;top:-12px;right:18px;background:linear-gradient(135deg,#7c5cff,#22d3ee);color:#0b1020;padding:4px 12px;border-radius:999px;font-size:11px;font-weight:800;letter-spacing:.05em}
.plan-ribbon-current{background:linear-gradient(135deg,#10b981,#22d3ee)}
.plan-card h3{font-size:20px;margin:0 0 6px}
.plan-desc{color:var(--muted);font-size:13.5px;margin:0 0 18px;min-height:38px}
.plan-price{margin:8px 0 6px;display:flex;align-items:baseline;gap:6px}
.plan-price b{font-size:38px;font-weight:800;letter-spacing:-.02em;background:linear-gradient(135deg,#7c5cff,#22d3ee);-webkit-background-clip:text;background-clip:text;color:transparent}
.plan-price span{color:var(--muted);font-size:14px;font-weight:500}
.plan-credits{font-size:13px;color:var(--muted);margin-bottom:14px}
.plan-credits b{color:var(--text);font-size:15px;font-weight:700}
.plan-feats{list-style:none;padding:0;margin:0 0 18px;display:flex;flex-direction:column;gap:8px;flex:1}
.plan-feats li{position:relative;padding-left:22px;font-size:13.5px;color:var(--muted);line-height:1.5}
.plan-feats li::before{content:"✓";position:absolute;left:0;color:#10b981;font-weight:700}

.plan-faq{margin-top:48px}
.faq-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:14px;margin-top:14px}
.faq-item{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:18px}
.faq-item b{display:block;font-size:14px;margin-bottom:6px}
.faq-item p{margin:0;font-size:13px;color:var(--muted);line-height:1.55}

/* ============================================================
   BILLING
   ============================================================ */
.bill-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:14px}
@media (max-width:760px){ .bill-grid{grid-template-columns:1fr} }
.bill-card{background:var(--surface);border:1px solid var(--line);border-radius:18px;display:flex;flex-direction:column;overflow:hidden}
.bill-card-h{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--line);background:rgba(255,255,255,.02)}
.bill-card-h span{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:700}
.bill-card-h b{font-size:22px;font-weight:800}
.bill-card-body{padding:18px 20px;display:flex;flex-direction:column;gap:10px;flex:1}
.bill-card-body .field{margin:0}
.bill-line{display:flex;justify-content:space-between;align-items:center;font-size:13.5px;padding:6px 0;border-bottom:1px dashed var(--line)}
.bill-line:last-child{border-bottom:0}
.bill-line span{color:var(--muted)}
.bill-line b{color:var(--text);font-weight:600}
.bill-line code{background:var(--bg-2);padding:2px 8px;border-radius:5px;font-size:11.5px;color:#cdd5f0;border:1px solid var(--line);font-family:'JetBrains Mono','SF Mono',Consolas,monospace}
.bill-card-foot{padding:14px 20px;border-top:1px solid var(--line);background:rgba(0,0,0,.15);display:flex;gap:8px;flex-wrap:wrap}

.bill-actions{margin-top:36px;display:flex;gap:10px;justify-content:flex-end;flex-wrap:wrap}

.danger-zone{border-color:rgba(239,68,68,.4) !important}
.danger-zone .bill-card-h{background:rgba(239,68,68,.06);border-color:rgba(239,68,68,.3)}

/* ============================================================
   FILTER PILLS (admin)
   ============================================================ */
.filter-pills{display:flex;gap:6px;flex-wrap:wrap}
.filter-pills a{padding:7px 14px;background:var(--surface);border:1px solid var(--line);border-radius:999px;font-size:13px;font-weight:600;color:var(--muted);text-decoration:none;transition:.15s;display:inline-flex;align-items:center;gap:6px}
.filter-pills a:hover{color:var(--text);border-color:var(--line-2)}
.filter-pills a.active{background:linear-gradient(135deg,#7c5cff,#22d3ee);color:#0b1020;border-color:transparent;box-shadow:0 6px 14px -6px rgba(124,92,255,.6)}
.filter-pills em{font-style:normal;font-size:11px;background:rgba(0,0,0,.2);padding:1px 8px;border-radius:999px;font-weight:700}
.filter-pills a:not(.active) em{background:var(--bg-2);color:var(--muted)}

/* ============================================================
   API KEYS — admin
   ============================================================ */
.key-banner{display:flex;align-items:center;gap:18px;padding:18px 22px;margin:14px 0 22px;
  background:linear-gradient(135deg,rgba(16,185,129,.15),rgba(34,211,238,.06));
  border:1px solid rgba(16,185,129,.4);border-radius:16px;flex-wrap:wrap}
.key-banner h3{margin:0 0 4px;font-size:16px;color:#a7f3d0}
.key-banner p{margin:0;font-size:13px}
.key-show{flex:1;min-width:240px;padding:12px 14px;background:#0a0f22;border:1px solid var(--line-2);border-radius:10px;
  font-family:'JetBrains Mono','SF Mono',Consolas,monospace;font-size:13px;color:#67e8f9;user-select:all;word-break:break-all}

.key-form-card{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:22px}
.key-form{display:grid;grid-template-columns:1.4fr 1fr auto;gap:14px;align-items:end}
.key-form .field{margin:0}
.key-form-actions{display:flex;gap:8px}
@media (max-width:760px){ .key-form{grid-template-columns:1fr} }

.keys-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:14px;margin-top:14px}
.key-card{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:18px;transition:.18s;display:flex;flex-direction:column;gap:14px}
.key-card:hover{border-color:var(--line-2);box-shadow:0 14px 30px -16px rgba(0,0,0,.5)}
.key-inactive{opacity:.6}
.key-card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}
.key-card-head h3{margin:0 0 6px;font-size:15px;line-height:1.3}
.key-card-tags{display:flex;flex-wrap:wrap;gap:4px}

.key-row{display:flex;gap:6px;align-items:center;padding:10px 12px;background:#0a0f22;border:1px solid var(--line);border-radius:10px}
.key-value{flex:1;font-family:'JetBrains Mono','SF Mono',Consolas,monospace;font-size:12.5px;color:#cdd5f0;word-break:break-all;cursor:text;user-select:all}

.key-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:6px;font-size:12.5px}
.key-stats > div{display:flex;flex-direction:column;padding:8px 10px;background:var(--bg-2);border-radius:8px;border:1px solid var(--line)}
.key-stats span{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;font-weight:600}
.key-stats b{font-size:13px;color:var(--text);font-weight:600;font-variant-numeric:tabular-nums}

.key-card-foot{display:flex;gap:6px;flex-wrap:wrap;padding-top:12px;border-top:1px solid var(--line)}

/* ============================================================
   ADMIN TABLES — dense overview style
   ============================================================ */
.adm-table-wrap{background:var(--surface);border:1px solid var(--line);border-radius:14px;overflow:hidden;margin-top:14px}
.adm-table{width:100%;border-collapse:collapse;font-size:13px}
.adm-table thead{background:var(--surface-2)}
.adm-table th{
  padding:11px 14px;text-align:left;vertical-align:middle;
  font-size:10.5px;text-transform:uppercase;letter-spacing:.07em;font-weight:700;
  color:var(--muted);border-bottom:1px solid var(--line);white-space:nowrap;
}
.adm-table td{padding:11px 14px;text-align:left;vertical-align:middle;border-bottom:1px solid var(--line);color:var(--text)}
.adm-table tr:last-child td{border-bottom:0}
.adm-table tbody tr{transition:background .12s}
.adm-table tbody tr:hover{background:rgba(124,92,255,.06)}
.adm-table .mono{font-family:'JetBrains Mono','SF Mono',Consolas,monospace;font-size:12px;color:#cdd5f0}
.adm-table .num{text-align:right;font-variant-numeric:tabular-nums;font-family:'JetBrains Mono','SF Mono',Consolas,monospace}
.adm-table .muted-cell{color:var(--muted);font-size:12px}
.adm-table .actions-cell{white-space:nowrap;text-align:right}
.adm-table .actions-cell form{display:inline-block;margin:0}
.adm-table .actions-cell .btn,
.adm-table .actions-cell .icon-btn{padding:5px 10px;font-size:12px;height:30px;min-width:30px}
.adm-table .icon-btn{width:30px;height:30px;font-size:13px;border-radius:7px}
.adm-table .row-img{width:46px;height:46px;border-radius:8px;object-fit:cover;display:block;background:#0a0f22;flex-shrink:0}
.adm-table .row-title{display:flex;flex-direction:column;gap:2px;min-width:0}
.adm-table .row-title b{font-size:13px;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:340px;display:block}
.adm-table .row-title small{color:var(--muted);font-size:11.5px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:340px;display:block}
.adm-table .row-with-img{display:flex;gap:10px;align-items:center}
.adm-table .mini-bar{height:4px;width:80px;background:var(--bg-2);border-radius:999px;overflow:hidden;border:1px solid var(--line);margin-top:3px}
.adm-table .mini-bar > div{height:100%;border-radius:999px}

/* dot status */
.dot{display:inline-block;width:8px;height:8px;border-radius:50%;vertical-align:middle;margin-right:6px}
.dot-on{background:#10b981;box-shadow:0 0 6px rgba(16,185,129,.7)}
.dot-off{background:#64748b}
.dot-warn{background:#f59e0b;box-shadow:0 0 6px rgba(245,158,11,.7)}
.dot-err{background:#ef4444;box-shadow:0 0 6px rgba(239,68,68,.7)}

@media (max-width:1024px){
  .adm-table-wrap:not(.adm-stack){overflow-x:auto}
  .adm-table-wrap:not(.adm-stack) .adm-table{min-width:780px}
}

/* ========================================================
   Stacked table — converts rows to labeled cards on mobile
   Add class .adm-stack on .adm-table-wrap and data-label="…"
   on every <td> to expose the column header inline.
   ======================================================== */
.adm-table-wrap.adm-stack{overflow:visible}
@media (max-width:640px){
  .adm-stack .adm-table{display:block;width:100%;border:0;background:transparent;min-width:0}
  .adm-stack .adm-table thead{display:none}
  .adm-stack .adm-table tbody{display:block}
  .adm-stack .adm-table tr{
    display:block;width:100%;
    background:var(--surface);border:1px solid var(--line);
    border-radius:12px;padding:10px 14px;margin-bottom:8px;
  }
  .adm-stack .adm-table tr:hover{background:var(--surface)}
  .adm-stack .adm-table td{
    display:flex;justify-content:space-between;align-items:center;gap:12px;
    padding:6px 0;border-bottom:1px dashed var(--line);text-align:right;
    font-size:13px;
  }
  .adm-stack .adm-table td:last-child{border-bottom:0}
  .adm-stack .adm-table td::before{
    content:attr(data-label);
    font-size:10.5px;text-transform:uppercase;letter-spacing:.06em;
    color:var(--muted);font-weight:700;text-align:left;flex-shrink:0;
    max-width:42%;white-space:normal;
  }
  .adm-stack .adm-table td:not([data-label])::before{display:none}
  .adm-stack .adm-table .num{text-align:right;font-variant-numeric:tabular-nums}
  .adm-stack .adm-table .actions-cell{justify-content:flex-end;flex-wrap:wrap;gap:4px}
}

/* AZURE form */
.azure-form{display:grid;grid-template-columns:1fr 1fr;gap:14px;align-items:end}
.azure-form .field{margin:0}
.azure-form .field:first-child,
.azure-form .field:nth-child(2),
.azure-form .field:nth-child(3),
.azure-form .field:nth-child(4),
.azure-form .field:nth-child(7),
.azure-form .key-form-actions{grid-column:1 / -1}
.azure-form .field-row{grid-column:1 / -1;display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media (max-width:760px){
  .azure-form{grid-template-columns:1fr}
  .azure-form .field-row{grid-template-columns:1fr}
}
.azure-form input,.azure-form select{
  width:100%;background:var(--bg-2);border:1px solid var(--line-2);border-radius:12px;
  padding:12px 14px;color:var(--text);font-family:inherit;font-size:14px;outline:none;color-scheme:dark;
}
.azure-form select{cursor:pointer;appearance:none;-webkit-appearance:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path fill='%239aa6c7' d='M6 8L0 0h12z'/></svg>");
  background-repeat:no-repeat;background-position:right 14px center;padding-right:36px;
}
.azure-form input:focus,.azure-form select:focus{border-color:#7c5cff;box-shadow:0 0 0 3px rgba(124,92,255,.18)}

/* AZURE card extras */
.key-paused{opacity:.78;border-color:rgba(245,158,11,.4) !important}
.azure-spec{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;font-size:12px;margin-top:2px}
.azure-spec > div{display:flex;flex-direction:column;padding:8px 10px;background:var(--bg-2);border:1px solid var(--line);border-radius:8px;min-width:0}
.azure-spec span{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;font-weight:600}
.azure-spec b{font-size:12.5px;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-family:'JetBrains Mono','SF Mono',Consolas,monospace}

.azure-meters{display:flex;flex-direction:column;gap:8px;margin-top:2px}
.azure-meter-h{display:flex;justify-content:space-between;align-items:baseline;font-size:12px;margin-bottom:4px}
.azure-meter-h span{color:var(--muted);text-transform:uppercase;letter-spacing:.05em;font-weight:600;font-size:10.5px}
.azure-meter-h b{font-variant-numeric:tabular-nums;font-size:13px}
.azure-bar{height:6px;background:var(--bg-2);border-radius:999px;overflow:hidden;border:1px solid var(--line)}
.azure-bar > div{height:100%;border-radius:999px;transition:width .4s}

.azure-err{padding:8px 12px;background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.3);border-radius:8px;color:#fca5a5;font-size:12px;line-height:1.4;font-family:'JetBrains Mono','SF Mono',Consolas,monospace}

/* Usage table */
.usage-block{margin-top:14px}
.usage-table-wrap{background:var(--surface);border:1px solid var(--line);border-radius:14px;overflow:hidden}
.usage-table{width:100%;border-collapse:collapse;font-size:13px}
.usage-table th,.usage-table td{padding:10px 14px;text-align:left;vertical-align:top;border-bottom:1px solid var(--line)}
.usage-table th{background:var(--surface-2);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}
.usage-table tr:last-child td{border-bottom:0}
.usage-table .mono{font-family:'JetBrains Mono','SF Mono',Consolas,monospace;font-size:12px;color:#cdd5f0}
.status-pill{display:inline-block;padding:2px 9px;border-radius:6px;font-size:11px;font-weight:700;font-family:'JetBrains Mono',monospace}
.st-ok{background:rgba(16,185,129,.18);color:#6ee7b7;border:1px solid rgba(16,185,129,.4)}
.st-warn{background:rgba(245,158,11,.18);color:#fcd34d;border:1px solid rgba(245,158,11,.4)}
.st-err{background:rgba(239,68,68,.18);color:#fca5a5;border:1px solid rgba(239,68,68,.4)}

@media (max-width:760px){
  .usage-table th:nth-child(6),.usage-table td:nth-child(6){display:none}
  .key-stats{grid-template-columns:1fr}
}

/* ============================================================
   PHOTO PAGE (full-bleed image, h1 above)
   ============================================================ */
.photo-section{padding:30px 0 60px}
.back-link{display:inline-block;color:var(--muted);text-decoration:none;font-size:14px;margin-bottom:18px;transition:.15s}
.back-link:hover{color:var(--text)}

.photo-head{max-width:880px;margin:0 auto 24px;text-align:center}
.photo-head-tags{display:flex;justify-content:center;flex-wrap:wrap;gap:8px;margin-bottom:18px}
.ph-chip{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;background:rgba(124,92,255,.12);border:1px solid rgba(124,92,255,.3);border-radius:999px;font-size:12px;font-weight:600;color:#dcd5ff}
.photo-head h1{font-size:clamp(28px,4.5vw,46px);margin:0 0 14px;line-height:1.15;letter-spacing:-.02em}
.photo-lead{font-size:17px;line-height:1.65;color:#b8c1e0;margin:0;max-width:720px;margin-left:auto;margin-right:auto}

.photo-figure{margin:30px 0 0;padding:0;position:relative;border-radius:22px;overflow:hidden;background:#0a0f22;border:1px solid var(--line);box-shadow:0 30px 70px -25px rgba(0,0,0,.6)}
.photo-figure img{display:block;width:100%;height:auto;max-width:100%}
.photo-figure figcaption{padding:14px 22px;background:rgba(0,0,0,.35);border-top:1px solid var(--line);color:var(--muted);font-size:13px;line-height:1.55;font-style:italic}

.photo-actions{display:flex;justify-content:center;gap:12px;flex-wrap:wrap;margin:28px 0 36px}

/* Attribute cards */
.photo-attrs{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin:0 0 36px}
.attr-card{display:flex;align-items:center;gap:14px;padding:16px 18px;background:linear-gradient(135deg, var(--surface), rgba(124,92,255,.04));border:1px solid var(--line);border-radius:14px;transition:.18s}
.attr-card:hover{border-color:var(--line-2);transform:translateY(-2px);box-shadow:0 10px 24px -10px rgba(124,92,255,.3)}
.attr-icon{display:grid;place-items:center;width:42px;height:42px;border-radius:11px;background:linear-gradient(135deg,rgba(124,92,255,.18),rgba(34,211,238,.08));border:1px solid rgba(124,92,255,.3);font-size:20px;flex-shrink:0}
.attr-card > div{display:flex;flex-direction:column;gap:1px;min-width:0}
.attr-label{font-size:10.5px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:700}
.attr-card b{font-size:14.5px;color:var(--text);font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

.photo-section-block{margin:36px 0}
.section-h{display:flex;align-items:center;font-size:13px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);font-weight:700;margin:0 0 12px}

.photo-prompt-box{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:18px 22px;margin:30px 0}
.photo-prompt-box summary{cursor:pointer;display:flex;align-items:center;list-style:none;padding:4px 0}
.photo-prompt-box summary::-webkit-details-marker{display:none}
.photo-prompt-box summary::before{content:"▸";display:inline-block;margin-right:10px;color:#7c5cff;transition:.2s;font-size:14px}
.photo-prompt-box[open] summary::before{transform:rotate(90deg)}
.photo-prompt-box pre{margin:14px 0 0;padding:14px 16px;background:#0a0f22;border:1px solid var(--line);border-radius:10px;font-family:'JetBrains Mono','SF Mono',Consolas,monospace;font-size:13px;line-height:1.6;color:#cdd5f0;white-space:pre-wrap;word-break:break-word}

/* Related */
.related-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px}
.rel-card{display:block;text-decoration:none;color:inherit;background:var(--surface);border:1px solid var(--line);border-radius:12px;overflow:hidden;transition:.18s}
.rel-card:hover{transform:translateY(-3px);border-color:#7c5cff;box-shadow:0 12px 24px -12px rgba(124,92,255,.4)}
.rel-img{aspect-ratio:1/1;overflow:hidden;background:#0a0f22}
.rel-img img{width:100%;height:100%;object-fit:cover;transition:transform .35s ease}
.rel-card:hover img{transform:scale(1.05)}
.rel-title{padding:10px 12px;font-size:13px;line-height:1.35;color:var(--text);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

/* ============================================================
   MOBILE / TABLET — keep heading inside viewport, tight spacing
   ============================================================ */
/* Hamburger appears earlier (≤1024) because the auth-aware topnav
   gets cramped with credits + avatar pills. */
@media (max-width:1024px){
  .topnav{display:none}
  .menu-toggle{display:flex}
}
@media (max-width:880px){
  .wrap{padding:0 16px}
  .mobile-nav{display:flex}

  .topbar-inner{height:58px}
  .logo{font-size:16px}
  .logo-mark{width:130px;height:32px}

  .hero{padding:24px 0 4px;text-align:center}
  .hero-grid{grid-template-columns:1fr;gap:0;justify-items:center}
  .hero-copy{text-align:center;width:100%}
  .hero h1{
    font-size:clamp(22px,6.2vw,30px);
    line-height:1.18;letter-spacing:-.01em;
    margin:0 auto 8px;max-width:100%;
    overflow-wrap:break-word;word-break:normal;hyphens:auto;
  }
  .hero h1 br{display:none}
  .lead{font-size:14px;line-height:1.5;max-width:100%;margin:0 auto;text-align:center}
  .pill{font-size:11px;padding:5px 10px;margin:0 auto 10px}
  .hero-stats{grid-template-columns:repeat(2,1fr);padding:14px 16px;gap:10px;margin-left:auto;margin-right:auto}
  .hero-cta{justify-content:center}
  .badges{justify-content:center}
  /* Step 1 panel: center the title + helper copy */
  .panel h2{text-align:center}
  .panel > p.muted:first-of-type{text-align:center}

  /* Hero glow halo smaller so it doesn't bleed sideways */
  #start.section::before{height:240px;width:120%;filter:blur(60px)}

  .trust{padding:10px 0}
  .trust-row{gap:8px;font-size:11px;padding:0 8px}
  .trust-sep{display:none}

  .panel{padding:18px 16px;border-radius:16px}
  .panel h2{font-size:18px;line-height:1.25}
  .panel > p.muted:first-of-type{font-size:13.5px}

  .step-rail{position:sticky;top:58px;padding:6px 8px;gap:3px;border-radius:11px;overflow-x:hidden}
  .step-dot{padding:3px;gap:0;background:transparent !important}
  .step-dot,.step-dot.active{padding:3px}
  .step-dot b{width:22px;height:22px;font-size:11px;border-radius:50%}
  /* Hide ALL labels in the rail on mobile — active included (was leaking + wrapping) */
  .step-rail .step-dot span,
  .step-rail .step-dot.active span{display:none !important}
  .step-line{flex:1;min-width:0;max-width:none;height:2px}

  .footer-grid{grid-template-columns:1fr 1fr;gap:24px}
  .footer{padding:40px 0 20px;margin-top:36px}
  .footer h4{font-size:13px}

  .url-row{flex-direction:column}
  .url-row .btn{width:100%;justify-content:center}

  .actions{flex-direction:column-reverse;align-items:stretch}
  .actions .btn{width:100%;justify-content:center}

  .lightbox{padding:10px}
  .lb-close{top:8px;right:8px;width:38px;height:38px;font-size:22px}
  .lb-nav{width:38px;height:38px;font-size:24px}
  .lb-prev{left:6px}.lb-next{right:6px}

  /* Compact hero orbs so they don't push layout */
  .orb-1{width:340px;height:340px;top:-140px;right:-140px}
  .orb-2{width:280px;height:280px;top:160px;left:-180px}
}

@media (max-width:480px){
  .wrap{padding:0 14px}
  .logo-mark{width:110px;height:28px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:18px 12px}
  .hero{padding:18px 0 2px}
  .hero h1{font-size:clamp(20px,7vw,26px);hyphens:auto;-webkit-hyphens:auto}
  .lead{font-size:13.5px}
  .section{padding:24px 0}
  .panel{padding:16px 14px}
  .panel h2{font-size:17px}
  .hero-stats{grid-template-columns:repeat(2,1fr);padding:12px 14px}
  .hero-stats b{font-size:16px}
  .hero-stats span{font-size:9.5px}
  .badges{font-size:12px;gap:12px}
  .step-rail{padding:5px 6px;gap:2px;overflow-x:hidden}
  .step-line{flex:1;min-width:0;max-width:none}
  .step-dot,.step-dot.active{padding:2px}
  .step-dot b{width:20px;height:20px;font-size:10px}
  .copy{padding:14px;font-size:12px;line-height:1.7}
  /* Tabs (URL / Description) stretch full width */
  .tabs{display:flex;width:100%}
  .tabs button{flex:1}
  /* Drop zone vertical on tiny screens */
  .dz{flex-direction:column;text-align:center;padding:14px}
  .dz-paste-btn{width:100%;justify-content:center}
}

/* HERO SLIDESHOW — one photo at a time, fading + soft zoom */
.hero-slideshow{
  position:relative;width:100%;aspect-ratio:4/3;max-width:460px;margin-left:auto;
  border-radius:16px;overflow:hidden;background:var(--surface);
  border:1px solid var(--line-2);
  box-shadow:0 24px 60px -20px rgba(0,0,0,.7), 0 0 0 1px rgba(255,255,255,.04) inset;
}
.hero-slideshow .slide{
  position:absolute;inset:0;opacity:0;transition:opacity .9s ease;
  pointer-events:none;
}
.hero-slideshow .slide.is-active{opacity:1;pointer-events:auto}
.hero-slideshow .slide img{
  width:100%;height:100%;object-fit:cover;display:block;
  transform:scale(1.06);transition:transform 4s ease-out;
}
.hero-slideshow .slide.is-active img{transform:scale(1)}

.slideshow-badge{
  position:absolute;left:14px;bottom:14px;z-index:2;
  display:inline-flex;align-items:center;gap:8px;
  padding:7px 12px;border-radius:999px;
  background:rgba(10,13,22,.75);backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.14);
  font-size:12px;font-weight:600;color:var(--text);letter-spacing:.005em;
}
.slideshow-dot{
  width:7px;height:7px;border-radius:50%;background:#10b981;
  box-shadow:0 0 0 0 rgba(16,185,129,.7);animation:livePulse 2s infinite;
}
@keyframes livePulse{
  0%{box-shadow:0 0 0 0 rgba(16,185,129,.6)}
  70%{box-shadow:0 0 0 8px rgba(16,185,129,0)}
  100%{box-shadow:0 0 0 0 rgba(16,185,129,0)}
}

@media (max-width:900px){
  .hero-slideshow{max-width:100%;aspect-ratio:16/10;margin:8px 0 0}
}

@media (prefers-reduced-motion:reduce){
  .hero-slideshow .slide,.hero-slideshow .slide img,.slideshow-dot{transition:none !important;animation:none !important}
}
