/* ============================================================
   SnapCal — refined dark editorial design
   Target: event organizers · scenesters · busy parents · travelers
   Standalone stylesheet (no dependency on style.css / miniapp.css)
   ============================================================ */

:root {
  color-scheme: dark;

  /* Background — warm slate-navy (NOT pure black) */
  --bg:        #0c1116;
  --bg-2:      #070b10;
  --surface:   #131a23;
  --surface-2: #1a2230;
  --surface-3: #232d3d;
  --hairline:  #1f2735;
  --border:    #2a3548;
  --border-2:  #3a4762;

  /* Text — warm cream tones, NOT cold blue-whites */
  --text:      #f3edd9;     /* primary text - warm cream */
  --text-2:    #ccc4ad;     /* secondary - aged paper */
  --muted:     #8c8474;     /* tertiary - warm gray */
  --muted-2:   #5d564a;     /* deepest muted */

  /* Primary accent — warm coral (eventful, energetic, distinctive) */
  --accent:       #ff6b4a;
  --accent-soft:  #ff8c70;
  --accent-deep:  #e8533a;
  --accent-glow:  rgba(255, 107, 74, 0.28);
  --accent-trace: rgba(255, 107, 74, 0.12);

  /* Secondary — sage green (calm success / pinned) */
  --ok:        #7fb697;
  --ok-soft:   #9fcdb1;

  /* Warning + danger — earthier than neon */
  --warn:      #e8a851;
  --danger:    #d65a5a;

  /* Gold — for moments of "special" highlight (upcoming events) */
  --gold:      #d4a868;
  --gold-soft: #e6c590;

  /* Type system */
  --sans:  ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont,
           "Segoe UI Variable", "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  --serif: ui-serif, "Iowan Old Style", "Apple Garamond", Baskerville,
           "Times New Roman", "Source Serif Pro", Georgia, serif;
  --mono:  ui-monospace, "SF Mono", "JetBrains Mono", Menlo, Consolas,
           "Roboto Mono", monospace;

  --radius-xs:  6px;
  --radius-sm:  8px;
  --radius:     12px;
  --radius-lg:  16px;
  --radius-xl:  20px;

  --tap: 44px;
  --shadow-soft: 0 1px 0 rgba(255,255,255,0.04), 0 8px 28px rgba(0,0,0,0.35);
  --shadow-card: 0 1px 0 rgba(255,255,255,0.06), 0 12px 36px rgba(0,0,0,0.45);
}

* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  color: var(--text);
  font: 15.5px/1.55 var(--sans);
  font-feature-settings: "ss01" on, "cv11" on;
  overflow-x: clip;
  padding-bottom: max(1rem, env(safe-area-inset-bottom));
  min-height: var(--tg-viewport-h, 100dvh);

  /* The room — warm ambient light from the top, like dusk */
  background:
    radial-gradient(60vw 50vh at 80% -10%,
      rgba(255, 107, 74, 0.06) 0%, transparent 60%),
    radial-gradient(50vw 40vh at -10% 110%,
      rgba(212, 168, 104, 0.05) 0%, transparent 60%),
    linear-gradient(180deg, var(--bg) 0%, var(--bg-2) 100%);
  background-attachment: fixed;
}

img, video { max-width: 100%; height: auto; display: block; }
a { color: var(--accent); text-decoration: none; }
a:hover { text-decoration: underline; text-underline-offset: 3px;
          text-decoration-color: color-mix(in srgb, var(--accent) 60%, transparent); }
a:active { opacity: 0.75; }

::selection { background: var(--accent-trace); color: var(--text); }

button { font: inherit; cursor: pointer; }

/* ============ TOP BAR ============ */
.sc-bar {
  position: sticky; top: 0; z-index: 30;
  padding: 0.85rem 1.1rem;
  padding-top: max(0.85rem, env(safe-area-inset-top));
  background: color-mix(in srgb, var(--bg) 88%, transparent);
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
  border-bottom: 1px solid var(--hairline);
  display: flex; align-items: center; gap: 0.5rem;
}
.sc-brand {
  display: inline-flex; align-items: baseline; gap: 0.25rem;
  font: 700 1.1rem/1 var(--sans);
  letter-spacing: -0.015em;
  color: var(--text);
  text-decoration: none;
  margin-right: auto;
}
.sc-brand-snap { color: var(--text); }
.sc-brand-cal { color: var(--accent);
                text-shadow: 0 0 24px var(--accent-glow); }
.sc-brand-dot {
  width: 5px; height: 5px; border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 12px var(--accent-glow);
  margin-left: 0.3rem;
}
.sc-brand:hover { text-decoration: none; }

.sc-status {
  font: 500 0.72rem/1 var(--mono);
  letter-spacing: 0.04em;
  color: var(--muted);
  padding: 0.35rem 0.55rem;
  border-radius: 999px;
  background: var(--surface);
  border: 1px solid var(--hairline);
}
.sc-status.ok { color: var(--ok); border-color: color-mix(in srgb, var(--ok) 35%, var(--hairline)); }
.sc-status.err { color: var(--danger); border-color: color-mix(in srgb, var(--danger) 40%, var(--hairline)); }
.sc-status.loading { color: var(--text-2); }

.sc-icon-btn {
  width: 38px; height: 38px;
  display: inline-flex; align-items: center; justify-content: center;
  background: transparent;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  color: var(--text-2);
  font-size: 1.1rem;
  transition: color 0.15s, border-color 0.15s, background 0.15s;
}
.sc-icon-btn:hover {
  color: var(--text);
  border-color: var(--border-2);
  background: var(--surface);
}
.sc-icon-btn:active { transform: scale(0.95); }
.sc-install {
  border-color: color-mix(in srgb, var(--ok) 45%, var(--border));
  color: var(--ok);
  font: 600 0.74rem/1 var(--sans);
  letter-spacing: 0.04em;
  padding: 0 0.75rem;
  width: auto; gap: 0.4rem;
}
.sc-install::before { content: "↓"; font-weight: 700; }
.sc-install:hover { background: color-mix(in srgb, var(--ok) 12%, transparent);
                    color: var(--ok-soft); }

/* ============ LAYOUT ============ */
.sc-main {
  max-width: 720px;
  margin: 0 auto;
  padding: 1.25rem 1.1rem 2.5rem;
}

/* ============ GREETING ============ */
.sc-greeting {
  margin-bottom: 1.5rem;
}
.sc-hello {
  font: 400 0.82rem/1.3 var(--mono);
  color: var(--muted);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin-bottom: 0.35rem;
}
.sc-greeting-name {
  font: 700 1.85rem/1.15 var(--sans);
  letter-spacing: -0.025em;
  color: var(--text);
  margin: 0;
}
.sc-greeting-name em {
  font: italic 700 1.85rem/1.15 var(--serif);
  letter-spacing: -0.015em;
  color: var(--accent);
  font-style: italic;
}

