@import url('https://fonts.googleapis.com/css2?family=Syne:wght@400;500;600;700;800&family=DM+Sans:ital,wght@0,300;0,400;0,500;1,300&display=swap');

/* ── Reset ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

/* ── Design tokens ── */
:root {
  --bg: #F5F2ED;
  --surface: #FDFCFA;
  --surface2: #F0EDE7;
  --border: rgba(60,52,40,0.12);
  --border-med: rgba(60,52,40,0.22);
  --text: #1E1A14;
  --text-2: #6B6358;
  --text-3: #857A70;
  --accent: #7B5CF0;
  --accent-light: #EDE8FD;
  --accent-dark: #5B3ED4;
  --teal: #0F6E56;
  --teal-light: #E4F5EE;
  --teal-mid: #1D9E75;
  --blue: #185FA5;
  --blue-light: #E6F1FB;
  --coral: #C4432A;
  --coral-light: #FDECEA;
  --amber: #B86800;
  --amber-light: #FEF3DC;
  --green: #1B7A5A;
  --green-light: #E4F5EE;
  --radius: 16px;
  --radius-sm: 10px;
  --shadow: 0 2px 16px rgba(30,26,20,0.08);
}

/* ── Dark mode ── */
[data-theme="dark"] {
  --bg: #000000;
  --surface: rgba(255,255,255,0.04);
  --surface2: rgba(255,255,255,0.07);
  --border: rgba(255,255,255,0.08);
  --border-med: rgba(255,255,255,0.14);
  --text: #FFFFFF;
  --text-2: rgba(255,255,255,0.65);
  --text-3: rgba(255,255,255,0.35);
  --accent-light: #2D2454;
  --teal-light: #0D2E26;
  --blue-light: #0D1E35;
  --coral-light: #2E1210;
  --amber-light: #2A1E06;
  --gold-light: #2A1E06;
  --accent-dark: #A78BFA;
  --shadow: 0 2px 24px rgba(0,0,0,0.8);
}
[data-theme="dark"] .app-nav-badge.pro { background: #2A1E06; color: #FCD49A; }
[data-theme="dark"] .global-nav-badge.pro { background: #2A1E06; color: #FCD49A; }

/* ── Scrollbars ── */
html, * { scrollbar-width: none; -ms-overflow-style: none; }
::-webkit-scrollbar { display: none; }

/* ── Base ── */
html { background: var(--bg, #F5F2ED); }
body { font-family: 'DM Sans', sans-serif; background: var(--bg); color: var(--text); min-height: 100vh; display: flex; align-items: flex-start; justify-content: center; }
.phone-frame { width: 100%; max-width: 420px; min-height: 100vh; background: var(--surface); display: flex; flex-direction: column; }

/* ── Overlay / bottom-sheet panel ── */
.overlay { position: fixed; inset: 0; background: rgba(0,0,0,0.85); backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px); z-index: 100; display: none; align-items: flex-end; justify-content: center; }
.overlay.open { display: flex; }
.panel { background: var(--surface); border-radius: 24px 24px 0 0; width: 100%; max-width: 420px; max-height: 90vh; overflow-y: auto; padding: 20px 20px 40px; animation: slideUp 0.3s ease; position: relative; }
@keyframes slideUp { from { transform: translateY(40px); opacity: 0; } to { transform: translateY(0); opacity: 1; } }
.panel-handle { width: 36px; height: 4px; background: var(--border-med); border-radius: 99px; margin: 0 auto 20px; }
.panel-title { font-family: 'Syne', sans-serif; font-size: 20px; font-weight: 700; letter-spacing: -0.3px; margin-bottom: 4px; }
.panel-sub { font-size: 13px; color: var(--text-2); margin-bottom: 24px; }
.close-btn { position: absolute; top: 16px; right: 20px; width: 32px; height: 32px; border-radius: 50%; background: var(--surface2); border: none; display: flex; align-items: center; justify-content: center; cursor: pointer; color: var(--text-2); }

/* ── Crisis panel content ── */
.crisis-resources { display: flex; flex-direction: column; gap: 10px; margin-bottom: 20px; }
.crisis-item { background: var(--surface2); border-radius: var(--radius-sm); padding: 14px 16px; display: flex; align-items: center; gap: 12px; }
.crisis-item-body { flex: 1; }
.crisis-item-name { font-size: 14px; font-weight: 500; color: var(--text); }
.crisis-item-detail { font-size: 12px; color: var(--text-2); margin-top: 2px; }
.crisis-call-btn { background: var(--coral-light); border: 1px solid rgba(196,67,42,0.2); border-radius: 8px; padding: 6px 12px; font-size: 12px; font-weight: 500; color: var(--coral); cursor: pointer; white-space: nowrap; display: flex; align-items: center; gap: 4px; }
.affirm-card { background: var(--accent-light); border: 1.5px solid rgba(123,92,240,0.15); border-radius: var(--radius); padding: 16px; text-align: center; margin-bottom: 16px; }
.affirm-card .icon-wrap { color: var(--accent-dark); display: flex; justify-content: center; margin-bottom: 8px; }
.affirm-text { font-size: 15px; color: var(--accent-dark); line-height: 1.6; font-style: italic; }

/* ── Crisis strip (inline footer bar) ── */
.crisis-strip { background: var(--surface2); border-top: 1px solid var(--border); padding: 12px 20px; display: flex; align-items: center; gap: 10px; cursor: pointer; transition: background 0.15s; }
.crisis-strip:hover { background: var(--coral-light); }
.crisis-text { font-size: 12px; color: var(--text-2); flex: 1; }
.crisis-text strong { color: var(--coral); font-weight: 500; }

/* ── Bottom nav ── */
.bottom-nav { background: var(--surface); border-top: 1px solid var(--border); display: flex; align-items: center; justify-content: space-around; padding: 10px 0 18px; position: sticky; bottom: 0; }
.nav-item { display: flex; flex-direction: column; align-items: center; gap: 3px; cursor: pointer; padding: 4px 10px; border-radius: 8px; transition: background 0.15s; color: var(--text-3); text-decoration: none; }
.nav-item:hover { background: var(--surface2); }
.nav-item.active { color: var(--accent-dark); }
.nav-label { font-size: 10px; font-weight: 500; color: inherit; }

/* ── Hamburger button ── */
.hamburger-btn { width: 34px; height: 34px; border-radius: var(--radius-sm); border: 1px solid var(--border); background: var(--surface); display: flex; align-items: center; justify-content: center; cursor: pointer; color: var(--text-2); transition: all 0.15s; flex-shrink: 0; }
.hamburger-btn:hover { background: var(--surface2); color: var(--accent-dark); }

/* ── App nav (global menu sheet) ── */
.app-nav-wrap { position: fixed; top: 0; bottom: 0; left: 50%; transform: translateX(-50%); width: 100%; max-width: 420px; z-index: 300; display: flex; flex-direction: column; justify-content: flex-end; pointer-events: none; }
.app-nav-backdrop { position: absolute; inset: 0; background: rgba(0,0,0,0); transition: background 0.35s ease; pointer-events: none; }
.app-nav-wrap.open { pointer-events: all; }
.app-nav-wrap.open .app-nav-backdrop { background: rgba(0,0,0,0.55); pointer-events: all; }
.app-nav-sheet { background: var(--surface); border-radius: 0; padding: 0 0 40px; transform: translateY(100%); transition: transform 0.4s cubic-bezier(0.32,0.72,0,1); max-height: 100dvh; overflow-y: auto; position: relative; z-index: 1; scrollbar-width: none; -ms-overflow-style: none; }
.app-nav-sheet::-webkit-scrollbar { display: none; }
.app-nav-wrap.open .app-nav-sheet { transform: translateY(0); }
.app-nav-handle-row { display: flex; align-items: center; justify-content: space-between; padding: 14px 20px 10px; border-bottom: 1px solid var(--border); }
.app-nav-handle { width: 36px; height: 4px; background: var(--border-med); border-radius: 99px; margin: 0 auto; }
.app-nav-logo { font-family: "Syne", sans-serif; font-size: 17px; font-weight: 700; color: var(--text); display: flex; align-items: center; gap: 7px; }
.app-nav-dot { width: 7px; height: 7px; background: var(--accent); border-radius: 50%; }
.app-nav-close { width: 30px; height: 30px; border-radius: 50%; border: none; background: var(--surface2); display: flex; align-items: center; justify-content: center; cursor: pointer; color: var(--text-2); }
.app-nav-section { padding: 14px 20px 0; }
.app-nav-section-label { font-size: 10px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.09em; color: var(--text-3); margin-bottom: 6px; }
.app-nav-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-bottom: 4px; }
.app-nav-tile { background: var(--bg); border-radius: var(--radius-sm); padding: 12px; display: flex; flex-direction: column; gap: 8px; text-decoration: none; transition: all 0.15s; border: 1.5px solid transparent; cursor: pointer; }
.app-nav-tile:hover, .app-nav-tile:active { border-color: var(--accent); background: var(--accent-light); }
.app-nav-tile-icon { width: 32px; height: 32px; border-radius: 8px; display: flex; align-items: center; justify-content: center; }
.app-nav-tile-title { font-size: 13px; font-weight: 500; color: var(--text); line-height: 1.3; }
.app-nav-tile-sub { font-size: 11px; color: var(--text-3); line-height: 1.3; margin-top: -4px; }
.app-nav-badge { font-size: 9px; padding: 2px 6px; border-radius: 99px; font-weight: 600; display: inline-block; margin-top: 2px; }
.app-nav-badge.ai { background: var(--accent-light); color: var(--accent-dark); }
.app-nav-badge.pro { background: #FEF6DC; color: #8A6200; }

/* ── Notification overlay ── */
.notif-overlay { display: none; position: fixed; inset: 0; z-index: 9999; flex-direction: column; justify-content: flex-end; align-items: center; background: rgba(0,0,0,0.5); }
.notif-overlay.open { display: flex; }
.notif-overlay.open .notif-panel { animation: slideUp 0.35s cubic-bezier(0.32,0.72,0,1) both; }
.notif-panel { background: var(--surface); border-radius: 20px 20px 0 0; width: 100%; max-width: 420px; min-height: 50vh; max-height: 80vh; overflow-y: auto; scrollbar-width: none; padding-bottom: 40px; }
.notif-top { position: sticky; top: 0; background: var(--surface); z-index: 2; }
.notif-handle-row { display: flex; justify-content: center; padding: 10px 0 6px; }
.notif-handle { width: 36px; height: 4px; background: var(--border-med); border-radius: 99px; }
.notif-header { display: flex; align-items: center; justify-content: space-between; padding: 2px 20px 12px; border-bottom: 1px solid var(--border); }
.notif-title-text { font-family: 'Syne', sans-serif; font-size: 17px; font-weight: 700; color: var(--text); }
.notif-close { width: 28px; height: 28px; border-radius: 50%; border: none; background: var(--surface2); display: flex; align-items: center; justify-content: center; cursor: pointer; color: var(--text-2); }
.notif-list { padding: 8px 0; }
.notif-item { display: flex; align-items: flex-start; gap: 12px; padding: 12px 20px; cursor: pointer; transition: background 0.15s; border-bottom: 1px solid var(--border); }
.notif-item:last-child { border-bottom: none; }
.notif-item:active { background: var(--surface2); }
.notif-item-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; margin-top: 5px; }
.notif-item-body { flex: 1; }
.notif-item-title { font-size: 14px; font-weight: 500; color: var(--text); }
.notif-item-sub { font-size: 12px; color: var(--text-3); margin-top: 2px; }
.notif-item-chevron { color: var(--text-3); flex-shrink: 0; align-self: center; }
.notif-item-unread { background: var(--surface2); }
.notif-item-unread .notif-item-title { font-weight: 600; }


/* ═══ DARK MODE — Black Glassmorphism ═══ */

/* Step 2 — Glass surface backdrop-filter on panels and cards */
[data-theme="dark"] .panel,
[data-theme="dark"] .notif-panel,
[data-theme="dark"] .app-nav-sheet,
[data-theme="dark"] .close-btn,
[data-theme="dark"] .notif-close,
[data-theme="dark"] .crisis-item,
[data-theme="dark"] .app-nav-tile {
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border: 1px solid rgba(255,255,255,0.09);
}

/* Step 3 — Bottom nav glassmorphism */
[data-theme="dark"] .bottom-nav {
  background: rgba(0,0,0,0.7);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  border-top: 1px solid rgba(255,255,255,0.08);
}

/* Step 4 — Buttons / tiles: glass outlined style */
[data-theme="dark"] .hamburger-btn,
[data-theme="dark"] .nav-item,
[data-theme="dark"] .app-nav-close,
[data-theme="dark"] .notif-close,
[data-theme="dark"] .close-btn,
[data-theme="dark"] .icon-btn {
  background: rgba(255,255,255,0.06);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid rgba(255,255,255,0.12);
}

/* Step 5 — Suppress all gradients in dark mode */
[data-theme="dark"] .hero,
[data-theme="dark"] .hero-bg,
[data-theme="dark"] [style*="gradient"] {
  background: #000000 !important;
  background-image: none !important;
}

/* Step 7 — App nav drawer glassmorphism */
[data-theme="dark"] .app-nav-sheet {
  background: rgba(0,0,0,0.85);
  backdrop-filter: blur(32px);
  -webkit-backdrop-filter: blur(32px);
  border-right: 1px solid rgba(255,255,255,0.08);
}

/* Step 8 — Notification panel and overlays */
[data-theme="dark"] .notif-panel,
[data-theme="dark"] .panel,
[data-theme="dark"] .gif-panel {
  background: rgba(0,0,0,0.85);
  backdrop-filter: blur(32px);
  -webkit-backdrop-filter: blur(32px);
  border-top: 1px solid rgba(255,255,255,0.10);
}

/* Step 9 — Tool tiles: color as left border, not fill */
[data-theme="dark"] .tool-tile { background: rgba(255,255,255,0.04); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); border: 1px solid rgba(255,255,255,0.09); }
[data-theme="dark"] .tool-tile.purple { border-left: 3px solid var(--accent); }
[data-theme="dark"] .tool-tile.teal   { border-left: 3px solid var(--teal); }
[data-theme="dark"] .tool-tile.coral  { border-left: 3px solid var(--coral); }
[data-theme="dark"] .tool-tile.amber  { border-left: 3px solid var(--amber); }
[data-theme="dark"] .tool-tile.blue   { border-left: 3px solid var(--blue); }

/* Step 10 — Premium frosted glass buttons (all app pages) */
[data-theme="dark"] .energy-btn,
[data-theme="dark"] .appt-card-action,
[data-theme="dark"] .insight-refresh,
[data-theme="dark"] .price-preview-btn,
[data-theme="dark"] .break-btn,
[data-theme="dark"] .send-btn,
[data-theme="dark"] .view-tab,
[data-theme="dark"] .tab-btn,
[data-theme="dark"] .action-btn,
[data-theme="dark"] .providers-cta {
  background: rgba(255,255,255,0.08) !important;
  backdrop-filter: blur(16px) !important;
  -webkit-backdrop-filter: blur(16px) !important;
  border: 1.5px solid rgba(255,255,255,0.15) !important;
  border-radius: 14px;
  color: #fff !important;
}
[data-theme="dark"] .appt-card-action { border-color: var(--accent) !important; }
[data-theme="dark"] .break-btn { border-color: var(--accent) !important; }
[data-theme="dark"] .providers-cta { border-color: var(--teal) !important; }

/* Step 11 — Bottom nav glass pills */
[data-theme="dark"] .nav-item {
  background: rgba(255,255,255,0.06) !important;
  backdrop-filter: blur(12px) !important;
  -webkit-backdrop-filter: blur(12px) !important;
  border: 1px solid rgba(255,255,255,0.1) !important;
  border-radius: 12px !important;
  padding: 8px 12px !important;
}

/* ═══ TOPBAR — Glass dark mode ═══ */
[data-theme="dark"] .topbar {
  background: rgba(0,0,0,0.85) !important;
  backdrop-filter: blur(20px) !important;
  -webkit-backdrop-filter: blur(20px) !important;
  border-bottom: 1px solid rgba(255,255,255,0.08) !important;
}

/* ═══ CARDS — Glass backdrop-filter ═══ */
[data-theme="dark"] .today-card,
[data-theme="dark"] .mood-card,
[data-theme="dark"] .appt-card,
[data-theme="dark"] .feat-card,
[data-theme="dark"] .stat-card,
[data-theme="dark"] .streak-bar,
[data-theme="dark"] .post-card,
[data-theme="dark"] .reward-card,
[data-theme="dark"] .badge-card,
[data-theme="dark"] .reminder-card,
[data-theme="dark"] .appt-item,
[data-theme="dark"] .provider-card,
[data-theme="dark"] .room-card,
[data-theme="dark"] .setting-row,
[data-theme="dark"] .milestone-item,
[data-theme="dark"] .match-card,
[data-theme="dark"] .entry-card,
[data-theme="dark"] .journal-card,
[data-theme="dark"] .note-card,
[data-theme="dark"] .section-card {
  backdrop-filter: blur(16px) !important;
  -webkit-backdrop-filter: blur(16px) !important;
}

/* ═══ BUTTONS — Extended glass coverage ═══ */
[data-theme="dark"] .connect-btn,
[data-theme="dark"] .disconnect-btn,
[data-theme="dark"] .key-save-btn,
[data-theme="dark"] .add-appt-btn,
[data-theme="dark"] .appt-join,
[data-theme="dark"] .book-strip-icon,
[data-theme="dark"] .room-join-btn,
[data-theme="dark"] .join-btn,
[data-theme="dark"] .ai-btn,
[data-theme="dark"] .generate-btn,
[data-theme="dark"] .copy-btn,
[data-theme="dark"] .regenerate-btn,
[data-theme="dark"] .book-btn,
[data-theme="dark"] .save-btn,
[data-theme="dark"] .confirm-btn,
[data-theme="dark"] .submit-btn,
[data-theme="dark"] .reflect-btn,
[data-theme="dark"] .start-btn,
[data-theme="dark"] .add-btn,
[data-theme="dark"] .celebrate-btn,
[data-theme="dark"] .pv-edit-btn,
[data-theme="dark"] .list-cta-btn,
[data-theme="dark"] .plan-cta,
[data-theme="dark"] .back-btn-top,
[data-theme="dark"] .energy-pill,
[data-theme="dark"] .period-tab,
[data-theme="dark"] .sort-btn,
[data-theme="dark"] .filter-btn,
[data-theme="dark"] .clear-btn,
[data-theme="dark"] .history-btn,
[data-theme="dark"] .sos-btn,
[data-theme="dark"] .back-btn,
[data-theme="dark"] .skip-btn,
[data-theme="dark"] .dismiss-btn,
[data-theme="dark"] .streak-pill {
  background: rgba(255,255,255,0.08) !important;
  backdrop-filter: blur(16px) !important;
  -webkit-backdrop-filter: blur(16px) !important;
  border: 1.5px solid rgba(255,255,255,0.15) !important;
  color: #fff !important;
}
/* Feature-colored borders for primary action buttons */
[data-theme="dark"] .generate-btn,
[data-theme="dark"] .submit-btn,
[data-theme="dark"] .save-btn,
[data-theme="dark"] .add-appt-btn,
[data-theme="dark"] .key-save-btn,
[data-theme="dark"] .connect-btn { border-color: var(--accent) !important; }
[data-theme="dark"] .start-btn,
[data-theme="dark"] .room-join-btn,
[data-theme="dark"] .join-btn { border-color: var(--teal) !important; }
[data-theme="dark"] .sos-btn { border-color: var(--coral) !important; }

/* ═══ FOCUS STATES — Accessibility (WCAG 2.1 AA) ═══ */
button:focus-visible,
a:focus-visible,
input:focus-visible,
textarea:focus-visible,
select:focus-visible,
[tabindex="0"]:focus-visible {
  outline: 2px solid var(--accent) !important;
  outline-offset: 2px;
}

/* ═══ TOUCH TARGETS — Min 44px (WCAG 2.5.5) ═══ */
.hamburger-btn,
.hero-notif,
.sos-btn,
.add-btn,
.appt-join,
.join-btn,
.room-join-btn,
.generate-btn,
.submit-btn,
.book-btn,
.plan-cta,
.nav-item { min-height: 44px; }

/* ═══ GRADIENT PURGE — Intentional exceptions: pitch hero kept ═══ */
[data-theme="dark"] .ai-card,
[data-theme="dark"] .streak-hero { background: rgba(255,255,255,0.04) !important; background-image: none !important; }
