/* ─────────────────────────────────────────────────────────
   Zerith App — app.css
   Inter (body) + Sora (headings)
   Dark/light theme via data-theme attribute
───────────────────────────────────────────────────────── */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --bg-primary:#0B0F1A;
  --bg-secondary:#0F1424;
  --bg-card:#12182B;
  --bg-hover:#18203A;
  --primary:#7C5CFF;
  --primary-light:#9B87FF;
  --primary-bg:rgba(124,92,255,0.1);
  --primary-border:rgba(124,92,255,0.25);
  --text-primary:#E6EAF2;
  --text-secondary:#A9B1C6;
  --text-muted:#6B7280;
  --border-subtle:rgba(255,255,255,0.06);
  --border-strong:rgba(255,255,255,0.12);
  --green:#22C97A;
  --green-bg:rgba(34,201,122,0.12);
  --amber:#F5A623;
  --amber-bg:rgba(245,166,35,0.12);
  --red:#FF5C5C;
  --red-bg:rgba(255,92,92,0.12);
  --sidebar-w:220px;
  --topbar-h:52px;
  --font-head:'Sora',system-ui,sans-serif;
  --font-body:'Inter',system-ui,sans-serif;
  --r-sm:6px;
  --surface:var(--bg-card);
  --surface-raised:#1e2a45;
  --primary-dim:rgba(124,92,255,0.35);
  --border:var(--border-subtle);
  --r-md:8px;
  --r-lg:12px;
  --r-xl:14px;
}

[data-theme="light"]{
  --surface:var(--bg-card);
  --surface-raised:#eef0ff;
  --primary-dim:rgba(124,92,255,0.3);
  --border:var(--border-subtle);
  --bg-primary:#F5F7FA;
  --bg-secondary:#FFFFFF;
  --bg-card:#FFFFFF;
  --bg-hover:#EEF1F7;
  --primary:#7C5CFF;
  --primary-light:#6B4EE6;
  --primary-bg:rgba(124,92,255,0.08);
  --primary-border:rgba(124,92,255,0.2);
  --text-primary:#111827;
  --text-secondary:#374151;
  --text-muted:#6B7280;
  --border-subtle:rgba(0,0,0,0.07);
  --border-strong:rgba(0,0,0,0.13);
  --green:#16A34A;
  --green-bg:rgba(22,163,74,0.1);
  --amber:#D97706;
  --amber-bg:rgba(217,119,6,0.1);
  --red:#DC2626;
  --red-bg:rgba(220,38,38,0.08);
}

html{scroll-behavior:smooth}
body{font-family:var(--font-body);background:var(--bg-primary);color:var(--text-primary);line-height:1.6;-webkit-font-smoothing:antialiased;min-height:100vh;overflow-x:hidden;transition:background .25s,color .25s}
a{text-decoration:none;color:inherit}
.hidden{display:none!important}

/* ─── AUTH GATE ─── */
.auth-gate{position:fixed;inset:0;background:var(--bg-primary);display:flex;align-items:center;justify-content:center;z-index:1000}
.auth-gate-inner{text-align:center}
.auth-logo{display:flex;align-items:center;justify-content:center;gap:10px;font-family:var(--font-head);font-size:22px;font-weight:700;color:var(--text-primary);margin-bottom:24px}
.auth-spinner{width:24px;height:24px;border:2px solid var(--border-subtle);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto}
@keyframes spin{to{transform:rotate(360deg)}}

