*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}

:root{
  --white:#ffffff;
  --off:#f8f7f4;
  --off2:#f1ede6;
  --line:#e5e0d8;
  --line2:#d0c9be;
  --ink:#0f0e0b;
  --ink2:#3d3a34;
  --ink3:#7a746c;
  --ink4:#a8a29a;
  --accent:#1c4f3f;
  --accent-bg:#ebf3ef;
  --accent2:#9b4a1e;
  --accent2-bg:#fdf0e8;
  --amber:#a07318;
  --amber-bg:#fdf5e0;
  --blue:#1e3f78;
  --blue-bg:#edf2fc;
  --red:#b22c2c;
  --red-bg:#fdeeed;
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'Figtree',system-ui,sans-serif;
  --mono:'Martian Mono',monospace;
  --r:8px;
  --r-lg:12px;
  --shadow:0 1px 3px rgba(15,14,11,.07),0 4px 16px rgba(15,14,11,.04);
  --shadow-lg:0 2px 8px rgba(15,14,11,.08),0 16px 40px rgba(15,14,11,.06);
  --sb-w:220px;
}

body{font-family:var(--sans);background:var(--off);color:var(--ink);min-height:100vh;font-size:14px;line-height:1.6}
.app-main{background:var(--off);background-image:radial-gradient(circle at 1px 1px, rgba(15,14,11,.04) 1px, transparent 0);background-size:24px 24px;}

