:root {
  --blue:#007aff;
  --blue-600:#0066d6;
  --blue-50:#eaf4ff;
  --ink:#1d1d1f;
  --ink-2:#6e6e73;
  --ink-3:#8e8e93;
  --bg:#f5f5f7;
  --bg-2:#fbfbfd;
  --card:#fff;
  --line:#e5e5ea;
  --line-2:#efeff2;
  --green:#34a65f;
  --green-soft:#e6f4ec;
  --orange:#c8861a;
  --orange-soft:#fbf1e1;
  --red:#c9342e;
  --red-soft:#fbe9e8;
  --info-soft:#e5f0ff;
  --radius:14px;
  --radius-lg:20px;
  --radius-xl:28px;
  --shadow-xs:0 1px 2px rgba(15,17,21,.04),0 1px 1px rgba(15,17,21,.03);
  --shadow-md:0 10px 30px rgba(15,17,21,.06),0 2px 8px rgba(15,17,21,.04);
  --shadow-lg:0 30px 60px rgba(15,17,21,.1),0 8px 20px rgba(15,17,21,.06);
  --shadow-blue:0 12px 28px rgba(0,122,255,.28);
  --font:"Inter",-apple-system,BlinkMacSystemFont,"SF Pro Text","Segoe UI",system-ui,sans-serif;
  --sidebar:248px;
  --topbar:64px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
}

[data-theme="dark"] {
  --blue:#0a84ff;
  --blue-600:#409cff;
  --blue-50:rgba(10,132,255,.12);
  --ink:#f5f5f7;
  --ink-2:#98989d;
  --ink-3:#6e6e73;
  --bg:#0b0b0f;
  --bg-2:#0e0e13;
  --card:#161618;
  --line:#2a2a2e;
  --line-2:#202024;
  --green:#30d158;
  --green-soft:rgba(48,209,88,.12);
  --orange:#ff9f0a;
  --orange-soft:rgba(255,159,10,.14);
  --red:#ff453a;
  --red-soft:rgba(255,69,58,.14);
  --info-soft:rgba(10,132,255,.14);
  --shadow-xs:0 1px 2px rgba(0,0,0,.45);
  --shadow-md:0 10px 30px rgba(0,0,0,.45),0 2px 6px rgba(0,0,0,.35);
  --shadow-lg:0 30px 60px rgba(0,0,0,.55),0 8px 20px rgba(0,0,0,.4);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:var(--font);
  background:var(--bg);
  color:var(--ink);
  font-size:14px;
  line-height:1.5;
  min-height:100vh;
  overflow-x:hidden;
  transition:background-color .45s var(--ease),color .45s var(--ease);
  -webkit-font-smoothing:antialiased;
}
button,input,select,textarea{font:inherit;color:inherit}
button{cursor:pointer;border:0;background:none}
a{color:inherit;text-decoration:none}
[hidden]{display:none!important}