/* ─── Z BADGE ─── */
.z-badge{width:28px;height:28px;background:var(--primary);border-radius:7px;display:inline-flex;align-items:center;justify-content:center;font-family:var(--font-head);font-weight:700;font-size:14px;color:#fff;flex-shrink:0;line-height:1}

/* ─── UPGRADE BANNER ─── */
.upgrade-banner{background:rgba(245,166,35,0.1);border-bottom:1px solid rgba(245,166,35,0.2);padding:10px 20px;display:flex;align-items:center;justify-content:center;gap:10px;font-size:13px;color:#C4A882;position:relative;flex-shrink:0}
.upgrade-banner svg{color:#F5A623;flex-shrink:0}
.upgrade-banner a{color:#F5A623;font-weight:600}
.upgrade-banner a:hover{text-decoration:underline}
.banner-close{background:none;border:none;color:#7A6040;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;border-radius:var(--r-sm);position:absolute;right:16px;transition:color .15s}
.banner-close:hover{color:#F5A623}

/* ─── APP SHELL ─── */
.app{display:flex;flex-direction:column;height:100vh;overflow:hidden}
.app-shell{display:flex;flex:1;overflow:hidden;min-height:0}

/* ─── SIDEBAR ─── */
.sidebar{width:var(--sidebar-w);min-width:var(--sidebar-w);background:var(--bg-secondary);border-right:1px solid var(--border-subtle);display:flex;flex-direction:column;height:100%;overflow:hidden;transition:background .25s}
.sidebar-logo{padding:16px 18px;border-bottom:1px solid var(--border-subtle)}
.logo-link{display:flex;align-items:center;gap:9px;text-decoration:none}
.logo-text{font-family:var(--font-head);font-size:17px;font-weight:700;color:var(--text-primary)}
.sidebar-nav{flex:1;overflow-y:auto;padding:12px 10px}
.nav-section-label{display:block;font-size:10px;font-weight:600;letter-spacing:.09em;text-transform:uppercase;color:var(--text-muted);padding:8px 10px 4px;margin-top:4px}
.nav-item{display:flex;align-items:center;gap:9px;width:100%;background:none;border:none;border-right:2px solid transparent;border-radius:var(--r-md) 0 0 var(--r-md);padding:8px 10px;font-family:var(--font-body);font-size:13px;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .15s;text-align:left;position:relative}
.nav-item:hover{color:var(--text-primary);background:var(--bg-hover)}
.nav-item.active{color:var(--primary-light);background:var(--primary-bg);border-right-color:var(--primary)}
.nav-item svg{flex-shrink:0;stroke:currentColor}
.nav-lock-badge{margin-left:auto;font-size:9px;font-weight:600;background:rgba(245,166,35,0.15);color:var(--amber);padding:2px 6px;border-radius:20px;letter-spacing:.04em;white-space:nowrap}

/* ─── SIDEBAR BOTTOM ─── */
.sidebar-bottom{border-top:1px solid var(--border-subtle);padding:12px 14px}
.sidebar-user{display:flex;align-items:center;gap:9px;position:relative}
.user-avatar{width:30px;height:30px;border-radius:50%;background:var(--primary-bg);border:1px solid var(--primary-border);color:var(--primary-light);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;flex-shrink:0;cursor:pointer;user-select:none}
.user-info{flex:1;min-width:0}
.user-name{font-size:12px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.user-plan{font-size:11px;color:var(--text-muted)}
.user-settings-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:var(--r-sm);display:flex;transition:color .15s}
.user-settings-btn:hover{color:var(--text-secondary)}
.user-dropdown{position:absolute;bottom:calc(100% + 8px);left:0;right:0;background:var(--bg-card);border:1px solid var(--border-strong);border-radius:var(--r-lg);padding:6px;z-index:200;min-width:180px}
.user-email{font-size:12px;color:var(--text-muted);padding:4px 8px;word-break:break-all}
.dropdown-divider{border:none;border-top:1px solid var(--border-subtle);margin:4px 0}
.user-dropdown button{width:100%;background:none;border:none;color:var(--text-primary);font-family:var(--font-body);font-size:13px;padding:7px 8px;text-align:left;cursor:pointer;border-radius:var(--r-sm);transition:background .15s}
.user-dropdown button:hover{background:var(--bg-hover)}

/* ─── MAIN CONTENT ─── */
.main-content{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0;height:100%;width:0}

/* ─── TOPBAR ─── */
.topbar{height:var(--topbar-h);border-bottom:1px solid var(--border-subtle);display:flex;align-items:center;justify-content:space-between;padding:0 20px;flex-shrink:0;background:var(--bg-primary);transition:background .25s}
.topbar-left{display:flex;align-items:center;gap:12px}
.topbar-title{font-family:var(--font-head);font-size:15px;font-weight:600;color:var(--text-primary)}
.mobile-menu-btn{display:none;background:none;border:1px solid var(--border-strong);border-radius:var(--r-sm);padding:6px;cursor:pointer;color:var(--text-secondary)}
.topbar-right{display:flex;align-items:center;gap:10px}

/* Plan badge */
.plan-badge{font-size:11px;font-weight:600;padding:3px 10px;border-radius:20px;letter-spacing:.05em;text-transform:uppercase;background:var(--primary-bg);color:var(--primary-light);border:1px solid var(--primary-border)}
.plan-badge.pro{background:rgba(34,201,122,0.1);color:var(--green);border-color:rgba(34,201,122,0.2)}
.plan-badge.ultimate{background:rgba(245,166,35,0.1);color:var(--amber);border-color:rgba(245,166,35,0.2)}
.plan-badge.business{background:rgba(124,92,255,0.15);color:var(--primary-light);border-color:var(--primary-border)}

.upgrade-topbar-btn{background:var(--primary);color:#fff;border:none;border-radius:var(--r-md);padding:6px 14px;font-family:var(--font-body);font-size:12px;font-weight:600;cursor:pointer;transition:opacity .2s}
.upgrade-topbar-btn:hover{opacity:.85}

/* Theme toggle */
.theme-toggle{width:34px;height:34px;border-radius:var(--r-md);background:var(--bg-card);border:1px solid var(--border-strong);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:background .2s,border-color .2s}
.theme-toggle:hover{background:var(--bg-hover)}
.icon-moon{display:block}
.icon-sun{display:none}
[data-theme="light"] .icon-moon{display:none}
[data-theme="light"] .icon-sun{display:block}

/* ─── PAGE ─── */
.page{flex:1;overflow-y:auto;min-height:0;width:100%}
.page-inner{max-width:1280px;width:100%;margin:0 auto;padding:24px 24px 48px;box-sizing:border-box}

/* ─── BUTTONS ─── */
.btn-primary{background:var(--primary);color:#fff;border:none;border-radius:var(--r-md);padding:10px 20px;font-family:var(--font-body);font-size:14px;font-weight:600;cursor:pointer;transition:opacity .2s,transform .15s;display:inline-flex;align-items:center;gap:6px}
.btn-primary:hover{opacity:.9;transform:translateY(-1px)}

/* ─── SEARCH BAR ─── */
.search-bar-row{margin-bottom:20px}
.search-bar-wrap{display:flex;align-items:center;background:var(--bg-secondary);border:1.5px solid var(--border-strong);border-radius:var(--r-lg);padding:6px 6px 6px 14px;gap:8px;transition:border-color .2s}
.search-bar-wrap:focus-within{border-color:var(--primary)}
.search-input{flex:1;background:none;border:none;outline:none;color:var(--text-primary);font-family:var(--font-body);font-size:14px;padding:6px 0;min-width:0}
.search-input::placeholder{color:var(--text-muted)}
.lang-select{background:var(--bg-hover);border:1px solid var(--border-strong);color:var(--text-secondary);font-family:var(--font-body);font-size:12px;padding:7px 8px;border-radius:var(--r-sm);outline:none;cursor:pointer;flex-shrink:0}
.search-btn{background:var(--primary);color:#fff;border:none;border-radius:var(--r-sm);padding:9px 18px;font-family:var(--font-body);font-size:13px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:6px;white-space:nowrap;flex-shrink:0;transition:opacity .2s}
.search-btn:hover{opacity:.9}
.search-btn:disabled{opacity:.5;cursor:not-allowed}
.search-meta{font-size:12px;color:var(--text-muted);margin-top:8px}
.spinner{width:14px;height:14px;animation:spin .8s linear infinite;flex-shrink:0}

/* ─── STATS GRID ─── */
.stats-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:20px}
.stat-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--r-lg);padding:16px}
.stat-label{font-size:11px;color:var(--text-muted);margin-bottom:6px;text-transform:uppercase;letter-spacing:.05em}
.stat-value{font-family:var(--font-head);font-size:22px;font-weight:700;color:var(--text-primary)}
.stat-value.accent{color:var(--primary-light)}
.stat-value.green{color:var(--green)}
.stat-sub{font-size:11px;color:var(--text-muted);margin-top:3px}
.stat-bar-wrap{margin-top:8px;height:3px;background:var(--border-subtle);border-radius:2px;overflow:hidden}
.stat-bar-fill{height:100%;border-radius:2px;background:var(--amber);transition:width .3s}
/* Ring meter cards */
.stat-card-ring{display:flex;flex-direction:column;align-items:center;gap:8px;height:220px;box-sizing:border-box}
.stat-ring-title{font-size:12px;font-weight:600;color:var(--text-primary);text-align:center;white-space:nowrap}
.stat-ring-desc{font-size:11px;color:var(--text-muted);text-align:center;white-space:nowrap;margin-top:-4px}
.stat-ring-wrap{position:relative;width:80px;height:80px;flex-shrink:0;transform:rotate(-90deg)}
.stat-ring-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;transform:rotate(90deg)}
.stat-ring-val{font-size:22px;font-weight:700;font-family:var(--font-head);line-height:1;color:var(--green)}
.stat-ring-sub{font-size:10px;color:var(--text-muted);margin-top:2px}
.ring-fill{stroke:var(--green);transition:stroke-dashoffset .6s ease,stroke .3s}
.ring-fill.amber{stroke:var(--amber)}
.ring-fill.red{stroke:var(--red)}
.stat-ring-remaining{font-size:12px;font-weight:500;color:var(--green);text-align:center}
.stat-ring-remaining.amber{color:var(--amber)}
.stat-ring-remaining.red{color:var(--red)}
.stat-ring-topic{font-size:10px;color:var(--text-muted);font-weight:400;max-width:110px}
.stat-ring-foot{border-top:1px solid var(--border-subtle);padding-top:8px;width:100%;display:flex;align-items:center;justify-content:center;gap:5px;margin-top:auto}
.stat-ring-total{font-size:12px;font-weight:600;color:var(--text-primary)}
.stat-ring-foot-desc{font-size:11px;color:var(--text-muted)}

/* ─── OVERVIEW TWO COL ─── */
.overview-two-col{display:grid;grid-template-columns:1fr 1fr;gap:16px}

/* ─── CARD ─── */
.card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--r-xl);padding:18px}
.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.card-title{font-size:13px;font-weight:600;color:var(--text-primary)}
.card-link{background:none;border:none;font-size:12px;color:var(--primary-light);cursor:pointer;padding:0;font-family:var(--font-body)}
.card-link:hover{text-decoration:underline}
.empty-msg{font-size:13px;color:var(--text-muted);padding:12px 0}

/* ─── RECENT LIST ─── */
.recent-list{display:flex;flex-direction:column;gap:0}
.recent-item{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid var(--border-subtle);cursor:pointer}
.recent-item:last-child{border-bottom:none}
.recent-item:hover .ri-topic{color:var(--primary-light)}
.ri-icon{width:28px;height:28px;border-radius:var(--r-md);background:var(--primary-bg);display:flex;align-items:center;justify-content:center;color:var(--primary-light);flex-shrink:0}
.ri-icon svg{stroke:currentColor}
.ri-body{flex:1;min-width:0}
.ri-topic{font-size:12px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color .15s}
.ri-meta{font-size:11px;color:var(--text-muted)}
.ri-score{font-size:12px;font-weight:600;color:var(--green);flex-shrink:0}

/* ─── UPGRADE PANEL (overview) ─── */
.upgrade-panel{background:var(--primary-bg);border:1px solid var(--primary-border);border-radius:var(--r-xl);padding:20px}
.up-title{font-family:var(--font-head);font-size:14px;font-weight:700;color:var(--text-primary);margin-bottom:6px}
.up-desc{font-size:13px;color:var(--text-secondary);margin-bottom:14px;line-height:1.5}
.up-feats{list-style:none;display:flex;flex-direction:column;gap:7px;margin-bottom:16px}
.up-feats li{font-size:13px;color:var(--text-secondary);display:flex;align-items:center;gap:7px}
.up-feats li::before{content:'✓';color:var(--green);font-weight:700;font-size:11px;flex-shrink:0}

/* ─── EXPLORER RESULTS ─── */
.explorer-results{display:flex;gap:16px;align-items:flex-start}
.explorer-table-wrap{flex:1;min-width:0;max-width:100%;overflow-x:hidden}
.results-toolbar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;margin-bottom:10px}
.results-info{font-size:13px;color:var(--text-secondary)}
.results-info strong{color:var(--text-primary)}
.results-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.filter-select{background:var(--bg-card);border:1px solid var(--border-subtle);color:var(--text-secondary);font-family:var(--font-body);font-size:12px;padding:6px 10px;border-radius:var(--r-sm);outline:none;cursor:pointer;transition:border-color .15s}
.filter-select:hover{border-color:var(--primary-border)}
.action-btn{background:none;border:1px solid var(--border-strong);color:var(--text-secondary);font-family:var(--font-body);font-size:12px;padding:6px 12px;border-radius:var(--r-sm);cursor:pointer;display:flex;align-items:center;gap:5px;transition:border-color .15s,color .15s}
.action-btn:hover{border-color:var(--primary-border);color:var(--text-primary)}

/* Export tooltip */
.export-btn-wrap{position:relative}
.export-tooltip{position:absolute;top:calc(100% + 6px);right:0;background:var(--bg-card);border:1px solid var(--border-strong);border-radius:var(--r-md);padding:8px 12px;font-size:12px;color:var(--text-secondary);white-space:nowrap;z-index:10;display:flex;align-items:center;gap:6px}
.export-tooltip svg{color:var(--amber);flex-shrink:0}
.export-tooltip a{color:var(--primary-light);font-weight:500}

/* ─── TABLE ─── */
.table-container{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--r-xl);overflow:hidden;max-width:100%;box-sizing:border-box}
.data-table{width:100%;border-collapse:collapse;table-layout:auto;min-width:640px}
.data-table th{padding:10px 14px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);border-bottom:1px solid var(--border-subtle);background:var(--bg-secondary);text-align:left;white-space:nowrap}
.data-table td{padding:10px 14px;border-bottom:1px solid var(--border-subtle);color:var(--text-primary);font-size:13px;vertical-align:middle}
.data-table tr:last-child td{border-bottom:none}
.data-table tr:hover td{background:var(--bg-hover)}
.data-table tr.clickable{cursor:pointer}
.kw-cell{font-weight:500;max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* Intent badges */
.intent{display:inline-block;font-size:10px;font-weight:600;padding:2px 8px;border-radius:4px;letter-spacing:.03em}
.intent-info{background:var(--primary-bg);color:var(--primary-light)}
.intent-com{background:var(--green-bg);color:var(--green)}
.intent-trans{background:var(--amber-bg);color:var(--amber)}
.intent-nav{background:rgba(169,177,198,0.12);color:var(--text-secondary)}

/* Difficulty */
.diff-wrap{display:flex;align-items:center;gap:6px}
.diff-bar-bg{width:40px;height:4px;background:var(--border-strong);border-radius:2px;overflow:hidden;flex-shrink:0}
.diff-bar-fill{height:4px;border-radius:2px}
.diff-label{font-size:12px;color:var(--text-secondary)}

/* Opportunity */
.opp-score{display:inline-block;font-size:11px;font-weight:600;padding:2px 8px;border-radius:4px}
.opp-high{background:var(--green-bg);color:var(--green)}
.opp-mid{background:var(--amber-bg);color:var(--amber)}
.opp-low{background:var(--red-bg);color:var(--red)}
/* Locked blur — colour matches what the real value would show */
.opp-locked{display:inline-block;font-size:11px;font-weight:600;padding:2px 8px;border-radius:4px;filter:blur(4px);user-select:none;cursor:default}
.opp-locked.opp-high{background:var(--green-bg);color:var(--green)}
.opp-locked.opp-mid{background:var(--amber-bg);color:var(--amber)}
.opp-locked.opp-low{background:var(--red-bg);color:var(--red)}
.cpc-locked{display:inline-block;font-size:11px;font-weight:600;padding:2px 6px;border-radius:4px;filter:blur(4px);user-select:none;cursor:default;background:rgba(255,255,255,0.08);color:var(--text-primary)}

/* Locked row */
.locked-row td{color:var(--text-muted);opacity:.4}

/* Remove btn */
.row-remove-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:3px 5px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;transition:color .15s,background .15s}
.row-remove-btn:hover{color:var(--red);background:var(--red-bg)}
.row-save-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:3px 5px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;transition:color .15s,background .15s}
.row-save-btn:hover{color:var(--primary-light);background:var(--primary-bg)}

