/* =========================================================
   QuetMap — shared design system
   ========================================================= */
:root{
  /* BBO Tech palette — deep ink + bamboo lime */
  --bg:        oklch(0.14 0.008 150);
  --bg-2:      oklch(0.17 0.010 150);
  --surface:   oklch(0.195 0.011 150);
  --surface-2: oklch(0.23 0.013 150);
  --surface-3: oklch(0.27 0.013 150);
  --line:      oklch(0.30 0.013 150);
  --line-2:    oklch(0.38 0.014 150);
  --text:      oklch(0.98 0.005 150);
  --text-2:    oklch(0.80 0.012 150);
  --text-3:    oklch(0.58 0.014 150);
  --text-4:    oklch(0.44 0.012 150);
  --accent:    oklch(0.88 0.22 128);     /* bamboo lime */
  --accent-2:  oklch(0.82 0.22 128);
  --accent-3:  oklch(0.92 0.20 128);
  --accent-soft: oklch(0.32 0.10 128);
  --accent-ink: oklch(0.18 0.04 150);     /* dark ink for on-lime text */
  --danger:    oklch(0.72 0.18 25);
  --danger-soft: oklch(0.30 0.10 25);
  --ok:        oklch(0.78 0.15 142);
  --ok-soft:   oklch(0.30 0.08 142);
  --warn:      oklch(0.84 0.16 85);
  --warn-soft: oklch(0.32 0.10 85);
  --info:      oklch(0.76 0.13 215);
  --info-soft: oklch(0.30 0.08 215);
  --radius:    10px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:"Geist", ui-sans-serif, system-ui, sans-serif;
  background: var(--bg);
  color: var(--text);
  font-size:14px;
  line-height:1.45;
  -webkit-font-smoothing:antialiased;
  min-height:100vh;
  background-image:
    radial-gradient(1100px 600px at 80% -10%, oklch(0.55 0.20 128 / 0.10), transparent 60%),
    radial-gradient(900px 500px at -10% 110%, oklch(0.35 0.08 150 / 0.12), transparent 60%);
}
a{color:inherit}
button{font-family:inherit}

/* ---------- nav ---------- */
.nav{
  position:sticky;top:0;z-index:20;
  background: oklch(0.14 0.008 150 / 0.82);
  backdrop-filter: saturate(140%) blur(10px);
  -webkit-backdrop-filter: saturate(140%) blur(10px);
  border-bottom:1px solid var(--line);
}
.nav-inner{
  max-width:1320px;margin:0 auto;
  padding:14px 28px;
  display:flex;align-items:center;gap:28px;
}
.brand{
  display:flex;align-items:center;gap:10px;
  font-weight:600;letter-spacing:-0.005em;font-size:15px;
  color:var(--text);text-decoration:none;
}
.brand .brand-mark{
  width:28px;height:28px;border-radius:8px;
  background: linear-gradient(135deg, var(--accent) 0%, oklch(0.72 0.20 142) 100%);
  display:flex;align-items:center;justify-content:center;
  box-shadow: 0 6px 18px oklch(0.65 0.20 128 / 0.30);
}
.brand .brand-mark svg{width:15px;height:15px;color:var(--accent-ink)}
.nav-links{display:flex;gap:4px;margin-left:8px}
.nav-link{
  display:inline-flex;align-items:center;gap:6px;
  color:var(--text-3);
  padding:7px 12px;border-radius:8px;
  font-size:13.5px;font-weight:500;text-decoration:none;
  transition: color .15s, background .15s;
  position:relative;
}
.nav-link svg{width:14px;height:14px;flex-shrink:0}
.nav-link:hover{color:var(--text);background:var(--surface)}
.nav-link.active{color:var(--text); background:var(--surface)}
.nav-spacer{flex:1}
.nav-meta{display:flex;align-items:center;gap:10px}
.nav-search{
  display:flex;align-items:center;gap:8px;
  background:var(--surface);border:1px solid var(--line);
  padding:0 10px;height:34px;border-radius:8px;
  color:var(--text-3);font-size:12.5px;
  min-width:200px;
}
.nav-search input{
  background:transparent;border:0;outline:0;color:var(--text);
  font:inherit;font-size:13px;width:100%;
}
.nav-search kbd{
  font-family:"JetBrains Mono",monospace;font-size:10.5px;
  background:var(--bg-2);border:1px solid var(--line);
  padding:1px 5px;border-radius:4px;color:var(--text-3);
}
.nav-user{
  display:flex;align-items:center;gap:8px;
  background:var(--surface);border:1px solid var(--line);
  padding:3px 10px 3px 3px;height:34px;border-radius:999px;
  color:var(--text-2);font-size:12.5px;cursor:pointer;
}
.nav-user .avatar{
  width:26px;height:26px;border-radius:50%;
  background: linear-gradient(135deg, var(--accent), oklch(0.72 0.20 142));
  display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:700;color:var(--accent-ink);
  letter-spacing:.02em;
}

