/* =====================================================================
   TAKING STOCK BUILDER — scoped design-system styling.
   All tokens + components are scoped under .tsb and prefixed tsb- so they
   never collide with the main app stylesheet. Dark theme inherits via
   [data-theme="dark"] .tsb.
   ===================================================================== */

.tsb {
  /* palette */
  --tsb-navy-900:#06060e; --tsb-navy-800:#0b1d38; --tsb-navy-700:#13284a;
  --tsb-blue-600:#2a6ad6; --tsb-blue-500:#3d81f0; --tsb-blue-100:#eaf1fd;
  --tsb-orange-600:#e8650b; --tsb-orange-500:#f97316; --tsb-orange-100:#fdeede;
  --tsb-white:#fff; --tsb-grey-050:#f5f6f8; --tsb-grey-100:#eef0f3;
  --tsb-grey-200:#e7e9ee; --tsb-grey-300:#dadde6; --tsb-grey-500:#9aa3b5;
  --tsb-grey-700:#54607a; --tsb-ink:#0b1d38;
  --tsb-green:#2f7d4f; --tsb-amber:#d98a1a; --tsb-red:#e0413f;

  /* semantic */
  --tsb-bg:var(--tsb-white);
  --tsb-surface:var(--tsb-white);
  --tsb-surface-2:var(--tsb-grey-050);
  --tsb-text:var(--tsb-ink);
  --tsb-text-soft:var(--tsb-grey-700);
  --tsb-text-faint:var(--tsb-grey-500);
  --tsb-line:var(--tsb-grey-200);
  --tsb-line-strong:var(--tsb-grey-300);
  --tsb-accent:var(--tsb-blue-500);
  --tsb-accent-text:var(--tsb-blue-600);
  --tsb-accent-soft:var(--tsb-blue-100);
  --tsb-accent-border:#d8e6fb;
  --tsb-cta:var(--tsb-orange-500);
  --tsb-cta-hover:var(--tsb-orange-600);
  --tsb-overlay:rgba(11,29,56,.32);

  --tsb-font-sans:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --tsb-font-serif:'Source Serif 4',Georgia,serif;
  --tsb-font-mono:'JetBrains Mono','IBM Plex Mono',monospace;

  --tsb-r-sm:10px; --tsb-r-md:14px; --tsb-r-lg:22px; --tsb-r-pill:99px;
  --tsb-shadow-sm:0 1px 2px rgba(11,29,56,.05);
  --tsb-shadow-md:0 2px 4px rgba(11,29,56,.04), 0 8px 24px -16px rgba(11,29,56,.18);
  --tsb-shadow-lg:0 2px 4px rgba(11,29,56,.04), 0 28px 56px -32px rgba(11,29,56,.22);
  --tsb-shadow-xl:0 4px 8px rgba(11,29,56,.06), 0 40px 80px -40px rgba(11,29,56,.32);
  --tsb-shadow-cta:0 8px 18px -10px rgba(249,115,22,.75);
  --tsb-ease:cubic-bezier(.4,0,.2,1);

  font-family:var(--tsb-font-sans);
  color:var(--tsb-text);
}

[data-theme="dark"] .tsb {
  --tsb-bg:var(--tsb-navy-900);
  --tsb-surface:var(--tsb-navy-800);
  --tsb-surface-2:var(--tsb-navy-700);
  --tsb-text:#eef2f8;
  --tsb-text-soft:#a7b2c6;
  --tsb-text-faint:#6b7794;
  --tsb-line:rgba(255,255,255,.08);
  --tsb-line-strong:rgba(255,255,255,.14);
  --tsb-accent-text:#7aa7f6;
  --tsb-accent-soft:rgba(61,129,240,.14);
  --tsb-accent-border:rgba(61,129,240,.32);
  --tsb-overlay:rgba(0,0,0,.55);
  --tsb-shadow-md:0 4px 20px rgba(0,0,0,.45);
  --tsb-shadow-lg:0 12px 40px rgba(0,0,0,.5);
  --tsb-shadow-xl:0 20px 60px rgba(0,0,0,.55);
}

/* ---------- secondary nav item (global, not scoped) ---------- */
.nav-item.nav-subitem{font-size:13px;opacity:.82;padding-top:6px;padding-bottom:6px;}
.nav-item.nav-subitem svg{width:16px;height:16px;}