/* ── LOGIN WALL ── */
.login-wall{
  display:none;position:fixed;inset:0;z-index:500;
  background:var(--white);
  grid-template-columns:1fr 1fr;
}
.login-wall.show{display:grid}
.lw-left{
  background:var(--ink);
  padding:60px 56px;
  display:flex;flex-direction:column;justify-content:center;
  color:white;
}
.lw-brand{display:flex;align-items:center;gap:10px;font-family:var(--sans);font-weight:700;font-size:16px;color:white;margin-bottom:48px}
.lw-left h1{font-family:var(--serif);font-size:clamp(40px,4vw,56px);font-weight:400;line-height:1.1;letter-spacing:-.5px;color:white;margin-bottom:20px}
.lw-left h1 em{font-style:italic;color:#9fc9bc}
.lw-left p{font-size:15px;color:rgba(255,255,255,.65);line-height:1.75;max-width:420px;margin-bottom:40px;font-weight:300}
.lw-testimonials{display:flex;flex-direction:column;gap:12px}
.lw-t{font-size:13px;color:rgba(255,255,255,.5);font-style:italic}
.lw-t span{color:rgba(255,255,255,.3);font-style:normal}
.lw-right{display:flex;align-items:center;justify-content:center;padding:40px;background:var(--off)}
.lw-card{background:white;border:1px solid var(--line);border-radius:16px;padding:40px;width:100%;max-width:400px;box-shadow:var(--shadow-lg)}
.lw-card-logo{display:flex;align-items:center;gap:9px;font-family:var(--sans);font-weight:700;font-size:15px;color:var(--ink);margin-bottom:24px}
.lw-card h2{font-family:var(--serif);font-size:28px;font-weight:400;letter-spacing:-.3px;margin-bottom:8px}
.lw-card-sub{font-size:13px;color:var(--ink3);margin-bottom:24px;line-height:1.6}
.btn-google-big{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;font-family:var(--sans);font-size:14px;font-weight:500;background:white;color:var(--ink);border:1.5px solid var(--line2);padding:12px 20px;border-radius:9px;cursor:pointer;transition:all .15s;box-shadow:0 1px 3px rgba(0,0,0,.07);margin-bottom:10px}
.btn-google-big:hover{background:var(--off);transform:translateY(-1px);box-shadow:0 3px 10px rgba(0,0,0,.1)}
.lw-divider{text-align:center;font-size:12px;color:var(--ink4);margin:8px 0;position:relative}
.lw-divider::before,.lw-divider::after{content:'';position:absolute;top:50%;width:42%;height:1px;background:var(--line)}
.lw-divider::before{left:0}.lw-divider::after{right:0}
.lw-skip{width:100%;background:none;border:1px solid var(--line);font-family:var(--sans);font-size:13px;color:var(--ink3);padding:10px;border-radius:7px;cursor:pointer;transition:all .15s;margin-bottom:20px}
.lw-skip:hover{background:var(--off);color:var(--ink)}
.lw-perks{display:grid;grid-template-columns:1fr 1fr;gap:7px;border-top:1px solid var(--line);padding-top:18px}
.lw-perk{font-size:12px;color:var(--ink2);display:flex;align-items:center;gap:6px}
.lw-check{color:var(--accent);font-weight:600}

/* ── APP SHELL ── */
.app-shell{display:block;min-height:100vh}

/* ── SIDEBAR ── */
.sidebar{
  width:var(--sb-w);position:fixed;top:0;left:0;bottom:0;
  background:var(--white);border-right:1px solid var(--line);
  display:flex;flex-direction:column;z-index:100;
}
.sb-top{flex:1;padding:20px 12px;display:flex;flex-direction:column;gap:0}
.sb-logo{display:flex;align-items:center;gap:9px;font-family:var(--sans);font-weight:700;font-size:15px;color:var(--ink);padding:8px 8px 20px;border-bottom:1px solid var(--line);margin-bottom:8px}
.sb-nav{display:flex;flex-direction:column;gap:2px}
.sbnav-item{display:flex;align-items:center;gap:10px;font-family:var(--sans);font-size:13px;font-weight:400;color:var(--ink3);background:none;border:none;padding:9px 10px;border-radius:7px;cursor:pointer;transition:all .12s;text-align:left;width:100%}
.sbnav-item:hover{color:var(--ink);background:var(--off)}
.sbnav-item.active{color:var(--ink);background:var(--off2);font-weight:500}
.sbnav-divider{height:1px;background:var(--line);margin:8px 0}
.sb-bottom{padding:12px;border-top:1px solid var(--line)}
.sb-user{display:flex;align-items:center;gap:8px;padding:8px;border-radius:8px;background:var(--off)}
.sb-avatar{width:30px;height:30px;border-radius:50%;object-fit:cover;border:1.5px solid var(--line)}
.sb-user-info{flex:1;min-width:0}
.sb-user-name{display:block;font-size:12px;font-weight:500;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sb-user-plan{font-family:var(--mono);font-size:10px;color:var(--ink4);letter-spacing:.2px}
.sb-signout{background:none;border:none;color:var(--ink4);cursor:pointer;padding:3px;border-radius:4px;display:flex;align-items:center;transition:color .12s}
.sb-signout:hover{color:var(--red)}
.sb-signin-btn{display:flex;align-items:center;gap:7px;width:100%;font-family:var(--sans);font-size:12px;font-weight:500;background:var(--off);color:var(--ink);border:1px solid var(--line);padding:9px 12px;border-radius:7px;cursor:pointer;transition:all .12s}
.sb-signin-btn:hover{background:var(--off2)}

/* ── MAIN ── */
.app-main{margin-left:220px;min-height:100vh;display:flex;flex-direction:column}
.view{display:none;width:100%}
.view.active{display:flex;flex-direction:column;width:100%;min-height:100vh}
.view-inner{width:100%;padding:40px 48px 64px}
.view-header{margin-bottom:32px}
.view-header h2{font-family:var(--serif);font-size:36px;font-weight:400;letter-spacing:-.5px;margin-bottom:6px}
.view-header p{font-size:14px;color:var(--ink3);line-height:1.6}

/* ── DASHBOARD ── */
.dash-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:28px;gap:16px;flex-wrap:wrap;max-width:860px}
.dash-header h2{font-family:var(--serif);font-size:32px;font-weight:400;letter-spacing:-.3px;margin-bottom:4px}
.dash-sub{font-size:13px;color:var(--ink3)}
.dash-stats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:28px;max-width:860px}
.dstat{background:var(--white);border:1px solid var(--line);border-radius:var(--r-lg);padding:16px 18px;box-shadow:var(--shadow)}
.dstat-n{font-family:var(--serif);font-size:36px;font-weight:400;color:var(--ink);line-height:1;letter-spacing:-1px;margin-bottom:4px}
.dstat-l{font-family:var(--mono);font-size:10px;color:var(--ink4);letter-spacing:.3px;text-transform:uppercase}
.dash-section{margin-bottom:28px;max-width:860px}
.dash-section-title{font-family:var(--mono);font-size:11px;color:var(--ink4);letter-spacing:.5px;text-transform:uppercase;margin-bottom:12px}
.chart-wrap{background:var(--white);border:1px solid var(--line);border-radius:var(--r-lg);padding:20px;min-height:160px;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow);max-width:860px;width:100%}
.chart-empty{display:flex;flex-direction:column;align-items:center;gap:10px;color:var(--ink3);font-size:13px;text-align:center}
#gradeChart{width:100%!important;height:140px!important}
.dash-empty{font-size:13px;color:var(--ink3);padding:20px 0}
.inline-link{background:none;border:none;color:var(--accent);cursor:pointer;font-size:13px;text-decoration:underline;text-underline-offset:2px;font-family:var(--sans)}
.qa-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;max-width:860px}
.qa-card{background:var(--white);border:1px solid var(--line);border-radius:var(--r-lg);padding:18px;cursor:pointer;transition:all .15s;box-shadow:var(--shadow)}
.qa-card:hover{border-color:var(--line2);transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.qa-icon{font-size:22px;margin-bottom:10px}
.qa-title{font-size:13px;font-weight:600;color:var(--ink);margin-bottom:4px}
.qa-sub{font-size:12px;color:var(--ink3);line-height:1.5}
.recent-card{background:var(--white);border:1px solid var(--line);border-radius:var(--r-lg);padding:14px 18px;display:flex;align-items:center;gap:14px;cursor:pointer;transition:all .15s;box-shadow:var(--shadow);margin-bottom:8px}
.recent-card:hover{border-color:var(--line2);box-shadow:var(--shadow-lg)}
.rc-score{font-family:var(--serif);font-size:32px;font-weight:400;line-height:1;letter-spacing:-1px;width:48px;text-align:center;flex-shrink:0}
.rc-body{flex:1;min-width:0}
.rc-preview{font-size:13px;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:3px}
.rc-meta{font-family:var(--mono);font-size:10px;color:var(--ink4);letter-spacing:.2px}
.rc-chip{font-family:var(--mono);font-size:10px;font-weight:500;padding:3px 9px;border-radius:3px;letter-spacing:.4px;text-transform:uppercase;flex-shrink:0}

/* ── WRITE VIEW ── */
.write-layout{display:grid;grid-template-columns:1fr 340px;flex:1;gap:0}
.editor-col{display:flex;flex-direction:column;border-right:1px solid var(--line);background:var(--white)}
.editor-topbar{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-bottom:1px solid var(--line);background:var(--off);gap:12px;flex-wrap:wrap}
.etb-left{display:flex;align-items:center;gap:8px}
.etb-right{display:flex;align-items:center;gap:6px}

/* Subject dropdown */
.subject-dropdown-wrap{position:relative}
.subject-dropdown-btn{display:flex;align-items:center;gap:6px;font-family:var(--mono);font-size:11px;color:var(--ink);background:var(--white);border:1px solid var(--line2);padding:5px 12px;border-radius:5px;cursor:pointer;transition:all .12s;letter-spacing:.2px}
.subject-dropdown-btn:hover{border-color:var(--line2);background:var(--off)}
.subject-menu{position:absolute;top:calc(100% + 4px);left:0;background:var(--white);border:1px solid var(--line2);border-radius:var(--r);box-shadow:var(--shadow-lg);z-index:200;min-width:160px;padding:4px}
.smenu-item{display:block;width:100%;text-align:left;font-family:var(--mono);font-size:11px;color:var(--ink3);background:none;border:none;padding:7px 10px;border-radius:5px;cursor:pointer;transition:all .1s;letter-spacing:.2px}
.smenu-item:hover{background:var(--off);color:var(--ink)}
.smenu-item.on{background:var(--ink);color:white}
.level-toggle{display:flex;border:1px solid var(--line);border-radius:5px;overflow:hidden}
.ltog{font-family:var(--mono);font-size:11px;padding:5px 12px;border:none;color:var(--ink3);background:var(--white);cursor:pointer;transition:all .12s;letter-spacing:.2px}
.ltog.on{background:var(--ink);color:white}
.wc-badge{font-family:var(--mono);font-size:10px;background:var(--off2);border:1px solid var(--line);color:var(--ink3);padding:2px 8px;border-radius:3px}
.editor-chrome{flex:1;display:flex;flex-direction:column}
.essay-ta{flex:1;min-height:500px;padding:28px;font-family:var(--serif);font-size:17.5px;line-height:1.9;color:var(--ink);border:none;outline:none;resize:none;background:var(--white);width:100%}
.essay-ta::placeholder{color:var(--ink4);font-style:italic}
.editor-footer{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-top:1px solid var(--line);background:var(--off)}
.ef-left{display:flex;gap:6px}
.ef-right{display:flex;align-items:center;gap:8px}
.ec-btn{font-family:var(--mono);font-size:10px;border:1px solid var(--line);background:var(--white);color:var(--ink3);padding:5px 11px;border-radius:4px;cursor:pointer;transition:all .12s;letter-spacing:.2px}
.ec-btn:hover{border-color:var(--line2);color:var(--ink)}
.char-count{font-family:var(--mono);font-size:10px;color:var(--ink4);letter-spacing:.2px}
.run-btn{display:inline-flex;align-items:center;gap:7px;background:var(--ink);color:white;border:none;padding:9px 18px;border-radius:7px;font-family:var(--sans);font-size:13px;font-weight:600;cursor:pointer;transition:all .15s}
.run-btn:hover{background:#2a2820;transform:translateY(-1px)}
.run-btn.busy{opacity:.6;pointer-events:none}
.rl-spin{width:14px;height:14px;flex-shrink:0;display:none;animation:rot .65s linear infinite}
.run-btn.busy .rl-arrow,.run-btn.busy .rl-text{opacity:.4}
.run-btn.busy .rl-spin{display:block}
@keyframes rot{to{transform:rotate(360deg)}}

/* ANALYSIS COL */
.analysis-col{display:flex;flex-direction:column;overflow-y:auto;max-height:100vh;position:sticky;top:0}
.panel-score{background:var(--white);border-bottom:1px solid var(--line);padding:18px}
.ps-empty{display:flex;flex-direction:column;align-items:center;gap:8px;padding:12px 0;text-align:center;font-size:12px;color:var(--ink3);line-height:1.6}
.ps-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:14px}
.ps-num-wrap{display:flex;align-items:baseline;gap:3px}
.ps-num{font-family:var(--serif);font-size:56px;font-weight:300;color:var(--ink);line-height:1;letter-spacing:-2px}
.ps-denom{font-family:var(--mono);font-size:11px;color:var(--ink3)}
.ps-right{display:flex;flex-direction:column;gap:4px;text-align:right;padding-top:4px}
.ps-grade-chip{font-family:var(--mono);font-size:10px;font-weight:500;letter-spacing:.6px;text-transform:uppercase;padding:3px 9px;border-radius:3px;display:inline-block;align-self:flex-end}
.g-first{background:var(--accent-bg);color:var(--accent)}
.g-21{background:var(--blue-bg);color:var(--blue)}
.g-22{background:var(--amber-bg);color:var(--amber)}
.g-3{background:var(--red-bg);color:var(--red)}
.ps-alevel{font-family:var(--mono);font-size:10px;color:var(--ink4);letter-spacing:.3px}
.ps-dims{display:flex;flex-direction:column;gap:7px}
.ps-dim{display:flex;align-items:center;gap:8px}
.psd-l{font-family:var(--mono);font-size:10px;color:var(--ink3);width:54px;flex-shrink:0;letter-spacing:.2px}
.psd-b{flex:1;height:3px;background:var(--off2);border-radius:2px;overflow:hidden}
.psd-f{height:100%;border-radius:2px;transition:width 1.1s cubic-bezier(.4,0,.2,1)}
.psd-f1{background:var(--accent)}.psd-f2{background:var(--blue)}.psd-f3{background:var(--amber)}.psd-f4{background:var(--accent2)}
.psd-v{font-family:var(--mono);font-size:10px;color:var(--ink3);width:28px;text-align:right;flex-shrink:0}
.ps-gap{margin-top:10px;padding-top:10px;border-top:1px solid var(--line);font-size:12px;color:var(--red);font-weight:500;line-height:1.5}
.atabs-bar{display:flex;border-bottom:1px solid var(--line);background:var(--off)}
.atab{flex:1;font-family:var(--sans);font-size:12px;font-weight:400;color:var(--ink3);background:transparent;border:none;border-bottom:2px solid transparent;padding:9px 6px;cursor:pointer;transition:all .12s}
.atab:hover{color:var(--ink)}
.atab.active{color:var(--ink);font-weight:500;border-bottom-color:var(--ink);background:var(--white)}
.atab-body{display:none;background:var(--white)}
.atab-body.active{display:block}
.tab-intro{font-size:12px;color:var(--ink3);line-height:1.6;padding:10px 14px;border-bottom:1px solid var(--line);background:var(--off)}
.acc-item{border-bottom:1px solid var(--line)}
.acc-item:last-child{border-bottom:none}
.acc-head{display:flex;align-items:center;gap:8px;padding:10px 14px;cursor:pointer;transition:background .12s;user-select:none}
.acc-head:hover{background:var(--off)}
.acc-tag{font-family:var(--mono);font-size:9px;font-weight:500;letter-spacing:.6px;text-transform:uppercase;padding:2px 7px;border-radius:2px;flex-shrink:0}
.atag-green{background:var(--accent-bg);color:var(--accent)}
.atag-red{background:var(--red-bg);color:var(--red)}
.atag-amber{background:var(--amber-bg);color:var(--amber)}
.atag-blue{background:var(--blue-bg);color:var(--blue)}
.acc-title{font-size:12px;font-weight:500;color:var(--ink);flex:1}
.acc-count{font-family:var(--mono);font-size:10px;background:var(--off2);color:var(--ink3);padding:1px 6px;border-radius:2px}
.acc-chev{color:var(--ink3);width:12px;height:12px;transition:transform .18s;flex-shrink:0}
.acc-chev.open{transform:rotate(180deg)}
.acc-body{display:none;padding:10px 14px}
.acc-body.open{display:block}
.awaiting-msg{font-family:var(--mono);font-size:11px;color:var(--ink4)}
.summary-card{font-size:13px;color:var(--ink2);line-height:1.75;border-left:2px solid var(--accent);padding-left:10px}
.gap-card{background:var(--red-bg);border:1px solid rgba(178,44,44,.12);border-radius:var(--r);padding:10px 12px;font-size:12px;color:var(--ink2);line-height:1.65}
.gap-card strong{display:block;font-weight:600;color:var(--red);margin-bottom:3px;font-size:12px}
.miss-list,.impr-list{display:flex;flex-direction:column}
.miss-item,.impr-item{display:flex;gap:8px;align-items:flex-start;padding:7px 0;border-bottom:1px solid var(--line);font-size:12px;color:var(--ink2);line-height:1.6}
.miss-item:last-child,.impr-item:last-child{border-bottom:none;padding-bottom:0}
.miss-dot{width:15px;height:15px;border-radius:50%;background:var(--accent2-bg);border:1.5px solid var(--accent2);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px;font-size:8px;color:var(--accent2);font-weight:700}
.impr-num{font-family:var(--mono);font-size:9px;color:var(--blue);background:var(--blue-bg);border-radius:3px;padding:2px 6px;flex-shrink:0;margin-top:1px}
.live-list{display:flex;flex-direction:column}
.live-item{padding:9px 0;border-bottom:1px solid var(--line)}
.live-item:last-child{border-bottom:none}
.live-quote{font-family:var(--serif);font-style:italic;font-size:13px;color:var(--ink3);background:var(--off2);border-radius:4px;padding:6px 9px;margin-bottom:5px;line-height:1.6}
.live-suggestion{font-size:12px;color:var(--ink2);line-height:1.65}
.src-item{border:1px solid var(--line);border-radius:var(--r);padding:11px;margin-bottom:7px;background:var(--off)}
.src-item:last-child{margin-bottom:0}
.src-name{font-size:13px;font-weight:600;color:var(--ink);margin-bottom:3px}
.src-why{font-size:12px;color:var(--ink2);line-height:1.6;margin-bottom:5px}
.src-how{font-family:var(--mono);font-size:11px;color:var(--blue);background:var(--blue-bg);padding:5px 8px;border-radius:4px;line-height:1.5}
.rw-label{font-family:var(--mono);font-size:9px;letter-spacing:.5px;text-transform:uppercase;color:var(--ink4);margin-bottom:4px}
.rw-original{font-family:var(--serif);font-style:italic;font-size:13px;color:var(--ink3);border-left:2px solid var(--line2);padding-left:9px;line-height:1.65;margin-bottom:10px}
.rw-21{font-size:12px;color:var(--ink2);line-height:1.7;border-left:3px solid var(--amber);padding-left:9px;margin-bottom:10px}
.rw-1st{font-size:12px;color:var(--ink);line-height:1.7;border-left:3px solid var(--accent);padding:7px 9px;border-radius:0 4px 4px 0;background:var(--accent-bg)}
.ck-item{display:flex;gap:8px;align-items:flex-start;padding:8px 0;border-bottom:1px solid var(--line);font-size:12px;color:var(--ink2);line-height:1.55}
.ck-item:last-child{border-bottom:none;padding-bottom:0}
.ck-dot{width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:8px;font-weight:700}
.ck-done{background:var(--accent-bg);border:1.5px solid var(--accent);color:var(--accent)}
.ck-warn{background:var(--amber-bg);border:1.5px solid var(--amber);color:var(--amber)}
.ck-miss{background:var(--red-bg);border:1.5px solid var(--red);color:var(--red)}
.checklist-footer{padding:10px 14px;border-top:1px solid var(--line);background:var(--off);font-family:var(--mono);font-size:11px;color:var(--ink3);display:flex;flex-direction:column;gap:5px}
#clfNum{font-weight:500;color:var(--ink)}
.clf-bar{height:3px;background:var(--off2);border-radius:2px;overflow:hidden}
.clf-fill{height:100%;background:var(--accent);border-radius:2px;transition:width .8s ease}

/* ── PLANNER ── */
.planner-grid{display:grid;grid-template-columns:380px 1fr;gap:28px;align-items:start;max-width:900px}
.planner-inputs{display:flex;flex-direction:column;gap:14px}
.planner-output{display:flex;flex-direction:column;gap:10px}
.field-group{display:flex;flex-direction:column;gap:5px}
.field-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}
.field-label{font-family:var(--mono);font-size:11px;color:var(--ink3);letter-spacing:.2px}
.field-ta,.field-input,.field-select{font-family:var(--sans);font-size:13px;color:var(--ink);background:var(--white);border:1px solid var(--line2);border-radius:var(--r);padding:8px 11px;outline:none;transition:border-color .15s;width:100%}
.field-ta{resize:vertical;min-height:80px;line-height:1.6}
.field-ta:focus,.field-input:focus,.field-select:focus{border-color:var(--ink2)}
.plan-output{background:var(--white);border:1px solid var(--line);border-radius:var(--r-lg);min-height:400px;padding:24px;box-shadow:var(--shadow);overflow-y:auto}
.plan-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:320px;gap:10px;color:var(--ink3);font-size:13px;text-align:center}
.plan-content{font-size:13px;color:var(--ink2);line-height:1.8;white-space:pre-wrap}
.plan-actions{display:flex;gap:8px;justify-content:flex-end}
.btn-primary{font-family:var(--sans);font-size:13px;font-weight:600;background:var(--ink);color:white;border:none;padding:8px 18px;border-radius:7px;cursor:pointer;transition:all .15s;display:inline-flex;align-items:center;gap:6px}
.btn-primary:hover{background:#2a2820;transform:translateY(-1px)}
.btn-secondary{font-family:var(--sans);font-size:13px;font-weight:400;background:var(--white);color:var(--ink2);border:1px solid var(--line2);padding:7px 16px;border-radius:7px;cursor:pointer;transition:all .15s}
.btn-secondary:hover{background:var(--off)}
.full-btn{width:100%;justify-content:center}
#planBtn .rl-spin,#cmpBtn .rl-spin{display:none;animation:rot .65s linear infinite;width:14px;height:14px}
#planBtn.busy .plan-rl,#cmpBtn.busy .cmp-rl{opacity:.4}
#planBtn.busy .rl-spin,#cmpBtn.busy .rl-spin{display:inline-block}
#planBtn.busy,#cmpBtn.busy{opacity:.7;pointer-events:none}

/* ── HISTORY ── */
.history-list{display:flex;flex-direction:column;gap:8px;max-width:860px}
.history-empty{display:flex;flex-direction:column;align-items:center;gap:12px;padding:60px 0;color:var(--ink3);font-size:13px;text-align:center;line-height:1.7}
.history-card{background:var(--white);border:1px solid var(--line);border-radius:var(--r-lg);padding:14px 18px;display:flex;align-items:center;gap:14px;cursor:pointer;transition:all .15s;box-shadow:var(--shadow)}
.history-card:hover{box-shadow:var(--shadow-lg);border-color:var(--line2)}
.hc-score{font-family:var(--serif);font-size:32px;font-weight:400;line-height:1;letter-spacing:-1px;width:48px;text-align:center;flex-shrink:0}
.hc-body{flex:1;min-width:0}
.hc-title{font-size:13px;font-weight:500;color:var(--ink);margin-bottom:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hc-meta{font-family:var(--mono);font-size:10px;color:var(--ink4);letter-spacing:.2px}
.hc-chip{font-family:var(--mono);font-size:10px;font-weight:500;padding:3px 9px;border-radius:3px;letter-spacing:.4px;text-transform:uppercase;flex-shrink:0}
.hc-actions{display:flex;gap:5px;flex-shrink:0}
.hc-btn{font-family:var(--mono);font-size:10px;border:1px solid var(--line);background:var(--white);color:var(--ink3);padding:4px 10px;border-radius:4px;cursor:pointer;transition:all .12s}
.hc-btn:hover{border-color:var(--line2);color:var(--ink)}

/* ── COMPARE ── */
.compare-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px;max-width:900px}
.compare-col{display:flex;flex-direction:column;gap:6px}
.compare-col-header{display:flex;align-items:center;justify-content:space-between}
.compare-label{font-family:var(--mono);font-size:12px;font-weight:500;color:var(--ink)}
.compare-badge{font-family:var(--mono);font-size:11px;padding:2px 9px;border-radius:3px;background:var(--off2);color:var(--ink3)}
.compare-ta{font-family:var(--serif);font-size:15px;line-height:1.8;color:var(--ink);background:var(--white);border:1px solid var(--line2);border-radius:var(--r-lg);padding:16px 18px;height:260px;resize:vertical;outline:none;transition:border-color .15s}
.compare-ta:focus{border-color:var(--ink2)}
.compare-wc{font-family:var(--mono);font-size:10px;color:var(--ink4)}
.compare-actions{display:flex;justify-content:center;margin-bottom:24px}
.compare-results{animation:fadeUp .3s ease}
.cmp-score-row{display:grid;grid-template-columns:1fr auto 1fr;gap:14px;align-items:center;margin-bottom:16px}
.cmp-score-card{background:var(--white);border:1px solid var(--line);border-radius:var(--r-lg);padding:18px;box-shadow:var(--shadow);text-align:center}
.cmp-score-card.winner{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-bg),var(--shadow)}
.csc-score{font-family:var(--serif);font-size:44px;font-weight:300;color:var(--ink);line-height:1;letter-spacing:-1px}
.csc-grade{font-family:var(--mono);font-size:11px;margin-top:5px;padding:3px 9px;border-radius:3px;display:inline-block}
.csc-label{font-size:12px;color:var(--ink3);margin-top:6px}
.cmp-vs{font-family:var(--mono);font-size:12px;color:var(--ink4);text-align:center;letter-spacing:.5px}
.cmp-verdict{background:var(--white);border:1px solid var(--line);border-radius:var(--r-lg);padding:18px;font-size:13px;color:var(--ink2);line-height:1.75;box-shadow:var(--shadow)}
.cmp-verdict strong{color:var(--ink);font-weight:600}

