: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)}
.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}
.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;
}
.content{padding:28px 32px 64px;max-width:1440px;width:100%;margin:0 auto;flex:1;min-width:0}
.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{background:var(--card);border:1px solid var(--line);border-radius:var(--radius-lg);padding:22px;box-shadow:var(--shadow-xs)}
.cal-toolbar{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:18px}.cal-month{font-size:22px;font-weight:800;letter-spacing:-.02em;min-width:200px}
.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,1fr);gap:6px}.cal-dow{font-size:11px;font-weight:800;color:var(--ink-3);text-transform:uppercase;letter-spacing:.06em;padding:8px 10px}
.cal-cell{position:relative;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}
.cal-event{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{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}
.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)}
.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)}
.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)}
.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,.4);backdrop-filter:blur(6px);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}.sidebar.open{transform:translateX(0);box-shadow:var(--shadow-lg)}.menu-btn{display:grid}.content{padding:20px 18px 60px}.topbar{padding:0 18px}.page-title{font-size:28px}.calendar{padding:14px}.cal-cell{min-height:64px}.date-chip{display:none}
}
@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,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:600px){.search{display:none}.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}}
