/* ============ TOKENS ============ */
:root{
  --bg:#F6F3EC;
  --bg-deep:#EFEAE0;
  --surface:#FFFFFF;
  --surface-2:#F1EDE3;
  --ink:#16241F;
  --ink-soft:#57685F;
  --ink-faint:#8B978F;
  --brand:#0B6E4F;
  --brand-dark:#073E2C;
  --brand-soft:#E3F0EA;
  --gold:#B8892B;
  --gold-soft:#F8EFDA;
  --red:#B23A2E;
  --red-soft:#FBEAE7;
  --border:#E3DDCE;
  --border-soft:#ECE7DA;
  --radius-sm:10px;
  --radius-md:16px;
  --radius-lg:26px;
  --shadow-sm:0 1px 3px rgba(22,36,29,.07);
  --shadow-md:0 10px 30px rgba(22,36,29,.09);
  --shadow-lg:0 24px 60px rgba(22,36,29,.16);
  --font-display:'Unbounded',sans-serif;
  --font-body:'Inter',sans-serif;
  --font-mono:'JetBrains Mono',monospace;
  --ease:cubic-bezier(.16,1,.3,1);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-body);
  background:var(--bg);
  color:var(--ink);
  min-height:100vh;
  overflow-x:hidden;
  background-image:
    radial-gradient(circle at 8% 8%, rgba(11,110,79,.05), transparent 40%),
    radial-gradient(circle at 92% 18%, rgba(184,137,43,.06), transparent 40%);
}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
input,select{font-family:inherit}
::selection{background:var(--brand);color:#fff}
.visually-hidden{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}

@media (prefers-reduced-motion: reduce){
  *{animation-duration:.001ms !important;transition-duration:.001ms !important;}
}

/* ============ ICON SPRITE ============ */
svg.ic{width:20px;height:20px;stroke:currentColor;stroke-width:1.8;fill:none;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0}

/* ============ SCREEN MANAGEMENT ============ */
.screen{display:none}
.screen.active{display:block;animation:screenIn .5s var(--ease)}
@keyframes screenIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* ============ AUTH LAYOUT ============ */
#screen-auth.active{display:grid}
.auth-wrap{
  min-height:100vh;
  display:grid;
  grid-template-columns:1.05fr 1fr;
}
@media (max-width:920px){.auth-wrap{grid-template-columns:1fr}}

.auth-brand{
  background:radial-gradient(circle at 20% 15%, #0E7E5A 0%, var(--brand-dark) 55%, #052318 100%);
  color:#fff;
  padding:56px 60px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  position:relative;
  overflow:hidden;
}
@media (max-width:920px){.auth-brand{padding:40px 28px;min-height:340px}}
.auth-brand::before{
  content:"";position:absolute;inset:0;
  background-image:radial-gradient(circle, rgba(255,255,255,.06) 1px, transparent 1px);
  background-size:26px 26px;
  opacity:.5;
}
.brand-top{position:relative;z-index:1;display:flex;align-items:center;gap:12px}
.brand-mark{
  width:42px;height:42px;border-radius:12px;background:rgba(255,255,255,.12);
  display:flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.18);
}
.brand-mark svg{width:24px;height:24px;stroke:#F4D98B}
.brand-name{font-family:var(--font-display);font-size:20px;font-weight:700;letter-spacing:.02em}
.brand-name span{color:#F4D98B}

.brand-hero{position:relative;z-index:1;margin-top:40px}
.brand-eyebrow{
  font-family:var(--font-mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;
  color:#9FD9BE;margin-bottom:18px;display:flex;align-items:center;gap:10px;
}
.brand-eyebrow::before{content:"";width:26px;height:1px;background:#9FD9BE}
.coat-of-arms{
  width:68px;height:68px;border-radius:50%;background:#F6F3EC;padding:7px;
  box-shadow:0 0 0 1px rgba(244,217,139,.5), 0 4px 12px rgba(0,0,0,.25);
  object-fit:contain;flex-shrink:0;
}
.brand-hero h1{
  font-family:var(--font-display);font-weight:700;font-size:clamp(28px,3.4vw,42px);
  line-height:1.18;max-width:520px;letter-spacing:-.01em;
}
.brand-hero p{margin-top:18px;color:#CFE6DA;max-width:460px;line-height:1.6;font-size:15px}

.clock-stage{position:relative;z-index:1;margin-top:36px;display:flex;align-items:center;gap:26px}
.clock-legend{display:flex;flex-direction:column;gap:10px;font-family:var(--font-mono);font-size:12px;color:#CFE6DA}
.clock-legend .row{display:flex;align-items:center;gap:8px}
.dot{width:8px;height:8px;border-radius:50%}
.dot.open{background:#F4D98B}
.dot.track{background:rgba(255,255,255,.25)}

.brand-foot{position:relative;z-index:1;display:flex;gap:28px;flex-wrap:wrap;padding-top:32px;border-top:1px solid rgba(255,255,255,.14)}
.brand-foot .stat b{font-family:var(--font-display);font-size:22px;display:block;color:#fff}
.brand-foot .stat span{font-size:12px;color:#A9CDBB}

.auth-panel{
  display:flex;align-items:center;justify-content:center;padding:48px 24px;
}
.auth-card{
  width:100%;max-width:420px;background:var(--surface);border:1px solid var(--border-soft);
  border-radius:var(--radius-lg);padding:38px 36px;box-shadow:var(--shadow-md);
}
.auth-tabs{display:flex;background:var(--surface-2);border-radius:999px;padding:4px;margin-bottom:28px}
.auth-tab{
  flex:1;text-align:center;padding:10px 0;border:none;background:transparent;border-radius:999px;
  font-weight:600;font-size:14px;color:var(--ink-soft);transition:all .3s var(--ease);
}
.auth-tab.active{background:var(--ink);color:#fff;box-shadow:var(--shadow-sm)}

.auth-form{display:none;flex-direction:column;gap:16px}
.auth-form.active{display:flex;animation:screenIn .35s var(--ease)}
.field{display:flex;flex-direction:column;gap:6px;min-width:0}
.field label{font-size:12.5px;font-weight:600;color:var(--ink-soft);letter-spacing:.01em}
.field input,.field select{
  width:100%;min-width:0;box-sizing:border-box;
  border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:12px 14px;font-size:14.5px;
  background:#fff;color:var(--ink);transition:border-color .2s var(--ease), box-shadow .2s var(--ease);
}
.field input:focus,.field select:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 4px var(--brand-soft)}
.field-row{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:12px}
.help-text{font-size:12px;color:var(--ink-faint)}

.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  border:none;border-radius:var(--radius-sm);padding:13px 20px;font-weight:700;font-size:14.5px;
  transition:transform .2s var(--ease), box-shadow .2s var(--ease), background .2s var(--ease);
}
.btn:active{transform:scale(.98)}
.btn-primary{background:var(--brand);color:#fff;box-shadow:0 8px 20px rgba(11,110,79,.28)}
.btn-primary:hover{background:var(--brand-dark);box-shadow:0 10px 26px rgba(11,110,79,.36)}
.btn-block{width:100%}
.btn-ghost{background:transparent;color:var(--ink-soft);border:1.5px solid var(--border)}
.btn-ghost:hover{border-color:var(--ink);color:var(--ink)}
.btn-sm{padding:9px 14px;font-size:13px}
.btn-gold{background:var(--gold);color:#fff}

.auth-foot-note{margin-top:20px;text-align:center;font-size:13px;color:var(--ink-faint)}
.lang-mini{position:absolute;top:24px;right:24px;z-index:2}
@media(max-width:920px){.lang-mini{position:static;display:flex;justify-content:flex-end;margin-bottom:8px}}

/* Lang toggle pill (reused) */
.lang-toggle{display:flex;background:rgba(255,255,255,.16);border-radius:999px;padding:3px;border:1px solid rgba(255,255,255,.25)}
.lang-toggle button{border:none;background:transparent;color:#EAF3EE;font-size:12px;font-weight:700;padding:6px 12px;border-radius:999px;font-family:var(--font-mono);letter-spacing:.04em}
.lang-toggle button.active{background:#fff;color:var(--brand-dark)}
.lang-toggle.on-light{background:var(--surface-2);border-color:var(--border)}
.lang-toggle.on-light button{color:var(--ink-soft)}
.lang-toggle.on-light button.active{background:var(--ink);color:#fff}

/* ============ APP SHELL ============ */
.app-shell{display:grid;grid-template-columns:264px 1fr;min-height:100vh}
@media (max-width:960px){.app-shell{grid-template-columns:1fr}}

.sidebar{
  background:linear-gradient(180deg,var(--brand-dark),#052318);
  color:#fff;padding:26px 18px;display:flex;flex-direction:column;gap:6px;position:sticky;top:0;height:100vh;
}
@media (max-width:960px){.sidebar{position:fixed;left:0;top:0;z-index:40;width:264px;transform:translateX(-100%);transition:transform .35s var(--ease);box-shadow:var(--shadow-lg)}
  .sidebar.open{transform:translateX(0)}}
.side-brand{display:flex;align-items:center;gap:10px;padding:6px 10px 22px}
.side-brand .brand-mark{width:36px;height:36px}
.side-brand .brand-mark svg{width:20px;height:20px}
.side-brand span{font-family:var(--font-display);font-weight:700;font-size:17px}
.side-brand em{color:#F4D98B;font-style:normal}

.side-section-label{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:#7FB79B;padding:14px 12px 6px}
.nav-item{
  display:flex;align-items:center;gap:12px;padding:11px 12px;border-radius:12px;color:#D6EADF;
  font-size:14px;font-weight:500;border:none;background:transparent;width:100%;text-align:left;
  transition:background .2s var(--ease), color .2s var(--ease);position:relative;
}
.nav-item svg{width:19px;height:19px;opacity:.85}
.nav-item:hover{background:rgba(255,255,255,.07);color:#fff}
.nav-item.active{background:rgba(255,255,255,.14);color:#fff;box-shadow:inset 3px 0 0 var(--gold)}
.nav-item .badge{margin-left:auto;background:var(--gold);color:#fff;font-size:10.5px;font-weight:700;padding:1px 7px;border-radius:999px;font-family:var(--font-mono)}

.side-foot{margin-top:auto;padding-top:14px;border-top:1px solid rgba(255,255,255,.1)}
.side-user{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:12px}
.side-avatar{width:34px;height:34px;border-radius:10px;background:var(--gold);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:700;color:#3B2A05;font-size:14px}
.side-user .who{line-height:1.25}
.side-user .who b{display:block;font-size:13px}
.side-user .who small{color:#9FC6B0;font-size:11.5px}

.main{min-width:0}
.topbar{
  position:sticky;top:0;z-index:20;background:rgba(246,243,236,.85);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--border-soft);padding:16px 30px;display:flex;align-items:center;gap:16px;
}
.hamburger{display:none;border:none;background:var(--surface-2);border-radius:10px;width:38px;height:38px;align-items:center;justify-content:center}
@media (max-width:960px){.hamburger{display:flex}}
.topbar h2{font-family:var(--font-display);font-size:17px;font-weight:600}
.topbar .sub{font-size:12.5px;color:var(--ink-faint)}
.topbar-spacer{flex:1}
.icon-btn{width:38px;height:38px;border-radius:10px;border:1px solid var(--border);background:#fff;display:flex;align-items:center;justify-content:center;color:var(--ink-soft);position:relative}
.icon-btn .dotnotif{position:absolute;top:6px;right:7px;width:7px;height:7px;border-radius:50%;background:var(--red);border:1.5px solid #fff}

.view{display:none;padding:28px 30px 60px;animation:screenIn .4s var(--ease)}
.view.active{display:block}

/* ============ CARDS / GRID ============ */
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:26px}
@media(max-width:960px){.stat-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.stat-grid{grid-template-columns:1fr}}
.stat-card{
  background:var(--surface);border:1px solid var(--border-soft);border-radius:var(--radius-md);
  padding:20px 20px;box-shadow:var(--shadow-sm);transition:transform .25s var(--ease), box-shadow .25s var(--ease);
}
.stat-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.stat-card .top{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.stat-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center}
.stat-icon svg{width:18px;height:18px}
.stat-card .num{font-family:var(--font-display);font-size:30px;font-weight:700;line-height:1}
.stat-card .lbl{font-size:12.5px;color:var(--ink-faint);margin-top:6px}

.grid-2{display:grid;grid-template-columns:1.3fr 1fr;gap:20px}
@media(max-width:1100px){.grid-2{grid-template-columns:1fr}}

.panel{background:var(--surface);border:1px solid var(--border-soft);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);overflow:hidden}
.panel-head{padding:18px 22px;border-bottom:1px solid var(--border-soft);display:flex;align-items:center;justify-content:space-between}
.panel-head h3{font-family:var(--font-display);font-size:15.5px;font-weight:600}
.panel-body{padding:20px 22px}

/* Radial clock */
.clock-face{position:relative}
.clock-face svg{display:block;overflow:visible}
.clock-time-label{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;
}
.clock-time-label b{display:block;font-family:var(--font-mono);font-size:15px;letter-spacing:-.02em}
.clock-time-label span{display:block;font-size:9.5px;color:var(--ink-faint);text-transform:uppercase;letter-spacing:.08em;margin-top:2px}

.timeline{position:relative;padding-left:22px}
.timeline::before{content:"";position:absolute;left:5px;top:4px;bottom:4px;width:2px;background:var(--border)}
.tl-item{position:relative;padding-bottom:20px}
.tl-item:last-child{padding-bottom:0}
.tl-item::before{content:"";position:absolute;left:-22px;top:2px;width:12px;height:12px;border-radius:50%;background:var(--surface);border:2.5px solid var(--brand)}
.tl-item.pending::before{border-color:var(--gold)}
.tl-item.muted::before{border-color:var(--border)}
.tl-item b{display:block;font-size:13.5px;font-weight:600}
.tl-item small{color:var(--ink-faint);font-size:11.5px;font-family:var(--font-mono)}

/* badges */
.badge{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:700;padding:5px 11px;border-radius:999px;letter-spacing:.01em}
.badge::before{content:"";width:6px;height:6px;border-radius:50%}
.badge.pending{background:var(--gold-soft);color:#8A650F}
.badge.pending::before{background:var(--gold)}
.badge.approved{background:var(--brand-soft);color:var(--brand-dark)}
.badge.approved::before{background:var(--brand)}
.badge.rejected{background:var(--red-soft);color:var(--red)}
.badge.rejected::before{background:var(--red)}
.badge.draft{background:var(--surface-2);color:var(--ink-soft)}
.badge.draft::before{background:var(--ink-faint)}

/* Applications list */
.app-list{display:flex;flex-direction:column;gap:12px}
.app-row{
  display:grid;grid-template-columns:52px 1.5fr 1fr 1fr auto;align-items:center;gap:16px;
  padding:16px 18px;border:1px solid var(--border-soft);border-radius:var(--radius-sm);background:#fff;
  transition:box-shadow .25s var(--ease), transform .25s var(--ease);cursor:pointer;
}
.app-row:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}
@media(max-width:800px){.app-row{grid-template-columns:44px 1fr;grid-template-areas:"icon title" "icon meta" "icon status";row-gap:4px}}
.app-icon{width:44px;height:44px;border-radius:12px;background:var(--brand-soft);display:flex;align-items:center;justify-content:center;color:var(--brand-dark)}
.app-icon svg{width:20px;height:20px}
.app-row .title{font-weight:700;font-size:14.5px}
.app-row .meta{font-size:12px;color:var(--ink-faint);font-family:var(--font-mono)}
.app-row .hours{font-family:var(--font-mono);font-size:13px;color:var(--ink-soft)}

/* Wizard */
.wizard-steps{display:flex;align-items:center;gap:0;margin-bottom:28px;overflow-x:auto;padding-bottom:4px}
.wstep{display:flex;align-items:center;gap:10px;flex-shrink:0}
.wstep .circ{width:30px;height:30px;border-radius:50%;background:var(--surface-2);color:var(--ink-faint);display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:12.5px;font-weight:700;border:2px solid transparent;transition:all .3s var(--ease)}
.wstep.done .circ{background:var(--brand);color:#fff}
.wstep.active .circ{background:#fff;color:var(--brand);border-color:var(--brand)}
.wstep .lbl{font-size:12.5px;font-weight:600;color:var(--ink-faint);white-space:nowrap}
.wstep.active .lbl{color:var(--ink)}
.wstep.done .lbl{color:var(--brand-dark)}
.wsep{width:36px;height:2px;background:var(--border);margin:0 6px;flex-shrink:0}

.wpanel{display:none}
.wpanel.active{display:block;animation:screenIn .35s var(--ease)}

.type-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
@media(max-width:900px){.type-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.type-grid{grid-template-columns:1fr}}
.type-card{
  border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:16px;cursor:pointer;
  transition:all .2s var(--ease);background:#fff;text-align:left;
}
.type-card:hover{border-color:var(--brand);box-shadow:var(--shadow-sm)}
.type-card.selected{border-color:var(--brand);background:var(--brand-soft);box-shadow:0 0 0 3px var(--brand-soft)}
.type-icon{width:34px;height:34px;border-radius:10px;background:var(--surface-2);display:flex;align-items:center;justify-content:center;margin-bottom:10px;color:var(--brand-dark);transition:background .2s var(--ease),color .2s var(--ease)}
.type-icon svg{width:17px;height:17px}
.type-card.selected .type-icon{background:var(--brand);color:#fff}
.type-card .nm{font-weight:700;font-size:13.5px;margin-bottom:6px;line-height:1.3}
.type-card .hrs{font-family:var(--font-mono);font-size:11.5px;color:var(--ink-faint)}

.doc-list{display:flex;flex-direction:column;gap:10px}
.doc-item{display:flex;align-items:flex-start;gap:14px;padding:14px 16px;border:1.5px dashed var(--border);border-radius:var(--radius-sm);transition:all .2s var(--ease)}
.doc-item.uploaded{border-style:solid;border-color:var(--brand);background:var(--brand-soft)}
.doc-item .dstat{width:32px;height:32px;border-radius:9px;background:var(--surface-2);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.doc-item.uploaded .dstat{background:var(--brand);color:#fff}
.doc-item .dinfo{flex:1;font-size:13.5px;font-weight:600}
.doc-item .dinfo small{display:block;font-weight:400;color:var(--ink-faint);font-size:11.5px;margin-top:2px;font-family:var(--font-mono)}

.file-chip-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.file-chip{position:relative;width:46px;height:46px;border-radius:10px;overflow:hidden;border:1px solid var(--border);background:var(--surface-2);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.file-chip img{width:100%;height:100%;object-fit:cover;display:block}
.file-chip svg{width:18px;height:18px;color:var(--ink-faint)}
.file-chip .rm{position:absolute;top:-5px;right:-5px;width:17px;height:17px;border-radius:50%;background:var(--red);color:#fff;display:flex;align-items:center;justify-content:center;border:1.5px solid #fff;cursor:pointer;padding:0;border-style:solid}
.file-chip .rm svg{width:9px;height:9px;color:#fff}
.add-file-chip{width:46px;height:46px;border-radius:10px;border:1.5px dashed var(--border);display:flex;align-items:center;justify-content:center;color:var(--ink-faint);cursor:pointer;background:#fff;flex-shrink:0;transition:all .2s var(--ease)}
.add-file-chip:hover{border-color:var(--brand);color:var(--brand);background:var(--brand-soft)}
.add-file-chip svg{width:17px;height:17px}

.time-picker-row{display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.time-box{display:flex;flex-direction:column;gap:6px}
.time-box label{font-size:12px;font-weight:600;color:var(--ink-soft)}
.time-box input{font-family:var(--font-mono);font-size:16px;border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:10px 14px;width:120px}
.time-box input:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 4px var(--brand-soft)}
.warn-note{display:flex;gap:10px;align-items:flex-start;background:var(--gold-soft);border:1px solid #EBD9A4;border-radius:var(--radius-sm);padding:12px 14px;font-size:12.5px;color:#7A5A0E;margin-top:14px}
.warn-note svg{width:16px;height:16px;flex-shrink:0;margin-top:1px}

.review-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:640px){.review-grid{grid-template-columns:1fr}}
.review-item{background:var(--surface-2);border-radius:var(--radius-sm);padding:14px 16px}
.review-item .k{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-faint);margin-bottom:4px;font-family:var(--font-mono)}
.review-item .v{font-weight:700;font-size:14px}

.wizard-nav{display:flex;justify-content:space-between;margin-top:28px;gap:12px}

/* ===== dashboard hero & extras ===== */
.hero-row{display:grid;grid-template-columns:1.4fr 1fr;gap:20px;margin-bottom:20px}
@media(max-width:900px){.hero-row{grid-template-columns:1fr}}
.hero-greet{background:linear-gradient(135deg,#fff,var(--surface-2));border:1px solid var(--border-soft);border-radius:var(--radius-lg);padding:28px 30px;position:relative;overflow:hidden;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;justify-content:center}
.hero-greet::after{content:"";position:absolute;right:-50px;top:-60px;width:200px;height:200px;border-radius:50%;background:radial-gradient(circle,var(--brand-soft),transparent 70%)}
.hero-greet::before{content:"";position:absolute;right:20px;bottom:-30px;width:120px;height:120px;border-radius:50%;background:radial-gradient(circle,var(--gold-soft),transparent 70%);opacity:.7}
.hero-greet .eyebrow{position:relative;font-family:var(--font-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--brand-dark);margin-bottom:10px;display:flex;align-items:center;gap:8px}
.hero-greet .eyebrow::before{content:"";width:20px;height:1px;background:var(--brand)}
.hero-greet h1{position:relative;font-family:var(--font-display);font-size:25px;font-weight:700;margin-bottom:8px;letter-spacing:-.01em}
.hero-greet p{position:relative;color:var(--ink-soft);font-size:13.5px;max-width:480px;line-height:1.55}
.hero-progress{background:var(--surface);border:1px solid var(--border-soft);border-radius:var(--radius-lg);padding:22px 24px;display:flex;align-items:center;gap:18px;box-shadow:var(--shadow-sm)}
.ring-wrap{position:relative;width:78px;height:78px;flex-shrink:0}
.ring-wrap svg{transform:rotate(-90deg)}
.ring-label{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-weight:700;font-size:15px;color:var(--brand-dark)}
.hero-progress .txt b{display:block;font-size:14px;margin-bottom:5px;font-family:var(--font-display)}
.hero-progress .txt span{font-size:12px;color:var(--ink-faint);line-height:1.5;display:block}

.stat-trend{font-size:11px;font-family:var(--font-mono);margin-top:7px;display:flex;align-items:center;gap:4px}
.stat-trend.up{color:var(--brand)}
.stat-trend.flat{color:var(--ink-faint)}

.act-row{display:flex;gap:12px;align-items:flex-start}
.act-icon{width:30px;height:30px;border-radius:9px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.act-icon svg{width:15px;height:15px}

.row3{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:20px}
@media(max-width:900px){.row3{grid-template-columns:1fr}}
.session-card{background:linear-gradient(135deg,#fff,var(--gold-soft));border:1px solid #EBD9A4;border-radius:var(--radius-md);padding:22px 24px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:14px}
.session-card .row{display:flex;align-items:center;gap:14px}
.session-num{font-family:var(--font-display);font-size:32px;font-weight:700;color:var(--gold);line-height:1}
.session-num small{display:block;font-family:var(--font-mono);font-size:10.5px;color:var(--ink-faint);font-weight:400;text-transform:uppercase;letter-spacing:.06em;margin-top:2px}
.checklist-card{background:var(--surface);border:1px solid var(--border-soft);border-radius:var(--radius-md);padding:20px 22px;box-shadow:var(--shadow-sm)}
.chk-item{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px dashed var(--border-soft);font-size:13px}
.chk-item:last-child{border-bottom:none}
.chk-dot{width:20px;height:20px;border-radius:6px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.chk-dot svg{width:12px;height:12px}
.chk-dot.done{background:var(--brand);color:#fff}
.chk-dot.todo{background:var(--surface-2);color:var(--ink-faint);border:1.5px dashed var(--border)}

.req-checklist{margin-top:18px;padding-top:18px;border-top:1px dashed var(--border-soft)}
.req-checklist h4{font-size:13px;color:var(--ink-soft);margin-bottom:10px;font-family:var(--font-display);font-weight:600}
.req-item{display:flex;flex-direction:column;gap:8px;padding:12px;border:1px solid var(--border-soft);border-radius:10px;margin-bottom:8px;font-size:12.5px;background:#fff;transition:all .2s var(--ease)}
.req-item.filled{border-color:var(--brand);background:var(--brand-soft)}
.req-item .req-top{display:flex;align-items:center;gap:10px}
.req-item svg{width:15px;height:15px;color:var(--brand);flex-shrink:0}

.comment-box{background:var(--red-soft);border:1px solid #EBC3BC;border-radius:var(--radius-sm);padding:14px 16px;margin-bottom:16px}
.comment-box .who{font-size:11px;font-weight:700;color:var(--red);margin-bottom:6px;font-family:var(--font-mono);letter-spacing:.03em;text-transform:uppercase;display:flex;align-items:center;gap:6px}
.comment-box p{font-size:13px;color:#7A2C22;line-height:1.5}

.docs-section h4{font-size:13px;color:var(--ink-soft);margin-bottom:10px;font-family:var(--font-display);font-weight:600}
.doc-mini{display:flex;align-items:center;gap:10px;padding:9px 12px;border:1px solid var(--border-soft);border-radius:10px;margin-bottom:6px;font-size:12.5px}
.doc-mini svg{width:14px;height:14px;color:var(--brand);flex-shrink:0}
.revision-tag{font-family:var(--font-mono);font-size:10.5px;background:var(--surface-2);color:var(--ink-soft);padding:2px 8px;border-radius:999px;margin-left:8px}

/* toast */
#toast{
  position:fixed;bottom:26px;right:26px;z-index:100;display:flex;flex-direction:column;gap:10px;
}
.toast{
  background:var(--ink);color:#fff;padding:14px 18px;border-radius:12px;display:flex;align-items:center;gap:12px;
  box-shadow:var(--shadow-lg);font-size:13.5px;font-weight:500;min-width:280px;
  animation:toastIn .4s var(--ease);
}
.toast svg{width:18px;height:18px;color:#F4D98B;flex-shrink:0}
@keyframes toastIn{from{opacity:0;transform:translateY(14px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}

/* modal drawer */
.overlay{position:fixed;inset:0;background:rgba(15,25,20,.5);backdrop-filter:blur(2px);z-index:60;display:none;animation:screenIn .3s var(--ease)}
.overlay.active{display:block}
.drawer{
  position:fixed;top:0;right:0;height:100vh;width:420px;max-width:92vw;background:var(--surface);
  z-index:61;box-shadow:var(--shadow-lg);transform:translateX(100%);transition:transform .4s var(--ease);
  display:flex;flex-direction:column;
}
.drawer.active{transform:translateX(0)}
.drawer-head{padding:22px 24px;border-bottom:1px solid var(--border-soft);display:flex;align-items:center;justify-content:space-between}
.drawer-body{padding:22px 24px;overflow-y:auto;flex:1}
.drawer-close{width:34px;height:34px;border-radius:10px;border:1px solid var(--border);background:#fff;display:flex;align-items:center;justify-content:center}

/* profile */
.profile-header{display:flex;align-items:center;gap:18px;margin-bottom:24px}
.profile-avatar{width:64px;height:64px;border-radius:16px;background:var(--gold);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:22px;font-weight:700;color:#3B2A05}
.profile-header h2{font-family:var(--font-display);font-size:19px;margin-bottom:4px}
.profile-header .tag{font-size:12.5px;color:var(--ink-faint);font-family:var(--font-mono)}
.form-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:16px}
@media(max-width:700px){.form-grid{grid-template-columns:1fr}}

.hint-empty{text-align:center;padding:50px 20px;color:var(--ink-faint)}
.hint-empty svg{width:44px;height:44px;margin-bottom:14px;opacity:.5}
.hint-empty p{font-size:13.5px;max-width:280px;margin:6px auto 0}

/* mobile sidebar overlay */
.sb-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:35}
.sb-overlay.active{display:block}