/* Results footer */
.results-footer{margin-top:10px;font-size:13px;color:var(--text-secondary);padding:10px 14px;background:var(--primary-bg);border:1px solid var(--primary-border);border-radius:var(--r-md)}
.results-footer a{color:var(--primary-light);font-weight:600}

/* ─── AI INSIGHT PANEL ─── */
.insight-panel{width:240px;min-width:240px;background:var(--bg-card);border:1px solid var(--primary-border);border-radius:var(--r-xl);padding:16px;display:flex;flex-direction:column;gap:12px;height:fit-content;position:sticky;top:20px}
.ip-header{display:flex;align-items:center;justify-content:space-between}
.ip-badge{background:var(--primary-bg);color:var(--primary-light);font-size:10px;font-weight:600;padding:3px 8px;border-radius:20px;display:flex;align-items:center;gap:4px;letter-spacing:.04em}
.ip-score{font-family:var(--font-head);font-size:22px;font-weight:700;color:var(--green)}
.ip-score span{font-size:11px;color:var(--text-muted);font-family:var(--font-body);font-weight:400}
.score-locked{filter:blur(4px);user-select:none;letter-spacing:2px}
.ip-kw{font-size:12px;font-weight:500;color:var(--text-primary);background:var(--bg-hover);border-left:2px solid var(--primary);padding:6px 10px;border-radius:0 4px 4px 0;margin-bottom:12px}
.ip-check{font-size:11px;color:var(--text-secondary);display:flex;align-items:center;gap:6px}
.ip-check::before{content:'✓';color:var(--green);font-weight:700;font-size:11px;flex-shrink:0}
.ip-why{font-size:11px;color:var(--text-secondary);border-left:2px solid var(--primary-border);padding-left:8px;line-height:1.5}
.ip-divider{border:none;border-top:1px solid var(--border-subtle);margin:12px 0}
.ip-angle-lbl{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px}
.ip-angle-val{font-size:12px;color:var(--text-secondary);font-style:italic;line-height:1.4}
.ip-lock{background:var(--amber-bg);border:1px solid rgba(245,166,35,0.2);border-radius:var(--r-md);padding:10px 12px;font-size:11px;color:var(--text-secondary);display:flex;align-items:flex-start;gap:6px;line-height:1.4;margin-top:12px;margin-bottom:10px}
.ip-cta{background:var(--primary);color:#fff;border:none;border-radius:var(--r-md);padding:9px 12px;font-family:var(--font-body);font-size:12px;font-weight:600;cursor:pointer;transition:opacity .2s;width:100%}
.ip-cta:hover{opacity:.9}

/* ─── UPGRADE WALL ─── */
.upgrade-wall{max-width:480px;margin:60px auto;padding:48px 32px;background:var(--bg-card);border:1px solid var(--primary-border);border-radius:var(--r-xl);text-align:center}
.uw-icon{color:var(--primary-light);margin-bottom:16px}
.uw-icon svg{stroke:currentColor}
.upgrade-wall h3{font-family:var(--font-head);font-size:20px;font-weight:700;margin-bottom:8px}
.upgrade-wall p{font-size:14px;color:var(--text-secondary);margin-bottom:24px;line-height:1.6}

/* ─── LOCK WALL ─── */
.lock-wall{max-width:520px;margin:60px auto;padding:48px 32px;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--r-xl);text-align:center}
.lw-icon{width:64px;height:64px;border-radius:50%;background:var(--primary-bg);border:1px solid var(--primary-border);color:var(--primary-light);display:flex;align-items:center;justify-content:center;margin:0 auto 20px}
.lw-icon svg{stroke:currentColor}
.lock-wall h3{font-family:var(--font-head);font-size:22px;font-weight:700;margin-bottom:10px}
.lock-wall p{font-size:14px;color:var(--text-secondary);margin-bottom:20px;line-height:1.6}
.lw-feats{list-style:none;text-align:left;display:flex;flex-direction:column;gap:8px;margin-bottom:28px;background:var(--bg-secondary);border-radius:var(--r-lg);padding:16px 20px}
.lw-feats li{font-size:13px;color:var(--text-secondary);display:flex;align-items:center;gap:8px}
.lw-feats li::before{content:'✓';color:var(--green);font-weight:700;font-size:12px;flex-shrink:0}
.lw-note{font-size:12px;color:var(--text-muted);margin-top:12px}

/* ─── KEYWORD IDEAS ─── */
.ideas-layout{display:flex;flex-direction:column;gap:0}
.ideas-tabs{display:flex;gap:2px;border-bottom:1px solid var(--border-subtle);margin-bottom:16px}
.ideas-tab{background:none;border:none;border-bottom:2px solid transparent;padding:9px 14px;font-family:var(--font-body);font-size:13px;font-weight:500;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;gap:6px;margin-bottom:-1px;transition:color .15s}
.ideas-tab:hover{color:var(--text-primary)}
.ideas-tab.active{color:var(--primary-light);border-bottom-color:var(--primary)}
.tab-count{font-size:10px;background:var(--primary-bg);color:var(--primary-light);padding:1px 6px;border-radius:20px}
.cluster-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;padding-top:4px}
.cluster-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--r-lg);padding:16px;cursor:pointer;transition:border-color .15s}
.cluster-card:hover{border-color:var(--primary-border)}
.cc-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.cc-name{font-size:13px;font-weight:600;color:var(--text-primary);margin-bottom:6px;display:flex;align-items:center;gap:8px}
.cc-meta{font-size:11px;color:var(--text-muted);display:flex;gap:12px}

