/* ═══ TOOLBAR SYSTEM ═══ */
body.toolbar-active{padding-top:56px;}
.app-toolbar{position:fixed;top:0;left:0;right:0;height:56px;background:#fff;border-bottom:1px solid #e5e7eb;display:none;align-items:center;justify-content:space-between;padding:0 16px;z-index:1000;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);}
.app-toolbar.active{display:flex;}
.toolbar-left,.toolbar-right{display:flex;align-items:center;gap:12px;}
.toolbar-btn{padding:0.5rem 1rem;border:1px solid #e5e7eb;background:#fff;color:#111827;border-radius:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:0.5rem;font-size:0.875rem;font-weight:600;transition:all 0.2s ease;}
.toolbar-btn svg{width:20px;height:20px;display:block;}
.toolbar-btn:hover{border-color:#c49a28;}
.toolbar-btn:active{transform:scale(0.95);}
.toolbar-logo{display:flex;align-items:center;gap:10px;}
.toolbar-logo .logo-icon-img{width:32px;height:32px;object-fit:contain;}
.toolbar-logo .logo-text{font-family:'Playfair Display',Georgia,serif!important;font-weight:600;font-size:1.25rem;color:#0F1D2F;}
.toolbar-logo .logo-text .logo-accent{color:#D4AF5C;}
@media(max-width:600px){.toolbar-logo .logo-text{display:none;}.toolbar-btn span{display:none;}}

/* Profile Dropdown */
.toolbar-profile{position:relative;}
.profile-btn{display:flex;align-items:center;gap:8px;padding:6px 12px 6px 6px;background:transparent;border:1px solid #e5e7eb;border-radius:24px;cursor:pointer;transition:all 0.2s ease;}
.profile-btn:hover{background:#fafafa;border-color:#9ca3af;}
.profile-avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,#0F1D2F,#c49a28);color:#fff;font-weight:700;font-size:0.8rem;display:flex;align-items:center;justify-content:center;}
.profile-name{font-size:0.875rem;font-weight:500;color:#111827;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.profile-chevron{color:#9ca3af;transition:transform 0.2s ease;}
@media(max-width:600px){.profile-name{display:none;}.profile-btn{padding:6px;border-radius:50%;}.profile-chevron{display:none;}}
.profile-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:280px;background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 10px 40px rgba(0,0,0,0.15);opacity:0;visibility:hidden;transform:translateY(-10px) scale(0.95);transform-origin:top right;transition:all 0.2s ease;z-index:1001;}
.profile-dropdown.active{opacity:1;visibility:visible;transform:translateY(0) scale(1);}
.dropdown-user-info{display:flex;align-items:center;gap:12px;padding:16px;}
.dropdown-avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,#0F1D2F,#c49a28);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.1rem;flex-shrink:0;}
.dropdown-user-details{flex:1;min-width:0;}
.dropdown-user-name{font-weight:600;font-size:0.95rem;color:#111827;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.dropdown-user-email{font-size:0.8rem;color:#6b7280;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.dropdown-user-plan{font-size:0.75rem;color:#c49a28;font-weight:600;margin-top:2px;}
.dropdown-divider{height:1px;background:#e5e7eb;margin:0;}
.dropdown-item{display:flex;align-items:center;gap:12px;padding:12px 16px;background:transparent;border:none;width:100%;font-size:0.875rem;font-weight:500;color:#111827;cursor:pointer;transition:all 0.15s ease;text-align:left;font-family:'DM Sans',sans-serif;}
.dropdown-item:hover{background:#fafafa;}
.dropdown-item svg{width:16px;height:16px;color:#9ca3af;}

/* App Launcher */
.app-launcher-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,0.3);opacity:0;visibility:hidden;transition:opacity 0.2s ease;z-index:998;}
.app-launcher-overlay.active{opacity:1;visibility:visible;}
.app-launcher{position:fixed;top:64px;left:16px;width:420px;background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 10px 40px rgba(0,0,0,0.15);opacity:0;visibility:hidden;transform:scale(0.9) translateY(-10px);transform-origin:top left;transition:all 0.2s cubic-bezier(0.4,0,0.2,1);z-index:999;overflow:hidden;max-height:80vh;}
.app-launcher.active{opacity:1;visibility:visible;transform:scale(1) translateY(0);}
.app-launcher-header{padding:16px 20px;border-bottom:1px solid #e5e7eb;font-weight:600;font-size:0.9rem;color:#111827;}
.app-launcher-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;padding:10px;max-height:calc(80vh - 52px);overflow-y:auto;}
.app-launcher-item{display:flex;flex-direction:column;align-items:center;gap:6px;padding:14px 8px;background:transparent;border:1px solid transparent;border-radius:10px;cursor:pointer;transition:all 0.2s ease;text-decoration:none;color:#111827;}
.app-launcher-item:hover{background:#fafafa;border-color:#e5e7eb;}
.app-launcher-item.current{background:#fafafa;border-color:#c49a28;}
.app-launcher-icon{width:40px;height:40px;border-radius:10px;background:#fafafa;display:flex;align-items:center;justify-content:center;transition:all 0.2s ease;}
.app-emoji{font-size:1.35rem;}
.app-launcher-item:hover .app-launcher-icon{transform:scale(1.05);box-shadow:0 4px 12px rgba(0,0,0,0.1);}
.app-launcher-label{font-size:0.7rem;font-weight:500;text-align:center;line-height:1.3;}
@media(max-width:480px){.app-launcher{left:8px;right:8px;width:auto;}.app-launcher-grid{grid-template-columns:repeat(2,1fr);}}

/* ═══ EDITOR STYLES ═══ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --cream:#f8f4ee;--cream2:#f0ead9;--cream3:#e8dfc8;
  --ink:#17120e;--ink2:#2c2018;--ink3:#3d3025;
  --muted:#7a6e62;--rule:#ddd4c0;--rule2:#cfc5b0;
  --gold:#c49a28;--gold2:#e8d08a;--gold3:#f5e8b0;--gold-glow:rgba(196,154,40,0.18);
  --green:#2a6e2f;--green2:#3d8b42;--green-bg:#edf7ee;--green-border:#b2d9b4;
  --amber:#c07000;--amber-bg:#fff5e0;--amber-border:#f0c060;
  --red:#b52222;--red-bg:#fdf0f0;--red-border:#e8a0a0;
  --blue:#1558a8;--blue-bg:#edf4ff;--blue-border:#90b8e8;
  --purple:#6a1b9a;--purple-bg:#f5eeff;--purple-border:#c890e8;
  --shadow-sm:0 1px 4px rgba(23,18,14,0.08);
  --shadow-md:0 3px 16px rgba(23,18,14,0.10);
  --shadow-lg:0 8px 32px rgba(23,18,14,0.13);
  --radius:7px;
}
html,body{height:100%;overflow:hidden}
body{background:var(--cream);color:var(--ink);font-family:'DM Sans',sans-serif;font-size:14px;line-height:1.65;display:flex;flex-direction:column}

/* ═══ HEADER ═══ */
.hdr{background:var(--ink2);height:52px;display:flex;align-items:center;padding:0 28px;gap:20px;border-bottom:2px solid var(--gold);flex-shrink:0;position:relative;z-index:100}
.hdr-brand{font-family:'Playfair Display',serif;font-size:16px;font-weight:900;color:#0a0806;letter-spacing:0.02em;white-space:nowrap;display:flex;align-items:center;gap:9px;flex-shrink:0}
.hdr-ver{font-size:9px;font-weight:700;letter-spacing:0.12em;color:#3d3025;background:rgba(44,32,24,0.1);padding:2px 7px;border-radius:20px;border:1px solid rgba(44,32,24,0.2)}
.hdr-div{width:1px;height:28px;background:rgba(232,208,138,0.12);flex-shrink:0}
.hdr-keys{display:flex;align-items:center;gap:14px;flex:1}
.key-grp{display:flex;align-items:center;gap:6px}
.key-dot{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,0.12);flex-shrink:0;transition:background 0.4s,box-shadow 0.4s}
.key-dot.on{background:#6ec976;box-shadow:0 0 6px rgba(110,201,118,0.6)}
.key-lbl{font-size:9px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:rgba(232,208,138,0.35);white-space:nowrap}
.key-inp{background:rgba(255,255,255,0.05);border:1px solid rgba(232,208,138,0.14);border-radius:4px;padding:4px 10px;font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--gold2);width:190px;outline:none;transition:border-color 0.2s}
.key-inp:focus{border-color:rgba(196,154,40,0.55)}
.key-inp::placeholder{color:rgba(232,208,138,0.18)}
.hdr-right{display:flex;align-items:center;gap:10px;flex-shrink:0}
.hdr-badge{font-size:9px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;padding:3px 9px;border-radius:20px;border:1px solid;cursor:default}
.badge-fc{background:rgba(192,112,0,0.12);color:#e8c060;border-color:rgba(192,112,0,0.25)}

/* ═══ LAYOUT ═══ */
.app{display:grid;grid-template-columns:360px 1fr;flex:1;overflow:hidden;min-height:0;position:relative}

/* ═══ INGESTION OVERLAY ═══ */
.ingest{position:absolute;inset:0;z-index:50;background:var(--cream);display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:44px 40px 40px;transition:opacity 0.45s ease,transform 0.45s ease;overflow-y:auto}
.ingest.gone{opacity:0;transform:translateY(-18px) scale(0.98);pointer-events:none}
.ingest-inner{width:100%;max-width:760px;display:flex;flex-direction:column;gap:22px}
.ingest-hero{text-align:center;margin-bottom:4px}
.ingest-title{font-family:'Playfair Display',serif;font-size:28px;font-weight:900;color:var(--ink);letter-spacing:-0.01em;margin-bottom:5px}
.ingest-sub{font-size:13px;color:var(--muted);line-height:1.6}
.ingest-ta{width:100%;height:280px;background:#fff;border:1.5px solid var(--rule);border-radius:10px;padding:18px 20px;font-family:'DM Sans',sans-serif;font-size:15px;line-height:1.75;color:var(--ink);resize:none;outline:none;transition:border-color 0.2s,box-shadow 0.2s;box-shadow:var(--shadow-md);display:block}
.ingest-ta:focus{border-color:var(--gold);box-shadow:0 0 0 3px var(--gold-glow),var(--shadow-md)}
.ingest-ta::placeholder{color:var(--muted);opacity:0.4;font-size:14px}
.ingest-ta-foot{display:flex;align-items:center;justify-content:space-between;margin-top:7px;padding:0 2px}
.ingest-chips{display:flex;gap:6px;flex-wrap:wrap}
.ingest-wc{font-size:11px;color:var(--muted)}
.ingest-bottom{display:grid;grid-template-columns:1fr auto;gap:18px;align-items:start}
.ingest-profiles{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}
.ingest-pf{background:#fff;border:1.5px solid var(--rule);border-radius:7px;padding:9px 7px;cursor:pointer;text-align:center;transition:all 0.15s;box-shadow:var(--shadow-sm)}
.ingest-pf:hover{border-color:var(--gold);transform:translateY(-1px)}
.ingest-pf.active{border-color:var(--gold);background:#fffbf2;box-shadow:0 0 0 3px var(--gold-glow)}
.ingest-pf .p-icon{font-size:17px;margin-bottom:3px}
.ingest-pf .p-name{font-size:9px;font-weight:700;color:var(--ink);line-height:1.3}
.ingest-actions{display:flex;flex-direction:column;gap:8px;min-width:175px}
.ingest-analyse{background:var(--ink2);color:var(--gold2);border:none;border-radius:var(--radius);padding:14px 20px;font-family:'Playfair Display',serif;font-size:15px;font-weight:900;cursor:pointer;transition:all 0.2s;display:flex;align-items:center;justify-content:center;gap:8px;letter-spacing:0.02em;white-space:nowrap;width:100%}
.ingest-analyse:hover:not(:disabled){background:var(--ink3);transform:translateY(-1px);box-shadow:var(--shadow-md)}
.ingest-analyse:disabled{opacity:0.4;cursor:not-allowed;transform:none}
.ingest-analyse .sp{width:14px;height:14px;border:2px solid rgba(232,208,138,0.2);border-top-color:var(--gold2);border-radius:50%;animation:spin 0.7s linear infinite;display:none;flex-shrink:0}
.ingest-analyse.busy .sp{display:block}
.ingest-analyse.busy .bt{opacity:0.6}
.ingest-voice-row{display:flex;gap:7px}
.ingest-voice-inp{flex:1;background:#fff;border:1.5px solid var(--rule);border-radius:var(--radius);padding:8px 11px;font-family:'DM Sans',sans-serif;font-size:12px;color:var(--ink);outline:none;transition:border-color 0.2s}
.ingest-voice-inp:focus{border-color:var(--gold)}
.ingest-voice-inp::placeholder{color:var(--muted);opacity:0.4;font-size:11px}
.ingest-sec-lbl{font-size:9px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--muted);margin-bottom:7px;display:flex;align-items:center;gap:5px}
.ingest-sec-dot{width:4px;height:4px;border-radius:50%;background:var(--gold)}

/* ═══ SETTINGS PANEL ═══ */
.settings-overlay{position:fixed;inset:0;z-index:190;background:rgba(23,18,14,0.5);backdrop-filter:blur(2px);display:flex;align-items:flex-start;justify-content:flex-end;opacity:0;pointer-events:none;transition:opacity 0.2s}
.settings-overlay.vis{opacity:1;pointer-events:all}
.settings-panel{background:var(--cream);width:360px;max-width:90vw;height:100%;box-shadow:var(--shadow-lg);border-left:1.5px solid var(--rule);padding:28px 24px;overflow-y:auto;transform:translateX(20px);transition:transform 0.25s;display:flex;flex-direction:column;gap:22px}
.settings-overlay.vis .settings-panel{transform:none}
.settings-head{display:flex;align-items:center;justify-content:space-between}
.settings-title{font-family:'Playfair Display',serif;font-size:18px;font-weight:900;color:var(--ink)}
.settings-close{background:none;border:1px solid var(--rule);border-radius:20px;padding:4px 12px;font-size:10px;font-weight:700;color:var(--muted);cursor:pointer;transition:all 0.15s}
.settings-close:hover{border-color:var(--gold);color:var(--gold)}
.settings-sec{display:flex;flex-direction:column;gap:8px}
.settings-lbl{font-size:9px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--muted);display:flex;align-items:center;gap:6px}
.settings-key-row{display:flex;align-items:center;gap:8px}
.settings-key-inp{flex:1;background:#fff;border:1.5px solid var(--rule);border-radius:var(--radius);padding:9px 12px;font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--ink);outline:none;transition:border-color 0.2s}
.settings-key-inp:focus{border-color:var(--gold)}
.settings-key-inp::placeholder{color:var(--muted);opacity:0.35}
.settings-dot{width:8px;height:8px;border-radius:50%;background:rgba(0,0,0,0.1);flex-shrink:0;transition:all 0.3s}
.settings-dot.on{background:#6ec976;box-shadow:0 0 6px rgba(110,201,118,0.6)}
.hdr-settings{background:none;border:1px solid rgba(232,208,138,0.15);border-radius:20px;padding:4px 10px;font-size:9px;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;color:rgba(232,208,138,0.45);cursor:pointer;transition:all 0.15s;display:flex;align-items:center;gap:5px}
.hdr-settings:hover{border-color:rgba(232,208,138,0.35);color:rgba(232,208,138,0.7)}

/* ═══ SIDEBAR ═══ */
.sidebar{background:var(--cream2);border-right:1.5px solid var(--rule);display:flex;flex-direction:column;overflow:hidden}
.sb-scroll{flex:1;overflow-y:auto;padding:20px 18px;display:flex;flex-direction:column;gap:18px}
.sb-scroll::-webkit-scrollbar{width:3px}
.sb-scroll::-webkit-scrollbar-thumb{background:var(--rule2);border-radius:2px}

.sb-sec{}
.sb-lbl{font-size:9px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--muted);margin-bottom:7px;display:flex;align-items:center;gap:6px}
.sb-lbl-dot{width:4px;height:4px;border-radius:50%;background:var(--gold)}

textarea.art{width:100%;height:170px;background:#fff;border:1.5px solid var(--rule);border-radius:var(--radius);padding:11px 13px;font-family:'DM Sans',sans-serif;font-size:13px;line-height:1.65;color:var(--ink);resize:none;outline:none;transition:border-color 0.2s;box-shadow:var(--shadow-sm)}
textarea.art:focus{border-color:var(--gold)}
textarea.art::placeholder{color:var(--muted);opacity:0.45}
.art-meta{display:flex;gap:6px;margin-top:6px;flex-wrap:wrap}
.art-chip{font-size:9px;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;padding:2px 8px;border-radius:20px;background:#fff;border:1px solid var(--rule);color:var(--muted);transition:all 0.25s}
.art-chip.easy{background:var(--green-bg);color:var(--green2);border-color:var(--green-border)}
.art-chip.med {background:var(--amber-bg);color:var(--amber);border-color:var(--amber-border)}
.art-chip.hard{background:var(--red-bg);color:var(--red);border-color:var(--red-border)}

/* Voice Reference */
.voice-wrap{position:relative}
.voice-inp-row{display:flex;gap:7px;align-items:center}
.voice-inp{flex:1;background:#fff;border:1.5px solid var(--rule);border-radius:var(--radius);padding:8px 11px;font-family:'DM Sans',sans-serif;font-size:12px;color:var(--ink);outline:none;transition:border-color 0.2s;box-shadow:var(--shadow-sm)}
.voice-inp:focus{border-color:var(--gold)}
.voice-inp::placeholder{color:var(--muted);opacity:0.45}
.voice-btn{background:var(--ink2);color:var(--gold2);border:none;border-radius:var(--radius);padding:8px 12px;font-size:11px;font-weight:600;cursor:pointer;white-space:nowrap;transition:all 0.2s;display:flex;align-items:center;gap:5px}
.voice-btn:hover{background:var(--ink3)}
.voice-btn:disabled{opacity:0.45;cursor:not-allowed}
.voice-btn .sp{width:12px;height:12px;border:2px solid rgba(232,208,138,0.2);border-top-color:var(--gold2);border-radius:50%;animation:spin 0.7s linear infinite;flex-shrink:0}
.voice-status{margin-top:6px;font-size:11px;color:var(--muted);display:flex;align-items:center;gap:6px;min-height:16px}
.voice-on{color:var(--green2);font-weight:600}
.voice-pill{display:inline-flex;align-items:center;gap:4px;background:var(--green-bg);border:1px solid var(--green-border);border-radius:20px;padding:2px 8px;font-size:9px;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;color:var(--green)}

/* Profiles */
.profiles{display:grid;grid-template-columns:1fr 1fr;gap:6px}
.pf-btn{background:#fff;border:1.5px solid var(--rule);border-radius:var(--radius);padding:8px 9px;cursor:pointer;text-align:left;transition:all 0.15s;box-shadow:var(--shadow-sm)}
.pf-btn:hover{border-color:var(--gold);transform:translateY(-1px);box-shadow:var(--shadow-md)}
.pf-btn.active{border-color:var(--gold);background:#fffbf2;box-shadow:0 0 0 3px var(--gold-glow),var(--shadow-sm)}
.pf-icon{font-size:15px;margin-bottom:3px}
.pf-name{font-size:10px;font-weight:600;color:var(--ink);line-height:1.3}
.pf-desc{font-size:9px;color:var(--muted);margin-top:1px;line-height:1.25}

/* Intent Select */
.intent-select{width:100%;background:#fff;border:1.5px solid var(--rule);border-radius:var(--radius);padding:9px 11px;font-family:'DM Sans',sans-serif;font-size:12px;color:var(--ink);outline:none;cursor:pointer;transition:border-color 0.2s;box-shadow:var(--shadow-sm);-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%237a6e62'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 11px center;padding-right:28px}
.intent-select:focus{border-color:var(--gold)}
.intent-hint{font-size:10px;color:var(--muted);margin-top:6px;line-height:1.45;font-style:italic;transition:all 0.2s;min-height:15px}
.intent-badge{display:inline-flex;align-items:center;gap:4px;font-size:8px;font-weight:700;letter-spacing:0.06em;text-transform:uppercase;padding:2px 7px;border-radius:20px;background:rgba(196,154,40,0.1);color:var(--gold);border:1px solid rgba(196,154,40,0.2);margin-left:6px;white-space:nowrap}

/* Slider */
.sl-row{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:8px}
.sl-val{font-family:'Playfair Display',serif;font-size:22px;font-weight:900;color:var(--gold)}
.sl-cap{font-size:10px;color:var(--muted)}
input[type=range]{-webkit-appearance:none;width:100%;height:4px;background:var(--rule);border-radius:2px;outline:none}
input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;border-radius:50%;background:var(--gold);cursor:pointer;box-shadow:0 1px 4px rgba(0,0,0,0.18);transition:transform 0.1s}
input[type=range]::-webkit-slider-thumb:active{transform:scale(1.25)}
.sl-labs{display:flex;justify-content:space-between;font-size:9px;color:var(--muted);margin-top:5px}

/* Action Buttons */
.btn-row{display:flex;gap:7px}
.btn{border:none;border-radius:var(--radius);padding:12px 16px;font-family:'Playfair Display',serif;font-size:14px;font-weight:700;letter-spacing:0.02em;cursor:pointer;transition:all 0.2s;display:flex;align-items:center;justify-content:center;gap:7px;flex:1;position:relative;overflow:hidden}
.btn:disabled{opacity:0.45;cursor:not-allowed;transform:none!important}
.btn-main{background:var(--ink2);color:var(--gold2)}
.btn-main:hover:not(:disabled){background:var(--ink3);transform:translateY(-1px);box-shadow:var(--shadow-md)}
.btn-iter{background:#243824;color:#88c48c;border:1.5px solid #3a6040;display:none}
.btn-iter:hover:not(:disabled){background:#1a2e1a;transform:translateY(-1px)}
.btn .sp{width:13px;height:13px;border:2px solid rgba(232,208,138,0.2);border-top-color:var(--gold2);border-radius:50%;animation:spin 0.7s linear infinite;display:none;flex-shrink:0}
.btn.busy .sp{display:block}
.btn.busy .bt{opacity:0.6}
@keyframes spin{to{transform:rotate(360deg)}}

/* Round Tracker */
.round-track{display:none;align-items:center;gap:0;margin-top:10px}
.round-track.vis{display:flex}
.rt-step{display:flex;flex-direction:column;align-items:center;gap:3px;flex:1}
.rt-dot{width:10px;height:10px;border-radius:50%;background:var(--rule);border:1.5px solid var(--rule2);transition:all 0.4s;position:relative;z-index:1}
.rt-dot.done{background:var(--gold);border-color:var(--gold);box-shadow:0 0 8px var(--gold-glow)}
.rt-dot.current{background:var(--gold2);border-color:var(--gold);animation:pulse-gold 1.5s ease infinite}
@keyframes pulse-gold{0%,100%{box-shadow:0 0 0 0 var(--gold-glow)}50%{box-shadow:0 0 0 5px transparent}}
.rt-lbl{font-size:8px;font-weight:600;letter-spacing:0.08em;text-transform:uppercase;color:var(--muted);text-align:center}
.rt-lbl.done{color:var(--gold)}
.rt-line{flex:1;height:1.5px;background:var(--rule);margin-top:-17px;transition:background 0.4s}
.rt-line.done{background:var(--gold)}

/* Score Card */
.score-card{background:var(--ink2);border-radius:var(--radius);padding:16px 18px;display:none;position:relative;overflow:hidden}
.score-card.vis{display:block}
.score-card::before{content:'';position:absolute;top:-20px;right:-20px;width:80px;height:80px;border-radius:50%;background:radial-gradient(circle,rgba(196,154,40,0.12) 0%,transparent 70%);pointer-events:none}
.sc-row{display:flex;align-items:flex-end;gap:0;justify-content:center;margin-bottom:6px}
.sc-num{font-family:'Playfair Display',serif;font-size:44px;font-weight:900;line-height:1;transition:all 0.6s}
.sc-orig{color:#f09090}
.sc-arr{font-size:20px;color:rgba(232,208,138,0.5);margin:0 10px;padding-bottom:6px}
.sc-rev{color:#88d888}
.sc-delta{font-family:'Playfair Display',serif;font-size:14px;font-weight:900;padding:3px 10px;border-radius:20px;margin-left:8px;padding-bottom:6px;align-self:flex-end}
.sc-delta.pos{color:#70d070;background:rgba(70,160,74,0.15);border:1px solid rgba(70,160,74,0.25)}
.sc-delta.neg{color:#e07575;background:rgba(224,117,117,0.12)}
.sc-bars{display:flex;gap:10px;margin:8px 0}
.sc-bar-w{flex:1;height:3px;background:rgba(255,255,255,0.12);border-radius:2px;overflow:hidden}
.sc-bar-f{height:100%;border-radius:2px;transition:width 1s cubic-bezier(0.34,1.56,0.64,1)}
.bar-o{background:linear-gradient(90deg,#d06060,#f09090)}
.bar-r{background:linear-gradient(90deg,#4aa84e,#88d888)}
.sc-labs{display:flex;justify-content:space-between;font-size:9px;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;color:rgba(232,208,138,0.55)}
.sc-wc{margin-top:8px;padding-top:8px;border-top:1px solid rgba(232,208,138,0.12);display:flex;align-items:center;justify-content:center;gap:8px;font-size:10px;color:rgba(232,208,138,0.7)}
.sc-wc-delta{font-family:'Playfair Display',serif;font-size:12px;font-weight:900;padding:1px 7px;border-radius:12px}
.sc-wc-delta.cut{color:#88d888;background:rgba(70,160,74,0.2)}
.sc-wc-delta.grew{color:#f0a0a0;background:rgba(224,117,117,0.15)}
.sc-wc-delta.same{color:rgba(232,208,138,0.6)}
.sc-dims{display:grid;grid-template-columns:1fr 1fr;gap:6px 12px;margin-top:10px;padding-top:10px;border-top:1px solid rgba(232,208,138,0.12)}
.sc-dim{display:flex;align-items:center;justify-content:space-between;gap:6px}
.sc-dim-lbl{font-size:8px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:rgba(232,208,138,0.6)}
.sc-dim-val{font-family:'Playfair Display',serif;font-size:14px;font-weight:900;transition:color 0.4s}

/* Editorial Impact Module */
.ei{background:var(--cream2);border-bottom:1.5px solid var(--rule);display:none;flex-shrink:0;animation:ei-in 0.3s ease}
.ei.vis{display:block}
@keyframes ei-in{from{opacity:0}to{opacity:1}}
/* Slim bar (default / collapsed state) */
.ei-slim{display:flex;align-items:center;gap:14px;padding:8px 22px;cursor:pointer;transition:background 0.15s;overflow:hidden}
.ei-slim:hover{background:rgba(196,154,40,0.04)}
.ei-slim-title{font-family:'Playfair Display',serif;font-size:11px;font-weight:900;color:var(--ink);white-space:nowrap;flex-shrink:0}
.ei-slim-stats{display:flex;align-items:center;gap:10px;flex:1;overflow:hidden;min-width:0}
.ei-pill{font-size:9px;font-weight:600;color:var(--muted);white-space:nowrap;display:flex;align-items:center;gap:3px}
.ei-pill-val{font-family:'JetBrains Mono',monospace;font-size:9px;font-weight:700;padding:1px 5px;border-radius:10px}
.ei-pill-pos{color:var(--green2);background:var(--green-bg);border:1px solid var(--green-border)}
.ei-pill-neg{color:var(--red);background:var(--red-bg);border:1px solid var(--red-border)}
.ei-pill-neutral{color:var(--muted);background:var(--cream);border:1px solid var(--rule)}
.ei-slim-gain{font-size:9px;color:var(--muted);font-style:italic;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}
.ei-slim-toggle{font-size:8px;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;color:var(--muted);background:none;border:1px solid var(--rule);border-radius:12px;padding:2px 8px;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:all 0.15s}
.ei-slim-toggle:hover{color:var(--gold);border-color:var(--gold)}
/* Expanded state */
.ei-expanded{display:none;padding:0 22px 14px}
.ei.open .ei-expanded{display:block}
.ei.open .ei-slim{border-bottom:1px solid var(--rule);margin-bottom:0}
.ei-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin:14px 0 12px}
.ei-stat{background:#fff;border:1.5px solid var(--rule);border-radius:8px;padding:12px 14px;box-shadow:var(--shadow-sm);text-align:center;transition:all 0.2s}
.ei-stat:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}
.ei-stat-lbl{font-size:8px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:var(--muted);margin-bottom:6px}
.ei-stat-vals{display:flex;align-items:baseline;justify-content:center;gap:5px;margin-bottom:3px}
.ei-stat-from{font-family:'Playfair Display',serif;font-size:16px;font-weight:900;color:var(--muted);opacity:0.45}
.ei-stat-arrow{font-size:10px;color:var(--rule2)}
.ei-stat-to{font-family:'Playfair Display',serif;font-size:20px;font-weight:900;color:var(--ink)}
.ei-stat-delta{font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:600;padding:1px 6px;border-radius:12px;display:inline-block;margin-bottom:4px}
.ei-delta-pos{color:var(--green2);background:var(--green-bg);border:1px solid var(--green-border)}
.ei-delta-neg{color:var(--red);background:var(--red-bg);border:1px solid var(--red-border)}
.ei-delta-neutral{color:var(--muted);background:var(--cream);border:1px solid var(--rule)}
.ei-stat-interp{font-size:9px;color:var(--muted);line-height:1.35;font-style:italic}
.ei-gain{background:var(--ink2);border-radius:7px;padding:10px 16px;display:flex;align-items:flex-start;gap:10px}
.ei-gain-lbl{font-size:8px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:var(--gold);white-space:nowrap;padding-top:1px}
.ei-gain-txt{font-size:12px;color:rgba(232,208,138,0.75);line-height:1.45;font-style:italic}
@media(max-width:900px){.ei-grid{grid-template-columns:1fr 1fr}}

/* Impact */
.impact-list{display:none;flex-direction:column;gap:6px}
.impact-list.vis{display:flex}
.ic{background:#fff;border:1px solid var(--rule);border-left:3px solid var(--gold);border-radius:5px;padding:9px 11px;transition:all 0.15s;cursor:default}
.ic:hover{box-shadow:var(--shadow-sm);border-color:var(--rule2)}
.ic-rank{font-size:8px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:var(--gold);margin-bottom:1px}
.ic-title{font-size:11px;font-weight:700;color:var(--ink);margin-bottom:1px}
.ic-desc{font-size:10px;color:var(--muted);line-height:1.4}
.ic-eff{display:inline-block;font-size:8px;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;padding:1px 6px;border-radius:20px;margin-top:4px;background:var(--green);color:#fff}

/* Error */
.err{background:var(--red-bg);border:1px solid var(--red-border);border-radius:5px;padding:9px 11px;font-size:11px;color:var(--red);margin-top:6px;display:none}
.err.vis{display:block}
.ingest-err{margin-top:8px}

/* ═══ MAIN ═══ */
.main{display:flex;flex-direction:column;overflow:hidden;min-height:0}

/* Tab Bar */
.tab-bar{background:var(--cream2);border-bottom:1.5px solid var(--rule);display:flex;align-items:center;flex-shrink:0;padding:0 8px;gap:0;overflow-x:auto;scrollbar-width:none}
.tab-bar::-webkit-scrollbar{display:none}
.tab-btn{font-family:'DM Sans',sans-serif;font-size:10px;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;padding:14px 16px;cursor:pointer;border:none;background:transparent;color:var(--muted);border-bottom:2px solid transparent;transition:all 0.18s;white-space:nowrap;display:flex;align-items:center;gap:6px;margin-bottom:-1.5px}
.tab-btn:hover{color:var(--ink)}
.tab-btn.active{color:var(--gold);border-bottom-color:var(--gold)}
.tab-btn .t-ico{font-size:13px;line-height:1}
.tab-badge{font-size:8px;font-weight:700;padding:1px 5px;border-radius:20px;background:var(--rule);color:var(--muted);transition:all 0.25s;letter-spacing:0.05em}
.tab-badge.ready{background:var(--green);color:#fff}
.tab-badge.live{background:var(--blue);color:#fff}
.tab-badge.lock{background:var(--amber-bg);color:var(--amber)}

/* Empty State */
.empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:60px;text-align:center}
.empty-glyph{font-size:52px;opacity:0.15;font-family:'Playfair Display',serif;font-weight:900;color:var(--ink)}
.empty-title{font-family:'Playfair Display',serif;font-size:22px;font-weight:900;color:var(--cream3)}
.empty-sub{font-size:12px;color:var(--cream3);max-width:300px;line-height:1.7;opacity:0.7}
.empty-steps{display:flex;flex-direction:column;gap:6px;text-align:left;margin-top:4px;max-width:260px}
.empty-step{display:flex;align-items:center;gap:8px;font-size:11px;color:var(--cream3);opacity:0.6}
.es-num{width:18px;height:18px;border-radius:50%;background:var(--rule);color:var(--muted);display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;flex-shrink:0}

/* Panels */
.tab-panel{display:none;flex:1;overflow:hidden;flex-direction:column;min-height:0}
.tab-panel.active{display:flex}
.panel-scroll{flex:1;overflow-y:auto;padding:28px 32px 60px}
.panel-scroll::-webkit-scrollbar{width:4px}
.panel-scroll::-webkit-scrollbar-thumb{background:var(--rule);border-radius:2px}

/* Rewrite panel */
.rw-bar{background:var(--cream2);border-bottom:1.5px solid var(--rule);padding:10px 22px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0;gap:12px}
.rw-bar-l{font-size:10px;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;color:var(--muted)}
.legend{display:flex;gap:12px}
.leg{display:flex;align-items:center;gap:4px;font-size:9px;color:var(--muted)}
.leg-d{width:8px;height:8px;border-radius:2px;flex-shrink:0}
.d-same{background:transparent;border:1.5px solid var(--rule)}
.d-chg{background:var(--amber-bg);border:1.5px solid var(--amber-border)}
.d-add{background:var(--green-bg);border:1.5px solid var(--green-border)}
.rw-copy-btn{font-size:9px;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;padding:4px 10px;border-radius:20px;border:1px solid var(--rule);background:#fff;color:var(--muted);cursor:pointer;transition:all 0.15s}
.rw-copy-btn:hover{border-color:var(--gold);color:var(--gold)}

.compare{display:grid;grid-template-columns:1fr 1fr;flex:1;overflow:hidden;min-height:0}
.col{display:flex;flex-direction:column;overflow:hidden}
.col-head{padding:10px 20px 8px;border-bottom:1.5px solid var(--rule);background:var(--cream);flex-shrink:0;display:flex;align-items:center;justify-content:space-between}
.col:first-child{border-right:1px solid var(--rule)}
.col-lbl{font-size:9px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:var(--muted)}
.col-scroll{overflow-y:auto;padding:20px 20px 60px;flex:1}
.col-scroll::-webkit-scrollbar{width:3px}
.col-scroll::-webkit-scrollbar-thumb{background:var(--rule);border-radius:2px}

.para-blk{margin-bottom:16px;transition:opacity 0.3s,transform 0.3s}
.para-blk.dimmed{opacity:0.15;transform:scale(0.99)}
.para-num{font-size:8px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:var(--muted);opacity:0.5;margin-bottom:3px;display:flex;align-items:center;gap:6px}
.cf-badge{background:var(--green2);color:#fff;font-size:8px;font-weight:700;letter-spacing:0.06em;padding:1px 5px;border-radius:20px}
.para-txt{padding:9px 12px;border-radius:4px;border-left:3px solid var(--rule);font-size:13px;line-height:1.7;transition:all 0.2s}
.para-txt.chg{border-left-color:var(--amber);background:var(--amber-bg)}
.para-txt.add{border-left-color:var(--green2);background:var(--green-bg)}
.para-reason{font-size:10px;color:var(--muted);font-style:italic;margin-top:3px;padding-left:14px;line-height:1.45}
.et-badge{font-size:7px;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;padding:1px 6px;border-radius:20px;border:1px solid;display:inline-flex;margin-left:4px}
.et-line{background:rgba(21,88,168,0.08);color:var(--blue);border-color:var(--blue-border)}
.et-structural{background:rgba(196,154,40,0.1);color:var(--gold);border-color:rgba(196,154,40,0.25)}
.et-argument{background:rgba(106,27,154,0.08);color:var(--purple);border-color:var(--purple-border)}
.et-standards{background:rgba(181,34,34,0.08);color:var(--red);border-color:var(--red-border)}
.sc-verdict{margin-top:10px;padding-top:10px;border-top:1px solid rgba(232,208,138,0.08)}
.sc-verdict-lbl{font-size:8px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;margin-bottom:4px}
.sc-verdict-lbl.pub-perfect{color:#88d888}
.sc-verdict-lbl.has-movement{color:var(--gold2)}
.sc-verdict-summary{font-size:10px;color:rgba(232,208,138,0.75);line-height:1.4;margin-bottom:6px}
.sc-breakdown{display:flex;gap:6px;flex-wrap:wrap}
.sc-brk{font-size:8px;font-weight:700;letter-spacing:0.06em;padding:1px 6px;border-radius:12px;border:1px solid rgba(232,208,138,0.18);color:rgba(232,208,138,0.55)}
.sc-brk.has{color:rgba(232,208,138,0.9);border-color:rgba(232,208,138,0.35)}
.hed-blk{padding:12px 13px;border-radius:5px;border-left:3px solid var(--rule);margin-bottom:18px;transition:all 0.2s}
.hed-blk.chg{border-left-color:var(--amber);background:var(--amber-bg)}
.hed-blk.add{border-left-color:var(--green2);background:var(--green-bg)}
.hed-txt{font-family:'Playfair Display',serif;font-size:18px;font-weight:900;line-height:1.25;margin-bottom:4px}
.hed-sub{font-size:11px;color:var(--muted);font-style:italic}
/* Headline states */
.hed-blk.pending-review::after{content:'●';font-size:6px;color:var(--amber);position:absolute;top:14px;right:14px}
.hed-blk{position:relative}
.hed-blk.decided-accept{border-left-color:var(--rule);background:transparent}
.hed-blk.decided-accept ins{color:var(--ink);background:transparent;font-weight:900}
.hed-blk.decided-reject{opacity:0.2;border-left-color:var(--red)}
.hed-blk.decided-reject .hed-txt{text-decoration:line-through;text-decoration-color:var(--red)}

/* Loading skeleton */
.skel-line{height:13px;border-radius:4px;background:linear-gradient(90deg,var(--rule) 25%,var(--cream3) 50%,var(--rule) 75%);background-size:200% 100%;animation:shimmer 1.4s infinite;margin-bottom:8px}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* Headlines Panel */
.hl-grid{display:flex;flex-direction:column;gap:12px}
.hl-card{background:#fff;border:1.5px solid var(--rule);border-radius:9px;overflow:hidden;transition:all 0.18s;cursor:pointer}
.hl-card:hover{border-color:var(--gold);box-shadow:var(--shadow-md);transform:translateY(-2px)}
.hl-card.winner{border-color:var(--gold);background:#fffcf2;box-shadow:0 0 0 3px var(--gold-glow)}
.hl-card-inner{padding:16px 18px;display:flex;gap:14px;align-items:flex-start}
.hl-num{font-family:'Playfair Display',serif;font-size:30px;font-weight:900;color:var(--rule);line-height:1;width:32px;flex-shrink:0;text-align:right;transition:color 0.2s}
.hl-card.winner .hl-num{color:var(--gold)}
.hl-body{flex:1}
.hl-text{font-family:'Playfair Display',serif;font-size:17px;font-weight:700;line-height:1.3;margin-bottom:5px}
.hl-subhed{font-size:11px;color:var(--muted);margin-bottom:8px;font-style:italic}
.hl-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.hl-score{font-family:'Playfair Display',serif;font-size:24px;font-weight:900}
.hl-score-lbl{font-size:8px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:var(--muted)}
.hl-angle{font-size:9px;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;padding:2px 8px;border-radius:20px;background:var(--cream2);color:var(--muted);border:1px solid var(--rule)}
.hl-why{font-size:10px;color:var(--muted);font-style:italic;flex:1}
.hl-use{font-size:9px;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;padding:4px 10px;border-radius:20px;border:1px solid var(--gold);background:transparent;color:var(--gold);cursor:pointer;transition:all 0.18s;white-space:nowrap}
.hl-use:hover{background:var(--gold);color:var(--ink)}
.hl-bar{height:3px;background:linear-gradient(90deg,var(--gold),var(--gold2));transition:width 0.8s ease}

/* Structural Review */
.kyd-intro{background:var(--ink2);border-radius:9px;padding:16px 18px;margin-bottom:20px}
.kyd-intro-txt{font-size:13px;color:rgba(240,235,226,0.7);line-height:1.6}
.kyd-intro-txt strong{color:var(--gold2)}
.kyd-card{background:#fff;border:1.5px solid var(--rule);border-radius:9px;overflow:hidden;margin-bottom:14px;box-shadow:var(--shadow-sm)}
.kyd-top{background:linear-gradient(135deg,#fff5f5,#fff0f0);border-bottom:1px solid var(--red-border);padding:14px 18px;display:flex;gap:13px;align-items:flex-start}
.kyd-badge{flex-shrink:0;padding-top:2px}
.kyd-sev{font-size:8px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;padding:3px 8px;border-radius:20px}
.sev-h{background:var(--red-bg);color:var(--red);border:1px solid var(--red-border)}
.sev-m{background:var(--amber-bg);color:var(--amber);border:1px solid var(--amber-border)}
.kyd-quote{font-family:'Playfair Display',serif;font-size:15px;font-weight:700;font-style:italic;color:var(--ink);line-height:1.4;flex:1}
.kyd-body{padding:14px 18px;display:flex;flex-direction:column;gap:8px}
.kyd-row{font-size:12px;line-height:1.5}
.kyd-row strong{color:var(--ink);font-weight:700}
.kyd-fix{font-size:12px;color:var(--green2);font-weight:600;display:flex;align-items:flex-start;gap:5px}
.kyd-fix::before{content:'→';font-family:'Playfair Display',serif;font-weight:900;flex-shrink:0}

/* Readability Panel */
.read-dash{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px;margin-bottom:20px}
.read-met{background:#fff;border:1.5px solid var(--rule);border-radius:9px;padding:18px 16px;text-align:center;box-shadow:var(--shadow-sm);transition:all 0.3s}
.rm-num{font-family:'Playfair Display',serif;font-size:38px;font-weight:900;line-height:1;margin-bottom:4px;transition:color 0.4s}
.rm-lbl{font-size:9px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:var(--muted)}
.rm-sub{font-size:10px;color:var(--muted);margin-top:3px}
.read-bar-row{display:flex;align-items:center;gap:10px;margin-bottom:9px}
.rbar-lbl{font-size:10px;font-weight:600;color:var(--muted);width:96px;flex-shrink:0}
.rbar-bg{flex:1;height:7px;background:var(--rule);border-radius:4px;overflow:hidden}
.rbar-fill{height:100%;border-radius:4px;transition:width 0.6s ease}
.rbar-cnt{font-size:10px;font-weight:600;color:var(--muted);width:24px;text-align:right}
.bench-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:16px}
.bench-item{background:#fff;border:1.5px solid var(--rule);border-radius:7px;padding:10px 13px;display:flex;align-items:center;gap:10px;box-shadow:var(--shadow-sm)}
.bench-ico{font-size:18px}
.bench-info{flex:1}
.bench-name{font-size:11px;font-weight:700;color:var(--ink)}
.bench-grade{font-size:9px;color:var(--muted)}
.bench-diff{font-family:'Playfair Display',serif;font-size:18px;font-weight:900}
.bd-above{color:var(--red)}
.bd-below{color:var(--green2)}
.bd-match{color:var(--amber)}

/* Verification Panel */
.fc-intro{background:var(--blue-bg);border:1px solid var(--blue-border);border-radius:9px;padding:14px 16px;margin-bottom:18px;font-size:12px;color:var(--blue);line-height:1.55}
.fc-intro strong{font-weight:700}
.fc-empty{text-align:center;padding:36px 28px 44px;max-width:420px;margin:0 auto}
.fc-empty-title{font-family:'Playfair Display',serif;font-size:17px;font-weight:700;color:var(--ink);margin-bottom:10px}
.fc-empty-sub{font-size:12px;color:var(--muted);line-height:1.6;margin-bottom:18px;text-align:left}
.fc-empty-rerun{margin-top:4px}
.fc-empty-debug{font-size:10px;color:var(--muted);margin-top:20px;text-align:left;opacity:0.85}
.fc-empty-debug code{font-family:'JetBrains Mono',monospace;font-size:9px}
.claims-list{display:flex;flex-direction:column;gap:10px}
.claim-card{background:#fff;border:1.5px solid var(--rule);border-radius:7px;overflow:hidden;box-shadow:var(--shadow-sm)}
.claim-top{padding:12px 15px;display:flex;align-items:flex-start;gap:11px}
.claim-status{flex-shrink:0;margin-top:1px}
.claim-icon{font-size:18px;line-height:1}
.claim-text{font-size:13px;color:var(--ink);flex:1;font-weight:500;line-height:1.5}
.claim-body{padding:8px 15px 12px;border-top:1px solid var(--rule);display:flex;flex-direction:column;gap:4px}
.claim-verdict{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:0.08em}
.cv-verified{color:var(--green2)}
.cv-unverified{color:var(--amber)}
.cv-contradicted{color:var(--red)}
.claim-note{font-size:11px;color:var(--muted);line-height:1.5}
.claim-source{font-size:10px;color:var(--blue);font-style:italic}

/* Field Intelligence Panel */
.ce-section{margin-bottom:28px}
.ce-section-title{font-family:'Playfair Display',serif;font-size:16px;font-weight:700;margin-bottom:4px}
.ce-section-sub{font-size:12px;color:var(--muted);margin-bottom:16px}
.kw-opp{background:#fff;border:1.5px solid var(--rule);border-radius:9px;padding:18px;box-shadow:var(--shadow-sm);margin-bottom:12px}
.kw-primary{font-family:'Playfair Display',serif;font-size:20px;font-weight:900;color:var(--ink);margin-bottom:4px}
.kw-volume{font-size:11px;color:var(--muted);margin-bottom:10px}
.kw-action{font-size:12px;color:var(--green2);font-weight:600;line-height:1.5}
.gap-card{background:#fff;border:1.5px solid var(--rule);border-radius:9px;overflow:hidden;box-shadow:var(--shadow-sm);margin-bottom:10px}
.gap-head{background:var(--ink2);padding:12px 16px;display:flex;align-items:center;justify-content:space-between}
.gap-head-lbl{font-size:9px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:var(--gold2)}
.gap-urgency{font-size:9px;font-weight:700;letter-spacing:0.06em;padding:2px 8px;border-radius:20px}
.gu-high{background:rgba(196,154,40,0.2);color:var(--gold2)}
.gu-med{background:rgba(255,255,255,0.1);color:rgba(232,208,138,0.7)}
.gap-body{padding:14px 16px}
.gap-angle{font-family:'Playfair Display',serif;font-size:15px;font-weight:700;margin-bottom:6px;line-height:1.3}
.gap-why{font-size:12px;color:var(--muted);line-height:1.55}
.gap-tweak{background:var(--green-bg);border:1px solid var(--green-border);border-radius:5px;padding:8px 11px;font-size:11px;color:var(--green);font-weight:600;margin-top:8px}
.gap-tweak::before{content:'One tweak: ';font-weight:700}

/* Competitor URL inputs */
.comp-urls{display:flex;flex-direction:column;gap:7px;margin-bottom:14px}
.comp-url-row{display:flex;gap:7px}
.comp-url-inp{flex:1;background:#fff;border:1.5px solid var(--rule);border-radius:var(--radius);padding:8px 11px;font-family:'DM Sans',sans-serif;font-size:12px;color:var(--ink);outline:none;transition:border-color 0.2s}
.comp-url-inp:focus{border-color:var(--gold)}
.comp-url-inp::placeholder{color:var(--muted);opacity:0.4}

/* FC required overlay */
.fc-lock{text-align:center;padding:60px 40px;display:flex;flex-direction:column;align-items:center;gap:12px}
.fc-lock-ico{font-size:36px;opacity:0.3}
.fc-lock-title{font-family:'Playfair Display',serif;font-size:18px;font-weight:700;color:var(--ink);opacity:0.5}
.fc-lock-sub{font-size:12px;color:var(--muted);max-width:280px;line-height:1.6;text-align:center}
.fc-lock-badge{display:inline-flex;align-items:center;gap:5px;background:var(--amber-bg);border:1px solid var(--amber-border);border-radius:20px;padding:4px 12px;font-size:10px;font-weight:700;color:var(--amber);letter-spacing:0.06em;text-transform:uppercase;margin-top:4px}

/* Run feature button */
.run-feat-wrap{text-align:center;padding:40px 30px}
.run-feat-wrap p{font-size:12px;color:var(--muted);margin-top:10px;line-height:1.55;max-width:320px;margin-left:auto;margin-right:auto}
.btn-feature{display:inline-flex;align-items:center;gap:8px;background:var(--ink2);color:var(--gold2);border:none;border-radius:var(--radius);padding:13px 24px;font-family:'Playfair Display',serif;font-size:14px;font-weight:700;cursor:pointer;transition:all 0.2s}
.btn-feature:hover{background:var(--ink3);transform:translateY(-1px);box-shadow:var(--shadow-md)}
.btn-feature:disabled{opacity:0.45;cursor:not-allowed;transform:none}
.btn-feature .sp{width:14px;height:14px;border:2px solid rgba(232,208,138,0.2);border-top-color:var(--gold2);border-radius:50%;animation:spin 0.7s linear infinite;display:none}
.btn-feature.busy .sp{display:block}
.btn-feature.busy .bt{opacity:0.6}
.fc-pow{display:inline-flex;align-items:center;gap:4px;font-size:8px;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;padding:2px 7px;border-radius:20px;background:var(--amber-bg);color:var(--amber);border:1px solid var(--amber-border)}

/* Loading state */
.loading-state{padding:40px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:12px}
.loading-ring{width:36px;height:36px;border:3px solid var(--rule);border-top-color:var(--gold);border-radius:50%;animation:spin 0.9s linear infinite}
.loading-msg{font-size:13px;color:var(--muted);font-style:italic}

/* Toast */
.toast-container{position:fixed;bottom:24px;right:24px;display:flex;flex-direction:column;gap:8px;z-index:9999;pointer-events:none}
.toast{background:var(--ink2);color:var(--gold2);border:1px solid var(--gold);border-radius:6px;padding:10px 16px;font-size:12px;font-weight:600;letter-spacing:0.04em;box-shadow:var(--shadow-lg);animation:toast-in 0.3s ease,toast-out 0.3s ease 2.2s forwards;pointer-events:none;max-width:280px}
@keyframes toast-in{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
@keyframes toast-out{from{opacity:1;transform:none}to{opacity:0;transform:translateY(8px)}}

/* Panel head + actions */
.panel-head{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:6px;gap:12px}
.panel-title{font-family:'Playfair Display',serif;font-size:20px;font-weight:900}
.panel-sub{font-size:12px;color:var(--muted);margin-bottom:22px;line-height:1.55}
.section-card{background:#fff;border:1.5px solid var(--rule);border-radius:9px;padding:18px 20px;box-shadow:var(--shadow-sm);margin-bottom:16px}
.section-card-title{font-size:10px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:var(--muted);margin-bottom:12px}

/* Misc */
ins{color:var(--green2);text-decoration:none;font-weight:600}
del{color:var(--red);opacity:0.65}
.divider{height:1px;background:var(--rule);margin:20px 0}


/* ═══ ACCEPT / REJECT + WORD DIFF ═══ */
.para-ar{display:flex;gap:5px;margin-top:7px;padding-left:2px}
.ar-btn{font-size:9px;font-weight:700;letter-spacing:0.06em;padding:3px 11px;border-radius:20px;border:1.5px solid var(--rule);background:#fff;cursor:pointer;transition:all 0.25s;color:var(--muted);line-height:1.6}
.ar-btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-sm)}
.ar-btn.acc{border-color:var(--green-border);color:var(--green2);background:var(--green-bg)}
.ar-btn.acc.active{background:var(--green2);color:#fff;border-color:var(--green2);box-shadow:0 2px 8px rgba(42,110,47,0.3);transform:scale(1.05)}
.ar-btn.rej{border-color:var(--red-border);color:var(--red);background:var(--red-bg)}
.ar-btn.rej.active{background:var(--red);color:#fff;border-color:var(--red);box-shadow:0 2px 8px rgba(181,34,34,0.3);transform:scale(1.05)}
/* Pending — tiny amber dot, paragraph looks untouched */
.para-blk.pending-review .para-num::after{content:'●';font-size:6px;color:var(--amber);margin-left:5px;vertical-align:middle}
/* Accepted — paragraph calms down to neutral, feels settled and done */
.para-blk.decided-accept .para-txt{border-left-color:var(--rule);background:transparent;transition:all 0.4s}
.para-blk.decided-accept .para-txt ins{color:var(--ink);background:transparent;font-weight:500}
.para-blk.decided-accept .para-ar .ar-btn.acc{background:var(--green2);color:#fff;border-color:var(--green2)}
/* Rejected — faded, clear revert */
.para-blk.decided-reject .para-txt{opacity:0.2;text-decoration:line-through;text-decoration-color:var(--red);border-left-color:var(--red);transition:all 0.4s}
.para-blk.decided-reject .para-reason{display:none}
.para-blk.decided-reject .para-ar .ar-btn.rej{background:var(--red);color:#fff;border-color:var(--red)}
del{color:var(--red);background:rgba(181,34,34,0.07);border-radius:2px;text-decoration:line-through;padding:0 1px}
ins{color:var(--green2);background:rgba(42,110,47,0.07);border-radius:2px;text-decoration:none;font-weight:600;padding:0 1px}

/* ═══ FINALISE BUTTON ═══ */
.finalise-bar{display:none;align-items:center;padding:6px 22px;border-bottom:1px solid var(--rule);background:var(--cream2);flex-shrink:0}
.finalise-bar.vis{display:flex}
.finalise-bar-center{flex:1;display:flex;justify-content:center}
.finalise-btn{background:var(--ink2);color:var(--gold2);border:2px solid var(--gold);border-radius:26px;padding:8px 26px;font-family:'Playfair Display',serif;font-size:14px;font-weight:900;cursor:pointer;letter-spacing:0.03em;box-shadow:var(--shadow-md);transition:all 0.25s;display:flex;align-items:center;gap:9px;animation:finalise-glow 1.05s ease infinite;white-space:nowrap}
.finalise-btn:hover{background:var(--ink3);transform:scale(1.03);box-shadow:var(--shadow-lg),0 0 30px rgba(196,154,40,0.35);animation:none}
@keyframes finalise-glow{0%,100%{box-shadow:var(--shadow-md),0 0 12px rgba(196,154,40,0.12);border-color:rgba(196,154,40,0.5)}50%{box-shadow:var(--shadow-md),0 0 28px rgba(196,154,40,0.4);border-color:var(--gold2)}}
.finalise-count{font-family:'JetBrains Mono',monospace;font-size:11px;font-weight:600;background:rgba(196,154,40,0.2);padding:2px 9px;border-radius:12px;color:var(--gold2)}

/* ═══ FINALISE PANEL ═══ */
.final-overlay{position:fixed;inset:0;z-index:180;background:rgba(23,18,14,0.6);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity 0.3s}
.final-overlay.vis{opacity:1;pointer-events:all}
.final-card{background:var(--cream);border-radius:12px;width:720px;max-width:90vw;max-height:92vh;box-shadow:var(--shadow-lg);border:1.5px solid var(--rule);display:flex;flex-direction:column;overflow:hidden}
.final-top{background:var(--ink2);padding:18px 24px;border-bottom:2px solid var(--gold);display:flex;align-items:center;justify-content:space-between}
.final-title{font-family:'Playfair Display',serif;font-size:16px;font-weight:900;color:var(--gold2)}
.final-meta{font-size:10px;color:rgba(232,208,138,0.4)}
.final-actions{display:flex;gap:8px}
.final-btn{font-size:10px;font-weight:700;letter-spacing:0.06em;padding:6px 14px;border-radius:20px;border:1px solid;cursor:pointer;transition:all 0.15s}
.final-btn-copy{background:var(--gold);color:var(--ink2);border-color:var(--gold)}
.final-btn-copy:hover{background:var(--gold2);transform:translateY(-1px)}
.final-btn-export{background:transparent;color:var(--gold2);border-color:rgba(232,208,138,0.25)}
.final-btn-export:hover{border-color:var(--gold2)}
.final-btn-close{background:transparent;color:rgba(232,208,138,0.4);border-color:rgba(232,208,138,0.15)}
.final-btn-close:hover{color:var(--gold2);border-color:rgba(232,208,138,0.3)}
.final-body{flex:1;overflow-y:auto;padding:28px 32px 40px}
.final-body::-webkit-scrollbar{width:4px}
.final-body::-webkit-scrollbar-thumb{background:var(--rule);border-radius:2px}
.final-text{font-family:'DM Sans',sans-serif;font-size:15px;line-height:1.8;color:var(--ink);white-space:pre-wrap}
.final-text h1{font-family:'Playfair Display',serif;font-size:24px;font-weight:900;line-height:1.25;margin-bottom:6px}
.final-text .final-subhed{font-size:14px;color:var(--muted);font-style:italic;margin-bottom:24px}
.final-text p{margin-bottom:16px}
.final-text h3.final-section{font-family:'DM Sans',sans-serif;font-size:13px;font-weight:700;letter-spacing:0.04em;text-transform:uppercase;color:var(--muted);margin:28px 0 8px;padding-bottom:6px;border-bottom:1px solid var(--rule)}
.final-text strong{font-weight:700;color:var(--ink)}
.final-text em{font-style:italic}

/* ═══ SYNC SCROLL LOCK ═══ */
.sync-btn{font-size:9px;font-weight:700;letter-spacing:0.06em;padding:3px 9px 3px 7px;border-radius:20px;border:1.5px solid var(--rule);background:#fff;cursor:pointer;color:var(--muted);display:flex;align-items:center;gap:4px;transition:all 0.15s;white-space:nowrap}
.sync-btn:hover{border-color:var(--gold);color:var(--gold)}
.sync-btn.locked{border-color:var(--gold);color:var(--gold);background:#fffbf0}
.sync-icon{font-size:11px;line-height:1}

/* ═══ EXPORT BUTTON ═══ */
.export-btn{font-size:9px;font-weight:700;letter-spacing:0.06em;padding:4px 10px;border-radius:20px;border:1px solid var(--rule);background:#fff;color:var(--muted);cursor:pointer;transition:all 0.15s}
.export-btn:hover{border-color:var(--gold);color:var(--gold)}

/* ═══ INLINE EDIT SURFACE ═══ */
.es-inline{display:flex;align-items:center;gap:5px;border-left:1px solid var(--rule);padding-left:10px;margin-left:2px}
.es-lbl{font-size:8px;font-weight:700;letter-spacing:0.06em;text-transform:uppercase;color:var(--muted);flex-shrink:0}
.es-slider{-webkit-appearance:none;width:70px;height:3px;background:var(--rule);border-radius:2px;outline:none;flex-shrink:0}
.es-slider::-webkit-slider-thumb{-webkit-appearance:none;width:12px;height:12px;border-radius:50%;background:var(--gold);cursor:pointer;box-shadow:0 1px 3px rgba(0,0,0,0.15)}
.es-val{font-size:8px;font-weight:700;letter-spacing:0.04em;color:var(--gold);min-width:42px;text-align:center}

/* ═══ CONTENT-AWARE LOADING ANIMATIONS ═══ */
.analysis-loader{position:fixed;inset:0;z-index:200;background:rgba(23,18,14,0.55);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity 0.3s;pointer-events:none}
.analysis-loader.vis{opacity:1;pointer-events:all}
.al-card{background:var(--cream);border-radius:12px;width:480px;max-width:90vw;box-shadow:var(--shadow-lg);border:1.5px solid var(--rule);overflow:hidden}
.al-top{background:var(--ink2);padding:18px 22px;border-bottom:2px solid var(--gold)}
.al-title{font-family:'Playfair Display',serif;font-size:16px;font-weight:900;color:var(--gold2);margin-bottom:3px}
.al-subtitle{font-size:11px;color:rgba(232,208,138,0.45);letter-spacing:0.06em;text-transform:uppercase}
.al-body{padding:20px 22px;display:flex;flex-direction:column;gap:14px}
.al-step{display:flex;align-items:flex-start;gap:12px;transition:all 0.3s}
.al-step.active .al-step-icon{color:var(--gold)}
.al-step.done .al-step-icon{color:var(--green2)}
.al-step.waiting .al-step-icon{color:var(--rule2)}
.al-step-icon{font-size:18px;width:24px;flex-shrink:0;margin-top:1px;line-height:1}
.al-step-body{flex:1}
.al-step-label{font-size:13px;font-weight:600;color:var(--ink);line-height:1.3;transition:color 0.3s}
.al-step.waiting .al-step-label{color:var(--muted)}
.al-step-detail{font-size:11px;color:var(--muted);margin-top:2px;line-height:1.4;min-height:16px;transition:all 0.3s}
.al-step-bar{height:2px;background:var(--rule);border-radius:1px;margin-top:6px;overflow:hidden}
.al-step-bar-fill{height:100%;background:linear-gradient(90deg,var(--gold),var(--gold2));border-radius:1px;width:0%;transition:width 0.8s ease}
.al-step.active .al-step-bar-fill{animation:bar-pulse 1.6s ease infinite}
.al-step.done .al-step-bar-fill{width:100%!important;animation:none}
@keyframes bar-pulse{0%{width:15%}50%{width:80%}100%{width:40%}}

/* Excerpt preview */
.al-excerpt{background:var(--cream2);border:1px solid var(--rule);border-radius:6px;padding:12px 14px;margin-top:4px}
.al-excerpt-lbl{font-size:8px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:var(--muted);margin-bottom:5px}
.al-excerpt-lines{display:flex;flex-direction:column;gap:4px}
.al-line{height:8px;border-radius:4px;background:var(--rule);animation:skel-shimmer 1.4s infinite}
.al-line.short{width:45%}
.al-line.med{width:72%}
.al-line.long{width:90%}
.al-line.highlighted{background:linear-gradient(90deg,var(--amber-bg),var(--amber-border));animation:hl-pulse 1.2s ease infinite}
.al-line.improved{background:linear-gradient(90deg,var(--green-bg),var(--green-border));animation:hl-pulse 1.2s ease 0.3s infinite}
@keyframes skel-shimmer{0%{opacity:0.5}50%{opacity:1}100%{opacity:0.5}}
@keyframes hl-pulse{0%,100%{opacity:0.6}50%{opacity:1}}

/* Score reveal animation */
.al-score-preview{display:flex;align-items:center;gap:12px;margin-top:4px;padding:10px 14px;background:var(--ink2);border-radius:6px;opacity:0;transition:opacity 0.6s}
.al-score-preview.vis{opacity:1}
.al-score-num{font-family:'Playfair Display',serif;font-size:28px;font-weight:900;color:#e07575}
.al-score-arrow{color:rgba(232,208,138,0.3);font-size:16px}
.al-score-num-new{font-family:'Playfair Display',serif;font-size:28px;font-weight:900;color:#70c070}
.al-score-cap{font-size:9px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:rgba(232,208,138,0.35)}

.al-footer{padding:14px 22px;border-top:1px solid var(--rule);display:flex;align-items:center;gap:10px}
.al-progress-outer{flex:1;height:4px;background:var(--rule);border-radius:2px;overflow:hidden}
.al-progress-inner{height:100%;background:linear-gradient(90deg,var(--gold),var(--gold2));border-radius:2px;transition:width 0.6s ease}
.al-progress-pct{font-size:10px;font-weight:700;color:var(--muted);white-space:nowrap}