/* ============ "UP NEXT" HERO CARD ============ */
.sc-upnext {
  position: relative;
  background:
    linear-gradient(135deg,
      color-mix(in srgb, var(--accent) 8%, var(--surface)) 0%,
      var(--surface) 60%,
      color-mix(in srgb, var(--gold) 5%, var(--surface)) 100%);
  border: 1px solid color-mix(in srgb, var(--accent) 35%, var(--border));
  border-radius: var(--radius-lg);
  padding: 1.4rem 1.4rem 1.25rem;
  margin-bottom: 1.75rem;
  box-shadow: var(--shadow-card),
              0 0 40px color-mix(in srgb, var(--accent) 8%, transparent);
  overflow: hidden;
}
.sc-upnext::before {
  content: ""; position: absolute; top: 0; left: 0; right: 0; height: 2px;
  background: linear-gradient(90deg, transparent, var(--accent) 30%, var(--gold) 70%, transparent);
  opacity: 0.85;
}
.sc-upnext-label {
  font: 600 0.7rem/1 var(--mono);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 0.65rem;
  display: flex; align-items: center; gap: 0.5rem;
}
.sc-upnext-label::before {
  content: ""; width: 6px; height: 6px; border-radius: 50%;
  background: var(--accent); box-shadow: 0 0 8px var(--accent-glow);
}
.sc-upnext-countdown {
  font: 500 0.9rem/1.2 var(--mono);
  color: var(--gold);
  margin-bottom: 0.4rem;
  font-variant-numeric: tabular-nums;
}
.sc-upnext-title {
  font: 600 1.45rem/1.15 var(--serif);
  letter-spacing: -0.01em;
  color: var(--text);
  margin: 0 0 0.55rem;
}
.sc-upnext-meta {
  display: flex; flex-direction: column; gap: 0.25rem;
  margin-bottom: 1.1rem;
}
.sc-upnext-when, .sc-upnext-where {
  font: 500 0.9rem/1.4 var(--sans);
  color: var(--text-2);
  display: flex; align-items: center; gap: 0.45rem;
}
.sc-upnext-when::before { content: "⌒"; color: var(--accent); font-size: 0.9em; }
.sc-upnext-where::before { content: "•"; color: var(--gold); }
.sc-upnext-when { font-variant-numeric: tabular-nums; }

.sc-upnext-cta {
  display: inline-flex; align-items: center; justify-content: center;
  gap: 0.5rem;
  padding: 0.85rem 1.4rem;
  background: var(--accent);
  color: #1a0e09;
  border: 0;
  border-radius: var(--radius);
  font: 600 0.92rem/1 var(--sans);
  letter-spacing: 0.005em;
  text-decoration: none;
  box-shadow: 0 6px 22px color-mix(in srgb, var(--accent) 35%, transparent),
              inset 0 1px 0 color-mix(in srgb, white 25%, transparent);
  transition: transform 0.12s, box-shadow 0.15s, background 0.15s;
  min-height: var(--tap);
}
.sc-upnext-cta:hover {
  background: var(--accent-soft);
  box-shadow: 0 8px 28px color-mix(in srgb, var(--accent) 50%, transparent),
              inset 0 1px 0 color-mix(in srgb, white 30%, transparent);
  text-decoration: none;
  transform: translateY(-1px);
}
.sc-upnext-cta::after { content: "→"; font-weight: 500; }

/* ============ SECTION HEADERS ============ */
.sc-section-head {
  display: flex; align-items: baseline; justify-content: space-between;
  gap: 1rem;
  margin: 1.5rem 0 0.85rem;
}
.sc-section-title {
  font: 600 0.95rem/1.2 var(--sans);
  letter-spacing: -0.005em;
  color: var(--text);
  margin: 0;
}
.sc-section-meta {
  font: 500 0.78rem/1 var(--mono);
  color: var(--muted);
  letter-spacing: 0.02em;
}

/* ============ FILTER CHIPS ============ */
.sc-search {
  margin: 0 0 0.6rem;
}
.sc-search-input {
  width: 100%;
  box-sizing: border-box;
  padding: 0.6rem 0.85rem;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  color: var(--text);
  -webkit-appearance: none;
  appearance: none;
  transition: border-color 0.15s ease, background 0.15s ease;
}
.sc-search-input::placeholder { color: var(--muted); }
.sc-search-input:focus {
  outline: none;
  border-color: var(--accent);
  background: var(--surface-2);
}

.sc-filters {
  display: flex; gap: 0.45rem;
  overflow-x: auto;
  padding: 0.25rem 0 0.5rem;
  margin: 0 -1.1rem 1rem;
  padding-left: 1.1rem; padding-right: 1.1rem;
  scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
}
.sc-filters::-webkit-scrollbar { display: none; }
.sc-chip {
  flex: 0 0 auto;
  background: transparent;
  border: 1px solid var(--border);
  color: var(--text-2);
  font: 500 0.85rem/1 var(--sans);
  letter-spacing: 0;
  padding: 0.6rem 0.95rem;
  border-radius: 999px;
  cursor: pointer;
  white-space: nowrap;
  min-height: 36px;
  transition: background 0.15s, color 0.15s, border-color 0.15s;
}
.sc-chip:hover { color: var(--text); border-color: var(--border-2); }
.sc-chip.active {
  background: var(--text);
  color: var(--bg);
  border-color: var(--text);
  font-weight: 600;
}

/* ============ NOTE LIST ============ */
.sc-notes { display: grid; gap: 0.75rem; }

/* Generic state messages */
.sc-loading, .sc-error {
  padding: 3rem 1rem;
  text-align: center;
  font: 500 0.88rem/1.5 var(--mono);
  color: var(--muted);
}
.sc-error { color: var(--danger); }

/* ============ EMPTY STATE (first run) ============ */
.sc-empty {
  margin: 2rem 0;
  background:
    linear-gradient(180deg,
      color-mix(in srgb, var(--accent) 5%, var(--surface)) 0%,
      var(--surface) 100%);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 2.5rem 1.75rem 2rem;
  text-align: center;
  box-shadow: var(--shadow-soft);
}
.sc-empty-icon {
  width: 64px; height: 64px;
  margin: 0 auto 1.25rem;
  display: grid; place-items: center;
  background:
    radial-gradient(circle at 30% 30%,
      color-mix(in srgb, var(--accent) 30%, transparent) 0%,
      transparent 70%);
  border-radius: 50%;
  position: relative;
}
.sc-empty-icon::before {
  content: ""; position: absolute; inset: 12px;
  background: var(--accent);
  -webkit-mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='currentColor' d='M19 4h-1V2h-2v2H8V2H6v2H5a2 2 0 0 0-2 2v14a2 2 0 0 0 2 2h14a2 2 0 0 0 2-2V6a2 2 0 0 0-2-2zm0 16H5V9h14v11zm0-13H5V6h14v1z'/></svg>") center/contain no-repeat;
          mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='currentColor' d='M19 4h-1V2h-2v2H8V2H6v2H5a2 2 0 0 0-2 2v14a2 2 0 0 0 2 2h14a2 2 0 0 0 2-2V6a2 2 0 0 0-2-2zm0 16H5V9h14v11zm0-13H5V6h14v1z'/></svg>") center/contain no-repeat;
}
.sc-empty-title {
  font: 600 1.25rem/1.3 var(--serif);
  font-style: italic;
  color: var(--text);
  margin: 0 0 0.65rem;
  letter-spacing: -0.005em;
}
.sc-empty-body {
  font: 400 0.92rem/1.55 var(--sans);
  color: var(--text-2);
  margin: 0 auto 1.5rem;
  max-width: 360px;
}
.sc-empty-cta {
  display: inline-flex; align-items: center; gap: 0.5rem;
  padding: 0.8rem 1.3rem;
  background: var(--accent);
  color: #1a0e09;
  border: 0;
  border-radius: var(--radius);
  font: 600 0.9rem/1 var(--sans);
  text-decoration: none;
  min-height: var(--tap);
  box-shadow: 0 6px 22px color-mix(in srgb, var(--accent) 35%, transparent);
  transition: background 0.15s, transform 0.12s;
}
.sc-empty-cta:hover { background: var(--accent-soft); text-decoration: none; }
.sc-empty-cta:active { transform: scale(0.97); }
.sc-empty-cta::after { content: "→"; }
.sc-empty-hint {
  font: 400 0.76rem/1.4 var(--mono);
  color: var(--muted);
  margin: 1.5rem 0 0;
  letter-spacing: 0.02em;
}

