@import url('https://fonts.googleapis.com/css2?family=Public+Sans:wght@400;500;600;700;800&family=Archivo:wght@500;600;700;800&family=IBM+Plex+Mono:wght@400;500;600&display=swap');

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

:root{
  /* hue driven accent — data-accent sets the hue, theme sets L/C */
  --accent-h:255;
  --font:'Public Sans',system-ui,sans-serif;
  --font-display:'Public Sans',system-ui,sans-serif;
  --mono:'IBM Plex Mono','JetBrains Mono',monospace;
  --r:8px; --rl:14px; --rs:6px;

  /* density */
  --pad-card:24px; --gap:18px; --pad-ctrl:10px 13px;

  /* fluid type */
  --fz-xs:clamp(11px,1.05vw,12.5px);
  --fz-sm:clamp(12px,1.15vw,13.5px);
  --fz-base:clamp(13.5px,1.3vw,15px);
  --fz-md:clamp(15px,1.5vw,17px);
  --fz-xl:clamp(26px,4vw,44px);
  --fz-mono:clamp(24px,2.4vw,34px);

  /* ---- LIGHT THEME (default) ---- */
  --surface:#ffffff;
  --canvas:oklch(0.985 0.003 255);
  --bg:var(--surface);
  --bg2:oklch(0.972 0.004 255);
  --bg3:oklch(0.948 0.006 255);
  --nav-bg:rgba(255,255,255,.82);
  --border:oklch(0.905 0.006 255);
  --border2:oklch(0.83 0.008 255);
  --text:oklch(0.255 0.018 262);
  --text2:oklch(0.47 0.014 262);
  --text3:oklch(0.62 0.011 262);

  --green:oklch(0.585 0.12 152);
  --amber:oklch(0.66 0.13 70);
  --red:oklch(0.555 0.19 27);
  --purple:oklch(0.52 0.15 290);

  --accent:oklch(0.52 0.145 var(--accent-h));
  --accent-contrast:#fff;
  --accent-bg:color-mix(in oklab, oklch(0.6 0.15 var(--accent-h)) 11%, var(--surface));
  --accent-border:color-mix(in oklab, oklch(0.55 0.15 var(--accent-h)) 32%, var(--surface));

  --green-bg:color-mix(in oklab, var(--green) 12%, var(--surface));
  --green-border:color-mix(in oklab, var(--green) 34%, var(--surface));
  --amber-bg:color-mix(in oklab, var(--amber) 14%, var(--surface));
  --amber-border:color-mix(in oklab, var(--amber) 36%, var(--surface));
  --red-bg:color-mix(in oklab, var(--red) 11%, var(--surface));
  --red-border:color-mix(in oklab, var(--red) 30%, var(--surface));
  --purple-bg:color-mix(in oklab, var(--purple) 11%, var(--surface));
  --purple-border:color-mix(in oklab, var(--purple) 30%, var(--surface));

  --shadow-sm:0 1px 2px rgba(16,24,40,.04), 0 1px 3px rgba(16,24,40,.05);
  --shadow-md:0 4px 16px -4px rgba(16,24,40,.10), 0 2px 6px -2px rgba(16,24,40,.06);
  --shadow-lg:0 18px 44px -12px rgba(16,24,40,.22);
}

[data-theme="dark"]{
  --surface:oklch(0.262 0.013 263);
  --canvas:oklch(0.198 0.011 263);
  --bg:var(--surface);
  --bg2:oklch(0.295 0.014 263);
  --bg3:oklch(0.335 0.015 263);
  --nav-bg:color-mix(in oklab, oklch(0.262 0.013 263) 80%, transparent);
  --border:oklch(0.37 0.013 263);
  --border2:oklch(0.46 0.014 263);
  --text:oklch(0.955 0.005 263);
  --text2:oklch(0.75 0.012 263);
  --text3:oklch(0.62 0.013 263);

  --green:oklch(0.72 0.14 155);
  --amber:oklch(0.79 0.13 75);
  --red:oklch(0.66 0.18 27);
  --purple:oklch(0.7 0.15 290);

  --accent:oklch(0.72 0.13 var(--accent-h));
  --accent-contrast:oklch(0.2 0.02 263);
  --accent-bg:color-mix(in oklab, oklch(0.7 0.14 var(--accent-h)) 16%, var(--surface));
  --accent-border:color-mix(in oklab, oklch(0.72 0.14 var(--accent-h)) 38%, var(--surface));

  --shadow-sm:0 1px 2px rgba(0,0,0,.4);
  --shadow-md:0 6px 20px -6px rgba(0,0,0,.55);
  --shadow-lg:0 22px 50px -14px rgba(0,0,0,.6);
}