/* ─── SAVED LISTS ─── */
.lists-layout{display:flex;gap:16px;align-items:flex-start}
.lists-sidebar-panel{width:220px;min-width:220px;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--r-xl);padding:14px;display:flex;flex-direction:column;gap:8px}
.lsp-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}
.icon-btn{background:none;border:1px solid var(--border-strong);border-radius:var(--r-sm);width:26px;height:26px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-secondary);transition:border-color .15s,color .15s}
.icon-btn:hover{border-color:var(--primary-border);color:var(--primary-light)}
.lists-nav{display:flex;flex-direction:column;gap:4px}
.list-nav-item{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;border-radius:var(--r-md);cursor:pointer;transition:background .15s;border:1px solid transparent}
.list-nav-item:hover{background:var(--bg-hover)}
.list-nav-item.active{background:var(--primary-bg);border-color:var(--primary-border)}
.lni-name{font-size:12px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.lni-count{font-size:10px;background:var(--primary-bg);color:var(--primary-light);padding:1px 6px;border-radius:20px;flex-shrink:0}
.new-list-btn{display:flex;align-items:center;gap:6px;background:none;border:1px dashed var(--border-strong);border-radius:var(--r-md);padding:8px 10px;font-family:var(--font-body);font-size:12px;color:var(--text-muted);cursor:pointer;width:100%;transition:border-color .15s,color .15s;margin-top:4px}
.new-list-btn:hover{border-color:var(--primary-border);color:var(--primary-light)}
.list-detail{flex:1;min-width:0}
.list-detail-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.list-detail-title{font-family:var(--font-head);font-size:15px;font-weight:600;color:var(--text-primary)}
.list-detail-meta{font-size:12px;color:var(--text-muted);margin-top:2px}
.list-actions{display:flex;gap:6px}

/* ─── HISTORY ─── */
.history-layout{display:flex;gap:16px;align-items:flex-start}
.history-list-panel{width:300px;min-width:300px;display:flex;flex-direction:column;gap:10px}
.history-search-wrap{display:flex;align-items:center;gap:8px;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--r-lg);padding:9px 12px}
.history-search-wrap svg{color:var(--text-muted);flex-shrink:0}
.history-search-input{background:none;border:none;outline:none;font-family:var(--font-body);font-size:13px;color:var(--text-primary);flex:1;min-width:0}
.history-search-input::placeholder{color:var(--text-muted)}
.history-grouped-list{display:flex;flex-direction:column;gap:12px}
.history-date-group{display:flex;flex-direction:column;gap:6px}
.history-date-label{font-size:10px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;padding:0 2px}
.history-item{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--r-lg);padding:12px 14px;display:flex;align-items:center;gap:10px;cursor:pointer;transition:border-color .15s}
.history-item:hover{border-color:var(--primary-border)}
.history-item.active{border-color:rgba(124,92,255,0.4);background:var(--primary-bg)}
.hi-icon{width:30px;height:30px;border-radius:var(--r-md);background:var(--primary-bg);display:flex;align-items:center;justify-content:center;color:var(--primary-light);flex-shrink:0}
.hi-body{flex:1;min-width:0}
.hi-topic{font-size:12px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:2px}
.hi-meta{font-size:11px;color:var(--text-muted);display:flex;gap:8px}
.hi-score{font-size:12px;font-weight:600;color:var(--green);flex-shrink:0}
.hi-actions{display:flex;gap:4px;flex-shrink:0}
.hi-btn{background:none;border:1px solid var(--border-subtle);border-radius:var(--r-sm);padding:4px 7px;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;font-size:11px;gap:3px;transition:border-color .15s,color .15s}
.hi-btn:hover{border-color:var(--primary-border);color:var(--primary-light)}
.hi-btn.danger:hover{border-color:var(--red-bg);color:var(--red)}
.history-detail-panel{flex:1;min-width:0}
.hdp-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--r-xl);overflow:hidden}
.hdp-header{padding:14px 16px;border-bottom:1px solid var(--border-subtle);display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.hdp-topic{font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:3px}
.hdp-meta{font-size:11px;color:var(--text-muted)}
.hdp-rerun{background:var(--primary);color:#fff;border:none;border-radius:var(--r-sm);padding:6px 14px;font-family:var(--font-body);font-size:12px;font-weight:600;cursor:pointer;white-space:nowrap;flex-shrink:0;display:flex;align-items:center;gap:5px;transition:opacity .2s}
.hdp-rerun:hover{opacity:.9}
.hdp-stats{display:grid;grid-template-columns:repeat(3,1fr);border-bottom:1px solid var(--border-subtle)}
.hdp-stat{padding:12px 16px;text-align:center;border-right:1px solid var(--border-subtle)}
.hdp-stat:last-child{border-right:none}
.hdp-stat-val{font-family:var(--font-head);font-size:18px;font-weight:700;color:var(--text-primary)}
.hdp-stat-lbl{font-size:10px;color:var(--text-muted);margin-top:2px;text-transform:uppercase;letter-spacing:.05em}
.retention-note{background:var(--amber-bg);border:1px solid rgba(245,166,35,0.2);border-radius:var(--r-md);padding:10px 14px;font-size:12px;color:var(--text-secondary);display:flex;align-items:center;gap:8px;margin-bottom:12px}
.retention-note svg{color:var(--amber);flex-shrink:0}

/* ─── EMPTY STATE ─── */
.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 24px;text-align:center;color:var(--text-muted)}
.empty-state svg{stroke:currentColor;margin-bottom:16px;opacity:.4}
.empty-title{font-size:15px;font-weight:600;color:var(--text-secondary);margin-bottom:6px}
.empty-sub{font-size:13px;color:var(--text-muted);max-width:360px;line-height:1.5}

/* ─── QUICK SEARCH (Overview) ─── */
.quick-search-bar{display:flex;align-items:center;background:var(--bg-card);border:1.5px solid var(--border-strong);border-radius:var(--r-lg);padding:8px 8px 8px 16px;gap:10px;margin-bottom:20px;transition:border-color .2s}
.quick-search-bar:focus-within{border-color:var(--primary)}
.quick-search-bar svg{color:var(--text-muted);flex-shrink:0;stroke:currentColor}
.quick-search-input{flex:1;background:none;border:none;outline:none;color:var(--text-primary);font-family:var(--font-body);font-size:14px;padding:4px 0;min-width:0}
.quick-search-input::placeholder{color:var(--text-muted)}
.quick-lang-select{background:var(--bg-hover);border:1px solid var(--border-strong);color:var(--text-secondary);font-family:var(--font-body);font-size:12px;padding:6px 8px;border-radius:var(--r-sm);outline:none;cursor:pointer;flex-shrink:0}
.quick-search-btn{background:var(--primary);color:#fff;border:none;border-radius:var(--r-sm);padding:9px 18px;font-family:var(--font-body);font-size:13px;font-weight:600;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:opacity .2s}
.quick-search-btn:hover{opacity:.9}
.longtail-toggle{display:flex;align-items:center;gap:5px;cursor:pointer;font-size:12px;color:var(--text-secondary);white-space:nowrap;flex-shrink:0;user-select:none}
.longtail-toggle input[type="checkbox"]{width:13px;height:13px;accent-color:var(--primary);cursor:pointer;flex-shrink:0;margin:0}

/* ─── RESPONSIVE ─── */
@media(max-width:1024px){
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .overview-two-col{grid-template-columns:1fr}
  .explorer-results{flex-direction:column}
  .insight-panel{width:100%;min-width:unset;position:static}
  .history-layout{flex-direction:column}
  .history-list-panel{width:100%;min-width:unset}
  .lists-layout{flex-direction:column}
  .lists-sidebar-panel{width:100%;min-width:unset}
  .list-detail{width:100%}
}

@media(max-width:768px){
  :root{--sidebar-w:0px}
  .sidebar{position:fixed;left:-240px;width:240px;min-width:240px;z-index:300;transition:left .25s;height:100vh;top:0}
  .sidebar.open{left:0}
  .mobile-menu-btn{display:flex}
  .main-content{width:100%}
  .stats-grid{grid-template-columns:1fr 1fr}
  .page-inner{padding:16px 16px 40px}
  .search-bar-wrap{flex-wrap:wrap}
  .search-btn{width:100%;justify-content:center}
  .lang-select{max-width:none}
  .quick-search-bar{flex-wrap:wrap}
  .quick-search-btn{width:100%;justify-content:center;margin-top:4px}
}

@media(max-width:480px){
  .stats-grid{grid-template-columns:1fr}
  .ideas-tabs{overflow-x:auto}
  .ideas-tab{white-space:nowrap}
}

/* ─── INSIGHT PANEL STICKY FIX ─── */
.explorer-results { align-items: flex-start; }
.insight-panel { position: sticky; top: 20px; transition: top 0.2s; }

/* ─── INSIGHT TIP ─── */
.insight-tip { display: flex; align-items: center; gap: 5px; font-size: 11px; color: var(--text-muted); background: var(--bg-card); border: 1px solid var(--border-subtle); border-radius: var(--r-sm); padding: 5px 10px; }
.insight-tip svg { stroke: currentColor; flex-shrink: 0; }

/* ─── MODAL ─── */
.modal-overlay { position: fixed; inset: 0; background: rgba(0,0,0,0.6); z-index: 500; display: flex; align-items: center; justify-content: center; backdrop-filter: blur(4px); }
.modal { background: var(--bg-card); border: 1px solid var(--border-strong); border-radius: var(--r-xl); width: 100%; max-width: 420px; margin: 16px; box-shadow: 0 24px 48px rgba(0,0,0,0.4); max-height: 90vh; display: flex; flex-direction: column; }
.modal-header { display: flex; align-items: center; justify-content: space-between; padding: 18px 20px 0; }
.modal-title { font-family: var(--font-head); font-size: 15px; font-weight: 600; color: var(--text-primary); }
.modal-close { background: none; border: none; color: var(--text-muted); cursor: pointer; padding: 4px; border-radius: var(--r-sm); display: flex; transition: color .15s; }
.modal-close:hover { color: var(--text-primary); }
.modal-body { padding: 16px 20px; overflow-y: auto; flex: 1; }
.modal-label { display: block; font-size: 12px; font-weight: 600; color: var(--text-secondary); margin-bottom: 6px; }
.modal-input { width: 100%; background: var(--bg-secondary); border: 1.5px solid var(--border-strong); border-radius: var(--r-md); padding: 10px 14px; font-family: var(--font-body); font-size: 14px; color: var(--text-primary); outline: none; transition: border-color .2s; }
.modal-input:focus { border-color: var(--primary); }
.modal-hint { font-size: 12px; color: var(--text-muted); margin-top: 6px; }
.modal-footer { display: flex; gap: 8px; justify-content: flex-end; padding: 0 20px 18px; }
.modal-btn-cancel { background: none; border: 1px solid var(--border-strong); border-radius: var(--r-md); padding: 8px 16px; font-family: var(--font-body); font-size: 13px; color: var(--text-secondary); cursor: pointer; transition: border-color .15s; }
.modal-btn-cancel:hover { border-color: var(--text-muted); }
.modal-btn-confirm { background: var(--primary); color: #fff; border: none; border-radius: var(--r-md); padding: 8px 18px; font-family: var(--font-body); font-size: 13px; font-weight: 600; cursor: pointer; transition: opacity .2s; }
.modal-btn-confirm:hover { opacity: .9; }

/* ─── BOTTOM SHEET (mobile insight panel) ─── */
.bottom-sheet-overlay { position: fixed; inset: 0; background: rgba(0,0,0,0.5); z-index: 400; }
.bottom-sheet { position: fixed; bottom: 0; left: 0; right: 0; background: var(--bg-card); border: 1px solid var(--border-strong); border-bottom: none; border-radius: 18px 18px 0 0; z-index: 401; padding: 0 20px 32px; max-height: 70vh; overflow-y: auto; transform: translateY(100%); transition: transform 0.28s cubic-bezier(0.32,0.72,0,1); }
.bottom-sheet.open { transform: translateY(0); }
.bottom-sheet-handle { width: 36px; height: 4px; background: var(--border-strong); border-radius: 2px; margin: 12px auto 16px; }
.bottom-sheet-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px; }
.bottom-sheet-body { display: flex; flex-direction: column; gap: 10px; }

/* ─── TOAST ─── */
.toast { position: fixed; bottom: 24px; left: 50%; transform: translateX(-50%) translateY(16px); background: var(--bg-card); border: 1px solid var(--border-strong); border-radius: var(--r-lg); padding: 10px 18px; font-size: 13px; color: var(--text-primary); z-index: 600; opacity: 0; transition: opacity .25s, transform .25s; white-space: nowrap; box-shadow: 0 8px 24px rgba(0,0,0,0.3); pointer-events: none; }
.toast.show { opacity: 1; transform: translateX(-50%) translateY(0); }

/* ─── SETTINGS PAGE ─── */
.settings-wrap { max-width: 640px; width: 100%; display: flex; flex-direction: column; gap: 24px; box-sizing: border-box; }
.settings-section-title { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; color: var(--text-muted); margin-bottom: 8px; }
.settings-card { background: var(--bg-card); border: 1px solid var(--border-subtle); border-radius: var(--r-xl); overflow: hidden; }
.settings-row { display: flex; align-items: center; justify-content: space-between; padding: 16px 20px; gap: 16px; }
.settings-row-label { flex: 1; min-width: 0; }
.settings-row-title { display: block; font-size: 14px; font-weight: 500; color: var(--text-primary); margin-bottom: 2px; }
.settings-row-sub { display: block; font-size: 12px; color: var(--text-muted); }
.settings-divider { border: none; border-top: 1px solid var(--border-subtle); margin: 0; }
.settings-btn { background: none; border: 1px solid var(--border-strong); border-radius: var(--r-md); padding: 7px 14px; font-family: var(--font-body); font-size: 13px; color: var(--text-secondary); cursor: pointer; white-space: nowrap; transition: border-color .15s, color .15s; flex-shrink: 0; }
.settings-btn:hover { border-color: var(--primary-border); color: var(--text-primary); }
.settings-btn-primary { background: var(--primary); color: #fff; border-color: transparent !important; }
.settings-btn-primary:hover { opacity: .9; }
.settings-btn-danger { color: var(--red) !important; border-color: rgba(255,92,92,0.2) !important; }
.settings-btn-danger:hover { background: var(--red-bg); border-color: var(--red) !important; }
.settings-theme-toggle { display: flex; border: 1px solid var(--border-strong); border-radius: var(--r-md); overflow: hidden; flex-shrink: 0; }
.theme-opt { background: none; border: none; padding: 7px 14px; font-family: var(--font-body); font-size: 13px; color: var(--text-secondary); cursor: pointer; transition: background .15s, color .15s; }
.theme-opt.active { background: var(--primary); color: #fff; }

/* ─── ADMIN ROLE SWITCHER ─── */
.role-switcher{display:flex;align-items:center;gap:6px;background:rgba(255,92,92,0.08);border:1px solid rgba(255,92,92,0.2);border-radius:var(--r-md);padding:6px 14px;margin:6px 10px 2px}
.role-switcher-label{font-size:11px;font-weight:600;color:var(--red);white-space:nowrap}
.role-switcher-select{background:none;border:none;outline:none;font-family:var(--font-body);font-size:12px;font-weight:600;color:var(--text-primary);cursor:pointer;padding:0}
.role-switcher-select option{background:var(--bg-card);color:var(--text-primary)}
.plan-badge.admin{background:rgba(255,92,92,0.1);color:var(--red);border-color:rgba(255,92,92,0.25)}
.plan-badge.free{background:var(--bg-hover);color:var(--text-muted);border-color:var(--border-strong)}
.plan-picker-card{transition:border-color .15s,background .15s}.plan-picker-card:hover{background:var(--bg-hover)}

/* ─── SIDEBAR LEGAL LINKS ─── */
.sidebar-legal{display:flex;align-items:center;gap:5px;padding:6px 16px 8px;flex-wrap:wrap}
.sidebar-legal a{font-size:11px;color:var(--text-muted);text-decoration:none;transition:color .15s}
.sidebar-legal a:hover{color:var(--text-secondary)}
.sidebar-legal span{font-size:11px;color:var(--text-muted);opacity:0.4}

/* ─── SERP ANALYSER ─── */
.serp-wrap{display:flex;flex-direction:column;gap:16px}
.serp-search-bar{display:flex;align-items:center;background:var(--bg-secondary);border:1.5px solid var(--border-strong);border-radius:var(--r-lg);padding:6px 6px 6px 14px;gap:8px;transition:border-color .2s}
.serp-search-bar:focus-within{border-color:var(--primary)}
.serp-input{flex:1;background:none;border:none;outline:none;font-family:var(--font-body);font-size:14px;color:var(--text-primary);min-width:0}
.serp-input::placeholder{color:var(--text-muted)}
.serp-source-badge{display:flex;gap:8px}
#overviewDataBadge,#explorerDataBadge,#ideasDataBadge{margin:8px 0 16px}
.source-badge{font-size:11px;font-weight:600;padding:3px 10px;border-radius:20px;letter-spacing:.03em}
.source-dfs{background:rgba(34,201,122,0.1);color:var(--green);border:1px solid rgba(34,201,122,0.2)}
.source-ai{background:rgba(124,92,255,0.1);color:var(--primary-light);border:1px solid var(--primary-border)}
.serp-grid{display:grid;grid-template-columns:1fr 300px;gap:20px;align-items:start}
.serp-section-title{font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:10px}
.serp-table{display:flex;flex-direction:column;gap:0;border:1px solid var(--border-subtle);border-radius:var(--r-lg);overflow:hidden}
.serp-table-header{display:flex;align-items:center;gap:12px;padding:8px 14px;background:var(--bg-hover);border-bottom:1px solid var(--border-subtle);font-size:11px;font-weight:600;color:var(--text-muted)}
.serp-result-row{display:flex;align-items:flex-start;gap:12px;padding:12px 14px;border-bottom:1px solid var(--border-subtle);transition:background .15s}
.serp-result-row:last-child{border-bottom:none}
.serp-result-row:hover{background:var(--bg-hover)}
.serp-pos{width:28px;font-size:12px;font-weight:700;color:var(--text-muted);flex-shrink:0;padding-top:2px}
.serp-result-info{flex:1;min-width:0}
.serp-result-title{font-size:13px;font-weight:600;color:var(--primary-light);text-decoration:none;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.serp-result-title:hover{text-decoration:underline}
.serp-result-domain{font-size:11px;color:var(--text-muted);margin:2px 0}
.serp-result-desc{font-size:12px;color:var(--text-secondary);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.serp-metric{width:50px;text-align:center;font-size:12px;font-weight:600;color:var(--text-primary);flex-shrink:0;padding-top:2px}
.serp-featured{background:var(--primary-bg);border:1px solid var(--primary-border);border-radius:var(--r-md);padding:12px 14px;margin-bottom:8px}
.serp-featured-label{font-size:10px;font-weight:700;color:var(--primary-light);text-transform:uppercase;letter-spacing:.08em;margin-bottom:4px}
.serp-featured-answer{font-size:13px;color:var(--text-primary);line-height:1.5;margin-bottom:4px}
.serp-featured-url{font-size:11px;color:var(--text-muted);text-decoration:none}
.serp-paa-item{padding:8px 12px;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--r-md);font-size:13px;color:var(--text-primary);margin-bottom:6px}
.serp-related-grid{display:flex;flex-wrap:wrap;gap:6px}
.serp-related-tag{background:var(--bg-hover);border:1px solid var(--border-subtle);border-radius:20px;padding:4px 12px;font-size:12px;color:var(--text-secondary);cursor:default}
.serp-analysis-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--r-lg);padding:16px;position:sticky;top:70px}
.serp-analysis-title{font-family:var(--font-head);font-size:14px;font-weight:700;color:var(--text-primary);margin-bottom:14px}
.serp-opp-score{text-align:center;margin-bottom:14px}
.serp-opp-num{font-family:var(--font-head);font-size:36px;font-weight:700;line-height:1}
.serp-opp-lbl{font-size:11px;color:var(--text-muted);margin-top:2px}
.serp-analysis-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.serp-analysis-lbl{font-size:11px;font-weight:600;color:var(--text-muted)}
.serp-analysis-note{font-size:12px;color:var(--text-secondary);line-height:1.5;margin-bottom:8px}
.serp-divider{border:none;border-top:1px solid var(--border-subtle);margin:12px 0}
.serp-heading-item{font-size:12px;color:var(--text-primary);padding:5px 8px;background:var(--bg-hover);border-radius:var(--r-sm);margin-bottom:4px}
.serp-gap-item{display:flex;align-items:flex-start;gap:6px;font-size:12px;color:var(--text-secondary);margin-bottom:6px}
@media(max-width:900px){.serp-grid{grid-template-columns:1fr}.serp-analysis-card{position:static}}

/* ── INSIGHT FLOATING MODAL ── */
.insight-modal{
  background:var(--bg-card);
  border:1px solid var(--border-strong);
  border-radius:14px;
  padding:20px;
  width:100%;
  max-width:340px;
  max-height:90vh;
  overflow-y:auto;
  position:relative;
  box-shadow:0 8px 40px rgba(0,0,0,0.5);
  animation:insightIn .15s ease;
}
@keyframes insightIn{from{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}
.insight-modal-close{
  position:absolute;top:12px;right:12px;
  background:none;border:none;cursor:pointer;
  color:var(--text-muted);padding:4px;border-radius:6px;
  line-height:1;
}
.insight-modal-close:hover{background:var(--bg-hover);color:var(--text-primary)}
.insight-modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}

/* Metric pills grid — replaces the old ip-check list */
.ip-checks{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-bottom:12px}
.ip-metric{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--r-md);padding:7px 10px;display:flex;flex-direction:column;gap:2px}
.ip-metric-lbl{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted)}
.ip-metric-win{border-color:rgba(34,201,122,0.25);background:var(--green-bg)}
.ip-metric-val{font-size:12px;font-weight:600;color:var(--text-primary)}

@media(max-width:600px){
  .insight-modal{max-width:100%;border-radius:10px}
  .modal-overlay{align-items:flex-end;padding:0}
  .insight-modal{border-bottom-left-radius:0;border-bottom-right-radius:0;padding-bottom:32px}
}

/* ── CONTENT BRIEF SECTION (inside insight modal) ── */
.ip-brief-header{display:flex;align-items:center;gap:5px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);margin-bottom:8px}
.ip-brief-header svg{stroke:var(--primary-light);flex-shrink:0}
.ip-brief-row{display:flex;flex-direction:column;gap:2px;margin-bottom:7px}
.ip-brief-lbl{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted)}
.ip-brief-val{font-size:12px;color:var(--text-secondary);line-height:1.4}
.ip-brief-tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px}
.ip-brief-tag{font-size:10px;background:var(--primary-bg);color:var(--primary-light);border:1px solid var(--primary-border);border-radius:20px;padding:2px 8px;line-height:1.5}
.ip-brief-lock{background:var(--amber-bg);border:1px solid rgba(245,166,35,0.2);border-radius:var(--r-md);padding:10px 12px;font-size:11px;color:var(--text-secondary);display:flex;align-items:flex-start;gap:6px;line-height:1.4;margin-bottom:10px}
.ip-brief-lock svg{stroke:var(--amber);flex-shrink:0;margin-top:1px}
.ip-brief-loading{display:flex;flex-direction:column;gap:6px;padding:4px 0}
.ip-brief-skeleton{height:10px;background:var(--bg-secondary);border-radius:4px;width:100%;animation:shimmer 1.4s ease infinite}
@keyframes shimmer{0%,100%{opacity:.4}50%{opacity:.9}}
.ip-brief-outline{display:flex;flex-direction:column;gap:5px;margin-bottom:7px}
.ip-brief-outline-item{display:flex;align-items:flex-start;gap:7px;font-size:12px;color:var(--text-secondary);line-height:1.4}
.ip-brief-outline-num{font-size:9px;font-weight:700;color:var(--primary-light);background:var(--primary-bg);border:1px solid var(--primary-border);border-radius:4px;padding:1px 5px;flex-shrink:0;margin-top:2px}


