/* ============================================================
   Marketing Dept — managed workspace (automarketingdept.com)
   Theme: "The Team You Hired" — dark org/careers UI
   Accent: #5B7BFF (blue) · Warm secondary: #FFAE5C (amber)
   ============================================================ */

:root{
  --bg:        #0B0E17;
  --bg2:       #0E1220;
  --panel:     #131828;
  --panel2:    #181E32;
  --line:      #232A40;
  --line2:     #2C3450;
  --text:      #E8ECF8;
  --muted:     #8B93AD;
  --dim:       #5D6580;
  --blue:      #5B7BFF;
  --blue-soft: rgba(91,123,255,.14);
  --warm:      #FFAE5C;
  --warm-soft: rgba(255,174,92,.13);
  --green:     #4DD6A9;
  --green-soft:rgba(77,214,169,.13);
  --red:       #FF6B8A;
  --red-soft:  rgba(255,107,138,.12);
  --purple:    #C77BFF;
  --cyan:      #4DB8FF;
  --gold:      #FFD166;
  --radius:    14px;
  --disp:      "Space Grotesk", sans-serif;
  --body:      "Inter", sans-serif;
  --mono:      "JetBrains Mono", monospace;
  --side-w:    244px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--bg);
  color:var(--text);
  font-family:var(--body);
  font-size:14.5px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
a{color:var(--blue);text-decoration:none}
a:hover{text-decoration:none}
.mono{font-family:var(--mono);font-size:.78em;letter-spacing:.04em}
button{font-family:var(--body);cursor:pointer}
::selection{background:rgba(91,123,255,.35)}

/* ---------- layout ---------- */
.app{display:flex;min-height:100vh}
.main{flex:1;min-width:0;display:flex;flex-direction:column}
.view{flex:1;padding:26px 30px 40px;max-width:1240px;width:100%;margin:0 auto}

/* ---------- sidebar ---------- */
.sidebar{
  width:var(--side-w);flex-shrink:0;
  background:var(--bg2);
  border-right:1px solid var(--line);
  display:flex;flex-direction:column;
  position:sticky;top:0;height:100vh;
  padding:18px 14px;
}
.side-brand{display:flex;gap:11px;align-items:center;padding:4px 8px 18px}
.brand-mark{
  width:38px;height:38px;border-radius:10px;flex-shrink:0;
  background:linear-gradient(135deg,var(--blue),#3E56C4);
  display:grid;place-items:center;
  font-family:var(--disp);font-weight:700;font-size:19px;color:#fff;
  box-shadow:0 4px 18px rgba(91,123,255,.35);
}
.brand-name{font-family:var(--disp);font-weight:600;font-size:15.5px;letter-spacing:.01em}
.brand-sub{color:var(--dim);font-size:10.5px}
.side-label{color:var(--dim);font-size:10px;text-transform:uppercase;letter-spacing:.14em;padding:6px 10px 8px}
.side-nav{display:flex;flex-direction:column;gap:2px}
.nav-item{
  display:flex;align-items:center;gap:11px;
  padding:9px 12px;border-radius:9px;
  color:var(--muted);font-weight:500;font-size:14px;
  border:1px solid transparent;transition:.15s;
}
.nav-item:hover{color:var(--text);background:rgba(255,255,255,.03)}
.nav-item.active{
  color:var(--text);background:var(--blue-soft);
  border-color:rgba(91,123,255,.25);
}
.nav-item.active .nav-ico{color:var(--blue)}
.nav-ico{width:18px;text-align:center;font-size:14px;color:var(--dim);flex-shrink:0}
.nav-tag{margin-left:auto;color:var(--dim);font-size:10.5px}
.nav-badge{
  margin-left:auto;background:var(--warm);color:#1B1206;
  font-size:10.5px;font-weight:600;padding:1px 7px;border-radius:20px;
}
.nav-badge.zero{background:var(--line);color:var(--muted)}
.side-foot{margin-top:auto;display:flex;flex-direction:column;gap:12px;padding-top:16px}
.plan-chip{
  background:var(--panel);border:1px solid var(--line);border-radius:12px;
  padding:12px 14px;
}
.plan-price{font-family:var(--disp);font-weight:700;font-size:20px}
.plan-price span{font-size:12px;color:var(--muted);font-weight:500}
.plan-line{color:var(--muted);font-size:10.5px;margin-top:2px}
.live-dot{
  display:inline-block;width:7px;height:7px;border-radius:50%;
  background:var(--green);box-shadow:0 0 8px var(--green);
  animation:pulse 2.2s infinite;vertical-align:1px;
}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.45}}
.side-client{display:flex;gap:10px;align-items:center;padding:0 4px}
.side-client-name{font-weight:600;font-size:13.5px}
.side-client-sub{color:var(--dim);font-size:10px}

