﻿/* ============================================================
   ULTIMATE RESTAURANT POS — Design System
   A warm, control-room aesthetic for hospitality operations.
   Display: Plus Jakarta Sans · UI: Inter · Tickets: JetBrains Mono
   ============================================================ */

:root{
  /* Brand — appetizing warm orange */
  --brand-50:#FFF5ED;
  --brand-100:#FFE7D3;
  --brand-200:#FFCDA6;
  --brand-300:#FFAA6F;
  --brand-400:#FB7E33;
  --brand-500:#F2620F;   /* primary */
  --brand-600:#D94E09;
  --brand-700:#B23D0C;
  --brand-grad:linear-gradient(135deg,#FF8A3D 0%,#F2620F 55%,#D94E09 100%);

  /* Ink / neutral (slightly warm slate) */
  --ink-950:#0C111B;
  --ink-900:#111726;   /* sidebar */
  --ink-850:#161D2E;
  --ink-800:#1B2335;
  --ink-700:#27314A;
  --ink-600:#3A465F;
  --ink-500:#5A6884;
  --ink-400:#8290A8;
  --ink-300:#AEB8CC;
  --ink-200:#D7DDE8;
  --ink-100:#E9EDF3;
  --ink-50:#F4F6F9;

  /* Surfaces */
  --bg:#F3F5F8;
  --surface:#FFFFFF;
  --surface-2:#FAFBFC;
  --line:#E7EBF1;
  --line-strong:#D8DEE8;

  /* Text */
  --text:#16203A;
  --text-soft:#5A6884;
  --text-mute:#8A95AB;
  --text-inv:#F4F6F9;

  /* Semantic status */
  --green:#16A34A; --green-bg:#E7F7ED; --green-bd:#BBE9CB;
  --amber:#E08A00; --amber-bg:#FEF3DA; --amber-bd:#F6DCA3;
  --red:#E1453B;   --red-bg:#FDEAE8;   --red-bd:#F6C5BF;
  --blue:#2563EB;  --blue-bg:#E6EEFE;  --blue-bd:#BFD2FB;
  --violet:#7C3AED;--violet-bg:#F0E9FE;--violet-bd:#D6C4F8;
  --teal:#0D9488;  --teal-bg:#E1F5F2;  --teal-bd:#B6E5DE;

  /* Radii */
  --r-xs:8px; --r-sm:10px; --r-md:14px; --r-lg:18px; --r-xl:24px; --r-pill:999px;

  /* Shadows */
  --sh-xs:0 1px 2px rgba(16,24,40,.06);
  --sh-sm:0 1px 3px rgba(16,24,40,.08),0 1px 2px rgba(16,24,40,.04);
  --sh-md:0 4px 14px rgba(16,24,40,.08),0 2px 6px rgba(16,24,40,.04);
  --sh-lg:0 12px 32px rgba(16,24,40,.12),0 4px 10px rgba(16,24,40,.06);
  --sh-brand:0 8px 22px rgba(217,78,9,.28);

  --sidebar-w:264px;
  --topbar-h:68px;
  --font-display:"Plus Jakarta Sans",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --font-body:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
  --font-mono:"JetBrains Mono",ui-monospace,"SF Mono",Menlo,monospace;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:var(--font-body);
  background:var(--bg);
  color:var(--text);
  font-size:14px;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
h1,h2,h3,h4,h5{font-family:var(--font-display);margin:0;color:var(--text);letter-spacing:-.01em;font-weight:700}
a{color:inherit;text-decoration:none}
button{font-family:inherit}
:focus-visible{outline:3px solid rgba(242,98,15,.4);outline-offset:2px;border-radius:6px}
::selection{background:var(--brand-200)}
img{max-width:100%;display:block}
.num{font-variant-numeric:tabular-nums}

/* Scrollbars */
*::-webkit-scrollbar{width:10px;height:10px}
*::-webkit-scrollbar-thumb{background:#cdd5e0;border-radius:20px;border:2px solid transparent;background-clip:content-box}
*::-webkit-scrollbar-thumb:hover{background:#b4bdcc;background-clip:content-box}
*::-webkit-scrollbar-track{background:transparent}

/* ============================================================
   APP SHELL
   ============================================================ */
.app{display:flex;min-height:100vh}

/* ---- Sidebar ---- */
.sidebar{
  width:var(--sidebar-w);
  flex:0 0 var(--sidebar-w);
  background:var(--ink-900);
  color:#AEB8CC;
  display:flex;flex-direction:column;
  position:sticky;top:0;height:100vh;
  border-right:1px solid rgba(255,255,255,.04);
  z-index:30;
}
.brand{
  display:flex;align-items:center;gap:12px;
  padding:20px 20px 18px;
}
.brand-logo{
  width:42px;height:42px;border-radius:12px;background:var(--brand-grad);
  display:grid;place-items:center;color:#fff;flex:0 0 42px;
  box-shadow:var(--sh-brand);
}
.brand-logo svg{width:22px;height:22px}
.brand-name{color:#fff;font-family:var(--font-display);font-weight:800;font-size:15px;letter-spacing:-.02em;line-height:1.1}
.brand-sub{font-size:11px;color:var(--ink-500);letter-spacing:.04em;text-transform:uppercase;font-weight:600}

.branch-switch{
  margin:0 14px 8px;padding:11px 12px;border-radius:12px;
  background:var(--ink-850);border:1px solid var(--ink-700);
  display:flex;align-items:center;gap:10px;cursor:pointer;transition:.15s;
}
.branch-switch:hover{background:var(--ink-800);border-color:var(--ink-600)}
.branch-ic{width:34px;height:34px;border-radius:9px;background:rgba(242,98,15,.16);color:var(--brand-300);display:grid;place-items:center;flex:0 0 34px}
.branch-ic svg{width:17px;height:17px}
.branch-meta{flex:1;min-width:0}
.branch-meta b{color:#fff;font-size:13px;font-weight:600;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.branch-meta span{font-size:11px;color:var(--ink-500)}
.branch-switch .chev{color:var(--ink-500);width:15px;height:15px}

.nav{flex:1;overflow-y:auto;padding:8px 12px 16px}
.nav-group{margin-top:14px}
.nav-label{font-size:10.5px;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:var(--ink-600);padding:0 12px 7px}
.nav-item{
  display:flex;align-items:center;gap:12px;
  padding:9px 12px;border-radius:10px;margin-bottom:2px;
  color:var(--ink-300);font-weight:500;font-size:13.5px;
  transition:.14s;cursor:pointer;position:relative;
}
.nav-item svg{width:19px;height:19px;flex:0 0 19px;stroke-width:1.9}
.nav-item:hover{background:var(--ink-800);color:#fff}
.nav-item.active{background:linear-gradient(90deg,rgba(242,98,15,.20),rgba(242,98,15,.05));color:#fff}
.nav-item.active::before{content:"";position:absolute;left:-12px;top:50%;transform:translateY(-50%);width:3px;height:22px;background:var(--brand-500);border-radius:0 3px 3px 0}
.nav-item .nav-badge{margin-left:auto;background:var(--brand-500);color:#fff;font-size:10.5px;font-weight:700;min-width:19px;height:19px;border-radius:9px;display:grid;place-items:center;padding:0 5px}
.nav-item .nav-badge.alt{background:var(--ink-700);color:var(--ink-200)}
.nav-item .nav-badge.live{background:var(--green)}

.side-foot{padding:12px 14px;border-top:1px solid rgba(255,255,255,.05)}
.user-chip{display:flex;align-items:center;gap:10px;padding:8px;border-radius:11px;cursor:pointer;transition:.15s}
.user-chip:hover{background:var(--ink-800)}
.user-av{width:36px;height:36px;border-radius:10px;background:var(--brand-grad);display:grid;place-items:center;color:#fff;font-weight:700;font-size:13px;flex:0 0 36px;font-family:var(--font-display)}
.user-meta{flex:1;min-width:0}
.user-meta b{color:#fff;font-size:13px;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:600}
.user-meta span{font-size:11px;color:var(--ink-500)}
.user-chip .lg{color:var(--ink-500);width:17px;height:17px}

/* ---- Main column ---- */
.main{flex:1;min-width:0;display:flex;flex-direction:column}

/* ---- Topbar ---- */
.topbar{
  height:var(--topbar-h);position:sticky;top:0;z-index:20;
  background:rgba(255,255,255,.82);backdrop-filter:saturate(180%) blur(12px);
  border-bottom:1px solid var(--line);
  display:flex;align-items:center;gap:18px;padding:0 26px;
}
.page-h{display:flex;flex-direction:column;gap:1px;min-width:0}
.crumbs{font-size:11.5px;color:var(--text-mute);font-weight:500;display:flex;align-items:center;gap:6px}
.crumbs svg{width:12px;height:12px}
.page-title{font-size:19px;font-weight:700;letter-spacing:-.02em}
.topbar-spacer{flex:1}

.search{
  display:flex;align-items:center;gap:9px;background:var(--ink-50);
  border:1px solid var(--line);border-radius:11px;padding:9px 13px;
  width:300px;color:var(--text-mute);transition:.15s;
}
.search:focus-within{background:#fff;border-color:var(--brand-300);box-shadow:0 0 0 3px var(--brand-50)}
.search svg{width:16px;height:16px;flex:0 0 16px}
.search input{border:0;background:transparent;outline:0;width:100%;font-size:13.5px;color:var(--text)}
.search kbd{font-family:var(--font-body);font-size:10.5px;background:#fff;border:1px solid var(--line-strong);border-radius:5px;padding:2px 6px;color:var(--text-mute);box-shadow:0 1px 0 var(--line-strong)}

.icon-btn{
  width:40px;height:40px;border-radius:11px;border:1px solid var(--line);
  background:#fff;color:var(--text-soft);display:grid;place-items:center;
  cursor:pointer;transition:.15s;position:relative;
}
.icon-btn:hover{background:var(--ink-50);color:var(--text);border-color:var(--line-strong)}
.icon-btn svg{width:18px;height:18px}
.icon-btn .dot{position:absolute;top:9px;right:10px;width:8px;height:8px;border-radius:50%;background:var(--red);border:2px solid #fff}

.live-pill{
  display:flex;align-items:center;gap:8px;padding:7px 13px 7px 11px;border-radius:var(--r-pill);
  background:var(--green-bg);border:1px solid var(--green-bd);color:#0f7a37;font-weight:600;font-size:12.5px;
}
.live-dot{width:8px;height:8px;border-radius:50%;background:var(--green);position:relative}
.live-dot::after{content:"";position:absolute;inset:-4px;border-radius:50%;background:var(--green);opacity:.35;animation:pulse 1.8s ease-out infinite}
@keyframes pulse{0%{transform:scale(.6);opacity:.5}100%{transform:scale(1.9);opacity:0}}

/* ---- Content ---- */
.content{padding:26px;flex:1}
.content-narrow{max-width:1280px;margin:0 auto}

/* Page intro row */
.page-intro{display:flex;align-items:flex-end;justify-content:space-between;gap:18px;margin-bottom:22px;flex-wrap:wrap}
.page-intro h1{font-size:24px;font-weight:800;letter-spacing:-.03em}
.page-intro .lead{color:var(--text-soft);font-size:14px;margin-top:3px}
.page-actions{display:flex;gap:10px;flex-wrap:wrap}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  height:42px;padding:0 18px;border-radius:11px;border:1px solid transparent;
  font-weight:600;font-size:13.5px;cursor:pointer;transition:.15s;white-space:nowrap;
  font-family:var(--font-body);
}
.btn svg{width:17px;height:17px;flex:0 0 17px;stroke-width:2}
.btn-primary{background:var(--brand-500);color:#fff;box-shadow:var(--sh-brand)}
.btn-primary:hover{background:var(--brand-600);transform:translateY(-1px);box-shadow:0 10px 26px rgba(217,78,9,.34)}
.btn-primary:active{transform:translateY(0)}
.btn-dark{background:var(--ink-900);color:#fff}
.btn-dark:hover{background:var(--ink-800)}
.btn-ghost{background:#fff;color:var(--text);border-color:var(--line-strong)}
.btn-ghost:hover{background:var(--ink-50);border-color:var(--ink-300)}
.btn-soft{background:var(--brand-50);color:var(--brand-600);border-color:var(--brand-100)}
.btn-soft:hover{background:var(--brand-100)}
.btn-success{background:var(--green);color:#fff}
.btn-success:hover{filter:brightness(.95)}
.btn-danger{background:var(--red);color:#fff}
.btn-danger:hover{filter:brightness(.95)}
.btn-sm{height:34px;padding:0 12px;font-size:12.5px;border-radius:9px}
.btn-sm svg{width:15px;height:15px}
.btn-lg{height:50px;padding:0 24px;font-size:15px;border-radius:13px}
.btn-block{width:100%}
.btn-icon{padding:0;width:42px}
.btn-icon.btn-sm{width:34px}

/* ============================================================
   CARDS & SURFACES
   ============================================================ */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-sm)}
.card-pad{padding:20px}
.card-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:17px 20px;border-bottom:1px solid var(--line)}
.card-head h3{font-size:15.5px;font-weight:700}
.card-head .sub{font-size:12.5px;color:var(--text-mute);font-weight:500}
.card-body{padding:20px}
.card-foot{padding:14px 20px;border-top:1px solid var(--line);background:var(--surface-2);border-radius:0 0 var(--r-lg) var(--r-lg)}

.grid{display:grid;gap:18px}
.g-2{grid-template-columns:repeat(2,1fr)}
.g-3{grid-template-columns:repeat(3,1fr)}
.g-4{grid-template-columns:repeat(4,1fr)}

/* ============================================================
   STAT TILES
   ============================================================ */
.stat{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:20px;box-shadow:var(--sh-sm);position:relative;overflow:hidden}
.stat-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.stat-ic{width:44px;height:44px;border-radius:12px;display:grid;place-items:center}
.stat-ic svg{width:21px;height:21px}
.stat-ic.o{background:var(--brand-50);color:var(--brand-600)}
.stat-ic.g{background:var(--green-bg);color:var(--green)}
.stat-ic.b{background:var(--blue-bg);color:var(--blue)}
.stat-ic.v{background:var(--violet-bg);color:var(--violet)}
.stat-ic.a{background:var(--amber-bg);color:var(--amber)}
.stat-label{font-size:13px;color:var(--text-soft);font-weight:500}
.stat-value{font-family:var(--font-display);font-size:28px;font-weight:800;letter-spacing:-.03em;line-height:1.05}
.stat-value small{font-size:16px;font-weight:700;color:var(--text-mute)}
.stat-foot{display:flex;align-items:center;gap:7px;margin-top:9px;font-size:12.5px}
.trend{display:inline-flex;align-items:center;gap:3px;font-weight:700;padding:2px 7px;border-radius:7px}
.trend svg{width:13px;height:13px}
.trend.up{color:var(--green);background:var(--green-bg)}
.trend.down{color:var(--red);background:var(--red-bg)}
.stat-foot .vs{color:var(--text-mute)}
.stat .spark{position:absolute;right:0;bottom:0;opacity:.9}

/* ============================================================
   BADGES / PILLS / CHIPS
   ============================================================ */
.badge{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:700;padding:3px 9px;border-radius:var(--r-pill);border:1px solid transparent;line-height:1.5;white-space:nowrap}
.badge .bd{width:6px;height:6px;border-radius:50%}
.badge.green{background:var(--green-bg);color:#0f7a37;border-color:var(--green-bd)} .badge.green .bd{background:var(--green)}
.badge.amber{background:var(--amber-bg);color:#9a6200;border-color:var(--amber-bd)} .badge.amber .bd{background:var(--amber)}
.badge.red{background:var(--red-bg);color:#b5271d;border-color:var(--red-bd)} .badge.red .bd{background:var(--red)}
.badge.blue{background:var(--blue-bg);color:#1d4ed8;border-color:var(--blue-bd)} .badge.blue .bd{background:var(--blue)}
.badge.violet{background:var(--violet-bg);color:#6d28d9;border-color:var(--violet-bd)} .badge.violet .bd{background:var(--violet)}
.badge.teal{background:var(--teal-bg);color:#0b7268;border-color:var(--teal-bd)} .badge.teal .bd{background:var(--teal)}
.badge.gray{background:var(--ink-50);color:var(--text-soft);border-color:var(--line-strong)} .badge.gray .bd{background:var(--ink-400)}
.badge.solid-o{background:var(--brand-500);color:#fff}

.chip{display:inline-flex;align-items:center;gap:7px;height:36px;padding:0 14px;border-radius:var(--r-pill);background:#fff;border:1px solid var(--line-strong);font-weight:600;font-size:13px;color:var(--text-soft);cursor:pointer;transition:.14s;white-space:nowrap}
.chip:hover{border-color:var(--ink-300);color:var(--text)}
.chip.active{background:var(--ink-900);color:#fff;border-color:var(--ink-900)}
.chip svg{width:16px;height:16px}
.chip .ct{font-size:11px;background:var(--ink-100);color:var(--text-soft);border-radius:8px;padding:1px 6px;font-weight:700}
.chip.active .ct{background:rgba(255,255,255,.18);color:#fff}

/* Segmented control */
.seg{display:inline-flex;background:var(--ink-50);border:1px solid var(--line);border-radius:11px;padding:3px;gap:2px}
.seg button{border:0;background:transparent;padding:7px 15px;border-radius:8px;font-weight:600;font-size:13px;color:var(--text-soft);cursor:pointer;transition:.14s;font-family:var(--font-body)}
.seg button:hover{color:var(--text)}
.seg button.active{background:#fff;color:var(--text);box-shadow:var(--sh-xs)}

/* ============================================================
   TABLES
   ============================================================ */
.tbl{width:100%;border-collapse:collapse}
.tbl th{text-align:left;font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text-mute);padding:11px 16px;border-bottom:1px solid var(--line);background:var(--surface-2);white-space:nowrap}
.tbl td{padding:14px 16px;border-bottom:1px solid var(--line);font-size:13.5px;vertical-align:middle}
.tbl tr:last-child td{border-bottom:0}
.tbl tbody tr{transition:.12s}
.tbl tbody tr:hover{background:var(--surface-2)}
.tbl .right{text-align:right}
.tbl .strong{font-weight:700;color:var(--text)}
.cell-prod{display:flex;align-items:center;gap:12px}
.cell-thumb{width:42px;height:42px;border-radius:10px;object-fit:cover;flex:0 0 42px;background:var(--ink-100)}
.cell-prod b{font-weight:600;display:block;line-height:1.2}
.cell-prod span{font-size:12px;color:var(--text-mute)}

/* Avatars */
.av{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;font-weight:700;font-size:12.5px;color:#fff;flex:0 0 34px;font-family:var(--font-display)}
.av.sm{width:28px;height:28px;font-size:11px}
.av-c1{background:#F2620F}.av-c2{background:#2563EB}.av-c3{background:#16A34A}.av-c4{background:#7C3AED}.av-c5{background:#0D9488}.av-c6{background:#E08A00}

/* ============================================================
   FORMS
   ============================================================ */
.field{margin-bottom:16px}
.field label{display:block;font-size:13px;font-weight:600;color:var(--text);margin-bottom:7px}
.field .hint{font-size:12px;color:var(--text-mute);margin-top:6px}
.input,.select,.textarea{
  width:100%;height:44px;border:1px solid var(--line-strong);border-radius:11px;
  padding:0 14px;font-size:14px;color:var(--text);background:#fff;transition:.15s;font-family:var(--font-body);
}
.textarea{height:auto;padding:11px 14px;min-height:90px;resize:vertical;line-height:1.5}
.input::placeholder,.textarea::placeholder{color:var(--text-mute)}
.input:focus,.select:focus,.textarea:focus{outline:0;border-color:var(--brand-400);box-shadow:0 0 0 3px var(--brand-50)}
.input-group{position:relative;display:flex;align-items:center}
.input-group .lead-ic{position:absolute;left:14px;color:var(--text-mute);width:18px;height:18px;pointer-events:none}
.input-group .input{padding-left:42px}
.input-group .suffix{position:absolute;right:14px;color:var(--text-mute);font-weight:600;font-size:13px}
.select{appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%238A95AB' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");background-repeat:no-repeat;background-position:right 12px center;padding-right:40px}

/* Toggle */
.switch{position:relative;display:inline-flex;width:44px;height:25px;flex:0 0 44px;cursor:pointer}
.switch input{opacity:0;width:0;height:0}
.switch .track{position:absolute;inset:0;background:var(--ink-200);border-radius:var(--r-pill);transition:.2s}
.switch .track::before{content:"";position:absolute;left:3px;top:3px;width:19px;height:19px;background:#fff;border-radius:50%;transition:.2s;box-shadow:var(--sh-sm)}
.switch input:checked + .track{background:var(--brand-500)}
.switch input:checked + .track::before{transform:translateX(19px)}

/* Stepper */
.stepper{display:inline-flex;align-items:center;border:1px solid var(--line-strong);border-radius:10px;overflow:hidden;background:#fff}
.stepper button{width:34px;height:34px;border:0;background:#fff;color:var(--text);font-size:18px;cursor:pointer;display:grid;place-items:center;transition:.12s}
.stepper button:hover{background:var(--ink-50);color:var(--brand-600)}
.stepper .val{min-width:34px;text-align:center;font-weight:700;font-size:14px;font-variant-numeric:tabular-nums}

/* ============================================================
   MISC HELPERS
   ============================================================ */
.row{display:flex;align-items:center;gap:12px}
.col{display:flex;flex-direction:column;gap:12px}
.between{justify-content:space-between}
.wrap{flex-wrap:wrap}
.muted{color:var(--text-mute)}
.soft{color:var(--text-soft)}
.tiny{font-size:12px}
.mono{font-family:var(--font-mono)}
.price{font-family:var(--font-display);font-weight:700}
.divider{height:1px;background:var(--line);margin:16px 0}
.dot-sep{width:3px;height:3px;border-radius:50%;background:var(--ink-300);display:inline-block}
.scrollx{overflow-x:auto}
.empty{text-align:center;padding:40px 20px;color:var(--text-mute)}
.empty svg{width:46px;height:46px;color:var(--ink-300);margin:0 auto 12px}
.kbd{font-size:11px;background:var(--ink-50);border:1px solid var(--line-strong);border-radius:6px;padding:2px 7px;font-weight:600;color:var(--text-soft)}

/* Progress */
.bar{height:8px;background:var(--ink-100);border-radius:var(--r-pill);overflow:hidden}
.bar > i{display:block;height:100%;border-radius:var(--r-pill);background:var(--brand-500)}
.bar.green > i{background:var(--green)} .bar.red > i{background:var(--red)} .bar.amber > i{background:var(--amber)} .bar.blue > i{background:var(--blue)}

/* Progress ring helper via conic-gradient */
.ring{position:relative;width:120px;height:120px;border-radius:50%;display:grid;place-items:center}
.ring::before{content:"";position:absolute;inset:14px;background:#fff;border-radius:50%}
.ring .ring-v{position:relative;font-family:var(--font-display);font-weight:800;font-size:24px}

/* List rows */
.lrow{display:flex;align-items:center;gap:13px;padding:13px 0;border-bottom:1px solid var(--line)}
.lrow:last-child{border-bottom:0}
.lrow .lmeta{flex:1;min-width:0}
.lrow .lmeta b{font-weight:600;display:block}
.lrow .lmeta span{font-size:12.5px;color:var(--text-mute)}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1200px){
  .g-4{grid-template-columns:repeat(2,1fr)}
  .search{width:220px}
}
@media(max-width:900px){
  .sidebar{position:fixed;left:0;transform:translateX(-100%);transition:.25s;box-shadow:var(--sh-lg)}
  .sidebar.open{transform:none}
  .g-3,.g-2{grid-template-columns:1fr}
  .menu-toggle{display:grid !important}
  .search{display:none}
}
@media(max-width:600px){
  .g-4{grid-template-columns:1fr}
  .content{padding:16px}
  .topbar{padding:0 14px}
}
.menu-toggle{display:none}

@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms !important;transition-duration:.001ms !important}
}