/* ── LAYER 2 INSIGHT SECTION (inside insight modal) ── */
.ip-insight-wrap{border-top:1px solid var(--border-subtle);margin-top:12px;padding-top:12px}
.ip-insight-loading{display:flex;align-items:center;gap:7px;font-size:11px;color:var(--text-muted);padding:6px 0}
.ip-insight-result{display:flex;flex-direction:column;gap:8px}
.ip-insight-row{display:flex;flex-direction:column;gap:2px}
.ip-insight-lbl{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted)}
.ip-insight-val{font-size:12px;color:var(--text-secondary);line-height:1.5}
.ip-insight-type-row{flex-direction:row;align-items:center;gap:8px;margin-top:2px}
.ip-insight-type-badge{font-size:10px;font-weight:600;background:var(--primary-bg);color:var(--primary-light);border:1px solid var(--primary-border);border-radius:20px;padding:2px 10px;line-height:1.6;white-space:nowrap}
.ip-insight-btn{width:100%;margin-top:10px;padding:8px 14px;background:var(--primary-bg);color:var(--primary-light);border:1px solid var(--primary-border);border-radius:var(--r-md);font-family:var(--font-body);font-size:12px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;transition:background .15s,border-color .15s}
.ip-insight-btn:hover{background:var(--primary);color:#fff;border-color:var(--primary)}
/* ── SEARCH SKELETON ROWS ── */
.skeleton-row td{padding:10px 12px}
.skeleton-cell{height:10px;background:var(--bg-secondary);border-radius:4px;animation:shimmer 1.4s ease infinite}

/* ── BRIEF READY DOT (keyword row indicator) ── */
.brief-dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--primary-light);margin-right:5px;flex-shrink:0;vertical-align:middle;opacity:.8}