/* ── PRICING ── */
.pricing-header{text-align:center;padding:48px 0 40px;max-width:500px;margin:0 auto}
.pricing-header h2{font-family:var(--serif);font-size:44px;font-weight:400;letter-spacing:-.5px;margin-bottom:10px}
.pricing-header p{font-size:15px;color:var(--ink3)}
.pricing-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:24px;margin-bottom:48px;max-width:680px;margin-left:0}
.plan-card{background:var(--white);border:1px solid var(--line);border-radius:16px;padding:28px;display:flex;flex-direction:column;gap:0;box-shadow:var(--shadow);position:relative}
.plan-card-featured{border:2px solid var(--ink);box-shadow:var(--shadow-lg)}
.plan-popular{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--ink);color:white;font-family:var(--mono);font-size:10px;letter-spacing:.5px;padding:4px 14px;border-radius:20px;white-space:nowrap}
.plan-name{font-family:var(--mono);font-size:12px;font-weight:500;color:var(--ink3);letter-spacing:.5px;text-transform:uppercase;margin-bottom:8px}
.plan-price{font-family:var(--serif);font-size:48px;font-weight:400;color:var(--ink);line-height:1;letter-spacing:-1px;margin-bottom:10px}
.plan-price span{font-family:var(--sans);font-size:14px;font-weight:400;color:var(--ink3);letter-spacing:0}
.plan-desc{font-size:13px;color:var(--ink3);line-height:1.6;margin-bottom:20px;padding-bottom:20px;border-bottom:1px solid var(--line)}
.plan-features{list-style:none;display:flex;flex-direction:column;gap:9px;margin-bottom:24px;flex:1}
.plan-features li{font-size:13px;color:var(--ink2);display:flex;align-items:center;gap:8px;line-height:1.4}
.pf-check{color:var(--accent);font-weight:600;flex-shrink:0}
.pf-grey{color:var(--ink4)}
.pf-grey span{color:var(--line2)}
.plan-btn{width:100%;font-family:var(--sans);font-size:13px;font-weight:600;padding:11px;border-radius:8px;cursor:pointer;transition:all .15s;margin-top:auto}
.plan-btn-primary{background:var(--ink);color:white;border:none}
.plan-btn-primary:hover{background:#2a2820;transform:translateY(-1px)}
.plan-btn-outline{background:white;color:var(--ink);border:1.5px solid var(--line2)}
.plan-btn-outline:hover{background:var(--off);border-color:var(--ink)}
.pricing-faq{max-width:860px;margin:0 auto}
.pricing-faq h3{font-family:var(--serif);font-size:28px;font-weight:400;text-align:center;margin-bottom:24px;letter-spacing:-.3px}
.faq-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;max-width:780px;margin:0 auto}
.faq-item{background:var(--white);border:1px solid var(--line);border-radius:var(--r-lg);padding:18px;box-shadow:var(--shadow)}
.faq-q{font-size:13px;font-weight:600;color:var(--ink);margin-bottom:6px}
.faq-a{font-size:13px;color:var(--ink3);line-height:1.65}

