/* ============================================================
   With the Hive — shared client-dashboard stylesheet
   Every color/font is a CSS variable. Per-client themes override
   these in an inline <style> injected by the template. Do not
   hardcode client colors here — change them in the client JSON.
   ============================================================ */
:root{
  --cream:#F6F0E4; --cream-2:#EFE7D6; --paper:#FFFDF7;
  --ink:#23291E; --ink-soft:#5A5F4E;
  --cedar:#3C4A33; --cedar-2:#566B49; --sage:#E4E9D7;
  --clay:#B5673F; --clay-soft:#E7C9B4;
  --honey:#D99A2B; --honey-deep:#B97E16;
  --good:#5B7A4E; --bad:#B5523F;
  --sidebar-grad:linear-gradient(170deg,#39472F 0%,#2C3724 100%);
  --sidebar-ink:#2C3724;
  --avatar-grad:linear-gradient(135deg,#B5673F,#915132);
  --line:rgba(35,41,30,0.12); --line-2:rgba(35,41,30,0.07);
  --shadow:0 1px 2px rgba(35,41,30,.05), 0 8px 28px -12px rgba(35,41,30,.18);
  --shadow-lg:0 30px 70px -30px rgba(35,41,30,.4);
  --radius:18px;
  --display:"Fraunces",Georgia,serif;
  --body:"Hanken Grotesk",-apple-system,BlinkMacSystemFont,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--body);color:var(--ink);background:var(--cream);
  background-image:
    radial-gradient(1200px 600px at 100% -10%, color-mix(in srgb, var(--honey) 8%, transparent), transparent 60%),
    radial-gradient(900px 500px at -10% 110%, color-mix(in srgb, var(--cedar) 11%, transparent), transparent 55%);
  background-attachment:fixed;-webkit-font-smoothing:antialiased;line-height:1.5;
}
::selection{background:var(--honey);color:var(--ink)}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}

.app{display:grid;grid-template-columns:264px 1fr;min-height:100vh}

