/* =============================================================
   comp-library-phone/style.css
   Johnson Appraisal — Phone Companion Page (Prompt 4c)

   Palette:   warm parchment · deep forest green · aged gold
   Display:   Playfair Display 600/700  (property addresses)
   UI:        Jost 300/400/500/600      (labels, prices, meta)
   ============================================================= */

/* ── Design tokens ──────────────────────────────────────────── */
:root {
  --paper:      #f2eddb;       /* warm parchment — main background */
  --paper-2:    #ece4c6;       /* slightly richer — card surfaces  */
  --paper-3:    #e5dbb8;       /* input backgrounds, tray          */
  --ink:        #18211e;       /* near-black with green undertone  */
  --ink-soft:   #566560;       /* secondary labels                 */
  --ink-ghost:  #8fa199;       /* placeholders, timestamps         */
  --field:      #2f5d50;       /* deep green — primary actions     */
  --field-dk:   #1e3d34;       /* pressed / hover                  */
  --field-lt:   #d2e9e3;       /* light green tint                 */
  --field-ml:   #a7cfc6;       /* medium-light green               */
  --gold:       #b5872a;       /* aged gold — stars, pins, FAB     */
  --gold-dk:    #8c6620;       /* deeper gold                      */
  --gold-lt:    #f6efdc;       /* very light gold surface          */
  --line:       #cec5a2;       /* borders                          */
  --line-soft:  #ddd5bb;       /* subtle dividers                  */
  --danger:     #7d2b2b;       /* warm muted red                   */
  --white:      #ffffff;

  --hdr-h:     56px;           /* header height */
  --nav-h:     62px;           /* bottom nav height */
  --fab-sz:    56px;
  --safe-t:    env(safe-area-inset-top,    0px);
  --safe-b:    env(safe-area-inset-bottom, 0px);
  --safe-l:    env(safe-area-inset-left,   0px);
  --safe-r:    env(safe-area-inset-right,  0px);

  --r:         10px;            /* standard border-radius */
  --r-sm:       6px;
  --r-lg:      18px;
  --r-pill:    100px;

  --shadow-xs: 0 1px 2px rgba(24,33,30,.06), 0 2px 8px rgba(24,33,30,.05);
  --shadow-sm: 0 2px 6px rgba(24,33,30,.08), 0 6px 18px rgba(24,33,30,.06);
  --shadow-md: 0 6px 20px rgba(24,33,30,.12), 0 16px 40px rgba(24,33,30,.08);
  --shadow-lg: 0 16px 48px rgba(24,33,30,.18), 0 32px 80px rgba(24,33,30,.12);

  --ease:      cubic-bezier(.4, 0, .2, 1);
  --spring:    cubic-bezier(.34, 1.56, .64, 1);
  --fast:      .14s;
  --normal:    .24s;
  --slow:      .36s;
}

/* ── Reset ──────────────────────────────────────────────────── */
*, *::before, *::after {
  box-sizing: border-box; margin: 0; padding: 0;
  -webkit-tap-highlight-color: transparent;
}
html { height: 100%; }
body {
  height: 100%; min-height: 100dvh;
  font-family: 'Jost', 'Helvetica Neue', Arial, sans-serif;
  font-size: 16px; color: var(--ink);
  background: var(--paper);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow: hidden;           /* views scroll internally */
  /* subtle atmospheric gradients — won't compete with content */
  background-image:
    radial-gradient(ellipse at 15% 8%,  rgba(47,93,80,.045), transparent 48%),
    radial-gradient(ellipse at 85% 92%, rgba(181,135,42,.04), transparent 48%);
}

/* Paper grain texture — very subtle, adds physicality */
body::after {
  content: '';
  position: fixed; inset: 0;
  pointer-events: none; z-index: 9999;
  opacity: .022;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='320' height='320'%3E%3Cfilter id='g'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.72' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='320' height='320' filter='url(%23g)'/%3E%3C/svg%3E");
  background-size: 180px 180px;
}

/* ── Header ─────────────────────────────────────────────────── */
#header {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 30;
  height: calc(var(--hdr-h) + var(--safe-t));
  background: var(--field);
  display: flex; align-items: flex-end;
  justify-content: space-between;
  padding-bottom: 10px;
  padding-left: max(18px, var(--safe-l));
  padding-right: max(18px, var(--safe-r));
  box-shadow: 0 1px 0 rgba(0,0,0,.15);
}

