  /* ===== Light theme (default) ===== */
  :root{
    --bg:#eef1f7; --bg2:#e6eaf3; --panel:#ffffff; --panel2:#f3f5fa; --panel3:#fbfcfe;
    --border:#e4e8f0; --border2:#d6dbe6;
    --text:#10151f; --text2:#33405a; --muted:#6b7689;
    --brand:#ff3b30; --brand2:#e11d2a;
    --accent:#4f46e5; --accent-d:#4338ca; --accent-soft:#eef0fe;
    --ok:#16a34a; --ok-soft:#e7f6ee; --warn:#d97706; --err:#dc2626; --err-soft:#fdecec;
    --radius:16px; --radius-sm:11px;
    --headerbg:rgba(255,255,255,.85);
    --shadow:0 1px 2px rgba(16,24,40,.04), 0 8px 24px rgba(16,24,40,.06);
    --shadow-lg:0 12px 48px rgba(16,24,40,.18);
    --ring:0 0 0 3px rgba(79,70,229,.18);
  }
  /* ===== Dark theme ===== */
  body.dark{
    --bg:#0a0d14; --bg2:#0d1119; --panel:#141925; --panel2:#1b2230; --panel3:#10151f;
    --border:#262e3d; --border2:#313a4c;
    --text:#eaf0f9; --text2:#c2ccdb; --muted:#8b97ab;
    --brand:#ff5d54; --brand2:#ff3b30;
    --accent:#7c7bff; --accent-d:#6366f1; --accent-soft:#1d2140;
    --ok:#34d399; --ok-soft:#10241c; --warn:#fbbf24; --err:#f87171; --err-soft:#2a1717;
    --headerbg:rgba(10,13,20,.82);
    --shadow:0 1px 2px rgba(0,0,0,.4), 0 8px 28px rgba(0,0,0,.45);
    --shadow-lg:0 16px 56px rgba(0,0,0,.6);
    --ring:0 0 0 3px rgba(124,123,255,.28);
  }
  *{box-sizing:border-box}
  body{margin:0;font-family:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
    background:radial-gradient(1200px 500px at 80% -10%, var(--bg2), transparent), var(--bg);
    color:var(--text);line-height:1.55;-webkit-font-smoothing:antialiased;
    transition:background .25s,color .25s;min-height:100vh;display:flex;flex-direction:column}

  /* ===== Header / nav ===== */
  header{padding:14px 30px;border-bottom:1px solid var(--border);
    display:flex;align-items:center;gap:13px;position:sticky;top:0;background:var(--headerbg);
    backdrop-filter:blur(14px) saturate(1.4);z-index:20}
  header h1{font-size:17px;margin:0;font-weight:700;letter-spacing:-.2px}
  header .logo{width:38px;height:38px;border-radius:11px;
    background:linear-gradient(135deg,var(--brand),var(--brand2));
    display:grid;place-items:center;font-size:17px;color:#fff;
    box-shadow:0 4px 12px rgba(255,59,48,.35)}
  header .sub{color:var(--muted);font-size:13px}
  header .navactions{margin-left:auto;display:flex;align-items:center;gap:9px}
  .navbtn{background:var(--panel);border:1px solid var(--border2);color:var(--text);
    padding:9px 15px;border-radius:10px;font-size:13px;font-weight:600;cursor:pointer;
    display:flex;align-items:center;gap:7px;transition:.15s;box-shadow:var(--shadow)}
  .navbtn:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-1px)}
  .navbtn.icon{padding:9px 12px;font-size:15px;line-height:1}
  .nav-run{padding:10px 20px;font-size:14px}

  /* ===== Tabs ===== */
  .tabs{display:flex;gap:4px;margin-left:14px}
  .tab{background:transparent;border:0;color:var(--muted);font-weight:600;font-size:14px;
    padding:9px 15px;border-radius:10px;cursor:pointer;box-shadow:none;display:flex;gap:7px;align-items:center;
    transition:.13s}
  .tab:hover{color:var(--text);background:var(--panel2);transform:none}
  .tab.active{color:var(--accent);background:var(--accent-soft)}
  body.dark .tab.active{background:var(--panel2);color:var(--text)}
  .tabpanel{display:none}
  .tabpanel.active{display:block;animation:fade .22s ease}
  @keyframes fade{from{opacity:0;transform:translateY(5px)}to{opacity:1;transform:none}}

  /* ===== Panel header ===== */
  .panel-head{display:flex;align-items:flex-start;gap:14px;margin-bottom:20px}
  .panel-head h2{margin:0 0 3px;font-size:17px;font-weight:800;letter-spacing:-.3px}
  .panel-head p{margin:0;font-size:13px;color:var(--muted)}
  .panel-head .status{margin-left:auto;margin-top:4px}
  .count-badge{margin-left:auto;font-size:12px;font-weight:700;color:var(--accent-d);
    background:var(--accent-soft);border-radius:20px;padding:5px 12px;white-space:nowrap}
  body.dark .count-badge{color:var(--text);background:var(--panel2)}
  .sub-h{font-size:13px !important;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);margin:0 0 16px !important}

  .wrap{max-width:1060px;width:100%;margin:0 auto;padding:30px 30px 60px;flex:1 0 auto}

  /* ===== Hero ===== */
  .hero{margin-bottom:26px}
  .hero h2{font-size:27px;margin:0 0 8px;font-weight:800;letter-spacing:-.6px;line-height:1.2}
  .hero h2 .grad{background:linear-gradient(120deg,var(--brand),var(--accent));
    -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
  .hero p{margin:0;color:var(--muted);font-size:15px;max-width:620px}
  .flow{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px}
  .flow span{font-size:12px;font-weight:600;color:var(--text2);background:var(--panel);
    border:1px solid var(--border);border-radius:20px;padding:6px 13px;box-shadow:var(--shadow)}
  .flow span b{color:var(--accent)}

  /* ===== Cards ===== */
  .card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);
    padding:24px;margin-bottom:20px;box-shadow:var(--shadow)}
  .card h2{margin:0 0 18px;font-size:16px;font-weight:700;color:var(--text);
    display:flex;align-items:center;gap:11px;letter-spacing:-.2px}
  .card h2 .n{width:26px;height:26px;border-radius:8px;
    background:linear-gradient(135deg,var(--accent),var(--accent-d));
    display:grid;place-items:center;font-size:13px;color:#fff;font-weight:700;
    box-shadow:0 3px 8px rgba(79,70,229,.3)}

  /* ===== Forms ===== */
  label{display:block;font-size:12.5px;color:var(--text2);margin:0 0 7px;font-weight:600}
  input,textarea,select{width:100%;background:var(--panel3);border:1px solid var(--border2);color:var(--text);
    padding:11px 13px;border-radius:var(--radius-sm);font-size:14px;font-family:inherit;outline:none;
    transition:.15s}
  input::placeholder,textarea::placeholder{color:var(--muted)}
  input:focus,textarea:focus,select:focus{border-color:var(--accent);box-shadow:var(--ring)}
  select{cursor:pointer;appearance:none;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%236b7689' d='M6 8 0 0h12z'/%3E%3C/svg%3E");
    background-repeat:no-repeat;background-position:right 13px center;padding-right:34px}
  .grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
  .grid3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}
  .row{display:flex;gap:12px;align-items:flex-end}
  .row .grow{flex:1}

  /* ===== Buttons ===== */
  button{background:linear-gradient(135deg,var(--accent),var(--accent-d));color:#fff;border:0;
    padding:11px 18px;border-radius:var(--radius-sm);font-size:14px;font-weight:600;cursor:pointer;
    font-family:inherit;transition:.15s;box-shadow:0 4px 12px rgba(79,70,229,.25)}
  button:hover{transform:translateY(-1px);box-shadow:0 6px 18px rgba(79,70,229,.35)}
  button:active{transform:translateY(0)}
  button.secondary{background:var(--panel3);border:1px solid var(--border2);color:var(--text);box-shadow:var(--shadow)}
  button.secondary:hover{border-color:var(--accent);color:var(--accent)}
  button.ghost{background:transparent;border:1px solid var(--border);color:var(--muted);padding:6px 10px;font-size:12px;box-shadow:none}
  button.run{background:linear-gradient(135deg,var(--brand),var(--brand2));font-size:15px;padding:14px 30px;
    box-shadow:0 6px 18px rgba(255,59,48,.35)}
  button.run:hover{box-shadow:0 8px 24px rgba(255,59,48,.45)}
  button:disabled{opacity:.45;cursor:not-allowed;transform:none;box-shadow:none}

  /* ===== Chips ===== */
  .chips{display:flex;flex-wrap:wrap;gap:9px;margin-top:14px}
  .chip{background:var(--accent-soft);border:1px solid transparent;border-radius:22px;padding:7px 11px 7px 14px;
    font-size:13px;font-weight:600;color:var(--accent-d);display:flex;align-items:center;gap:9px}
  body.dark .chip{color:var(--text)}
  .chip button{background:transparent;border:0;color:inherit;opacity:.6;padding:0;font-size:15px;cursor:pointer;box-shadow:none}
  .chip button:hover{opacity:1;color:var(--err);transform:none}

  /* ===== Autocomplete suggestions ===== */
  .sugg-wrap{position:relative}
  .sugg{position:absolute;top:calc(100% + 6px);left:0;right:0;z-index:30;
    background:var(--panel);border:1px solid var(--border2);border-radius:var(--radius-sm);
    box-shadow:var(--shadow-lg);overflow:hidden;max-height:340px;overflow-y:auto;display:none}
  .sugg.open{display:block}
  .sugg-item{display:flex;align-items:center;gap:12px;padding:10px 13px;cursor:pointer;
    border-bottom:1px solid var(--border);transition:.1s}
  .sugg-item:last-child{border-bottom:0}
  .sugg-item:hover,.sugg-item.active{background:var(--accent-soft)}
  body.dark .sugg-item:hover,body.dark .sugg-item.active{background:var(--panel2)}
  .sugg-item img{width:40px;height:40px;border-radius:50%;object-fit:cover;flex-shrink:0;background:var(--panel2)}
  .sugg-item .si-main{min-width:0;flex:1}
  .sugg-item .si-title{font-size:14px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .sugg-item .si-sub{font-size:12px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .sugg-item .si-add{font-size:12px;font-weight:700;color:var(--accent);flex-shrink:0}
  .sugg-note{padding:10px 13px;font-size:12.5px;color:var(--muted);text-align:center}
  /* ===== Professional content-strategy report (YouTube only) ===== */
  .crp-top{display:flex;align-items:flex-start;gap:14px;border-bottom:2px solid var(--border);padding-bottom:16px}
  .crp-top .cat{font-size:21px;font-weight:800;letter-spacing:-.4px;color:var(--text)}
  .crp-top .meta{font-size:12.5px;color:var(--muted);margin-top:4px}
  .crp-conf{margin-left:auto;text-align:center;background:#1e3a8a;color:#fff;border-radius:11px;padding:8px 14px;flex-shrink:0}
  .crp-conf b{font-size:19px;font-weight:800;display:block;line-height:1}
  .crp-conf span{font-size:9px;text-transform:uppercase;letter-spacing:.5px;opacity:.85}
  .crp-h{font-size:12px;font-weight:800;letter-spacing:.7px;text-transform:uppercase;color:#1e3a8a;margin:24px 0 13px;padding-left:11px;border-left:3px solid #1e3a8a}
  body.dark .crp-h{color:#9db8ff;border-left-color:#9db8ff}
  .crp-snap{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
  .crp-snap .cell{background:var(--panel3);border:1px solid var(--border);border-radius:10px;padding:11px 13px}
  .crp-snap .k{font-size:10px;text-transform:uppercase;letter-spacing:.4px;color:var(--muted);font-weight:700}
  .crp-snap .v{font-size:13.5px;font-weight:600;color:var(--text);margin-top:4px;line-height:1.4}
  .crp-pats{display:grid;gap:11px}
  .crp-pat{background:var(--panel3);border:1px solid var(--border);border-left:3px solid #16a34a;border-radius:10px;padding:13px 15px}
  .crp-pat .pn{font-size:14.5px;font-weight:700;color:var(--text)}
  .crp-pat .ev{font-size:12.5px;color:var(--text2);margin-top:5px;line-height:1.5}
  .crp-pat .ev b{color:var(--muted);font-weight:700}
  .crp-pat .ev.sm{font-size:11.5px;color:var(--muted)}
  .crp-pat .fmt{display:inline-block;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;background:#e7f6ee;color:#16a34a;padding:3px 10px;border-radius:20px;margin-top:8px}
  body.dark .crp-pat .fmt{background:#10241c}
  /* recommendation card — title + hook are the hero, details below */
  .crp-rec{border:1px solid var(--border);border-radius:13px;padding:18px 20px;margin-bottom:14px;background:var(--panel);box-shadow:var(--shadow)}
  .crp-rec .rh{display:flex;align-items:flex-start;gap:13px}
  .crp-rec .rnum{flex-shrink:0;width:28px;height:28px;border-radius:8px;background:linear-gradient(135deg,#1e3a8a,#3753b8);color:#fff;display:grid;place-items:center;font-weight:800;font-size:13px;box-shadow:0 3px 8px rgba(30,58,138,.3)}
  .crp-rec .rt-wrap{flex:1;min-width:0}
  .crp-rec .rt{font-size:18px;font-weight:800;color:var(--text);line-height:1.3;letter-spacing:-.3px}
  .crp-rec .rt-tags{display:flex;align-items:center;gap:9px;margin-top:9px;flex-wrap:wrap}
  .crp-rec .fmt-badge{display:inline-block;font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.4px;background:#eef0fe;color:#1e3a8a;padding:4px 11px;border-radius:20px}
  body.dark .crp-rec .fmt-badge{background:var(--panel2);color:#9db8ff}
  .crp-rec .rscore{font-size:13px;font-weight:800;color:#fff;background:#ea7317;padding:3px 10px;border-radius:20px;white-space:nowrap}
  .crp-rec .hook{font-size:15px;font-weight:600;color:var(--text);background:var(--panel3);border-left:4px solid #ea7317;padding:11px 15px;border-radius:0 9px 9px 0;margin:13px 0 0;line-height:1.45}
  .crp-rec .hook .hk-label{display:inline-block;font-size:9px;font-weight:800;text-transform:uppercase;letter-spacing:.6px;color:#fff;background:#ea7317;padding:2px 8px;border-radius:5px;margin-right:9px;vertical-align:1px}
  .crp-detail{margin-top:14px;padding-top:14px;border-top:1px dashed var(--border2)}
  /* beginner report bits */
  .crp-summary{font-size:14.5px;line-height:1.6;color:var(--text);background:var(--panel3);border:1px solid var(--border);border-left:4px solid #1e3a8a;border-radius:0 10px 10px 0;padding:13px 16px;margin-top:14px}
  .crp-why{font-size:13.5px;color:var(--text2);margin-top:11px;line-height:1.5}
  .crp-proof{font-size:13px;color:var(--text2);background:var(--panel3);border:1px solid var(--border);border-radius:9px;padding:9px 13px;margin-top:11px;line-height:1.5}
  .crp-proof b{color:var(--muted);font-weight:700;text-transform:uppercase;font-size:10px;letter-spacing:.3px;margin-right:5px}
  .crp-proof.ok{background:#e7f6ee;border-color:#bfe6cd;color:#11603e}
  .crp-proof.ok b{color:#16a34a} .crp-proof.ok b:last-of-type{color:#11603e;font-size:13px;text-transform:none;letter-spacing:0}
  body.dark .crp-proof.ok{background:#10241c;border-color:#1f4d36;color:#a7e8c4}
  .crp-outline{margin:6px 0 0;padding-left:0;list-style:none;counter-reset:o;display:grid;gap:6px}
  .crp-outline li{position:relative;padding:7px 11px 7px 30px;background:var(--panel3);border:1px solid var(--border);border-radius:8px;font-size:13px;color:var(--text2);counter-increment:o;line-height:1.45}
  .crp-outline li:before{content:counter(o);position:absolute;left:8px;top:50%;transform:translateY(-50%);width:17px;height:17px;border-radius:50%;background:#1e3a8a;color:#fff;font-size:10px;font-weight:800;display:grid;place-items:center}
  .crp-thumb{font-size:12.5px;color:var(--text2);margin-top:11px}
  .crp-thumb b{color:var(--muted);font-weight:700}
  .crp-proof a{color:#ff0000;font-weight:700;text-decoration:none}
  .crp-proof a:hover{color:#c00;text-decoration:underline}
  .crp-actions{margin-top:13px;display:flex;gap:8px;flex-wrap:wrap}
  .script-btn{background:var(--accent-soft,#eef2ff);color:var(--accent);border:1px solid var(--accent);
    font-size:12px;font-weight:700;padding:7px 14px;border-radius:9px;cursor:pointer;transition:.15s}
  .script-btn:hover{background:var(--accent);color:#fff;transform:translateY(-1px)}
  .script-btn:disabled{opacity:.55;cursor:default;transform:none}

  /* ---- script writer: language chooser ---- */
  .script-lang{padding:8px 2px 4px}
  .sl-q{font-size:16px;font-weight:800;color:var(--text)}
  .sl-sub{font-size:12.5px;color:var(--muted);margin:4px 0 16px}
  .sl-opts{display:grid;grid-template-columns:1fr 1fr;gap:12px}
  .sl-btn{display:flex;flex-direction:column;align-items:flex-start;gap:3px;text-align:left;
    background:var(--panel);border:1.5px solid var(--border2);border-radius:14px;padding:16px 16px;cursor:pointer;transition:.16s}
  .sl-btn:hover{border-color:var(--accent);background:var(--accent-soft);transform:translateY(-2px);box-shadow:0 8px 22px rgba(79,70,229,.15)}
  .sl-emoji{font-size:26px;line-height:1}
  .sl-t{font-size:15px;font-weight:800;color:var(--text);margin-top:6px}
  .sl-d{font-size:11.5px;color:var(--muted)}

  /* ---- script writer: rendered script ---- */
  .script-out{font-size:14px;line-height:1.7;color:var(--text);max-height:62vh;overflow:auto}
  .script-loading{display:flex;align-items:center;gap:10px;color:var(--muted);font-size:13.5px;padding:24px 4px}
  .script-loading .spin{width:16px;height:16px;border:2.5px solid var(--border2);border-top-color:var(--accent);border-radius:50%;animation:scSpin .7s linear infinite}
  @keyframes scSpin{to{transform:rotate(360deg)}}
  .sc-lang-tag{display:inline-block;font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.5px;
    color:var(--accent);background:var(--accent-soft);border:1px solid var(--border2);padding:3px 10px;border-radius:20px;margin-bottom:14px}
  .sc-block{border-radius:12px;padding:13px 15px;margin:10px 0;opacity:0;animation:scRise .4s ease forwards}
  @keyframes scRise{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
  .sc-label{font-size:10.5px;font-weight:800;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);margin-bottom:6px}
  .sc-main-label{margin:18px 0 2px;font-size:11.5px;color:var(--accent)}
  .sc-block.hook{background:linear-gradient(135deg,var(--accent-soft),var(--panel));border:1px solid var(--accent);}
  .sc-block.hook .sc-label{color:var(--accent)}
  .sc-block.main{background:var(--panel);border:1px solid var(--border2)}
  .sc-block.outro{background:var(--ok-soft,#ecfdf5);border:1px solid var(--ok,#10b981)}
  .sc-block.outro .sc-label{color:var(--ok,#10b981)}
  .sc-h{font-size:13.5px;font-weight:800;color:var(--text);margin-bottom:5px}
  .sc-text{font-size:14px;line-height:1.72;color:var(--text);white-space:pre-wrap}
  .sc-text b{font-weight:800;color:var(--accent-d,#4338ca);background:var(--accent-soft);padding:0 3px;border-radius:4px}
  .sc-block.outro .sc-text b{color:#047857;background:var(--ok-soft,#ecfdf5)}
  .crp-field{font-size:12.5px;line-height:1.55;margin:8px 0}
  .crp-field > b{display:block;font-size:9.5px;text-transform:uppercase;letter-spacing:.4px;color:var(--muted);font-weight:800;margin-bottom:3px}
  .crp-field ul{margin:0;padding-left:16px} .crp-field li{margin-bottom:2px}
  .crp-pkg{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:4px}
  .crp-pkg .p{background:var(--panel3);border:1px solid var(--border);border-radius:8px;padding:8px 11px;font-size:12px;color:var(--text2)}
  .crp-pkg .p b{font-size:9px;text-transform:uppercase;color:var(--muted);display:block;letter-spacing:.3px;margin-bottom:2px}
  .crp-risk{font-size:12.5px;color:#b4452f;background:#fdf2ef;border:1px solid #f3cabb;border-radius:8px;padding:8px 12px;margin-top:9px}
  body.dark .crp-risk{background:#2a1714;color:#f0a58c;border-color:#5a2a20}
  .crp-gap{background:var(--panel3);border:1px solid var(--border);border-radius:10px;padding:13px 15px;margin-bottom:10px}
  .crp-gap .them{font-size:12.5px;color:var(--muted)} .crp-gap .them b{color:var(--text2)}
  .crp-gap .us{color:#16a34a;font-weight:700;font-size:14.5px;margin-top:6px;line-height:1.4}
  .crp-gap .wy{font-size:11.5px;color:var(--muted);margin-top:5px}
  .crp-avoid{list-style:none;padding:0;margin:0;display:grid;gap:7px}
  .crp-avoid li{font-size:13px;padding:9px 13px;background:#fdf2ef;border:1px solid #f3cabb;border-left:3px solid #dc2626;border-radius:8px;color:var(--text2);line-height:1.5}
  body.dark .crp-avoid li{background:#241413;border-color:#4a201a}
  .crp-avoid li b{color:#b4452f;font-weight:700}
  .crp-picks{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
  .crp-pick{border:1px solid var(--border);border-radius:11px;padding:14px;background:var(--panel3)}
  .crp-pick .pl{font-size:9.5px;font-weight:800;text-transform:uppercase;letter-spacing:.4px;padding:3px 9px;border-radius:20px;display:inline-block}
  .crp-pick .pt{font-size:14px;font-weight:700;margin:10px 0 5px;color:var(--text);line-height:1.3}
  .crp-pick .pm{font-size:11.5px;color:var(--muted);line-height:1.45}
  .crp-pick .ps{font-size:12.5px;font-weight:800;color:#ea7317;margin-top:7px}
  .pbadge{display:inline-block;font-size:10.5px;font-weight:700;padding:2px 10px;border-radius:20px;white-space:nowrap}
  .pbadge.green{background:#e7f6ee;color:#16a34a} .pbadge.orange{background:#fdf0e1;color:#c2660a}
  .pbadge.red{background:#fdeaea;color:#dc2626} .pbadge.navy{background:#e8eeff;color:#1e3a8a}
  body.dark .pbadge.green{background:#10241c;color:#34d399} body.dark .pbadge.orange{background:#2a1f12;color:#f0a35a}
  body.dark .pbadge.red{background:#2a1414;color:#f87171} body.dark .pbadge.navy{background:#16203c;color:#9db8ff}
  .crp-disc{font-size:11.5px;color:var(--muted);background:var(--panel3);border:1px dashed var(--border2);border-radius:8px;padding:9px 12px;margin-top:16px;line-height:1.5}
  @media(max-width:680px){.crp-snap,.crp-picks,.crp-pkg{grid-template-columns:1fr}}

  /* ===== Report motion & highlights ===== */
  @keyframes crpRise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
  @keyframes crpFade{from{opacity:0}to{opacity:1}}
  @keyframes crpPop{0%{opacity:0;transform:scale(.85)}60%{transform:scale(1.06)}100%{opacity:1;transform:scale(1)}}
  .strat{animation:crpRise .4s cubic-bezier(.22,1,.36,1) both}
  .crp-h{animation:crpFade .5s ease both}
  .crp-conf{animation:crpPop .45s cubic-bezier(.22,1,.36,1) both;box-shadow:0 6px 16px rgba(30,58,138,.3)}
  .crp-snap .cell{animation:crpRise .4s ease both;transition:border-color .18s,transform .18s,box-shadow .18s}
  .crp-snap .cell:nth-child(2){animation-delay:.04s}.crp-snap .cell:nth-child(3){animation-delay:.08s}
  .crp-snap .cell:nth-child(4){animation-delay:.12s}.crp-snap .cell:nth-child(5){animation-delay:.16s}.crp-snap .cell:nth-child(6){animation-delay:.2s}
  .crp-snap .cell:hover{border-color:#1e3a8a;transform:translateY(-2px);box-shadow:var(--shadow)}
  .crp-pat,.crp-rec,.crp-gap,.crp-pick{animation:crpRise .42s cubic-bezier(.22,1,.36,1) both}
  .crp-pat{transition:transform .18s,border-left-width .18s,box-shadow .18s}
  .crp-pat:hover{transform:translateX(4px);box-shadow:var(--shadow)}
  .crp-rec{transition:transform .18s,box-shadow .18s,border-color .18s}
  .crp-rec:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:#1e3a8a}
  .crp-rec .rnum{transition:transform .18s} .crp-rec:hover .rnum{transform:scale(1.12) rotate(-4deg)}
  .crp-pick{transition:transform .18s,box-shadow .18s,border-color .18s}
  .crp-pick:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:#ea7317}
  .crp-gap{transition:transform .18s,box-shadow .18s} .crp-gap:hover{transform:translateX(4px);box-shadow:var(--shadow)}
  .crp-avoid li{transition:transform .15s} .crp-avoid li:hover{transform:translateX(4px)}
  .pbadge{transition:transform .15s} tr:hover .pbadge{transform:scale(1.08)}
  .fmt-badge,.crp-pat .fmt{transition:transform .15s}
  .crp-rec:hover .fmt-badge{transform:translateY(-1px)}
  @media (prefers-reduced-motion: reduce){ *{animation:none!important} }

  /* ===== Action-first report layout ===== */
  .rep-sec{margin-top:20px}
  .rep-h{font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.6px;color:var(--accent-d);margin-bottom:11px;display:flex;align-items:center;gap:7px}
  body.dark .rep-h{color:var(--text2)}
  .rep-cols{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:20px}
  .rep-list{list-style:none;padding:0;margin:0;display:grid;gap:7px}
  .rep-list li{font-size:13.5px;line-height:1.5;padding:9px 13px;background:var(--panel3);border:1px solid var(--border);
    border-radius:9px;border-left:3px solid var(--ok);color:var(--text2)}
  .rep-list.bad li{border-left-color:var(--err)}
  .make-list{display:grid;gap:10px}
  .make{display:flex;gap:13px;background:var(--panel);border:1px solid var(--border);border-left:4px solid var(--brand);
    border-radius:11px;padding:13px 15px;box-shadow:var(--shadow)}
  .make .mk-n{flex-shrink:0;width:26px;height:26px;border-radius:8px;background:linear-gradient(135deg,var(--brand),var(--accent));
    color:#fff;display:grid;place-items:center;font-weight:800;font-size:13px}
  .make .mk-b{flex:1;min-width:0}
  .make .mk-t{font-size:15px;font-weight:700;color:var(--text);line-height:1.35;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
  .make .mk-t .fmt{font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;background:var(--accent-soft);color:var(--accent-d);padding:2px 8px;border-radius:20px}
  body.dark .make .mk-t .fmt{background:var(--panel2);color:var(--text2)}
  .make .mk-hook{font-size:13px;color:var(--muted);margin-top:4px;line-height:1.5}
  .make .mk-kw{margin-top:8px;display:flex;flex-wrap:wrap;gap:6px}
  .takeaway{background:linear-gradient(135deg,var(--accent-soft),var(--panel));border:1px solid var(--border2);
    border-radius:var(--radius-sm);padding:15px 17px;margin-top:20px;font-size:14.5px;line-height:1.65;color:var(--text)}
  body.dark .takeaway{background:var(--panel2)}
  .takeaway b{color:var(--brand)}
  .rep-ref{margin-top:18px;border-top:1px solid var(--border);padding-top:12px}
  .rep-ref summary{cursor:pointer;font-size:12.5px;font-weight:700;color:var(--muted);list-style:none}
  .rep-ref summary::-webkit-details-marker{display:none}
  .rep-ref summary:before{content:'▸ ';color:var(--accent)}
  .rep-ref[open] summary:before{content:'▾ '}
  @media(max-width:680px){.rep-cols{grid-template-columns:1fr}}

  /* ===== Report table (scan results) ===== */
  .rtable-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius-sm);margin-top:6px}
  table.rtable{width:100%;border-collapse:collapse;font-size:13px;min-width:560px}
  table.rtable th{background:var(--panel2);text-align:left;padding:9px 11px;font-weight:700;color:var(--text2);
    font-size:11px;text-transform:uppercase;letter-spacing:.4px;border-bottom:1px solid var(--border)}
  table.rtable td{padding:9px 11px;border-bottom:1px solid var(--border);vertical-align:top;color:var(--text2)}
  table.rtable tr:last-child td{border-bottom:0}
  table.rtable tr:hover td{background:var(--panel3)}
  table.rtable a{color:var(--accent);text-decoration:none;font-weight:600}
  table.rtable a:hover{text-decoration:underline}
  table.rtable .num{text-align:right;white-space:nowrap;font-variant-numeric:tabular-nums}
  table.rtable .nowrap{white-space:nowrap}
  table.rtable td:first-child{font-weight:600;color:var(--text)}
  .runcat-chip.all{background:var(--accent);color:#fff;border-color:transparent}
  .runcat-chip.all.off{background:var(--panel3);color:var(--text2)}
  .conclusion{background:var(--accent-soft);border:1px solid var(--border2);border-radius:var(--radius-sm);
    padding:13px 16px;margin-top:16px;font-size:14px;line-height:1.6;color:var(--text)}
  body.dark .conclusion{background:var(--panel2)}
  .conclusion b{color:var(--accent-d)} body.dark .conclusion b{color:var(--text)}

  /* ===== Ranked priority lists (category reports) ===== */
  ol.rank{margin:0;padding:0;list-style:none;counter-reset:r;display:grid;gap:6px}
  ol.rank li{position:relative;padding:8px 10px 8px 34px;background:var(--panel3);border:1px solid var(--border);
    border-radius:9px;font-size:13.5px;counter-increment:r}
  ol.rank li:before{content:counter(r);position:absolute;left:8px;top:50%;transform:translateY(-50%);
    width:20px;height:20px;border-radius:6px;background:var(--accent);color:#fff;font-size:11px;font-weight:800;
    display:grid;place-items:center}
  ol.rank.flop li:before{background:var(--muted)}
  ol.rank li b{color:var(--text)}

  /* ===== Category headings (creator groups) ===== */
  .cat-head{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.6px;
    color:var(--accent-d);margin:16px 0 8px;display:flex;align-items:center;gap:8px}
  body.dark .cat-head{color:var(--text2)}
  .cat-head:first-child{margin-top:14px}

  /* ===== Niche chips ===== */
  .niche-grid{display:flex;flex-wrap:wrap;gap:9px;margin-top:12px}
  .niche-chip{background:var(--panel3);border:1px solid var(--border2);border-radius:22px;
    padding:8px 14px;font-size:13px;font-weight:600;color:var(--text2);cursor:pointer;
    user-select:none;transition:.13s}
  .niche-chip:hover{border-color:var(--accent);color:var(--accent)}
  .niche-chip.on{background:linear-gradient(135deg,var(--accent),var(--accent-d));
    color:#fff;border-color:transparent;box-shadow:0 3px 10px rgba(79,70,229,.3)}

  /* ===== Virality badges ===== */
  .vbadge{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:700;
    padding:3px 9px;border-radius:20px;border:1px solid transparent}
  .vbadge.viral{background:#fef2f2;color:#dc2626;border-color:#fecaca}
  .vbadge.good{background:#eef6ff;color:#2563eb;border-color:#cfe2ff}
  .vbadge.avg{background:var(--panel2);color:var(--muted)}
  .vbadge.flop{background:#f1f5f9;color:#64748b;border-color:#e2e8f0}
  body.dark .vbadge.viral{background:#2a1414;color:#fca5a5;border-color:#5a2a2a}
  body.dark .vbadge.good{background:#13233f;color:#93c5fd;border-color:#244a7a}
  body.dark .vbadge.avg,body.dark .vbadge.flop{background:#1b2230;color:#94a3b8;border-color:#2a3140}

  /* ===== Strategy report ===== */
  .strat{background:linear-gradient(135deg,var(--accent-soft),var(--panel));
    border:1px solid var(--border2);border-radius:var(--radius);padding:24px;margin-bottom:20px;box-shadow:var(--shadow)}
  body.dark .strat{background:linear-gradient(135deg,#181d33,var(--panel))}
  .strat .st-head{display:flex;align-items:center;gap:11px;margin-bottom:6px}
  .strat .st-head .ic{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;font-size:19px;
    background:linear-gradient(135deg,var(--brand),var(--accent));color:#fff;box-shadow:0 4px 12px rgba(255,59,48,.3)}
  .strat h3{margin:0;font-size:18px;font-weight:800;letter-spacing:-.3px}
  .strat .st-niche{font-size:12.5px;color:var(--muted);font-weight:600}
  .strat .st-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:18px}
  .strat .st-sec .h{font-size:11px;text-transform:uppercase;letter-spacing:.7px;color:var(--muted);font-weight:700;margin-bottom:9px}
  .strat .st-sec p{margin:0;font-size:14px;color:var(--text2);line-height:1.6}
  .kwrap{display:flex;flex-wrap:wrap;gap:7px}
  .kw{font-size:12.5px;font-weight:600;padding:5px 11px;border-radius:20px;
    background:var(--panel);border:1px solid var(--border2);color:var(--accent-d)}
  body.dark .kw{color:var(--text)}
  .kw.bad{color:#b91c1c;border-color:#fca5a5}
  body.dark .kw.bad{color:#fca5a5;border-color:#5a2a2a}
  .ideas{display:grid;gap:11px;margin-top:18px}
  .idea{background:var(--panel);border:1px solid var(--border);border-left:3px solid var(--brand);
    border-radius:var(--radius-sm);padding:14px 16px}
  .idea .it{font-weight:700;font-size:14.5px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
  .idea .fmt{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:2px 8px;border-radius:20px;
    background:var(--accent-soft);color:var(--accent-d)}
  body.dark .idea .fmt{background:var(--panel2);color:var(--text2)}
  .idea .why{font-size:13px;color:var(--muted);margin-top:5px}
  .idea .ik{margin-top:9px}
  .st-stats{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
  .st-stat{font-size:12px;font-weight:600;color:var(--text2);background:var(--panel);border:1px solid var(--border);
    border-radius:20px;padding:5px 12px}
  .st-stat b{color:var(--brand)}

  /* ===== Automation ===== */
  .auto-toggle{display:flex;align-items:center;gap:16px;background:var(--panel3);
    border:1px solid var(--border);border-radius:var(--radius-sm);padding:16px 18px}
  .auto-toggle .at-title{font-weight:700;font-size:14.5px}
  .auto-toggle .at-sub{font-size:12.5px;color:var(--muted);margin-top:2px}
  .switch{margin-left:auto;position:relative;display:inline-block;width:48px;height:27px;flex-shrink:0}
  .switch input{opacity:0;width:0;height:0}
  .slider{position:absolute;inset:0;background:var(--border2);border-radius:30px;cursor:pointer;transition:.2s}
  .slider:before{content:"";position:absolute;height:21px;width:21px;left:3px;top:3px;background:#fff;border-radius:50%;transition:.2s;box-shadow:0 1px 3px rgba(0,0,0,.3)}
  .switch input:checked + .slider{background:linear-gradient(135deg,var(--ok),#22c55e)}
  .switch input:checked + .slider:before{transform:translateX(21px)}
  .auto-status{margin-top:18px;padding:12px 15px;border-radius:var(--radius-sm);font-size:13.5px;font-weight:600;
    background:var(--panel2);color:var(--muted);border:1px solid var(--border)}
  .auto-status.on{background:var(--ok-soft);color:var(--ok);border-color:transparent}

  /* ===== Usage monitor ===== */
  .usage{display:grid;gap:14px}
  .u-prov{background:var(--panel3);border:1px solid var(--border);border-radius:var(--radius-sm);padding:13px 14px}
  .u-h{font-size:12.5px;font-weight:700;color:var(--text);margin-bottom:10px;display:flex;align-items:center;gap:7px}
  .u-empty{font-size:12.5px;color:var(--muted)}
  .u-key{margin-bottom:11px}
  .u-key:last-child{margin-bottom:0}
  .u-key-top{display:flex;justify-content:space-between;gap:10px;font-size:12.5px;margin-bottom:5px}
  .u-mask{font-family:ui-monospace,Menlo,monospace;color:var(--text2);font-weight:600}
  .u-stat{color:var(--muted);font-weight:600;white-space:nowrap}
  .u-key.ex .u-stat{color:var(--err)}
  .u-key.warn .u-stat{color:var(--warn)}
  .u-bar{height:7px;background:var(--panel2);border-radius:20px;overflow:hidden}
  .u-bar i{display:block;height:100%;border-radius:20px;background:linear-gradient(90deg,var(--ok),#22c55e);transition:width .3s}
  .u-key.warn .u-bar i{background:linear-gradient(90deg,var(--warn),#f59e0b)}
  .u-key.ex .u-bar i{background:linear-gradient(90deg,var(--err),#ef4444)}
  .hint{font-size:12.5px;color:var(--muted);margin-top:10px}
  .hint a{color:var(--accent);font-weight:600;text-decoration:none}
  .hint a:hover{text-decoration:underline}

  /* ===== Toolbar / status ===== */
  .toolbar{display:flex;align-items:center;gap:13px;flex-wrap:wrap}
  .status{font-size:13px;color:var(--muted);min-height:20px;margin-left:auto;font-weight:500}
  .status.busy{color:var(--warn)} .status.done{color:var(--ok)} .status.err{color:var(--err)}

  /* ===== Report items ===== */
  .report{margin-top:8px}
  .item{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);
    padding:0;margin-bottom:18px;overflow:hidden;box-shadow:var(--shadow)}
  .item .top{display:flex;gap:16px;padding:18px;border-bottom:1px solid var(--border);
    background:linear-gradient(180deg,var(--panel3),transparent)}
  .item .thumb{width:168px;height:94px;border-radius:11px;object-fit:cover;flex-shrink:0;background:var(--panel2);
    box-shadow:var(--shadow)}
  .item .meta{flex:1;min-width:0}
  .item .meta .creator{font-size:12px;color:var(--accent);font-weight:700;letter-spacing:.1px}
  .item .meta h3{margin:5px 0 7px;font-size:16px;line-height:1.35;font-weight:700;letter-spacing:-.2px}
  .item .meta h3 a{color:var(--text);text-decoration:none}
  .item .meta h3 a:hover{color:var(--accent)}
  .item .meta .date{font-size:12px;color:var(--muted);display:flex;flex-wrap:wrap;gap:6px;align-items:center}
  .item .body{padding:20px;display:grid;gap:18px}
  .sec .h{font-size:11px;text-transform:uppercase;letter-spacing:.7px;color:var(--muted);margin-bottom:8px;font-weight:700}
  .sec p{margin:0;font-size:14.5px;color:var(--text2);line-height:1.6}
  .topics{list-style:none;padding:0;margin:0;display:grid;gap:9px}
  .topics li{background:var(--panel3);border:1px solid var(--border);border-left:3px solid var(--accent);
    border-radius:var(--radius-sm);padding:12px 14px;font-size:14px;transition:.15s}
  .topics li:hover{border-left-color:var(--brand);background:var(--accent-soft)}
  body.dark .topics li:hover{background:var(--panel2)}
  .topics li .tt{font-weight:700;color:var(--text)}
  .topics li .ta{font-size:12.5px;color:var(--muted);margin-top:4px}

  .err-box{background:var(--err-soft);border:1px solid var(--err);color:var(--err);padding:11px 14px;border-radius:var(--radius-sm);font-size:13px;font-weight:500}
  .empty{text-align:center;color:var(--muted);padding:54px 20px;font-size:14.5px;
    background:var(--panel);border:1px dashed var(--border2);border-radius:var(--radius)}
  details summary{cursor:pointer;color:var(--muted);font-size:12px;margin-top:4px}

  .save-bar{display:flex;align-items:center;gap:12px;margin-top:14px;flex-wrap:wrap}
  .badge{font-size:11.5px;font-weight:600;padding:4px 11px;border-radius:20px;background:var(--panel2);border:1px solid var(--border2);color:var(--muted)}
  .badge.live{color:var(--ok);background:var(--ok-soft);border-color:transparent}

  /* ===== Welcome notice ===== */
  #setupNotice{background:linear-gradient(135deg,var(--accent-soft),var(--panel));border:1px solid var(--border2)}
  body.dark #setupNotice{background:var(--panel)}

  /* ===== Dialogs ===== */
  dialog{background:var(--panel);color:var(--text);border:1px solid var(--border);
    border-radius:20px;padding:0;max-width:680px;width:92%;box-shadow:var(--shadow-lg)}
  dialog[open]{animation:pop .18s ease-out}
  @keyframes pop{from{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:none}}
  dialog::backdrop{background:rgba(15,23,42,.5);backdrop-filter:blur(3px)}
  .modal-head{display:flex;align-items:center;gap:11px;padding:20px 24px;border-bottom:1px solid var(--border);
    position:sticky;top:0;background:var(--panel);border-radius:20px 20px 0 0;z-index:1}
  .modal-head h2{margin:0;font-size:16px;font-weight:700}
  .modal-head .x{margin-left:auto;background:transparent;border:0;color:var(--muted);font-size:18px;cursor:pointer;
    padding:4px 8px;border-radius:8px;box-shadow:none}
  .modal-head .x:hover{color:var(--err);background:var(--err-soft);transform:none}
  .modal-body{padding:24px;max-height:68vh;overflow:auto}
  .modal-body .blk{margin-bottom:20px}
  .modal-body .blk:last-child{margin-bottom:0}
  .modal-foot{padding:16px 24px;border-top:1px solid var(--border);display:flex;align-items:center;gap:12px;
    background:var(--panel3);border-radius:0 0 20px 20px}

  /* ===== Footer (compact, pinned to bottom) ===== */
  footer{border-top:1px solid var(--border);background:var(--panel);flex-shrink:0}
  .foot-in{max-width:1060px;margin:0 auto;padding:11px 30px;display:flex;align-items:center;
    gap:9px;flex-wrap:wrap;font-size:12.5px}
  .foot-ava{width:24px;height:24px;border-radius:7px;display:grid;place-items:center;font-size:10px;
    font-weight:800;color:#fff;background:linear-gradient(135deg,var(--brand),var(--accent));flex-shrink:0}
  .foot-name{font-weight:700;color:var(--text)}
  .foot-role{color:var(--muted)}
  .foot-mail{color:var(--accent);font-weight:600;text-decoration:none}
  .foot-mail:hover{text-decoration:underline}
  .foot-ig{margin-left:auto;display:inline-flex;align-items:center;gap:7px;text-decoration:none;
    font-weight:700;font-size:12px;color:#fff;padding:6px 12px;border-radius:20px;
    background:linear-gradient(135deg,#f9ce34,#ee2a7b 50%,#6228d7);box-shadow:0 3px 10px rgba(238,42,123,.3)}
  .foot-ig:hover{filter:brightness(1.07)}
  .foot-ig svg{width:15px;height:15px}
  .foot-meta{color:var(--muted)}
  @media(max-width:560px){.foot-ig{margin-left:0}}

  @media(max-width:820px){
    header{flex-wrap:wrap;padding:12px 16px;gap:10px}
    header h1{font-size:16px}
    .tabs{order:3;width:100%;margin-left:0;justify-content:space-between}
    .tab{flex:1;justify-content:center}
    .navactions{margin-left:auto}
  }
  @media(max-width:720px){
    .wrap{padding:22px 16px 80px}.card{padding:18px}
    .grid,.grid3{grid-template-columns:1fr}
    .item .top{flex-direction:column}.item .thumb{width:100%;height:auto;aspect-ratio:16/9}
    .panel-head{flex-wrap:wrap}.count-badge,.panel-head .status{margin-left:0}
  }