/* sidebar */
.sidebar{position:sticky;top:0;height:100vh;background:var(--sidebar-grad);color:#EEE9DA;display:flex;flex-direction:column;padding:26px 20px;gap:26px;border-right:1px solid rgba(0,0,0,.2)}
.brand{display:flex;align-items:center;gap:11px}
.hex{width:34px;height:38px;flex:0 0 auto;filter:drop-shadow(0 2px 6px rgba(0,0,0,.3))}
.brand .wm{display:flex;flex-direction:column;line-height:1}
.brand .wm b{font-family:var(--display);font-weight:600;font-size:16px;letter-spacing:.5px}
.brand .wm span{font-size:9.5px;letter-spacing:3px;text-transform:uppercase;color:var(--honey);margin-top:4px}
.client-switch{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:14px;padding:12px 13px;display:flex;align-items:center;gap:11px;cursor:pointer;transition:.2s}
.client-switch:hover{background:rgba(255,255,255,.1)}
.c-avatar{width:34px;height:34px;border-radius:9px;background:var(--avatar-grad);display:grid;place-items:center;font-family:var(--display);font-weight:600;font-size:13px;color:#fff;flex:0 0 auto}
.client-switch .meta{flex:1;min-width:0}
.client-switch .meta b{display:block;font-size:13.5px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.client-switch .meta span{font-size:11px;color:rgba(238,233,218,.6)}
.client-switch .caret{color:rgba(238,233,218,.5);font-size:12px}
nav{display:flex;flex-direction:column;gap:3px;margin-top:2px}
.nav-label{font-size:10px;letter-spacing:2px;text-transform:uppercase;color:rgba(238,233,218,.4);padding:0 12px;margin-bottom:7px}
nav a{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:11px;font-size:14px;font-weight:500;color:rgba(238,233,218,.78);transition:.18s;position:relative}
nav a svg{width:18px;height:18px;opacity:.8}
nav a:hover{background:rgba(255,255,255,.07);color:#fff}
nav a.active{background:var(--honey);color:var(--sidebar-ink);font-weight:600}
nav a.active svg{opacity:1}
.side-foot{margin-top:auto;display:flex;flex-direction:column;gap:14px}
.cta-call{background:var(--honey);color:var(--sidebar-ink);border-radius:13px;padding:13px 15px;font-weight:600;font-size:13.5px;display:flex;align-items:center;gap:10px;justify-content:center;transition:.2s;box-shadow:0 6px 18px -6px color-mix(in srgb, var(--honey) 60%, transparent)}
.cta-call:hover{transform:translateY(-2px);filter:brightness(1.05)}
.side-note{font-size:11px;color:rgba(238,233,218,.45);line-height:1.5;text-align:center}

/* main */
.scrim{display:none}
.main{min-width:0;display:flex;flex-direction:column}
.topbar{display:flex;align-items:center;gap:18px;padding:20px 38px;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:30;background:color-mix(in srgb, var(--cream) 82%, transparent);backdrop-filter:blur(14px)}
.greet{flex:1;min-width:0}
.greet h1{font-family:var(--display);font-weight:500;font-size:22px;letter-spacing:-.2px}
.greet h1 em{font-style:italic;color:var(--cedar-2)}
.greet p{font-size:13px;color:var(--ink-soft);margin-top:2px}
.period{position:relative}
.period-btn{display:flex;align-items:center;gap:10px;background:var(--paper);border:1px solid var(--line);border-radius:12px;padding:10px 14px;font-size:13.5px;font-weight:600;box-shadow:var(--shadow);transition:.18s}
.period-btn:hover{border-color:var(--cedar-2)}
.period-btn .dot{width:7px;height:7px;border-radius:50%;background:var(--honey)}
.period-menu{position:absolute;right:0;top:calc(100% + 8px);background:var(--paper);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow-lg);padding:6px;min-width:200px;display:none;z-index:40}
.period-menu.open{display:block;animation:pop .16s ease}
.period-menu button{display:flex;width:100%;align-items:center;justify-content:space-between;padding:10px 12px;border-radius:9px;font-size:13.5px;font-weight:500;transition:.12s}
.period-menu button:hover{background:var(--sage)}
.period-menu button.sel{color:var(--cedar);font-weight:600}
.period-menu button .tick{color:var(--cedar);opacity:0}
.period-menu button.sel .tick{opacity:1}
.icon-btn{width:42px;height:42px;border-radius:12px;background:var(--paper);border:1px solid var(--line);display:grid;place-items:center;box-shadow:var(--shadow);transition:.18s;position:relative}
.icon-btn:hover{border-color:var(--cedar-2)}
.icon-btn svg{width:18px;height:18px}
.icon-btn .badge{position:absolute;top:8px;right:9px;width:8px;height:8px;background:var(--clay);border-radius:50%;border:2px solid var(--paper)}
.me{width:42px;height:42px;border-radius:12px;background:linear-gradient(135deg,var(--cedar-2),var(--cedar));display:grid;place-items:center;color:#fff;font-family:var(--display);font-weight:600;font-size:14px}
.content{padding:30px 38px 70px;display:flex;flex-direction:column;gap:30px;max-width:1240px;width:100%}
.section-head{display:flex;align-items:baseline;gap:14px;margin-bottom:-6px}
.section-head h2{font-family:var(--display);font-weight:500;font-size:21px;letter-spacing:-.2px}
.section-head .ln{flex:1;height:1px;background:var(--line)}
.section-head .meta{font-size:12px;color:var(--ink-soft);font-weight:500}
.card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}

/* hero */
.hero{display:grid;grid-template-columns:1.55fr 1fr;gap:18px}
.hero-summary{padding:26px 28px;position:relative;overflow:hidden}
.hero-summary::after{content:"";position:absolute;right:-60px;top:-60px;width:200px;height:200px;background:radial-gradient(circle,color-mix(in srgb,var(--honey) 14%,transparent),transparent 70%)}
.ai-tag{display:inline-flex;align-items:center;gap:7px;font-size:11px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;color:var(--honey-deep);background:color-mix(in srgb,var(--honey) 13%,transparent);padding:5px 11px;border-radius:30px;margin-bottom:16px}
.ai-tag svg{width:13px;height:13px}
.hero-summary h3{font-family:var(--display);font-size:20px;font-weight:500;margin-bottom:12px;letter-spacing:-.2px}
.hero-summary p{font-size:14.5px;color:var(--ink-soft);line-height:1.65;max-width:54ch}
.hero-summary p b{color:var(--ink);font-weight:600}
.hero-highlights{display:flex;gap:26px;margin-top:22px;flex-wrap:wrap}
.hl{display:flex;flex-direction:column}
.hl .v{font-family:var(--display);font-size:25px;font-weight:600;color:var(--cedar)}
.hl .l{font-size:11.5px;color:var(--ink-soft);margin-top:1px}
.hl .d{font-size:11.5px;font-weight:600;margin-top:3px}
.up{color:var(--good)} .down{color:var(--bad)}
.goals{padding:24px 26px;display:flex;flex-direction:column}
.goals h3{font-family:var(--display);font-size:16px;font-weight:600;margin-bottom:16px;display:flex;align-items:center;gap:9px}
.goals h3 svg{width:17px;height:17px;color:var(--clay)}
.goal{display:flex;flex-direction:column;gap:7px;margin-bottom:16px}
.goal:last-child{margin-bottom:0}
.goal .gt{display:flex;justify-content:space-between;font-size:13px;font-weight:500}
.goal .gt span{color:var(--ink-soft);font-weight:600}
.bar{height:7px;background:var(--cream-2);border-radius:10px;overflow:hidden}
.bar i{display:block;height:100%;border-radius:10px;background:linear-gradient(90deg,var(--cedar-2),var(--cedar));width:0;transition:width 1.1s cubic-bezier(.2,.8,.2,1)}
.bar.honey i{background:linear-gradient(90deg,var(--honey),var(--honey-deep))}

/* kpis */
.kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.kpi{padding:20px 21px;position:relative;overflow:hidden;transition:.25s}
.kpi:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.kpi .name{font-size:12.5px;color:var(--ink-soft);font-weight:600;display:flex;align-items:center;gap:8px;margin-bottom:13px}
.kpi .name .ic{width:30px;height:30px;border-radius:9px;background:var(--sage);display:grid;place-items:center;color:var(--cedar)}
.kpi .name .ic svg{width:15px;height:15px}
.kpi .val{font-family:var(--display);font-size:29px;font-weight:600;letter-spacing:-.5px;line-height:1}
.kpi .sub{display:flex;align-items:center;gap:8px;margin-top:10px;font-size:12.5px}
.kpi .delta{font-weight:700;display:inline-flex;align-items:center;gap:3px}
.kpi .delta svg{width:12px;height:12px}
.kpi .vs{color:var(--ink-soft)}
.spark{position:absolute;right:16px;bottom:14px;width:62px;height:30px;opacity:.85}

/* funnel (service clients) */
.funnel{padding:24px 26px}
.funnel-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.funnel-head h3{font-family:var(--display);font-size:18px;font-weight:600}
.funnel-head .meta{font-size:12px;color:var(--ink-soft);font-weight:600}
.frow{display:flex;align-items:center;gap:16px;padding:7px 0}
.frow .flabel{width:172px;font-size:13.5px;font-weight:700;flex:0 0 auto}
.fbar-wrap{flex:1;background:var(--cream-2);border-radius:10px;height:38px;overflow:hidden}
.fbar{height:100%;border-radius:10px;background:linear-gradient(90deg,var(--cedar-2),var(--cedar));display:flex;align-items:center;padding:0 15px;color:#fff;font-family:var(--display);font-weight:700;font-size:16px;width:0;transition:width 1s cubic-bezier(.2,.8,.2,1);white-space:nowrap}
.fconv{width:128px;flex:0 0 auto;font-size:12px;color:var(--ink-soft);text-align:right;font-weight:600}

/* chart */
.chart-card{padding:24px 26px}
.chart-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;flex-wrap:wrap;gap:12px}
.chart-head h3{font-family:var(--display);font-size:17px;font-weight:600}
.legend{display:flex;gap:16px;font-size:12px;color:var(--ink-soft);font-weight:500}
.legend span{display:inline-flex;align-items:center;gap:6px}
.legend i{width:11px;height:11px;border-radius:3px;display:inline-block}
.chartwrap{position:relative;width:100%;height:230px}
svg.chart{width:100%;height:100%;overflow:visible}
.chart .gridline{stroke:var(--line-2);stroke-width:1}
.chart .axlabel{fill:var(--ink-soft);font-size:11px;font-family:var(--body)}
.chart .area{opacity:.16}
.chart .linepath{fill:none;stroke:var(--cedar);stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round}
.chart .pt{fill:var(--paper);stroke:var(--cedar);stroke-width:2.5;cursor:pointer}
.chart .pt:hover{fill:var(--honey)}
.ctip{position:absolute;background:var(--ink);color:var(--cream);padding:7px 11px;border-radius:9px;font-size:12px;font-weight:600;pointer-events:none;opacity:0;transform:translate(-50%,-12px);transition:opacity .15s;white-space:nowrap;z-index:5}
.ctip span{color:var(--honey)}

.two{display:grid;grid-template-columns:1fr 1fr;gap:18px}

/* social */
.social{padding:24px 26px}
.social .ai-block{background:var(--sage);border-radius:14px;padding:17px 19px;margin-bottom:20px;border:1px solid var(--line)}
.social .ai-block .ai-tag{margin-bottom:10px}
.social .ai-block p{font-size:13.5px;color:var(--ink);line-height:1.6}
.social .ai-block p b{color:var(--cedar);font-weight:700}
.posts{display:grid;grid-template-columns:repeat(3,1fr);gap:13px}
.post{border:1px solid var(--line);border-radius:13px;overflow:hidden;transition:.22s;cursor:pointer}
.post:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.post .ph{height:108px;position:relative;display:grid;place-items:end start;padding:9px}
.post .ph .plat{background:rgba(0,0,0,.35);backdrop-filter:blur(4px);color:#fff;font-size:10px;font-weight:600;padding:3px 8px;border-radius:20px}
.post .pb{padding:11px 12px}
.post .pb .cap{font-size:11.5px;color:var(--ink-soft);line-height:1.45;height:33px;overflow:hidden}
.post .pb .eng{display:flex;gap:13px;margin-top:9px;font-size:11.5px;font-weight:600;color:var(--cedar)}
.post .pb .eng span{display:inline-flex;align-items:center;gap:4px}
.post .pb .eng svg{width:12px;height:12px}

/* tasks */
.tasks{padding:24px 26px}
.chips{display:flex;gap:8px;margin-bottom:18px;flex-wrap:wrap}
.chip{font-size:12.5px;font-weight:600;padding:7px 14px;border-radius:30px;border:1px solid var(--line);background:var(--paper);color:var(--ink-soft);transition:.16s}
.chip:hover{border-color:var(--cedar-2)}
.chip.on{background:var(--cedar);color:var(--cream);border-color:var(--cedar)}
.chip .n{opacity:.65;margin-left:4px}
.task{display:flex;align-items:center;gap:15px;padding:14px 4px;border-bottom:1px solid var(--line-2);transition:.15s}
.task:hover{background:linear-gradient(90deg,color-mix(in srgb,var(--sage) 55%,transparent),transparent);padding-left:10px;border-radius:10px}
.task:last-child{border-bottom:none}
.st{width:11px;height:11px;border-radius:50%;flex:0 0 auto}
.st.prog{background:var(--honey);box-shadow:0 0 0 4px color-mix(in srgb,var(--honey) 22%,transparent)}
.st.up{background:var(--cedar-2);box-shadow:0 0 0 4px color-mix(in srgb,var(--cedar-2) 20%,transparent)}
.st.done{background:var(--good);box-shadow:0 0 0 4px color-mix(in srgb,var(--good) 20%,transparent)}
.task .tinfo{flex:1;min-width:0}
.task .tinfo b{font-size:14px;font-weight:600;display:block}
.task.is-done .tinfo b{text-decoration:line-through;color:var(--ink-soft);text-decoration-color:var(--line)}
.task .tinfo .sub{font-size:11.5px;color:var(--ink-soft);margin-top:2px}
.task .badge2{font-size:11px;font-weight:600;padding:4px 10px;border-radius:20px;white-space:nowrap}
.b-prog{background:color-mix(in srgb,var(--honey) 15%,transparent);color:var(--honey-deep)}
.b-up{background:color-mix(in srgb,var(--cedar) 13%,transparent);color:var(--cedar)}
.b-done{background:color-mix(in srgb,var(--good) 14%,transparent);color:var(--good)}
.task .owner{width:30px;height:30px;border-radius:8px;display:grid;place-items:center;font-size:11px;font-weight:700;color:#fff;flex:0 0 auto}
.task .due{font-size:11.5px;color:var(--ink-soft);width:74px;text-align:right;flex:0 0 auto;font-weight:500}
.embed-note{display:flex;align-items:center;gap:8px;margin-top:16px;font-size:11.5px;color:var(--ink-soft);background:var(--cream-2);border-radius:9px;padding:9px 12px}
.embed-note svg{width:14px;height:14px;color:var(--cedar-2);flex:0 0 auto}

/* work */
.work{padding:24px 26px}
.work-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.work-col h4{font-size:12px;letter-spacing:1.5px;text-transform:uppercase;color:var(--ink-soft);margin-bottom:14px;display:flex;align-items:center;gap:8px}
.work-col h4 .dotc{width:9px;height:9px;border-radius:50%}
.work-col ul{list-style:none;display:flex;flex-direction:column;gap:11px}
.work-col li{font-size:13.5px;line-height:1.5;padding-left:24px;position:relative;color:var(--ink)}
.work-col li::before{content:"";position:absolute;left:4px;top:7px;width:7px;height:7px;border-radius:2px;transform:rotate(45deg)}
.did li::before{background:var(--good)}
.next li::before{background:var(--honey)}

/* reports */
.reports{padding:22px 26px}
.rep-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
.sortbtn{font-size:12px;font-weight:600;color:var(--cedar);display:inline-flex;align-items:center;gap:6px;padding:7px 12px;border-radius:9px;border:1px solid var(--line);transition:.15s}
.sortbtn:hover{background:var(--sage)}
.sortbtn svg{width:13px;height:13px}
.rep{display:flex;align-items:center;gap:15px;padding:14px 6px;border-bottom:1px solid var(--line-2);transition:.15s;cursor:pointer}
.rep:hover{background:linear-gradient(90deg,color-mix(in srgb,var(--sage) 55%,transparent),transparent);padding-left:12px;border-radius:10px}
.rep:last-child{border-bottom:none}
.rep .ric{width:38px;height:46px;border-radius:7px;background:linear-gradient(160deg,#fff,var(--cream-2));border:1px solid var(--line);display:grid;place-items:center;flex:0 0 auto}
.rep .ric svg{width:17px;height:17px;color:var(--clay)}
.rep .rinfo{flex:1}
.rep .rinfo b{font-size:14px;font-weight:600;display:block}
.rep .rinfo .sub{font-size:11.5px;color:var(--ink-soft);margin-top:1px}
.rep .rtype{font-size:11px;font-weight:600;padding:4px 11px;border-radius:20px;background:var(--sage);color:var(--cedar)}
.rep .dl{color:var(--cedar-2)}
.rep .dl svg{width:18px;height:18px}

/* invoices + scope */
.inv{padding:24px 26px;display:flex;flex-direction:column}
.inv h3,.scope h3{font-family:var(--display);font-size:16px;font-weight:600;margin-bottom:16px;display:flex;align-items:center;gap:9px}
.inv h3 svg,.scope h3 svg{width:17px;height:17px;color:var(--clay)}
.inv-row{display:flex;align-items:center;gap:12px;padding:11px 0;border-bottom:1px solid var(--line-2);font-size:13.5px}
.inv-row:last-of-type{border-bottom:none}
.inv-row .id{flex:1}
.inv-row .id b{font-weight:600}
.inv-row .id span{display:block;font-size:11.5px;color:var(--ink-soft)}
.inv-row .amt{font-weight:700;font-family:var(--display)}
.pill{font-size:10.5px;font-weight:700;padding:3px 9px;border-radius:20px;text-transform:uppercase;letter-spacing:.4px}
.pill.paid{background:color-mix(in srgb,var(--good) 14%,transparent);color:var(--good)}
.pill.due{background:color-mix(in srgb,var(--clay) 16%,transparent);color:var(--clay)}
.inv-btn{margin-top:18px;background:var(--cedar);color:var(--cream);border-radius:12px;padding:13px;font-weight:600;font-size:13.5px;display:flex;align-items:center;justify-content:center;gap:9px;transition:.2s}
.inv-btn:hover{filter:brightness(.92);transform:translateY(-2px)}
.inv-btn svg{width:16px;height:16px}
.scope{padding:24px 26px}
.scope .tags{display:flex;flex-wrap:wrap;gap:9px;margin-bottom:22px}
.scope .tags .t{font-size:12.5px;font-weight:600;padding:8px 14px;border-radius:11px;background:var(--sage);color:var(--cedar);display:inline-flex;align-items:center;gap:7px}
.scope .tags .t svg{width:13px;height:13px}
.scope .avail-h{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--ink-soft);margin-bottom:12px}
.avail{display:flex;flex-wrap:wrap;gap:9px}
.avail .a{font-size:12.5px;font-weight:600;padding:8px 14px;border-radius:11px;border:1.5px dashed var(--clay-soft);color:var(--clay);background:color-mix(in srgb,var(--clay) 5%,transparent);transition:.18s;cursor:pointer;display:inline-flex;align-items:center;gap:7px}
.avail .a:hover{background:var(--clay);color:#fff;border-color:var(--clay)}
.avail .a svg{width:13px;height:13px}

.foot{padding:26px 38px;border-top:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;font-size:12px;color:var(--ink-soft);flex-wrap:wrap;gap:10px}
.foot .pb{display:flex;align-items:center;gap:8px;font-weight:600;color:var(--cedar)}
.foot .pb svg{width:16px;height:18px}

/* modal */
.overlay{position:fixed;inset:0;background:color-mix(in srgb,var(--ink) 50%,transparent);backdrop-filter:blur(5px);z-index:100;display:none;align-items:center;justify-content:center;padding:24px}
.overlay.open{display:flex;animation:fade .2s ease}
.modal{background:var(--paper);border-radius:22px;max-width:480px;width:100%;box-shadow:var(--shadow-lg);overflow:hidden;animation:rise .28s cubic-bezier(.2,.8,.2,1)}
.modal-head{padding:24px 26px 18px;border-bottom:1px solid var(--line);display:flex;align-items:flex-start;gap:14px}
.modal-head .mi{width:44px;height:44px;border-radius:12px;background:var(--sage);display:grid;place-items:center;color:var(--cedar);flex:0 0 auto}
.modal-head .mi svg{width:21px;height:21px}
.modal-head h3{font-family:var(--display);font-size:19px;font-weight:600}
.modal-head p{font-size:13px;color:var(--ink-soft);margin-top:3px}
.modal-head .x{margin-left:auto;color:var(--ink-soft);font-size:22px;line-height:1;padding:4px;border-radius:8px;transition:.15s}
.modal-head .x:hover{background:var(--cream-2);color:var(--ink)}
.modal-body{padding:22px 26px 26px}
.modal-body .inv-row{font-size:14px}
.mtot{display:flex;justify-content:space-between;align-items:center;margin-top:16px;padding-top:16px;border-top:2px solid var(--line)}
.mtot b{font-family:var(--display);font-size:20px;font-weight:600}
.mbtn{margin-top:20px;width:100%;background:var(--honey);color:var(--sidebar-ink);border-radius:13px;padding:14px;font-weight:700;font-size:14px;transition:.2s}
.mbtn:hover{filter:brightness(1.05);transform:translateY(-2px)}
.field{margin-bottom:14px}
.field label{display:block;font-size:12.5px;font-weight:600;margin-bottom:6px;color:var(--ink-soft)}
.field input,.field select{width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:11px;font-family:inherit;font-size:14px;background:var(--cream);color:var(--ink)}
.field input:focus,.field select:focus{outline:none;border-color:var(--cedar-2)}
.slots{display:grid;grid-template-columns:repeat(3,1fr);gap:9px}
.slot{padding:11px 6px;border:1px solid var(--line);border-radius:11px;text-align:center;font-size:13px;font-weight:600;transition:.15s}
.slot:hover{border-color:var(--cedar-2)}
.slot.sel{background:var(--cedar);color:var(--cream);border-color:var(--cedar)}

.toast{position:fixed;bottom:26px;left:50%;transform:translateX(-50%) translateY(40px);background:var(--ink);color:var(--cream);padding:14px 22px;border-radius:14px;font-size:13.5px;font-weight:600;box-shadow:var(--shadow-lg);z-index:200;opacity:0;transition:.3s;display:flex;align-items:center;gap:10px}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast svg{width:17px;height:17px;color:var(--honey)}

.reveal{opacity:0;transform:translateY(18px);transition:opacity .6s ease,transform .6s cubic-bezier(.2,.8,.2,1)}
.reveal.in{opacity:1;transform:none}
@keyframes pop{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}
@keyframes fade{from{opacity:0}to{opacity:1}}
@keyframes rise{from{opacity:0;transform:translateY(26px) scale(.97)}to{opacity:1;transform:none}}

.menu-toggle{display:none}
@media(max-width:1080px){.hero{grid-template-columns:1fr}.kpis{grid-template-columns:repeat(2,1fr)}.two{grid-template-columns:1fr}.work-grid{grid-template-columns:1fr}}
@media(max-width:820px){
  .app{grid-template-columns:1fr}
  .sidebar{position:fixed;left:0;top:0;z-index:90;width:264px;transform:translateX(-100%);transition:.3s}
  .sidebar.open{transform:none;box-shadow:var(--shadow-lg)}
  .menu-toggle{display:grid}
  .content{padding:22px 16px 60px}
  /* topbar: stop the greeting and month dropdown from colliding */
  .topbar{padding:14px 16px;gap:10px}
  .greet{min-width:0}
  .greet h1{font-size:17px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .greet .greet-prefix{display:none}        /* show just the client name on mobile */
  .greet p{display:none}
  .topbar .icon-btn[title="Notifications"]{display:none} /* declutter to make room */
  .period-btn{padding:9px 11px;font-size:13px}
  /* section headers: more horizontal + vertical breathing room */
  .section-head{flex-wrap:wrap;column-gap:10px;row-gap:2px;margin-bottom:8px}
  .section-head .ln{display:none}
  .section-head h2{font-size:18px}
  .section-head .meta{margin-left:auto}
  .posts{grid-template-columns:1fr}.kpis{grid-template-columns:1fr}
  .frow .flabel{width:120px;font-size:12px}.fconv{width:auto}
  /* tasks: title on its own row, meta (status/owner/due) below it */
  .task{flex-wrap:wrap;column-gap:12px;row-gap:7px}
  .task .st{order:0}
  .task .tinfo{flex:1 1 calc(100% - 27px);order:1}
  .task .badge2{order:2}
  .task .owner{order:3}
  .task .due{order:4;margin-left:auto}
  .scrim{position:fixed;inset:0;background:color-mix(in srgb,var(--ink) 45%,transparent);z-index:85;display:none}
  .scrim.open{display:block}
}