/* ---------- layout ---------- */
.shell{
  max-width:1320px;
  margin:0 auto;
  padding:28px 28px 80px;
}
.shell-narrow{max-width:1080px}

/* ---------- page header ---------- */
.page-head{
  display:flex;align-items:flex-end;justify-content:space-between;
  gap:24px;
  padding-bottom:22px;margin-bottom:24px;
  border-bottom:1px solid var(--line);
}
.page-head h1{
  margin:0 0 6px;font-size:26px;font-weight:600;letter-spacing:-0.01em;
}
.page-head .sub{color:var(--text-3);font-size:13.5px}
.page-head .sub strong{color:var(--text-2);font-weight:500}
.page-head-actions{display:flex;gap:10px;align-items:center}

/* ---------- buttons ---------- */
.btn{
  appearance:none;border:1px solid transparent;
  height:36px;padding:0 14px;
  border-radius:9px;
  font:inherit;font-size:13px;font-weight:500;
  cursor:pointer;
  display:inline-flex;align-items:center;gap:7px;
  transition:all .15s;
  white-space:nowrap;
}
.btn-lg{height:40px;padding:0 18px;font-size:13.5px;border-radius:10px}
.btn-sm{height:28px;padding:0 10px;font-size:12px;border-radius:7px;gap:5px}
.btn-ghost{background:transparent;color:var(--text-2);border-color:var(--line)}
.btn-ghost:hover{color:var(--text);border-color:var(--line-2);background:var(--surface)}
.btn-soft{background:var(--surface);color:var(--text-2);border-color:var(--line)}
.btn-soft:hover{color:var(--text);border-color:var(--line-2);background:var(--surface-2)}
.btn-primary{
  background:var(--accent);color:var(--accent-ink);font-weight:600;
  box-shadow:0 1px 0 oklch(1 0 0 / 0.25) inset, 0 6px 18px oklch(0.65 0.20 128 / 0.25);
}
.btn-primary:hover{background:var(--accent-2)}
.btn-primary:active{transform:translateY(1px)}
.btn-danger{background:transparent;color:var(--danger);border-color:oklch(0.45 0.14 25 / 0.6)}
.btn-danger:hover{background:oklch(0.35 0.10 25 / 0.18); border-color:var(--danger)}
.btn-icon{
  width:32px;height:32px;padding:0;justify-content:center;
  background:transparent;border:1px solid var(--line);color:var(--text-3);
  border-radius:8px;
}
.btn-icon:hover{color:var(--text);border-color:var(--line-2);background:var(--surface)}
.btn-icon svg{width:14px;height:14px}
.btn[disabled]{opacity:.5;cursor:not-allowed}

/* ---------- card ---------- */
.card{
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:14px;
  overflow:hidden;
}
.card + .card{margin-top:18px}

/* ---------- icons ---------- */
svg.i{
  width:14px;height:14px;stroke-width:1.7;stroke:currentColor;fill:none;
  stroke-linecap:round;stroke-linejoin:round;flex-shrink:0;
}
svg.i.sm{width:12px;height:12px}
svg.i.lg{width:16px;height:16px}
svg.i.xl{width:20px;height:20px}

/* ---------- badges ---------- */
.badge{
  display:inline-flex;align-items:center;gap:5px;
  height:22px;padding:0 8px;border-radius:999px;
  font-size:11.5px;font-weight:500;line-height:1;
  letter-spacing:.01em;
  border:1px solid transparent;
  white-space:nowrap;
}
.badge .dot{width:6px;height:6px;border-radius:50%;background:currentColor;flex-shrink:0}
.badge-ok{ color:var(--ok); background:var(--ok-soft); border-color:oklch(0.42 0.10 160 / 0.45)}
.badge-warn{ color:var(--warn); background:var(--warn-soft); border-color:oklch(0.42 0.10 85 / 0.45)}
.badge-info{ color:var(--info); background:var(--info-soft); border-color:oklch(0.42 0.10 230 / 0.45)}
.badge-danger{color:var(--danger); background:var(--danger-soft); border-color:oklch(0.42 0.12 25 / 0.5)}
.badge-muted{ color:var(--text-2); background:var(--bg-2); border-color:var(--line)}
.badge-accent{color:var(--accent-3); background:var(--accent-soft); border-color:oklch(0.50 0.18 128 / 0.5)}