/* ============ AUTH GATE (no Telegram init) ============ */
.sc-gate {
  margin: 2.5rem 0;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 2.5rem 1.75rem;
  text-align: center;
}
.sc-gate-icon {
  width: 56px; height: 56px;
  margin: 0 auto 1rem;
  border-radius: 50%;
  background: color-mix(in srgb, var(--accent) 15%, transparent);
  display: grid; place-items: center;
  color: var(--accent);
  font-size: 1.5rem;
  font-weight: 700;
}
.sc-gate-title {
  font: italic 600 1.25rem/1.3 var(--serif);
  color: var(--text);
  margin: 0 0 0.55rem;
}
.sc-gate-body {
  font: 400 0.9rem/1.55 var(--sans);
  color: var(--text-2);
  margin: 0 auto 1.5rem;
  max-width: 380px;
}
.sc-gate-actions {
  display: grid; gap: 0.55rem;
  max-width: 320px; margin: 0 auto;
}
.sc-gate-btn {
  display: inline-flex; align-items: center; justify-content: center;
  padding: 0.85rem 1rem;
  border-radius: var(--radius);
  font: 600 0.88rem/1 var(--sans);
  text-decoration: none;
  min-height: var(--tap);
  transition: background 0.15s, color 0.15s;
}
.sc-gate-btn.primary {
  background: var(--accent);
  color: #1a0e09;
  box-shadow: 0 6px 22px color-mix(in srgb, var(--accent) 35%, transparent);
}
.sc-gate-btn.primary:hover { background: var(--accent-soft); text-decoration: none; }
.sc-gate-btn.secondary {
  background: transparent;
  color: var(--text-2);
  border: 1px solid var(--border);
}
.sc-gate-btn.secondary:hover { background: var(--surface-2); color: var(--text); text-decoration: none; }

/* ============ EVENT CARD (the hero card type) ============ */
.sc-note { isolation: isolate; }

.sc-event {
  display: grid;
  grid-template-columns: 64px 1fr;
  gap: 0;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--shadow-soft);
  transition: transform 0.15s, box-shadow 0.15s;
}
.sc-event:hover {
  box-shadow: var(--shadow-card);
  transform: translateY(-1px);
}

/* Date "tear-off" stripe on the left */
.sc-event-date {
  background:
    linear-gradient(180deg,
      color-mix(in srgb, var(--accent) 14%, var(--surface-2)) 0%,
      var(--surface-2) 100%);
  border-right: 1px solid var(--border);
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  padding: 0.6rem 0.5rem;
  position: relative;
}
.sc-event-date::after {
  /* perforated edge — subtle */
  content: "";
  position: absolute; top: 0; bottom: 0; right: -1px; width: 2px;
  background: radial-gradient(circle at center,
              var(--bg) 1px, transparent 1.5px) 0 0 / 4px 8px;
}
.sc-event-day {
  font: 700 1.55rem/1 var(--sans);
  color: var(--text);
  letter-spacing: -0.025em;
  font-variant-numeric: tabular-nums;
}
.sc-event-month {
  font: 600 0.7rem/1 var(--mono);
  color: var(--accent);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  margin-top: 0.25rem;
}
.sc-event-year {
  font: 400 0.62rem/1 var(--mono);
  color: var(--muted);
  margin-top: 0.2rem;
  font-variant-numeric: tabular-nums;
}

.sc-event-body {
  padding: 0.95rem 1.1rem 0.9rem;
  min-width: 0;
}
.sc-event-title {
  font: 600 1.1rem/1.25 var(--serif);
  letter-spacing: -0.005em;
  color: var(--text);
  margin: 0 0 0.4rem;
  word-wrap: break-word;
}
.sc-event-when {
  font: 500 0.83rem/1.3 var(--mono);
  color: var(--text-2);
  margin: 0 0 0.2rem;
  font-variant-numeric: tabular-nums;
}
.sc-event-where {
  font: 400 0.85rem/1.4 var(--sans);
  color: var(--muted);
  margin: 0 0 0.65rem;
}
.sc-event-where::before { content: "•  "; color: var(--accent); }
.sc-event-image {
  display: block; width: 100%; max-height: 220px;
  object-fit: cover;
  border-radius: var(--radius-sm);
  margin: 0.6rem 0 0.55rem;
  background: var(--surface-2);
}

.sc-event-actions {
  display: flex; gap: 0.4rem; flex-wrap: wrap;
  margin-top: 0.75rem;
  align-items: center;
}
.sc-cta-cal {
  display: inline-flex; align-items: center; gap: 0.4rem;
  padding: 0.55rem 0.95rem;
  background: var(--accent);
  color: #1a0e09;
  border: 0;
  border-radius: var(--radius-sm);
  font: 600 0.8rem/1 var(--sans);
  text-decoration: none;
  min-height: 36px;
  box-shadow: 0 4px 14px color-mix(in srgb, var(--accent) 30%, transparent);
  transition: background 0.15s, transform 0.1s;
}
.sc-cta-cal:hover { background: var(--accent-soft); text-decoration: none; }
.sc-cta-cal:active { transform: scale(0.97); }
.sc-cta-cal::after { content: "→"; font-weight: 500; }

.sc-action {
  background: transparent;
  border: 1px solid var(--border);
  color: var(--muted);
  font: 500 0.78rem/1 var(--sans);
  padding: 0.5rem 0.8rem;
  border-radius: var(--radius-sm);
  min-height: 36px;
  transition: color 0.12s, border-color 0.12s, background 0.12s;
}
.sc-action:hover {
  color: var(--text);
  border-color: var(--border-2);
  background: var(--surface-2);
}
.sc-action.is-pinned {
  color: var(--ok); border-color: color-mix(in srgb, var(--ok) 45%, var(--border));
  background: color-mix(in srgb, var(--ok) 10%, transparent);
}
.sc-action.danger:hover {
  color: var(--danger); border-color: color-mix(in srgb, var(--danger) 50%, var(--border));
  background: color-mix(in srgb, var(--danger) 10%, transparent);
}

