@import url('https://fonts.googleapis.com/css2?family=Instrument+Serif:ital@0;1&family=Geist:wght@300;400;500;600&family=Geist+Mono:wght@300;400;500&family=Dancing+Script:wght@600;700&display=swap');

/* Global Pebble token layer that overrides legacy token families */
:root,
:root:not([data-theme]),
[data-theme="light"] {
    --pebble-champagne: #F3EEE3;
    --pebble-forest: #1B2B24;
    --pebble-gold: #C48A4E;
    --pebble-rose: #C4756A;
    --pebble-ink-soft: #4A5E55;
    --pebble-ink-muted: #8A9E95;
    --pebble-surface: rgba(255, 255, 255, 0.78);
    --pebble-border: rgba(27, 43, 36, 0.12);

    /* Shared app tokens */
    --bg-app: var(--pebble-champagne);
    --bg-surface: #ffffff;
    --bg-surface-hover: #F7F2E9;
    --bg-surface-active: #EFE8DB;
    --bg-overlay: rgba(243, 238, 227, 0.9);

    --text-primary: var(--pebble-forest);
    --text-secondary: var(--pebble-ink-soft);
    --text-tertiary: var(--pebble-ink-muted);
    --text-inverse: var(--pebble-champagne);

    --border-subtle: rgba(27, 43, 36, 0.08);
    --border-default: var(--pebble-border);
    --border-hover: rgba(27, 43, 36, 0.2);
    --border-active: var(--pebble-gold);

    --accent-primary: var(--pebble-gold);
    --accent-primary-hover: #AB7740;
    --accent-primary-subtle: rgba(196, 138, 78, 0.12);

    --color-success: #5FA26B;
    --color-warning: #C48A4E;
    --color-error: var(--pebble-rose);
    --color-info: var(--pebble-ink-soft);

    --shadow-sm: 0 8px 18px rgba(27, 43, 36, 0.08);
    --shadow-md: 0 14px 30px rgba(27, 43, 36, 0.12);
    --shadow-lg: 0 20px 42px rgba(27, 43, 36, 0.16);

    /* Legacy aliases: cosmic */
    --cosmic-bg-light: var(--bg-app);
    --cosmic-accent-violet: var(--pebble-gold);
    --cosmic-accent-cyan: var(--pebble-forest);
    --cosmic-accent-blue: var(--pebble-gold);
    --cosmic-text-primary: var(--text-primary);
    --cosmic-text-secondary: var(--text-secondary);
    --cosmic-card-bg: var(--pebble-surface);
    --cosmic-card-border: var(--pebble-border);
    --cosmic-card-hover: #ffffff;
    --cosmic-sidebar-bg: rgba(255, 255, 255, 0.74);
    --cosmic-shadow-sm: var(--shadow-sm);
    --cosmic-shadow-md: var(--shadow-md);
    --cosmic-shadow-lg: var(--shadow-lg);

    /* Legacy aliases: auth/legal */
    --auth-bg-light: var(--bg-app);
    --auth-accent-violet: var(--pebble-gold);
    --auth-accent-cyan: var(--pebble-forest);
    --auth-accent-blue: var(--pebble-gold);
    --auth-text-primary: var(--text-primary);
    --auth-text-secondary: var(--text-secondary);
    --auth-border: var(--pebble-border);

    /* Legacy aliases: marketing/index variants */
    --bg: var(--bg-app);
    --bg2: #EDE6DA;
    --surface: rgba(255, 255, 255, 0.75);
    --surface2: rgba(255, 255, 255, 0.88);
    --border: var(--pebble-border);
    --border2: rgba(27, 43, 36, 0.22);
    --mint: var(--pebble-forest);
    --mint-bright: var(--pebble-gold);
    --mint-dim: rgba(27, 43, 36, 0.08);
    --mint-glow: rgba(196, 138, 78, 0.16);
    --violet: var(--pebble-gold);
    --ice: var(--pebble-rose);
    --text-1: var(--text-primary);
    --text-2: var(--text-secondary);
    --text-3: var(--text-tertiary);
    --accent-violet: var(--pebble-gold);
    --accent-cyan: var(--pebble-forest);
    --accent-blue: var(--pebble-gold);

    /* Legacy aliases: practice */
    --color-primary: var(--pebble-gold);
    --color-primary-dark: #9F6E3D;
    --color-primary-light: #D8B081;
    --color-secondary: var(--pebble-forest);
    --color-accent: var(--pebble-gold);
    --color-bg-primary: var(--bg-app);
    --color-bg-secondary: var(--bg-surface);
    --color-bg-tertiary: #EFE8DB;
    --color-surface: rgba(255, 255, 255, 0.74);
    --color-surface-hover: rgba(255, 255, 255, 0.9);
    --color-border: var(--border-default);
    --color-border-light: var(--border-subtle);
    --color-text-primary: var(--text-primary);
    --color-text-secondary: var(--text-secondary);
    --color-text-tertiary: var(--text-tertiary);
}