[data-accent="cobalt"]{--accent-h:255}
[data-accent="teal"]{--accent-h:200}
[data-accent="indigo"]{--accent-h:288}
[data-accent="ember"]{--accent-h:47}

[data-font="archivo"]{--font-display:'Archivo',system-ui,sans-serif}

[data-density="compact"]{--pad-card:16px; --gap:12px; --pad-ctrl:8px 11px}

html{background:var(--canvas)}
body{
  background:var(--canvas);
  color:var(--text);
  font-family:var(--font);
  font-size:var(--fz-base);
  line-height:1.5;
  min-height:100vh;
  display:flex;
  flex-direction:column;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
::selection{background:var(--accent-bg)}

/* subtle top sheen, no busy image */
body::before{
  content:'';position:fixed;inset:0 0 auto 0;height:340px;z-index:0;pointer-events:none;
  background:
    radial-gradient(120% 100% at 50% -20%, color-mix(in oklab, oklch(0.6 0.15 var(--accent-h)) 9%, transparent), transparent 70%);
}

.topbar-wrap,.main,footer{position:relative;z-index:1}
#settings-panel,#appearance-panel{position:relative;z-index:5}

/* ---------- HEADER ---------- */
.topbar-wrap{
  position:sticky;top:0;z-index:100;
  display:flex;align-items:center;justify-content:center;
  padding:0;
}
.topbar{
  width:100%;max-width:none;
  background:var(--nav-bg);
  backdrop-filter:saturate(160%) blur(14px);
  -webkit-backdrop-filter:saturate(160%) blur(14px);
  border-bottom:1px solid var(--border);
  border-radius:0;
  padding:11px max(20px, calc((100% - 1240px)/2));
  display:flex;align-items:center;gap:8px;
  pointer-events:auto;
  transition:box-shadow .2s,border-color .2s;
}
.topbar.scrolled{box-shadow:var(--shadow-sm)}
.logo{
  display:flex;align-items:center;gap:11px;
  font-family:var(--font-display);
  font-size:16px;font-weight:700;color:var(--text);
  letter-spacing:-.015em;margin-right:auto;text-decoration:none;
}
.logo>span{display:flex;flex-direction:column;line-height:1.15;white-space:nowrap}
.logo small{display:block;font-size:10.5px;font-weight:500;color:var(--text3);letter-spacing:.04em;margin-top:1px}
.logo-shield{
  width:34px;height:34px;
  background:linear-gradient(160deg, color-mix(in oklab, var(--accent) 88%, white), var(--accent));
  border-radius:9px;display:flex;align-items:center;justify-content:center;flex-shrink:0;
  box-shadow:0 2px 6px -1px color-mix(in oklab, var(--accent) 45%, transparent);
}
.topbar-nav{display:flex;gap:2px}
.tnav{
  padding:7px 13px;border-radius:var(--r);
  font-size:var(--fz-sm);font-weight:600;cursor:pointer;
  color:var(--text2);background:transparent;border:none;
  font-family:var(--font);letter-spacing:-.005em;
  transition:background .15s,color .15s;
  display:inline-flex;align-items:center;gap:6px;
}
.tnav:hover{background:var(--bg3);color:var(--text)}
.tnav.active{background:var(--accent-bg);color:var(--accent)}
.pill{font-size:10px;font-weight:700;padding:1px 7px;border-radius:999px;line-height:1.5;font-family:var(--mono)}
.pill-amber{background:var(--amber-bg);color:var(--amber)}
.pill-purple{background:var(--purple-bg);color:var(--purple)}

.icon-btn{
  background:transparent;border:1px solid transparent;padding:7px 11px;
  color:var(--text2);cursor:pointer;display:flex;align-items:center;gap:6px;
  font-size:var(--fz-sm);font-weight:600;border-radius:var(--r);flex-shrink:0;
  font-family:var(--font);transition:background .15s,color .15s,border-color .15s;
}
.icon-btn:hover{background:var(--bg3);color:var(--text)}

.status-pill{
  display:flex;align-items:center;gap:7px;font-size:11px;font-weight:600;
  padding:5px 11px;border-radius:999px;
  background:var(--green-bg);border:1px solid var(--green-border);color:var(--green);flex-shrink:0;
  font-family:var(--mono);letter-spacing:-.01em;
}
.status-pill.offline{background:var(--red-bg);border-color:var(--red-border);color:var(--red)}
.status-pill.stub{background:var(--amber-bg);border-color:var(--amber-border);color:var(--amber)}
.dot{width:7px;height:7px;border-radius:50%}
.dot-green{background:var(--green)}.dot-red{background:var(--red)}.dot-amber{background:var(--amber)}

.mob-toggle{display:none;background:none;border:none;cursor:pointer;color:var(--text2);padding:6px;margin-left:auto}
@media (max-width:1024px){
  .topbar-nav{display:none!important}
  .mob-toggle{display:flex!important}
  .btn-label{display:none}
  .logo small{display:none}
}
@media (max-width:560px){
  .hide-sm{display:none!important}
}

/* ---------- LAYOUT ---------- */
.main{
  flex:1;width:100%;max-width:1240px;margin:0 auto;
  padding:clamp(20px,3vw,40px) max(20px, calc((100% - 1240px)/2)) 64px;
  display:flex;flex-direction:column;
}
.page{display:none;flex-direction:column;gap:var(--gap);animation:fadeIn .22s ease}
.page.show{display:flex}
@keyframes fadeIn{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}

/* ---------- HERO ---------- */
.hero{
  display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(20px,4vw,56px);
  align-items:center;
  padding:clamp(18px,3vw,40px) 0 clamp(20px,3vw,36px);
  border-bottom:1px solid var(--border);margin-bottom:6px;
}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-size:var(--fz-xs);font-weight:700;letter-spacing:.13em;text-transform:uppercase;
  color:var(--accent);margin-bottom:18px;font-family:var(--mono);
}
.hero-eyebrow::before{content:'';width:22px;height:1.5px;background:var(--accent);display:inline-block}
.hero h1{
  font-family:var(--font-display);font-size:var(--fz-xl);line-height:1.04;
  font-weight:800;letter-spacing:-.03em;color:var(--text);margin-bottom:18px;text-wrap:balance;
}
.hero h1 em{font-style:normal;color:var(--accent)}
.hero-lede{font-size:var(--fz-md);color:var(--text2);line-height:1.55;max-width:46ch;text-wrap:pretty}
.hero-meta{display:flex;flex-wrap:wrap;align-items:center;gap:12px;margin-top:22px}
.hero-actions{display:contents}
.hero-cta{padding:12px 22px;font-size:var(--fz-base);border-radius:var(--r)}
.hero-cta svg{transition:transform .2s}
.hero-cta:hover svg{transform:translateY(2px)}
.hero-cta-note{font-size:var(--fz-xs);color:var(--text3);font-family:var(--mono)}
.hero-chip{
  display:inline-flex;align-items:center;gap:7px;
  padding:7px 13px;border-radius:999px;border:1px solid var(--border);
  background:var(--surface);font-size:var(--fz-xs);font-weight:600;color:var(--text2);
  box-shadow:var(--shadow-sm);
}
.hero-chip svg{color:var(--accent)}
.hero-aside{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--rl);
  padding:22px;box-shadow:var(--shadow-md);display:flex;flex-direction:column;gap:14px;
}
.hero-aside-head{display:flex;align-items:center;justify-content:space-between}
.hero-aside-title{font-size:var(--fz-xs);font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text3)}
.hero-stat{display:flex;flex-direction:column;gap:3px}
.hero-stat .n{font-family:var(--mono);font-size:clamp(22px,2.6vw,30px);font-weight:600;color:var(--text);letter-spacing:-.02em}
.hero-stat .l{font-size:var(--fz-xs);color:var(--text3)}
.hero-band{display:flex;height:10px;border-radius:999px;overflow:hidden;border:1px solid var(--border)}
.hero-band i{display:block;height:100%}
.hero-legend{display:flex;justify-content:space-between;font-size:10.5px;color:var(--text3);font-family:var(--mono)}
@media (max-width:840px){.hero{grid-template-columns:1fr;gap:24px}.hero-aside{order:-1;display:none}}