/* running dot pulse */
.badge.running .dot{
  background: var(--info);
  box-shadow: 0 0 0 0 oklch(0.76 0.13 215 / 0.6);
  animation: pulse 1.6s infinite;
}
@keyframes pulse{
  0%{ box-shadow: 0 0 0 0 oklch(0.76 0.13 215 / 0.6)}
  70%{ box-shadow: 0 0 0 6px oklch(0.76 0.13 215 / 0)}
  100%{ box-shadow: 0 0 0 0 oklch(0.76 0.13 215 / 0)}
}

/* ---------- inputs ---------- */
.input, .select{
  width:100%;height:36px;
  background:var(--bg-2);
  border:1px solid var(--line);
  color:var(--text);
  border-radius:var(--radius);
  padding:0 12px;
  font:inherit;font-size:13.5px;
  transition: border-color .15s, box-shadow .15s, background .15s;
  outline:none;
}
.input::placeholder{color:var(--text-3)}
.input:hover, .select:hover{border-color:var(--line-2)}
.input:focus, .select:focus{
  border-color:var(--accent);
  box-shadow:0 0 0 3px oklch(0.78 0.20 128 / 0.22);
  background:var(--bg);
}
.input.mono{font-family:"JetBrains Mono",monospace;font-size:13px}
.input-wrap{position:relative}
.input-wrap .prefix, .input-wrap .suffix{
  position:absolute;top:0;bottom:0;display:flex;align-items:center;
  color:var(--text-3);font-size:12.5px;pointer-events:none;
}
.input-wrap .prefix{left:10px}
.input-wrap .suffix{right:10px}
.input-wrap.has-prefix .input{padding-left:34px}
.input-wrap.has-suffix .input{padding-right:42px}
.input-wrap .prefix svg{width:14px;height:14px}

/* ---------- segmented control ---------- */
.seg{
  display:inline-flex;
  background:var(--bg-2);
  border:1px solid var(--line);
  border-radius:9px;
  padding:3px;
  gap:2px;
}
.seg button{
  appearance:none;border:0;background:transparent;
  color:var(--text-3);
  height:28px;padding:0 12px;
  font:inherit;font-size:12.5px;font-weight:500;
  border-radius:6px;
  cursor:pointer;
  display:inline-flex;align-items:center;gap:6px;
  transition:all .15s;
}
.seg button:hover{color:var(--text)}
.seg button.active{
  background:var(--surface-2);
  color:var(--text);
  box-shadow: 0 1px 0 oklch(0.40 0.014 270 / 0.5) inset;
}
.seg .count{
  background:var(--bg);
  color:var(--text-3);
  font-size:10.5px;
  padding:1px 6px;border-radius:999px;
  font-family:"JetBrains Mono",monospace;
}
.seg button.active .count{color:var(--text-2)}

/* ---------- table ---------- */
.table-wrap{overflow:auto}
.tbl{
  width:100%;
  border-collapse:separate;border-spacing:0;
  font-size:13px;
}
.tbl thead th{
  text-align:left;
  font-size:11px;
  font-weight:500;
  color:var(--text-3);
  letter-spacing:.06em;
  text-transform:uppercase;
  padding:14px 16px;
  background:var(--bg-2);
  border-bottom:1px solid var(--line);
  white-space:nowrap;
  position:sticky;top:0;
}
.tbl thead th .sort{
  display:inline-flex;align-items:center;gap:5px;
  cursor:pointer;user-select:none;
}
.tbl thead th .sort svg{opacity:.4}
.tbl thead th .sort:hover{color:var(--text-2)}
.tbl tbody td{
  padding:14px 16px;
  border-bottom:1px solid var(--line);
  color:var(--text-2);
  vertical-align:middle;
}
.tbl tbody tr:hover td{background:oklch(0.21 0.013 270 / 0.6)}
.tbl tbody tr:last-child td{border-bottom:0}
.tbl .col-actions{text-align:right;white-space:nowrap}
.tbl .col-actions .btn{margin-left:6px}
.tbl .muted{color:var(--text-4);font-style:italic;font-size:12.5px}
.tbl .num{font-family:"JetBrains Mono",monospace;font-size:12.5px;color:var(--text)}
.tbl .time{font-family:"JetBrains Mono",monospace;font-size:12px;color:var(--text-3)}
.tbl .primary{color:var(--text);font-weight:500}

