/*
 * Groundskeeper™, compiled stylesheet (committed Tailwind CLI output).
 * Source of truth: tailwind/src/input.css + tailwind/tailwind.config.js.
 * Rebuild with: cd tailwind && npm install && npm run build
 */
*,::before,::after{box-sizing:border-box;border:0 solid #e5e7eb}
html{line-height:1.5;-webkit-text-size-adjust:100%;font-family:Inter,system-ui,sans-serif}
body{margin:0;line-height:inherit}
h1,h2,h3,p{margin:0}
a{color:inherit;text-decoration:inherit}
img,svg{display:block;vertical-align:middle;max-width:100%;height:auto}

:root{
  --bg:#f5f7f2; --fg:#2d3824; --muted:#516838; --card:#ffffff; --border:#e6ecdd;
}
.dark{
  --bg:#2d3824; --fg:#e6ecdd; --muted:#aabf90; --card:#354229; --border:#40512f;
}

body{background:var(--bg);color:var(--fg);min-height:100vh}

.container{width:100%;max-width:72rem;margin-left:auto;margin-right:auto;padding-left:1.5rem;padding-right:1.5rem}
.header{position:sticky;top:0;z-index:50;backdrop-filter:blur(8px);background:color-mix(in srgb,var(--bg) 85%,transparent);border-bottom:1px solid var(--border)}
.nav{display:flex;align-items:center;justify-content:space-between;height:4rem}
.brand{display:flex;align-items:center;gap:.625rem;font-weight:700;font-size:1.125rem}
.brand-badge{display:inline-flex;align-items:center;justify-content:center;width:2.25rem;height:2.25rem;border-radius:.75rem;background:#516838;color:#fff;font-weight:800}

.hero{padding:5rem 0 3rem;text-align:center}
.hero h1{font-size:2.5rem;font-weight:800;line-height:1.1;margin-bottom:1rem}
.hero p{font-size:1.125rem;color:var(--muted);max-width:42rem;margin:0 auto 2rem}

.btn-primary{display:inline-flex;align-items:center;justify-content:center;border-radius:.5rem;background:#516838;color:#fff;padding:.625rem 1.25rem;font-weight:500;box-shadow:0 1px 2px rgba(0,0,0,.08);transition:background .15s;cursor:pointer}
.btn-primary:hover{background:#40512f}
.btn-ghost{display:inline-flex;align-items:center;justify-content:center;border-radius:.5rem;border:1px solid var(--border);padding:.625rem 1.25rem;font-weight:500;cursor:pointer}

.grid{display:grid;gap:1.5rem;margin-top:3rem}
@media(min-width:768px){.grid{grid-template-columns:repeat(3,minmax(0,1fr))}.hero h1{font-size:3.25rem}}
.card{border-radius:.75rem;border:1px solid var(--border);background:var(--card);padding:1.5rem;box-shadow:0 1px 2px rgba(0,0,0,.05)}
.card h3{font-weight:700;margin-bottom:.5rem}
.card p{color:var(--muted);font-size:.95rem}

.footer{margin-top:4rem;border-top:1px solid var(--border);padding:2rem 0;text-align:center;color:var(--muted);font-size:.875rem}
.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:2.25rem;height:2.25rem;border-radius:.5rem;border:1px solid var(--border);cursor:pointer;background:transparent;color:inherit;font-size:1rem}
.icon-btn:hover{background:color-mix(in srgb,var(--fg) 8%,transparent)}

/* ======================================================================
 * Step 4, Splash / landing page
 * ==================================================================== */
:root{
  --gk:#516838; --gk-dark:#40512f; --gk-soft:#aabf90; --gk-burrow:#8a6a4a;
  --lp-band:#516838; --lp-band-fg:#f5f7f2;
}

html{scroll-behavior:smooth}
@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

.skip-link{position:absolute;left:-999px;top:0;z-index:100;background:var(--gk);color:#fff;padding:.6rem 1rem;border-radius:0 0 .5rem 0}
.skip-link:focus{left:0}

.btn-lg{padding:.85rem 1.6rem;font-size:1.05rem;border-radius:.65rem}
.btn-primary:focus-visible,.btn-ghost:focus-visible,.icon-btn:focus-visible,.lp-links a:focus-visible{outline:2px solid var(--gk-soft);outline-offset:2px}

/* ---- Sticky header ---- */
.lp-header{position:sticky;top:0;z-index:50;background:color-mix(in srgb,var(--bg) 80%,transparent);backdrop-filter:blur(10px);border-bottom:1px solid transparent;transition:border-color .25s,box-shadow .25s,background .25s}
.lp-header.is-stuck{border-bottom-color:var(--border);box-shadow:0 2px 18px rgba(0,0,0,.06)}
.lp-nav{display:flex;align-items:center;justify-content:space-between;gap:1rem;height:4.25rem}
.lp-links{display:none;align-items:center;gap:1.75rem;font-weight:500;font-size:.95rem}
.lp-links a{color:var(--muted);transition:color .15s}
.lp-links a:hover{color:var(--fg)}
.lp-actions{display:flex;align-items:center;gap:.6rem}
.lp-signin{display:none}
@media(min-width:900px){.lp-links{display:flex}.lp-signin{display:inline-flex}}

/* ---- Hero ---- */
.lp-hero{position:relative;overflow:hidden;padding:4rem 0 3rem}
.lp-hero-glow{position:absolute;inset:-20% -10% auto -10%;height:420px;background:radial-gradient(60% 60% at 70% 20%,color-mix(in srgb,var(--gk-soft) 45%,transparent),transparent 70%);pointer-events:none;z-index:0}
.lp-hero-grid{position:relative;z-index:1;display:grid;gap:2.5rem;align-items:center}
@media(min-width:960px){.lp-hero{padding:6rem 0 4.5rem}.lp-hero-grid{grid-template-columns:1.1fr .9fr;gap:3rem}}
.lp-eyebrow{display:inline-block;font-size:.8rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--gk);background:color-mix(in srgb,var(--gk-soft) 28%,transparent);padding:.3rem .75rem;border-radius:999px;margin-bottom:1rem}
.lp-hero-copy h1{font-size:2.3rem;font-weight:800;line-height:1.08;letter-spacing:-.02em;margin-bottom:1.1rem}
@media(min-width:768px){.lp-hero-copy h1{font-size:3.25rem}}
.lp-lede{font-size:1.12rem;line-height:1.6;color:var(--muted);max-width:38rem;margin-bottom:1.75rem}
.lp-hero-cta{display:flex;flex-wrap:wrap;gap:.85rem}
.lp-hero-trust{list-style:none;display:flex;flex-wrap:wrap;gap:1.1rem;margin:1.75rem 0 0;padding:0;color:var(--muted);font-size:.9rem;font-weight:500}

.lp-hero-art{position:relative;display:flex;align-items:center;justify-content:center;min-height:280px}
.lp-mascot{width:min(360px,80vw);filter:drop-shadow(0 18px 30px rgba(0,0,0,.18));animation:lp-bob 5s ease-in-out infinite}
@keyframes lp-bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
@media(prefers-reduced-motion:reduce){.lp-mascot{animation:none}}
.lp-float{position:absolute;background:var(--card);border:1px solid var(--border);border-radius:.75rem;padding:.6rem .85rem;font-size:.85rem;font-weight:600;box-shadow:0 8px 24px rgba(0,0,0,.12)}
.lp-float-a{top:8%;left:-2%;animation:lp-bob 6s ease-in-out infinite}
.lp-float-b{bottom:10%;right:-2%;animation:lp-bob 7s ease-in-out .5s infinite}

/* ---- Sections ---- */
.lp-section{padding:4rem 0}
@media(min-width:768px){.lp-section{padding:5.5rem 0}}
.lp-section-alt{background:color-mix(in srgb,var(--gk-soft) 12%,var(--bg))}
.lp-section-head{max-width:42rem;margin:0 auto 3rem;text-align:center}
.lp-kicker{display:inline-block;font-size:.78rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--gk)}
.lp-section-head h2{font-size:1.85rem;font-weight:800;line-height:1.15;letter-spacing:-.01em;margin:.6rem 0 .85rem}
@media(min-width:768px){.lp-section-head h2{font-size:2.4rem}}
.lp-section-head p{color:var(--muted);font-size:1.05rem;line-height:1.6}

/* ---- Value pillars ---- */
.lp-value-grid{display:grid;gap:1.5rem}
@media(min-width:768px){.lp-value-grid{grid-template-columns:repeat(3,1fr)}}
.lp-value-card{border:1px solid var(--border);background:var(--card);border-radius:1rem;padding:1.75rem;box-shadow:0 1px 2px rgba(0,0,0,.05)}
.lp-value-stat{font-size:1.6rem;font-weight:800;color:var(--gk)}
.lp-value-card h3{margin:.5rem 0 .4rem;font-size:1.1rem;font-weight:700}
.lp-value-card p{color:var(--muted);font-size:.95rem;line-height:1.55}

/* ---- Feature grid ---- */
.lp-feature-grid{display:grid;gap:1.5rem}
@media(min-width:640px){.lp-feature-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1000px){.lp-feature-grid{grid-template-columns:repeat(3,1fr)}}
.lp-feature-card{border:1px solid var(--border);background:var(--card);border-radius:1rem;padding:1.75rem;box-shadow:0 1px 2px rgba(0,0,0,.05);transition:transform .2s,box-shadow .2s}
.lp-feature-card:hover{transform:translateY(-4px);box-shadow:0 14px 30px rgba(0,0,0,.10)}
.lp-feature-icon{display:inline-flex;align-items:center;justify-content:center;width:3rem;height:3rem;border-radius:.85rem;background:color-mix(in srgb,var(--gk-soft) 30%,transparent);font-size:1.5rem;margin-bottom:1rem}
.lp-feature-card h3{font-size:1.12rem;font-weight:700;margin-bottom:.5rem}
.lp-feature-card p{color:var(--muted);font-size:.95rem;line-height:1.55}

/* ---- Pricing matrix ---- */
.lp-pricing-grid{display:grid;gap:1.5rem;align-items:stretch}
@media(min-width:640px){.lp-pricing-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1100px){.lp-pricing-grid{grid-template-columns:repeat(4,1fr)}}
.lp-price-card{position:relative;display:flex;flex-direction:column;border:1px solid var(--border);background:var(--card);border-radius:1rem;padding:1.75rem;box-shadow:0 1px 2px rgba(0,0,0,.05)}
.lp-price-featured{border-color:var(--gk);box-shadow:0 18px 40px rgba(81,104,56,.22);transform:translateY(-6px)}
@media(max-width:1099px){.lp-price-featured{transform:none}}
.lp-price-badge{position:absolute;top:-.85rem;left:50%;transform:translateX(-50%);background:var(--gk);color:#fff;font-size:.72rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:.3rem .7rem;border-radius:999px;white-space:nowrap}
.lp-price-name{font-size:1.15rem;font-weight:700}
.lp-price-amount{display:flex;align-items:baseline;gap:.25rem;margin:.6rem 0 .25rem}
.lp-price-num{font-size:2.2rem;font-weight:800;letter-spacing:-.02em}
.lp-price-custom{font-size:1.9rem;font-weight:800}
.lp-price-per{color:var(--muted);font-weight:600}
.lp-price-desc{color:var(--muted);font-size:.9rem;margin-bottom:.5rem}
.lp-price-features{list-style:none;margin:1.1rem 0 1.5rem;padding:0;display:grid;gap:.6rem;flex:1}
.lp-price-features li{display:flex;align-items:flex-start;gap:.55rem;font-size:.92rem;line-height:1.4}
.lp-price-features li span{flex:none;font-weight:700;width:1.1rem;text-align:center}
.lp-price-features li.is-yes span{color:var(--gk)}
.lp-price-features li.is-no{color:var(--muted)}
.lp-price-features li.is-no span{color:#b04a4a}
.lp-price-cta{width:100%}
.lp-pricing-note{text-align:center;color:var(--muted);font-size:.9rem;margin-top:2rem}
.lp-empty{grid-column:1/-1;text-align:center;color:var(--muted)}

/* ---- Reviews ---- */
.lp-review-grid{display:grid;gap:1.5rem}
@media(min-width:768px){.lp-review-grid{grid-template-columns:repeat(3,1fr)}}
.lp-review-card{border:1px solid var(--border);background:var(--card);border-radius:1rem;padding:1.75rem;box-shadow:0 1px 2px rgba(0,0,0,.05);display:flex;flex-direction:column;gap:1rem}
.lp-stars{color:#e0a73a;letter-spacing:.1em;font-size:1.05rem}
.lp-review-card blockquote{margin:0;font-size:1rem;line-height:1.55;flex:1}
.lp-review-by{display:flex;align-items:center;gap:.75rem;margin:0}
.lp-avatar{display:inline-flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;border-radius:999px;background:var(--gk);color:#fff;font-weight:700;font-size:.85rem;flex:none}
.lp-review-by strong{display:block;font-size:.95rem}
.lp-review-by small{color:var(--muted);font-size:.82rem}

/* ---- Final CTA band ---- */
.lp-cta-band{background:linear-gradient(135deg,var(--gk),var(--gk-dark));color:var(--lp-band-fg);text-align:center;padding:4.5rem 0}
.lp-cta-band h2{font-size:1.9rem;font-weight:800;margin-bottom:.6rem}
@media(min-width:768px){.lp-cta-band h2{font-size:2.4rem}}
.lp-cta-band p{color:color-mix(in srgb,#fff 82%,transparent);font-size:1.1rem;margin-bottom:1.75rem}
.lp-cta-band-actions{justify-content:center}
.lp-ghost-light{border-color:rgba(255,255,255,.55);color:#fff}
.lp-ghost-light:hover{background:rgba(255,255,255,.12)}

/* ---- Footer ---- */
.lp-footer{border-top:1px solid var(--border);background:color-mix(in srgb,var(--gk-soft) 8%,var(--bg));padding:3.5rem 0 1.5rem;margin-top:0}
.lp-footer-grid{display:grid;gap:2rem}
@media(min-width:768px){.lp-footer-grid{grid-template-columns:2fr 1fr 1fr 1fr}}
.lp-footer-brand p{color:var(--muted);font-size:.92rem;line-height:1.55;margin-top:.85rem;max-width:24rem}
.lp-footer-col h4{font-size:.82rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--fg);margin-bottom:.85rem}
.lp-footer-col{display:flex;flex-direction:column;gap:.55rem}
.lp-footer-col a{color:var(--muted);font-size:.92rem;transition:color .15s}
.lp-footer-col a:hover{color:var(--fg)}
.lp-footer-bottom{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-top:2.5rem;padding-top:1.5rem;border-top:1px solid var(--border);color:var(--muted);font-size:.85rem}

/* ---- Scroll reveal ---- */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease;transition-delay:calc(var(--d,0)*70ms)}
.reveal.is-visible{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* ============================================================
   Properties & Units app shell (Step 6)
   ============================================================ */
.app-wrap{max-width:80rem;margin:2rem auto;padding:0 1.5rem}
.app-head{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-bottom:1.25rem}
.app-head h1{margin:.25rem 0 .15rem;font-size:1.6rem}
.app-head p{margin:0;color:var(--muted)}
.tabs{display:flex;gap:.25rem;border-bottom:1px solid var(--border);margin-bottom:1.25rem;overflow-x:auto}
.tab{appearance:none;background:transparent;border:0;border-bottom:2px solid transparent;color:var(--muted);padding:.65rem 1rem;font-weight:600;cursor:pointer;white-space:nowrap}
.tab:hover{color:var(--fg)}
.tab.active{color:var(--fg);border-bottom-color:var(--muted)}
.toolbar{display:flex;gap:.6rem;flex-wrap:wrap;align-items:center;margin-bottom:1rem}
.toolbar .grow{flex:1 1 14rem}
.input,.select,textarea.input{width:100%;border:1px solid var(--border);background:var(--card);color:var(--fg);border-radius:.5rem;padding:.55rem .7rem;font:inherit}
.input:focus,.select:focus{outline:2px solid var(--muted);outline-offset:1px}
.field{display:flex;flex-direction:column;gap:.3rem;margin-bottom:.85rem}
.field label{font-size:.85rem;font-weight:600;color:var(--fg)}
.field .err{color:#dc2626;font-size:.8rem;min-height:1em}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:0 1rem}
@media(max-width:560px){.grid-2{grid-template-columns:1fr}}

.table-wrap{border:1px solid var(--border);border-radius:.75rem;overflow:auto;background:var(--card)}
table.data{width:100%;border-collapse:collapse;font-size:.92rem}
table.data th,table.data td{text-align:left;padding:.7rem .9rem;border-bottom:1px solid var(--border);white-space:nowrap}
table.data th{position:sticky;top:0;background:var(--card);font-size:.78rem;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}
table.data tr:last-child td{border-bottom:0}
table.data tr:hover td{background:color-mix(in srgb,var(--muted) 8%,transparent)}

.badge{display:inline-block;border-radius:999px;padding:.15rem .6rem;font-size:.75rem;font-weight:600;background:color-mix(in srgb,var(--muted) 18%,transparent);color:var(--fg)}
.badge.ok{background:color-mix(in srgb,#16a34a 22%,transparent)}
.badge.warn{background:color-mix(in srgb,#f59e0b 26%,transparent)}
.badge.muted{background:color-mix(in srgb,var(--muted) 14%,transparent);opacity:.85}
.row-actions{display:flex;gap:.4rem}
.btn-sm{padding:.35rem .7rem;font-size:.82rem;border-radius:.45rem;border:1px solid var(--border);background:transparent;color:var(--fg);cursor:pointer;font-weight:600}
.btn-sm:hover{background:color-mix(in srgb,var(--muted) 12%,transparent)}
.btn-sm.danger{color:#dc2626;border-color:color-mix(in srgb,#dc2626 40%,var(--border))}

.state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.6rem;padding:3rem 1.5rem;text-align:center;color:var(--muted)}
.state svg{opacity:.5}
.spinner{width:2rem;height:2rem;border-radius:50%;border:3px solid var(--border);border-top-color:var(--muted);animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.state.error{color:#dc2626}

.modal-back{position:fixed;inset:0;background:rgba(0,0,0,.5);display:flex;align-items:flex-start;justify-content:center;padding:3rem 1rem;z-index:100;overflow:auto}
.modal-back[hidden]{display:none}
.modal{background:var(--card);color:var(--fg);border:1px solid var(--border);border-radius:.9rem;width:100%;max-width:40rem;padding:1.5rem;box-shadow:0 20px 50px rgba(0,0,0,.3)}
.modal h2{margin:0 0 .25rem}
.modal .sub{color:var(--muted);font-size:.9rem;margin:0 0 1rem}
.modal-actions{display:flex;justify-content:flex-end;gap:.6rem;margin-top:1rem}

.toast-stack{position:fixed;right:1rem;bottom:1rem;display:flex;flex-direction:column;gap:.6rem;z-index:200;max-width:24rem}
.toast{background:var(--card);color:var(--fg);border:1px solid var(--border);border-left:4px solid var(--muted);border-radius:.6rem;padding:.8rem 1rem;box-shadow:0 8px 24px rgba(0,0,0,.18);display:flex;align-items:center;gap:.75rem;animation:toast-in .2s ease}
.toast.error{border-left-color:#dc2626}
.toast.success{border-left-color:#16a34a}
.toast .msg{flex:1;font-size:.9rem}
.toast button{background:transparent;border:0;color:var(--muted);font-weight:700;cursor:pointer;font-size:.85rem;text-transform:uppercase;letter-spacing:.03em}
.toast button:hover{color:var(--fg)}
@keyframes toast-in{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.toast.ok{border-left-color:#16a34a}
.toast-undo{background:transparent;border:0;color:var(--gk,#16a34a);font-weight:700;cursor:pointer;font-size:.82rem;text-transform:uppercase;letter-spacing:.03em}

/* ============================================================
   Work Orders (Step 8), list + detail + realtime thread
   ============================================================ */
.state-panel{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.7rem;padding:3rem 1.5rem;text-align:center;color:var(--muted)}
.state-panel[hidden]{display:none}
.state-panel.error{color:#dc2626}
.data-table{width:100%;border-collapse:collapse;font-size:.92rem}
.data-table th,.data-table td{text-align:left;padding:.65rem .85rem;border-bottom:1px solid var(--border);vertical-align:top}
.data-table th{font-size:.74rem;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}
.data-table tr:last-child td{border-bottom:0}
.data-table tr:hover td{background:color-mix(in srgb,var(--muted) 8%,transparent)}
.row-deleted td{opacity:.5}
.field-err{color:#dc2626;font-size:.78rem;min-height:1em;display:block}
.btn-xs{padding:.3rem .6rem;font-size:.78rem;border-radius:.4rem;font-weight:600;line-height:1}

.wo-chip{display:inline-flex;align-items:center;gap:.35rem;border-radius:999px;padding:.18rem .6rem;font-size:.74rem;font-weight:700;color:var(--chip,var(--fg));background:color-mix(in srgb,var(--chip,var(--muted)) 16%,transparent);border:1px solid color-mix(in srgb,var(--chip,var(--muted)) 35%,transparent);white-space:nowrap}
.wo-chip-row{display:flex;flex-wrap:wrap;gap:.4rem}
.wo-link{color:var(--gk,#16a34a);font-weight:600;text-decoration:none}
.wo-link:hover{text-decoration:underline}

.wo-back{display:inline-block;color:var(--muted);text-decoration:none;font-size:.88rem;margin-bottom:1rem}
.wo-back:hover{color:var(--fg)}
.wo-head{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-bottom:1.25rem}
.wo-head h1{margin:.3rem 0 .25rem;font-size:1.5rem}
.wo-head-meta{display:flex;flex-direction:column;align-items:flex-end;gap:.6rem}
.muted{color:var(--muted)}

.wo-grid{display:grid;grid-template-columns:minmax(0,1fr) 22rem;gap:1.25rem;align-items:start}
@media(max-width:880px){.wo-grid{grid-template-columns:1fr}}
.wo-main{display:flex;flex-direction:column;gap:1.25rem;min-width:0}
.wo-card h3{margin:0 0 .75rem;font-size:1rem}
.wo-card-head{display:flex;align-items:center;justify-content:space-between}
.wo-desc{white-space:pre-wrap;margin:0 0 1rem;color:var(--fg)}
.wo-facts{display:grid;grid-template-columns:auto 1fr;gap:.35rem 1rem;margin:0;font-size:.9rem}
.wo-facts dt{color:var(--muted)}
.wo-facts dd{margin:0;color:var(--fg)}
.wo-total{margin:.75rem 0 0;font-size:.92rem;color:var(--muted)}

.wo-actions{display:flex;flex-direction:column;gap:.9rem}
.wo-actions label{display:flex;flex-direction:column;gap:.3rem;font-size:.85rem;font-weight:600;max-width:18rem}
.wo-approval{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}
.wo-approval-actions{display:flex;gap:.5rem}

.wo-media-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(8rem,1fr));gap:.7rem}
.wo-media-item{margin:0;border:1px solid var(--border);border-radius:.6rem;overflow:hidden;background:var(--card);position:relative}
.wo-media-item img{width:100%;height:7rem;object-fit:cover;display:block}
.wo-media-item figcaption{padding:.4rem .55rem;font-size:.78rem;color:var(--muted)}
.wo-media-phase{position:absolute;top:.4rem;left:.4rem;font-size:.66rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;padding:.12rem .45rem;border-radius:999px;color:#fff;background:rgba(0,0,0,.55)}
.wo-media-phase.phase-before{background:#6366f1}
.wo-media-phase.phase-during{background:#f59e0b}
.wo-media-phase.phase-after{background:#16a34a}
.wo-media-form{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:.9rem}
.wo-media-form .grow{flex:1 1 8rem}

/* Realtime thread */
.wo-thread{display:flex;flex-direction:column;max-height:38rem;position:sticky;top:1rem}
.wo-thread-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem}
.wo-thread-head h3{margin:0;font-size:1rem}
.wo-conn{font-size:.7rem;color:var(--muted)}
.wo-conn.live{color:#16a34a}
.wo-conn.connecting{color:#f59e0b}
.wo-conn.off{color:#dc2626}
.wo-messages{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:.6rem;padding:.25rem;min-height:8rem}
.wo-msg{max-width:90%;align-self:flex-start}
.wo-msg.mine{align-self:flex-end;text-align:right}
.wo-msg-meta{display:flex;gap:.5rem;align-items:baseline;font-size:.78rem}
.wo-msg-meta strong{font-size:.82rem}
.wo-msg-meta time,.wo-msg time{color:var(--muted);font-size:.72rem}
.wo-msg-body{background:color-mix(in srgb,var(--muted) 12%,transparent);border-radius:.7rem;padding:.45rem .7rem;font-size:.9rem;display:inline-block;text-align:left;white-space:pre-wrap;margin-top:.15rem}
.wo-msg.mine .wo-msg-body{background:color-mix(in srgb,var(--gk,#16a34a) 18%,transparent)}
.wo-msg.system{align-self:center;text-align:center}
.wo-msg.system .wo-msg-sys{font-size:.76rem;color:var(--muted);font-style:italic}
.wo-typing{min-height:1.1rem;font-size:.76rem;color:var(--muted);font-style:italic;padding:.1rem .25rem}
.wo-compose{display:flex;gap:.5rem;align-items:flex-end;margin-top:.5rem}
.wo-compose textarea{resize:vertical}

.wo-presence{display:flex;align-items:center;gap:.25rem}
.wo-avatar{width:1.6rem;height:1.6rem;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:700;color:#fff;background:var(--gk,#16a34a);border:2px solid var(--card);margin-left:-.4rem}
.wo-avatar:first-child{margin-left:0}
.wo-presence-count{font-size:.74rem;color:var(--muted);margin-left:.4rem}

/* ============================================================
   Media Library (Step 9), gallery, uploads, detail/versions
   ============================================================ */
.dropzone{border:2px dashed var(--border);border-radius:.75rem;padding:1.5rem;text-align:center;color:var(--muted);margin-bottom:1rem;background:color-mix(in srgb,var(--muted) 6%,transparent)}
.upload-list{display:flex;flex-direction:column;gap:.45rem;margin-bottom:1rem}
.upload-row{display:flex;align-items:center;gap:.7rem;font-size:.85rem;background:var(--card);border:1px solid var(--border);border-radius:.5rem;padding:.5rem .7rem}
.upload-row.ok{border-color:color-mix(in srgb,#16a34a 50%,var(--border))}
.upload-row.err{border-color:color-mix(in srgb,#dc2626 50%,var(--border))}
.upload-name{flex:1 1 12rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.upload-bar{flex:2 1 10rem;height:.5rem;border-radius:999px;background:color-mix(in srgb,var(--muted) 18%,transparent);overflow:hidden}
.upload-fill{display:block;height:100%;width:0;background:var(--gk,#16a34a);transition:width .2s ease}
.upload-pct{flex:0 0 3rem;text-align:right;font-variant-numeric:tabular-nums;color:var(--muted)}

.media-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(11rem,1fr));gap:1rem}
.media-card{margin:0;border:1px solid var(--border);border-radius:.75rem;overflow:hidden;background:var(--card);cursor:pointer;display:flex;flex-direction:column;position:relative;transition:box-shadow .15s,transform .15s}
.media-card:hover{box-shadow:0 8px 24px rgba(0,0,0,.12);transform:translateY(-2px)}
.media-thumb{position:relative;aspect-ratio:4/3;background:color-mix(in srgb,var(--muted) 10%,transparent);display:flex;align-items:center;justify-content:center;overflow:hidden}
.media-thumb img{width:100%;height:100%;object-fit:cover}
.media-icon{font-size:2.5rem;opacity:.7}
.media-icon.lg{font-size:4rem;padding:2rem}
.media-type-chip{position:absolute;bottom:.4rem;right:.4rem;font-size:.64rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;padding:.1rem .4rem;border-radius:999px;color:#fff;background:rgba(0,0,0,.55)}
.media-card figcaption{padding:.55rem .65rem;display:flex;flex-direction:column;gap:.2rem;min-width:0}
.media-card figcaption strong{font-size:.85rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.media-card .small{font-size:.74rem}
.media-tags{display:flex;flex-wrap:wrap;gap:.25rem;margin-top:.2rem}
.media-actions{position:absolute;top:.4rem;right:.4rem;display:flex;gap:.3rem}
.media-actions .icon-btn.sm,.btn-ghost.sm{width:1.9rem;height:1.9rem;font-size:.85rem;padding:0;background:rgba(0,0,0,.45);color:#fff;border:0}
.btn-ghost.sm{width:auto;padding:.25rem .6rem;font-size:.78rem}

.detail-img{width:100%;max-height:24rem;object-fit:contain;border-radius:.6rem;background:#000;margin-bottom:1rem}
.detail-meta{display:grid;grid-template-columns:1fr;gap:.4rem;margin:0 0 1rem;font-size:.9rem}
.detail-meta div{display:flex;gap:.6rem}
.detail-meta dt{color:var(--muted);min-width:7rem}
.detail-meta dd{margin:0}
.version-list{list-style:none;padding:0;margin:.5rem 0 0;display:flex;flex-direction:column;gap:.35rem;font-size:.85rem}
.version-list li{display:flex;gap:.6rem;align-items:center;flex-wrap:wrap}
.version-list a{color:var(--gk,#16a34a);font-weight:600}


/* --- Accounting (Step 10) --- */
.acct-lines{display:flex;flex-direction:column;gap:.4rem;margin:.25rem 0}
.acct-line-row{display:flex;gap:.4rem;align-items:center;flex-wrap:wrap}
.acct-line-row .input{flex:1 1 120px;min-width:80px}
.acct-line-del{flex:0 0 auto}
.acct-json{background:var(--card,#0b1220);border:1px solid var(--border,#334155);border-radius:.5rem;padding:.75rem;max-height:50vh;overflow:auto;font-size:.78rem;white-space:pre;line-height:1.4}

/* ===== Messaging & notifications (Step 12) ===== */
.msg-wrap{max-width:1200px;margin:0 auto;padding:1rem}
.msg-layout{display:grid;grid-template-columns:320px 1fr;gap:1rem;height:calc(100vh - 170px);min-height:480px}
.msg-sidebar{display:flex;flex-direction:column;gap:.6rem;border:1px solid var(--border,#334155);border-radius:.75rem;background:var(--card,#0b1220);padding:.75rem;overflow:hidden}
.msg-sidebar-head{display:flex;align-items:center;justify-content:space-between}
.msg-sidebar-head h1{font-size:1.15rem;margin:0}
.msg-search{width:100%}
.msg-filters{display:flex;flex-wrap:wrap;gap:.35rem}
.chip-filter{font-size:.72rem;padding:.2rem .55rem;border-radius:999px;border:1px solid var(--border,#334155);background:transparent;color:var(--muted,#94a3b8);cursor:pointer}
.chip-filter.active{background:var(--gk,#16a34a);border-color:var(--gk,#16a34a);color:#fff}
.convo-list{list-style:none;margin:0;padding:0;overflow-y:auto;flex:1}
.convo-item{padding:.55rem .5rem;border-radius:.5rem;cursor:pointer;border:1px solid transparent}
.convo-item:hover{background:rgba(148,163,184,.08)}
.convo-item.active{background:rgba(22,163,74,.12);border-color:var(--gk,#16a34a)}
.convo-item-top{display:flex;align-items:center;justify-content:space-between;gap:.5rem}
.convo-title{font-weight:600;font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.convo-unread{background:var(--gk,#16a34a);color:#fff;font-size:.68rem;border-radius:999px;padding:.05rem .4rem;min-width:1.2rem;text-align:center}
.convo-item-sub{display:flex;gap:.4rem;align-items:center;margin-top:.15rem}
.convo-scope-tag{font-size:.62rem;text-transform:uppercase;letter-spacing:.03em;color:var(--muted,#94a3b8);border:1px solid var(--border,#334155);border-radius:.3rem;padding:0 .3rem;flex:0 0 auto}
.convo-preview{font-size:.76rem;color:var(--muted,#94a3b8);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.msg-main{border:1px solid var(--border,#334155);border-radius:.75rem;background:var(--card,#0b1220);display:flex;flex-direction:column;overflow:hidden}
.msg-placeholder{height:100%;display:flex;align-items:center;justify-content:center}
.msg-thread{display:flex;flex-direction:column;height:100%}
.msg-thread-head{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-bottom:1px solid var(--border,#334155)}
.msg-thread-head h2{margin:0;font-size:1.05rem}
.msg-thread-actions{display:flex;align-items:center;gap:.4rem}
.conn-dot{width:.6rem;height:.6rem;border-radius:50%;background:#9ca3af;display:inline-block}
.conn-dot.on{background:#10b981}.conn-dot.off{background:#ef4444}.conn-dot.connecting{background:#f59e0b}
.msg-messages{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:.5rem}
.msg-bubble{max-width:75%;align-self:flex-start;background:rgba(148,163,184,.1);border:1px solid var(--border,#334155);border-radius:.6rem;padding:.45rem .65rem}
.msg-bubble.mine{align-self:flex-end;background:rgba(22,163,74,.14);border-color:rgba(22,163,74,.4)}
.msg-meta{display:flex;gap:.5rem;align-items:baseline;font-size:.72rem}
.msg-author{font-weight:600}
.msg-time{color:var(--muted,#94a3b8)}
.msg-text{margin-top:.15rem;white-space:pre-wrap;word-break:break-word;font-size:.9rem}
.msg-text .mention{color:var(--gk,#16a34a);font-weight:600}
.msg-edited{color:var(--muted,#94a3b8);font-size:.72rem}
.msg-quote{font-size:.72rem;color:var(--muted,#94a3b8);border-left:2px solid var(--border,#334155);padding-left:.4rem;margin:.15rem 0}
.msg-atts{margin-top:.3rem;display:flex;flex-wrap:wrap;gap:.35rem}
.msg-att{font-size:.76rem;color:var(--gk,#16a34a);text-decoration:none;border:1px solid var(--border,#334155);border-radius:.4rem;padding:.1rem .4rem}
.msg-row-actions{display:flex;gap:.5rem;margin-top:.2rem;opacity:0;transition:opacity .15s}
.msg-bubble:hover .msg-row-actions{opacity:1}
.msg-mini{background:none;border:none;color:var(--muted,#94a3b8);font-size:.72rem;cursor:pointer;padding:0}
.msg-mini:hover{color:var(--fg,#e2e8f0)}
.msg-system{align-self:center;font-size:.74rem;color:var(--muted,#94a3b8);font-style:italic}
.msg-typing{min-height:1.1rem;padding:0 1rem;font-size:.76rem;color:var(--muted,#94a3b8)}
.msg-compose{border-top:1px solid var(--border,#334155);padding:.6rem 1rem}
.msg-reply-banner{display:flex;align-items:center;justify-content:space-between;gap:.5rem;background:rgba(148,163,184,.08);border-radius:.4rem;padding:.25rem .5rem;margin-bottom:.4rem;font-size:.76rem;color:var(--muted,#94a3b8)}
.msg-compose-row{display:flex;gap:.5rem;align-items:flex-end}
.msg-compose-row .input{flex:1;resize:none;max-height:140px}
.msg-hint{margin:.25rem 0 0;font-size:.7rem;color:var(--muted,#94a3b8)}
.state-panel.sm{padding:1rem;min-height:auto}

/* Notification bell */
.nav-notif{position:relative;display:inline-flex}
.notif-badge{position:absolute;top:-.3rem;right:-.3rem;background:#ef4444;color:#fff;font-size:.62rem;border-radius:999px;padding:0 .3rem;min-width:1rem;text-align:center}
.notif-panel{position:absolute;top:2.4rem;right:0;width:340px;max-height:70vh;overflow-y:auto;background:var(--card,#0b1220);border:1px solid var(--border,#334155);border-radius:.6rem;box-shadow:0 10px 30px rgba(0,0,0,.35);z-index:60}
.notif-head{display:flex;align-items:center;justify-content:space-between;padding:.6rem .75rem;border-bottom:1px solid var(--border,#334155)}
.notif-link{background:none;border:none;color:var(--gk,#16a34a);font-size:.74rem;cursor:pointer}
.notif-empty{padding:1.5rem;text-align:center;color:var(--muted,#94a3b8);font-size:.85rem}
.notif-list{list-style:none;margin:0;padding:0}
.notif-item{display:flex;gap:.5rem;padding:.55rem .75rem;border-bottom:1px solid var(--border,#334155);cursor:pointer}
.notif-item:hover{background:rgba(148,163,184,.08)}
.notif-item.unread{background:rgba(22,163,74,.07)}
.notif-icon{flex:0 0 auto}
.notif-body{display:flex;flex-direction:column;gap:.1rem;min-width:0}
.notif-title{font-size:.84rem;font-weight:600}
.notif-text{font-size:.76rem;color:var(--muted,#94a3b8);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.notif-time{font-size:.68rem;color:var(--muted,#94a3b8)}
.notif-item.level-warning .notif-icon,.notif-item.level-error .notif-icon{filter:none}
@media(max-width:760px){.msg-layout{grid-template-columns:1fr;height:auto}.msg-sidebar{height:auto;max-height:40vh}.msg-main{height:60vh}.notif-panel{width:280px}}

/* ---- AI Keys & BYOK settings (Step 13) ---------------------------------- */
.ai-wrap{max-width:60rem}
.ai-head{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.25rem}
.ai-head h1{font-size:1.5rem;font-weight:800}
.ai-status{align-items:stretch;text-align:left;border:1px solid var(--border);border-left:4px solid var(--muted);border-radius:.7rem;background:var(--card);margin-bottom:1.25rem}
.ai-status .ai-status-body{display:flex;flex-direction:column;gap:.35rem;width:100%}
.ai-status p{font-size:.9rem;color:var(--fg)}
.ai-status.tone-ok{border-left-color:#16a34a}
.ai-status.tone-warn{border-left-color:#f59e0b}
.ai-status.tone-block{border-left-color:#dc2626}
.ai-badge{display:inline-block;font-size:.72rem;font-weight:700;padding:.12rem .5rem;border-radius:1rem;background:var(--bg);border:1px solid var(--border);color:var(--muted);letter-spacing:.02em}
.ai-badge.ok{background:rgba(22,163,74,.12);border-color:rgba(22,163,74,.4);color:#16a34a}
.ai-badge.bad{background:rgba(220,38,38,.12);border-color:rgba(220,38,38,.4);color:#dc2626}
.ai-key-list{display:flex;flex-direction:column;gap:.75rem}
.ai-key-card{display:flex;align-items:center;justify-content:space-between;gap:1rem;background:var(--card);border:1px solid var(--border);border-radius:.7rem;padding:.9rem 1.1rem}
.ai-key-main{display:flex;flex-direction:column;gap:.35rem;min-width:0}
.ai-key-row1{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}
.ai-key-label{font-weight:700}
.ai-key-scope{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);background:var(--bg);border:1px solid var(--border);border-radius:1rem;padding:.1rem .5rem}
.ai-key-row2{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;font-size:.82rem;color:var(--muted)}
.ai-key-mask{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;background:var(--bg);border:1px solid var(--border);border-radius:.4rem;padding:.1rem .45rem;color:var(--fg)}
.ai-key-err{font-size:.78rem;color:#dc2626}
.ai-key-actions{display:flex;gap:.4rem;flex-shrink:0}
.btn-xs.danger,.btn-ghost.danger{color:#dc2626}
.btn-xs.danger:hover,.btn-ghost.danger:hover{background:rgba(220,38,38,.1)}
/* AI modal (reuses shared modal look) */
.modal-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.5);display:flex;align-items:flex-start;justify-content:center;padding:3rem 1rem;z-index:100;overflow:auto}
.modal-backdrop[hidden]{display:none}
.modal-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem}
.modal-head h2{margin:0;font-size:1.2rem;font-weight:800}
.modal-body{display:flex;flex-direction:column}
.modal-foot{display:flex;justify-content:flex-end;gap:.6rem;margin-top:1rem}
.field-error{color:#dc2626;font-size:.82rem;background:rgba(220,38,38,.08);border:1px solid rgba(220,38,38,.3);border-radius:.5rem;padding:.5rem .7rem;white-space:pre-line;margin-bottom:.5rem}
.toast-action{background:transparent;border:0;color:var(--gk,#16a34a);font-weight:700;cursor:pointer;font-size:.82rem;text-transform:uppercase;letter-spacing:.03em}
@media(max-width:640px){.ai-key-card{flex-direction:column;align-items:stretch}.ai-key-actions{justify-content:flex-end}}

/* === AI Assistant (Step 14) ============================================== */
.ai-assistant-head{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;flex-wrap:wrap}
.ai-quota-pill{background:var(--card);border:1px solid var(--border);border-radius:999px;padding:.4rem .85rem;font-size:.82rem;color:var(--muted);white-space:nowrap}
.ai-quota-pill strong{color:var(--fg)}
.ai-quota-pill.warn{border-color:#f59e0b;color:#b45309}
.ai-quota-pill.over{border-color:#dc2626;color:#b91c1c}
.ai-banner.warn{border-color:#f59e0b;background:rgba(245,158,11,.08)}
.ai-banner a{color:var(--gk,#16a34a);font-weight:600}
.ai-assistant-grid{margin-top:1rem}
.ai-chat-col{display:flex;flex-direction:column;min-height:60vh}
.ai-tools{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap;margin-bottom:.6rem}
.ai-tools .input{max-width:230px}
.ai-prompts{display:flex;gap:.4rem;flex-wrap:wrap;margin-bottom:.7rem}
.ai-chip{background:var(--card);border:1px solid var(--border);border-radius:999px;padding:.35rem .8rem;font-size:.8rem;cursor:pointer;color:var(--fg)}
.ai-chip:hover{border-color:var(--gk,#16a34a)}
.ai-thread{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:.7rem;padding:.6rem;background:var(--card);border:1px solid var(--border);border-radius:.75rem;min-height:320px;max-height:58vh}
.ai-bubble{max-width:80%;padding:.65rem .85rem;border-radius:.9rem;font-size:.9rem;line-height:1.45;word-wrap:break-word}
.ai-bubble.user{align-self:flex-end;background:var(--gk,#16a34a);color:#fff;border-bottom-right-radius:.2rem}
.ai-bubble.ai{align-self:flex-start;background:var(--bg);border:1px solid var(--border);border-bottom-left-radius:.2rem}
.ai-bubble.ai.error{border-color:#dc2626;background:rgba(220,38,38,.07)}
.ai-bubble.pending{align-self:flex-start;color:var(--muted);font-style:italic}
.ai-bubble-meta{margin-top:.35rem;font-size:.72rem;color:var(--muted);display:flex;gap:.5rem;align-items:center}
.ai-bubble.user .ai-bubble-meta{color:rgba(255,255,255,.8)}
.ai-json{background:rgba(0,0,0,.05);border-radius:.5rem;padding:.5rem;font-size:.78rem;overflow-x:auto;margin:0;white-space:pre-wrap}
.ai-speak{background:transparent;border:0;cursor:pointer;font-size:.85rem;padding:0;line-height:1}
.ai-composer{margin-top:.7rem;display:flex;flex-direction:column;gap:.4rem}
.ai-input-row{display:flex;gap:.5rem;align-items:flex-end}
.ai-input-row .input{flex:1;resize:vertical}
.ai-composer-foot{display:flex;justify-content:space-between;align-items:center;gap:1rem}
#btn-mic.listening{color:#dc2626;animation:pulse 1.2s infinite}
.spinner.sm{width:14px;height:14px;border-width:2px;display:inline-block;vertical-align:middle}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
@media(max-width:640px){.ai-bubble{max-width:92%}.ai-tools .input{max-width:100%;flex:1}}

/* ── Admin monitoring dashboard (Step 15) ─────────────────────────────── */
.mon-wrap{display:flex;flex-direction:column;gap:1.25rem}
.mon-head{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;flex-wrap:wrap}
.mon-head h1{font-size:1.6rem;font-weight:800}
.mon-health{display:inline-flex;align-items:center;gap:.5rem;padding:.4rem .8rem;border-radius:999px;border:1px solid var(--border);background:var(--card);font-size:.85rem;font-weight:600}
.mon-health .dot{width:.6rem;height:.6rem;border-radius:50%;background:var(--muted)}
.mon-health.health-ok .dot{background:#2f9e44}.mon-health.health-ok{color:#2f9e44}
.mon-health.health-warn .dot{background:#f59f00}.mon-health.health-warn{color:#b8860b}
.mon-health.health-down .dot{background:#e03131}.mon-health.health-down{color:#e03131}

.mon-kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:.85rem}
.kpi{border:1px solid var(--border);background:var(--card);border-radius:.75rem;padding:1rem 1.1rem;box-shadow:0 1px 2px rgba(0,0,0,.05)}
.kpi-val{font-size:1.5rem;font-weight:800;line-height:1.1}
.kpi-lbl{color:var(--muted);font-size:.82rem;margin-top:.25rem}
.kpi-sub{color:var(--muted);font-size:.7rem;opacity:.8}

.mon-tabs{display:flex;gap:.4rem;flex-wrap:wrap;border-bottom:1px solid var(--border);padding-bottom:.25rem}
.mon-tab{border:1px solid transparent;background:transparent;color:var(--muted);padding:.5rem .9rem;border-radius:.5rem .5rem 0 0;font-weight:600;cursor:pointer}
.mon-tab:hover{color:var(--fg)}
.mon-tab.is-active{color:var(--fg);background:var(--card);border-color:var(--border);border-bottom-color:var(--card)}

.mon-panel{display:none;flex-direction:column;gap:1rem}
.mon-panel.is-active{display:flex}
.mon-grid.two{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem}
.chart-card{min-height:240px}
.chart-card canvas{max-height:240px}

.mon-toolbar{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:.75rem;flex-wrap:wrap}
.mon-toolbar .input{max-width:240px}

.mon-table-wrap{overflow-x:auto}
.mon-table{width:100%;border-collapse:collapse;font-size:.88rem}
.mon-table th,.mon-table td{text-align:left;padding:.55rem .65rem;border-bottom:1px solid var(--border);white-space:nowrap}
.mon-table th{color:var(--muted);font-weight:600;font-size:.78rem;text-transform:uppercase;letter-spacing:.02em}
.mon-table tbody tr:hover{background:color-mix(in srgb,var(--muted) 8%,transparent)}

.pill{display:inline-block;padding:.15rem .55rem;border-radius:999px;font-size:.72rem;font-weight:700;border:1px solid var(--border)}
.pill.ok{color:#2f9e44;border-color:#2f9e44}
.pill.off,.pill.rejected{color:#e03131;border-color:#e03131}
.pill.pending{color:#f59f00;border-color:#f59f00}
.pill.approved{color:#2f9e44;border-color:#2f9e44}

.health-list{list-style:none;display:flex;flex-direction:column;gap:.5rem;margin:0;padding:0}
.health-row{display:grid;grid-template-columns:auto auto 1fr auto;align-items:center;gap:.6rem;padding:.45rem .5rem;border:1px solid var(--border);border-radius:.5rem}
.health-row .dot{width:.6rem;height:.6rem;border-radius:50%;background:var(--muted)}
.health-row.state-ok .dot{background:#2f9e44}
.health-row.state-warn .dot{background:#f59f00}
.health-row.state-down .dot{background:#e03131}
.hc-name{font-weight:700;text-transform:capitalize}
.hc-detail{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.8rem}
.hc-latency{font-variant-numeric:tabular-nums;font-size:.8rem;color:var(--muted)}

.feedback-list{display:flex;flex-direction:column;gap:.75rem}
.feedback-item{border:1px solid var(--border);border-radius:.6rem;padding:.85rem 1rem}
.fb-head{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap;margin-bottom:.35rem}
.fb-stars{color:#f59f00;letter-spacing:.05em}
.fb-body{color:var(--fg);font-size:.92rem;margin:.25rem 0}
.fb-meta{font-size:.78rem;margin-bottom:.5rem}
.fb-actions{display:flex;gap:.4rem;flex-wrap:wrap}

.ref-links{list-style:none;display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:.5rem;margin:.75rem 0 0;padding:0}
.ref-link{display:flex;flex-direction:column;border:1px solid var(--border);border-radius:.5rem;padding:.6rem .75rem;text-decoration:none;color:var(--fg)}
.ref-link:hover{background:color-mix(in srgb,var(--muted) 8%,transparent)}
.ref-link span:last-child{font-size:.72rem;word-break:break-all}
@media(max-width:640px){.mon-head h1{font-size:1.3rem}}

/* ======================================================================
 * Step 16, UI polish: design tokens, a11y, responsive nav, skeletons,
 * PWA offline banner, support widget, role-specific "Today" dashboard.
 * ==================================================================== */

/* ---- Design tokens (semantic, theme-aware) ---- */
:root{
  --ok:#2f9e44; --warn:#b8860b; --warn-bg:#f59f00; --danger:#e03131;
  --radius:.75rem; --radius-sm:.5rem; --radius-lg:1rem;
  --shadow-sm:0 1px 2px rgba(0,0,0,.05); --shadow-md:0 8px 24px rgba(0,0,0,.12);
  --space:1rem;
}
.dark{--shadow-sm:0 1px 2px rgba(0,0,0,.3);--shadow-md:0 10px 28px rgba(0,0,0,.45)}

/* ---- Accessibility: visually-hidden + focus ---- */
.sr-only{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
:focus-visible{outline:2px solid var(--gk,#516838);outline-offset:2px}
.tab:focus-visible,.today-row:focus-visible,.today-action:focus-visible{outline:2px solid var(--gk,#516838);outline-offset:2px;border-radius:.4rem}
#main-content:focus{outline:none}

/* ---- Primary navigation: always a hamburger dropdown menu ---- */
.nav{position:relative;justify-content:flex-start;gap:.5rem}
.nav .brand{margin-right:auto}
.nav-toggle{display:inline-flex;order:2}
.nav-actions{display:flex;align-items:center;gap:.6rem;order:1}
.nav-links{
  display:none;order:3;position:absolute;top:calc(100% + .4rem);right:0;
  min-width:14rem;max-width:min(22rem,calc(100vw - 2rem));
  flex-direction:column;align-items:stretch;gap:.1rem;
  background:var(--card);border:1px solid var(--border);border-radius:.65rem;
  padding:.4rem;box-shadow:0 12px 32px rgba(0,0,0,.2);z-index:60;
  max-height:calc(100vh - 4.5rem);max-height:calc(100dvh - 4.5rem);
  overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch
}
.nav-links.is-open{display:flex}
.nav-links .btn-ghost{justify-content:flex-start;border-color:transparent;width:100%;padding:.4rem .7rem;font-size:.9rem;font-weight:500}
.nav-account{display:flex;flex-direction:column;gap:.1rem;border-top:1px solid var(--border);margin-top:.25rem;padding-top:.25rem}
.nav-account .btn-ghost{width:100%}
.nav-logout{color:#dc2626}
@media(max-width:640px){
  .nav .brand span:last-child{font-size:.95rem}
}

/* ---- Skeleton loaders ---- */
.skel{position:relative;overflow:hidden;background:color-mix(in srgb,var(--muted) 16%,var(--card));border-radius:.4rem}
.skel::after{content:"";position:absolute;inset:0;transform:translateX(-100%);background:linear-gradient(90deg,transparent,color-mix(in srgb,var(--fg) 8%,transparent),transparent);animation:skel 1.3s infinite}
@keyframes skel{100%{transform:translateX(100%)}}
.skel-line{height:.9rem;margin:.4rem 0}
.skel-line.lg{height:1.5rem;width:60%}
.skel-line.sm{height:.7rem;width:40%}
.skel-stat{display:flex;flex-direction:column;gap:.5rem;padding:1rem}
@media(prefers-reduced-motion:reduce){.skel::after{animation:none}}

/* ---- PWA offline banner ---- */
.offline-banner{position:fixed;left:0;right:0;bottom:0;z-index:240;display:flex;align-items:center;justify-content:center;gap:.6rem;padding:.7rem 1rem;background:#3a2d12;color:#ffe8b0;font-size:.9rem;font-weight:600;box-shadow:0 -4px 18px rgba(0,0,0,.25)}
.offline-dot{width:.6rem;height:.6rem;border-radius:50%;background:var(--warn-bg,#f59f00);box-shadow:0 0 0 0 rgba(245,159,0,.6);animation:offpulse 1.6s infinite}
@keyframes offpulse{0%{box-shadow:0 0 0 0 rgba(245,159,0,.5)}70%{box-shadow:0 0 0 8px rgba(245,159,0,0)}100%{box-shadow:0 0 0 0 rgba(245,159,0,0)}}
@media(prefers-reduced-motion:reduce){.offline-dot{animation:none}}
.is-offline .support-fab{bottom:4rem}

/* ---- Realtime (websocket) status indicator ---- */
.rt-indicator{display:inline-flex;align-items:center;justify-content:center;width:2.25rem;height:2.25rem}
.rt-dot{width:.7rem;height:.7rem;border-radius:50%;background:#f59f00;box-shadow:0 0 0 0 rgba(245,159,0,.5);transition:background .25s ease}
.rt-indicator.is-up .rt-dot{background:#22c55e;box-shadow:0 0 0 3px rgba(34,197,94,.18)}
.rt-indicator.is-down .rt-dot{background:#ef4444;box-shadow:0 0 0 0 rgba(239,68,68,.55);animation:rtpulse 1.6s infinite}
@keyframes rtpulse{0%{box-shadow:0 0 0 0 rgba(239,68,68,.5)}70%{box-shadow:0 0 0 7px rgba(239,68,68,0)}100%{box-shadow:0 0 0 0 rgba(239,68,68,0)}}
@media(prefers-reduced-motion:reduce){.rt-indicator.is-down .rt-dot{animation:none}}

/* ---- Support widget (Rocket.Chat fallback launcher) ---- */
.support-fab{position:fixed;right:1.25rem;bottom:1.25rem;z-index:230;display:inline-flex;align-items:center;gap:.5rem;padding:.7rem 1.1rem;border:0;border-radius:999px;background:var(--gk,#516838);color:#fff;font-weight:700;font-size:.9rem;cursor:pointer;box-shadow:var(--shadow-md)}
.support-fab:hover{background:var(--gk-dark,#40512f)}
.support-fab:focus-visible{outline:2px solid var(--gk-soft,#aabf90);outline-offset:2px}
@media(max-width:520px){.support-fab-label{display:none}.support-fab{padding:.8rem;border-radius:50%}}

/* ---- Today dashboard ---- */
.today-hero{margin-bottom:1.25rem}
.today-eyebrow{color:var(--muted);font-size:.85rem;font-weight:600;text-transform:capitalize;margin:0 0 .35rem}
.today-hero h1{font-size:1.8rem;font-weight:800;letter-spacing:-.01em}
@media(min-width:768px){.today-hero h1{font-size:2.2rem}}

.today-actions{display:flex;gap:.6rem;flex-wrap:wrap;margin-bottom:1.5rem}
.today-action{display:inline-flex;align-items:center;gap:.5rem;padding:.55rem .9rem;border:1px solid var(--border);background:var(--card);border-radius:999px;font-weight:600;font-size:.9rem;color:var(--fg);box-shadow:var(--shadow-sm);transition:transform .12s,box-shadow .12s}
.today-action:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
.today-action-icon{font-size:1.05rem}

.today-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:.85rem;margin-bottom:1.5rem}
.today-stat{display:flex;flex-direction:column;gap:.15rem;border:1px solid var(--border);background:var(--card);border-radius:var(--radius);padding:1rem 1.1rem;box-shadow:var(--shadow-sm)}
.today-stat.is-warn{border-color:var(--warn-bg);box-shadow:0 0 0 1px var(--warn-bg) inset}
.today-stat-icon{font-size:1.1rem}
.today-stat-value{font-size:1.6rem;font-weight:800;line-height:1.05;font-variant-numeric:tabular-nums}
.today-stat-label{color:var(--muted);font-size:.82rem}

.today-grid{display:grid;gap:1.25rem;grid-template-columns:1fr}
@media(min-width:768px){.today-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1200px){.today-grid{grid-template-columns:repeat(3,1fr)}}
.today-card{display:flex;flex-direction:column;border:1px solid var(--border);background:var(--card);border-radius:var(--radius-lg);padding:1.4rem;box-shadow:var(--shadow-sm)}
.today-card-head h2{font-size:1.1rem;font-weight:700}
.today-card-head p{color:var(--muted);font-size:.85rem;margin-top:.15rem}
.today-card-body{flex:1;margin-top:1rem}
.today-card-foot{margin-top:1rem;padding-top:.85rem;border-top:1px solid var(--border)}
.today-card-link{color:var(--gk,#516838);font-weight:700;font-size:.88rem}
.today-empty{color:var(--muted);font-size:.92rem;padding:.75rem 0}

.today-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}
.today-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.6rem .7rem;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--fg);transition:background .12s}
.today-row:hover{background:color-mix(in srgb,var(--muted) 8%,transparent)}
.today-row-main{font-size:.92rem;overflow:hidden;text-overflow:ellipsis}
.today-row-meta{display:flex;align-items:center;gap:.4rem;flex-wrap:wrap;flex:none}
.today-chip{display:inline-block;padding:.12rem .5rem;border-radius:999px;font-size:.72rem;font-weight:700;color:#fff;background:var(--chip,var(--muted))}
.today-meta{color:var(--muted);font-size:.78rem}
.today-badge{display:inline-block;min-width:1.4rem;text-align:center;padding:.12rem .5rem;border-radius:999px;font-size:.74rem;font-weight:800}
.today-badge.warn{background:var(--warn-bg,#f59f00);color:#3a2d12}

.today-minigrid{display:grid;grid-template-columns:repeat(2,1fr);gap:.6rem}
.today-mini{display:flex;flex-direction:column;border:1px solid var(--border);border-radius:var(--radius-sm);padding:.8rem;color:var(--fg)}
.today-mini:hover{background:color-mix(in srgb,var(--muted) 8%,transparent)}
.today-mini-value{font-size:1.4rem;font-weight:800;font-variant-numeric:tabular-nums}
.today-mini-label{color:var(--muted);font-size:.8rem}

.today-shift{display:flex;align-items:center;gap:.75rem;padding:.85rem 1rem;border:1px solid var(--border);border-radius:var(--radius-sm)}
.today-shift>div{flex:1}
.today-shift-dot{width:.7rem;height:.7rem;border-radius:50%;background:var(--muted);flex:none}
.today-shift.on .today-shift-dot{background:var(--ok);box-shadow:0 0 0 4px color-mix(in srgb,var(--ok) 25%,transparent)}

/* Step 17, sign-in page ------------------------------------------------- */
.auth-card{max-width:25rem;margin:4rem auto;padding:2rem 1.75rem;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 4px 20px rgba(0,0,0,.06)}
.auth-card h1{margin:0 0 .35rem;font-size:1.5rem}
.auth-card .auth-sub{margin:0 0 1.5rem;color:var(--muted);font-size:.92rem}
.auth-card form{display:flex;flex-direction:column;gap:.35rem}
.auth-card label{font-size:.85rem;font-weight:600;color:var(--fg);margin-top:.6rem}
.auth-card input{width:100%;border:1px solid var(--border);background:var(--bg);color:var(--fg);border-radius:.5rem;padding:.6rem .7rem;font:inherit}
.auth-card input:focus-visible{outline:2px solid var(--gk-soft);outline-offset:1px;border-color:var(--gk)}
.auth-card .btn-primary{width:100%;margin-top:1.25rem}
.auth-card .auth-msg{color:#dc2626;font-size:.85rem;min-height:1.1em;margin:.85rem 0 0}
.auth-card .auth-msg:empty{display:none}
.auth-card .auth-links{margin:1.25rem 0 0;font-size:.88rem;color:var(--muted);text-align:center}
.auth-card .auth-links a{color:var(--gk);font-weight:600}

/* ---- Profile / account self-service ---- */
.profile-head{margin-bottom:1.25rem}
.profile-head h1{font-size:1.6rem;font-weight:800;letter-spacing:-.01em}
.profile-grid{display:grid;grid-template-columns:1fr;gap:1.25rem;max-width:42rem}
.profile-summary .profile-meta{display:grid;grid-template-columns:auto 1fr;gap:.4rem .9rem;margin:.6rem 0 .25rem}
.profile-summary .profile-meta dt{font-weight:600;color:var(--muted)}
.profile-summary .profile-meta dd{color:var(--fg);word-break:break-word}
.profile-note{margin-top:.6rem;font-size:.82rem}
.profile-grid form .btn-primary{margin-top:.5rem}

/* ---- Tenant brand in header + organization settings (Step 18) ---- */
.nav:has(.org-brand) .brand{margin-right:.6rem}
.org-brand{display:inline-flex;align-items:center;gap:.45rem;margin-right:auto;padding:.25rem .5rem;border-radius:.6rem;color:var(--fg);text-decoration:none;min-width:0;max-width:42vw;overflow:hidden}
.org-brand:hover{background:color-mix(in srgb,var(--fg) 7%,transparent)}
.org-brand-logo{height:1.9rem;width:auto;max-width:100%;object-fit:contain;flex:0 1 auto}
.org-brand-name{font-weight:600;font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}
@media(max-width:640px){
  /* Keep the tenant logo + name visible on phones; free up room by trimming
     the global brand wordmark down to just its badge. */
  .nav:has(.org-brand) .brand span:last-child{display:none}
  .org-brand{max-width:55vw}
  .org-brand-name{font-size:.9rem}
}
.org-identity{display:flex;align-items:center;gap:.9rem}
.org-identity-name{font-weight:700;font-size:1.05rem;margin:0}
.org-logo-frame{display:inline-flex;align-items:center;justify-content:center;width:4rem;height:4rem;border-radius:.8rem;border:1px solid var(--border);background:var(--card);overflow:hidden;flex:0 0 auto}
.org-logo-frame img{width:100%;height:100%;object-fit:cover}
.org-logo-empty{font-weight:800;font-size:1.5rem;color:var(--muted)}
.settings-wrap .form-row{display:flex;gap:.6rem;align-items:center;flex-wrap:wrap;margin-top:.5rem}

/* ---- Team management (add members + roster) ---- */
.team-grid{display:grid;grid-template-columns:1fr;gap:1.25rem;align-items:start;max-width:64rem}
@media(min-width:860px){.team-grid{grid-template-columns:22rem 1fr}}
.team-add form .btn-primary{margin-top:.5rem}
.team-add .req{color:#dc2626}
.team-list{margin-top:.4rem}
.team-rows{list-style:none;margin:0;padding:0;display:flex;flex-direction:column}
.team-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.7rem .25rem;border-bottom:1px solid var(--border)}
.team-row:last-child{border-bottom:0}
.team-cell-main{display:flex;flex-direction:column;min-width:0}
.team-name{font-weight:600}
.team-cell-sub{font-size:.82rem;color:var(--muted);word-break:break-word}
.team-cell-meta{display:flex;align-items:center;gap:.5rem;flex:0 0 auto}
.team-role{font-size:.82rem;font-weight:600;color:var(--fg);background:color-mix(in srgb,var(--fg) 8%,transparent);padding:.15rem .55rem;border-radius:1rem;white-space:nowrap}
.team-badge{font-size:.72rem;font-weight:700;padding:.12rem .5rem;border-radius:1rem}
.team-badge.active{color:#047857;background:color-mix(in srgb,#10b981 18%,transparent)}
.team-badge.inactive{color:#b91c1c;background:color-mix(in srgb,#ef4444 18%,transparent)}


/* ---- Legal / policy pages ---- */
.legal{padding:2.5rem 0 3.5rem}
.legal-inner{max-width:48rem}
.legal-tabs{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:2rem;border-bottom:1px solid var(--border);padding-bottom:1rem}
.legal-tabs a{font-size:.85rem;font-weight:600;color:var(--muted);border:1px solid var(--border);border-radius:999px;padding:.35rem .85rem;text-decoration:none;transition:background .12s,color .12s,border-color .12s}
.legal-tabs a:hover{color:var(--fg);border-color:var(--gk,#516838)}
.legal-tabs a.is-active{background:var(--gk,#516838);border-color:var(--gk,#516838);color:#fff}
.legal-head{margin-bottom:2rem}
.legal-head h1{font-size:2rem;font-weight:800;letter-spacing:-.01em;line-height:1.15}
@media(min-width:768px){.legal-head h1{font-size:2.4rem}}
.legal-meta{color:var(--muted);font-size:.9rem;margin-top:.5rem}
.legal-body{font-size:1rem;line-height:1.7;color:var(--fg)}
.legal-body h2{font-size:1.25rem;font-weight:700;letter-spacing:-.01em;margin:2rem 0 .75rem}
.legal-body p{margin:0 0 1rem;color:color-mix(in srgb,var(--fg) 88%,var(--muted))}
.legal-body ul{margin:0 0 1rem 1.25rem;padding:0;display:flex;flex-direction:column;gap:.4rem}
.legal-body li{line-height:1.6}
.legal-body a{color:var(--gk,#516838);font-weight:600;text-decoration:underline}
.legal-body a:hover{color:var(--gk-dark,#40512f)}
.legal-table{width:100%;border-collapse:collapse;margin:0 0 1rem;font-size:.92rem}
.legal-table th,.legal-table td{text-align:left;padding:.55rem .65rem;border:1px solid var(--border);vertical-align:top}
.legal-table th{background:color-mix(in srgb,var(--muted) 10%,transparent);font-weight:700;font-size:.82rem}
.legal-note{font-size:.85rem;color:var(--muted)}
.legal-foot{margin-top:2.5rem;padding-top:1.25rem;border-top:1px solid var(--border);color:var(--muted);font-size:.9rem}
.legal-foot a{color:var(--gk,#516838);font-weight:600}