@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

/* ── RESPONSIVE ── */
@media(max-width:1100px){.pricing-grid{grid-template-columns:1fr 1fr}.qa-grid{grid-template-columns:1fr 1fr}}
@media(max-width:900px){
  .sidebar{transform:translateX(-220px);transition:transform .2s}
  .sidebar.open{transform:translateX(0)}
  .app-main{margin-left:0}
  .write-layout{grid-template-columns:1fr}
  .analysis-col{max-height:none;position:static}
  .planner-grid{grid-template-columns:1fr}
  .compare-grid{grid-template-columns:1fr}
  .dash-stats{grid-template-columns:1fr 1fr}
  .qa-grid{grid-template-columns:1fr 1fr}
  .pricing-grid{grid-template-columns:1fr}
  .faq-grid{grid-template-columns:1fr}
  .lw-left{display:none}
  .login-wall{grid-template-columns:1fr}
}
@media(max-width:600px){
  .view-inner{padding:24px 16px 48px}
  .dash-stats{grid-template-columns:1fr 1fr}
  .qa-grid{grid-template-columns:1fr}
  .field-row{grid-template-columns:1fr}
}

/* ── FIXES ── */
.qa-num{font-family:var(--mono);font-size:11px;color:var(--ink4);letter-spacing:.4px;margin-bottom:10px}
.qa-card{background:var(--white);border:1px solid var(--line);border-radius:var(--r-lg);padding:20px;cursor:pointer;transition:all .15s;box-shadow:var(--shadow)}
.qa-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.qa-title{font-size:14px;font-weight:600;color:var(--ink);margin-bottom:5px;letter-spacing:-.1px}
.qa-sub{font-size:12px;color:var(--ink3);line-height:1.55}