/* ---------- PAGE HEADERS ---------- */
.page-eyebrow{
  font-size:var(--fz-xs);font-weight:700;color:var(--accent);
  text-transform:uppercase;letter-spacing:.12em;margin-bottom:9px;
  display:flex;align-items:center;gap:7px;font-family:var(--mono);
}
.page-title-gradient{
  font-family:var(--font-display);font-size:clamp(22px,2.6vw,32px);font-weight:800;
  letter-spacing:-.025em;color:var(--text);margin-bottom:7px;line-height:1.1;
  background:none;-webkit-text-fill-color:currentColor;animation:none;
}
.page-desc-sub{font-size:var(--fz-md);color:var(--text2);margin-bottom:6px;max-width:70ch;text-wrap:pretty}

/* ---------- CARDS ---------- */
.card{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--rl);
  padding:var(--pad-card);box-shadow:var(--shadow-sm);
}
.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;gap:12px;flex-wrap:wrap}
.card-title{font-size:var(--fz-sm);font-weight:700;color:var(--text);display:flex;align-items:center;gap:8px;letter-spacing:-.01em}
.card-title svg{color:var(--accent)}
.row2{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,420px),1fr));gap:var(--gap);align-items:stretch}
@media (max-width:860px){.row2{grid-template-columns:1fr}}