/* ---------- layout ---------- */
.tsb{max-width:860px;margin:0 auto;}
.tsb-topline{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:8px;}
.tsb-step{font-size:13px;color:var(--tsb-text-soft);font-variant-numeric:tabular-nums;}
.tsb-step b{color:var(--tsb-text);}
.tsb-progress{height:4px;background:var(--tsb-line);border-radius:var(--tsb-r-pill);overflow:hidden;margin:14px 0 26px;}
.tsb-progress__fill{height:100%;background:var(--tsb-accent);border-radius:var(--tsb-r-pill);transition:width .5s var(--tsb-ease);width:0;}

/* ---------- panel ---------- */
.tsb-panel{
  background:var(--tsb-surface);border:1px solid var(--tsb-line);border-radius:var(--tsb-r-lg);
  padding:clamp(26px,4.5vw,46px) clamp(22px,4.5vw,48px);box-shadow:var(--tsb-shadow-lg);
}

/* ---------- eyebrow ---------- */
.tsb-eyebrow{
  display:inline-flex;align-items:center;gap:9px;font-size:12px;font-weight:600;
  letter-spacing:.05em;text-transform:uppercase;color:var(--tsb-accent-text);
  background:var(--tsb-accent-soft);padding:6px 12px;border-radius:var(--tsb-r-pill);
}
.tsb-eyebrow .num{font-variant-numeric:tabular-nums;opacity:.7;}

/* ---------- note ---------- */
.tsb-note{display:flex;gap:12px;background:var(--tsb-surface-2);border:1px solid var(--tsb-line);
  border-radius:var(--tsb-r-md);padding:16px 18px;margin:22px 0 26px;}
.tsb-note__ico{flex:none;width:22px;height:22px;border-radius:6px;background:var(--tsb-accent-soft);
  color:var(--tsb-accent-text);display:grid;place-items:center;font-size:13px;font-weight:700;margin-top:1px;}
.tsb-note p{font-size:14.5px;line-height:1.55;color:var(--tsb-text-soft);margin:0;}
.tsb-note b{color:var(--tsb-text);font-weight:600;}

/* ---------- question / display type ---------- */
.tsb-q{font-family:var(--tsb-font-serif);font-weight:600;font-size:clamp(25px,3.4vw,33px);
  line-height:1.2;letter-spacing:-.01em;color:var(--tsb-text);margin:0 0 8px;}
.tsb-sub{font-size:15px;color:var(--tsb-text-faint);margin:0 0 26px;}
.tsb-hl{color:var(--tsb-accent-text);}

/* ---------- field / input ---------- */
.tsb-field{background:var(--tsb-surface);border:1px solid var(--tsb-line-strong);border-radius:var(--tsb-r-md);
  box-shadow:var(--tsb-shadow-md);overflow:hidden;}
.tsb-field__label{padding:11px 18px;border-bottom:1px solid var(--tsb-line);background:var(--tsb-surface-2);
  font-size:12px;font-weight:600;letter-spacing:.03em;text-transform:uppercase;color:var(--tsb-text-soft);
  display:flex;justify-content:space-between;align-items:center;}
.tsb-field__label .meta{font-weight:500;text-transform:none;letter-spacing:0;color:var(--tsb-text-faint);}
.tsb-field textarea,.tsb-field input{width:100%;border:none;outline:none;resize:none;background:transparent;
  font-family:var(--tsb-font-sans);font-size:16px;line-height:1.55;color:var(--tsb-text);padding:18px;}
.tsb-field__row{padding:18px;display:flex;align-items:center;gap:16px;flex-wrap:wrap;}

/* ---------- buttons ---------- */
.tsb-btn{font-family:var(--tsb-font-sans);font-weight:600;font-size:14.5px;border:none;
  border-radius:var(--tsb-r-sm);padding:13px 22px;cursor:pointer;display:inline-flex;align-items:center;
  gap:8px;line-height:1;text-decoration:none;
  transition:transform .14s var(--tsb-ease),background .14s var(--tsb-ease),box-shadow .14s var(--tsb-ease),border-color .14s var(--tsb-ease);}