/* ============ NON-EVENT NOTE CARD ============ */
.sc-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 0.95rem 1.1rem 0.9rem;
  box-shadow: var(--shadow-soft);
}
.sc-card.pinned {
  border-left: 3px solid var(--ok);
  background: linear-gradient(90deg,
              color-mix(in srgb, var(--ok) 4%, var(--surface)) 0%,
              var(--surface) 30%);
}
.sc-card-meta {
  display: flex; align-items: center; gap: 0.45rem;
  font: 500 0.74rem/1 var(--mono);
  color: var(--muted);
  margin-bottom: 0.4rem;
  flex-wrap: wrap;
  letter-spacing: 0.02em;
}
.sc-kind-icon {
  width: 22px; height: 22px;
  border-radius: 50%;
  display: inline-grid; place-items: center;
  background: var(--surface-2);
  font-size: 0.78rem;
  color: var(--text-2);
}
.sc-card-id {
  color: var(--muted);
  font-variant-numeric: tabular-nums;
}
.sc-card-intent {
  background: var(--accent-trace);
  color: var(--accent-soft);
  padding: 0.15rem 0.55rem;
  border-radius: 999px;
  font: 600 0.68rem/1.2 var(--mono);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.sc-card-ts {
  margin-left: auto;
  font-variant-numeric: tabular-nums;
}
.sc-card-title {
  font: 600 1.02rem/1.3 var(--serif);
  color: var(--text);
  margin: 0.2rem 0 0.35rem;
  letter-spacing: -0.005em;
}
.sc-card-url {
  display: block;
  font: 500 0.84rem/1.4 var(--mono);
  color: var(--accent-soft);
  word-break: break-all;
  margin: 0.25rem 0 0.4rem;
}
.sc-card-content {
  font: 400 0.92rem/1.5 var(--sans);
  color: var(--text-2);
  margin: 0.3rem 0 0;
  white-space: pre-wrap;
  word-wrap: break-word;
}
.sc-card-image {
  display: block;
  width: 100%; max-height: 280px;
  object-fit: cover;
  border-radius: var(--radius-sm);
  margin: 0.6rem 0 0.4rem;
  background: var(--surface-2);
}
.sc-card-tags {
  margin-top: 0.55rem;
  display: flex; flex-wrap: wrap; gap: 0.3rem;
}
.sc-tag {
  background: var(--surface-2);
  color: var(--text-2);
  border: 1px solid var(--border);
  padding: 0.18rem 0.55rem;
  border-radius: 999px;
  font: 500 0.72rem/1.4 var(--sans);
  letter-spacing: 0;
}
.sc-card-actions {
  display: flex; gap: 0.4rem; flex-wrap: wrap;
  margin-top: 0.7rem;
}

/* ============ REMOVING ANIMATION ============ */
.sc-note.removing {
  opacity: 0;
  transform: translateX(-10px);
  transition: opacity 0.22s, transform 0.22s;
}

/* ============ FOOTER ============ */
.sc-foot {
  margin-top: 2.5rem;
  padding: 1.25rem 0;
  border-top: 1px solid var(--hairline);
  display: flex; justify-content: space-between; align-items: center;
  gap: 1rem; flex-wrap: wrap;
  font: 400 0.78rem/1.4 var(--mono);
  color: var(--muted);
  letter-spacing: 0.02em;
}
.sc-foot a, .sc-foot button.linklike {
  background: none; border: 0; padding: 0;
  color: var(--text-2);
  font: inherit;
  cursor: pointer;
  text-decoration: none;
}
.sc-foot a:hover, .sc-foot button.linklike:hover {
  color: var(--accent);
  text-decoration: underline;
  text-underline-offset: 3px;
}
.sc-foot-links { display: flex; gap: 1rem; }

/* ============ ACCOUNT SHEET ============ */
.sc-sheet { display: none; }
.sc-sheet.open {
  display: flex;
  position: fixed; inset: 0; z-index: 50;
  align-items: flex-end; justify-content: center;
  animation: sc-sheet-fade 0.18s ease-out;
}
@keyframes sc-sheet-fade { from { opacity: 0; } to { opacity: 1; } }
.sc-sheet-backdrop {
  position: absolute; inset: 0;
  background: rgba(0, 0, 0, 0.55);
  -webkit-backdrop-filter: blur(6px);
  backdrop-filter: blur(6px);
}
.sc-sheet-panel {
  position: relative; z-index: 1;
  width: 100%; max-width: 480px;
  max-height: var(--tg-viewport-stable-h, 100dvh);
  overflow-y: auto;
  background: var(--surface);
  border: 1px solid var(--border); border-bottom: 0;
  border-radius: var(--radius-xl) var(--radius-xl) 0 0;
  padding: 1.1rem 1.25rem max(1.5rem, env(safe-area-inset-bottom));
  box-shadow: 0 -16px 64px rgba(0, 0, 0, 0.55);
  animation: sc-sheet-slide-up 0.24s cubic-bezier(.2, .9, .3, 1);
}
@keyframes sc-sheet-slide-up {
  from { transform: translateY(20px); }
  to   { transform: translateY(0); }
}
.sc-sheet-grab {
  width: 40px; height: 4px;
  background: var(--border-2);
  border-radius: 4px;
  margin: -0.25rem auto 0.85rem;
}
.sc-sheet-title {
  font: italic 600 1.2rem/1.2 var(--serif);
  color: var(--text);
  margin: 0 0 1rem;
}
.sc-sheet-rows { display: grid; gap: 0.85rem; margin-bottom: 1.4rem; }
.sc-sheet-row {
  display: flex; justify-content: space-between; align-items: baseline;
  padding: 0.75rem 0;
  border-bottom: 1px solid var(--hairline);
}
.sc-sheet-row:last-child { border-bottom: 0; }
.sc-sheet-label {
  font: 500 0.78rem/1 var(--mono);
  color: var(--muted);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.sc-sheet-value {
  font: 600 0.95rem/1 var(--sans);
  color: var(--text);
  font-variant-numeric: tabular-nums;
}
.sc-sheet-actions { display: grid; gap: 0.55rem; }
.sc-sheet-btn {
  display: flex; align-items: center; justify-content: center;
  padding: 0.85rem 1rem;
  background: var(--surface-2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  color: var(--text);
  font: 500 0.9rem/1 var(--sans);
  min-height: var(--tap);
  text-decoration: none;
  transition: background 0.15s, color 0.15s, border-color 0.15s;
}
.sc-sheet-btn:hover { background: var(--surface-3); text-decoration: none; }
.sc-sheet-btn.danger {
  color: var(--danger);
  border-color: color-mix(in srgb, var(--danger) 35%, var(--border));
}
.sc-sheet-btn.danger:hover {
  background: color-mix(in srgb, var(--danger) 12%, var(--surface-2));
  color: var(--danger);
}
.sc-sheet-btn.primary {
  background: var(--accent);
  color: #0c1116;
  border-color: var(--accent);
  font-weight: 600;
}
.sc-sheet-btn.primary:hover {
  background: color-mix(in srgb, var(--accent) 88%, white);
  color: #0c1116;
  border-color: color-mix(in srgb, var(--accent) 88%, white);
}
.sc-sheet-btn:disabled {
  opacity: 0.55;
  cursor: wait;
}
.sc-sheet-foot {
  margin-top: 1rem;
  font: 400 0.76rem/1.5 var(--sans);
  color: var(--muted);
  text-align: center;
}

/* ============ RESPONSIVE TWEAKS ============ */
@media (min-width: 540px) {
  .sc-main { padding: 1.5rem 1.5rem 3rem; }
  .sc-greeting-name { font-size: 2rem; }
  .sc-greeting-name em { font-size: 2rem; }
}
@media (min-width: 760px) {
  .sc-sheet.open { align-items: center; }
  .sc-sheet-panel {
    border-radius: var(--radius-xl);
    border-bottom: 1px solid var(--border);
    max-width: 460px;
  }
  .sc-sheet-grab { display: none; }
}

/* Prevent iOS zoom on input focus */
input, select, textarea, button { font-size: 16px; }
@media (min-width: 640px) { input, select, textarea, button { font-size: inherit; } }

/* ============ PWA SHARE-TARGET BANNER ============
   Transient confirmation / gate prompt that lands at the top of the page
   when the user arrives via /snap?shared=N or /snap?gate=share. Styled in
   the editorial palette — coral for success, gold for warn, no neon glow.
   ================================================================== */
.sc-banner {
  position: fixed;
  top: env(safe-area-inset-top, 0);
  left: 0;
  right: 0;
  z-index: 1000;
  padding: 0.75rem 2.5rem 0.75rem 1rem;
  font: 500 0.9rem/1.4 var(--sans);
  color: var(--text);
  background: rgba(127, 182, 151, 0.18);                /* default = ok */
  border-bottom: 1px solid rgba(127, 182, 151, 0.4);
  backdrop-filter: blur(12px) saturate(120%);
  -webkit-backdrop-filter: blur(12px) saturate(120%);
  animation: sc-banner-in 220ms cubic-bezier(.2,.7,.2,1) both;
}
.sc-banner.warn {
  background: rgba(212, 168, 104, 0.18);
  border-bottom-color: rgba(212, 168, 104, 0.4);
}
.sc-banner.err {
  background: rgba(255, 107, 74, 0.18);
  border-bottom-color: rgba(255, 107, 74, 0.4);
}
.sc-banner__x {
  position: absolute;
  top: 50%;
  right: 0.5rem;
  transform: translateY(-50%);
  width: 1.75rem;
  height: 1.75rem;
  border: 0;
  border-radius: 50%;
  background: transparent;
  color: var(--text);
  opacity: 0.55;
  font: 400 1.25rem/1 var(--sans);
  cursor: pointer;
  transition: opacity 120ms;
}
.sc-banner__x:hover { opacity: 1; }
@keyframes sc-banner-in {
  from { transform: translateY(-100%); opacity: 0; }
  to   { transform: translateY(0);     opacity: 1; }
}

/* ============ PAYWALL / WAITLIST HERO ============
   Rendered above the notes list when the tenant has hit the 3-note
   free-tier cap. Color-emphasized in coral when the user has NOT
   yet joined the waitlist, softened to sage when they have. Sized to
   feel important without screaming — this is a friendly nudge, not
   a popup interrupt.
   ================================================== */
.sc-paywall {
  margin: 1rem 0 1.25rem;
  padding: 1.25rem 1.25rem 1rem;
  border-radius: var(--radius-xl, 14px);
  background: linear-gradient(180deg,
    rgba(255, 107, 74, 0.10) 0%,
    rgba(255, 107, 74, 0.04) 100%);
  border: 1px solid rgba(255, 107, 74, 0.30);
  color: var(--text);
}
.sc-paywall.is-waitlisted {
  background: linear-gradient(180deg,
    rgba(127, 182, 151, 0.10) 0%,
    rgba(127, 182, 151, 0.04) 100%);
  border-color: rgba(127, 182, 151, 0.30);
}
.sc-paywall-head {
  display: flex;
  align-items: baseline;
  gap: 0.75rem;
  margin-bottom: 0.5rem;
}
.sc-paywall-meter {
  font: 500 0.75rem/1 var(--mono);
  letter-spacing: 0.05em;
  color: var(--accent);
  padding: 0.25rem 0.5rem;
  border-radius: 999px;
  background: rgba(255, 107, 74, 0.15);
  flex-shrink: 0;
}
.sc-paywall.is-waitlisted .sc-paywall-meter {
  color: var(--ok);
  background: rgba(127, 182, 151, 0.18);
}
.sc-paywall-title {
  font: italic 600 1.15rem/1.3 var(--serif);
  margin: 0;
  color: var(--text);
}
.sc-paywall-sub {
  margin: 0 0 0.9rem;
  font: 400 0.875rem/1.45 var(--sans);
  color: color-mix(in srgb, var(--text) 75%, transparent);
}
.sc-paywall-form {
  display: flex;
  gap: 0.5rem;
  margin-bottom: 0.6rem;
}
.sc-paywall-form input[type="email"] {
  flex: 1;
  min-width: 0;
  padding: 0.65rem 0.85rem;
  border-radius: var(--radius-md, 10px);
  border: 1px solid color-mix(in srgb, var(--text) 18%, transparent);
  background: rgba(0, 0, 0, 0.20);
  color: var(--text);
  font: 400 0.9rem/1.2 var(--sans);
}
.sc-paywall-form input[type="email"]:focus {
  outline: none;
  border-color: var(--accent);
  background: rgba(0, 0, 0, 0.30);
}
.sc-paywall-cta {
  padding: 0.65rem 1.1rem;
  border: 0;
  border-radius: var(--radius-md, 10px);
  background: var(--accent);
  color: #0c1116;
  font: 600 0.85rem/1 var(--sans);
  letter-spacing: 0.02em;
  cursor: pointer;
  white-space: nowrap;
  transition: filter 120ms;
}
.sc-paywall.is-waitlisted .sc-paywall-cta {
  background: var(--ok);
}
.sc-paywall-cta:hover:not(:disabled) { filter: brightness(1.08); }
.sc-paywall-cta:disabled { opacity: 0.55; cursor: wait; }
.sc-paywall-hint {
  margin: 0;
  font: 400 0.78rem/1.4 var(--sans);
  color: color-mix(in srgb, var(--text) 55%, transparent);
}
.sc-paywall-hint a { color: var(--accent); text-decoration: underline; }
.sc-paywall-hint a:hover { color: color-mix(in srgb, var(--accent) 80%, var(--text)); }
.sc-paywall-ok {
  margin: 0.6rem 0 0;
  font: 500 0.85rem/1.4 var(--sans);
  color: var(--ok);
}

/* ============ ONBOARDING (empty state) ============
   Replaces the bare "Capture your first event" with a numbered 3-step
   walkthrough that doesn't disappear until the user actually has notes.
   The steps echo the bot's `/start` welcome so cross-surface
   consistency holds.
   =================================================== */
.sc-onboarding {
  text-align: left;
}
.sc-onboarding .sc-empty-icon,
.sc-onboarding .sc-empty-title,
.sc-onboarding .sc-empty-body,
.sc-onboarding .sc-empty-cta,
.sc-onboarding .sc-empty-hint {
  text-align: center;
}
.sc-onb-steps {
  list-style: none;
  margin: 1.5rem auto 1.5rem;
  padding: 0;
  max-width: 24rem;
  display: grid;
  gap: 1rem;
}
.sc-onb-step {
  display: grid;
  grid-template-columns: 2.25rem 1fr;
  align-items: start;
  gap: 0.85rem;
}
.sc-onb-num {
  width: 2.25rem;
  height: 2.25rem;
  border-radius: 50%;
  background: rgba(255, 107, 74, 0.15);
  color: var(--accent);
  font: 600 1rem/2.25rem var(--mono);
  text-align: center;
  border: 1px solid rgba(255, 107, 74, 0.30);
  flex-shrink: 0;
}
.sc-onb-body {
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
}
.sc-onb-body strong {
  font: 600 0.95rem/1.35 var(--sans);
  color: var(--text);
}
.sc-onb-body strong em {
  font: italic 600 0.95rem/1.35 var(--serif);
  color: var(--accent);
  font-style: italic;
}
.sc-onb-body span {
  font: 400 0.825rem/1.4 var(--sans);
  color: color-mix(in srgb, var(--text) 65%, transparent);
}

/* ============ ERROR PAGE ============ */
.sc-error-page {
  max-width: 28rem;
  margin: 5rem auto 2rem;
  padding: 1.5rem;
  text-align: center;
  font-family: var(--sans);
  color: var(--text);
}
.sc-error-title {
  font: italic 600 1.75rem/1.2 var(--serif);
  margin: 0 0 0.75rem;
  color: var(--text);
}
.sc-error-sub {
  font: 400 1rem/1.5 var(--sans);
  color: color-mix(in srgb, var(--text) 70%, transparent);
  margin: 0 0 1.5rem;
}
.sc-error-code {
  font: 600 0.85rem/1 var(--mono);
  color: var(--accent);
  margin: 0 0 1rem;
}
.sc-error-code code {
  padding: 0.25rem 0.6rem;
  background: rgba(255, 107, 74, 0.15);
  border-radius: 999px;
}
.sc-error-detail {
  font: 400 0.9rem/1.45 var(--sans);
  color: color-mix(in srgb, var(--text) 60%, transparent);
  margin: 0 0 2rem;
}
.sc-error-actions {
  display: flex;
  gap: 0.75rem;
  justify-content: center;
  flex-wrap: wrap;
}
.sc-error-cta {
  padding: 0.75rem 1.5rem;
  border-radius: var(--radius-md, 10px);
  background: var(--accent);
  color: #0c1116;
  font: 600 0.9rem/1 var(--sans);
  text-decoration: none;
}
.sc-error-cta:hover { filter: brightness(1.08); }
.sc-error-cta--ghost {
  background: transparent;
  color: var(--text);
  border: 1px solid color-mix(in srgb, var(--text) 25%, transparent);
}
.sc-error-cta--ghost:hover {
  background: color-mix(in srgb, var(--text) 8%, transparent);
}

/* ============ SHARE-TO-FRIEND BUTTON ============
   The Share button on event cards (Phase B9). Lives in the action row
   alongside Pin/Archive/Delete, but warrants a softer coral tint to
   pull the eye — virality is the value.
   ================================================== */
.sc-share-btn {
  color: var(--accent);
}
.sc-share-btn:hover {
  background: rgba(255, 107, 74, 0.10);
  border-color: rgba(255, 107, 74, 0.30);
}

/* ============ LEGAL PAGES (Privacy / Terms) ============ */
.sc-legal {
  max-width: 42rem;
  margin: 3rem auto 4rem;
  padding: 0 1.25rem;
  font-family: var(--sans);
  color: var(--text);
  line-height: 1.6;
}
.sc-legal-back {
  font: 400 0.85rem/1.4 var(--sans);
  color: color-mix(in srgb, var(--text) 55%, transparent);
  margin: 0 0 1.5rem;
}
.sc-legal-back a { color: var(--accent); text-decoration: none; }
.sc-legal-back a:hover { text-decoration: underline; }
.sc-legal-title {
  font: italic 600 2.25rem/1.15 var(--serif);
  margin: 0 0 0.4rem;
}
.sc-legal-effective {
  font: 400 0.85rem/1 var(--sans);
  color: color-mix(in srgb, var(--text) 55%, transparent);
  margin: 0 0 2rem;
}
.sc-legal-lede {
  font: italic 400 1.1rem/1.55 var(--serif);
  color: color-mix(in srgb, var(--text) 85%, transparent);
  margin: 0 0 2rem;
  padding: 1rem 1.25rem;
  border-left: 3px solid var(--accent);
  background: rgba(255, 107, 74, 0.05);
  border-radius: 0 var(--radius-md, 10px) var(--radius-md, 10px) 0;
}
.sc-legal h2 {
  font: italic 600 1.35rem/1.3 var(--serif);
  margin: 2rem 0 0.75rem;
  color: var(--text);
}
.sc-legal p, .sc-legal li {
  font: 400 0.95rem/1.55 var(--sans);
  color: color-mix(in srgb, var(--text) 80%, transparent);
}
.sc-legal ul {
  padding-left: 1.25rem;
  margin: 0.75rem 0 1.25rem;
}
.sc-legal li { margin-bottom: 0.35rem; }
.sc-legal a {
  color: var(--accent);
  text-decoration: underline;
  text-underline-offset: 2px;
}
.sc-legal a:hover { color: color-mix(in srgb, var(--accent) 80%, var(--text)); }
.sc-legal code {
  font: 400 0.85em/1 var(--mono);
  padding: 0.1rem 0.4rem;
  border-radius: 4px;
  background: rgba(255, 255, 255, 0.06);
  color: var(--text);
}
.sc-legal-table {
  width: 100%;
  border-collapse: collapse;
  margin: 1rem 0 1.5rem;
  font: 400 0.85rem/1.45 var(--sans);
}
.sc-legal-table th,
.sc-legal-table td {
  text-align: left;
  vertical-align: top;
  padding: 0.6rem 0.75rem;
  border-bottom: 1px solid color-mix(in srgb, var(--text) 12%, transparent);
}
.sc-legal-table th {
  font: 600 0.8rem/1.3 var(--sans);
  color: var(--text);
  background: rgba(255, 107, 74, 0.06);
  letter-spacing: 0.02em;
}
.sc-legal-table td {
  color: color-mix(in srgb, var(--text) 75%, transparent);
}
.sc-legal-footer {
  margin-top: 3rem;
  padding-top: 1.5rem;
  border-top: 1px solid color-mix(in srgb, var(--text) 12%, transparent);
  text-align: center;
  font: 400 0.85rem/1.4 var(--sans);
  color: color-mix(in srgb, var(--text) 60%, transparent);
}

/* ============ COOKIE CONSENT BANNER (Phase D3) ============
   Shown once on first /snap visit until user accepts the single
   essential cookie. Sticky at the bottom; coral CTA.
   ============================================================ */
.sc-consent {
  position: fixed;
  left: 0; right: 0;
  bottom: env(safe-area-inset-bottom, 0);
  z-index: 999;
  padding: 1rem 1.25rem calc(1rem + env(safe-area-inset-bottom, 0));
  background: rgba(12, 17, 22, 0.95);
  border-top: 1px solid rgba(255, 107, 74, 0.30);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  font: 400 0.85rem/1.45 var(--sans);
  color: var(--text);
  animation: sc-consent-in 240ms cubic-bezier(.2,.7,.2,1) both;
}
@media (min-width: 540px) {
  .sc-consent {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    gap: 1.25rem;
  }
}
.sc-consent-body { flex: 1; }
.sc-consent-body a {
  color: var(--accent);
  text-decoration: underline;
  text-underline-offset: 2px;
}
.sc-consent-cta {
  padding: 0.6rem 1.25rem;
  border: 0;
  border-radius: var(--radius-md, 10px);
  background: var(--accent);
  color: #0c1116;
  font: 600 0.85rem/1 var(--sans);
  cursor: pointer;
  white-space: nowrap;
}
.sc-consent-cta:hover { filter: brightness(1.08); }
@keyframes sc-consent-in {
  from { transform: translateY(100%); opacity: 0; }
  to   { transform: translateY(0);    opacity: 1; }
}

/* ============ FEEDBACK SHEET (Phase 1.0.1) ============
   Reuses the account-sheet container; new template for the form.
   Type picker (radio chip group), textarea, optional email, submit.
   ====================================================== */
.sc-sheet-head {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 0.5rem;
}
.sc-sheet-back {
  width: 2rem;
  height: 2rem;
  border: 0;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.06);
  color: var(--text);
  font: 500 1.1rem/1 var(--sans);
  cursor: pointer;
  transition: background 120ms;
}
.sc-sheet-back:hover { background: rgba(255, 255, 255, 0.12); }
.sc-sheet-lede {
  margin: 0 0 1.25rem;
  font: italic 400 0.95rem/1.5 var(--serif);
  color: color-mix(in srgb, var(--text) 75%, transparent);
}

.sc-fb-kinds {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.5rem;
  margin-bottom: 1rem;
}
@media (min-width: 420px) {
  .sc-fb-kinds { grid-template-columns: repeat(4, 1fr); }
}
.sc-fb-kind {
  padding: 0.65rem 0.5rem;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid color-mix(in srgb, var(--text) 12%, transparent);
  border-radius: var(--radius-md, 10px);
  color: var(--text);
  font: 500 0.85rem/1.2 var(--sans);
  cursor: pointer;
  transition: all 140ms;
  text-align: center;
}
.sc-fb-kind:hover {
  background: rgba(255, 255, 255, 0.08);
  border-color: color-mix(in srgb, var(--text) 25%, transparent);
}
.sc-fb-kind.is-selected {
  background: var(--accent-soft, rgba(255, 107, 74, 0.15));
  border-color: var(--accent);
  color: var(--accent);
}
.sc-fb-label {
  display: block;
  margin: 0.75rem 0 0.35rem;
  font: 500 0.78rem/1.2 var(--sans);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: color-mix(in srgb, var(--text) 55%, transparent);
}
.sc-fb-label-mute {
  text-transform: none;
  font-weight: 400;
  letter-spacing: 0;
  color: color-mix(in srgb, var(--text) 40%, transparent);
}
.sc-fb-textarea,
.sc-fb-email {
  width: 100%;
  padding: 0.75rem 0.85rem;
  border-radius: var(--radius-md, 10px);
  border: 1px solid color-mix(in srgb, var(--text) 18%, transparent);
  background: rgba(0, 0, 0, 0.20);
  color: var(--text);
  font: 400 0.95rem/1.5 var(--sans);
  resize: vertical;
}
.sc-fb-textarea:focus,
.sc-fb-email:focus {
  outline: none;
  border-color: var(--accent);
  background: rgba(0, 0, 0, 0.30);
}
.sc-fb-textarea {
  min-height: 7rem;
  font-family: var(--sans);
}
.sc-sheet-foot.ok  { color: var(--ok); }
.sc-sheet-foot.err { color: var(--accent); }

/* ============ EMPTY-STATE FEEDBACK LINK (Phase 1.0.1) ============ */
.sc-empty-feedback {
  margin: 1.5rem 0 0;
  padding: 1rem 1.25rem;
  border-top: 1px solid color-mix(in srgb, var(--text) 10%, transparent);
  font: 400 0.85rem/1.4 var(--sans);
  color: color-mix(in srgb, var(--text) 60%, transparent);
  text-align: center;
}
.sc-empty-feedback a {
  color: var(--accent);
  font-weight: 500;
  text-decoration: none;
  border-bottom: 1px dashed color-mix(in srgb, var(--accent) 50%, transparent);
}
.sc-empty-feedback a:hover {
  color: color-mix(in srgb, var(--accent) 80%, white);
  border-bottom-style: solid;
}

/* ============================================================
   v1.0.1 — MINI-APP VISUAL POLISH
   Pure CSS additions; no HTML/JS changes required. Respects
   prefers-reduced-motion. Layer over existing tokens.
   ============================================================ */

/* Loading state — coral shimmer instead of plain "loading…" text */
.sc-loading {
  position: relative;
  padding: 2rem 1rem;
  text-align: center;
  color: var(--muted);
  font: 500 0.78rem/1 var(--mono);
  letter-spacing: 0.1em;
  text-transform: uppercase;
}
@media (prefers-reduced-motion: no-preference) {
  .sc-loading::before {
    content: "";
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 2px;
    border-radius: 999px;
    background: linear-gradient(90deg,
      transparent 0%,
      color-mix(in srgb, var(--accent) 80%, transparent) 50%,
      transparent 100%);
    animation: sc-loading-bar 1.4s ease-in-out infinite;
  }
}
@keyframes sc-loading-bar {
  0%   { transform: translateX(-100%); }
  100% { transform: translateX(100%); }
}

/* Status pill — soft pulse when loading */
@media (prefers-reduced-motion: no-preference) {
  .sc-status.loading {
    animation: sc-status-pulse 1.6s ease-in-out infinite;
  }
}
@keyframes sc-status-pulse {
  0%, 100% { opacity: 0.65; }
  50%      { opacity: 1; }
}

/* Note + event cards — subtle hover lift on capable devices */
@media (hover: hover) and (pointer: fine) {
  .sc-note {
    transition: transform 200ms cubic-bezier(.2,.7,.2,1),
                border-color 200ms, box-shadow 200ms;
  }
  .sc-note:hover {
    transform: translateY(-2px);
    border-color: color-mix(in srgb, var(--accent) 25%, var(--border));
    box-shadow: 0 1px 0 rgba(255, 255, 255, 0.04) inset,
                0 12px 24px -8px rgba(0, 0, 0, 0.35);
  }
}

/* Greeting — small accent dot before "Good evening" */
.sc-hello::before {
  content: "";
  display: inline-block;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--accent);
  margin-right: 0.5rem;
  vertical-align: middle;
  box-shadow: 0 0 8px var(--accent-glow);
}

/* Up-next card — slow shimmer along the top stripe */
@media (prefers-reduced-motion: no-preference) {
  .sc-upnext::before {
    background-size: 200% 100%;
    animation: sc-upnext-shimmer 6s linear infinite;
  }
}
@keyframes sc-upnext-shimmer {
  0%   { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

/* Action buttons — softer pressed state */
.sc-action:active,
.sc-cta-cal:active {
  transform: scale(0.97);
}

/* Empty state — gentle coral glow on the icon */
@media (prefers-reduced-motion: no-preference) {
  .sc-empty-icon::after {
    content: "";
    position: absolute;
    inset: -8px;
    border-radius: 50%;
    background: radial-gradient(circle, var(--accent-glow) 0%, transparent 70%);
    z-index: -1;
    animation: sc-empty-pulse 4s ease-in-out infinite;
  }
}
.sc-empty-icon { position: relative; z-index: 0; }
@keyframes sc-empty-pulse {
  0%, 100% { opacity: 0.5; transform: scale(1); }
  50%      { opacity: 0.85; transform: scale(1.06); }
}

/* Filter pills — smoother active swap */
.sc-filter {
  transition: background 180ms, color 180ms, border-color 180ms,
              transform 120ms;
}
.sc-filter:active { transform: scale(0.97); }

/* Focus rings — accessibility everywhere */
button:focus-visible,
a:focus-visible,
input:focus-visible,
textarea:focus-visible,
select:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
  border-radius: var(--radius-sm);
}

/* Reduced motion — kill all the wobbles */
@media (prefers-reduced-motion: reduce) {
  .sc-loading::before,
  .sc-status.loading,
  .sc-upnext::before,
  .sc-empty-icon::after {
    animation: none;
  }
  .sc-note { transition: none; }
}

/* ============ CalDAV SUBSCRIPTION SHEET (Phase 1.1) ============ */
.sc-cd-url-block {
  margin-bottom: 1.25rem;
}
.sc-cd-url {
  padding: 0.85rem 1rem;
  background: rgba(0, 0, 0, 0.30);
  border: 1px solid color-mix(in srgb, var(--text) 18%, transparent);
  border-radius: var(--radius);
  margin-bottom: 0.6rem;
  word-break: break-all;
  overflow-wrap: break-word;
}
.sc-cd-url code {
  font: 400 0.78rem/1.45 var(--mono);
  color: var(--text);
  background: transparent;
  padding: 0;
  display: block;
}
.sc-cd-url-actions {
  display: flex;
  gap: 0.5rem;
}
.sc-cd-url-actions button {
  flex: 1;
}
.sc-sheet-btn.is-success {
  background: var(--ok);
  border-color: var(--ok);
  color: #0c1116;
}

.sc-cd-help {
  margin: 0.5rem 0 1rem;
  padding: 0.75rem 1rem;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid color-mix(in srgb, var(--text) 10%, transparent);
  border-radius: var(--radius);
}
.sc-cd-help summary {
  cursor: pointer;
  font: 500 0.85rem/1.4 var(--sans);
  color: var(--text);
  list-style: none;
  user-select: none;
  padding: 0.25rem 0;
}
.sc-cd-help summary::before {
  content: "▸ ";
  color: var(--accent);
  display: inline-block;
  transition: transform 180ms;
  font-size: 0.85em;
}
.sc-cd-help[open] summary::before { content: "▾ "; }
.sc-cd-help summary::-webkit-details-marker { display: none; }

.sc-cd-providers {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  padding-top: 0.85rem;
}
.sc-cd-provider strong {
  display: block;
  font: 600 0.9rem/1.3 var(--sans);
  color: var(--text);
  margin-bottom: 0.4rem;
}
.sc-cd-provider ol {
  margin: 0;
  padding-left: 1.25rem;
  font: 400 0.83rem/1.55 var(--sans);
  color: color-mix(in srgb, var(--text) 75%, transparent);
}
.sc-cd-provider li { margin-bottom: 0.15rem; }
.sc-cd-provider a {
  color: var(--accent);
  text-decoration: underline;
  text-underline-offset: 2px;
}

.sc-cd-danger {
  margin-top: 1.25rem;
  padding-top: 1.25rem;
  border-top: 1px solid color-mix(in srgb, var(--text) 10%, transparent);
}

/* ============ SECONDARY FILTER CHIPS (Phase 1.1) ============
   The primary kind/intent chips strip stays as-is. Below it, we
   render a category strip and a city strip — both hidden until
   ≥2 distinct categories or cities exist. They scroll horizontally
   on overflow to support travel-heavy users (many cities).
   ============================================================ */
.sc-filters-secondary {
  display: flex;
  gap: 0.4rem;
  margin-top: -0.4rem;      /* tuck closer to the primary strip */
  margin-bottom: 1rem;
  padding-bottom: 0.4rem;
  overflow-x: auto;
  scrollbar-width: none;    /* Firefox: hide */
  -ms-overflow-style: none; /* IE/Edge: hide */
  flex-wrap: nowrap;
  scroll-snap-type: x proximity;
}
.sc-filters-secondary::-webkit-scrollbar { display: none; }
.sc-filters-secondary[hidden] { display: none; }

/* Category-row chip — softer than the primary chips so the
   category strip reads as "secondary filter," not "main filter." */
.sc-chip-cat, .sc-chip-city, .sc-chip-meta {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.45rem 0.75rem;
  font: 500 0.78rem/1 var(--sans);
  letter-spacing: 0.01em;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--text) 12%, transparent);
  background: rgba(255, 255, 255, 0.025);
  color: var(--text-2);
  cursor: pointer;
  scroll-snap-align: start;
  transition: background 140ms, border-color 140ms, color 140ms;
}
.sc-chip-cat:hover, .sc-chip-city:hover, .sc-chip-meta:hover {
  background: rgba(255, 255, 255, 0.05);
  border-color: color-mix(in srgb, var(--text) 22%, transparent);
  color: var(--text);
}
.sc-chip-cat.active, .sc-chip-city.active, .sc-chip-meta.active {
  background: var(--accent-trace);
  border-color: var(--accent);
  color: var(--accent);
}
.sc-chip-meta {
  font-style: italic;
  font-weight: 400;
  font-family: var(--serif);
  color: var(--muted);
}
.sc-chip-meta.active {
  color: var(--accent);
  background: var(--accent-trace);
  border-color: var(--accent);
}