[data-theme="dark"] {
    --bg-app: #1B2B24;
    --bg-surface: rgba(15, 26, 21, 0.92);
    --bg-surface-hover: rgba(27, 43, 36, 0.9);
    --bg-surface-active: rgba(27, 43, 36, 0.8);
    --bg-overlay: rgba(15, 26, 21, 0.88);

    --text-primary: #F3EEE3;
    --text-secondary: #D1D7D3;
    --text-tertiary: rgba(243, 238, 227, 0.62);
    --text-inverse: #1B2B24;

    --border-subtle: rgba(243, 238, 227, 0.06);
    --border-default: rgba(243, 238, 227, 0.14);
    --border-hover: rgba(243, 238, 227, 0.2);
    --border-active: #C48A4E;

    --accent-primary: #C48A4E;
    --accent-primary-hover: #D8A567;
    --accent-primary-subtle: rgba(196, 138, 78, 0.18);

    --color-success: #74B488;
    --color-warning: #D4A568;
    --color-error: #C4756A;
    --color-info: #D1D7D3;

    --shadow-sm: 0 10px 20px rgba(0, 0, 0, 0.26);
    --shadow-md: 0 16px 34px rgba(0, 0, 0, 0.34);
    --shadow-lg: 0 24px 48px rgba(0, 0, 0, 0.4);

    --cosmic-bg-light: var(--bg-app);
    --cosmic-accent-violet: var(--accent-primary);
    --cosmic-accent-cyan: var(--accent-primary);
    --cosmic-accent-blue: var(--accent-primary);
    --cosmic-text-primary: var(--text-primary);
    --cosmic-text-secondary: var(--text-secondary);
    --cosmic-card-bg: rgba(15, 26, 21, 0.82);
    --cosmic-card-border: var(--border-default);
    --cosmic-card-hover: rgba(27, 43, 36, 0.9);
    --cosmic-sidebar-bg: rgba(15, 26, 21, 0.88);

    --auth-bg-light: var(--bg-app);
    --auth-accent-violet: var(--accent-primary);
    --auth-accent-cyan: var(--accent-primary);
    --auth-accent-blue: var(--accent-primary);
    --auth-text-primary: var(--text-primary);
    --auth-text-secondary: var(--text-secondary);
    --auth-border: var(--border-default);

    --bg: var(--bg-app);
    --bg2: #14231D;
    --surface: rgba(15, 26, 21, 0.82);
    --surface2: rgba(27, 43, 36, 0.82);
    --border: var(--border-default);
    --border2: rgba(243, 238, 227, 0.22);
    --mint: #F3EEE3;
    --mint-bright: #C48A4E;
    --mint-dim: rgba(243, 238, 227, 0.08);
    --mint-glow: rgba(196, 138, 78, 0.2);
    --violet: #C48A4E;
    --ice: #C4756A;
    --text-1: var(--text-primary);
    --text-2: var(--text-secondary);
    --text-3: var(--text-tertiary);
    --accent-violet: var(--accent-primary);
    --accent-cyan: var(--accent-primary);
    --accent-blue: var(--accent-primary);

    --color-primary: var(--pebble-rose);
    --color-primary-dark: #A95F57;
    --color-primary-light: #D89F98;
    --color-secondary: var(--pebble-gold);
    --color-accent: var(--pebble-rose);
    --color-bg-primary: var(--bg-app);
    --color-bg-secondary: var(--bg-surface);
    --color-bg-tertiary: rgba(27, 43, 36, 0.9);
    --color-surface: rgba(15, 26, 21, 0.82);
    --color-surface-hover: rgba(27, 43, 36, 0.92);
    --color-border: var(--border-default);
    --color-border-light: var(--border-subtle);
    --color-text-primary: var(--text-primary);
    --color-text-secondary: var(--text-secondary);
    --color-text-tertiary: var(--text-tertiary);
}