/* Fix write view full height */
#view-write{min-height:calc(100vh - 0px)}
.write-layout{display:grid;grid-template-columns:1fr 340px;flex:1;min-height:calc(100vh);width:100%}
.editor-col{min-height:calc(100vh - 54px)}
.essay-ta{min-height:calc(100vh - 160px)}

/* Fix planner output expanding properly */
.planner-output{display:flex;flex-direction:column;gap:10px;min-width:0}

/* Fix pricing header margin */
.pricing-header{text-align:left;padding:0 0 32px;max-width:520px;margin-left:0}

/* Fix dashboard header spacing */
.view-inner .dash-header{padding-top:4px}

/* Responsive fix */
@media(max-width:1100px){
  .pricing-grid{grid-template-columns:1fr;max-width:440px}
  .qa-grid{grid-template-columns:1fr 1fr}
}

/* Login wall back link */
.lw-back{display:block;text-align:center;font-size:13px;color:var(--ink4);text-decoration:none;padding:6px 0;transition:color .15s;font-family:var(--sans)}
.lw-back:hover{color:var(--ink3)}

/* ── TOKEN / USAGE BAR ── */
.sb-token-bar{
  padding:10px 10px 6px;
  border-top:1px solid var(--line);
  margin-top:2px;
}
.stb-top{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:6px;
}
.stb-label{
  font-family:var(--mono);font-size:10px;
  color:var(--ink4);letter-spacing:.3px;
}
.stb-count{
  font-family:var(--mono);font-size:10px;
  color:var(--ink3);font-weight:500;
}
.stb-track{
  height:4px;background:var(--off2);
  border-radius:2px;overflow:hidden;margin-bottom:5px;
}
.stb-fill{
  height:100%;border-radius:2px;
  background:var(--accent);
  transition:width .5s ease;
}
.stb-fill.warn{background:var(--amber);}
.stb-fill.danger{background:var(--red);}
.stb-reset{
  font-family:var(--mono);font-size:9px;
  color:var(--ink4);letter-spacing:.2px;
  display:block;
}