/* Tiny count badge on each chip */
.sc-chip-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.25rem;
  height: 1rem;
  padding: 0 0.3rem;
  font: 600 0.65rem/1 var(--mono);
  border-radius: 999px;
  background: color-mix(in srgb, var(--text) 10%, transparent);
  color: var(--text-2);
}
.sc-chip-cat.active .sc-chip-count,
.sc-chip-city.active .sc-chip-count {
  background: var(--accent);
  color: #0c1116;
}

/* ============ TIPS & TRICKS SHEET (Phase 1.1) ============ */
.sc-tips-list {
  list-style: none;
  margin: 0 0 1rem;
  padding: 0;
  counter-reset: sctip;
}
.sc-tips-list li {
  counter-increment: sctip;
  position: relative;
  margin: 0 0 0.85rem;
  padding: 0.85rem 1rem 0.85rem 2.5rem;
  background: rgba(255, 255, 255, 0.025);
  border: 1px solid color-mix(in srgb, var(--text) 10%, transparent);
  border-radius: var(--radius);
  font: 400 0.88rem/1.5 var(--sans);
  color: var(--text-2);
}
.sc-tips-list li::before {
  content: counter(sctip);
  position: absolute;
  left: 0.85rem;
  top: 0.85rem;
  width: 1.25rem;
  height: 1.25rem;
  border-radius: 50%;
  background: var(--accent-trace);
  border: 1px solid var(--accent-line, color-mix(in srgb, var(--accent) 40%, transparent));
  color: var(--accent);
  font: 600 0.7rem/1.25rem var(--mono);
  text-align: center;
}
.sc-tips-list li strong {
  color: var(--text);
  font-weight: 600;
}
.sc-tips-list li code {
  font: 400 0.82em/1 var(--mono);
  padding: 0.1em 0.4em;
  background: rgba(0, 0, 0, 0.30);
  border-radius: 4px;
  color: var(--text);
}
.sc-tips-list li em {
  font: italic 500 inherit/inherit var(--serif);
  color: var(--accent);
}

