:root {
  --bg: #faf8f5;
  --surface: #ffffff;
  --ink: #1c1917;
  --muted: #78716c;
  --line: #ece8e1;
  --brand: #10b981;
  --brand-ink: #047857;
  --brand-soft: #d1fae5;
  --amber: #f59e0b;
  --radius: 20px;
  --radius-sm: 12px;
  --shadow: 0 6px 24px rgba(28, 25, 23, 0.08);
  --shadow-lg: 0 12px 40px rgba(28, 25, 23, 0.14);
  --safe-top: env(safe-area-inset-top, 0px);
  --safe-bottom: env(safe-area-inset-bottom, 0px);
}

* { box-sizing: border-box; -webkit-tap-highlight-color: transparent; }
html, body { margin: 0; padding: 0; }
body {
  font-family: 'Inter', system-ui, -apple-system, sans-serif;
  background: var(--bg);
  color: var(--ink);
  -webkit-font-smoothing: antialiased;
}
h1, h2, h3 { font-family: 'Fraunces', Georgia, serif; font-weight: 600; letter-spacing: -0.01em; margin: 0; }
button { font-family: inherit; cursor: pointer; border: none; background: none; color: inherit; }
img { display: block; }
a { color: var(--brand-ink); }

#app {
  max-width: 520px;
  margin: 0 auto;
  min-height: 100dvh;
  background: var(--bg);
  position: relative;
  box-shadow: 0 0 60px rgba(0,0,0,0.04);
}