/* checkbox */
.chk{
  appearance:none;
  width:16px;height:16px;
  border:1.5px solid var(--line-2);
  border-radius:4px;
  background:var(--bg-2);
  cursor:pointer;
  display:inline-flex;align-items:center;justify-content:center;
  transition:all .12s;
  position:relative;
}
.chk:hover{border-color:var(--accent)}
.chk:checked{
  background:var(--accent);
  border-color:var(--accent);
}
.chk:checked::after{
  content:"";
  width:9px;height:5px;
  border-left:1.8px solid var(--accent-ink);border-bottom:1.8px solid var(--accent-ink);
  transform:rotate(-45deg);margin-top:-2px;
}
.chk:indeterminate{
  background:var(--accent);
  border-color:var(--accent);
}
.chk:indeterminate::after{
  content:"";
  width:8px;height:1.8px;background:var(--accent-ink);
}

/* ---------- chips ---------- */
.chips{display:flex;flex-wrap:wrap;gap:8px}
.chip{
  appearance:none;
  background:var(--bg-2);
  border:1px solid var(--line);
  color:var(--text-2);
  height:30px;padding:0 12px;
  border-radius:999px;
  font:inherit;font-size:12.5px;
  cursor:pointer;
  display:inline-flex;align-items:center;gap:8px;
  transition:all .15s;
}
.chip:hover{border-color:var(--line-2);color:var(--text)}
.chip.active, .chip[aria-pressed="true"]{
  background:var(--accent-soft);
  border-color:var(--accent);
  color:var(--text);
}
.chip .ct{
  font-size:10.5px;color:var(--text-3);
  font-family:"JetBrains Mono",monospace;
}
.chip.active .ct, .chip[aria-pressed="true"] .ct{color:var(--accent-3)}

/* ---------- stars ---------- */
.stars{display:inline-flex;align-items:center;gap:3px;color:var(--warn)}
.stars svg{width:12px;height:12px;fill:currentColor;stroke:none}
.rating-cell{display:flex;flex-direction:column;gap:2px;align-items:flex-start}
.rating-cell .num-rate{
  display:inline-flex;align-items:center;gap:5px;
  font-family:"JetBrains Mono",monospace;font-size:12.5px;color:var(--text);
}
.rating-cell .reviews{font-size:11px;color:var(--text-3)}

/* ---------- biz cell ---------- */
.biz{display:flex;flex-direction:column;gap:4px;min-width:0}
.biz .name{font-weight:500;color:var(--text);font-size:13.5px}
.biz .tag{
  display:inline-flex;align-items:center;
  height:18px;padding:0 7px;border-radius:999px;
  background:var(--bg-2);border:1px solid var(--line);
  color:var(--text-3);font-size:10.5px;
  align-self:flex-start;
}

/* ---------- empty state ---------- */
.empty{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:60px 20px;color:var(--text-3);
  gap:8px;text-align:center;
}
.empty .empty-icon{
  width:48px;height:48px;border-radius:12px;
  background:var(--bg-2);border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;color:var(--text-3);
}
.empty h3{margin:6px 0 0;color:var(--text);font-size:15px;font-weight:600}
.empty p{margin:0;font-size:13px;max-width:360px;line-height:1.5}

/* ---------- pagination ---------- */
.pagination{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 20px;border-top:1px solid var(--line);
  background:var(--bg-2);
  color:var(--text-3);font-size:12.5px;
}
.pagination .pager{display:flex;align-items:center;gap:4px}
.pagination .pager button{
  height:28px;min-width:28px;padding:0 8px;
  background:transparent;border:1px solid transparent;
  color:var(--text-3);font:inherit;font-size:12px;border-radius:6px;
  cursor:pointer;
}
.pagination .pager button:hover{background:var(--surface);color:var(--text)}
.pagination .pager button.active{background:var(--surface-2);color:var(--text);border-color:var(--line)}
.pagination .pager button[disabled]{opacity:.35;cursor:not-allowed}