html,
body {
    background: var(--bg-app) !important;
    color: var(--text-primary) !important;
    font-family: 'Geist', system-ui, -apple-system, sans-serif !important;
}

h1,
h2,
h3,
h4,
h5,
h6,
.page-title,
.hero-title,
.session-title,
.auth-title,
.section-h2,
.f-title,
.step-title {
    font-family: 'Instrument Serif', Georgia, serif !important;
    font-style: italic !important;
    font-weight: 400 !important;
    letter-spacing: -0.025em !important;
}

.micro-label,
.section-label,
.step-label,
.hud-label,
.metric-label,
.stat-label,
.eyebrow,
.hero-kicker {
    font-family: 'Geist Mono', monospace !important;
    letter-spacing: 0.28em !important;
    text-transform: uppercase !important;
}

/* Readability mode for authenticated app screens */
body.post-login,
body.post-login p,
body.post-login li,
body.post-login label,
body.post-login input,
body.post-login button,
body.post-login a,
body.post-login span {
    font-family: 'Geist', system-ui, -apple-system, sans-serif !important;
}

body.post-login h1,
body.post-login h2,
body.post-login h3,
body.post-login h4,
body.post-login h5,
body.post-login h6,
body.post-login .page-title,
body.post-login .hero-title,
body.post-login .session-title,
body.post-login .auth-title,
body.post-login .section-h2,
body.post-login .f-title,
body.post-login .step-title {
    font-family: 'Geist', system-ui, -apple-system, sans-serif !important;
    font-style: normal !important;
    font-weight: 600 !important;
    letter-spacing: -0.012em !important;
}

body.post-login .micro-label,
body.post-login .section-label,
body.post-login .step-label,
body.post-login .hud-label,
body.post-login .metric-label,
body.post-login .stat-label,
body.post-login .eyebrow,
body.post-login .hero-kicker {
    font-family: 'Geist', system-ui, -apple-system, sans-serif !important;
    letter-spacing: 0.08em !important;
    font-weight: 500 !important;
    text-transform: uppercase !important;
}

.brand-cursive,
body.post-login .brand-cursive,
body.post-login span.brand-cursive,
body.post-login div.brand-cursive {
    font-family: 'Dancing Script', 'Segoe Script', 'Brush Script MT', cursive !important;
    font-style: normal !important;
    font-weight: 700 !important;
    letter-spacing: 0.01em !important;
    text-transform: lowercase !important;
    line-height: 1 !important;
}

.page-title {
    background: none !important;
    -webkit-text-fill-color: currentColor !important;
    color: var(--text-primary) !important;
}

.sidebar,
.nav,
.auth-card,
.action-card,
.history-section,
.panel,
.card,
.daily-modal {
    background: var(--bg-surface) !important;
    border-color: var(--border-default) !important;
    color: var(--text-primary) !important;
}

[data-theme="dark"] .sidebar,
[data-theme="dark"] .nav,
[data-theme="dark"] .auth-card,
[data-theme="dark"] .action-card,
[data-theme="dark"] .history-section,
[data-theme="dark"] .panel,
[data-theme="dark"] .card,
[data-theme="dark"] .daily-modal {
    background: var(--bg-surface) !important;
}