.wordmark { display: flex; flex-direction: column; gap: 2px; }

.wm-firm {
  font-family: 'Playfair Display', Georgia, serif;
  font-size: 18px; font-weight: 700;
  color: #fff; letter-spacing: .15px; line-height: 1;
}

.wm-sub {
  font-family: 'Jost', sans-serif;
  font-size: 10px; font-weight: 500;
  letter-spacing: 2.2px; text-transform: uppercase;
  color: rgba(255,255,255,.5); line-height: 1;
}

.status-dot {
  width: 9px; height: 9px; border-radius: 50%;
  background: rgba(255,255,255,.2);
  transition: background var(--normal) var(--ease),
              box-shadow  var(--normal) var(--ease);
  margin-bottom: 2px;
}
.status-dot.online  {
  background: #7ed4a0;
  box-shadow: 0 0 0 3px rgba(126,212,160,.2);
}
.status-dot.offline {
  background: #e87676;
  box-shadow: 0 0 0 3px rgba(232,118,118,.2);
}

/* ── App shell ──────────────────────────────────────────────── */
#app {
  position: fixed;
  top: calc(var(--hdr-h) + var(--safe-t));
  bottom: calc(var(--nav-h) + var(--safe-b));
  left: 0; right: 0;
  overflow: hidden;
}

/* ── Views ──────────────────────────────────────────────────── */
.view {
  position: absolute; inset: 0;
  overflow-y: auto; overflow-x: hidden;
  -webkit-overflow-scrolling: touch;
  transition:
    opacity   var(--normal) var(--ease),
    transform var(--normal) var(--ease);
}
.view.hidden {
  opacity: 0; pointer-events: none;
  transform: translateY(10px);
}

/* ── Search + filter zone (green, sticky in #view-comps) ────── */
.search-zone {
  position: sticky; top: 0; z-index: 10;
  background: var(--field);
  padding: 10px 14px 0;
  box-shadow: 0 4px 12px rgba(24,33,30,.18);
}

.search-row { margin-bottom: 8px; }

.search-wrap {
  position: relative; display: flex; align-items: center;
}

.search-icon {
  position: absolute; left: 12px; pointer-events: none;
  display: flex; align-items: center; color: var(--ink-soft);
}
.search-icon svg { width: 18px; height: 18px; }

#search {
  width: 100%;
  padding: 10px 14px 10px 38px;
  background: var(--paper);
  border: 1.5px solid transparent;
  border-radius: var(--r);
  font-family: 'Jost', sans-serif;
  font-size: 15px; color: var(--ink);
  outline: none;
  transition: border-color var(--fast) var(--ease),
              box-shadow   var(--fast) var(--ease);
  -webkit-appearance: none; appearance: none;
}
#search::placeholder  { color: var(--ink-ghost); }
#search:focus {
  border-color: var(--field-ml);
  box-shadow: 0 0 0 3px rgba(47,93,80,.15);
}
#search::-webkit-search-cancel-button { display: none; }

/* ── Filter chip rows ───────────────────────────────────────── */
.filter-scroll {
  display: flex; gap: 6px;
  overflow-x: auto; overflow-y: hidden;
  padding: 0 0 10px;
  scrollbar-width: none; -ms-overflow-style: none;
}
.filter-scroll::-webkit-scrollbar { display: none; }

.fchip {
  flex-shrink: 0;
  padding: 5px 13px;
  border-radius: var(--r-pill);
  font-family: 'Jost', sans-serif;
  font-size: 12.5px; font-weight: 500; letter-spacing: .15px;
  white-space: nowrap;
  border: 1.5px solid rgba(255,255,255,.22);
  background: rgba(255,255,255,.1);
  color: rgba(255,255,255,.7);
  cursor: pointer;
  transition: background var(--fast) var(--ease),
              color      var(--fast) var(--ease),
              border-color var(--fast) var(--ease),
              transform  var(--fast) var(--ease);
}
.fchip.active {
  background: #fff; color: var(--field);
  border-color: #fff; font-weight: 600;
}
.fchip:active { transform: scale(.94); }