/* ---------- App bar ---------- */
.appbar {
  position: sticky; top: 0; z-index: 30;
  padding: calc(var(--safe-top) + 14px) 18px 12px;
  display: flex; align-items: center; gap: 12px;
  background: color-mix(in srgb, var(--bg) 85%, transparent);
  backdrop-filter: saturate(1.4) blur(12px);
  border-bottom: 1px solid transparent;
}
.appbar.scrolled { border-bottom-color: var(--line); }
.appbar .title { flex: 1; min-width: 0; }
.appbar .title .eyebrow { font-size: 12px; color: var(--muted); font-weight: 600; text-transform: uppercase; letter-spacing: 0.08em; }
.appbar .title h1 { font-size: 24px; line-height: 1.1; }
.appbar .back { font-size: 22px; width: 38px; height: 38px; border-radius: 50%; display: grid; place-items: center; background: var(--surface); box-shadow: var(--shadow); }
.bell { position: relative; width: 42px; height: 42px; border-radius: 50%; display: grid; place-items: center; background: var(--surface); box-shadow: var(--shadow); font-size: 19px; }
.bell .badge { position: absolute; top: -2px; right: -2px; min-width: 18px; height: 18px; padding: 0 4px; border-radius: 9px; background: var(--amber); color: #fff; font-size: 11px; font-weight: 700; display: grid; place-items: center; border: 2px solid var(--bg); }

/* ---------- View ---------- */
.view { padding: 4px 18px 120px; }
.section-title { font-size: 19px; margin: 26px 2px 12px; }
.section-title:first-child { margin-top: 8px; }
.muted { color: var(--muted); }

/* ---------- Tab bar ---------- */
.tabbar {
  position: fixed; bottom: 0; left: 50%; transform: translateX(-50%);
  width: 100%; max-width: 520px; z-index: 40;
  display: flex; justify-content: space-around;
  padding: 8px 8px calc(8px + var(--safe-bottom));
  background: color-mix(in srgb, var(--surface) 92%, transparent);
  backdrop-filter: saturate(1.4) blur(14px);
  border-top: 1px solid var(--line);
}
.tabbar button { flex: 1; display: flex; flex-direction: column; align-items: center; gap: 3px; padding: 6px 0; color: var(--muted); font-size: 11px; font-weight: 600; border-radius: 12px; }
.tabbar button .ic { font-size: 21px; line-height: 1; filter: grayscale(1); opacity: .7; transition: .15s; }
.tabbar button.active { color: var(--brand-ink); }
.tabbar button.active .ic { filter: none; opacity: 1; transform: translateY(-1px); }

/* ---------- Buttons ---------- */
.btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; padding: 13px 18px; border-radius: 14px; font-weight: 600; font-size: 15px; background: var(--surface); box-shadow: var(--shadow); transition: transform .12s; }
.btn:active { transform: scale(0.97); }
.btn.primary { background: var(--brand); color: #fff; box-shadow: 0 8px 20px rgba(16,185,129,.35); }
.btn.ghost { background: transparent; box-shadow: none; border: 1px solid var(--line); }
.btn.block { width: 100%; }
.btn.sm { padding: 9px 14px; font-size: 14px; }

.chip { display: inline-flex; align-items: center; gap: 5px; padding: 5px 11px; border-radius: 999px; background: var(--surface); border: 1px solid var(--line); font-size: 12.5px; font-weight: 600; color: var(--muted); }
.chip.solid { background: var(--brand-soft); color: var(--brand-ink); border-color: transparent; }

/* ---------- Hero card (this week) ---------- */
.hero {
  position: relative; border-radius: var(--radius); overflow: hidden;
  background: var(--ink); color: #fff; box-shadow: var(--shadow-lg);
  min-height: 188px; display: flex; flex-direction: column; justify-content: flex-end;
}
.hero .collage { position: absolute; inset: 0; display: grid; opacity: .9; }
.hero .collage img { width: 100%; height: 100%; object-fit: cover; }
.hero .grad { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(0,0,0,0) 20%, rgba(0,0,0,.78) 100%); }
.hero .inner { position: relative; padding: 18px; }
.hero .eyebrow { font-size: 12px; font-weight: 600; opacity: .85; text-transform: uppercase; letter-spacing: .08em; }
.hero h2 { font-size: 26px; margin-top: 2px; color: #fff; }
.hero .row { display: flex; align-items: center; gap: 10px; margin-top: 12px; }
.hero .progress { flex: 1; height: 7px; border-radius: 4px; background: rgba(255,255,255,.25); overflow: hidden; }
.hero .progress > span { display: block; height: 100%; background: var(--brand); border-radius: 4px; transition: width .3s; }

/* ---------- Recipe grid + cards ---------- */
.grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.rcard {
  position: relative; border-radius: var(--radius-sm); overflow: hidden;
  background: var(--surface); box-shadow: var(--shadow); transition: transform .12s;
  display: flex; flex-direction: column;
}
.rcard:active { transform: scale(0.98); }
.rcard .imgwrap { position: relative; aspect-ratio: 4/3; background: var(--line); }
.rcard .imgwrap img { width: 100%; height: 100%; object-fit: cover; }
.rcard .time { position: absolute; left: 8px; top: 8px; background: rgba(0,0,0,.6); color: #fff; font-size: 11px; font-weight: 600; padding: 3px 8px; border-radius: 999px; backdrop-filter: blur(4px); }
.rcard .pick {
  position: absolute; right: 8px; top: 8px; width: 30px; height: 30px; border-radius: 50%;
  background: rgba(255,255,255,.92); display: grid; place-items: center; box-shadow: var(--shadow);
  font-size: 15px; color: var(--muted); transition: .15s;
}
.rcard.selected { outline: 3px solid var(--brand); outline-offset: -3px; }
.rcard.selected .pick { background: var(--brand); color: #fff; transform: scale(1.05); }
.rcard .body { padding: 10px 11px 12px; }
.rcard .name { font-size: 13.5px; font-weight: 600; line-height: 1.25; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.rcard .sub { font-size: 11.5px; color: var(--muted); margin-top: 3px; display: -webkit-box; -webkit-line-clamp: 1; -webkit-box-orient: vertical; overflow: hidden; }

/* full-width list card */
.lcard { display: flex; gap: 12px; background: var(--surface); border-radius: var(--radius-sm); box-shadow: var(--shadow); overflow: hidden; align-items: stretch; }
.lcard img { width: 96px; min-width: 96px; object-fit: cover; background: var(--line); }
.lcard .body { padding: 11px 12px; flex: 1; min-width: 0; display: flex; flex-direction: column; justify-content: center; }
.lcard .name { font-weight: 600; font-size: 15px; line-height: 1.2; }
.lcard .sub { font-size: 12.5px; color: var(--muted); margin-top: 4px; }

/* ---------- Stepper ---------- */
.stepper { display: inline-flex; align-items: center; background: var(--surface); border-radius: 999px; box-shadow: var(--shadow); padding: 3px; }
.stepper button { width: 34px; height: 34px; border-radius: 50%; font-size: 20px; font-weight: 600; display: grid; place-items: center; color: var(--brand-ink); }
.stepper .val { min-width: 30px; text-align: center; font-weight: 700; }

/* ---------- Sticky action bar ---------- */
.actionbar {
  position: fixed; bottom: calc(64px + var(--safe-bottom)); left: 50%; transform: translateX(-50%);
  width: calc(100% - 36px); max-width: 484px; z-index: 35;
}
.actionbar .btn { box-shadow: var(--shadow-lg); }

/* ---------- Recipe detail ---------- */
.detail-hero { position: relative; margin: -4px -18px 0; }
.detail-hero img { width: 100%; aspect-ratio: 16/11; object-fit: cover; }
.detail-hero .grad { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(0,0,0,.25), rgba(0,0,0,0) 35%, rgba(250,248,245,1) 100%); }
.detail-head { margin-top: -38px; position: relative; }
.detail-head h1 { font-size: 27px; line-height: 1.08; }
.detail-head .headline { color: var(--muted); margin-top: 6px; font-size: 14.5px; }
.meta-row { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 14px; }
.ing { display: flex; align-items: center; gap: 12px; padding: 9px 0; border-bottom: 1px solid var(--line); }
.ing img { width: 40px; height: 40px; border-radius: 10px; object-fit: cover; background: var(--line); }
.ing .nm { flex: 1; font-size: 14.5px; font-weight: 500; }
.ing .amt { font-weight: 700; font-size: 14px; color: var(--brand-ink); white-space: nowrap; }
.ing.pantry .amt { color: var(--muted); }
.step { display: flex; gap: 14px; padding: 12px 0; border-bottom: 1px solid var(--line); }
.step .n { min-width: 28px; height: 28px; border-radius: 50%; background: var(--brand-soft); color: var(--brand-ink); font-weight: 700; display: grid; place-items: center; font-size: 14px; }
.step p { margin: 2px 0 0; font-size: 14.5px; line-height: 1.5; }

/* ---------- Shopping list ---------- */
.cat { margin-top: 22px; }
.cat h3 { font-size: 15px; font-family: 'Inter', sans-serif; font-weight: 700; color: var(--brand-ink); text-transform: uppercase; letter-spacing: .05em; font-size: 12.5px; margin-bottom: 4px; }
.sitem { display: flex; align-items: center; gap: 12px; padding: 11px 0; border-bottom: 1px solid var(--line); }
.sitem .check { width: 24px; height: 24px; border-radius: 7px; border: 2px solid var(--line); display: grid; place-items: center; color: #fff; font-size: 14px; transition: .12s; flex: none; }
.sitem.done .check { background: var(--brand); border-color: var(--brand); }
.sitem.done .nm { text-decoration: line-through; color: var(--muted); }
.sitem .nm { flex: 1; font-size: 14.5px; font-weight: 500; }
.sitem .amt { font-weight: 700; font-size: 13.5px; color: var(--muted); white-space: nowrap; }
.sitem img { width: 34px; height: 34px; border-radius: 8px; object-fit: cover; background: var(--line); flex: none; }

/* ---------- Inbox ---------- */
.msg { display: flex; gap: 12px; padding: 14px; background: var(--surface); border-radius: var(--radius-sm); box-shadow: var(--shadow); margin-bottom: 10px; }
.msg.unread { border-left: 3px solid var(--amber); }
.msg .ic { font-size: 22px; }
.msg .t { font-weight: 600; font-size: 15px; }
.msg .b { font-size: 13.5px; color: var(--muted); margin-top: 3px; line-height: 1.45; }
.msg .when { font-size: 11.5px; color: var(--muted); margin-top: 6px; }

/* ---------- Module tiles (dashboard) ---------- */
.tiles { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.tile { background: var(--surface); border-radius: var(--radius-sm); box-shadow: var(--shadow); padding: 16px; display: flex; flex-direction: column; gap: 8px; min-height: 110px; transition: transform .12s; }
.tile:active { transform: scale(.97); }
.tile .ic { font-size: 28px; }
.tile .t { font-weight: 700; font-size: 15px; }
.tile .d { font-size: 12px; color: var(--muted); line-height: 1.35; }
.tile .accent { width: 28px; height: 4px; border-radius: 2px; margin-top: auto; }

/* ---------- Misc ---------- */
.empty { text-align: center; color: var(--muted); padding: 48px 24px; }
.empty .big { font-size: 44px; margin-bottom: 12px; }
.skeleton { background: linear-gradient(90deg, var(--line) 25%, #f4f1ec 50%, var(--line) 75%); background-size: 200% 100%; animation: sk 1.3s infinite; border-radius: var(--radius-sm); }
@keyframes sk { to { background-position: -200% 0; } }
.toast { position: fixed; bottom: calc(80px + var(--safe-bottom)); left: 50%; transform: translateX(-50%); background: var(--ink); color: #fff; padding: 11px 18px; border-radius: 999px; font-size: 13.5px; font-weight: 600; z-index: 60; box-shadow: var(--shadow-lg); animation: pop .2s; }
@keyframes pop { from { transform: translate(-50%, 8px); opacity: 0; } }
.spin { display: inline-block; width: 16px; height: 16px; border: 2px solid rgba(255,255,255,.4); border-top-color: #fff; border-radius: 50%; animation: rot .7s linear infinite; }
@keyframes rot { to { transform: rotate(360deg); } }
.fade { animation: fade .25s ease; }
@keyframes fade { from { opacity: 0; transform: translateY(6px); } }

/* ---------- Recommendation rows (Ontdek) ---------- */
.weather-strip { display: flex; align-items: center; justify-content: space-between; gap: 10px; font-size: 13.5px; font-weight: 600; color: var(--muted); margin: 4px 2px 6px; }
.row-section { margin-top: 22px; }
.row-head h2 { font-size: 19px; }
.row-head { margin: 0 2px 10px; }
.hscroll { display: flex; gap: 12px; overflow-x: auto; scroll-snap-type: x proximity; padding: 2px 2px 8px; margin: 0 -18px; padding-left: 18px; padding-right: 18px; scrollbar-width: none; }
.hscroll::-webkit-scrollbar { display: none; }
.scard { min-width: 148px; width: 148px; scroll-snap-align: start; }
.scard .imgwrap { position: relative; aspect-ratio: 4/3; border-radius: var(--radius-sm); overflow: hidden; background: var(--line); box-shadow: var(--shadow); }
.scard .imgwrap img { width: 100%; height: 100%; object-fit: cover; }
.scard .time { position: absolute; left: 7px; bottom: 7px; background: rgba(0,0,0,.6); color: #fff; font-size: 10.5px; font-weight: 600; padding: 2px 7px; border-radius: 999px; }
.scard .name { font-size: 12.5px; font-weight: 600; line-height: 1.25; margin-top: 7px; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }

/* ---------- Favorite star ---------- */
.star { position: absolute; right: 7px; top: 7px; width: 30px; height: 30px; border-radius: 50%; background: rgba(255,255,255,.92); box-shadow: var(--shadow); display: grid; place-items: center; font-size: 16px; color: var(--muted); transition: .15s; z-index: 2; }
.star.on { color: var(--amber); }
.star.big { width: 42px; height: 42px; font-size: 22px; top: auto; bottom: 14px; right: 14px; position: absolute; }
.star.list { position: static; align-self: center; margin-right: 10px; flex: none; }

/* ---------- Recipe detail extras ---------- */
.serv-row { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-top: 18px; padding: 13px 15px; background: var(--surface); border-radius: var(--radius-sm); box-shadow: var(--shadow); }
.stepper button:disabled { opacity: .3; }
.steps-head { display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.steps-head .section-title { margin-bottom: 0; }
.step { cursor: pointer; }
.step .step-body { flex: 1; min-width: 0; }
.step .step-text p { margin: 2px 0 6px; font-size: 14.5px; line-height: 1.55; }
.step .step-text p:last-child { margin-bottom: 0; }
.steps.cookmode .step-text p { font-size: 16.5px; line-height: 1.6; }
.step.done { opacity: .45; }
.step.done .n { background: var(--brand); color: #fff; }
.qty { display: inline-block; background: var(--brand-soft); color: var(--brand-ink); font-weight: 700; font-size: 12px; border-radius: 7px; padding: 0 6px; margin-left: 5px; white-space: nowrap; }
.timer-row { display: flex; gap: 8px; flex-wrap: wrap; margin: 8px 0 4px; }
.timerbtn { display: inline-flex; align-items: center; gap: 5px; padding: 7px 13px; border-radius: 999px; background: var(--ink); color: #fff; font-size: 13px; font-weight: 600; box-shadow: var(--shadow); }
.timerbtn:active { transform: scale(.96); }
.nutri { margin-top: 22px; }
.nutri summary { cursor: pointer; list-style: none; }
.nutri summary::-webkit-details-marker { display: none; }
.nutri summary::after { content: '▾'; margin-left: 8px; color: var(--muted); }
.nutri[open] summary::after { content: '▴'; }
.nutri-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 6px 18px; margin-top: 12px; }
.nrow { display: flex; justify-content: space-between; font-size: 13px; padding: 5px 0; border-bottom: 1px solid var(--line); }

/* ---------- Timer bar ---------- */
.timerbar { position: fixed; bottom: calc(72px + var(--safe-bottom)); left: 50%; transform: translateX(-50%); width: calc(100% - 24px); max-width: 496px; z-index: 45; display: flex; gap: 8px; overflow-x: auto; scrollbar-width: none; padding: 4px; }
.timer-chip { display: inline-flex; align-items: center; gap: 8px; padding: 9px 14px; border-radius: 999px; background: var(--ink); color: #fff; font-size: 13px; font-weight: 600; box-shadow: var(--shadow-lg); white-space: nowrap; }
.timer-chip .tt { font-variant-numeric: tabular-nums; color: #6ee7b7; }
.timer-chip.done { background: var(--brand); animation: pulse 1s infinite; }
.timer-chip.done .tt { color: #fff; }
@keyframes pulse { 50% { transform: scale(1.04); } }

/* ---------- Delhaize products ---------- */
.prod { display: flex; align-items: center; gap: 12px; padding: 10px 4px; border-bottom: 1px solid var(--line); cursor: pointer; border-radius: 10px; }
.prod:active { background: var(--brand-soft); }
.prod img, .prod .noimg { width: 52px; height: 52px; border-radius: 10px; object-fit: contain; background: #fff; border: 1px solid var(--line); flex: none; display: grid; place-items: center; font-size: 22px; }
.prod .pbody { flex: 1; min-width: 0; }
.prod .pname { font-size: 14px; font-weight: 600; line-height: 1.25; }
.prod .pmeta { display: flex; align-items: baseline; gap: 8px; margin-top: 3px; }
.prod .pprice { font-weight: 700; font-size: 14px; color: var(--brand-ink); }
.prod .punit { font-size: 11.5px; color: var(--muted); }
.prod.chosen { background: var(--brand-soft); }
.prod .pcheck { color: var(--brand-ink); font-weight: 800; font-size: 18px; }
.prod.unavailable { opacity: .5; }
.addbtn { width: 36px; height: 36px; border-radius: 50%; background: var(--brand); color: #fff; font-size: 20px; font-weight: 700; display: grid; place-items: center; box-shadow: var(--shadow); flex: none; }
.dlz-mini { display: flex; align-items: center; gap: 7px; margin-top: 5px; padding: 4px 9px 4px 4px; background: var(--bg); border: 1px solid var(--line); border-radius: 999px; font-size: 12px; max-width: 100%; }
.dlz-mini img { width: 24px; height: 24px; border-radius: 6px; object-fit: contain; background: #fff; }
.dlz-mini .dn { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; font-weight: 600; }
.dlz-mini .dp { color: var(--brand-ink); font-weight: 700; flex: none; }
.dlz-pick { margin-top: 5px; font-size: 12px; font-weight: 600; color: var(--brand-ink); padding: 0; }
.linkbtn { font-size: 12px; font-weight: 600; color: var(--brand-ink); padding: 0; text-decoration: underline; text-underline-offset: 2px; }

/* ---------- Bottom sheet ---------- */
.sheet-wrap { position: fixed; inset: 0; z-index: 70; }
.sheet-backdrop { position: absolute; inset: 0; background: rgba(28,25,23,.45); animation: fadeIn .18s; }
.sheet { position: absolute; bottom: 0; left: 50%; transform: translateX(-50%); width: 100%; max-width: 520px; max-height: 82dvh; background: var(--bg); border-radius: 22px 22px 0 0; display: flex; flex-direction: column; animation: slideUp .22s ease; }
.sheet-wrap.closing .sheet { animation: slideDown .18s ease forwards; }
.sheet-wrap.closing .sheet-backdrop { animation: fadeOut .18s forwards; }
.sheet-handle { width: 40px; height: 4px; border-radius: 2px; background: var(--line); margin: 10px auto 0; }
.sheet-head { display: flex; align-items: center; justify-content: space-between; padding: 10px 18px 4px; }
.sheet-head h2 { font-size: 19px; }
.sheet-close { width: 32px; height: 32px; border-radius: 50%; background: var(--surface); box-shadow: var(--shadow); font-size: 14px; }
.sheet-body { padding: 8px 18px calc(18px + var(--safe-bottom)); overflow-y: auto; }
.sheet-search input { width: 100%; padding: 12px 15px; border-radius: 12px; border: 1px solid var(--line); background: var(--surface); font-size: 15px; }
@keyframes slideUp { from { transform: translate(-50%, 60%); } }
@keyframes slideDown { to { transform: translate(-50%, 100%); } }
@keyframes fadeIn { from { opacity: 0; } }
@keyframes fadeOut { to { opacity: 0; } }

/* ---------- Shopping list v2 ---------- */
.inc-row { display: flex; gap: 8px; overflow-x: auto; scrollbar-width: none; padding: 8px 2px 4px; margin: 4px -18px 0; padding-left: 18px; padding-right: 18px; }
.inc-chip { display: flex; align-items: center; gap: 7px; padding: 5px 12px 5px 5px; border-radius: 999px; background: var(--surface); border: 2px solid var(--line); font-size: 12px; font-weight: 600; white-space: nowrap; opacity: .55; transition: .15s; }
.inc-chip img { width: 26px; height: 26px; border-radius: 50%; object-fit: cover; }
.inc-chip.on { border-color: var(--brand); opacity: 1; }
.sitem .nm .for-ing { font-size: 11.5px; color: var(--muted); font-weight: 500; margin-top: 2px; }
.sitem img { width: 42px; height: 42px; border-radius: 9px; object-fit: contain; background: #fff; border: 1px solid var(--line); }
.pcol { display: flex; flex-direction: column; align-items: flex-end; gap: 4px; }
.pcol .pprice { font-weight: 700; font-size: 13.5px; color: var(--brand-ink); white-space: nowrap; }
.qtyctl { display: inline-flex; align-items: center; gap: 2px; background: var(--bg); border: 1px solid var(--line); border-radius: 999px; }
.qtyctl button { width: 26px; height: 26px; font-size: 15px; font-weight: 700; color: var(--brand-ink); display: grid; place-items: center; }
.qtyctl span { min-width: 16px; text-align: center; font-size: 13px; font-weight: 700; }

/* ---------- Auth ---------- */
body.no-tabs .tabbar { display: none; }
.auth-card { max-width: 360px; margin: 8dvh auto 0; background: var(--surface); border-radius: var(--radius); box-shadow: var(--shadow-lg); padding: 28px 24px; }
.auth-logo { font-size: 44px; text-align: center; margin-bottom: 8px; }
.inp { width: 100%; padding: 13px 15px; border-radius: 12px; border: 1px solid var(--line); background: var(--bg); font-size: 15px; margin-bottom: 10px; font-family: inherit; }
.inp:focus { outline: 2px solid var(--brand); border-color: transparent; }
.auth-err { background: #fef2f2; color: #b91c1c; font-size: 13px; font-weight: 600; border-radius: 10px; padding: 10px 13px; margin-bottom: 10px; }
.acct { display: flex; align-items: center; gap: 12px; background: var(--surface); border-radius: var(--radius-sm); box-shadow: var(--shadow); padding: 14px; }
.acct .avatar { width: 42px; height: 42px; border-radius: 50%; background: var(--brand-soft); color: var(--brand-ink); font-weight: 800; display: grid; place-items: center; font-size: 17px; }

.actionbar.split { display: flex; gap: 10px; }