/* ---------- avatars (CSS monograms) ---------- */
.avatar{
  width:40px;height:40px;border-radius:50%;flex-shrink:0;
  display:grid;place-items:center;
  font-family:var(--disp);font-weight:700;font-size:14.5px;color:#fff;
  border:2px solid rgba(255,255,255,.14);
}
.avatar.lg{width:56px;height:56px;font-size:19px}
.avatar.sm{width:26px;height:26px;font-size:10px;border-width:1.5px}
.av-client{background:linear-gradient(135deg,#3B4C9E,#232E63);font-size:13px}

/* ---------- topbar ---------- */
.topbar{
  display:flex;align-items:flex-end;justify-content:space-between;gap:16px;
  padding:22px 30px 0;max-width:1240px;width:100%;margin:0 auto;
}
.crumb{color:var(--dim);font-size:10.5px;text-transform:uppercase;letter-spacing:.14em}
.page-title{font-family:var(--disp);font-weight:700;font-size:26px;letter-spacing:-.01em;margin-top:3px}
.topbar-right{display:flex;align-items:center;gap:14px;padding-bottom:4px}
.shift-chip{
  background:var(--green-soft);border:1px solid rgba(77,214,169,.25);
  color:var(--green);border-radius:20px;padding:4px 12px;font-size:11px;
}
.back-link{color:var(--dim);font-size:11px}
.back-link:hover{color:var(--muted)}

/* ---------- shared cards ---------- */
.panel{
  background:var(--panel);border:1px solid var(--line);
  border-radius:var(--radius);padding:20px 22px;
}
.panel-title{
  font-family:var(--disp);font-weight:600;font-size:15.5px;
  display:flex;align-items:center;gap:8px;margin-bottom:14px;
}
.panel-title .mono{color:var(--dim);font-weight:400;margin-left:auto}
.grid{display:grid;gap:16px}
.g2{grid-template-columns:1fr 1fr}
.g3{grid-template-columns:repeat(3,1fr)}
.g4{grid-template-columns:repeat(4,1fr)}
.section-gap{margin-top:16px}
.hint{color:var(--muted);font-size:13px}

/* ---------- buttons ---------- */
.btn{
  border:1px solid var(--line2);background:var(--panel2);color:var(--text);
  border-radius:9px;padding:8px 15px;font-size:13px;font-weight:600;
  transition:.15s;
}
.btn:hover{border-color:var(--blue);color:#fff;background:rgba(91,123,255,.12)}
.btn.primary{background:var(--blue);border-color:var(--blue);color:#fff}
.btn.primary:hover{background:#6E8AFF}
.btn.warm{background:var(--warm-soft);border-color:rgba(255,174,92,.4);color:var(--warm)}
.btn.warm:hover{background:rgba(255,174,92,.22)}
.btn.ghost{background:transparent}
.btn.sm{padding:5px 11px;font-size:12px;border-radius:7px}
.btn.danger{color:var(--red);border-color:rgba(255,107,138,.35)}
.btn.danger:hover{background:var(--red-soft)}
.btn:disabled{opacity:.45;cursor:default}

/* ---------- pills & statuses ---------- */
.pill{
  display:inline-block;padding:2px 9px;border-radius:20px;
  font-family:var(--mono);font-size:10px;letter-spacing:.05em;
  border:1px solid var(--line2);color:var(--muted);
}
.pill.blue{background:var(--blue-soft);color:var(--blue);border-color:rgba(91,123,255,.3)}
.pill.warm{background:var(--warm-soft);color:var(--warm);border-color:rgba(255,174,92,.3)}
.pill.green{background:var(--green-soft);color:var(--green);border-color:rgba(77,214,169,.3)}
.pill.red{background:var(--red-soft);color:var(--red);border-color:rgba(255,107,138,.3)}
.pill.purple{background:rgba(199,123,255,.12);color:var(--purple);border-color:rgba(199,123,255,.3)}
.pill.cyan{background:rgba(77,184,255,.12);color:var(--cyan);border-color:rgba(77,184,255,.3)}

/* ================= DASHBOARD ================= */
.dash-hero{
  display:grid;grid-template-columns:1.5fr 1fr;gap:16px;align-items:stretch;
}
.savings-card{
  background:linear-gradient(140deg,#151B31 0%,#101528 55%,#171226 100%);
  border:1px solid var(--line2);border-radius:var(--radius);
  padding:24px 26px;position:relative;overflow:hidden;
}
.savings-card::after{
  content:"";position:absolute;right:-70px;top:-70px;width:230px;height:230px;
  background:radial-gradient(circle,rgba(255,174,92,.16),transparent 68%);
}
.savings-label{color:var(--warm);font-family:var(--mono);font-size:10.5px;text-transform:uppercase;letter-spacing:.16em}
.savings-num{
  font-family:var(--disp);font-weight:700;font-size:46px;letter-spacing:-.02em;
  margin:6px 0 2px;color:#fff;font-variant-numeric:tabular-nums;
}
.savings-num small{font-size:18px;color:var(--muted);font-weight:500}
.savings-sub{color:var(--muted);font-size:13px;max-width:420px}
.savings-math{
  display:flex;gap:26px;margin-top:18px;padding-top:16px;
  border-top:1px solid var(--line);flex-wrap:wrap;
}
.savings-math div b{display:block;font-family:var(--disp);font-size:18px;font-weight:600}
.savings-math div span{color:var(--dim);font-size:11px;font-family:var(--mono)}
.savings-math .strike b{text-decoration:line-through;color:var(--muted)}
.savings-math .you b{color:var(--blue)}
.savings-math .save b{color:var(--warm)}

.plan-card{display:flex;flex-direction:column;justify-content:space-between}
.plan-card .big-price{font-family:var(--disp);font-weight:700;font-size:34px}
.plan-card .big-price span{font-size:14px;color:var(--muted);font-weight:500}
.plan-flags{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap}
.plan-meta{color:var(--muted);font-size:12.5px;margin-top:14px}
.plan-meta b{color:var(--text)}

.kpis{grid-template-columns:repeat(4,1fr)}
.kpi{padding:18px 20px}
.kpi-label{color:var(--muted);font-size:11.5px;font-family:var(--mono);text-transform:uppercase;letter-spacing:.1em}
.kpi-num{font-family:var(--disp);font-weight:700;font-size:27px;margin:6px 0 2px;font-variant-numeric:tabular-nums}
.kpi-trend{font-size:12px;font-weight:600}
.kpi-trend.up{color:var(--green)}
.kpi-trend.down{color:var(--red)}
.kpi-trend span{color:var(--dim);font-weight:400}
.kpi-spark{margin-top:10px}

.dash-cols{grid-template-columns:1.55fr 1fr}

.week-list{display:flex;flex-direction:column;gap:0}
.week-item{
  display:flex;gap:13px;align-items:flex-start;padding:11px 2px;
  border-bottom:1px solid var(--line);
}
.week-item:last-child{border-bottom:none}
.week-item .wtxt{flex:1;min-width:0}
.week-item .wtitle{font-weight:600;font-size:13.5px}
.week-item .wsub{color:var(--muted);font-size:12px;margin-top:1px}
.week-item .wtag{margin-left:auto;flex-shrink:0;align-self:center}

.feed{display:flex;flex-direction:column}
.feed-item{
  display:flex;gap:11px;padding:10px 2px;border-bottom:1px solid var(--line);
  font-size:13px;
}
.feed-item:last-child{border-bottom:none}
.feed-ico{
  width:26px;height:26px;border-radius:8px;background:var(--panel2);
  display:grid;place-items:center;font-size:12px;flex-shrink:0;
  border:1px solid var(--line2);
}
.feed-txt{flex:1;color:var(--text)}
.feed-txt b{font-weight:600}
.feed-time{color:var(--dim);font-size:10.5px;font-family:var(--mono);flex-shrink:0;padding-top:2px}

.approve-callout{
  display:flex;align-items:center;gap:16px;
  background:var(--warm-soft);border:1px solid rgba(255,174,92,.35);
  border-radius:var(--radius);padding:15px 20px;
}
.approve-callout .ico{
  width:38px;height:38px;border-radius:10px;background:rgba(255,174,92,.2);
  display:grid;place-items:center;font-size:17px;color:var(--warm);flex-shrink:0;
}
.approve-callout b{color:var(--warm)}
.approve-callout .btn{margin-left:auto;flex-shrink:0}

/* ================= TEAM ================= */
.team-grid{grid-template-columns:repeat(auto-fill,minmax(330px,1fr))}
.staff-card{display:flex;flex-direction:column;gap:0;padding:0;overflow:hidden}
.staff-head{display:flex;gap:14px;align-items:center;padding:18px 20px 14px}
.staff-name{font-family:var(--disp);font-weight:600;font-size:16px}
.staff-role{color:var(--muted);font-size:12.5px}
.staff-status{margin-left:auto;flex-shrink:0;text-align:right}
.on-shift{
  color:var(--green);font-family:var(--mono);font-size:10px;
  background:var(--green-soft);border:1px solid rgba(77,214,169,.3);
  padding:3px 9px;border-radius:20px;white-space:nowrap;
}
.staff-bio{padding:0 20px 12px;color:var(--muted);font-size:12.8px;font-style:italic}
.staff-shipped{border-top:1px solid var(--line);padding:13px 20px 8px;flex:1}
.shipped-label{font-family:var(--mono);font-size:10px;color:var(--dim);text-transform:uppercase;letter-spacing:.13em;margin-bottom:8px}
.shipped-list{list-style:none;display:flex;flex-direction:column;gap:7px}
.shipped-list li{
  font-size:12.8px;color:var(--text);padding-left:16px;position:relative;
}
.shipped-list li::before{
  content:"→";position:absolute;left:0;color:var(--blue);font-size:11px;
}
.staff-foot{
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 20px 16px;border-top:1px solid var(--line);margin-top:10px;
}
.staff-meta{color:var(--dim);font-size:10.5px;font-family:var(--mono)}

/* org chart */
.org{padding:30px 22px 34px;text-align:center}
.org-you{
  display:inline-flex;flex-direction:column;align-items:center;gap:8px;
  background:var(--panel2);border:1px solid var(--line2);border-radius:14px;
  padding:16px 30px;position:relative;
}
.org-you .avatar{background:linear-gradient(135deg,var(--warm),#D97E1F)}
.org-you-name{font-family:var(--disp);font-weight:600;font-size:15px}
.org-you-role{color:var(--muted);font-size:11.5px;font-family:var(--mono)}
.org-stem{width:2px;height:26px;background:var(--line2);margin:0 auto}
.org-rail{height:2px;background:var(--line2);margin:0 auto;max-width:860px;position:relative}
.org-row{
  display:flex;justify-content:center;gap:12px;flex-wrap:wrap;
  max-width:980px;margin:0 auto;
}
.org-node{
  display:flex;flex-direction:column;align-items:center;gap:7px;
  background:var(--panel2);border:1px solid var(--line);border-radius:12px;
  padding:14px 10px 12px;width:118px;position:relative;margin-top:24px;
  transition:.15s;cursor:pointer;
}
.org-node::before{
  content:"";position:absolute;top:-24px;left:50%;width:2px;height:24px;
  background:var(--line2);
}
.org-node:hover{border-color:var(--blue);transform:translateY(-2px)}
.org-node .nm{font-weight:600;font-size:12px;line-height:1.25}
.org-node .rl{color:var(--dim);font-size:9.5px;font-family:var(--mono);line-height:1.3}

/* ================= CALENDAR ================= */
.cal-head{display:flex;align-items:center;gap:14px;margin-bottom:14px;flex-wrap:wrap}
.cal-range{font-family:var(--disp);font-weight:600;font-size:16px}
.cal-legend{display:flex;gap:12px;margin-left:auto;flex-wrap:wrap}
.cal-legend span{font-size:11px;color:var(--muted);display:flex;align-items:center;gap:5px}
.cal-legend i{width:9px;height:9px;border-radius:3px;display:inline-block}
.cal-grid{
  display:grid;grid-template-columns:repeat(7,1fr);gap:10px;
}
.cal-day{
  background:var(--panel);border:1px solid var(--line);border-radius:12px;
  padding:10px 10px 12px;min-height:190px;
}
.cal-day.today{border-color:rgba(91,123,255,.5);background:linear-gradient(180deg,rgba(91,123,255,.07),var(--panel))}
.cal-dayname{font-family:var(--mono);font-size:10px;color:var(--dim);text-transform:uppercase;letter-spacing:.1em}
.cal-daynum{font-family:var(--disp);font-weight:600;font-size:17px;margin:1px 0 9px}
.cal-day.today .cal-daynum{color:var(--blue)}
.cal-items{display:flex;flex-direction:column;gap:6px}
.cal-item{
  border-radius:8px;padding:6px 8px 7px;font-size:11.3px;line-height:1.35;
  border:1px solid;cursor:pointer;transition:.12s;font-weight:500;
}
.cal-item:hover{transform:translateY(-1px);filter:brightness(1.15)}
.cal-item .ci-time{font-family:var(--mono);font-size:9px;opacity:.75;display:block}

/* ================= APPROVALS ================= */
.appr-list{display:flex;flex-direction:column;gap:14px}
.appr-card{padding:0;overflow:hidden}
.appr-top{display:flex;gap:14px;align-items:center;padding:16px 20px 12px}
.appr-type{
  width:40px;height:40px;border-radius:10px;display:grid;place-items:center;
  font-size:16px;flex-shrink:0;border:1px solid;
}
.appr-title{font-weight:600;font-size:14.5px}
.appr-sub{color:var(--muted);font-size:12px;margin-top:1px}
.appr-body{
  margin:0 20px 14px;padding:13px 16px;background:var(--bg2);
  border:1px solid var(--line);border-radius:10px;
  color:var(--muted);font-size:12.8px;line-height:1.6;
}
.appr-body b{color:var(--text)}
.appr-actions{
  display:flex;gap:9px;align-items:center;padding:12px 20px 16px;
  border-top:1px solid var(--line);
}
.appr-decided{color:var(--muted);font-size:12.5px;font-style:italic}
.appr-empty{padding:40px;text-align:center;color:var(--muted)}
.appr-empty .big{font-size:34px;margin-bottom:8px}

/* ================= ANALYTICS ================= */
.chart-panel svg{display:block;width:100%;height:auto}
.chart-note{color:var(--dim);font-size:11px;font-family:var(--mono);margin-top:8px}
.legend{display:flex;gap:14px;flex-wrap:wrap;margin-top:12px}
.legend span{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--muted)}
.legend i{width:10px;height:10px;border-radius:3px;display:inline-block}
.stat-row{display:flex;gap:22px;flex-wrap:wrap;margin-bottom:4px}
.stat-row div b{display:block;font-family:var(--disp);font-size:21px;font-weight:600}
.stat-row div span{color:var(--dim);font-size:10.5px;font-family:var(--mono)}

/* ================= LIBRARY ================= */
.lib-tools{display:flex;gap:10px;margin-bottom:14px;flex-wrap:wrap;align-items:center}
.lib-search{
  background:var(--panel);border:1px solid var(--line);border-radius:9px;
  color:var(--text);padding:9px 14px;font-size:13.5px;font-family:var(--body);
  width:260px;max-width:100%;
}
.lib-search:focus{outline:none;border-color:var(--blue)}
.chip{
  border:1px solid var(--line2);background:var(--panel);color:var(--muted);
  border-radius:20px;padding:5px 13px;font-size:12px;font-weight:500;transition:.13s;
}
.chip:hover{color:var(--text)}
.chip.active{background:var(--blue-soft);border-color:rgba(91,123,255,.45);color:var(--blue)}
.lib-count{margin-left:auto;color:var(--dim);font-family:var(--mono);font-size:11px}
.table-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:var(--radius);background:var(--panel)}
table{width:100%;border-collapse:collapse;font-size:13px;min-width:720px}
th{
  text-align:left;font-family:var(--mono);font-size:10px;color:var(--dim);
  text-transform:uppercase;letter-spacing:.11em;font-weight:500;
  padding:11px 16px;border-bottom:1px solid var(--line);white-space:nowrap;
}
td{padding:11px 16px;border-bottom:1px solid var(--line);vertical-align:middle}
tbody tr{cursor:pointer;transition:.12s}
tbody tr:hover{background:rgba(91,123,255,.05)}
tbody tr:last-child td{border-bottom:none}
td .t-title{font-weight:600}
td .t-sub{color:var(--dim);font-size:11px;margin-top:1px}
.owner-cell{display:flex;align-items:center;gap:8px;white-space:nowrap}

/* ================= CONNECTIONS ================= */
.conn-meter{margin-bottom:18px}
.meter-track{height:9px;background:var(--panel2);border-radius:20px;overflow:hidden;border:1px solid var(--line)}
.meter-fill{height:100%;background:linear-gradient(90deg,var(--blue),var(--warm));border-radius:20px;transition:width .5s cubic-bezier(.2,.8,.3,1)}
.meter-line{display:flex;justify-content:space-between;margin-bottom:8px;align-items:baseline}
.meter-line b{font-family:var(--disp);font-size:19px}
.conn-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}
.conn-card{display:flex;gap:14px;align-items:center;padding:16px 18px}
.conn-logo{
  width:42px;height:42px;border-radius:11px;display:grid;place-items:center;
  font-family:var(--disp);font-weight:700;font-size:15px;color:#fff;flex-shrink:0;
  border:1px solid rgba(255,255,255,.12);
}
.conn-name{font-weight:600;font-size:14px}
.conn-sub{color:var(--muted);font-size:11.5px;margin-top:1px}
.conn-state{font-family:var(--mono);font-size:9.5px;margin-top:3px}
.conn-state.on{color:var(--green)}
.conn-state.off{color:var(--dim)}
/* toggle */
.tgl{margin-left:auto;flex-shrink:0;width:44px;height:24px;border-radius:20px;border:1px solid var(--line2);background:var(--panel2);position:relative;transition:.2s;padding:0}
.tgl::after{
  content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;
  background:var(--muted);transition:.2s;
}
.tgl.on{background:rgba(77,214,169,.25);border-color:rgba(77,214,169,.5)}
.tgl.on::after{left:22px;background:var(--green)}

/* ================= SETTINGS ================= */
.set-grid{grid-template-columns:1.4fr 1fr;align-items:start}
.field{margin-bottom:14px}
.field label{
  display:block;font-family:var(--mono);font-size:10px;color:var(--dim);
  text-transform:uppercase;letter-spacing:.12em;margin-bottom:6px;
}
.field input,.field textarea,.field select{
  width:100%;background:var(--bg2);border:1px solid var(--line);border-radius:9px;
  color:var(--text);padding:10px 13px;font-size:13.5px;font-family:var(--body);
}
.field textarea{resize:vertical;min-height:74px;line-height:1.5}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--blue)}
.invoice-row{
  display:flex;align-items:center;gap:12px;padding:11px 2px;
  border-bottom:1px solid var(--line);font-size:13px;
}
.invoice-row:last-child{border-bottom:none}
.invoice-row .inv-id{font-family:var(--mono);font-size:11px;color:var(--muted)}
.invoice-row .inv-amt{margin-left:auto;font-weight:600;font-family:var(--disp)}
.roster-row{
  display:flex;justify-content:space-between;padding:7px 2px;font-size:12.5px;
  border-bottom:1px dashed var(--line);color:var(--muted);
}
.roster-row:last-child{border-bottom:none}
.roster-row b{color:var(--text);font-weight:500}
.roster-row .amt{font-family:var(--mono);font-size:11px}
.roster-total{display:flex;justify-content:space-between;padding:10px 2px 2px;font-weight:600}
.roster-total .amt{font-family:var(--mono);color:var(--warm)}

/* ================= MODAL ================= */
.modal-wrap{position:fixed;inset:0;z-index:90;display:grid;place-items:center;padding:20px}
.modal-wrap[hidden]{display:none}
.modal-scrim{position:absolute;inset:0;background:rgba(5,7,14,.72);backdrop-filter:blur(3px)}
.modal{
  position:relative;background:var(--panel);border:1px solid var(--line2);
  border-radius:16px;max-width:560px;width:100%;padding:24px 26px;
  max-height:82vh;overflow-y:auto;
  box-shadow:0 24px 70px rgba(0,0,0,.55);
  animation:mIn .18s cubic-bezier(.2,.9,.3,1.2);
}
@keyframes mIn{from{opacity:0;transform:translateY(12px) scale(.98)}to{opacity:1;transform:none}}
.modal h3{font-family:var(--disp);font-size:18px;margin-bottom:4px;padding-right:30px}
.modal .m-sub{color:var(--muted);font-size:12.5px;margin-bottom:14px}
.modal .m-body{color:var(--text);font-size:13.5px;line-height:1.65}
.modal .m-body p{margin-bottom:10px}
.modal .m-close{
  position:absolute;top:14px;right:14px;width:30px;height:30px;border-radius:8px;
  border:1px solid var(--line2);background:var(--panel2);color:var(--muted);font-size:14px;
}
.modal .m-close:hover{color:var(--text)}
.m-kv{display:flex;gap:10px;flex-wrap:wrap;margin:12px 0}

/* ================= TOASTS ================= */
.toasts{position:fixed;bottom:22px;right:22px;z-index:120;display:flex;flex-direction:column;gap:9px}
.toast{
  background:var(--panel2);border:1px solid var(--line2);border-left:3px solid var(--blue);
  border-radius:10px;padding:11px 16px;font-size:13px;min-width:230px;max-width:340px;
  box-shadow:0 12px 34px rgba(0,0,0,.5);
  animation:tIn .22s cubic-bezier(.2,.9,.3,1.15);
}
.toast.warm{border-left-color:var(--warm)}
.toast.green{border-left-color:var(--green)}
.toast.out{opacity:0;transform:translateX(16px);transition:.28s}
@keyframes tIn{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:none}}

/* ================= FOOTER ================= */
.app-foot{
  display:flex;justify-content:space-between;align-items:center;gap:12px;
  padding:16px 30px 22px;max-width:1240px;width:100%;margin:0 auto;
  color:var(--dim);font-size:12px;border-top:1px solid var(--line);flex-wrap:wrap;
}
.app-foot a{color:var(--muted);font-size:11px}
.app-foot a:hover{color:var(--blue)}

/* ================= RESPONSIVE ================= */
@media (max-width:1080px){
  .kpis{grid-template-columns:repeat(2,1fr)}
  .dash-cols,.dash-hero,.set-grid{grid-template-columns:1fr}
  .g3{grid-template-columns:1fr 1fr}
  .cal-grid{grid-template-columns:repeat(4,1fr)}
  .cal-day{min-height:150px}
}
@media (max-width:900px){
  .app{flex-direction:column}
  .sidebar{
    width:100%;height:auto;position:static;flex-direction:column;
    border-right:none;border-bottom:1px solid var(--line);padding:12px 14px;
  }
  .side-nav{flex-direction:row;overflow-x:auto;gap:5px;padding-bottom:4px;scrollbar-width:none}
  .side-nav::-webkit-scrollbar{display:none}
  .nav-item{white-space:nowrap;padding:7px 12px;font-size:13px}
  .nav-tag{display:none}
  .side-label{display:none}
  .side-foot{display:none}
  .side-brand{padding-bottom:10px}
  .topbar{padding:16px 18px 0;flex-wrap:wrap}
  .view{padding:18px 18px 32px}
  .page-title{font-size:21px}
  .savings-num{font-size:34px}
  .app-foot{padding:14px 18px 20px}
}
@media (max-width:640px){
  .kpis,.g2,.g3{grid-template-columns:1fr}
  .cal-grid{grid-template-columns:repeat(2,1fr)}
  .cal-day{min-height:0}
  .team-grid{grid-template-columns:1fr}
  .org-node{width:104px}
  .appr-actions{flex-wrap:wrap}
  .topbar-right{display:none}
  .savings-math{gap:16px}
  .lib-search{width:100%}
  .lib-count{margin-left:0;width:100%}
}