/* ============ INSTALL SHEET (Phase 1.2 — widgets) ============ */
.sc-install-tabs {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.5rem;
  margin-bottom: 1rem;
}
.sc-install-tab {
  padding: 0.65rem 0.5rem;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid color-mix(in srgb, var(--text) 12%, transparent);
  border-radius: var(--radius-md, 10px);
  color: var(--text);
  font: 500 0.85rem/1.2 var(--sans);
  cursor: pointer;
  text-align: center;
  transition: all 140ms;
}
.sc-install-tab:hover {
  background: rgba(255, 255, 255, 0.08);
  border-color: color-mix(in srgb, var(--text) 22%, transparent);
}
.sc-install-tab.is-selected {
  background: var(--accent-trace, rgba(255, 107, 74, 0.15));
  border-color: var(--accent);
  color: var(--accent);
}

.sc-install-panel { padding-top: 0.25rem; }
.sc-install-panel[hidden] { display: none; }

.sc-install-h {
  font: italic 600 0.95rem/1.3 var(--serif);
  color: var(--text);
  margin: 1.1rem 0 0.4rem;
}
.sc-install-h:first-child { margin-top: 0; }

.sc-install-steps {
  margin: 0 0 0.85rem;
  padding-left: 1.5rem;
  font: 400 0.88rem/1.55 var(--sans);
  color: var(--text-2);
}
.sc-install-steps li {
  margin-bottom: 0.25rem;
}
.sc-install-steps strong, .sc-install-panel strong {
  color: var(--text);
}
.sc-install-steps em, .sc-install-panel em {
  font-style: italic;
  color: var(--accent);
}
.sc-install-steps code, .sc-install-panel code {
  font: 400 0.82em/1.4 var(--mono);
  padding: 0.1em 0.4em;
  background: rgba(0, 0, 0, 0.30);
  border-radius: 4px;
  color: var(--text);
  word-break: break-all;
}

.sc-install-url {
  display: block;
  margin: 0.6rem 0;
  padding: 0.7rem 0.85rem;
  background: rgba(0, 0, 0, 0.30);
  border: 1px solid color-mix(in srgb, var(--text) 18%, transparent);
  border-radius: var(--radius-md, 10px);
  font: 400 0.75rem/1.45 var(--mono);
  color: var(--text);
  word-break: break-all;
  overflow-wrap: break-word;
}

.sc-install-note {
  margin: 0.85rem 0;
  padding: 0.75rem 0.9rem;
  background: rgba(255, 255, 255, 0.025);
  border-left: 3px solid var(--accent);
  border-radius: 0 var(--radius-md, 10px) var(--radius-md, 10px) 0;
  font: 400 0.85rem/1.45 var(--sans);
  color: var(--text-2);
}
.sc-install-note strong { color: var(--text); }
.sc-install-note .sc-sheet-btn { margin-top: 0.6rem; }