/* ---------- toolbar ---------- */
.toolbar{
  display:flex;align-items:center;gap:10px;flex-wrap:wrap;
  padding:14px 16px;
  background:var(--bg-2);
  border-bottom:1px solid var(--line);
}
.toolbar .spacer{flex:1}

/* ---------- focusable rows ---------- */
.tbl tbody tr{transition: background .12s}
.tbl tbody tr.sel td{background: oklch(0.40 0.12 128 / 0.10)}

/* scrollbar */
*::-webkit-scrollbar{width:10px;height:10px}
*::-webkit-scrollbar-track{background:transparent}
*::-webkit-scrollbar-thumb{background:var(--line);border-radius:10px;border:2px solid var(--bg)}
*::-webkit-scrollbar-thumb:hover{background:var(--line-2)}

/* small responsive */
@media (max-width:880px){
  .nav-search{display:none}
  .nav-links{overflow:auto;flex-shrink:1;min-width:0}
  .page-head{flex-direction:column;align-items:flex-start;gap:14px}
  .shell{padding:18px 16px 60px}
}

/* ============= Project utilities (alerts, auth, dropdown) ============= */

/* Alerts */
.alert{
  padding:12px 16px;
  border-radius:10px;
  margin-bottom:18px;
  font-size:13.5px;
  display:flex;align-items:center;gap:10px;
  border:1px solid transparent;
}
.alert-error{
  color:var(--danger);
  background:var(--danger-soft);
  border-color:oklch(0.45 0.14 25 / 0.5);
}
.alert-success{
  color:var(--ok);
  background:var(--ok-soft);
  border-color:oklch(0.42 0.10 160 / 0.45);
}
.alert-info{
  color:var(--info);
  background:var(--info-soft);
  border-color:oklch(0.42 0.10 230 / 0.45);
}

/* Auth layout (login/register) — Phase 5.5 will refine */
.auth-layout{
  display:flex;align-items:center;justify-content:center;
  min-height:100vh;padding:24px;
}
.auth-card{
  width:100%;max-width:420px;
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:14px;
  padding:32px;
}
.auth-card header{margin-bottom:24px;text-align:center}
.auth-card h1{margin:0 0 6px;font-size:22px;font-weight:600;letter-spacing:-0.01em}
.auth-card header p{margin:0;color:var(--text-3);font-size:13.5px}
.auth-card form label{
  display:block;margin-bottom:14px;
  font-size:12.5px;font-weight:500;color:var(--text-2);
}
.auth-card form input{
  display:block;width:100%;margin-top:6px;
  height:40px;padding:0 12px;
  background:var(--bg-2);border:1px solid var(--line);
  color:var(--text);border-radius:10px;
  font:inherit;font-size:14px;outline:none;
  transition: border-color .15s, box-shadow .15s;
}
.auth-card form input:focus{
  border-color:var(--accent);
  box-shadow:0 0 0 3px oklch(0.78 0.20 128 / 0.22);
}
.auth-card form button[type=submit]{
  width:100%;height:42px;margin-top:6px;
  background:var(--accent);color:var(--accent-ink);
  border:0;border-radius:10px;
  font:inherit;font-size:14px;font-weight:600;
  cursor:pointer;
  box-shadow:0 1px 0 oklch(1 0 0 / 0.25) inset, 0 6px 18px oklch(0.65 0.20 128 / 0.25);
}
.auth-card form button[type=submit]:hover{background:var(--accent-2)}
.auth-card a{color:var(--accent-3);text-decoration:none}
.auth-card a:hover{text-decoration:underline}

/* Dropdown (used by navbar user menu) */
.dropdown{position:relative}
.dropdown-menu{
  position:absolute;right:0;top:42px;z-index:30;
  min-width:200px;
  background:var(--surface-2);
  border:1px solid var(--line-2);
  border-radius:10px;
  box-shadow:0 12px 30px oklch(0 0 0 / 0.4);
  padding:6px;
  display:none;
}
.dropdown-menu.open{display:block}
.dropdown-menu .dd-header{
  padding:8px 10px 6px;font-size:11px;
  color:var(--text-3);letter-spacing:.04em;
  text-transform:uppercase;
  border-bottom:1px solid var(--line);margin-bottom:4px;
}
.dropdown-menu form{margin:0}
.dropdown-menu button,
.dropdown-menu a{
  display:flex;align-items:center;gap:8px;
  width:100%;padding:8px 10px;border-radius:6px;
  background:transparent;border:0;
  color:var(--text-2);font:inherit;font-size:13px;
  cursor:pointer;text-decoration:none;text-align:left;
}
.dropdown-menu button:hover,
.dropdown-menu a:hover{background:var(--bg-2);color:var(--text)}
.dropdown-menu .danger{color:var(--danger)}
.dropdown-menu .danger:hover{background:oklch(0.30 0.08 25 / 0.18)}