/* ── BRIEF GENERATING LABEL ── */
.ip-brief-generating{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--text-muted);margin-bottom:8px;margin-top:4px}
.ip-brief-generating-dot{width:6px;height:6px;border-radius:50%;background:var(--primary-light);flex-shrink:0;animation:pulse-dot 1.2s ease infinite}
@keyframes pulse-dot{0%,100%{opacity:.3;transform:scale(.8)}50%{opacity:1;transform:scale(1)}}

/* ── MOBILE TABLE HORIZONTAL SCROLL ── */
.table-scroll-wrap {width:100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  /* Must be constrained to parent width — critical for scroll containment */
  max-width: 100%;
  width: 100%;
  box-sizing: border-box;
}
.table-scroll-wrap .data-table {
  white-space: nowrap;
}
@media (max-width: 900px) {
  .table-scroll-wrap .data-table {
    table-layout: auto !important;
    min-width: 580px;
  }
}

/* ─────────────────────────────────────────────────────────
   INLINE & JS-INJECTED STYLES — consolidated from app.js
   and index.html inline styles
───────────────────────────────────────────────────────── */

/* ── Keyword difficulty labels ── */
.kd-easy{color:var(--green)}
.kd-med{color:var(--amber)}
.kd-hard{color:var(--red)}

/* ── Disabled action button ── */
.action-btn-disabled{opacity:0.4;cursor:not-allowed}
.action-btn-disabled:hover{border-color:var(--border-strong)!important;color:var(--text-secondary)!important}