/* ── AUTH TABS ── */
.auth-tabs{display:flex;border:1px solid var(--line);border-radius:7px;overflow:hidden;margin-bottom:18px}
.auth-tab{flex:1;font-family:var(--sans);font-size:13px;font-weight:400;color:var(--ink3);background:var(--off);border:none;padding:8px;cursor:pointer;transition:all .12s}
.auth-tab.active{background:var(--white);color:var(--ink);font-weight:500}
.auth-panel{display:none;flex-direction:column;gap:10px}
.auth-panel.active{display:flex}
.auth-field{display:flex;flex-direction:column}
.auth-input{font-family:var(--sans);font-size:13px;color:var(--ink);background:var(--white);border:1px solid var(--line2);border-radius:7px;padding:10px 12px;outline:none;transition:border-color .15s;width:100%}
.auth-input:focus{border-color:var(--ink2)}
.auth-error{font-size:12px;color:var(--red);min-height:16px;font-family:var(--mono)}
.auth-submit{width:100%;font-family:var(--sans);font-size:13px;font-weight:600;background:var(--ink);color:white;border:none;padding:11px;border-radius:7px;cursor:pointer;transition:all .15s}
.auth-submit:hover{background:#2a2820;transform:translateY(-1px)}
.auth-forgot{background:none;border:none;font-size:12px;color:var(--ink4);cursor:pointer;font-family:var(--sans);text-align:center;text-decoration:underline;text-underline-offset:2px;transition:color .15s}
.auth-forgot:hover{color:var(--ink3)}

/* ── TUTOR PANEL ── */
.tutor-panel{
  border-top:1px solid var(--line);
  background:var(--white);
  display:flex;flex-direction:column;
  max-height:420px;
}
.tp-header{
  padding:12px 16px 8px;
  border-bottom:1px solid var(--line);
  background:var(--off);
}
.tp-title{
  display:flex;align-items:center;gap:7px;
  font-family:var(--mono);font-size:11px;font-weight:500;
  color:var(--ink3);letter-spacing:.3px;text-transform:uppercase;
  margin-bottom:10px;
}
.tp-chips{display:flex;gap:6px;flex-wrap:wrap}
.tp-chip{
  font-family:var(--sans);font-size:12px;font-weight:400;
  color:var(--ink2);background:var(--white);
  border:1px solid var(--line2);
  padding:5px 11px;border-radius:20px;
  cursor:pointer;transition:all .12s;white-space:nowrap;
}
.tp-chip:hover{background:var(--ink);color:white;border-color:var(--ink)}
.tp-messages{
  flex:1;overflow-y:auto;padding:14px 16px;
  display:flex;flex-direction:column;gap:12px;
  min-height:80px;max-height:260px;
}
.tp-msg{display:flex;flex-direction:column;gap:4px;animation:fadeUp .2s ease}
.tp-msg-user{align-items:flex-end}
.tp-msg-ai{align-items:flex-start}
.tp-bubble{
  max-width:85%;font-size:13px;line-height:1.65;
  padding:9px 13px;border-radius:10px;
}
.tp-msg-user .tp-bubble{background:var(--ink);color:white;border-radius:10px 10px 2px 10px}
.tp-msg-ai .tp-bubble{background:var(--off2);color:var(--ink2);border-radius:10px 10px 10px 2px}
.tp-msg-ai .tp-bubble.loading{color:var(--ink4);font-style:italic}
.tp-input-row{
  display:flex;gap:8px;padding:10px 12px;
  border-top:1px solid var(--line);
  background:var(--off);
}
.tp-input{
  flex:1;font-family:var(--sans);font-size:13px;
  color:var(--ink);background:var(--white);
  border:1px solid var(--line2);border-radius:7px;
  padding:8px 12px;outline:none;transition:border-color .15s;
}
.tp-input:focus{border-color:var(--ink2)}
.tp-send{
  display:flex;align-items:center;justify-content:center;
  width:34px;height:34px;border-radius:7px;
  background:var(--ink);color:white;border:none;cursor:pointer;
  transition:all .15s;flex-shrink:0;
}
.tp-send:hover{background:#2a2820}

/* Write view - stack editor + tutor vertically */
#view-write{flex-direction:column}
.write-layout{flex:1}

/* ── PROFILE VIEW ── */
.profile-header{
  display:flex;align-items:center;gap:20px;
  padding-bottom:28px;border-bottom:1px solid var(--line);
  margin-bottom:28px;flex-wrap:wrap;
}
.ph-avatar-wrap{position:relative;flex-shrink:0}
.ph-avatar{
  width:72px;height:72px;border-radius:50%;
  background:var(--ink);color:white;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--serif);font-size:28px;font-weight:400;
  overflow:hidden;
}
.ph-avatar img{width:100%;height:100%;object-fit:cover}
.ph-avatar-edit{
  position:absolute;bottom:0;right:0;
  width:22px;height:22px;border-radius:50%;
  background:var(--white);border:1.5px solid var(--line2);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;color:var(--ink3);transition:all .12s;
}
.ph-avatar-edit:hover{background:var(--off);color:var(--ink)}
.ph-info{display:flex;flex-direction:column;gap:4px}
.ph-info h2{font-family:var(--serif);font-size:28px;font-weight:400;letter-spacing:-.3px;margin:0}
.ph-email{font-size:13px;color:var(--ink3)}
.ph-plan-badge{
  font-family:var(--mono);font-size:10px;font-weight:500;
  background:var(--off2);color:var(--ink3);
  padding:3px 9px;border-radius:3px;letter-spacing:.3px;
  width:fit-content;
}

.profile-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;align-items:start;max-width:860px}
.profile-col{display:flex;flex-direction:column;gap:16px}