/* ---------- FORM ---------- */
textarea,input,select{
  width:100%;background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);
  padding:11px 13px;color:var(--text);font-family:var(--font);font-size:var(--fz-base);
  outline:none;transition:border-color .15s,box-shadow .15s,background .15s;
}
textarea{resize:vertical;line-height:1.6;min-height:130px}
textarea::placeholder{color:var(--text3)}
textarea:focus,input:focus,select:focus{
  border-color:var(--accent);background:var(--surface);
  box-shadow:0 0 0 3.5px color-mix(in oklab, var(--accent) 16%, transparent);
}
select{cursor:pointer;-webkit-appearance:none;appearance:none;
  background-image:linear-gradient(45deg,transparent 50%,var(--text3) 50%),linear-gradient(135deg,var(--text3) 50%,transparent 50%);
  background-position:calc(100% - 16px) center,calc(100% - 11px) center;background-size:5px 5px,5px 5px;background-repeat:no-repeat;padding-right:30px}

input[type=range]{-webkit-appearance:none;appearance:none;height:5px;padding:0;background:var(--bg3);border:none;border-radius:999px}
input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:17px;height:17px;border-radius:50%;background:var(--accent);border:2.5px solid var(--surface);box-shadow:var(--shadow-sm);cursor:pointer}
input[type=range]::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--accent);border:2.5px solid var(--surface);cursor:pointer}
input[type=range]:focus{box-shadow:none}

button{
  padding:9px 16px;border-radius:var(--r);border:1px solid var(--border);
  background:var(--surface);color:var(--text);font-family:var(--font);
  font-size:var(--fz-sm);font-weight:600;cursor:pointer;
  display:inline-flex;align-items:center;gap:7px;
  transition:background .15s,border-color .15s,box-shadow .15s,transform .05s;
}
button:hover{background:var(--bg3);border-color:var(--border2)}
button:active{transform:translateY(.5px)}
button:disabled{opacity:.45;cursor:not-allowed}
button.primary{background:var(--accent);border-color:var(--accent);color:var(--accent-contrast);box-shadow:0 2px 8px -2px color-mix(in oklab, var(--accent) 50%, transparent)}
button.primary:hover{background:color-mix(in oklab, var(--accent) 88%, black);border-color:transparent}
button.success{background:var(--green-bg);border-color:var(--green-border);color:var(--green)}
button.danger{background:var(--red-bg);border-color:var(--red-border);color:var(--red)}
button.purple{background:var(--purple-bg);border-color:var(--purple-border);color:var(--purple)}
.field-label{display:block;font-size:var(--fz-xs);font-weight:700;color:var(--text2);text-transform:uppercase;letter-spacing:.05em;margin-bottom:7px}
/* ---------- BADGES ---------- */
.badge{display:inline-flex;align-items:center;font-size:var(--fz-xs);font-weight:600;font-family:var(--mono);padding:3px 10px;border-radius:999px;letter-spacing:-.01em;white-space:nowrap}
.badge-auto{background:var(--green-bg);color:var(--green);border:1px solid var(--green-border)}
.badge-review{background:var(--amber-bg);color:var(--amber);border:1px solid var(--amber-border)}
.badge-low{background:var(--red-bg);color:var(--red);border:1px solid var(--red-border)}
.badge-approved{background:var(--purple-bg);color:var(--purple);border:1px solid var(--purple-border)}