.user-avatar,
.nav-stone,
.stone-button {
    background: linear-gradient(135deg, #1B2B24, #C48A4E) !important;
}

.primary-action::before,
.secondary-action::before,
.progress-fill,
.hero-progress::before {
    background: linear-gradient(180deg, #C48A4E, #1B2B24) !important;
}

[data-theme="dark"] .primary-action::before,
[data-theme="dark"] .secondary-action::before,
[data-theme="dark"] .progress-fill,
[data-theme="dark"] .hero-progress::before {
    background: linear-gradient(180deg, #C48A4E, #C4756A) !important;
}

/* Remove old cosmic cyan/violet glow tones */
body::before {
    background: radial-gradient(circle at 14% 18%, rgba(196, 138, 78, 0.09), transparent 38%) !important;
}

body::after {
    background: radial-gradient(circle at 82% 72%, rgba(27, 43, 36, 0.07), transparent 45%) !important;
}

[data-theme="dark"] body::before {
    background: radial-gradient(circle at 16% 18%, rgba(196, 138, 78, 0.2), transparent 40%) !important;
}

[data-theme="dark"] body::after {
    background: radial-gradient(circle at 78% 70%, rgba(196, 117, 106, 0.2), transparent 50%) !important;
}

/* --------------------------------------------------------------------------
   Global Comfort Polish: spacing, rhythm, and safer controls across pages
   -------------------------------------------------------------------------- */
:root {
    --pebble-space-1: clamp(8px, 0.5vw, 10px);
    --pebble-space-2: clamp(12px, 0.8vw, 14px);
    --pebble-space-3: clamp(16px, 1.2vw, 20px);
    --pebble-space-4: clamp(20px, 1.8vw, 28px);
    --pebble-space-5: clamp(24px, 2.4vw, 36px);
    --pebble-content-max: 1280px;
}

main,
.page-shell,
.content-shell,
.feedback-shell,
.auth-shell {
    width: min(100%, var(--pebble-content-max));
    margin-inline: auto;
    padding-inline: var(--pebble-space-4);
}

.page-header {
    margin-bottom: var(--pebble-space-5) !important;
}

.page-subtitle,
.section-subtitle {
    max-width: 72ch;
    line-height: 1.55;
}

.dashboard-grid,
.grid,
.secondary-grid,
.top-grid {
    gap: var(--pebble-space-4) !important;
}

.card,
.action-card,
.history-section,
.daily-modal,
.auth-card,
.widget,
.insight-card {
    padding: var(--pebble-space-4) !important;
    border-radius: 20px !important;
}

.panel-header {
    padding: 14px 18px !important;
}

.panel-content {
    padding: var(--pebble-space-3) !important;
}

input[type="text"],
input[type="email"],
input[type="password"],
input[type="number"],
input[type="search"],
input[type="url"],
input[type="tel"],
select,
textarea {
    border-radius: 12px;
    min-height: 42px;
    padding: 10px 12px;
    border: 1px solid var(--border-default);
    background: var(--bg-surface);
    color: var(--text-primary);
}

textarea {
    min-height: 110px;
    resize: vertical;
}

button,
.btn,
.stone-button,
a.btn {
    min-height: 40px;
    padding-inline: 14px;
    border-radius: 12px;
}

.btn-group,
.panel-controls,
.form-row,
.field-row {
    gap: var(--pebble-space-2) !important;
}

.section + .section,
.card + .card,
.panel + .panel {
    margin-top: var(--pebble-space-3);
}

@media (max-width: 900px) {
    main,
    .page-shell,
    .content-shell,
    .feedback-shell,
    .auth-shell {
        padding-inline: var(--pebble-space-3);
    }

    .card,
    .action-card,
    .history-section,
    .daily-modal,
    .auth-card,
    .widget,
    .insight-card {
        padding: var(--pebble-space-3) !important;
    }
}