/* ── Result count bar ───────────────────────────────────────── */
.result-bar {
  padding: 10px 18px 4px;
  font-family: 'Jost', sans-serif;
  font-size: 11px; font-weight: 500;
  letter-spacing: .8px; text-transform: uppercase;
  color: var(--ink-soft);
  min-height: 30px;
}

/* ── Comp cards ─────────────────────────────────────────────── */
.comp-list {
  padding: 4px 14px 16px;
  display: flex; flex-direction: column; gap: 8px;
}

.comp-card {
  background: var(--white);
  border: 1px solid var(--line-soft);
  border-radius: var(--r);
  padding: 14px 14px 12px;
  box-shadow: var(--shadow-xs);
  display: grid;
  grid-template-columns: 1fr 44px;
  gap: 0 4px;
  align-items: start;
  transition: box-shadow var(--fast) var(--ease),
              border-color var(--fast) var(--ease);
}
.comp-card.is-starred {
  border-color: rgba(181,135,42,.35);
  background: #fffdf8;
}

.comp-body { min-width: 0; }

.comp-addr {
  font-family: 'Playfair Display', Georgia, serif;
  font-size: 15.5px; font-weight: 600; line-height: 1.25;
  color: var(--ink);
  overflow: hidden; text-overflow: ellipsis;
  display: -webkit-box; -webkit-box-orient: vertical; -webkit-line-clamp: 2;
}

.comp-nick {
  font-family: 'Jost', sans-serif;
  font-size: 12px; font-weight: 400; letter-spacing: .1px;
  color: var(--gold); margin-top: 3px;
}

.comp-stats {
  display: flex; flex-wrap: wrap; align-items: center;
  gap: 6px; margin-top: 9px;
}

.stat-price {
  font-family: 'Jost', sans-serif;
  font-size: 15px; font-weight: 600; color: var(--ink);
}
.stat-sf {
  font-family: 'Jost', sans-serif;
  font-size: 12.5px; color: var(--ink-soft);
}
.stat-psf {
  font-family: 'Jost', sans-serif;
  font-size: 12px; font-weight: 600;
  color: var(--field);
  background: var(--field-lt);
  padding: 2px 9px;
  border-radius: var(--r-pill);
}

.comp-meta {
  display: flex; flex-wrap: wrap; gap: 6px; align-items: center;
  margin-top: 7px;
}
.comp-date {
  font-family: 'Jost', sans-serif;
  font-size: 11.5px; color: var(--ink-ghost);
}
.comp-type {
  font-family: 'Jost', sans-serif;
  font-size: 10.5px; font-weight: 500; letter-spacing: .4px;
  padding: 2px 8px; border-radius: 4px;
  background: var(--gold-lt); color: var(--gold-dk);
}
.comp-used {
  font-family: 'Jost', sans-serif;
  font-size: 11px; font-style: italic; color: var(--ink-ghost);
  margin-top: 3px;
}

/* ── Star button ────────────────────────────────────────────── */
.star-btn {
  width: 44px; height: 44px;
  border: none; background: none; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  border-radius: 50%;
  position: relative;
  align-self: start; margin-top: -2px; margin-right: -4px;
}

.star-btn svg { width: 26px; height: 26px; }

.star-btn polygon {
  fill: none; stroke: var(--line); stroke-width: 1.8;
  transition: fill var(--normal) var(--ease),
              stroke var(--normal) var(--ease);
}

.star-btn.is-starred polygon {
  fill: var(--gold); stroke: var(--gold);
}

@keyframes star-pop {
  0%   { transform: scale(1); }
  35%  { transform: scale(1.5); }
  65%  { transform: scale(.85); }
  100% { transform: scale(1); }
}
.star-btn.popping svg { animation: star-pop var(--slow) var(--spring); }

.star-btn::after {
  content: ''; position: absolute; inset: 0;
  border-radius: 50%;
  background: var(--gold);
  opacity: 0; transform: scale(.6);
  transition: opacity .28s, transform .28s;
  pointer-events: none;
}
.star-btn.rippling::after {
  opacity: .14; transform: scale(1.7);
}

/* ── Placeholder / loading / empty states ───────────────────── */
.placeholder-msg {
  font-family: 'Jost', sans-serif;
  font-size: 14px; font-style: italic;
  color: var(--ink-soft); line-height: 1.6;
  text-align: center;
  padding: 44px 24px;
}
.placeholder-msg strong { font-style: normal; color: var(--ink); }