/* ---------- STAT CARDS ---------- */
.stat-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,170px),1fr));gap:var(--gap)}
.scard{background:var(--surface);border:1px solid var(--border);border-radius:var(--rl);padding:18px 20px;box-shadow:var(--shadow-sm)}
.scard-n{font-size:var(--fz-mono);font-weight:600;font-family:var(--mono);letter-spacing:-.02em;line-height:1.1}
.scard-l{font-size:var(--fz-xs);color:var(--text3);margin-top:5px;font-weight:600;text-transform:uppercase;letter-spacing:.05em}

/* ---------- CONFIDENCE / RESULTS ---------- */
.conf-wrap{margin:14px 0 0}
.conf-header{display:flex;justify-content:space-between;font-size:var(--fz-sm);color:var(--text2);margin-bottom:7px;font-weight:500}
.conf-pct{font-family:var(--mono);font-weight:600;color:var(--text)}
.conf-track{height:8px;background:var(--bg3);border-radius:999px;overflow:hidden}
.conf-fill{height:100%;border-radius:999px;transition:width .6s cubic-bezier(.4,0,.2,1)}
.result-chip{
  display:inline-flex;align-items:center;gap:7px;padding:9px 16px;border-radius:var(--r);
  background:var(--accent-bg);font-size:var(--fz-md);font-weight:700;color:var(--accent);
  border:1px solid var(--accent-border);letter-spacing:-.01em;
}

/* ---------- CONTROL GRID ---------- */
.ctrl-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,170px),1fr));gap:12px}
.ctrl-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:var(--pad-ctrl)}
.ctrl-key{font-size:10.5px;color:var(--text3);font-family:var(--mono);text-transform:uppercase;letter-spacing:.07em;margin-bottom:5px}
.ctrl-val{font-size:var(--fz-sm);font-weight:600;color:var(--text)}

/* ---------- TABLE ---------- */
.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;border:1px solid var(--border);border-radius:var(--r)}
table{width:100%;border-collapse:collapse;font-size:var(--fz-sm)}
th{text-align:left;padding:11px 14px;font-size:var(--fz-xs);font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border);background:var(--bg2)}
td{padding:12px 14px;border-bottom:1px solid var(--border);color:var(--text2)}
td.bold{color:var(--text);font-weight:600}
tr:last-child td{border-bottom:none}
tbody tr{transition:background .12s}
tr:hover td{background:var(--bg2)}

/* ---------- UPLOAD ---------- */
.upload-zone{border:1.5px dashed var(--border2);border-radius:var(--rl);padding:52px 24px;text-align:center;cursor:pointer;transition:border-color .2s,background .2s;background:var(--surface)}
.upload-zone:hover,.upload-zone.drag-over{border-color:var(--accent);background:var(--accent-bg)}

/* ---------- QUEUE ITEMS ---------- */
.queue-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--rl);padding:16px;display:flex;flex-direction:column;gap:11px;box-shadow:var(--shadow-sm)}
.queue-text{font-size:var(--fz-sm);color:var(--text);line-height:1.6}
.queue-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.correct-form{display:flex;align-items:center;gap:9px;margin-top:4px;padding:11px 13px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--r)}
.correct-form select{flex:1;font-size:var(--fz-xs);padding:7px 11px}

/* ---------- CATEGORY BARS ---------- */
.cat-bar-row{display:flex;flex-direction:column;gap:5px;margin-bottom:13px}
.cat-bar-header{display:flex;justify-content:space-between;font-size:var(--fz-sm);color:var(--text2)}
.cat-bar-track{height:7px;background:var(--bg3);border-radius:999px;overflow:hidden}
.cat-bar-fill{height:100%;border-radius:999px;background:var(--accent);transition:width .5s ease}