.profile-card{
  background:var(--white);border:1px solid var(--line);
  border-radius:var(--r-lg);padding:20px;box-shadow:var(--shadow);
}
.danger-card{border-color:rgba(178,44,44,.2)}
.pc-head{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:16px;
}
.pc-head h3{font-size:14px;font-weight:600;color:var(--ink);letter-spacing:-.1px}
.pc-edit-btn{
  font-family:var(--mono);font-size:11px;color:var(--accent);
  background:none;border:none;cursor:pointer;
  text-decoration:underline;text-underline-offset:2px;
  transition:color .12s;
}
.pc-edit-btn:hover{color:var(--ink)}
.pc-field{
  display:flex;justify-content:space-between;align-items:center;
  padding:8px 0;border-bottom:1px solid var(--line);font-size:13px;
}
.pc-field:last-child{border-bottom:none;padding-bottom:0}
.pcf-label{color:var(--ink3);flex-shrink:0;margin-right:12px}
.pcf-val{color:var(--ink);font-weight:400;text-align:right}
.pc-field-edit{display:flex;flex-direction:column;gap:5px}
.pc-field-edit label{font-family:var(--mono);font-size:11px;color:var(--ink3);letter-spacing:.2px}

.pc-pref{
  display:flex;align-items:center;justify-content:space-between;
  gap:12px;padding:10px 0;border-bottom:1px solid var(--line);
}
.pc-pref:last-child{border-bottom:none;padding-bottom:0}
.pcp-label{display:flex;flex-direction:column;gap:2px}
.pcp-label span:first-child{font-size:13px;color:var(--ink)}
.pcp-sub{font-size:11px;color:var(--ink4);font-family:var(--mono);letter-spacing:.2px}