.tsb-btn:disabled{opacity:.5;cursor:not-allowed;}
.tsb-btn--cta{background:var(--tsb-cta);color:#fff;box-shadow:var(--tsb-shadow-cta);}
.tsb-btn--cta:not(:disabled):hover{background:var(--tsb-cta-hover);transform:translateY(-2px);}
.tsb-btn--solid{background:var(--tsb-text);color:var(--tsb-bg);box-shadow:0 10px 22px -12px rgba(11,29,56,.6);}
.tsb-btn--solid:not(:disabled):hover{transform:translateY(-2px);}
.tsb-btn--ghost{background:var(--tsb-surface);color:var(--tsb-text);border:1px solid var(--tsb-line-strong);box-shadow:var(--tsb-shadow-sm);}
.tsb-btn--ghost:not(:disabled):hover{border-color:var(--tsb-text-faint);transform:translateY(-1px);}
.tsb-btn--link{background:none;color:var(--tsb-text-faint);padding:6px 4px;text-decoration:underline;text-underline-offset:3px;}
.tsb-btn--link:hover{color:var(--tsb-text-soft);}
.tsb-btn--sm{padding:8px 14px;font-size:13px;}
.tsb-recdot{width:9px;height:9px;border-radius:50%;background:currentColor;}
.tsb-btn--cta.is-live .tsb-recdot{animation:tsb-blink 1s steps(1) infinite;}
@keyframes tsb-blink{50%{opacity:.25;}}

.tsb-actions{margin-top:26px;display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;}

/* ---------- conversation log ---------- */
.tsb-log{margin-top:24px;display:flex;flex-direction:column;gap:14px;}
.tsb-msg{display:flex;gap:12px;}
.tsb-msg__av{flex:none;width:34px;height:34px;border-radius:9px;display:grid;place-items:center;font-size:13px;font-weight:700;}
.tsb-msg__bubble{flex:1;border-radius:var(--tsb-r-md);padding:14px 18px;}
.tsb-msg__nm{font-size:12px;font-weight:600;color:var(--tsb-text-soft);margin-bottom:5px;letter-spacing:.02em;}
.tsb-msg__bubble p{font-size:15.5px;line-height:1.55;margin:0;}
.tsb-msg--you .tsb-msg__av{background:var(--tsb-line);color:var(--tsb-text-soft);}
.tsb-msg--you .tsb-msg__bubble{background:var(--tsb-surface);border:1px solid var(--tsb-line);}
.tsb-msg--ai .tsb-msg__av{background:var(--tsb-accent);color:#fff;font-family:var(--tsb-font-serif);}
.tsb-msg--ai .tsb-msg__bubble{background:var(--tsb-accent-soft);border:1px solid var(--tsb-accent-border);}
.tsb-msg--ai .tsb-msg__nm{color:var(--tsb-accent-text);}
.tsb-msg--ai .tsb-msg__bubble p{font-family:var(--tsb-font-serif);}

/* ---------- captions while recording ---------- */
.tsb-caption{margin-top:14px;font-size:15px;color:var(--tsb-text-faint);font-style:italic;min-height:22px;}

/* ---------- onboarding (step 1) ---------- */
.tsb-onboard-list{display:flex;flex-direction:column;gap:12px;margin:18px 0;}
.tsb-url-row{display:flex;gap:8px;align-items:center;}
.tsb-url-row input{flex:1;border:1px solid var(--tsb-line-strong);border-radius:var(--tsb-r-sm);
  padding:12px 14px;font-size:15px;font-family:var(--tsb-font-sans);background:var(--tsb-surface);color:var(--tsb-text);outline:none;}
.tsb-url-row input:focus{border-color:var(--tsb-accent);}
.tsb-url-x{background:none;border:none;color:var(--tsb-text-faint);font-size:20px;cursor:pointer;padding:4px 8px;line-height:1;}
.tsb-paste{width:100%;min-height:120px;border:1px solid var(--tsb-line-strong);border-radius:var(--tsb-r-md);
  padding:14px;font-size:15px;font-family:var(--tsb-font-sans);background:var(--tsb-surface);color:var(--tsb-text);outline:none;resize:vertical;}
.tsb-addlink{background:none;border:none;color:var(--tsb-accent-text);font-weight:600;font-size:14px;cursor:pointer;padding:4px 0;text-align:left;}

/* ---------- document drawer ---------- */
.tsb-docbtn{display:inline-flex;align-items:center;gap:8px;}
.tsb-backdrop{position:fixed;inset:0;background:var(--tsb-overlay);opacity:0;pointer-events:none;
  transition:opacity .24s var(--tsb-ease);z-index:60;backdrop-filter:blur(2px);}
.tsb-backdrop.is-open{opacity:1;pointer-events:auto;}
.tsb-drawer{position:fixed;top:0;right:0;height:100%;width:min(560px,94vw);background:var(--tsb-bg);
  transform:translateX(100%);transition:transform .32s var(--tsb-ease);z-index:61;overflow-y:auto;box-shadow:var(--tsb-shadow-xl);}
.tsb-drawer.is-open{transform:translateX(0);}
.tsb-dhead{padding:22px 28px;border-bottom:1px solid var(--tsb-line);display:flex;justify-content:space-between;
  align-items:center;position:sticky;top:0;background:var(--tsb-bg);}
.tsb-dhead h2{margin:0;font-family:var(--tsb-font-serif);font-weight:600;font-size:22px;}
.tsb-dhead .x{background:none;border:none;font-size:24px;line-height:1;cursor:pointer;color:var(--tsb-text-faint);}
.tsb-docrow{padding:18px 28px;}
.tsb-docrow + .tsb-docrow{border-top:1px solid var(--tsb-line);}
.tsb-docrow .dl{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;gap:10px;}
.tsb-docrow .dl .t{font-size:13px;font-weight:600;}
.tsb-docrow .dl-right{display:inline-flex;align-items:center;gap:10px;flex:none;}
.tsb-redo{background:none;border:none;color:var(--tsb-accent-text);font-weight:600;font-size:12px;cursor:pointer;padding:0;text-decoration:underline;text-underline-offset:2px;}
.tsb-redo:hover{opacity:.8;}
.tsb-docrow p{font-size:14.5px;line-height:1.55;color:var(--tsb-text-soft);margin:0;white-space:pre-wrap;}
.tsb-docrow.todo p{color:var(--tsb-text-faint);font-style:italic;}

/* ---------- status pills ---------- */
.tsb-status{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;
  padding:4px 11px;border-radius:var(--tsb-r-pill);line-height:1.4;}
.tsb-status--ok{background:rgba(47,125,79,.12);color:var(--tsb-green);}
.tsb-status--active{background:var(--tsb-accent-soft);color:var(--tsb-accent-text);}
.tsb-status--muted{background:var(--tsb-surface-2);color:var(--tsb-text-faint);}

/* ---------- spinner ---------- */
.tsb-spin{width:18px;height:18px;border:2px solid var(--tsb-line-strong);border-top-color:var(--tsb-accent);
  border-radius:50%;animation:tsb-rot .7s linear infinite;display:inline-block;vertical-align:middle;}
@keyframes tsb-rot{to{transform:rotate(360deg);}}
.tsb-thinking{display:flex;align-items:center;gap:10px;color:var(--tsb-text-faint);font-size:14px;margin-top:16px;}

/* ---------- completion ---------- */
.tsb-done{text-align:center;padding:20px 0;}
.tsb-done .tsb-score{font-family:var(--tsb-font-serif);font-size:64px;font-weight:600;line-height:1;color:var(--tsb-text);}
.tsb-done .tsb-score small{font-size:24px;color:var(--tsb-text-faint);}

/* =====================================================================
   COPY-ASSET GENERATORS (Headlines, Ad Copy, Video Ad, VSL, Sales, Organic)
   Document + composer layout: full-width page, slim composer bar, and the
   generated copy flows down the page as a borderless document (the page
   scrolls, not an inner box).
   ===================================================================== */
.tsb.gendoc{max-width:980px;}
/* keep the header a single tidy unit: eyebrow + credits chip grouped on the left */
.gendoc .tsb-topline{justify-content:flex-start;gap:10px;padding-right:0;}
.gendoc .tsb-step{font-size:12px;font-weight:600;color:var(--tsb-text-faint);background:var(--tsb-surface-2);border:1px solid var(--tsb-line);padding:5px 11px;border-radius:var(--tsb-r-pill);}
.gendoc .tsb-q{margin-top:4px;}
.gendoc .tsb-step b{color:var(--tsb-text);}

/* composer bar */
.gendoc-bar{display:flex;align-items:flex-end;gap:10px;margin:22px 0 0;background:var(--tsb-surface);border:1px solid var(--tsb-line-strong);border-radius:16px;padding:10px 10px 10px 18px;box-shadow:var(--tsb-shadow-md);}
.gendoc-bar:focus-within{border-color:var(--tsb-accent);box-shadow:0 0 0 3px var(--tsb-accent-soft),var(--tsb-shadow-md);}
.gendoc-input{flex:1;border:none;outline:none;background:transparent;resize:none;font-family:var(--tsb-font-sans);font-size:16px;line-height:1.55;color:var(--tsb-text);padding:9px 0;min-height:26px;max-height:220px;overflow-y:auto;}
.gendoc-input::placeholder{color:var(--tsb-text-faint);}
.gendoc-go{flex:none;align-self:stretch;padding-left:22px;padding-right:22px;}

/* video-ad segmented control */
.gendoc-seg-row{display:flex;align-items:center;gap:12px;margin-top:20px;flex-wrap:wrap;}
.gendoc-seg-label{font-size:12px;font-weight:600;letter-spacing:.03em;text-transform:uppercase;color:var(--tsb-text-faint);}
.seg{display:inline-flex;background:var(--tsb-surface-2);border:1px solid var(--tsb-line);border-radius:var(--tsb-r-pill);padding:3px;}
.seg-opt{position:relative;display:inline-flex;}
.seg-opt input{position:absolute;inset:0;opacity:0;cursor:pointer;margin:0;}
.seg-opt span{display:block;padding:7px 16px;border-radius:var(--tsb-r-pill);font-size:13.5px;font-weight:600;color:var(--tsb-text-soft);cursor:pointer;transition:background .15s var(--tsb-ease),color .15s var(--tsb-ease);white-space:nowrap;}
.seg-opt input:checked + span{background:var(--tsb-surface);color:var(--tsb-accent-text);box-shadow:var(--tsb-shadow-sm);}

/* result stage: the copy is presented as a clean document "sheet" */
.gendoc-stage{margin-top:30px;}
.gendoc-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:72px 24px;background:var(--tsb-surface);border:1px solid var(--tsb-line);border-radius:18px;}
.gendoc-empty__ico{display:grid;place-items:center;width:60px;height:60px;border-radius:var(--tsb-r-pill);background:var(--tsb-accent-soft);margin-bottom:16px;}
.gendoc-empty__ico svg{width:26px;height:26px;fill:none;stroke:var(--tsb-accent-text);stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round;}
.gendoc-empty p{font-size:15px;color:var(--tsb-text-faint);margin:0;}
.gendoc-thinking{display:flex;align-items:center;justify-content:center;gap:10px;padding:72px 24px;color:var(--tsb-text-faint);font-size:15px;background:var(--tsb-surface);border:1px solid var(--tsb-line);border-radius:18px;}

/* generated document (markup from app.js renderGeneratorOutput) */
/* a single refined sheet: soft border + shadow + roomy padding, toolbar as its header */
.gendoc .output-content{background:var(--tsb-surface);border:1px solid var(--tsb-line);border-radius:18px;box-shadow:var(--tsb-shadow-md);padding:0 clamp(24px,3.2vw,46px) clamp(30px,3.2vw,44px);max-height:none;overflow:visible;}
.gendoc .output-actions{display:flex;align-items:center;gap:6px;margin:0 calc(-1*clamp(24px,3.2vw,46px));padding:14px clamp(24px,3.2vw,46px);border-bottom:1px solid var(--tsb-line);border-radius:18px 18px 0 0;position:sticky;top:0;background:var(--tsb-surface);z-index:3;}
.gendoc .output-actions .tsb-btn{background:transparent;border:none;color:var(--tsb-text-soft);box-shadow:none;padding:7px 10px;}
.gendoc .output-actions .tsb-btn:hover{background:var(--tsb-surface-2);color:var(--tsb-text);transform:none;}
.gen-saved{margin-left:auto;font-size:12.5px;color:var(--tsb-text-faint);font-variant-numeric:tabular-nums;white-space:nowrap;}
/* id-scoped to outrank #page-* .output-content .markdown rules in style.css */
#page-headlines .gendoc .output-content .markdown,
#page-ad-copy .gendoc .output-content .markdown,
#page-video-ad .gendoc .output-content .markdown,
#page-vsl-script .gendoc .output-content .markdown,
#page-sales-page .gendoc .output-content .markdown,
#page-organic-content .gendoc .output-content .markdown{background:transparent;border:none;border-radius:0;padding:0;min-height:0;margin-top:clamp(24px,3vw,32px);font-size:16px;line-height:1.78;color:var(--tsb-text);}
.gendoc .output-content .markdown h2{border:none;padding:0;margin-top:30px;}
.gendoc .output-content .markdown > :first-child{margin-top:0;}
.gendoc .output-warning{background:var(--tsb-orange-100);color:var(--tsb-orange-600);border-radius:var(--tsb-r-sm);padding:10px 14px;margin:clamp(24px,3vw,32px) 0 0;font-size:14px;}

@media (max-width:640px){
  .gendoc-bar{flex-direction:column;align-items:stretch;border-radius:14px;padding:12px 14px;}
  .gendoc-go{align-self:flex-end;}
}