/* ---------- MISC ---------- */
.placeholder-msg{color:var(--text3);font-size:var(--fz-sm);text-align:center;padding:40px;background:var(--bg2);border-radius:var(--r);border:1px dashed var(--border)}
.error-msg{color:var(--red);font-size:var(--fz-sm);padding:13px 15px;background:var(--red-bg);border:1px solid var(--red-border);border-radius:var(--r);margin-bottom:8px}
.spinner{display:inline-block;width:13px;height:13px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:spin .7s linear infinite}
.review-bulk-bar{display:none;align-items:center;gap:11px;padding:11px 15px;background:var(--accent-bg);border:1px solid var(--accent-border);border-radius:var(--r);margin-bottom:11px;font-size:var(--fz-sm)}
.review-bulk-bar.show{display:flex}
.itab{padding:10px 16px;font-size:var(--fz-sm);cursor:pointer;color:var(--text2);border:none;background:transparent;border-bottom:2px solid transparent;margin-bottom:-1px;font-weight:600;transition:color .15s,border-color .15s;font-family:var(--font)}
.itab:hover{color:var(--text)}
.itab.active{color:var(--accent);border-bottom-color:var(--accent)}

/* ---------- ABOUT ---------- */
.hero-about{background:linear-gradient(150deg, color-mix(in oklab, var(--accent) 92%, black), var(--accent));border-radius:var(--rl);padding:clamp(24px,3vw,36px) clamp(24px,3vw,40px);color:#fff;box-shadow:var(--shadow-md)}
.hero-meta{font-size:var(--fz-xs);font-weight:700;color:rgba(255,255,255,.7);text-transform:uppercase;letter-spacing:.12em;margin-bottom:14px;font-family:var(--mono)}
.hero-title-lg{font-family:var(--font-display);font-size:clamp(18px,2.2vw,26px);font-weight:800;line-height:1.2;margin-bottom:10px;max-width:680px;letter-spacing:-.02em}
.hero-subtitle-sm{font-size:var(--fz-base);color:rgba(255,255,255,.82);margin-bottom:0;max-width:620px}
.about-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--rl);padding:clamp(20px,2.4vw,28px);box-shadow:var(--shadow-sm)}
.about-section-title{font-family:var(--font-display);font-size:var(--fz-md);font-weight:700;color:var(--text);padding-bottom:14px;border-bottom:1px solid var(--border);margin-bottom:18px;letter-spacing:-.01em}
.team-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px}
.team-card-item{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:16px;display:flex;align-items:flex-start;gap:13px;cursor:pointer;transition:border-color .18s,background .18s,transform .1s}
.team-card-item:hover{border-color:var(--accent);background:var(--accent-bg);transform:translateY(-1px)}
.team-avatar{width:44px;height:44px;border-radius:50%;background:var(--accent-bg);border:1.5px solid var(--accent-border);display:flex;align-items:center;justify-content:center;font-size:var(--fz-sm);font-weight:700;color:var(--accent);flex-shrink:0;font-family:var(--mono)}
.team-name-link{font-size:var(--fz-sm);font-weight:700;color:var(--text);margin-bottom:3px}
.team-role-sm{font-size:var(--fz-xs);color:var(--text2);margin-bottom:3px}
.team-inst-sm{font-size:var(--fz-xs);color:var(--text3)}
.about-badge{display:inline-flex;font-size:9.5px;font-weight:700;padding:2px 8px;border-radius:999px;margin-left:6px;font-family:var(--mono);text-transform:uppercase;letter-spacing:.04em}
.about-badge-author{background:var(--accent-bg);color:var(--accent);border:1px solid var(--accent-border)}
.about-badge-supervisor{background:var(--green-bg);color:var(--green);border:1px solid var(--green-border)}
.about-badge-researcher{background:var(--purple-bg);color:var(--purple);border:1px solid var(--purple-border)}
.spec-table-row{display:flex;gap:16px;padding:10px 0;border-bottom:1px solid var(--border)}
.spec-table-row:last-child{border-bottom:none}
.spec-table-key{font-size:var(--fz-xs);color:var(--text3);width:170px;flex-shrink:0}
.spec-table-val{font-size:var(--fz-sm);color:var(--text);font-weight:600}
.resource-row{display:flex;align-items:center;gap:13px;padding:12px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);margin-bottom:8px}
.resource-row:last-child{margin-bottom:0}
.resource-icon-box{width:36px;height:36px;background:var(--accent-bg);border:1px solid var(--accent-border);border-radius:var(--r);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.resource-lbl{font-size:var(--fz-sm);font-weight:700;color:var(--text)}
.resource-sub-sm{font-size:var(--fz-xs);color:var(--text3)}
.resource-link-badge{font-size:10px;font-weight:700;padding:4px 11px;border-radius:999px;background:var(--bg3);color:var(--text2);border:1px solid var(--border);text-decoration:none;white-space:nowrap;font-family:var(--mono)}
.resource-link-badge:hover{background:var(--accent-bg);color:var(--accent);border-color:var(--accent-border)}
.about-placeholder{background:var(--bg2);border:1px dashed var(--border);border-radius:var(--r);padding:15px 18px;font-size:var(--fz-sm);color:var(--text3)}
.about-overview p{font-size:var(--fz-sm);color:var(--text2);line-height:1.8;margin-bottom:14px}
.about-overview p:last-child{margin-bottom:0}
.about-modal-overlay{position:fixed;inset:0;background:color-mix(in oklab, var(--canvas) 30%, rgba(8,12,20,.55));backdrop-filter:blur(3px);z-index:200;display:flex;align-items:center;justify-content:center;padding:24px;opacity:0;pointer-events:none;transition:opacity .2s}
.about-modal-overlay.show{opacity:1;pointer-events:all}
.about-modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--rl);padding:28px;max-width:500px;width:100%;max-height:82vh;overflow-y:auto;position:relative;transform:translateY(16px);transition:transform .2s;box-shadow:var(--shadow-lg)}
.about-modal-overlay.show .about-modal{transform:none}
.about-modal-close{position:absolute;top:14px;right:14px;background:var(--bg3);border:1px solid var(--border);border-radius:50%;width:30px;height:30px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:14px;color:var(--text2)}
.about-modal-close:hover{background:var(--border)}
.modal-avatar-lg{width:60px;height:60px;border-radius:50%;background:var(--accent-bg);border:1.5px solid var(--accent-border);display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700;color:var(--accent);flex-shrink:0;font-family:var(--mono)}
.interest-tag-sm{font-size:var(--fz-xs);padding:4px 11px;border-radius:999px;background:var(--bg2);border:1px solid var(--border);color:var(--text2)}
.team-info{flex:1;min-width:0}
.about-modal-header{display:flex;gap:16px;align-items:flex-start;margin-bottom:20px;padding-bottom:20px;border-bottom:1px solid var(--border)}
.about-interest-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}
.about-modal-footer{display:flex;gap:10px}
.btn-link-about{display:inline-flex;align-items:center;gap:7px;padding:9px 16px;border-radius:var(--r);font-size:var(--fz-sm);font-weight:600;font-family:var(--font);text-decoration:none;border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;transition:background .15s}
.btn-link-about:hover{background:var(--bg3)}