/* ── View headers (starred, pins, setup) ────────────────────── */
.view-head {
  padding: 20px 18px 12px;
  border-bottom: 1px solid var(--line-soft);
  margin-bottom: 10px;
}
.view-title {
  font-family: 'Playfair Display', Georgia, serif;
  font-size: 22px; font-weight: 700; color: var(--ink);
}
.view-sub {
  font-family: 'Jost', sans-serif;
  font-size: 13px; color: var(--ink-soft);
  margin-top: 3px; line-height: 1.5;
}

/* ── Pin cards (spotted sales) ──────────────────────────────── */
.pin-card {
  background: var(--white);
  border: 1px solid var(--line-soft);
  border-left: 4px solid var(--gold);
  border-radius: var(--r);
  padding: 14px 16px 12px;
  margin: 0 14px 8px;
  box-shadow: var(--shadow-xs);
}
.pin-label {
  font-family: 'Playfair Display', Georgia, serif;
  font-size: 15px; font-weight: 600; color: var(--ink);
}
.pin-city {
  font-family: 'Jost', sans-serif;
  font-size: 12px; color: var(--gold); margin-top: 2px;
}
.pin-note {
  font-family: 'Jost', sans-serif;
  font-size: 13px; color: var(--ink-soft);
  margin-top: 6px; line-height: 1.55;
}
.pin-when {
  font-family: 'Jost', sans-serif;
  font-size: 11px; color: var(--ink-ghost); margin-top: 6px;
}
.pin-actions {
  display: flex; gap: 8px;
  margin-top: 10px; padding-top: 10px;
  border-top: 1px solid var(--line-soft);
}
.pin-resolve {
  flex: 1; padding: 9px 12px;
  border: 1.5px solid var(--field-ml);
  background: var(--field-lt); color: var(--field);
  border-radius: var(--r-sm);
  font-family: 'Jost', sans-serif;
  font-size: 13px; font-weight: 500; cursor: pointer;
  transition: background var(--fast) var(--ease);
}
.pin-resolve:active { background: var(--field-ml); }

/* ── Setup ──────────────────────────────────────────────────── */
.setup-card {
  margin: 0 14px 12px;
  background: var(--white);
  border: 1px solid var(--line-soft);
  border-radius: var(--r);
  padding: 18px;
  box-shadow: var(--shadow-xs);
}
.setup-field { margin-bottom: 16px; }
.setup-label {
  display: block;
  font-family: 'Jost', sans-serif;
  font-size: 11px; font-weight: 600;
  letter-spacing: 1px; text-transform: uppercase;
  color: var(--ink-soft); margin-bottom: 6px;
}
.setup-field input {
  width: 100%;
  padding: 11px 13px;
  background: var(--paper);
  border: 1.5px solid var(--line);
  border-radius: var(--r-sm);
  font-family: 'Jost', sans-serif;
  font-size: 14px; color: var(--ink);
  outline: none;
  transition: border-color var(--fast) var(--ease);
}
.setup-field input:focus { border-color: var(--field); }
.setup-hint {
  display: block;
  font-family: 'Jost', sans-serif;
  font-size: 12px; color: var(--ink-ghost);
  margin-top: 5px; line-height: 1.5;
}
.setup-hint code {
  font-family: 'SFMono-Regular', 'Consolas', monospace;
  font-size: 11px; background: var(--paper-2);
  padding: 1px 5px; border-radius: 3px; color: var(--field-dk);
}
.setup-warning {
  display: flex; gap: 10px; align-items: flex-start;
  margin-top: 16px; padding: 12px 13px;
  background: rgba(181,135,42,.08);
  border: 1px solid rgba(181,135,42,.28);
  border-radius: var(--r-sm);
}
.setup-warn-icon { font-size: 15px; flex-shrink: 0; margin-top: 1px; }
.setup-warning p {
  font-family: 'Jost', sans-serif;
  font-size: 12px; color: var(--ink-soft); line-height: 1.6;
}
.setup-warning code {
  font-family: 'SFMono-Regular', 'Consolas', monospace;
  font-size: 11px; background: var(--paper-2);
  padding: 1px 5px; border-radius: 3px; color: var(--field-dk);
}