/* ── Tooltip on table headers ── */
.th-tooltip{cursor:help;border-bottom:1px dashed var(--border-strong);position:relative}
.th-tooltip::after{content:attr(data-tip);position:absolute;bottom:calc(100% + 6px);left:50%;transform:translateX(-50%);white-space:nowrap;background:var(--surface-raised);color:var(--text-primary);border:1px solid var(--border-strong);border-radius:6px;padding:5px 9px;font-size:11px;font-weight:400;pointer-events:none;opacity:0;transition:opacity .15s;z-index:100}
.th-tooltip:hover::after{opacity:1}

/* ── Insight modal action row ── */
.ip-action-row{display:flex;gap:8px;margin-top:16px;padding-top:14px;border-top:1px solid var(--border-subtle)}
.ip-action-btn{flex:1;padding:8px 12px;border-radius:8px;font-size:12px;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:5px;transition:opacity .15s}
.ip-action-primary{background:var(--primary);color:#fff;border:none}
.ip-action-primary:hover{opacity:.88}
.ip-action-secondary{background:transparent;color:var(--primary-light);border:1px solid var(--primary-dim)}
.ip-action-secondary:hover{background:var(--primary-bg)}

/* ── SERP action row ── */
.serp-action-row{display:flex;gap:8px;margin-top:16px;padding-top:14px;border-top:1px solid var(--border-subtle)}
.serp-action-btn{flex:1;padding:8px 12px;border-radius:8px;font-size:12px;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:5px;transition:opacity .15s}
.serp-action-primary{background:var(--primary);color:#fff;border:none}
.serp-action-primary:hover{opacity:.88}
.serp-action-secondary{background:transparent;color:var(--text-secondary);border:1px solid var(--border-strong)}
.serp-action-secondary:hover{background:var(--surface)}

/* ── Copy buttons (insight + SERP panels) ── */
.ip-copy-btn,.serp-copy-btn{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:2px 4px;border-radius:4px;display:flex;align-items:center;flex-shrink:0;transition:color .15s}
.ip-copy-btn:hover,.serp-copy-btn:hover{color:var(--text-primary)}

/* ── SERP extras ── */
.serp-outlier-flag{color:var(--amber);font-size:11px;font-weight:700;cursor:help}
.serp-diversity-warn{cursor:help;font-size:13px}
.serp-feature-list{display:flex;flex-direction:column;gap:8px;margin-top:20px;text-align:left;max-width:360px}
.serp-feature-item{display:flex;align-items:flex-start;gap:8px;font-size:13px;color:var(--text-secondary)}
.serp-feature-item svg{flex-shrink:0;margin-top:2px}
.serp-recent-pill{padding:5px 12px;border-radius:20px;border:1px solid var(--border-strong);background:transparent;color:var(--text-secondary);font-size:12px;cursor:pointer;transition:border-color .15s,color .15s;white-space:nowrap}
.serp-recent-pill:hover{border-color:var(--primary-light);color:var(--primary-light)}

/* ── Continue your work ── */
.cyw-item{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--border-subtle)}
.cyw-item:last-child{border-bottom:none}
.cyw-dot{font-size:10px;flex-shrink:0;line-height:1}
.cyw-body{flex:1;min-width:0}
.cyw-topic{font-size:13px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cyw-meta{font-size:11px;color:var(--text-muted);margin-top:2px}
.cyw-actions{display:flex;gap:6px;flex-shrink:0}
.cyw-btn{padding:5px 10px;border-radius:6px;font-size:11px;font-weight:500;cursor:pointer;white-space:nowrap}
.cyw-btn-primary{background:var(--primary);color:#fff;border:none}
.cyw-btn-primary:hover{opacity:.88}
.cyw-btn-secondary{background:transparent;color:var(--primary-light);border:1px solid var(--primary-dim)}
.cyw-btn-secondary:hover{background:var(--primary-bg)}

/* ── Keyword selection states ── */
#resultsBody tr.kw-selected{background:var(--primary-bg);box-shadow:inset 3px 0 0 var(--primary)}
#resultsBody tr.kw-selected td{background:transparent}
tr.kw-bulk-selected{background:var(--primary-bg)!important;box-shadow:inset 3px 0 0 var(--primary)}
tr.kw-bulk-selected td{background:transparent!important}
.kw-cb{flex-shrink:0}

/* ── Bulk selection bar ── */
/* ── Bulk selection bar — desktop ── */
.bulk-sel-bar{position:fixed;z-index:300;display:flex;align-items:center;gap:0;background:var(--primary);color:#fff;padding:10px 16px;box-shadow:0 2px 16px rgba(100,60,255,.5);border-radius:6px;box-sizing:border-box}
.bulk-sel-left{display:flex;align-items:center;gap:10px;padding-right:16px;border-right:1px solid rgba(255,255,255,.25);margin-right:16px}
.bulk-sel-actions{display:flex;align-items:center;gap:6px;flex:1}
.bulk-action-btn{padding:5px 12px;border-radius:5px;font-size:12px;font-weight:600;cursor:pointer;background:rgba(255,255,255,.22);color:#fff;border:1px solid rgba(255,255,255,.5);display:flex;align-items:center;gap:5px;transition:background .15s,border-color .15s;white-space:nowrap;line-height:1.4}
.bulk-action-btn:hover{background:rgba(255,255,255,.38);border-color:rgba(255,255,255,.8)}
.bulk-action-primary{background:rgba(255,255,255,.35);border-color:rgba(255,255,255,.7)}
.bulk-action-danger{background:rgba(255,92,92,.3);border-color:rgba(255,92,92,.5)}
.bulk-action-danger:hover{background:rgba(255,92,92,.5)}
.bulk-sel-close{margin-left:auto;background:transparent;border:none;color:rgba(255,255,255,.8);cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center}
.bulk-sel-close:hover{color:#fff;background:rgba(255,255,255,.15)}

/* ── Bulk selection bar — mobile bottom sheet ── */
@media(max-width:768px){
  .bulk-sel-bar{
    left:0!important;right:0!important;bottom:0!important;top:auto!important;
    width:100%!important;
    border-radius:10px 10px 0 0;
    flex-direction:column;
    align-items:stretch;
    gap:6px;
    padding:10px 12px 16px;
    transform:none!important;
  }
  .bulk-sel-left{
    border-right:none;
    border-bottom:1px solid rgba(255,255,255,.15);
    padding-right:0;
    margin-right:0;
    padding-bottom:8px;
    justify-content:space-between;
    width:100%;
  }
  .bulk-sel-actions{
    flex-wrap:nowrap;
    gap:6px;
  }
  .bulk-action-btn{
    flex:1;
    justify-content:center;
    padding:8px 4px;
    font-size:0;
    gap:0;
  }
  .bulk-action-btn svg{
    width:15px;
    height:15px;
    flex-shrink:0;
  }
  body.bulk-bar-active .page{
    padding-bottom:110px;
  }
}

/* ── Keyword Enrichment (analysis page) ── */
.analysis-progress-track{height:4px;background:var(--border-subtle);border-radius:2px;overflow:hidden}
.analysis-progress-fill{height:100%;background:var(--primary);border-radius:2px;transition:width .4s ease}
.analysis-skeleton-row{display:flex;gap:8px;padding:10px 0;border-bottom:1px solid var(--border-subtle);align-items:center}
.analysis-skeleton-cell{height:12px;background:var(--border-subtle);border-radius:4px;animation:skeleton-pulse 1.4s ease-in-out infinite}
@keyframes skeleton-pulse{0%,100%{opacity:1}50%{opacity:0.4}}

/* ── Input error state ── */
.input-error{border-color:var(--red)!important;animation:shake .3s ease}
@keyframes shake{0%,100%{transform:translateX(0)}25%{transform:translateX(-4px)}75%{transform:translateX(4px)}}

/* ── Settings extras ── */
.settings-row-redirect{font-size:11px;color:var(--text-muted);margin-top:2px;font-style:italic}

/* ── Team permissions ── */
.team-permissions-wrap{padding:12px 0 4px}
.team-permissions-title{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:10px}
.team-permissions-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px 16px}
.team-perm-item{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-secondary)}
.team-perm-yes svg,.team-perm-no svg{flex-shrink:0}
.team-perm-no{color:var(--text-muted)}

/* ── List rename button (appears on hover) ── */
.lni-rename-btn{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:2px;border-radius:3px;display:none;align-items:center;transition:color .15s}
.list-nav-item:hover .lni-rename-btn{display:flex}
.lni-rename-btn:hover{color:var(--text-primary)}

/* ── From index.html inline styles ── */
.stat-value-top-opp{font-size:14px;margin-top:4px}
.continue-work-section{margin-top:20px}
.kw-tabs{display:flex;gap:4px;margin-bottom:16px;border-bottom:1px solid var(--border);padding-bottom:0}
.kw-tab{padding:8px 16px;font-size:13px;font-weight:500;background:none;border:none;border-bottom:2px solid transparent;color:var(--text-secondary);cursor:pointer;transition:all .15s}
.kw-tab.active{color:var(--primary-light);border-bottom-color:var(--primary)}
.kw-explore-pane{flex:1;min-width:0}
.sort-label{font-size:12px;color:var(--text-muted);white-space:nowrap}
.analysis-back-link{color:var(--text-muted);font-size:12px;text-decoration:none;display:flex;align-items:center;gap:4px}
.analysis-back-link:hover{color:var(--text-secondary)}
.analysis-kw-label{font-size:13px;font-weight:600;color:var(--text-primary)}
.analysis-task-counter{font-size:12px;color:var(--text-muted)}
.analysis-textarea{width:100%;box-sizing:border-box;background:var(--surface);border:1px solid var(--border-strong);border-radius:8px;padding:12px 14px;font-size:13px;color:var(--text-primary);resize:vertical;font-family:inherit;line-height:1.6}
.analysis-hint{font-size:12px;color:var(--text-muted)}
.analysis-error{margin-top:10px;font-size:13px;color:var(--red);background:var(--red-bg);border:1px solid rgba(255,92,92,0.2);border-radius:8px;padding:10px 14px}
.analysis-data-notice{font-size:12px;color:var(--text-muted);background:var(--surface);border:1px solid var(--border-subtle);border-radius:8px;padding:10px 14px;margin-bottom:12px}
.analysis-summary{display:flex;gap:10px;align-items:center;font-size:13px;flex-wrap:wrap}
.analysis-results-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.history-date-filter{margin-top:6px;width:100%}
.auth-gate-legal{margin-top:24px;display:flex;gap:6px;align-items:center;font-size:11px;color:#888}
.auth-gate-legal a{color:#888;text-decoration:none}
.bulk-count{font-size:13px;font-weight:500}

/* ── Analysis page layout helpers (from inline styles) ── */
.analysis-back-row{display:flex;align-items:center;gap:8px;margin-bottom:12px}
.analysis-input-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.analysis-lang-row{display:flex;align-items:center;gap:10px;margin-top:10px}
.analysis-progress-wrap{margin-top:16px}
.analysis-status-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}
.analysis-skeleton-rows{margin-top:12px}
.analysis-results-section{margin-top:24px}
.analysis-empty{padding:60px 0}

/* ─── PAID SEARCH DATA — MOBILE REDESIGN ─── */
@media (max-width: 768px) {

  /* Input header: stack label above counter */
  .analysis-input-header {
    flex-direction: column;
    align-items: flex-start;
    gap: 4px;
  }

  /* Lang row: stack lang select, button, and hint vertically */
  .analysis-lang-row {
    flex-direction: column;
    align-items: stretch;
    gap: 8px;
  }

  /* Lang select full width */
  .analysis-lang-row .lang-select {
    max-width: none;
    width: 100%;
  }

  /* Button full width */
  .analysis-lang-row .search-btn {
    width: 100%;
    justify-content: center;
  }

  /* Hint sits below button, centered */
  .analysis-hint {
    text-align: center;
    width: 100%;
  }

  /* Results toolbar: stack summary above export button */
  .analysis-results-toolbar {
    flex-direction: column;
    align-items: flex-start;
    gap: 10px;
  }

  /* Export button full width on mobile */
  .analysis-results-toolbar .action-btn {
    width: 100%;
    justify-content: center;
  }

  /* Summary pills wrap cleanly */
  .analysis-summary {
    width: 100%;
  }
}

/* ─── SERP ANALYSER — MOBILE REDESIGN ─── */
@media (max-width: 768px) {

  /* Search bar: input on its own row, lang + button share the row below */
  .serp-search-bar {
    flex-wrap: wrap;
    padding: 10px 12px;
    gap: 8px;
  }

  /* Input takes full first row */
  .serp-input {
    width: 100%;
    flex-basis: 100%;
    order: 0;
  }

  /* Lang select and button share second row 50/50 */
  #serpLangSelect {
    flex: 1;
    max-width: none;
    order: 1;
  }

  #serpBtn {
    flex: 1;
    justify-content: center;
    order: 2;
  }

  /* Source badge row: quota counter (#serpQuotaDisplay) wraps to its own line */
  .serp-source-badge {
    flex-wrap: wrap;
    gap: 6px;
    align-items: center;
  }

  #serpQuotaDisplay {
    width: 100%;
    font-size: 11px !important;
  }

  /* Hide position # column in result rows */
  .serp-pos {
    display: none;
  }

  /* Also hide the # header cell (inline-styled span) via table-header first-child */
  .serp-table-header > span:first-child {
    display: none;
  }

  /* Tighten row padding */
  .serp-result-row {
    padding: 10px;
    gap: 8px;
  }

  .serp-table-header {
    padding: 8px 10px;
    gap: 8px;
  }

  /* DA + Backlinks metric columns: shrink to fit */
  .serp-metric {
    width: 38px;
    font-size: 11px;
  }

  /* Allow result titles to wrap instead of truncating off-screen */
  .serp-result-title {
    white-space: normal;
    word-break: break-word;
  }

  /* Action button: already single button, just ensure full width */
  .serp-action-row {
    flex-direction: column;
    gap: 8px;
  }

  .serp-action-btn {
    width: 100%;
  }

  /* Related searches tags: slightly smaller */
  .serp-related-tag {
    font-size: 11px;
    padding: 3px 10px;
  }

  /* Recent keyword pills: horizontal scroll, no wrap */
  #serpRecentPillList {
    flex-wrap: nowrap !important;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    justify-content: flex-start !important;
    padding-bottom: 4px;
  }

  .serp-recent-pill {
    flex-shrink: 0;
  }
}

/* ─── CONTENT WORKSPACE — MOBILE REDESIGN ─── */

/* Article card row: content left, buttons right (desktop) */
.plan-card-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

/* Button column: vertical stack, fixed width (desktop) */
.plan-card-btns {
  display: flex;
  flex-direction: column;
  gap: 4px;
  flex-shrink: 0;
}

/* Button size (desktop) */
.plan-card-btn {
  font-size: 11px;
  padding: 3px 10px;
  white-space: nowrap;
}

/* Keyword display line */
.plan-kw-display {
  font-size: 11px;
  color: var(--text-muted);
  margin-bottom: 4px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* Plan summary box: contain long text */
.plan-summary-box {
  overflow-x: hidden;
  word-break: break-word;
}

/* List detail: constrain width and contain overflow */
.list-detail {
  min-width: 0;
  max-width: 100%;
  overflow-x: hidden;
  box-sizing: border-box;
}

@media (max-width: 768px) {

  /* List detail header: stack title+meta above action buttons */
  .list-detail-header {
    flex-direction: column;
    align-items: flex-start;
    gap: 10px;
  }

  /* Action buttons row: full width */
  .list-actions {
    width: 100%;
  }

  .list-actions .action-btn {
    flex: 1;
    justify-content: center;
  }

  /* Article card: stack content above buttons */
  .plan-card-row {
    flex-direction: column;
    gap: 10px;
  }

  /* Buttons: side by side, full width */
  .plan-card-btns {
    flex-direction: row;
    width: 100%;
    gap: 8px;
  }

  .plan-card-btn {
    flex: 1;
    justify-content: center;
    text-align: center;
  }

  /* Keyword display: wrap instead of truncate */
  .plan-kw-display {
    white-space: normal;
    overflow: visible;
    text-overflow: unset;
  }
}