.svg-defs{width:0;height:0;position:absolute}
.ambient{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.ambient:before{
  content:"";
  position:absolute;
  inset:-10%;
  background:
    radial-gradient(60% 50% at 15% 20%,rgba(0,122,255,.10),transparent 60%),
    radial-gradient(50% 40% at 85% 10%,rgba(0,122,255,.06),transparent 60%),
    radial-gradient(70% 60% at 70% 90%,rgba(0,122,255,.05),transparent 60%);
  filter:blur(40px);
  animation:ambient 22s var(--ease) infinite alternate;
}
[data-theme="dark"] .ambient:before{
  background:
    radial-gradient(60% 50% at 15% 20%,rgba(10,132,255,.20),transparent 60%),
    radial-gradient(50% 40% at 85% 10%,rgba(10,132,255,.12),transparent 60%),
    radial-gradient(70% 60% at 70% 90%,rgba(10,132,255,.10),transparent 60%);
}
.blob{position:absolute;border-radius:50%;filter:blur(80px);opacity:.55;animation:float 16s var(--ease) infinite alternate}
.b1{width:520px;height:520px;left:-140px;top:-120px;background:#cfe2ff}
.b2{width:480px;height:480px;right:-160px;top:30vh;background:#e6efff;animation-duration:22s}
.b3{width:380px;height:380px;left:30%;bottom:-160px;background:#d8e6ff;animation-duration:28s}
[data-theme="dark"] .b1{background:rgba(10,132,255,.22)}
[data-theme="dark"] .b2{background:rgba(10,132,255,.16)}
[data-theme="dark"] .b3{background:rgba(10,132,255,.12)}
@keyframes ambient{0%{transform:translate3d(0,0,0) scale(1)}50%{transform:translate3d(-2%,1%,0) scale(1.05)}100%{transform:translate3d(2%,-1%,0) scale(1.02)}}
@keyframes float{from{transform:translate(0,0) scale(1)}to{transform:translate(40px,-30px) scale(1.08)}}

.app{position:relative;z-index:1;display:grid;grid-template-columns:var(--sidebar) 1fr;min-height:100vh}
.sidebar{
  position:sticky;top:0;height:100vh;padding:18px 14px;
  display:flex;flex-direction:column;gap:4px;
  background:rgba(255,255,255,.62);
  backdrop-filter:saturate(180%) blur(22px);
  border-right:1px solid var(--line);
  z-index:50;
  transition:transform .45s var(--ease-out),background-color .5s var(--ease);
}
[data-theme="dark"] .sidebar{background:rgba(14,14,19,.7)}
.brand{display:flex;align-items:center;gap:10px;padding:8px 10px 18px}
.brand-mark{
  width:30px;height:30px;border-radius:9px;
  background:linear-gradient(135deg,#0a84ff 0%,#0040a8 100%);
  display:grid;place-items:center;color:white;
  box-shadow:0 6px 14px rgba(0,122,255,.35),inset 0 1px 0 rgba(255,255,255,.4);
}
.brand-mark svg{width:16px;height:16px;stroke-width:2.4}
.brand-name{font-weight:700;font-size:15px;letter-spacing:-.02em}.brand-name span{color:var(--blue)}.brand-company{font-size:11px;color:var(--text-3);font-weight:500;margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:140px;}
.nav-label{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-3);padding:14px 12px 6px}
.nav-item{
  display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:10px;
  color:var(--ink-2);font-size:13.5px;font-weight:600;cursor:pointer;
  transition:background .2s var(--ease),color .2s var(--ease),transform .2s var(--ease);
}
.nav-item svg{width:18px;height:18px;stroke-width:1.8}
.nav-item:hover{color:var(--ink);background:rgba(0,122,255,.05)}
.nav-item.active{color:var(--ink);background:var(--card);box-shadow:var(--shadow-xs),inset 0 0 0 1px var(--line)}
.nav-item.active svg,.nav-item:hover svg{color:var(--blue)}
.badge-dot{
  margin-left:auto;background:var(--blue);color:white;font-size:10.5px;font-weight:700;
  height:18px;min-width:18px;padding:0 5px;border-radius:9px;display:grid;place-items:center;
}
.sidebar-footer{margin-top:auto;padding:12px;border-top:1px solid var(--line);display:flex;align-items:center;gap:10px}
.avatar{
  width:34px;height:34px;border-radius:50%;display:grid;place-items:center;
  background:linear-gradient(135deg,#007aff 0%,#003e8a 100%);
  color:white;font-weight:700;font-size:12px;flex-shrink:0;
  box-shadow:0 4px 10px rgba(0,122,255,.28),inset 0 1px 0 rgba(255,255,255,.2);
}
.avatar.lg{width:44px;height:44px;font-size:14px}.avatar.sm{width:28px;height:28px;font-size:11px}.avatar.xs{width:22px;height:22px;font-size:10px}
.avatar-name{font-size:13px;font-weight:700;line-height:1.2}.avatar-role{font-size:11.5px;color:var(--ink-2)}
.main{display:flex;flex-direction:column;min-width:0;overflow-x:hidden}
.topbar{
  position:sticky;top:0;z-index:40;height:var(--topbar);
  display:flex;align-items:center;gap:16px;padding:0 28px;
  background:rgba(245,245,247,.72);
  backdrop-filter:saturate(180%) blur(22px);
  border-bottom:1px solid var(--line);
}
[data-theme="dark"] .topbar{background:rgba(11,11,15,.72)}
.menu-btn{display:none}
.search{
  flex:1;max-width:460px;display:flex;align-items:center;gap:8px;
  padding:8px 12px;background:var(--card);border:1px solid var(--line);border-radius:10px;
  transition:border-color .2s var(--ease),box-shadow .2s var(--ease);
}
.search:focus-within{border-color:var(--blue);box-shadow:0 0 0 4px rgba(0,122,255,.15)}
.search svg{width:16px;height:16px;color:var(--ink-3)}
.search input{flex:1;border:0;outline:0;background:transparent;font-size:13.5px;min-width:0}
.search kbd{font:inherit;font-size:11px;padding:2px 6px;border-radius:5px;background:var(--bg);color:var(--ink-2);border:1px solid var(--line)}
.topbar-spacer{flex:1}.date-chip{font-size:12.5px;font-weight:600;color:var(--ink-2);padding:6px 10px;border-radius:8px}
.icon-btn{
  width:38px;height:38px;display:grid;place-items:center;border-radius:10px;color:var(--ink-2);
  transition:all .2s var(--ease);position:relative;
}
.icon-btn:hover{background:var(--card);color:var(--blue);box-shadow:var(--shadow-xs),inset 0 0 0 1px var(--line)}
.icon-btn svg{width:18px;height:18px;stroke-width:1.8}
.ping{position:absolute;top:8px;right:8px;width:8px;height:8px;border-radius:50%;background:var(--red);box-shadow:0 0 0 2px var(--bg)}
.profile-pill{
  display:flex;align-items:center;gap:8px;padding:4px 10px 4px 4px;background:var(--card);
  border:1px solid var(--line);border-radius:32px;cursor:pointer;
}
.impersonation-banner{width:100%;display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:12px;background:#ff9f0a;color:#fff;padding:10px 20px;font-size:13px;font-weight:700;box-shadow:inset 0 -1px 0 rgba(0,0,0,.08)}
.impersonation-banner svg{width:16px;height:16px;flex-shrink:0}.impersonation-text{min-width:0;line-height:1.35}.impersonation-exit{background:rgba(0,0,0,.22);color:#fff;border-radius:8px;padding:6px 14px;font-weight:800;white-space:nowrap}.impersonation-exit:hover{background:rgba(0,0,0,.30)}
.content{padding:28px 32px 40px;max-width:1440px;width:100%;margin:0 auto;flex:1;min-width:0}
.app-footer{max-width:1440px;width:100%;margin:0 auto;padding:18px 32px 30px;color:var(--ink-2);display:flex;align-items:center;justify-content:space-between;gap:16px;border-top:1px solid var(--line);font-size:12.5px}
.app-footer strong{display:block;color:var(--ink);font-size:13.5px;margin-bottom:2px}.app-footer span{display:inline-flex}.app-footer-links{display:flex;align-items:center;gap:14px;flex-wrap:wrap;justify-content:flex-end}.login-footer{width:100%;max-width:440px;margin:16px auto 0;color:var(--ink-2);font-size:12.5px;text-align:center}.login-footer>span{display:block;line-height:1.5}.login-footer-links{display:flex;justify-content:center;gap:12px;flex-wrap:wrap;margin-top:8px}.footer-link{display:inline-flex;align-items:center;color:var(--ink-2);font-size:12.5px;font-weight:700;padding:4px 0}.footer-link:hover,.footer-link.active{color:var(--blue)}
.public-shell{position:relative;z-index:1;min-height:100vh;display:flex;flex-direction:column}.public-topbar{position:sticky;top:0;z-index:40;display:flex;align-items:center;justify-content:space-between;gap:18px;padding:16px 32px;background:rgba(245,245,247,.72);backdrop-filter:saturate(180%) blur(22px);border-bottom:1px solid var(--line)}[data-theme="dark"] .public-topbar{background:rgba(11,11,15,.72)}.public-brand{padding:0;text-align:left}.public-content{flex:1}.public-footer{position:relative}.legal-document{max-width:960px;margin:0 auto}.legal-section{margin-bottom:16px}.legal-section h2{font-size:18px;line-height:1.25;margin:0 0 12px;letter-spacing:-.01em}.legal-section p{color:var(--ink-2);margin:0 0 12px}.legal-section p:last-child{margin-bottom:0}.legal-section address{font-style:normal;color:var(--ink-2);line-height:1.7;margin:0 0 12px}.legal-section a{color:var(--blue);font-weight:700}
.page{animation:pageIn .55s var(--ease-out)}@keyframes pageIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.page-head{display:flex;align-items:end;justify-content:space-between;margin-bottom:24px;gap:18px;flex-wrap:wrap}
.eyebrow{font-size:12px;font-weight:800;color:var(--blue);letter-spacing:.04em;text-transform:uppercase;margin-bottom:6px}
.page-title{font-size:34px;font-weight:700;letter-spacing:-.025em;line-height:1.1;margin:0}
.page-sub{color:var(--ink-2);font-size:15px;margin-top:6px}

.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:10px 16px;border-radius:10px;
  font-size:13.5px;font-weight:700;border:1px solid var(--line);background:var(--card);color:var(--ink);
  transition:all .2s var(--ease);white-space:nowrap;
}
.btn:hover{box-shadow:var(--shadow-xs);transform:translateY(-1px)}
.btn svg{width:15px;height:15px}.btn-primary{background:var(--blue);color:white;border-color:transparent;box-shadow:var(--shadow-blue)}
.btn-primary:hover{background:var(--blue-600)}.btn-ghost{background:transparent;border-color:transparent;color:var(--ink-2)}
.btn-success{background:var(--green);color:white;border-color:transparent}.btn-danger{background:var(--red);color:white;border-color:transparent}
.btn-sm{padding:6px 10px;font-size:12.5px}
.card{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius-lg);padding:22px;
  box-shadow:var(--shadow-xs);transition:transform .35s var(--ease),box-shadow .35s var(--ease),border-color .25s var(--ease);
}
.card.hoverable:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:rgba(0,122,255,.18)}
.card-title{font-size:15px;font-weight:800;letter-spacing:-.01em;margin:0 0 4px}.card-sub{color:var(--ink-2);font-size:12.5px}
.card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;gap:10px}
.grid{display:grid;gap:18px}.grid-4{grid-template-columns:repeat(4,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-2{grid-template-columns:repeat(2,1fr)}
.row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.col{display:flex;flex-direction:column;gap:10px}.between{justify-content:space-between}
.muted{color:var(--ink-2)}.text-sm{font-size:12.5px}.mt-sm{margin-top:8px}.mt-md{margin-top:14px}.mt-lg{margin-top:20px}

.kpi{display:flex;flex-direction:column;gap:14px}.kpi-icon{
  width:38px;height:38px;border-radius:11px;display:grid;place-items:center;background:var(--blue-50);color:var(--blue)
}
.kpi-icon svg{width:18px;height:18px}.kpi-icon.green{background:var(--green-soft);color:var(--green)}
.kpi-icon.orange{background:var(--orange-soft);color:var(--orange)}.kpi-icon.red{background:var(--red-soft);color:var(--red)}
.kpi-icon.ink{background:var(--line-2);color:var(--ink)}
.kpi-value{font-size:32px;font-weight:800;letter-spacing:-.025em;line-height:1;font-feature-settings:"tnum"}
.kpi-label{font-size:12.5px;color:var(--ink-2);margin-top:4px}
.hero{
  position:relative;display:grid;grid-template-columns:1.05fr 1fr;gap:36px;padding:42px 36px;border-radius:var(--radius-xl);
  background:linear-gradient(180deg,var(--card),color-mix(in srgb,var(--card) 92%,var(--blue) 8%));
  border:1px solid var(--line);overflow:hidden;margin-bottom:28px;box-shadow:var(--shadow-md);
}
.hero:before{content:"";position:absolute;right:-80px;top:-80px;width:360px;height:360px;border-radius:50%;background:radial-gradient(circle,rgba(0,122,255,.18),transparent 70%);filter:blur(20px)}
.hero h1{font-size:52px;font-weight:800;letter-spacing:-.035em;line-height:1.05;margin:8px 0 14px}
.hero p{color:var(--ink-2);font-size:16px;max-width:520px;margin:0 0 20px}.hero-cta{display:flex;gap:10px;flex-wrap:wrap}
.hero-features{display:flex;gap:18px;margin-top:26px;flex-wrap:wrap}.hero-feature{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--ink-2)}.hero-feature svg{width:14px;height:14px;color:var(--blue)}
.mock-card{background:var(--card);border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow-lg);padding:16px;animation:floaty 8s var(--ease) infinite alternate}
.hero-mockup{position:relative;min-height:330px}.mock-main{position:absolute;inset:20px;background:linear-gradient(180deg,var(--card),var(--bg-2))}
.mock-mini-cal{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.mock-day{aspect-ratio:1;border-radius:6px;background:var(--bg);display:grid;place-items:center;font-size:10px;color:var(--ink-2);font-weight:700}
.mock-day.green{background:var(--green-soft);color:var(--green)}.mock-day.orange{background:var(--orange-soft);color:var(--orange)}.mock-day.blue{background:var(--info-soft);color:var(--blue)}
.mock-floater{position:absolute;display:flex;align-items:center;gap:10px}.mock-f1{right:-10px;top:14%}.mock-f2{left:6%;bottom:6%}.mock-stack{display:flex}.mock-stack>.avatar{margin-left:-6px;border:2px solid var(--card)}.mock-stack>.avatar:first-child{margin-left:0}
@keyframes floaty{from{transform:translateY(0)}to{transform:translateY(-8px)}}

.badge{
  display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:700;padding:3px 8px;border-radius:6px;
  background:var(--line-2);color:var(--ink-2);white-space:nowrap;
}
.badge svg{width:11px;height:11px;stroke-width:2.2}.badge.green{background:var(--green-soft);color:var(--green)}
.badge.orange{background:var(--orange-soft);color:var(--orange)}.badge.red{background:var(--red-soft);color:var(--red)}
.badge.blue{background:var(--info-soft);color:var(--blue)}.badge.ink{background:var(--ink);color:var(--card)}
.dot{width:6px;height:6px;border-radius:50%;background:currentColor}
.list-row{display:flex;align-items:center;gap:12px;padding:12px 4px;border-bottom:1px solid var(--line-2)}
.list-row:last-child{border-bottom:0}.meta{flex:1;min-width:0}.meta-title{font-weight:700;font-size:13.5px}.meta-sub{font-size:12px;color:var(--ink-2)}
.progress{height:6px;border-radius:3px;background:var(--line-2);overflow:hidden}.progress>span{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--blue),#5ac8fa);border-radius:inherit;transition:width 1.2s var(--ease-out)}
.progress.green>span{background:linear-gradient(90deg,#34a65f,#6bd68a)}.progress.orange>span{background:linear-gradient(90deg,#c8861a,#ffb857)}.progress.red>span{background:linear-gradient(90deg,#c9342e,#ff6b66)}
.ring-wrap{position:relative;width:132px;height:132px;flex-shrink:0}.ring-wrap svg{transform:rotate(-90deg)}.track{fill:none;stroke:var(--line);stroke-width:10}.progress-circle{fill:none;stroke:url(#ringGrad);stroke-width:10;stroke-linecap:round;transition:stroke-dashoffset 1.2s var(--ease-out)}
.ring-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}.ring-center .v{font-size:26px;font-weight:800}.ring-center .l{font-size:11px;color:var(--ink-2)}
.barchart{display:grid;grid-template-columns:repeat(7,1fr);gap:10px;align-items:end;height:140px}.bar{background:linear-gradient(180deg,var(--blue),color-mix(in srgb,var(--blue) 50%,transparent));border-radius:6px 6px 4px 4px;height:0;min-height:6px;transition:height 1.2s var(--ease-out)}.bar.warn{background:linear-gradient(180deg,var(--orange),transparent)}.bar.crit{background:linear-gradient(180deg,var(--red),transparent)}.bar-row{display:grid;grid-template-columns:repeat(7,1fr);gap:10px;margin-top:8px}.bar-label{font-size:11px;color:var(--ink-2);text-align:center}

.calendar{width:100%;max-width:100%;overflow:hidden;background:var(--card);border:1px solid var(--line);border-radius:var(--radius-lg);padding:22px;box-shadow:var(--shadow-xs)}
.cal-toolbar{display:grid;gap:14px;margin-bottom:18px}.cal-title-row{display:grid;grid-template-columns:38px minmax(0,1fr) 38px;align-items:center;gap:10px}.cal-month{font-size:22px;font-weight:800;letter-spacing:-.02em;min-width:0;text-align:center}.cal-controls{display:grid;grid-template-columns:auto minmax(130px,170px) minmax(150px,190px) auto;align-items:center;gap:10px}.calendar-filter{width:100%;min-width:0}.calendar-legend{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:18px}
.cal-tabs,.filter-tabs,.toggle-pill{display:flex;padding:3px;gap:2px;background:var(--bg);border-radius:9px;border:1px solid var(--line)}
.cal-tabs button,.filter-tabs button,.toggle-pill button{padding:6px 12px;font-size:12.5px;border-radius:7px;color:var(--ink-2);font-weight:700}
.cal-tabs button.active,.filter-tabs button.active,.toggle-pill button.active{background:var(--card);color:var(--ink);box-shadow:var(--shadow-xs)}
.cal-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:6px}.cal-dow{min-width:0;font-size:11px;font-weight:800;color:var(--ink-3);text-transform:uppercase;letter-spacing:.06em;padding:8px 10px}
.cal-cell{position:relative;min-width:0;min-height:96px;border-radius:12px;background:var(--bg-2);border:1px solid transparent;padding:8px 9px;display:flex;flex-direction:column;cursor:pointer;transition:background .25s var(--ease),border-color .25s var(--ease),transform .25s var(--ease)}
.cal-cell:hover{background:var(--card);border-color:var(--line);transform:translateY(-1px)}.cal-cell.muted{opacity:.35}.cal-cell.today{border-color:var(--blue);background:var(--blue-50)}.cal-cell.weekend{background:transparent}.cal-cell.crit{background:var(--red-soft);border-color:rgba(201,52,46,.25)}
.cal-num{font-size:12.5px;font-weight:800;color:var(--ink);margin-bottom:6px}.cal-events{display:flex;flex-direction:column;gap:3px;min-width:0}
.cal-event{min-width:0;font-size:11px;padding:2px 6px;border-radius:4px;background:var(--green-soft);color:var(--green);display:flex;align-items:center;gap:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cal-event.orange{background:var(--orange-soft);color:var(--orange)}.cal-event.red{background:var(--red-soft);color:var(--red)}.cal-event.blue{background:var(--info-soft);color:var(--blue)}.cal-event.ink{background:var(--line-2);color:var(--ink)}
.cal-more{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:10.5px;color:var(--ink-2);font-weight:700;padding:0 2px}.cal-count{position:absolute;top:6px;right:7px;font-size:10px;color:var(--ink-2);background:var(--card);border:1px solid var(--line);padding:1px 5px;border-radius:5px;font-weight:700}
.popover{position:absolute;z-index:100;background:var(--card);border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow-lg);padding:14px;min-width:240px;max-width:300px;pointer-events:none}

.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}.form-grid .full{grid-column:1/-1}.field{display:flex;flex-direction:column;gap:6px}.field label{font-size:12.5px;font-weight:700;color:var(--ink-2)}
.input,.select,textarea.input{padding:10px 12px;background:var(--card);border:1px solid var(--line);border-radius:10px;font-size:13.5px;outline:0;transition:border-color .2s var(--ease),box-shadow .2s var(--ease)}
.input:focus,.select:focus,textarea.input:focus{border-color:var(--blue);box-shadow:0 0 0 4px rgba(0,122,255,.15)}textarea.input{resize:vertical;min-height:96px}
.select{appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' fill='none' stroke='%236E6E73' stroke-width='2' stroke-linecap='round'><path d='M1 1l4 4 4-4'/></svg>");background-repeat:no-repeat;background-position:right 14px center;padding-right:32px}
.request-layout{display:grid;grid-template-columns:minmax(0,1.4fr) minmax(320px,1fr);gap:18px;align-items:start}.request-layout>.card,.request-sidebar{min-width:0}.request-sidebar{display:flex;flex-direction:column;gap:18px}.request-submit{width:100%;margin-top:14px}
.types-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.type-card{display:flex;flex-direction:column;align-items:flex-start;gap:6px;padding:12px;border:1px solid var(--line);border-radius:12px;background:var(--card);cursor:pointer;transition:all .25s var(--ease)}
.type-card:hover{border-color:rgba(0,122,255,.4)}.type-card.active{border-color:var(--blue);background:var(--blue-50);box-shadow:0 0 0 4px rgba(0,122,255,.08)}.type-card svg{width:18px;height:18px;color:var(--blue)}.t-name{font-size:13px;font-weight:800}.t-desc{font-size:11.5px;color:var(--ink-2)}
.dropzone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:24px;border:1.5px dashed var(--line);border-radius:14px;background:var(--bg-2);text-align:center;cursor:pointer;transition:all .25s var(--ease)}.dropzone:hover{border-color:var(--blue);background:var(--blue-50)}.dropzone.has-file{border-color:var(--green);background:var(--green-soft)}.dropzone.has-file .dz-title{color:var(--green);font-weight:700;word-break:break-all}
.summary-card{background:var(--bg-2);border:1px solid var(--line-2);border-radius:14px;padding:16px}.summary-row{display:flex;justify-content:space-between;gap:14px;padding:6px 0;font-size:13px}.summary-row .l{color:var(--ink-2)}.summary-row .r{font-weight:800;text-align:right}

.table-wrap{background:var(--card);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-xs)}.table{width:100%;border-collapse:collapse;font-size:13px}.table th{background:var(--bg-2);text-align:left;padding:12px 16px;font-size:11.5px;font-weight:800;color:var(--ink-2);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--line)}.table td{padding:14px 16px;border-bottom:1px solid var(--line-2);vertical-align:middle}.table tr:hover td{background:var(--bg-2)}.who{display:flex;align-items:center;gap:10px}.who-name{font-weight:800}.who-role{font-size:11.5px;color:var(--ink-2)}.actions-cell{display:flex;gap:6px;justify-content:flex-end}.action-btn{width:30px;height:30px;display:grid;place-items:center;border-radius:8px;color:var(--ink-2);transition:all .2s var(--ease);border:1px solid transparent}.action-btn:hover{background:var(--bg-2);border-color:var(--line);color:var(--ink)}.action-btn.approve:hover{color:var(--green);background:var(--green-soft)}.action-btn.reject:hover{color:var(--red);background:var(--red-soft)}.action-btn svg{width:15px;height:15px}
.employee-card{position:relative;padding:22px;background:var(--card);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs);transition:all .3s var(--ease)}.employee-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:rgba(0,122,255,.18)}.emp-head{display:flex;align-items:center;gap:14px;margin-bottom:14px}.emp-name{font-size:15px;font-weight:800}.emp-role{font-size:12.5px;color:var(--ink-2)}.emp-tags{display:flex;gap:6px;flex-wrap:wrap;margin-top:12px}.tag{font-size:11px;padding:3px 8px;background:var(--bg-2);border:1px solid var(--line);border-radius:6px;color:var(--ink-2)}.emp-stats{display:flex;align-items:end;justify-content:space-between;margin-top:10px}.emp-stat .v{font-size:18px;font-weight:800}.emp-stat .l{font-size:11px;color:var(--ink-2)}
.notif-panel{position:fixed;top:70px;right:18px;width:360px;max-width:calc(100vw - 24px);background:var(--card);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow-lg);z-index:200;overflow:hidden}.notif-head{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--line)}.notif-head h3{margin:0;font-size:14px}.notif-list{max-height:420px;overflow:auto}.notif-item{display:flex;gap:10px;padding:12px 16px;border-bottom:1px solid var(--line-2);cursor:pointer;transition:background .2s var(--ease)}.notif-item:hover{background:var(--bg-2)}.n-icon{width:32px;height:32px;flex-shrink:0;border-radius:9px;display:grid;place-items:center;background:var(--blue-50);color:var(--blue)}.notif-item.green .n-icon{background:var(--green-soft);color:var(--green)}.notif-item.orange .n-icon{background:var(--orange-soft);color:var(--orange)}.notif-item.red .n-icon{background:var(--red-soft);color:var(--red)}.n-title{font-size:13px;font-weight:800}.n-sub{font-size:12px;color:var(--ink-2);margin-top:2px}.n-time{font-size:11px;color:var(--ink-3);margin-top:4px}
.modal-backdrop{position:fixed;inset:0;z-index:300;background:rgba(15,17,21,.45);backdrop-filter:blur(10px);display:grid;place-items:center;padding:20px}.modal{background:var(--card);border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow-lg);width:100%;max-width:520px;padding:26px;animation:modalIn .35s var(--ease-out)}.modal.lg{max-width:760px}@keyframes modalIn{from{opacity:0;transform:scale(.94) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal h3{margin:0 0 6px;font-size:18px}.modal p{color:var(--ink-2);margin:0}.modal-foot{display:flex;justify-content:flex-end;gap:8px;margin-top:22px}.success-icon{width:60px;height:60px;margin:0 auto 14px;border-radius:50%;background:var(--green-soft);display:grid;place-items:center;color:var(--green)}
.platform-form-modal .form-grid{margin-top:16px}
.platform-form-modal .input,.platform-form-modal .select{min-height:46px}
.platform-form-modal .summary-card{margin-top:14px}
.platform-check{display:inline-flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid var(--line);border-radius:10px;background:var(--bg-2);font-size:13px;font-weight:700;color:var(--ink)}
.platform-check input{width:16px;height:16px;margin:0;accent-color:var(--blue)}
.modal-backdrop{overflow-y:auto}
.modal-scroll{max-height:calc(100dvh - 40px);overflow-y:auto}
@supports not (height: 100dvh){.modal-scroll{max-height:calc(100vh - 40px)}}
.guide{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}.guide-section{background:var(--card);border:1px solid var(--line-2);border-radius:var(--radius);overflow:hidden}.guide-section summary{display:flex;align-items:center;gap:10px;padding:14px 18px;font-size:14px;font-weight:700;cursor:pointer;list-style:none;user-select:none;transition:background .15s}.guide-section summary::-webkit-details-marker{display:none}.guide-section summary::before{content:"";width:18px;height:18px;background:var(--bg-2);border-radius:6px;flex-shrink:0;display:grid;place-items:center;transition:transform .2s var(--ease)}.guide-section[open] summary::before{transform:rotate(90deg)}.guide-section summary:hover{background:var(--bg-2)}.guide-section summary .guide-icon{width:28px;height:28px;border-radius:8px;display:grid;place-items:center;flex-shrink:0}.guide-section summary .guide-icon svg{width:14px;height:14px}.guide-section summary .guide-icon.blue{background:var(--info-soft);color:var(--blue)}.guide-section summary .guide-icon.green{background:var(--green-soft);color:var(--green)}.guide-section summary .guide-icon.orange{background:var(--orange-soft);color:var(--orange)}.guide-section summary .guide-icon.red{background:var(--red-soft);color:var(--red)}.guide-section summary .guide-icon.ink{background:var(--bg-2);color:var(--ink)}.guide-body{padding:0 18px 16px;font-size:13px;line-height:1.65;color:var(--ink-2)}.guide-body strong{color:var(--ink);font-weight:700}.guide-body ul{margin:6px 0;padding-left:18px}.guide-body li{margin-bottom:4px}.guide-body .guide-step{display:flex;gap:10px;padding:8px 0;align-items:flex-start}.guide-body .step-num{width:22px;height:22px;border-radius:50%;background:var(--blue);color:#fff;font-size:11px;font-weight:800;display:grid;place-items:center;flex-shrink:0;margin-top:1px}.guide-body .guide-tip{background:var(--info-soft);border-radius:10px;padding:10px 14px;margin-top:8px;font-size:12.5px;color:var(--blue);display:flex;align-items:flex-start;gap:8px}.guide-body .guide-tip svg{width:14px;height:14px;flex-shrink:0;margin-top:2px}.guide-tabs{display:flex;gap:6px;margin-bottom:16px;flex-wrap:wrap}.guide-tabs button{padding:6px 14px;border-radius:8px;border:1px solid var(--line-2);background:var(--bg-2);font-size:12.5px;font-weight:600;cursor:pointer;transition:all .15s}.guide-tabs button.active{background:var(--blue);color:#fff;border-color:var(--blue)}
.toast-stack{position:fixed;bottom:24px;right:24px;z-index:400;display:flex;flex-direction:column;gap:10px}.toast{display:flex;align-items:center;gap:10px;padding:12px 16px;background:var(--card);border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow-lg);min-width:260px;max-width:360px;animation:toastIn .35s var(--ease-out)}@keyframes toastIn{from{opacity:0;transform:translateX(40px)}to{opacity:1;transform:translateX(0)}}.toast.out{opacity:0;transform:translateX(40px);transition:all .3s}.t-icon{width:28px;height:28px;flex-shrink:0;border-radius:8px;display:grid;place-items:center}.toast.success .t-icon{background:var(--green-soft);color:var(--green)}.toast.info .t-icon{background:var(--blue-50);color:var(--blue)}.toast.error .t-icon{background:var(--red-soft);color:var(--red)}.t-title{font-size:13px;font-weight:800}.t-sub{font-size:12px;color:var(--ink-2)}
.login-shell{position:relative;z-index:2;min-height:100vh;display:grid;place-items:center;padding:24px}.login-card{width:min(440px,100%);background:rgba(255,255,255,.78);backdrop-filter:blur(22px);border:1px solid var(--line);border-radius:24px;padding:30px;box-shadow:var(--shadow-lg)}[data-theme="dark"] .login-card{background:rgba(22,22,24,.78)}
.login-shell{max-width:1200px;margin:0 auto;grid-template-columns:minmax(0,1.1fr) minmax(340px,440px);gap:24px;align-content:center;place-items:stretch}
.login-hero{background:linear-gradient(180deg,var(--card),color-mix(in srgb,var(--card) 92%,var(--blue) 8%));border:1px solid var(--line);border-radius:24px;padding:34px;box-shadow:var(--shadow-md)}
.login-hero-title{font-size:52px;font-weight:800;letter-spacing:-.035em;line-height:1.05;margin:8px 0 14px}
.login-hero-sub{font-size:16px;line-height:1.6;color:var(--ink-2);max-width:620px;margin:0}
.login-hero-cta{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:22px}
.login-mobile-only{display:none}
.login-hero .hero-features{margin-top:24px}
.login-card{width:100%}
.login-footer{grid-column:1/-1;max-width:none;margin:2px 0 0}
[data-theme="dark"] .login-hero{background:linear-gradient(180deg,var(--card),color-mix(in srgb,var(--card) 90%,var(--blue) 10%))}
.loading{min-height:100vh;display:grid;place-items:center;position:relative;z-index:2}.skeleton{background:linear-gradient(90deg,var(--line-2),var(--bg-2),var(--line-2));background-size:200% 100%;animation:shimmer 1.4s infinite;border-radius:12px}@keyframes shimmer{to{background-position:-200% 0}}
.mobile-overlay{position:fixed;inset:0;background:rgba(15,17,21,.38);backdrop-filter:none;-webkit-backdrop-filter:none;z-index:49}
.iswitch{width:38px;height:22px;border-radius:14px;background:var(--line);position:relative;transition:background .25s var(--ease);display:inline-block}.iswitch.on{background:var(--blue)}.iswitch-thumb{position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;background:white;box-shadow:0 2px 4px rgba(0,0,0,.18);transition:transform .25s var(--ease)}.iswitch.on .iswitch-thumb{transform:translateX(16px)}

@media(max-width:1100px){.grid-4{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(2,1fr)}.hero{grid-template-columns:1fr}.hero h1{font-size:40px}}
@media(max-width:960px){
  .app{grid-template-columns:1fr}.sidebar{position:fixed;top:0;left:0;width:280px;transform:translateX(-100%);z-index:60;background:var(--card);backdrop-filter:none;-webkit-backdrop-filter:none}.sidebar.open{transform:translateX(0);box-shadow:var(--shadow-lg)}.menu-btn{display:grid}.content{padding:20px 18px 34px}.app-footer{padding:18px 18px 28px;flex-direction:column;align-items:stretch;gap:12px}.app-footer>div:first-child{width:100%}.app-footer strong,.app-footer>div:first-child span{display:block}.app-footer-links{width:100%;justify-content:flex-start;align-items:flex-start;gap:8px 14px}.app-footer-links>span{width:100%;line-height:1.5}.public-topbar{padding:14px 18px;align-items:flex-start;flex-direction:column}.topbar{width:100%;padding:0 18px}.impersonation-banner{padding:11px 18px}.request-layout{grid-template-columns:1fr;gap:16px}.request-sidebar{gap:16px}.page-title{font-size:28px}.calendar{padding:14px}.cal-cell{min-height:64px}.date-chip{display:none}.login-shell{grid-template-columns:1fr;max-width:720px;padding:20px 18px}.login-hero{padding:24px}.login-hero-title{font-size:38px}.login-card{padding:24px}
}
@media(max-width:760px){.grid-4,.grid-3,.grid-2{grid-template-columns:1fr}.form-grid{grid-template-columns:1fr}.types-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.table thead{display:none}.table tr{display:grid;grid-template-columns:1fr 1fr;gap:6px;padding:14px;border-bottom:1px solid var(--line-2)}.table td{display:block;padding:4px 0;border:0}.actions-cell{grid-column:1/-1;justify-content:flex-start}.hero{padding:28px 22px}.hero h1{font-size:32px}}
@media(max-width:760px){.login-mobile-only{display:inline-flex}}
@media(max-width:600px){.search{display:none}.content{padding:18px 14px 32px}.topbar{gap:12px}.impersonation-banner{grid-template-columns:22px minmax(0,1fr);align-items:start;gap:8px 10px;padding:12px 14px;font-size:13px}.impersonation-banner svg{width:18px;height:18px;margin-top:1px}.impersonation-exit{grid-column:2;justify-self:start;margin-top:2px;padding:7px 14px}.page-head{margin-bottom:18px}.page-title{font-size:30px}.page-sub{font-size:14px;line-height:1.45}.request-layout{gap:14px}.request-card,.request-side-card{padding:18px;border-radius:18px}.request-card .card-title,.request-side-card .card-title{font-size:17px}.request-card .card-sub,.request-side-card .card-sub{font-size:13px}.type-card{min-height:112px;padding:13px 12px;gap:7px}.type-card svg{width:20px;height:20px}.t-name{font-size:14.5px;line-height:1.2}.t-desc{font-size:12.5px;line-height:1.3}.field label{font-size:13px}.input,.select,textarea.input{min-height:48px;font-size:16px}.toggle-pill{width:100%}.toggle-pill button{flex:1;min-height:42px;font-size:14px}.summary-card{padding:14px}.summary-row{font-size:14px;align-items:flex-start}.summary-row .l{flex:0 0 42%}.summary-row .r{min-width:0}.request-submit{min-height:50px;font-size:15px}.cal-cell{min-height:50px}.cal-event{display:none}.cal-cell.has-events:after{content:"";position:absolute;bottom:6px;left:50%;transform:translateX(-50%);width:6px;height:6px;border-radius:50%;background:var(--blue)}.cal-cell.has-crit:after{background:var(--red)}.cal-count{display:none}.profile-pill span{display:none}.login-footer{padding:0}.login-hero{padding:20px}.login-hero-title{font-size:32px}.login-hero-sub{font-size:15px}.login-hero-cta{gap:8px}.login-hero-cta .btn{flex:1}.login-card{padding:20px}.login-footer-links{gap:10px 16px}.public-topbar .app-footer-links{gap:8px 12px}.public-topbar .app-footer-links .btn{width:100%;margin-top:2px}.footer-link{min-height:32px}}
@media(max-width:960px){.cal-controls{grid-template-columns:repeat(2,minmax(0,1fr))}.calendar-today,.calendar-filter,.cal-tabs{width:100%;max-width:none}.cal-tabs{grid-column:1/-1}.cal-tabs button{flex:1}.calendar-legend{gap:8px}.calendar-legend .badge{max-width:100%;white-space:normal;line-height:1.25}.cal-grid{grid-template-columns:repeat(7,minmax(0,1fr))}}
@media(max-width:760px){.calendar{padding:12px;border-radius:20px}.cal-toolbar{gap:12px;margin-bottom:14px}.cal-title-row{grid-template-columns:34px minmax(0,1fr) 34px;gap:6px}.cal-title-row .icon-btn{width:34px;height:34px}.cal-month{font-size:28px;line-height:1.08}.cal-controls{gap:10px}.calendar-today{justify-content:center;min-height:42px}.calendar-filter{min-height:42px}.cal-tabs button{min-height:38px;font-size:13px}.calendar-legend{margin-bottom:14px}.calendar-legend .badge{font-size:12px;padding:5px 8px}.cal-grid-month{gap:4px}.cal-dow{text-align:center;padding:6px 0;font-size:10.5px;letter-spacing:.04em}.cal-cell{min-height:54px;border-radius:10px;padding:6px 4px;align-items:center;overflow:hidden}.cal-cell:hover{transform:none}.cal-num{align-self:flex-start;margin:0 0 0 2px;font-size:13px;line-height:1}.cal-grid-month .cal-events,.cal-grid-month .cal-event,.cal-grid-month .cal-more{display:none}.cal-grid-month .cal-cell.has-events:after{content:"";position:absolute;bottom:7px;left:50%;transform:translateX(-50%);width:5px;height:5px;border-radius:50%;background:var(--blue)}.cal-grid-month .cal-cell.has-crit:after{background:var(--red)}.cal-grid-month .cal-count{display:grid;place-items:center;top:auto;right:4px;bottom:4px;min-width:16px;height:16px;padding:0 4px;border:0;border-radius:999px;background:var(--blue);color:#fff;font-size:10px;line-height:1}.cal-grid-month .cal-cell.crit .cal-count{background:var(--red)}.cal-grid-month .cal-cell.muted .cal-count{display:none}.cal-grid-week{grid-template-columns:1fr;gap:10px}.cal-grid-week>div{min-width:0}.cal-grid-week .cal-cell{min-height:auto;align-items:stretch}.cal-grid-week .cal-cell.has-events:after{content:none;display:none}.cal-grid-week .cal-events{display:flex}.cal-grid-week .cal-event{display:flex;white-space:normal;line-height:1.25}}
@media(max-width:600px){.calendar{margin-left:-2px;margin-right:-2px}.cal-controls{grid-template-columns:1fr}.cal-tabs{grid-column:auto}.cal-grid-month{gap:3px}.cal-dow{font-size:10px}.cal-cell{min-height:50px;border-radius:9px;padding:5px 3px}.cal-num{font-size:12.5px}.cal-grid-month .cal-count{right:3px;bottom:3px;min-width:15px;height:15px;font-size:9.5px}.cal-grid-month .cal-cell.has-events:after{bottom:6px;width:4px;height:4px}.popover{max-width:calc(100vw - 24px);min-width:0}}
@media(max-width:360px){.types-grid{grid-template-columns:1fr}.type-card{min-height:auto}.summary-row{display:grid;grid-template-columns:1fr;gap:2px}.summary-row .l{flex:auto}.summary-row .r{text-align:left}}