/* ---------- SETTINGS / APPEARANCE PANELS ---------- */
#settings-panel{box-shadow: var(--shadow-sm);}
#appearance-panel {background: var(--surface);border-bottom: 1px solid var(--border);padding: 20px max(20px, calc((100% - 1240px)/2));box-shadow: var(--shadow-sm);}
.seg{display:inline-flex;background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:3px;gap:3px}
.seg button{background:transparent;border:none;padding:7px 14px;border-radius:6px;font-size:var(--fz-xs);font-weight:600;color:var(--text2);cursor:pointer;box-shadow:none}
.seg button:hover{background:var(--bg3);color:var(--text)}
.seg button.on{background:var(--accent);color:var(--accent-contrast)}
.swatch-row{display:flex;gap:10px}
.swatch{width:34px;height:34px;border-radius:50%;cursor:pointer;border:2px solid var(--border);position:relative;transition:transform .12s}
.swatch:hover{transform:scale(1.08)}
.swatch.on{border-color:var(--text)}
.swatch.on::after{content:'';position:absolute;inset:0;margin:auto;width:11px;height:11px;border-radius:50%;background:#fff;box-shadow:0 0 0 2px rgba(0,0,0,.15)}
.appr-field{display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap}
.appr-label{font-size:var(--fz-sm);font-weight:700;color:var(--text)}
.appr-sub{font-size:var(--fz-xs);color:var(--text3);margin-top:2px}

/* ---------- FOOTER ---------- */
.btp-footer{background:var(--surface);border-top:1px solid var(--border);margin-top:56px;padding:48px max(20px, calc((100% - 1240px)/2)) 28px;color:var(--text2);font-size:var(--fz-sm)}
.btp-footer-inner{max-width:1240px;margin:0 auto;display:flex;flex-wrap:wrap;gap:40px;justify-content:space-between;align-items:flex-start}
.btp-footer-bottom{max-width:1240px;margin:28px auto 0;padding-top:18px;border-top:1px solid var(--border);font-size:var(--fz-xs);color:var(--text3);display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap}
.btp-footer a{color:var(--text2);text-decoration:none;transition:color .15s}
.btp-footer a:hover{color:var(--accent)}

@media (min-width:1500px){
  :root{--fz-base:16px;--fz-md:18.5px;--fz-sm:14px;--fz-xs:13px;--fz-xl:clamp(40px,3.3vw,50px);--fz-mono:clamp(30px,2.3vw,38px)}
  .topbar{max-width:none;padding:13px max(24px,calc((100% - 1480px)/2))}
  .main{max-width:1480px;padding-left:max(24px,calc((100% - 1480px)/2));padding-right:max(24px,calc((100% - 1480px)/2))}
  .btp-footer{padding-left:max(24px,calc((100% - 1480px)/2));padding-right:max(24px,calc((100% - 1480px)/2))}
  .btp-footer-inner,.btp-footer-bottom{max-width:1480px}
}
@media (min-width:2000px){
  :root{--fz-base:18px;--fz-md:21px;--fz-sm:15px;--fz-xs:13.5px;--fz-xl:clamp(48px,3.2vw,62px);--fz-mono:clamp(34px,2.2vw,46px);--gap:24px;--pad-card:30px}
  .topbar{padding:16px max(24px,calc((100% - 1760px)/2))}
  .main{max-width:1760px;padding-left:max(24px,calc((100% - 1760px)/2));padding-right:max(24px,calc((100% - 1760px)/2))}
  .btp-footer{padding-left:max(24px,calc((100% - 1760px)/2));padding-right:max(24px,calc((100% - 1760px)/2))}
  .btp-footer-inner,.btp-footer-bottom{max-width:1760px}
  .hero{padding-top:52px;padding-bottom:46px}
}
/* --------------------- user menu -------- */
.user-avatar-btn {
    width: 34px;
    height: 34px;
    border-radius: 50%;
    background: var(--accent-bg);
    border: 1.5px solid var(--accent-border);
    color: var(--accent);
    font-family: var(--mono);
    font-size: var(--fz-sm);
    font-weight: 700;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    transition: transform .12s, box-shadow .15s;
}
.user-avatar-btn:hover {
    transform: scale(1.05);
    box-shadow: var(--shadow-sm);
}

.user-dropdown {
    position: absolute;
    top: calc(100% + 8px);
    right: 0;
    min-width: 220px;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--rl);
    box-shadow: var(--shadow-lg);
    z-index: 200;
    padding: 6px;
    animation: fadeIn .15s ease;
}

.user-dropdown-header {
    padding: 12px 14px 14px;
}

.user-dropdown-divider {
    height: 1px;
    background: var(--border);
    margin: 4px 0;
}

.user-dropdown-item {
    display: flex;
    align-items: center;
    gap: 9px;
    width: 100%;
    padding: 9px 12px;
    border-radius: var(--r);
    border: none;
    background: transparent;
    color: var(--text);
    font-size: var(--fz-sm);
    font-weight: 500;
    cursor: pointer;
    text-align: left;
}
.user-dropdown-item:hover {
    background: var(--bg3);
}

.role-badge {
    display: inline-flex;
    font-size: 10px;
    font-weight: 700;
    padding: 2px 8px;
    border-radius: 999px;
    text-transform: uppercase;
    letter-spacing: .05em;
    font-family: var(--mono);
}
.role-badge-admin {
    background: var(--purple-bg);
    color: var(--purple);
    border: 1px solid var(--purple-border);
}
.role-badge-user {
    background: var(--accent-bg);
    color: var(--accent);
    border: 1px solid var(--accent-border);
}