/* Disable smaller  font in narrow context — keep design font-size */
body{font-size:14px}

/* ============= Project utilities (alerts, auth, dropdown) ============= */

/* Alerts */
.alert{
  padding:12px 16px;
  border-radius:10px;
  margin-bottom:18px;
  font-size:13.5px;
  display:flex;align-items:center;gap:10px;
  border:1px solid transparent;
}
.alert-error{
  color:var(--danger);
  background:var(--danger-soft);
  border-color:oklch(0.45 0.14 25 / 0.5);
}
.alert-success{
  color:var(--ok);
  background:var(--ok-soft);
  border-color:oklch(0.42 0.10 160 / 0.45);
}
.alert-info{
  color:var(--info);
  background:var(--info-soft);
  border-color:oklch(0.42 0.10 230 / 0.45);
}

/* Auth layout (login/register) — Phase 5.5 will refine */
.auth-layout{
  display:flex;align-items:center;justify-content:center;
  min-height:100vh;padding:24px;
}
.auth-card{
  width:100%;max-width:420px;
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:14px;
  padding:32px;
}
.auth-card header{margin-bottom:24px;text-align:center}
.auth-card h1{margin:0 0 6px;font-size:22px;font-weight:600;letter-spacing:-0.01em}
.auth-card header p{margin:0;color:var(--text-3);font-size:13.5px}
.auth-card form label{
  display:block;margin-bottom:14px;
  font-size:12.5px;font-weight:500;color:var(--text-2);
}
.auth-card form input{
  display:block;width:100%;margin-top:6px;
  height:40px;padding:0 12px;
  background:var(--bg-2);border:1px solid var(--line);
  color:var(--text);border-radius:10px;
  font:inherit;font-size:14px;outline:none;
  transition: border-color .15s, box-shadow .15s;
}
.auth-card form input:focus{
  border-color:var(--accent);
  box-shadow:0 0 0 3px oklch(0.78 0.20 128 / 0.22);
}
.auth-card form button[type=submit]{
  width:100%;height:42px;margin-top:6px;
  background:var(--accent);color:var(--accent-ink);
  border:0;border-radius:10px;
  font:inherit;font-size:14px;font-weight:600;
  cursor:pointer;
  box-shadow:0 1px 0 oklch(1 0 0 / 0.25) inset, 0 6px 18px oklch(0.65 0.20 128 / 0.25);
}
.auth-card form button[type=submit]:hover{background:var(--accent-2)}
.auth-card a{color:var(--accent-3);text-decoration:none}
.auth-card a:hover{text-decoration:underline}

/* Dropdown (used by navbar user menu) */
.dropdown{position:relative}
.dropdown-menu{
  position:absolute;right:0;top:42px;z-index:30;
  min-width:200px;
  background:var(--surface-2);
  border:1px solid var(--line-2);
  border-radius:10px;
  box-shadow:0 12px 30px oklch(0 0 0 / 0.4);
  padding:6px;
  display:none;
}
.dropdown-menu.open{display:block}
.dropdown-menu .dd-header{
  padding:8px 10px 6px;font-size:11px;
  color:var(--text-3);letter-spacing:.04em;
  text-transform:uppercase;
  border-bottom:1px solid var(--line);margin-bottom:4px;
}
.dropdown-menu form{margin:0}
.dropdown-menu button,
.dropdown-menu a{
  display:flex;align-items:center;gap:8px;
  width:100%;padding:8px 10px;border-radius:6px;
  background:transparent;border:0;
  color:var(--text-2);font:inherit;font-size:13px;
  cursor:pointer;text-decoration:none;text-align:left;
}
.dropdown-menu button:hover,
.dropdown-menu a:hover{background:var(--bg-2);color:var(--text)}
.dropdown-menu .danger{color:var(--danger)}
.dropdown-menu .danger:hover{background:oklch(0.30 0.08 25 / 0.18)}