/* TOGGLE SWITCH */
.toggle-switch{position:relative;display:inline-block;width:36px;height:20px;flex-shrink:0}
.toggle-switch input{opacity:0;width:0;height:0}
.ts-slider{
  position:absolute;inset:0;cursor:pointer;
  background:var(--line2);border-radius:20px;transition:.2s;
}
.ts-slider::before{
  content:'';position:absolute;height:14px;width:14px;
  left:3px;bottom:3px;background:white;border-radius:50%;transition:.2s;
}
.toggle-switch input:checked + .ts-slider{background:var(--accent)}
.toggle-switch input:checked + .ts-slider::before{transform:translateX(16px)}

/* USAGE IN PROFILE */
.usage-big{display:flex;align-items:baseline;gap:6px}
.ub-num{font-family:var(--serif);font-size:48px;font-weight:300;color:var(--ink);line-height:1;letter-spacing:-1px}
.ub-denom{font-size:14px;color:var(--ink3)}
.upgrade-nudge{
  margin-top:12px;padding:10px 12px;
  background:var(--amber-bg);border:1px solid rgba(160,115,24,.2);
  border-radius:var(--r);
  display:flex;align-items:center;justify-content:space-between;
  gap:10px;font-size:12px;color:var(--amber);
}
.upgrade-nudge button{
  font-family:var(--sans);font-size:12px;font-weight:600;
  background:var(--amber);color:white;border:none;
  padding:5px 12px;border-radius:5px;cursor:pointer;white-space:nowrap;
}

/* STATS IN PROFILE */
.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.stat-item{background:var(--off);border-radius:var(--r);padding:12px}
.stat-n{font-family:var(--serif);font-size:28px;font-weight:400;color:var(--ink);line-height:1;letter-spacing:-.5px;margin-bottom:3px}
.stat-l{font-family:var(--mono);font-size:10px;color:var(--ink4);letter-spacing:.3px;text-transform:uppercase}

/* DANGER BUTTON */
.btn-danger{
  width:100%;font-family:var(--sans);font-size:13px;font-weight:500;
  background:var(--red-bg);color:var(--red);
  border:1px solid rgba(178,44,44,.2);
  padding:9px;border-radius:7px;cursor:pointer;transition:all .15s;
}
.btn-danger:hover{background:var(--red);color:white}

/* Sidebar user clickable */
.sb-user{cursor:pointer}
.sb-user:hover{background:var(--off2);border-radius:8px}

@media(max-width:700px){.profile-grid{grid-template-columns:1fr}}

/* ── IMPROVED ANALYSIS COMPONENTS ── */

/* Gap to First pill */
.gap-to-first-pill{
  display:inline-flex;align-items:center;
  font-family:var(--mono);font-size:10px;font-weight:500;
  background:var(--red-bg);color:var(--red);
  padding:3px 8px;border-radius:3px;letter-spacing:.3px;
  margin-right:6px;vertical-align:middle;flex-shrink:0;
}
.gap-achieved{background:var(--accent-bg);color:var(--accent)}

/* Skill meta row */
.ps-skill-meta{
  display:flex;gap:8px;flex-wrap:wrap;
  margin-top:10px;padding-top:10px;
  border-top:1px solid var(--line);
}
.skill-weak{
  font-family:var(--mono);font-size:10px;
  background:var(--red-bg);color:var(--red);
  padding:3px 8px;border-radius:3px;
}
.skill-fast{
  font-family:var(--mono);font-size:10px;
  background:var(--accent-bg);color:var(--accent);
  padding:3px 8px;border-radius:3px;
}

/* Next action card */
.next-action-card{
  margin-top:10px;padding:11px 13px;
  background:var(--ink);color:white;
  border-radius:var(--r);font-size:12px;line-height:1.6;
}
.na-label{
  font-family:var(--mono);font-size:9px;letter-spacing:.6px;
  text-transform:uppercase;color:rgba(255,255,255,.4);
  margin-bottom:5px;
}

/* Evaluation boost card */
.eval-boost-card{
  margin-top:10px;padding:11px 13px;
  background:var(--blue-bg);
  border:1px solid rgba(30,63,120,.15);
  border-radius:var(--r);font-size:12px;color:var(--ink2);line-height:1.65;
}
.eb-label{
  font-family:var(--mono);font-size:9px;letter-spacing:.6px;
  text-transform:uppercase;color:var(--blue);
  margin-bottom:5px;display:block;font-weight:500;
}

/* Rich improvement cards */
.impr-card{
  border:1px solid var(--line);border-radius:var(--r);
  margin-bottom:10px;overflow:hidden;
}
.impr-card:last-child{margin-bottom:0}
.ic-header{
  display:flex;align-items:center;gap:8px;
  padding:10px 12px;background:var(--off);
  border-bottom:1px solid var(--line);
}
.ic-num{
  font-family:var(--mono);font-size:10px;color:var(--ink4);
  flex-shrink:0;letter-spacing:.3px;
}
.ic-issue{font-size:13px;font-weight:600;color:var(--ink);flex:1}
.ic-gain{
  font-family:var(--mono);font-size:10px;font-weight:500;
  background:var(--accent-bg);color:var(--accent);
  padding:2px 8px;border-radius:3px;flex-shrink:0;
}
.ic-why,.ic-first,.ic-fix{
  padding:9px 12px;border-bottom:1px solid var(--line);
  font-size:12px;color:var(--ink2);line-height:1.6;
}
.ic-fix{border-bottom:none;background:var(--off)}
.ic-label{
  display:block;font-family:var(--mono);font-size:9px;
  letter-spacing:.5px;text-transform:uppercase;
  margin-bottom:4px;
}
.ic-why .ic-label{color:var(--red)}
.ic-first .ic-label{color:var(--accent)}
.ic-fix .ic-label{color:var(--amber)}

/* UI polish — make analysis panel text more readable */
.acc-body.open{padding:12px 14px 14px}
.live-quote{font-size:12px;padding:7px 10px}
.live-suggestion{font-size:12px}
.summary-card{font-size:13px}