/* ── Buttons ────────────────────────────────────────────────── */
.btn-primary {
  display: block; width: 100%;
  padding: 14px 20px;
  background: var(--field); color: #fff;
  border: none; border-radius: var(--r-sm);
  font-family: 'Jost', sans-serif;
  font-size: 15px; font-weight: 600; letter-spacing: .2px;
  cursor: pointer; text-align: center;
  transition: background var(--fast) var(--ease),
              transform  var(--fast) var(--ease);
}
.btn-primary:active { background: var(--field-dk); transform: scale(.98); }
.setup-save { margin-top: 4px; }

.btn-ghost {
  display: block; width: 100%;
  padding: 13px 20px;
  background: none; color: var(--field);
  border: 1.5px solid var(--field-ml);
  border-radius: var(--r-sm);
  font-family: 'Jost', sans-serif;
  font-size: 15px; font-weight: 500; cursor: pointer;
  text-align: center;
  transition: background var(--fast) var(--ease);
}
.btn-ghost:active { background: var(--field-lt); }

/* ── Bottom navigation ──────────────────────────────────────── */
#bottom-nav {
  position: fixed; bottom: 0; left: 0; right: 0; z-index: 30;
  height: calc(var(--nav-h) + var(--safe-b));
  padding-bottom: var(--safe-b);
  padding-left: var(--safe-l); padding-right: var(--safe-r);
  background: var(--paper-2);
  border-top: 1px solid var(--line);
  display: flex;
  box-shadow: 0 -2px 14px rgba(24,33,30,.06);
}

.nav-btn {
  flex: 1; border: none; background: none; cursor: pointer;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  gap: 3px; padding: 6px 4px 4px;
  color: var(--ink-ghost); position: relative;
  transition: color var(--fast) var(--ease);
}
.nav-btn.active { color: var(--field); }

.nav-ico {
  width: 22px; height: 22px; display: block;
  transition: transform var(--spring);
}
.nav-btn.active .nav-ico { transform: translateY(-1px); }

.star-ico {
  font-size: 22px; line-height: 1;
  display: block; width: 22px; text-align: center;
}
.nav-btn.active .star-ico { color: var(--gold); }

.nav-label {
  font-family: 'Jost', sans-serif;
  font-size: 10px; font-weight: 500; letter-spacing: .25px;
}

.nav-badge {
  position: absolute; top: 7px; right: calc(50% - 20px);
  min-width: 16px; height: 16px; padding: 0 4px;
  border-radius: var(--r-pill);
  background: var(--gold); color: #fff;
  font-family: 'Jost', sans-serif;
  font-size: 10px; font-weight: 700;
  display: none; align-items: center; justify-content: center;
  line-height: 1;
}
.nav-badge.show { display: flex; }

/* ── FAB ────────────────────────────────────────────────────── */
.fab {
  position: fixed;
  right: max(18px, var(--safe-r));
  bottom: calc(var(--nav-h) + var(--safe-b) + 16px);
  width: var(--fab-sz); height: var(--fab-sz);
  border-radius: 50%;
  background: var(--gold); color: #fff;
  border: none; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  z-index: 20; overflow: hidden;
  box-shadow: 0 4px 16px rgba(181,135,42,.5), 0 2px 4px rgba(0,0,0,.12);
  transition: transform  var(--spring),
              box-shadow var(--fast) var(--ease),
              background var(--fast) var(--ease);
}
.fab svg { width: 24px; height: 24px; position: relative; z-index: 1; }
.fab:hover { background: var(--gold-dk); }
.fab:active {
  transform: scale(.88);
  box-shadow: 0 2px 8px rgba(181,135,42,.35);
}

.fab-ripple {
  position: absolute; inset: 0; border-radius: 50%;
  background: var(--gold); opacity: 0;
  animation: fab-pulse 3s ease-out infinite;
}
@keyframes fab-pulse {
  0%   { opacity: .45; transform: scale(1); }
  55%  { opacity: 0;   transform: scale(1.75); }
  100% { opacity: 0;   transform: scale(1.75); }
}

/* ── Bottom sheet ───────────────────────────────────────────── */
.sheet-scrim {
  position: fixed; inset: 0; z-index: 50;
  background: rgba(24,33,30,.52);
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
  display: flex; align-items: flex-end;
  transition: opacity var(--normal) var(--ease);
}
.sheet-scrim.hidden {
  opacity: 0; pointer-events: none;
}
.sheet-scrim.hidden .bottom-sheet {
  transform: translateY(100%);
}

.bottom-sheet {
  width: 100%;
  background: var(--paper);
  border-radius: 20px 20px 0 0;
  padding-bottom: calc(20px + var(--safe-b));
  box-shadow: var(--shadow-lg);
  max-height: 92dvh; overflow-y: auto;
  transition: transform var(--slow) var(--spring);
}

.sheet-handle {
  width: 38px; height: 4px; border-radius: 2px;
  background: var(--line); margin: 10px auto 0;
}

.sheet-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 20px 12px;
  border-bottom: 1px solid var(--line-soft);
}
.sheet-title {
  font-family: 'Playfair Display', Georgia, serif;
  font-size: 20px; font-weight: 700; color: var(--ink);
}
.sheet-close {
  width: 34px; height: 34px; border-radius: 50%;
  border: none; background: var(--paper-2); cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  color: var(--ink-soft);
  transition: background var(--fast) var(--ease);
}
.sheet-close svg { width: 16px; height: 16px; }
.sheet-close:active { background: var(--line-soft); }

.sheet-body { padding: 16px 20px; }
.sheet-desc {
  font-family: 'Jost', sans-serif;
  font-size: 13.5px; color: var(--ink-soft);
  line-height: 1.6; margin-bottom: 18px;
}

/* ── Form fields (sheet) ────────────────────────────────────── */
.form-field { margin-bottom: 14px; }

.form-label {
  display: block;
  font-family: 'Jost', sans-serif;
  font-size: 11px; font-weight: 600;
  letter-spacing: .9px; text-transform: uppercase;
  color: var(--ink-soft); margin-bottom: 6px;
}
.req { color: var(--field); margin-left: 1px; }
.opt {
  font-weight: 400; font-size: 10px;
  text-transform: none; letter-spacing: 0;
  color: var(--ink-ghost);
}

.form-field input,
.form-field textarea {
  width: 100%;
  padding: 11px 13px;
  background: var(--white);
  border: 1.5px solid var(--line);
  border-radius: var(--r-sm);
  font-family: 'Jost', sans-serif;
  font-size: 15px; color: var(--ink);
  outline: none; resize: vertical;
  min-height: 44px;
  transition: border-color var(--fast) var(--ease),
              box-shadow   var(--fast) var(--ease);
}
.form-field input::placeholder,
.form-field textarea::placeholder { color: var(--ink-ghost); }
.form-field input:focus,
.form-field textarea:focus {
  border-color: var(--field);
  box-shadow: 0 0 0 3px rgba(47,93,80,.1);
}

.form-row-2 { display: flex; gap: 10px; }
.form-row-2 .form-field { flex: 1; }

.photo-deferred {
  display: flex; align-items: flex-start; gap: 9px;
  padding: 11px 13px; margin-top: 6px;
  background: var(--paper-3);
  border-radius: var(--r-sm);
  font-family: 'Jost', sans-serif;
  font-size: 12px; color: var(--ink-soft); line-height: 1.55;
}

.sheet-footer { padding: 4px 20px 0; }

/* ── Toast ──────────────────────────────────────────────────── */
.toast {
  position: fixed;
  bottom: calc(var(--nav-h) + var(--safe-b) + 12px);
  left: 50%; transform: translateX(-50%) translateY(12px);
  background: var(--ink); color: #fff;
  font-family: 'Jost', sans-serif;
  font-size: 13.5px;
  padding: 11px 20px;
  border-radius: var(--r);
  box-shadow: var(--shadow-md);
  opacity: 0; pointer-events: none;
  white-space: nowrap; max-width: calc(100vw - 32px);
  text-align: center; z-index: 100;
  border-left: 3px solid transparent;
  transition: opacity var(--normal) var(--ease),
              transform var(--normal) var(--ease);
}
.toast.show {
  opacity: 1; transform: translateX(-50%) translateY(0);
}
.toast.t-ok    { border-left-color: #7ed4a0; }
.toast.t-star  { border-left-color: var(--gold); }
.toast.t-error { border-left-color: #e87676; }
