:root {
    --font-sans: 'Inter', 'SF Pro Display', 'Segoe UI', -apple-system, BlinkMacSystemFont, 'Roboto', sans-serif;
    --font-serif: 'Cormorant Garamond', 'Playfair Display', 'Georgia', serif;
    --bg-primary: #020617;
    --bg-elevated: rgba(12, 20, 40, 0.82);
    --bg-subtle: rgba(15, 23, 42, 0.72);
    --bg-overlay: rgba(10, 16, 31, 0.65);
    --bg-card: rgba(15, 23, 42, 0.6);
    --bg-card-muted: rgba(12, 20, 40, 0.74);
    --bg-card-strong: rgba(12, 19, 40, 0.84);
    --bg-card-highlight: rgba(15, 23, 42, 0.78);
    --border-soft: rgba(148, 163, 234, 0.22);
    --border-strong: rgba(168, 85, 247, 0.28);
    --text-primary: #f8fafc;
    --text-secondary: #e0e7ff;
    --text-muted: #93a5d6;
    --text-invert: #020617;
    --accent-primary: #a855f7;
    --accent-secondary: #38bdf8;
    --accent-tertiary: #fbbf24;
    --accent-danger: #fb7185;
    --accent-success: #34d399;
    --radius-lg: 28px;
    --radius-md: 18px;
    --radius-sm: 12px;
    --shadow-xl: 0 40px 80px -45px rgba(15, 23, 42, 0.88);
    --shadow-lg: 0 28px 60px -35px rgba(15, 23, 42, 0.7);
    --shadow-md: 0 20px 40px -28px rgba(15, 23, 42, 0.6);
    --shadow-soft: 0 14px 35px -24px rgba(15, 23, 42, 0.55);
    --transition-fast: 160ms ease;
    --transition-base: 240ms ease;
    --blur-amount: 24px;
    --gradient-primary: linear-gradient(120deg, rgba(168, 85, 247, 0.95), rgba(56, 189, 248, 0.95));
    --gradient-primary-soft: linear-gradient(120deg, rgba(168, 85, 247, 0.3), rgba(56, 189, 248, 0.22));
    --button-disabled-bg: rgba(148, 163, 184, 0.25);
    --button-disabled-border: rgba(148, 163, 184, 0.28);
    --button-disabled-text: rgba(226, 232, 240, 0.6);
    --surface-panel-base: rgba(12, 19, 40, 0.88);
    --surface-panel-gradient-start: rgba(12, 19, 40, 0.82);
    --surface-panel-gradient-end: rgba(16, 24, 46, 0.78);
    --surface-panel-border: rgba(56, 189, 248, 0.28);
    --surface-panel-highlight: rgba(168, 85, 247, 0.18);
    --surface-panel-radial: rgba(56, 189, 248, 0.18);
    --surface-panel-glow: rgba(168, 85, 247, 0.28);
    --surface-panel-orb: rgba(251, 191, 36, 0.35);
    --surface-card-blur: 18px;
}

html[data-theme="light"] {
    --bg-primary: #f8fafc;
    --bg-elevated: rgba(255, 255, 255, 0.92);
    --bg-subtle: rgba(241, 245, 249, 0.72);
    --bg-overlay: rgba(255, 255, 255, 0.65);
    --bg-card: rgba(255, 255, 255, 0.97);
    --bg-card-muted: rgba(248, 250, 252, 0.94);
    --bg-card-strong: rgba(241, 245, 249, 0.94);
    --bg-card-highlight: rgba(236, 242, 247, 0.94);
    --border-soft: rgba(99, 102, 241, 0.18);
    --border-strong: rgba(99, 102, 241, 0.28);
    --text-primary: #0f172a;
    --text-secondary: #1e293b;
    --text-muted: #475569;
    --text-invert: #f8fafc;
    --accent-primary: #6366f1;
    --accent-secondary: #0ea5e9;
    --accent-tertiary: #f59e0b;
    --accent-danger: #e11d48;
    --accent-success: #10b981;
    --shadow-xl: 0 35px 60px -30px rgba(15, 23, 42, 0.18);
    --shadow-lg: 0 26px 45px -26px rgba(15, 23, 42, 0.16);
    --shadow-md: 0 18px 32px -22px rgba(15, 23, 42, 0.14);
    --shadow-soft: 0 14px 28px -20px rgba(15, 23, 42, 0.12);
    --gradient-primary: linear-gradient(120deg, rgba(99, 102, 241, 0.95), rgba(14, 165, 233, 0.95));
    --gradient-primary-soft: linear-gradient(120deg, rgba(99, 102, 241, 0.22), rgba(14, 165, 233, 0.18));
    --button-disabled-bg: rgba(148, 163, 184, 0.18);
    --button-disabled-border: rgba(148, 163, 184, 0.22);
    --button-disabled-text: rgba(100, 116, 139, 0.7);
    --surface-panel-base: rgba(255, 255, 255, 0.97);
    --surface-panel-gradient-start: rgba(255, 255, 255, 0.98);
    --surface-panel-gradient-end: rgba(236, 242, 247, 0.94);
    --surface-panel-border: rgba(148, 163, 184, 0.35);
    --surface-panel-highlight: rgba(129, 140, 248, 0.16);
    --surface-panel-radial: rgba(14, 165, 233, 0.18);
    --surface-panel-glow: rgba(99, 102, 241, 0.18);
    --surface-panel-orb: rgba(250, 204, 21, 0.2);
    --surface-card-blur: 12px;
}

*, *::before, *::after {
    box-sizing: border-box;
}

html {
    font-size: 16px;
}

body {
    margin: 0;
    background: var(--bg-primary);
    color: var(--text-primary);
    font-family: var(--font-sans);
    min-height: 100vh;
    line-height: 1.6;
    letter-spacing: 0.01em;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
}

body.cosmic-ui {
    display: flex;
    justify-content: center;
    overflow-x: hidden;
}

h1, h2, h3, h4, h5, h6 {
    margin: 0;
    font-weight: 600;
    line-height: 1.2;
    color: var(--text-primary);
}

p {
    margin: 0;
    color: var(--text-muted);
}

ul, ol {
    margin: 0;
    padding-left: 1.2rem;
    color: var(--text-secondary);
}

a {
    color: var(--accent-secondary);
    text-decoration: none;
    transition: color var(--transition-fast), opacity var(--transition-fast);
}

a:hover {
    color: var(--accent-primary);
    opacity: 0.92;
}

.required-indicator {
    color: var(--accent-danger);
    font-weight: 600;
    margin-left: 0.25rem;
}

img {
    max-width: 100%;
    height: auto;
    display: block;
}

button, input, select, textarea {
    font: inherit;
    color: inherit;
}

button {
    cursor: pointer;
}

.text-muted {
    color: var(--text-muted);
}

/* ===== SURFACE UTILITIES ================================================== */
.surface-card {
    background: var(--bg-card);
    border: 1px solid var(--border-soft);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-lg);
    backdrop-filter: blur(var(--surface-card-blur));
}

.surface-card--muted {
    background: var(--bg-card-muted);
}

.surface-card--strong {
    background: var(--bg-card-strong);
}

.surface-card--highlight {
    background: var(--bg-card-highlight);
    border-color: var(--border-strong);
    box-shadow: var(--shadow-xl);
}

.surface-panel {
    background: var(--surface-panel-base);
    border: 1px solid var(--surface-panel-border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-lg);
    position: relative;
    overflow: hidden;
}

.surface-panel::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(145deg, var(--surface-panel-gradient-start), var(--surface-panel-gradient-end));
    opacity: 0.9;
    pointer-events: none;
}

.surface-chip {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    border-radius: 999px;
    padding: 0.2rem 0.8rem;
    background: var(--bg-card-highlight);
    color: var(--text-secondary);
    border: 1px solid var(--border-soft);
}

.cosmic-canvas {
    position: fixed;
    inset: 0;
    overflow: hidden;
    z-index: -2;
    pointer-events: none;
}

.cosmic-canvas__layer {
    position: absolute;
    inset: -20%;
}

.cosmic-canvas__layer--gradient {
    background:
        radial-gradient(circle at 20% 20%, rgba(56, 189, 248, 0.12), transparent 55%),
        radial-gradient(circle at 80% 28%, rgba(168, 85, 247, 0.14), transparent 60%),
        radial-gradient(circle at 50% 70%, rgba(251, 191, 36, 0.12), transparent 58%),
        linear-gradient(160deg, #030616 0%, #050b1f 45%, #0b1226 68%, #101935 100%);
    filter: saturate(115%);
}

html[data-theme="light"] .cosmic-canvas__layer--gradient {
    background:
        radial-gradient(circle at 20% 20%, rgba(14, 165, 233, 0.2), transparent 55%),
        radial-gradient(circle at 80% 30%, rgba(99, 102, 241, 0.18), transparent 60%),
        radial-gradient(circle at 50% 70%, rgba(245, 158, 11, 0.2), transparent 58%),
        linear-gradient(160deg, #dbeafe 0%, #e2e8f0 45%, #f8fafc 100%);
    filter: saturate(108%);
}

.cosmic-canvas__layer--aurora {
    background:
        radial-gradient(400px 600px at 10% 10%, rgba(56, 189, 248, 0.28), transparent 75%),
        radial-gradient(520px 480px at 85% 15%, rgba(168, 85, 247, 0.25), transparent 78%),
        radial-gradient(420px 540px at 40% 88%, rgba(251, 191, 36, 0.18), transparent 75%);
    mix-blend-mode: screen;
    opacity: 0.5;
    animation: aurora 18s ease-in-out infinite alternate;
}

html[data-theme="light"] .cosmic-canvas__layer--aurora {
    background:
        radial-gradient(400px 600px at 12% 12%, rgba(14, 165, 233, 0.22), transparent 75%),
        radial-gradient(520px 480px at 85% 18%, rgba(99, 102, 241, 0.18), transparent 78%),
        radial-gradient(420px 540px at 42% 90%, rgba(245, 158, 11, 0.16), transparent 75%);
    mix-blend-mode: multiply;
    opacity: 0.4;
}

.cosmic-canvas__layer--stars {
    background-image:
        radial-gradient(1px 1px at 20% 20%, rgba(255, 255, 255, 0.45) 0, transparent 55%),
        radial-gradient(1px 1px at 80% 30%, rgba(255, 255, 255, 0.32) 0, transparent 50%),
        radial-gradient(2px 2px at 60% 70%, rgba(244, 114, 182, 0.35) 0, transparent 45%),
        radial-gradient(1px 1px at 35% 85%, rgba(96, 165, 250, 0.25) 0, transparent 50%);
    opacity: 0.45;
    animation: twinkle 22s linear infinite;
}

html[data-theme="light"] .cosmic-canvas__layer--stars {
    background-image:
        radial-gradient(1px 1px at 22% 18%, rgba(99, 102, 241, 0.45) 0, transparent 55%),
        radial-gradient(1px 1px at 78% 32%, rgba(14, 165, 233, 0.32) 0, transparent 50%),
        radial-gradient(2px 2px at 62% 72%, rgba(244, 114, 182, 0.28) 0, transparent 45%),
        radial-gradient(1px 1px at 35% 85%, rgba(59, 130, 246, 0.25) 0, transparent 50%);
    opacity: 0.3;
}

@keyframes aurora {
    0% {
        transform: translate3d(-2%, -2%, 0) scale(1);
        opacity: 0.45;
    }
    50% {
        transform: translate3d(2%, 1%, 0) scale(1.03);
        opacity: 0.65;
    }
    100% {
        transform: translate3d(-1%, 2%, 0) scale(1.02);
        opacity: 0.5;
    }
}

@keyframes twinkle {
    0%, 100% {
        transform: translate3d(0, 0, 0) scale(1);
        opacity: 0.42;
    }
    50% {
        transform: translate3d(-1%, 1%, 0) scale(1.02);
        opacity: 0.66;
    }
}

.cosmic-shell {
    position: relative;
    width: min(1180px, 96vw);
    padding: clamp(28px, 5vw, 64px) 0 clamp(72px, 8vw, 116px);
    display: flex;
    flex-direction: column;
    min-height: 100vh;
    z-index: 0;
}

.app-header {
    padding: 0 clamp(1.5rem, 5vw, 3.5rem);
    margin-bottom: clamp(24px, 4vw, 56px);
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
}

.brand-wrap {
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
    position: relative;
}

.brand {
    font-family: var(--font-serif);
    font-size: clamp(1.8rem, 3vw, 2.6rem);
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    background: linear-gradient(120deg, rgba(168, 85, 247, 0.95), rgba(56, 189, 248, 0.95), rgba(251, 191, 36, 0.9));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
}

.brand span {
    font-weight: 400;
}

.brand-tagline {
    font-size: 0.9rem;
    letter-spacing: 0.26em;
    text-transform: uppercase;
    color: var(--text-muted);
    opacity: 0.85;
}

.app-header__actions {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.theme-toggle {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 46px;
    height: 46px;
    border-radius: var(--radius-sm);
    border: 1px solid var(--border-soft);
    background: var(--bg-elevated);
    color: var(--text-primary);
    box-shadow: var(--shadow-soft);
    transition: transform var(--transition-fast), border-color var(--transition-fast), background var(--transition-fast), color var(--transition-fast);
}

.theme-toggle:hover {
    transform: translateY(-1px);
    border-color: var(--accent-secondary);
}

.theme-toggle:focus-visible {
    outline: 2px solid var(--accent-secondary);
    outline-offset: 3px;
}

.theme-toggle__icon {
    position: absolute;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.2rem;
    transform: scale(0.6) rotate(-25deg);
    opacity: 0;
    transition: opacity var(--transition-fast), transform var(--transition-fast);
}

html[data-theme="dark"] .theme-toggle__icon--dark,
html[data-theme="light"] .theme-toggle__icon--light {
    opacity: 1;
    transform: scale(1) rotate(0deg);
}

html[data-theme="light"] .theme-toggle {
    background: var(--bg-card);
    border-color: rgba(148, 163, 184, 0.28);
}

.app-main {
    flex: 1;
    width: 100%;
    padding: 0 clamp(1.5rem, 5vw, 3.5rem);
    display: flex;
    flex-direction: column;
    gap: clamp(24px, 3vw, 40px);
}

.app-footer {
    margin-top: clamp(64px, 8vw, 96px);
    padding: clamp(2.5rem, 5vw, 4rem) clamp(1.5rem, 5vw, 3.5rem) clamp(1.5rem, 3vw, 2.5rem);
    border-top: 1px solid rgba(148, 163, 184, 0.18);
    backdrop-filter: blur(var(--blur-amount));
    background: linear-gradient(180deg, rgba(12, 20, 40, 0.65), rgba(12, 20, 40, 0.35));
    border-radius: var(--radius-md) var(--radius-md) 0 0;
    position: relative;
}

.app-footer::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 1px;
    background: linear-gradient(90deg,
        transparent,
        rgba(56, 189, 248, 0.3) 25%,
        rgba(99, 102, 241, 0.3) 50%,
        rgba(168, 85, 247, 0.3) 75%,
        transparent
    );
}

html[data-theme="light"] .app-footer {
    border-top-color: rgba(148, 163, 184, 0.28);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.9), rgba(241, 245, 249, 0.7));
}

.footer-content {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 220px), 1fr));
    gap: clamp(2rem, 4vw, 3rem);
    margin-bottom: clamp(2rem, 4vw, 3rem);
}

.footer-section h4 {
    font-size: 0.85rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--text-primary);
    margin: 0 0 1rem 0;
    background: linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.footer-section--brand {
    grid-column: 1 / -1;
}

@media (min-width: 768px) {
    .footer-section--brand {
        grid-column: span 2;
    }
}

.footer-brand h3 {
    font-size: 1.5rem;
    font-weight: 700;
    margin: 0 0 0.5rem 0;
    color: var(--text-primary);
    background: linear-gradient(135deg,
        rgba(56, 189, 248, 1),
        rgba(99, 102, 241, 1)
    );
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.footer-brand h3 span {
    opacity: 0.8;
}

.footer-tagline {
    font-size: 0.9rem;
    color: var(--text-muted);
    margin: 0 0 1rem 0;
    font-style: italic;
}

.footer-disclaimer {
    font-size: 0.85rem;
    color: var(--text-muted);
    line-height: 1.6;
    margin: 0;
    padding: 1rem;
    background: rgba(251, 191, 36, 0.08);
    border-left: 3px solid rgba(251, 191, 36, 0.4);
    border-radius: var(--radius-sm);
}

html[data-theme="light"] .footer-disclaimer {
    background: rgba(251, 191, 36, 0.12);
}

.footer-nav {
    display: flex;
    flex-direction: column;
    gap: 0.6rem;
}

.footer-nav a {
    color: var(--text-secondary);
    text-decoration: none;
    font-size: 0.9rem;
    transition: all var(--transition-fast);
    display: inline-block;
}

.footer-nav a:hover {
    color: var(--accent-primary);
    transform: translateX(4px);
}

.footer-bottom {
    padding-top: clamp(1.5rem, 3vw, 2rem);
    border-top: 1px solid rgba(148, 163, 184, 0.12);
    text-align: center;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.footer-bottom p {
    margin: 0;
    font-size: 0.85rem;
    color: var(--text-muted);
}

.footer-note {
    font-style: italic;
    opacity: 0.8;
}

@media (max-width: 768px) {
    .footer-content {
        grid-template-columns: 1fr;
    }

    .footer-section--brand {
        grid-column: 1;
    }
}

.container {
    width: 100%;
    max-width: 980px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: clamp(24px, 4vw, 32px);
}

.container--wide {
    max-width: 1140px;
}

.card,
.login-card,
.welcome-card,
.form-container,
.profile-header,
.family-section,
.chat-card,
.context-card {
    position: relative;
    background: var(--bg-elevated);
    border-radius: var(--radius-lg);
    padding: clamp(2rem, 3vw, 2.8rem);
    box-shadow: var(--shadow-lg);
    border: 1px solid var(--border-soft);
    overflow: hidden;
    backdrop-filter: blur(var(--blur-amount));
    overflow: hidden;
}

.card::before,
.login-card::before,
.welcome-card::before,
.form-container::before,
.profile-header::before,
.family-section::before,
.chat-card::before,
.context-card::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    padding: 1px;
    background: linear-gradient(140deg, rgba(168, 85, 247, 0.35), rgba(56, 189, 248, 0.22), rgba(251, 191, 36, 0.18));
    -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
    -webkit-mask-composite: xor;
    mask-composite: exclude;
    pointer-events: none;
    opacity: 0.9;
}

.card > *,
.login-card > *,
.welcome-card > *,
.form-container > *,
.profile-header > *,
.family-section > *,
.chat-card > *,
.context-card > * {
    position: relative;
    z-index: 1;
}

.chip {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.35rem 0.85rem;
    border-radius: 999px;
    font-size: 0.8rem;
    letter-spacing: 0.04em;
    background: rgba(56, 189, 248, 0.12);
    color: var(--accent-secondary);
}

.badge {
    display: inline-flex;
    align-items: center;
    padding: 0.25rem 0.7rem;
    border-radius: 999px;
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    background: rgba(168, 85, 247, 0.15);
    color: var(--accent-primary);
}

.flash-stack {
    position: fixed;
    top: clamp(16px, 3vw, 32px);
    left: 50%;
    transform: translateX(-50%);
    width: min(520px, calc(100vw - 32px));
    display: flex;
    flex-direction: column;
    gap: 12px;
    z-index: 99;
    pointer-events: none;
}

.rate-limit-section {
    padding: clamp(3rem, 6vw, 5rem) 0;
}

.rate-limit-card {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
    align-items: center;
}

.rate-limit-title {
    font-size: clamp(1.6rem, 3vw, 2rem);
    margin: 0;
}

.rate-limit-message,
.rate-limit-hint {
    color: var(--text-secondary);
    max-width: 420px;
}

.rate-limit-meta {
    font-size: 0.9rem;
    color: var(--text-muted);
}

.rate-limit-actions {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    width: min(260px, 100%);
}

.rate-limit-actions .btn {
    width: 100%;
}

.flash-card {
    pointer-events: auto;
    padding: 0.9rem 1.1rem;
    border-radius: var(--radius-sm);
    font-size: 0.92rem;
    line-height: 1.45;
    color: var(--text-primary);
    background: rgba(15, 23, 42, 0.9);
    border: 1px solid rgba(99, 102, 241, 0.45);
    box-shadow: var(--shadow-md);
    transition: opacity var(--transition-base), transform var(--transition-base);
}

html[data-theme="light"] .flash-card {
    background: rgba(255, 255, 255, 0.92);
    color: var(--text-secondary);
    border-color: rgba(99, 102, 241, 0.24);
}

.flash-card--hide {
    opacity: 0;
    transform: translateY(-10px);
}

.flash-success {
    border-color: rgba(52, 211, 153, 0.55);
    background: rgba(34, 197, 94, 0.16);
    color: #bbf7d0;
}

.flash-error {
    border-color: rgba(248, 113, 113, 0.4);
    background: rgba(248, 113, 113, 0.12);
    color: #fecaca;
}

.flash-warning {
    border-color: rgba(251, 191, 36, 0.55);
    background: rgba(251, 191, 36, 0.14);
    color: #fef3c7;
}

.flash-info {
    border-color: rgba(96, 165, 250, 0.55);
    background: rgba(59, 130, 246, 0.14);
    color: #dbeafe;
}

.btn,
.btn-primary,
.btn-secondary,
.btn-outline,
.btn-ghost,
.login-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.6rem;
    padding: 0.72rem 1.65rem;
    border-radius: 999px;
    border: 1px solid var(--border-soft);
    overflow: hidden;
    font-weight: 600;
    font-size: 0.95rem;
    letter-spacing: 0.03em;
    transition:
        transform var(--transition-fast),
        box-shadow var(--transition-fast),
        border-color var(--transition-fast),
        background var(--transition-fast),
        color var(--transition-fast);
    text-decoration: none;
    cursor: pointer;
    position: relative;
    overflow: hidden;
    background: var(--bg-card);
    color: var(--text-primary);
    backdrop-filter: blur(8px);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.05);
}

.btn::after,
.btn-primary::after,
.btn-secondary::after,
.btn-outline::after,
.btn-ghost::after,
.login-btn::after {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    background: linear-gradient(120deg, rgba(168, 85, 247, 0.22), rgba(56, 189, 248, 0.2), rgba(251, 191, 36, 0.16));
    opacity: 0;
    transition: opacity var(--transition-fast);
    pointer-events: none;
    mix-blend-mode: screen;
}

.btn:hover,
.btn-primary:hover,
.btn-secondary:hover,
.btn-outline:hover,
.btn-ghost:hover,
.login-btn:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-soft);
}

.btn:hover::after,
.btn-primary:hover::after,
.btn-secondary:hover::after,
.btn-outline:hover::after,
.btn-ghost:hover::after,
.login-btn:hover::after {
    opacity: 1;
}

.btn:active,
.btn-primary:active,
.btn-secondary:active,
.btn-outline:active,
.btn-ghost:active,
.login-btn:active {
    transform: translateY(0);
}

.btn-primary, .login-btn.google-btn {
    background-image: linear-gradient(135deg, rgba(168, 85, 247, 0.95), rgba(56, 189, 248, 0.95));
    background-size: 160% 160%;
    border: none;
    color: var(--text-primary);
    box-shadow: 0 20px 42px -20px rgba(99, 102, 241, 0.65);
}

.btn-primary:hover, .login-btn.google-btn:hover {
    background-position: 100% 0;
    box-shadow: 0 24px 46px -18px rgba(56, 189, 248, 0.75);
}

.btn-secondary {
    background: rgba(148, 163, 184, 0.14);
    border-color: var(--button-disabled-border);
    color: var(--text-secondary);
}

.btn-secondary:hover {
    background: rgba(148, 163, 184, 0.2);
    border-color: rgba(226, 232, 240, 0.38);
    color: var(--text-primary);
}

.btn-outline {
    background: rgba(15, 23, 42, 0.35);
    border: 1px solid rgba(148, 163, 184, 0.45);
    color: var(--text-secondary);
    box-shadow: inset 0 0 0 1px rgba(12, 20, 40, 0.45);
}

.btn-outline:hover {
    border-color: rgba(168, 85, 247, 0.5);
    color: var(--text-primary);
    background: rgba(15, 23, 42, 0.5);
}

.btn-ghost {
    background: rgba(15, 23, 42, 0.35);
    border: 1px solid var(--border-soft);
    overflow: hidden;
    color: var(--text-secondary);
    transition: transform var(--transition-fast), box-shadow var(--transition-fast), border-color var(--transition-fast);
}

.btn-ghost:hover {
    transform: translateY(-2px);
    border-color: var(--button-disabled-border);
    box-shadow: 0 18px 34px -24px rgba(148, 163, 184, 0.4);
    color: var(--text-primary);
}

.btn-danger {
    color: #fecaca;
}

.btn-small, .btn-sm {
    padding: 0.55rem 1.2rem;
    font-size: 0.85rem;
    border-radius: 999px;
}

.btn-icon {
    gap: 0.55rem;
    padding-inline: 1.1rem;
}

.btn-icon-small {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: clamp(28px, 5vw, 32px);
    height: clamp(28px, 5vw, 32px);
    border-radius: 12px;
    background: rgba(15, 23, 42, 0.55);
    border: 1px solid rgba(148, 163, 184, 0.35);
    font-size: 0.95rem;
    transition: background var(--transition-fast), transform var(--transition-fast);
}

.btn-icon-small:hover {
    background: rgba(148, 163, 234, 0.18);
    transform: translateY(-1px);
}

.btn-icon-small.btn-danger {
    border-color: rgba(248, 113, 113, 0.45);
    color: #fecaca;
}

html[data-theme="light"] .btn-secondary {
    background: rgba(226, 232, 240, 0.6);
    border-color: rgba(148, 163, 184, 0.35);
    color: var(--text-secondary);
}

html[data-theme="light"] .btn-secondary:hover {
    background: rgba(203, 213, 225, 0.72);
    border-color: rgba(99, 102, 241, 0.32);
}

html[data-theme="light"] .btn-outline {
    background: rgba(255, 255, 255, 0.8);
    border-color: rgba(148, 163, 184, 0.45);
    box-shadow: inset 0 0 0 1px rgba(148, 163, 184, 0.2);
}

html[data-theme="light"] .btn-outline:hover {
    background: rgba(226, 232, 240, 0.8);
}

html[data-theme="light"] .btn-ghost {
    background: rgba(255, 255, 255, 0.64);
    border-color: rgba(148, 163, 184, 0.35);
}

html[data-theme="light"] .btn-icon-small {
    background: rgba(226, 232, 240, 0.78);
    border-color: rgba(148, 163, 184, 0.4);
}

html[data-theme="light"] .btn-icon-small:hover {
    background: rgba(203, 213, 225, 0.85);
}

.btn-close {
    background: transparent;
    border: none;
    color: var(--text-muted);
    font-size: 1.4rem;
    line-height: 1;
    padding: 0.2rem;
    cursor: pointer;
    transition: color var(--transition-fast), transform var(--transition-fast);
}

.btn-close:hover {
    color: var(--text-secondary);
    transform: scale(1.05);
}

/* Loading Button States */
.btn-generate {
    position: relative;
}

.btn-generate .btn-loader {
    display: none;
    width: 14px;
    height: 14px;
    border: 2px solid transparent;
    border-top-color: currentColor;
    border-radius: 50%;
    animation: btn-spin 0.6s linear infinite;
    margin-left: 0.5rem;
}

.btn-generate.is-loading {
    pointer-events: none;
    opacity: 0.7;
}

.btn-generate.is-loading .btn-loader {
    display: inline-block;
}

@keyframes btn-spin {
    0% {
        transform: rotate(0deg);
    }
    100% {
        transform: rotate(360deg);
    }
}

.login-card, .welcome-card, .form-container {
    position: relative;
    padding: clamp(2.2rem, 4vw, 3rem);
    background: var(--surface-panel-base);
    border: 1px solid var(--surface-panel-border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-soft);
}

.login-card::after, .welcome-card::after {
    content: "";
    position: absolute;
    inset: 18% -40% -40% 55%;
    background: radial-gradient(circle at center, var(--surface-panel-highlight), transparent 65%);
    opacity: 0.75;
    pointer-events: none;
    z-index: 0;
}

.login-card h1, .welcome-card h1, .form-container h1 {
    font-size: clamp(1.9rem, 4vw, 2.4rem);
    font-family: var(--font-serif);
    letter-spacing: 0.08em;
    text-transform: uppercase;
    margin-bottom: 0.8rem;
}

.login-card p, .welcome-card p, .form-container p {
    font-size: 1rem;
    color: var(--text-secondary);
}

.login-options {
    margin-top: 2rem;
    display: flex;
    flex-direction: column;
    gap: 0.85rem;
}

.container--auth {
    max-width: 1040px;
}

.login-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 1.6rem;
    align-items: stretch;
}

.login-hero {
    position: relative;
    overflow: hidden;
    border-radius: var(--radius-lg);
    padding: clamp(2.4rem, 4vw, 3.2rem);
    background:
        linear-gradient(140deg, var(--surface-panel-gradient-start), var(--surface-panel-gradient-end)),
        radial-gradient(circle at 15% 20%, var(--surface-panel-radial), transparent 60%);
    border: 1px solid var(--surface-panel-border);
    box-shadow: var(--shadow-soft);
}

.login-hero::after {
    content: "";
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at 75% -10%, var(--surface-panel-glow), transparent 55%);
    pointer-events: none;
    opacity: 0.7;
}

.login-hero__orb {
    position: absolute;
    width: 320px;
    height: 320px;
    top: -90px;
    right: -90px;
    background: radial-gradient(circle, var(--surface-panel-orb), transparent 70%);
    filter: blur(6px);
    opacity: 0.7;
    pointer-events: none;
}

.login-hero h2 {
    font-family: var(--font-serif);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    font-size: clamp(1.6rem, 3vw, 2rem);
    margin-top: 0.6rem;
}

.login-hero .badge {
    background: rgba(168, 85, 247, 0.22);
    color: var(--accent-secondary);
    border: 1px solid rgba(168, 85, 247, 0.35);
    width: fit-content;
}

.login-hero p {
    margin-top: 1.2rem;
    font-size: 1rem;
    color: var(--text-secondary);
}

.login-hero__list {
    list-style: none;
    padding: 0;
    margin: 1.6rem 0 0;
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    color: var(--text-secondary);
}

.login-hero__list li {
    position: relative;
    padding-left: 1.6rem;
    font-size: 0.95rem;
}

.login-hero__list li::before {
    content: "✶";
    position: absolute;
    left: 0;
    top: 0.15rem;
    font-size: 0.85rem;
    color: var(--accent-tertiary);
}

.login-note {
    margin-top: 1.4rem;
    font-size: 0.9rem;
    color: var(--text-muted);
}

.login-btn {
    position: relative;
    background: rgba(15, 23, 42, 0.7);
    border: 1px solid var(--border-soft);
    overflow: hidden;
}

.login-icon {
    width: 20px;
    height: 20px;
}

.user-info {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 0.75rem;
}

.profile-photo, .profile-photo-placeholder {
    width: 88px;
    height: 88px;
    border-radius: 50%;
    object-fit: cover;
    border: 2px solid rgba(226, 232, 240, 0.28);
    box-shadow: 0 16px 35px -18px rgba(56, 189, 248, 0.55);
    background: rgba(56, 189, 248, 0.1);
}

.profile-photo-placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2.2rem;
    font-weight: 700;
    color: rgba(56, 189, 248, 0.9);
}

.user-info h1 {
    font-size: 1.8rem;
}

.user-email {
    color: var(--text-muted);
    font-size: 0.95rem;
}

.user-provider, .provider-badge {
    font-size: 0.75rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--accent-secondary);
    background: rgba(56, 189, 248, 0.12);
    border-radius: 999px;
    padding: 0.35rem 0.8rem;
}

.welcome-content {
    margin-top: 1.8rem;
    padding: 1.6rem 1.8rem;
    border-radius: var(--radius-md);
    background: linear-gradient(140deg, rgba(56, 189, 248, 0.12), rgba(168, 85, 247, 0.1));
    border: 1px solid var(--button-disabled-bg);
    color: var(--text-secondary);
}

.welcome-content h2 {
    font-family: var(--font-serif);
    font-size: 1.4rem;
    letter-spacing: 0.1em;
}

.welcome-layout {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 1.6rem;
    align-items: stretch;
}

.welcome-aside {
    position: relative;
    padding: clamp(2rem, 3.5vw, 2.6rem);
    background: linear-gradient(145deg, var(--surface-panel-gradient-start), var(--surface-panel-gradient-end));
    border: 1px solid var(--surface-panel-border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-soft);
    display: flex;
    flex-direction: column;
    gap: 1.2rem;
}

.welcome-aside h2 {
    font-size: 1.35rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.welcome-aside__intro {
    font-size: 0.95rem;
    color: var(--text-secondary);
}

.welcome-checklist {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 0.85rem;
}

.welcome-checklist li {
    position: relative;
    padding-left: 1.8rem;
    color: var(--text-secondary);
    font-size: 0.95rem;
}

.welcome-checklist li::before {
    content: "☽";
    position: absolute;
    left: 0;
    top: 0.1rem;
    font-size: 0.9rem;
    color: var(--accent-secondary);
}

.welcome-cta {
    margin-top: auto;
    display: flex;
    flex-direction: column;
    gap: 0.8rem;
    padding: 1.4rem 1.2rem;
    border-radius: var(--radius-md);
    background: var(--bg-card);
    border: 1px solid var(--border-strong);
}

.welcome-highlights {
    margin: 1rem 0 0;
    padding: 0;
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 0.8rem;
}

.welcome-highlights li {
    position: relative;
    padding-left: 1.6rem;
    color: var(--text-secondary);
    line-height: 1.55;
}

.welcome-highlights li::before {
    content: '✶';
    position: absolute;
    left: 0;
    top: 0.1rem;
    color: var(--accent-secondary);
    font-size: 0.9rem;
}

.actions {
    margin-top: 2rem;
    display: flex;
    gap: 0.85rem;
    justify-content: center;
    flex-wrap: wrap;
}

.profile-container {
    display: flex;
    flex-direction: column;
    gap: clamp(24px, 3vw, 36px);
}

.profile-main {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: clamp(1.6rem, 3vw, 2.2rem);
    align-items: flex-start;
}

.profile-header {
    padding: clamp(1.6rem, 4vw, 2.4rem);
    border-radius: var(--radius-lg);
    background: linear-gradient(130deg, var(--surface-panel-gradient-start), var(--surface-panel-gradient-end));
    border: 1px solid var(--surface-panel-border);
    backdrop-filter: blur(var(--blur-amount));
    box-shadow: var(--shadow-soft);
}

.header-wrapper {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.header-content h1 {
    font-size: clamp(1.6rem, 3vw, 2.1rem);
    font-family: var(--font-serif);
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.header-content .chip {
    width: fit-content;
}

.header-content p {
    color: var(--text-secondary);
    font-size: 1rem;
}

.header-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
}

.profile-card {
    display: flex;
    flex-direction: column;
    gap: 1.8rem;
}

.profile-card--sticky {
    position: sticky;
    top: clamp(80px, 12vh, 140px);
    z-index: 1;
}

.profile-card__section--stats {
    gap: 1rem;
}

.profile-metrics {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: 0.75rem;
}

.metric-card {
    border-radius: var(--radius-md);
    border: 1px solid var(--border-soft);
    background: var(--bg-card);
    padding: 0.85rem 1rem;
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

.metric-label {
    font-size: 0.75rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--text-muted);
}

.metric-value {
    font-size: 1.35rem;
    font-weight: 700;
    color: var(--text-primary);
}

.profile-card__section {
    display: flex;
    flex-direction: column;
    gap: 1.2rem;
    padding: 1.4rem 1.6rem;
    border-radius: var(--radius-md);
    background: var(--bg-card);
    border: 1px solid var(--border-soft);
    overflow: hidden;
}

.profile-card__section--identity {
    background: transparent;
    border: none;
    padding: 0;
}

.card-header {
    display: flex;
    flex-wrap: wrap;
    gap: 1.6rem;
    justify-content: space-between;
    align-items: center;
}

.profile-info {
    display: flex;
    align-items: center;
    gap: 1.4rem;
}

.profile-avatar, .profile-avatar-placeholder {
    width: 92px;
    height: 92px;
    border-radius: 24px;
    object-fit: cover;
    background: rgba(56, 189, 248, 0.1);
    border: 1px solid rgba(94, 234, 212, 0.25);
    box-shadow: 0 18px 36px -24px rgba(56, 189, 248, 0.6);
}

.profile-avatar-placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2.4rem;
    font-weight: 700;
    color: rgba(56, 189, 248, 0.9);
}

.profile-details h2 {
    font-size: 1.5rem;
    margin-bottom: 0.35rem;
}

.profile-email {
    color: var(--text-muted);
    font-size: 0.95rem;
    margin-bottom: 0.4rem;
}

.birth-info {
    display: flex;
    flex-direction: column;
    gap: 1.2rem;
}

.birth-info h3 {
    font-size: 1.15rem;
    letter-spacing: 0.05em;
    color: var(--text-secondary);
}

.birth-details {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 1rem;
}

.birth-item {
    background: var(--bg-card);
    padding: 0.75rem 1rem;
    border-radius: var(--radius-sm);
    border: 1px solid var(--border-soft);
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}

.birth-label {
    font-size: 0.8rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--text-muted);
}

.birth-value {
    color: var(--text-secondary);
    font-weight: 600;
    font-size: 0.95rem;
}

.kundali-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
}

.kundali-incomplete {
    color: var(--text-muted);
    font-size: 0.9rem;
}

.incomplete-profile {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1.2rem;
    padding: 1.1rem 1.3rem;
    border-radius: var(--radius-md);
    background: rgba(251, 191, 36, 0.12);
    border: 1px solid rgba(251, 191, 36, 0.3);
}

.incomplete-content {
    display: flex;
    align-items: center;
    gap: 0.85rem;
}

.incomplete-icon {
    font-size: 1.5rem;
}

.incomplete-text h4 {
    font-size: 1rem;
    margin-bottom: 0.25rem;
}

.incomplete-text p {
    font-size: 0.9rem;
}

.family-section {
    display: flex;
    flex-direction: column;
    gap: 1.4rem;
    padding: clamp(1.8rem, 3vw, 2.3rem);
    border-radius: var(--radius-lg);
    background: var(--bg-card);
    border: 1px solid var(--border-soft);
    overflow: hidden;
    box-shadow: var(--shadow-soft);
}

.family-overview {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    gap: 1rem;
    flex-wrap: wrap;
}

.family-overview h2 {
    font-size: 1.4rem;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    margin: 0;
}

.family-overview .chip {
    margin-bottom: 0.4rem;
    display: inline-flex;
}

.family-overview__actions {
    display: flex;
    gap: 0.6rem;
    align-items: center;
}

.section-subtitle {
    color: var(--text-muted);
    font-size: 0.9rem;
}

.family-scroll {
    max-height: calc(100vh - 240px);
    overflow-y: auto;
    padding-right: 0.35rem;
    margin-right: -0.2rem;
}

.family-scroll::-webkit-scrollbar {
    width: 6px;
}

.family-scroll::-webkit-scrollbar-thumb {
    background: rgba(148, 163, 184, 0.35);
    border-radius: 999px;
}

.family-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 1.2rem;
}

.family-member-card {
    padding: 1.4rem;
    border-radius: var(--radius-md);
    background: var(--bg-card);
    border: 1px solid var(--border-soft);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    gap: 1rem;
    transition: transform var(--transition-fast), box-shadow var(--transition-fast), border-color var(--transition-fast);
}

.family-member-card:hover {
    transform: translateY(-4px);
    border-color: rgba(168, 85, 247, 0.32);
    box-shadow: 0 18px 36px -24px rgba(168, 85, 247, 0.4);
}

.member-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 0.8rem;
}

.member-info {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

.member-info h3 {
    font-size: 1.15rem;
}

.relationship-tag {
    font-size: 0.75rem;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--accent-tertiary);
}

.member-actions {
    display: flex;
    gap: 0.5rem;
}

.member-details {
    display: flex;
    flex-direction: column;
    gap: 0.65rem;
}

.detail-item {
    display: flex;
    align-items: center;
    gap: 0.55rem;
    color: var(--text-secondary);
    font-size: 0.95rem;
}

.detail-icon {
    font-size: 1rem;
    color: rgba(148, 163, 184, 0.8);
}

.member-kundali-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem;
}

.empty-family-state {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1.1rem;
    padding: 2.5rem 1rem;
    border-radius: var(--radius-lg);
    background: var(--bg-card-muted);
    border: 1px dashed rgba(148, 163, 184, 0.3);
    text-align: center;
}

html[data-theme="light"] .empty-family-state {
    background: rgba(226, 232, 240, 0.65);
    border-color: rgba(148, 163, 184, 0.35);
}

.empty-icon {
    font-size: 2.4rem;
}

/* Unified People Grid Layout */
.people-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(min(100%, 340px), 1fr));
    gap: clamp(1.2rem, 2.5vw, 1.8rem);
    padding: 0;
}

.person-card {
    position: relative;
    background: var(--bg-elevated);
    border-radius: var(--radius-lg);
    border: 1px solid var(--border-soft);
    padding: clamp(1.4rem, 2.5vw, 1.8rem);
    display: flex;
    flex-direction: column;
    gap: 1.2rem;
    box-shadow: var(--shadow-sm);
    transition: all var(--transition-smooth);
}

.person-card::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: var(--radius-lg);
    padding: 1px;
    background: linear-gradient(135deg,
        rgba(56, 189, 248, 0.15),
        rgba(99, 102, 241, 0.15),
        rgba(168, 85, 247, 0.15)
    );
    -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
    -webkit-mask-composite: xor;
    mask-composite: exclude;
    opacity: 0;
    transition: opacity var(--transition-smooth);
}

.person-card:hover::before {
    opacity: 1;
}

.person-card > * {
    position: relative;
    z-index: 1;
}

.person-card--self {
    background: linear-gradient(135deg,
        rgba(56, 189, 248, 0.08),
        rgba(99, 102, 241, 0.08)
    );
    border-color: rgba(56, 189, 248, 0.2);
}

html[data-theme="light"] .person-card--self {
    background: linear-gradient(135deg,
        rgba(56, 189, 248, 0.12),
        rgba(99, 102, 241, 0.12)
    );
}

.person-card--add {
    border: 2px dashed rgba(148, 163, 184, 0.3);
    background: var(--bg-card-muted);
    cursor: pointer;
    transition: all var(--transition-smooth);
    min-height: 280px;
}

.person-card--add:hover {
    border-color: var(--accent-primary);
    background: var(--bg-card);
    transform: translateY(-2px);
}

html[data-theme="light"] .person-card--add {
    background: rgba(226, 232, 240, 0.5);
}

.add-card-content {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    gap: 1rem;
    height: 100%;
    padding: 2rem 1rem;
}

.add-card-icon {
    font-size: 2.5rem;
    opacity: 0.7;
}

.add-card-content h3 {
    font-size: 1.1rem;
    margin: 0;
    color: var(--text-primary);
}

.add-card-content p {
    font-size: 0.9rem;
    color: var(--text-muted);
    margin: 0;
}

.person-card__header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
}

.person-identity {
    display: flex;
    align-items: center;
    gap: 1rem;
    flex: 1;
    min-width: 0;
}

.person-avatar,
.person-avatar-placeholder {
    width: 56px;
    height: 56px;
    border-radius: 50%;
    flex-shrink: 0;
}

.person-avatar {
    object-fit: cover;
    border: 2px solid var(--border-soft);
}

.person-avatar-placeholder {
    background: linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.4rem;
    font-weight: 600;
    color: white;
}

.person-info {
    flex: 1;
    min-width: 0;
}

.person-info h2,
.person-info h3 {
    margin: 0 0 0.3rem 0;
    font-size: 1.1rem;
    color: var(--text-primary);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.relationship-tag {
    display: inline-block;
    background: rgba(99, 102, 241, 0.12);
    color: var(--accent-primary);
    padding: 0.25rem 0.65rem;
    border-radius: 999px;
    font-size: 0.75rem;
    font-weight: 500;
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

.relationship-tag--self {
    background: rgba(56, 189, 248, 0.15);
    color: #38bdf8;
}

html[data-theme="light"] .relationship-tag {
    background: rgba(99, 102, 241, 0.18);
}

html[data-theme="light"] .relationship-tag--self {
    background: rgba(56, 189, 248, 0.2);
}

.person-actions {
    display: flex;
    gap: 0.4rem;
}

.person-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.8rem;
    padding-bottom: 0.5rem;
    border-bottom: 1px solid var(--border-soft);
}

.meta-item {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 0.85rem;
    color: var(--text-secondary);
}

.meta-icon {
    font-size: 1rem;
    opacity: 0.7;
}

.meta-text {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.person-details {
    display: flex;
    flex-direction: column;
    gap: 0.6rem;
}

.person-kundali-actions {
    margin-top: 0.3rem;
}

.person-incomplete {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1rem;
    background: rgba(251, 191, 36, 0.08);
    border: 1px solid rgba(251, 191, 36, 0.2);
    border-radius: var(--radius-md);
}

html[data-theme="light"] .person-incomplete {
    background: rgba(251, 191, 36, 0.12);
}

.incomplete-icon {
    font-size: 1.5rem;
    flex-shrink: 0;
}

.incomplete-text {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 0.6rem;
}

.incomplete-text p {
    margin: 0;
    font-size: 0.9rem;
    color: var(--text-secondary);
}

@media (max-width: 768px) {
    .people-grid {
        grid-template-columns: 1fr;
    }

    .person-avatar,
    .person-avatar-placeholder {
        width: 48px;
        height: 48px;
    }

    .person-incomplete {
        flex-direction: column;
        text-align: center;
    }
}

.form-container {
    display: flex;
    flex-direction: column;
    gap: 1.8rem;
}

.profile-form {
    display: flex;
    flex-direction: column;
    gap: 1.2rem;
}

.form-group {
    display: flex;
    flex-direction: column;
    gap: 0.45rem;
}

.form-group label {
    font-size: 0.85rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--text-muted);
}

.form-group input,
.form-group select,
.form-group textarea {
    padding: 0.85rem 1rem;
    border-radius: 14px;
    border: 1px solid var(--border-soft);
    overflow: hidden;
    background: var(--bg-card);
    color: var(--text-secondary);
    transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
    outline: none;
}

.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
    border-color: rgba(56, 189, 248, 0.55);
    box-shadow: 0 0 0 3px rgba(56, 189, 248, 0.18);
}

.form-group small {
    font-size: 0.8rem;
    color: var(--text-muted);
}

.form-actions {
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
    justify-content: center;
}

.form-actions .btn {
    /* flex: 0 1 clamp(220px, 34vw, 320px); */
}

@media (max-width: 640px) {
    /* .form-actions .btn {
        flex: 0 1 clamp(140px, 56vw, 180px);
    } */

    .feedback-form .btn {
        padding: 0.55rem 1.15rem;
        font-size: 0.88rem;
    }
}

.form-section {
    padding: 1.5rem 0;
    border-top: 1px solid rgba(148, 163, 234, 0.18);
}

.form-section:first-of-type {
    border-top: none;
    padding-top: 0;
}

.form-section h2 {
    font-size: 1.1rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--text-secondary);
    margin-bottom: 0.95rem;
}

.section-subtitle {
    margin-bottom: 1.2rem;
    color: var(--text-muted);
    font-size: 0.95rem;
}

.form-grid {
    display: grid;
    gap: 1.1rem;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}

.form-grid--balanced {
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    align-items: start;
}

.feature-feedback-card {
    margin-top: 1.2rem;
    padding: 1.2rem 1.4rem;
    border-radius: 18px;
    background: linear-gradient(135deg, rgba(15, 23, 42, 0.82), rgba(12, 19, 40, 0.74));
    border: 1px solid rgba(168, 85, 247, 0.15);
    box-shadow: var(--shadow-soft);
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.feature-feedback-card__header h3 {
    font-size: 1.05rem;
    letter-spacing: 0.02em;
}

.rating-scale {
    display: flex;
    gap: 0.55rem;
    align-items: center;
    flex-wrap: wrap;
}

.rating-scale input[type="radio"] {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.rating-scale label {
    min-width: 2.6rem;
    text-align: center;
    padding: 0.55rem 0.75rem;
    border-radius: 12px;
    background: rgba(148, 163, 234, 0.15);
    border: 1px solid rgba(148, 163, 234, 0.2);
    color: var(--text-secondary);
    backdrop-filter: blur(12px);
    transition: all var(--transition-fast);
    cursor: pointer;
    font-weight: 600;
}

.rating-scale label:hover {
    border-color: rgba(56, 189, 248, 0.4);
    box-shadow: 0 0 0 3px rgba(56, 189, 248, 0.14);
}

.rating-scale input[type="radio"]:checked + label {
    background: linear-gradient(120deg, rgba(168, 85, 247, 0.85), rgba(56, 189, 248, 0.72));
    border-color: rgba(168, 85, 247, 0.65);
    color: var(--text-invert);
}

.feedback-form .form-note {
    flex: 1 1 100%;
    margin: 0;
    font-size: 0.9rem;
    color: var(--text-muted);
    text-align: center;
    align-self: center;
}

html[data-theme="light"] .feature-feedback-card {
    background: linear-gradient(135deg, rgba(248, 250, 252, 0.98), rgba(236, 242, 247, 0.92));
    border: 1px solid rgba(99, 102, 241, 0.12);
    box-shadow: 0 24px 45px -26px rgba(15, 23, 42, 0.12);
}

html[data-theme="light"] .feature-feedback-card__header h3 {
    color: #0f172a;
}

html[data-theme="light"] .rating-scale label {
    background: rgba(148, 163, 184, 0.12);
    border: 1px solid rgba(148, 163, 184, 0.26);
    color: #1e293b;
}

html[data-theme="light"] .rating-scale label:hover {
    border-color: rgba(99, 102, 241, 0.32);
    box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.18);
}

html[data-theme="light"] .rating-scale input[type="radio"]:checked + label {
    background: linear-gradient(120deg, rgba(99, 102, 241, 0.88), rgba(14, 165, 233, 0.74));
    border-color: rgba(99, 102, 241, 0.65);
    color: #f8fafc;
}

@media (max-width: 768px) {
    .feature-feedback-card {
        padding: 1rem 1.1rem;
    }

    .rating-scale {
        gap: 0.45rem;
    }
}

.admin-dashboard {
    gap: clamp(28px, 4vw, 40px);
}

.admin-header-card {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    flex-wrap: wrap;
    gap: clamp(1.5rem, 4vw, 2.8rem);
}

.admin-header-card__intro h1 {
    font-size: clamp(1.9rem, 4vw, 2.4rem);
    font-family: var(--font-serif);
    letter-spacing: 0.08em;
}

.admin-header-card__intro p {
    max-width: 640px;
    color: var(--text-muted);
}

.admin-header-card__meta {
    display: flex;
    align-items: flex-start;
    gap: 1.4rem;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.admin-meta {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
    align-items: flex-start;
}

.admin-meta__name {
    font-weight: 600;
    color: var(--text-secondary);
}

.admin-meta__email,
.admin-meta__timestamp {
    font-size: 0.85rem;
    letter-spacing: 0.04em;
    color: var(--text-muted);
}

.admin-meta--timestamp {
    align-items: flex-end;
    text-align: right;
}

.admin-section {
    display: flex;
    flex-direction: column;
    gap: 1.4rem;
}

.admin-section__heading {
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
}

.admin-section__heading h2 {
    font-size: 1.35rem;
    letter-spacing: 0.07em;
    text-transform: uppercase;
}

.admin-stats-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: clamp(1rem, 3vw, 1.6rem);
}

.admin-stats-grid--compact {
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
}

.admin-stat-card {
    display: flex;
    flex-direction: column;
    gap: 0.45rem;
    min-height: 150px;
    background: linear-gradient(135deg, rgba(12, 23, 42, 0.55), rgba(12, 19, 36, 0.65));
}

.admin-stat-card__label {
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--text-muted);
}

.admin-stat-card__value {
    font-size: clamp(1.6rem, 4vw, 2.2rem);
    font-weight: 600;
    color: var(--text-secondary);
}

.admin-stat-card__delta {
    font-size: 0.9rem;
    color: var(--text-muted);
}

.admin-feature-table {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    overflow-x: auto;
}

.admin-feature-table__header h3 {
    font-size: 1.1rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.admin-table {
    width: 100%;
    border-collapse: collapse;
    min-width: 420px;
}

.admin-table th,
.admin-table td {
    padding: 0.75rem 1rem;
    text-align: left;
    border-bottom: 1px solid var(--border-soft);
}

.admin-table th {
    font-size: 0.75rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--text-muted);
}

.admin-table td {
    font-size: 0.95rem;
    color: var(--text-secondary);
}

.admin-empty-state {
    padding: 1.2rem;
    text-align: center;
    font-style: italic;
    color: var(--text-muted);
    border: 1px dashed rgba(148, 163, 234, 0.25);
    border-radius: var(--radius-md);
}

.admin-section--grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
    gap: clamp(1.2rem, 3vw, 1.6rem);
}

.admin-subsection {
    display: flex;
    flex-direction: column;
    gap: 1.1rem;
}

.admin-country-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 0.6rem;
}

.admin-country-list li {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.75rem 1rem;
    border: 1px solid var(--border-soft);
    border-radius: var(--radius-md);
    background: rgba(12, 23, 42, 0.45);
    backdrop-filter: blur(12px);
}

.admin-country-list__metric {
    font-weight: 600;
    color: var(--accent-secondary);
}

.admin-feedback-stream {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.admin-feedback-stream--grid {
    flex-direction: row;
    flex-wrap: wrap;
    gap: 1rem;
}

.admin-feedback-stream--grid .admin-feedback-card {
    flex: 1 1 calc(50% - 0.5rem);
}

@media (max-width: 960px) {
    .admin-feedback-stream--grid {
        flex-direction: column;
    }

    .admin-feedback-stream--grid .admin-feedback-card {
        flex: 1 1 auto;
    }
}

.admin-feedback-card {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.admin-feedback-card header {
    display: flex;
    justify-content: space-between;
    gap: 0.6rem;
    align-items: flex-start;
}

.admin-feedback-card__meta {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    flex-wrap: wrap;
}

.admin-feedback-card__body {
    display: flex;
    flex-direction: column;
    gap: 0.6rem;
}

.admin-feedback-card__comment {
    margin: 0;
    font-style: italic;
    color: var(--text-secondary);
    line-height: 1.4;
}

.admin-feedback-card__comment--empty {
    font-style: normal;
    color: var(--text-muted);
}

.admin-feedback-card__metrics {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    align-items: flex-start;
}

.admin-feedback-card__ratings {
    display: flex;
    gap: 0.9rem;
}

.admin-feedback-card__ratings dt {
    font-size: 0.75rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--text-muted);
}

.admin-feedback-card__ratings dd {
    margin: 0;
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--text-secondary);
}

.admin-feedback-card__ratings div {
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
}

.admin-feedback-card__insights {
    display: flex;
    flex-direction: column;
    gap: 0.3rem;
    color: var(--text-muted);
}

.admin-feedback-card__insights p {
    margin: 0;
}

.admin-feedback-card__feature-notes {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
    font-size: 0.9rem;
    color: var(--text-secondary);
}

.admin-feedback-card__feature-notes p {
    margin: 0;
    line-height: 1.4;
}

html[data-theme="light"] .admin-stat-card {
    background: linear-gradient(135deg, rgba(248, 250, 252, 0.96), rgba(236, 242, 247, 0.9));
}

html[data-theme="light"] .admin-country-list li {
    background: rgba(248, 250, 252, 0.98);
    border-color: rgba(99, 102, 241, 0.18);
}

@media (max-width: 1024px) {
    .admin-section--grid {
        grid-template-columns: 1fr;
    }
}

.gate-form {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    margin-top: 1.6rem;
}

.gate-form .btn {
    width: 100%;
}

.gate-hint {
    margin-top: 1.2rem;
    text-align: center;
    font-size: 0.9rem;
    color: var(--text-muted);
}

.chat-layout {
    display: grid;
    grid-template-columns: minmax(0, 3.5fr) minmax(280px, 1.5fr);
    gap: 1.8rem;
    align-items: flex-start;
}

@media (max-width: 1100px) {
    .chat-layout {
        grid-template-columns: 1fr;
    }

    .context-card {
        position: static;
        max-height: none;
    }

    .context-card__scroll {
        max-height: none;
        overflow: visible;
    }
}

.chat-card,
.context-card {
    padding: clamp(1.8rem, 3vw, 2.2rem);
    border-radius: var(--radius-lg);
    background: var(--surface-panel-base);
    border: 1px solid var(--surface-panel-border);
    backdrop-filter: blur(var(--blur-amount));
    box-shadow: var(--shadow-soft);
}

.chat-card {
    display: flex;
    flex-direction: column;
    gap: 1.4rem;
    min-height: 540px;
}

.chat-card__header {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: flex-start;
    border-bottom: 1px solid rgba(148, 163, 184, 0.18);
    padding-bottom: 1rem;
}

.chat-card__title h1 {
    font-size: 1.5rem;
    font-family: var(--font-serif);
    letter-spacing: 0.08em;
}

.chat-card__title p {
    color: var(--text-secondary);
}

.chat-card__body {
    display: flex;
    flex-direction: column;
    gap: 1.2rem;
    flex: 1;
}

.chat-window {
    flex: 1;
    border-radius: var(--radius-md);
    padding: 1.2rem;
    border: 1px solid var(--border-soft);
    overflow: hidden;
    background: var(--bg-card);
    overflow-y: auto;
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.chat-message {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

.chat-message__meta {
    display: flex;
    justify-content: space-between;
    font-size: 0.8rem;
    color: var(--text-muted);
}

.chat-message__bubble {
    padding: 0.85rem 1rem;
    border-radius: 16px;
    line-height: 1.55;
    font-size: 0.95rem;
}

.chat-message--user .chat-message__bubble {
    background: linear-gradient(120deg, rgba(56, 189, 248, 0.28), rgba(168, 85, 247, 0.25));
    align-self: flex-end;
    color: var(--text-primary);
}

.chat-message--assistant .chat-message__bubble {
    background: var(--bg-card);
    border: 1px solid var(--border-soft);
    overflow: hidden;
    color: var(--text-secondary);
}

.chat-input-area {
    display: flex;
    gap: 1rem;
    align-items: flex-end;
}

.chat-input-area textarea {
    flex: 1;
    min-height: 80px;
    border-radius: var(--radius-md);
    border: 1px solid var(--border-soft);
    overflow: hidden;
    background: var(--bg-card);
    color: var(--text-secondary);
    padding: 0.9rem 1.1rem;
    resize: vertical;
}

.chat-input-area textarea:focus {
    border-color: rgba(56, 189, 248, 0.5);
    box-shadow: 0 0 0 3px rgba(56, 189, 248, 0.18);
}

.chat-input-area button {
    min-width: 120px;
    background: var(--gradient-primary);
    color: var(--text-primary);
    border: 1px solid var(--border-soft);
    overflow: hidden;
    border-radius: 14px;
    padding: 0.9rem 1.4rem;
    font-weight: 600;
    transition: transform var(--transition-fast), box-shadow var(--transition-fast);
}

.chat-input-area button:hover:not(:disabled) {
    transform: translateY(-2px);
    box-shadow: 0 18px 36px -24px rgba(56, 189, 248, 0.6);
}

.chat-input-area button:disabled {
    opacity: 0.45;
    cursor: not-allowed;
    background: var(--button-disabled-bg);
    color: var(--button-disabled-text);
    border-color: var(--button-disabled-border);
}

.context-card {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    position: sticky;
    top: 24px;
    max-height: calc(100vh - 80px);
}

.context-card__scroll {
    overflow-y: auto;
    padding-right: 0.3rem;
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.context-card h2 {
    font-size: 1.2rem;
    letter-spacing: 0.06em;
}

.context-card__status {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    color: var(--text-secondary);
}

.matchmaking-banner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    background: var(--bg-card-highlight);
    border: 1px solid var(--border-soft);
    border-radius: 14px;
    padding: 0.85rem 1rem;
    font-size: 0.9rem;
}

.context-matchmaking {
    border-radius: var(--radius-md);
    padding: 1rem;
    background: var(--bg-card);
    border: 1px solid var(--border-soft);
}

.context-matchmaking__header {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 1rem;
    margin-bottom: 0.5rem;
}

.context-matchmaking__list {
    margin-bottom: 0.6rem;
}

.context-matchmaking__list ul {
    padding-left: 1.1rem;
    margin: 0.35rem 0 0;
}

.context-person {
    border-radius: var(--radius-md);
    padding: 0.95rem 1.1rem;
    background: var(--bg-card);
    border: 1px solid var(--border-soft);
    overflow: hidden;
}

.context-person strong {
    color: var(--text-secondary);
}

.context-person small {
    color: var(--text-muted);
}

.context-person__header {
    display: flex;
    justify-content: space-between;
    gap: 0.5rem;
    align-items: flex-start;
    margin-bottom: 0.4rem;
}

.context-person__title {
    font-weight: 600;
    color: var(--text-primary);
    line-height: 1.4;
}

.context-person__view {
    font-size: 0.85rem;
    color: var(--accent-primary);
    text-decoration: none;
    transition: color var(--transition-fast);
    flex-shrink: 0;
}

.context-person__view:hover {
    color: var(--accent-strong);
}

.context-person__notes {
    margin-top: 0.45rem;
    color: rgba(251, 191, 36, 0.85);
    font-size: 0.9rem;
}

.chat-alert {
    border-radius: var(--radius-md);
    padding: 0.85rem 1rem;
    font-size: 0.92rem;
}

.chat-alert--error {
    background: rgba(248, 113, 113, 0.16);
    border: 1px solid rgba(248, 113, 113, 0.35);
    color: #fecaca;
}

.chat-alert--info {
    background: rgba(56, 189, 248, 0.16);
    border: 1px solid rgba(56, 189, 248, 0.3);
    color: #bae6fd;
}

.chat-alert--warning {
    background: rgba(251, 191, 36, 0.18);
    border: 1px solid rgba(251, 191, 36, 0.32);
    color: #fef3c7;
}

html[data-theme="light"] .chat-alert--info {
    background: rgba(14, 165, 233, 0.14);
    border-color: rgba(14, 165, 233, 0.24);
    color: #0c4a6e;
}

html[data-theme="light"] .chat-alert--warning {
    background: rgba(251, 191, 36, 0.16);
    border-color: rgba(251, 191, 36, 0.24);
    color: #92400e;
}

.chat-footer-note {
    font-size: 0.8rem;
    color: var(--text-muted);
    text-align: right;
}

.chat-rate-warning {
    margin: 1rem 0 0;
}

table {
    width: 100%;
    border-collapse: collapse;
    border-spacing: 0;
}

th, td {
    text-align: left;
    padding: 0.65rem 0.85rem;
    border-bottom: 1px solid rgba(148, 163, 184, 0.18);
    color: var(--text-secondary);
}

thead th {
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-size: 0.85rem;
    color: var(--text-muted);
    background: var(--bg-card-muted);
}

.table-scroll {
    overflow-x: auto;
    border-radius: var(--radius-md);
    border: 1px solid var(--border-soft);
    overflow: hidden;
    background: var(--bg-card);
}

.cosmic-section-header {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 1.2rem;
    padding: clamp(1.6rem, 3vw, 2rem);
    border-radius: var(--radius-lg);
    background: var(--bg-elevated);
    border: 1px solid var(--border-soft);
    overflow: hidden;
    backdrop-filter: blur(var(--blur-amount));
    box-shadow: var(--shadow-soft);
}

.cosmic-section-header__meta {
    display: flex;
    flex-direction: column;
    gap: 0.6rem;
}

.cosmic-section-header__meta h1 {
    font-size: clamp(1.7rem, 3vw, 2.2rem);
    font-family: var(--font-serif);
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.cosmic-section-header__meta p {
    color: var(--text-secondary);
    font-size: 0.95rem;
    max-width: 560px;
}

.cosmic-section-header__actions {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
}

.calendar-view {
    display: flex;
    flex-direction: column;
    gap: clamp(1.6rem, 3vw, 2.4rem);
}

.calendar-shell {
    display: flex;
    flex-direction: column;
    gap: 1.6rem;
    padding: clamp(1.8rem, 3vw, 2.2rem);
    border-radius: var(--radius-lg);
    border: 1px solid var(--border-soft);
    overflow: hidden;
    background: var(--bg-card-muted);
    box-shadow: var(--shadow-soft);
    backdrop-filter: blur(var(--blur-amount));
}

.cosmic-alert {
    padding: 1.4rem 1.6rem;
    border-radius: var(--radius-md);
    border: 1px solid var(--border-soft);
    overflow: hidden;
    background: rgba(15, 23, 42, 0.65);
    color: var(--text-secondary);
    display: flex;
    flex-direction: column;
    gap: 0.45rem;
}

.cosmic-alert h3 {
    font-size: 1.1rem;
    font-weight: 600;
    color: var(--text-primary);
}

.cosmic-alert--error {
    border-color: rgba(248, 113, 113, 0.35);
    background: rgba(120, 20, 40, 0.35);
    color: #fecaca;
}

.cosmic-empty {
    padding: 2.2rem 1.8rem;
    border-radius: var(--radius-lg);
    border: 1px dashed var(--button-disabled-border);
    background: rgba(12, 20, 40, 0.6);
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 0.8rem;
    color: var(--text-secondary);
}

.cosmic-empty__icon {
    font-size: 2.4rem;
}

.cosmic-card {
    position: relative;
    background: var(--bg-elevated);
    border-radius: var(--radius-lg);
    padding: clamp(1.9rem, 3vw, 2.4rem);
    border: 1px solid var(--border-soft);
    overflow: hidden;
    box-shadow: var(--shadow-lg);
    backdrop-filter: blur(var(--blur-amount));
    overflow: hidden;
}

.cosmic-card::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    padding: 1px;
    background: linear-gradient(140deg, rgba(168, 85, 247, 0.28), rgba(56, 189, 248, 0.18), rgba(251, 191, 36, 0.14));
    -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
    -webkit-mask-composite: xor;
    mask-composite: exclude;
    pointer-events: none;
}

.cosmic-card > * {
    position: relative;
    z-index: 1;
}

.cosmic-calendar {
    display: flex;
    flex-direction: column;
    gap: clamp(1.8rem, 3vw, 2.4rem);
}

.calendar-legend {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.calendar-legend__title {
    font-size: 1.2rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--text-secondary);
}

.calendar-legend__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 0.75rem;
}

.calendar-legend__item {
    display: inline-flex;
    align-items: center;
    gap: 0.7rem;
    font-size: 0.9rem;
    color: var(--text-muted);
    padding: 0.55rem 0.75rem;
    border-radius: var(--radius-sm);
    background: var(--bg-card);
    border: 1px solid rgba(148, 163, 184, 0.18);
}

.calendar-legend__swatch {
    width: 18px;
    height: 18px;
    border-radius: 6px;
    box-shadow: inset 0 0 0 1px rgba(15, 23, 42, 0.45);
}

.calendar-layers {
    display: flex;
    flex-direction: column;
    gap: clamp(1.6rem, 3vw, 2rem);
}

.calendar-layer__header {
    display: flex;
    justify-content: space-between;
    gap: 1.2rem;
    margin-bottom: 1.2rem;
}

.calendar-layer__meta {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.calendar-layer__meta h3 {
    font-size: 1.35rem;
    font-family: var(--font-serif);
    letter-spacing: 0.08em;
}

.calendar-layer__stats {
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem 1.1rem;
    font-size: 0.9rem;
    color: var(--text-muted);
}

.calendar-layer__summary {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 0.9rem;
    margin-bottom: 1.2rem;
}

.calendar-layer__summary-item {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
    padding: 0.75rem 0.9rem;
    border-radius: var(--radius-sm);
    border: 1px solid var(--border-soft);
    overflow: hidden;
    background: rgba(15, 23, 42, 0.55);
}

.calendar-layer__summary-item strong {
    font-size: 0.8rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--text-secondary);
}

.calendar-layer__insight {
    margin-bottom: 1.4rem;
    padding: 1rem 1.1rem;
    border-radius: var(--radius-md);
    border: 1px solid rgba(168, 85, 247, 0.22);
    background: rgba(99, 102, 241, 0.08);
    color: var(--text-secondary);
    font-size: 0.95rem;
    line-height: 1.55;
}

.calendar-layer__insight-title {
    font-size: 0.8rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: rgba(168, 196, 255, 0.86);
    margin-bottom: 0.45rem;
}

.calendar-months {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(272px, 1fr));
    gap: 1.1rem;
}

.calendar-month {
    border-radius: var(--radius-md);
    border: 1px solid rgba(148, 163, 184, 0.18);
    background: var(--bg-card);
    padding: 1rem 1rem 1.4rem;
    display: flex;
    flex-direction: column;
    gap: 0.45rem;
    box-shadow: var(--shadow-soft);
}

html[data-theme="light"] .calendar-month {
    border-color: rgba(148, 163, 184, 0.28);
}

.calendar-month__name {
    text-align: center;
    font-weight: 600;
    font-size: 0.95rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--text-secondary);
    padding-bottom: 0.45rem;
    border-bottom: 1px solid rgba(148, 163, 184, 0.18);
}

.calendar-weekdays {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 2px;
}

.calendar-weekday {
    text-align: center;
    font-size: 0.68rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--text-muted);
}

.calendar-days {
    display: grid;
    grid-template-columns: repeat(7, minmax(0, 1fr));
    gap: clamp(6px, 1.6vw, 8px);
    padding: 14px clamp(14px, 3vw, 20px) 20px;
    justify-items: center;
}

.calendar-months {
    gap: 1.1rem;
}

.calendar-day {
    position: relative;
    width: clamp(28px, 5vw, 32px);
    height: clamp(28px, 5vw, 32px);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.85rem;
    font-weight: 600;
    border-radius: 50%;
    border: 1px solid rgba(255, 255, 255, 0.08);
    color: #f8fafc;
    text-shadow: 0 0 6px rgba(3, 7, 18, 0.65);
    transition: transform var(--transition-fast), box-shadow var(--transition-fast);
    cursor: pointer;
}

html[data-theme="light"] .calendar-day {
    border-color: rgba(148, 163, 184, 0.25);
    text-shadow: none;
    color: var(--text-primary);
}

html[data-theme="light"] .calendar-day:hover {
    box-shadow: 0 12px 24px -12px rgba(15, 23, 42, 0.25);
    border-color: rgba(79, 70, 229, 0.35);
}

.calendar-day span {
    pointer-events: none;
}

.calendar-day:hover {
    transform: scale(1.25);
    z-index: 3;
    box-shadow: 0 12px 28px -12px rgba(251, 191, 36, 0.6);
    border-color: rgba(251, 191, 36, 0.5);
}

.event-day.event-day--radiant {
    background: linear-gradient(145deg, #bae6fd, #0ea5e9);
    border-color: #0ea5e9;
    color: #032a40;
    box-shadow: 0 12px 28px -18px rgba(14, 165, 233, 0.55);
}

.event-day.event-day--stellar {
    background: linear-gradient(145deg, #99f6e4, #14b8a6);
    border-color: #0f766e;
    color: #022c22;
    box-shadow: 0 12px 26px -18px rgba(20, 184, 166, 0.55);
}

.event-day.event-day--supportive {
    background: linear-gradient(145deg, #a7f3d0, #4ade80);
    border-color: #16a34a;
    color: #064e3b;
    box-shadow: 0 12px 24px -16px rgba(74, 222, 128, 0.55);
}

.event-day.event-day--steady {
    background: linear-gradient(145deg, #fef3c7, #facc15);
    border-color: #d97706;
    color: #7c2d12;
    box-shadow: 0 12px 24px -16px rgba(250, 204, 21, 0.55);
}

.event-day.event-day--balanced {
    background: linear-gradient(145deg, #fde68a, #fbbf24);
    border-color: #ea580c;
    color: #7c2d12;
    box-shadow: 0 12px 24px -16px rgba(251, 191, 36, 0.55);
}

.event-day.event-day--sensitive {
    background: linear-gradient(145deg, #fed7aa, #fb923c);
    border-color: #ea580c;
    color: #7c2d12;
    box-shadow: 0 12px 24px -16px rgba(251, 146, 60, 0.6);
}

.event-day.event-day--critical {
    background: linear-gradient(145deg, #fecdd3, #ef4444);
    border-color: #b91c1c;
    color: #7f1d1d;
    box-shadow: 0 12px 26px -18px rgba(239, 68, 68, 0.65);
}

.event-day.event-day--highlight-top {
    box-shadow: 0 0 0 1px rgba(16, 185, 129, 0.5) inset, 0 14px 28px -18px rgba(45, 212, 191, 0.7) !important;
}

.event-day.event-day--highlight-bottom {
    box-shadow: 0 0 0 1px rgba(249, 115, 22, 0.55) inset, 0 14px 28px -18px rgba(248, 113, 113, 0.7) !important;
}

.event-day.event-day--crowned {
    border: 2px solid rgba(253, 224, 71, 0.9) !important;
    box-shadow: 0 0 0 2px rgba(253, 224, 71, 0.35), 0 16px 32px -16px rgba(253, 224, 71, 0.55) !important;
}

.event-day.event-day--flagged {
    border: 2px solid rgba(248, 113, 113, 0.9) !important;
    box-shadow: 0 0 0 2px rgba(248, 113, 113, 0.35), 0 16px 32px -16px rgba(248, 113, 113, 0.6) !important;
}

.calendar-day.is-empty {
    background: transparent;
    border: none;
    cursor: default;
}

.calendar-day.is-empty:hover {
    transform: none;
    box-shadow: none;
}

.calendar-layer__weights {
    margin-bottom: 1.2rem;
    display: flex;
    flex-direction: column;
    gap: 0.6rem;
    color: var(--text-secondary);
    font-size: 0.9rem;
}

.calendar-layer__weight-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

    background: rgba(148, 163, 184, 0.12);
}

.calendar-event-view {
    margin-top: 1.5rem;
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.calendar-event-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
}

.event-calendar-legend {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem 1.1rem;
    font-size: 0.85rem;
    color: var(--text-muted);
    align-items: center;
    line-height: 1.4;
}

.event-calendar-legend span {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
}

.legend-dot {
    width: 12px;
    height: 12px;
    border-radius: 50%;
    display: inline-flex;
    margin-right: 0.15rem;
    box-shadow: 0 0 0 1px rgba(15, 23, 42, 0.12) inset;
}

.legend-dot--radiant { background: linear-gradient(135deg, #bae6fd, #0ea5e9); }
.legend-dot--stellar { background: linear-gradient(135deg, #99f6e4, #14b8a6); }
.legend-dot--supportive { background: linear-gradient(135deg, #a7f3d0, #4ade80); }
.legend-dot--steady { background: linear-gradient(135deg, #fef3c7, #facc15); }
.legend-dot--balanced { background: linear-gradient(135deg, #fde68a, #fbbf24); }
.legend-dot--sensitive { background: linear-gradient(135deg, #fed7aa, #fb923c); }
.legend-dot--critical { background: linear-gradient(135deg, #fecdd3, #ef4444); }

.event-view-controls {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

.event-view-controls select {
    background: var(--bg-card-muted);
    border: 1px solid rgba(148, 163, 184, 0.25);
    border-radius: 12px;
    padding: 0.4rem 0.6rem;
}

.event-calendar-status {
    padding: 0.85rem 1rem;
    border-radius: var(--radius-md);
    background: rgba(59, 130, 246, 0.08);
    border: 1px dashed rgba(59, 130, 246, 0.35);
    font-size: 0.95rem;
}

.event-calendar-summary {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    font-size: 0.9rem;
    color: var(--text-secondary);
}

.event-calendar-summary span {
    display: inline-flex;
    gap: 0.35rem;
}

#event-calendar-grid .calendar-month {
    background: rgba(255, 255, 255, 0.03);
}

.calendar-weight-tag {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    border-radius: 999px;
    padding: 0.4rem 0.75rem;
    font-size: 0.82rem;
    letter-spacing: 0.02em;
    background: rgba(56, 189, 248, 0.14);
    color: rgba(186, 230, 253, 0.95);
    border: 1px solid rgba(56, 189, 248, 0.32);
}

html[data-theme="light"] .calendar-weight-tag {
    background: rgba(99, 102, 241, 0.08);
    color: #1e1b4b;
    border-color: rgba(99, 102, 241, 0.2);
}

.calendar-layer--global {
    border-color: rgba(79, 70, 229, 0.25);
    background: var(--bg-card);
    box-shadow: 0 24px 60px -32px rgba(15, 23, 42, 0.45);
}

html[data-theme="light"] .calendar-layer--global {
    border-color: rgba(99, 102, 241, 0.2);
    box-shadow: 0 24px 60px -32px rgba(15, 23, 42, 0.12);
}

.calendar-layer--global .calendar-month {
    background: var(--bg-card-muted);
    border-radius: 18px;
    padding: 1rem;
    box-shadow: inset 0 0 0 1px rgba(148, 163, 184, 0.2);
}

.calendar-layer--global .calendar-months {
    gap: 1.5rem;
}

.calendar-tooltip {
    position: absolute;
    background: rgba(3, 7, 18, 0.95);
    border: 1px solid rgba(251, 191, 36, 0.45);
    color: #f8fafc;
    padding: 0.75rem 0.9rem;
    border-radius: var(--radius-sm);
    box-shadow: 0 20px 45px -20px rgba(3, 7, 18, 0.8);
    backdrop-filter: blur(12px);
    pointer-events: none;
    z-index: 999;
    width: max-content;
    max-width: 280px;
    text-align: center;
}

.calendar-tooltip__score {
    color: rgba(186, 230, 253, 0.9);
    margin-bottom: 0.35rem;
    font-weight: 600;
}

.calendar-tooltip__interpretation {
    font-size: 0.85rem;
    color: var(--text-secondary);
}


.visually-hidden {
    position: absolute !important;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    border: 0;
}

.kundali-tabs-page {
    display: flex;
    flex-direction: column;
    gap: clamp(1.8rem, 3vw, 2.6rem);
}

.kundali-hero {
    display: flex;
    flex-direction: column;
    gap: 1.8rem;
    padding: clamp(2rem, 4vw, 2.8rem);
    border-radius: var(--radius-lg);
    border: 1px solid var(--border-soft);
    overflow: hidden;
    background: radial-gradient(circle at 15% -10%, rgba(56, 189, 248, 0.16), transparent 65%),
                radial-gradient(circle at 80% -20%, rgba(168, 85, 247, 0.18), transparent 60%),
                var(--bg-elevated);
    box-shadow: var(--shadow-lg);
}

.kundali-hero__body {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1.5rem;
    flex-wrap: wrap;
}

.hero-actions {
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
    align-items: center;
}

.kundali-hero__meta {
    display: flex;
    flex-direction: column;
    gap: 0.9rem;
}

.chip--soft {
    background: rgba(56, 189, 248, 0.16);
    border: 1px solid var(--border-soft);
    overflow: hidden;
    color: rgba(186, 230, 253, 0.95);
}

html[data-theme="light"] .chip--soft {
    background: rgba(14, 165, 233, 0.12);
    color: var(--accent-secondary);
}

.kundali-hero__title {
    font-size: clamp(2.2rem, 4vw, 3rem);
    letter-spacing: 0.16em;
    text-transform: uppercase;
    font-family: var(--font-serif);
    color: var(--text-primary);
}

.kundali-hero__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 1rem;
}

.hero-card {
    border-radius: var(--radius-md);
    border: 1px solid var(--border-soft);
    overflow: hidden;
    background: var(--bg-card);
    padding: 1rem 1.15rem;
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

.hero-card h3 {
    margin: 0;
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--text-muted);
}

.hero-card p {
    margin: 0;
    font-size: 1rem;
    font-weight: 600;
    color: var(--text-primary);
}

.header-section {
    padding: clamp(1.6rem, 3vw, 2rem);
    border-radius: var(--radius-lg);
    background: var(--bg-card-strong);
    border: 1px solid var(--border-soft);
    overflow: hidden;
    box-shadow: var(--shadow-soft);
}

html[data-theme="light"] .header-section {
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.92), rgba(226, 232, 240, 0.82));
}

.header-section .container {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: center;
    flex-wrap: wrap;
}

.page-title {
    font-family: var(--font-serif);
    font-size: clamp(1.8rem, 3vw, 2.3rem);
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--text-primary);
}

.page-subtitle {
    color: var(--text-secondary);
    font-size: 0.95rem;
    margin-top: 0.35rem;
}

.back-link {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    color: var(--text-primary);
    background: var(--gradient-primary);
    border: 1px solid transparent;
    padding: 0.6rem 1.2rem;
    border-radius: 999px;
    font-weight: 600;
    transition: transform var(--transition-fast), box-shadow var(--transition-fast);
}

.back-link:hover {
    transform: translateY(-2px);
    box-shadow: 0 20px 40px -20px rgba(56, 189, 248, 0.6);
}

.kundali-tabs-container {
    display: flex;
    flex-direction: column;
    gap: 1.4rem;
}

.tab-link-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 1rem;
}

.tab-link {
    background: var(--bg-card);
    border: 1px solid var(--border-soft);
    overflow: hidden;
    border-radius: var(--radius-md);
    color: var(--text-secondary);
    padding: 1.1rem 1.2rem;
    display: flex;
    flex-direction: column;
    gap: 0.45rem;
    align-items: center;
    justify-content: center;
    min-height: 120px;
    font-weight: 600;
    transition: transform var(--transition-fast), border-color var(--transition-fast), background var(--transition-fast), box-shadow var(--transition-fast);
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.tab-link:hover {
    transform: translateY(-2px);
    border-color: rgba(56, 189, 248, 0.5);
}

.tab-link.active {
    background: var(--gradient-primary-soft);
    border-color: rgba(168, 85, 247, 0.4);
    color: var(--text-primary);
    box-shadow: 0 22px 38px -24px rgba(56, 189, 248, 0.65);
}

.tab-link__icon {
    font-size: 1.5rem;
}

.tab-link__title {
    font-size: 0.92rem;
}

.tab-link__subtitle {
    font-size: 0.75rem;
    letter-spacing: 0.08em;
    color: var(--text-muted);
}

.tab-content-wrapper {
    display: flex;
    flex-direction: column;
    gap: 1.6rem;
    padding: clamp(1.8rem, 3vw, 2.2rem);
    border-radius: var(--radius-lg);
    border: 1px solid var(--border-soft);
    overflow: hidden;
    background: var(--bg-card-muted);
    box-shadow: var(--shadow-soft);
    backdrop-filter: blur(var(--blur-amount));
}

.tab-content-area {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.tab-pane {
    display: none;
    width: 100%;
}

.tab-pane.show,
.tab-pane.active {
    display: block;
}

.tab-header {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 1rem;
}

.tab-header h3 {
    font-size: 1.4rem;
    font-family: var(--font-serif);
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.tab-actions {
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
}

.kundali-section {
    display: flex;
    flex-direction: column;
    gap: 1.4rem;
}

.section-title {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    flex-wrap: wrap;
    gap: 0.75rem;
    font-size: 1.1rem;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--accent-secondary);
}

.charts-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 1.2rem;
}

.chart-item {
    position: relative;
}

.chart-item-trigger {
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: 0.45rem;
    padding: 1rem 1.15rem;
    border-radius: var(--radius-md);
    border: 1px solid var(--border-soft);
    overflow: hidden;
    background: var(--bg-card);
    color: var(--text-secondary);
    text-align: left;
    transition: transform var(--transition-fast), border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.chart-item-trigger:hover,
.chart-item-trigger:focus-visible {
    transform: translateY(-4px);
    border-color: rgba(168, 85, 247, 0.4);
    box-shadow: 0 18px 36px -24px rgba(56, 189, 248, 0.6);
    outline: none;
}

.chart-name {
    font-weight: 600;
    font-size: 1rem;
    color: var(--text-primary);
}

.chart-details {
    display: flex;
    flex-direction: column;
    gap: 0.3rem;
    font-size: 0.9rem;
    color: var(--text-muted);
}

.chart-strength {
    font-weight: 600;
    color: var(--accent-secondary);
}

.chart-cta {
    margin-top: 0.4rem;
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    font-size: 0.85rem;
    color: var(--accent-secondary);
}

.divisional-modal {
    position: fixed;
    inset: 0;
    background: rgba(3, 7, 18, 0.6);
    display: none;
    align-items: center;
    justify-content: center;
    padding: 2rem;
    z-index: 2000;
}

.divisional-modal.is-open {
    display: flex;
}

.divisional-modal__backdrop {
    position: absolute;
    inset: 0;
    touch-action: auto;
    cursor: pointer;
}

.divisional-modal__dialog {
    position: relative;
    background: var(--bg-card-strong);
    border-radius: var(--radius-lg);
    border: 1px solid var(--border-soft);
    overflow: hidden;
    box-shadow: var(--shadow-xl);
    width: min(900px, 92vw);
    max-height: 90vh;
    overflow-y: auto;
    padding: clamp(1.6rem, 3vw, 2.2rem);
}

.divisional-modal__header {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: flex-start;
    margin-bottom: 1.2rem;
}

.divisional-modal__title {
    font-size: 1.35rem;
    font-family: var(--font-serif);
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.divisional-modal__close {
    position: relative;
    background: rgba(148, 163, 184, 0.15);
    border: 2px solid rgba(148, 163, 184, 0.4);
    color: var(--text-primary);
    font-size: 1.8rem;
    font-weight: 300;
    line-height: 1;
    cursor: pointer;
    transition: all var(--transition-fast);
    touch-action: manipulation;
    -webkit-tap-highlight-color: rgba(99, 102, 241, 0.4);
    -webkit-touch-callout: none;
    user-select: none;
    -webkit-user-select: none;
    padding: 0;
    width: 52px;
    height: 52px;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 9999;
    pointer-events: auto;
    border-radius: 50%;
    flex-shrink: 0;
}

.divisional-modal__close:active {
    color: #fff;
    background: rgba(99, 102, 241, 0.4);
    border-color: var(--accent-primary);
    transform: scale(0.85);
}

.divisional-modal__close:hover {
    color: #fff;
    background: rgba(148, 163, 184, 0.3);
    border-color: var(--accent-primary);
}

.divisional-modal__meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem;
    margin-bottom: 1.2rem;
}

.divisional-chip {
    background: rgba(56, 189, 248, 0.12);
    border-radius: 999px;
    padding: 0.35rem 0.8rem;
    font-size: 0.8rem;
    color: rgba(186, 230, 253, 0.95);
    border: 1px solid rgba(56, 189, 248, 0.3);
}

html[data-theme="light"] .divisional-chip {
    background: rgba(14, 165, 233, 0.12);
    color: var(--accent-secondary);
    border-color: rgba(14, 165, 233, 0.24);
}

.divisional-modal__body {
    display: flex;
    flex-direction: column;
    gap: 1.4rem;
}

.divisional-modal__section {
    display: flex;
    flex-direction: column;
    gap: 0.6rem;
}

.divisional-modal__section h4 {
    font-size: 1.05rem;
    color: var(--text-secondary);
}

.divisional-summary {
    background: var(--bg-card);
    border-radius: var(--radius-md);
    border: 1px solid var(--border-soft);
    overflow: hidden;
    padding: 1rem 1.1rem;
    color: var(--text-secondary);
    line-height: 1.6;
}

.divisional-table-wrapper {
    border: 1px solid var(--border-soft);
    overflow: hidden;
    border-radius: var(--radius-md);
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
}

.divisional-table {
    width: 100%;
    min-width: 720px;
    border-collapse: collapse;
    background: var(--bg-card-strong);
}

.divisional-table thead {
    background: var(--bg-card-highlight);
    color: var(--text-secondary);
}

.divisional-table th,
.divisional-table td {
    padding: 0.65rem 0.8rem;
    border-bottom: 1px solid rgba(148, 163, 184, 0.18);
    font-size: 0.9rem;
    color: var(--text-secondary);
}

.divisional-table tbody tr:hover {
    background: rgba(56, 189, 248, 0.12);
}

html[data-theme="light"] .divisional-table tbody tr:hover {
    background: rgba(14, 165, 233, 0.12);
}

.ashtakavarga-metrics {
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem;
    margin-bottom: 1.2rem;
}

.ashtakavarga-chip {
    border-radius: 999px;
    padding: 0.45rem 0.85rem;
    background: var(--bg-card);
    border: 1px solid rgba(168, 85, 247, 0.3);
    color: var(--text-secondary);
    font-size: 0.88rem;
    font-weight: 600;
}

html[data-theme="light"] .ashtakavarga-chip {
    border-color: rgba(99, 102, 241, 0.26);
}

.ashtakavarga-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 1rem;
}

.ashtakavarga-card-trigger {
    border-radius: var(--radius-md);
    padding: 1rem 1.1rem;
    background: var(--bg-card);
    border: 1px solid var(--border-soft);
    overflow: hidden;
    color: var(--text-secondary);
    display: flex;
    flex-direction: column;
    gap: 0.6rem;
    transition: transform var(--transition-fast), border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.ashtakavarga-card-trigger:hover,
.ashtakavarga-card-trigger:focus-visible {
    transform: translateY(-3px);
    border-color: rgba(56, 189, 248, 0.45);
    box-shadow: 0 18px 34px -24px rgba(56, 189, 248, 0.56);
    outline: none;
}

.ashtakavarga-card-trigger h4 {
    font-size: 1rem;
    color: rgba(251, 191, 36, 0.9);
}

.bindu-total {
    font-size: 0.9rem;
    color: var(--text-secondary);
    font-weight: 600;
    display: flex;
    align-items: center;
    gap: 0.45rem;
}

.bindu-badge {
    border-radius: 999px;
    padding: 0.2rem 0.65rem;
    background: linear-gradient(140deg, rgba(251, 191, 36, 0.85), rgba(245, 158, 11, 0.85));
    color: #0f172a;
    font-size: 0.82rem;
    font-weight: 700;
}

.ashtakavarga-card-trigger dl {
    margin: 0;
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 0.3rem 0.65rem;
    font-size: 0.85rem;
    color: var(--text-muted);
}

.ashtakavarga-house-table {
    margin-top: 0.5rem;
}

.chart-canvas-wrap {
    max-width: 620px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: 0.9rem;
}

.chart-canvas {
    min-height: 500px;
    border-radius: var(--radius-md);
    border: 1px solid var(--border-soft);
    overflow: hidden;
    background: var(--bg-card);
    position: relative;
    overflow: hidden;
}

.chart-canvas-container {
    display: flex;
    justify-content: center;
    margin: 1.5rem 0;
}

.chart-note {
    margin: 0;
    color: var(--text-secondary);
    font-size: 0.92rem;
    line-height: 1.55;
}

.chart-error {
    color: rgba(252, 165, 165, 0.92);
    text-align: center;
    padding: 1.8rem;
    border-radius: var(--radius-md);
    border: 1px solid rgba(248, 113, 113, 0.35);
    background: rgba(120, 20, 40, 0.32);
}

.planets-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 1rem;
}

.planet-item {
    padding: 0.85rem 1rem;
    display: flex;
    flex-direction: column;
    gap: 0.6rem;
}

.planet-name {
    font-size: 1rem;
}

.planet-details {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.4rem 0.6rem;
    font-size: 0.85rem;
    color: var(--text-muted);
}

.planet-details > div {
    line-height: 1.35;
}

.house-lords-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 0.9rem;
}

.house-lord-card {
    border-radius: var(--radius-md);
    border: 1px solid var(--border-soft);
    overflow: hidden;
    background: var(--bg-card);
    padding: 0.85rem 1rem;
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
    color: var(--text-secondary);
}

.house-no {
    font-size: 0.8rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--text-muted);
}

.house-sign {
    font-weight: 600;
    font-size: 0.95rem;
    color: rgba(251, 191, 36, 0.9);
}

.house-lord {
    font-size: 0.9rem;
}

.lord-placement {
    font-size: 0.85rem;
    color: var(--text-muted);
}

.yogas-doshas-container {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 1rem;
}

.yogas-doshas-container h4 {
    font-size: 1rem;
    margin-bottom: 0.6rem;
    color: var(--text-secondary);
}

.year-selector {
    display: flex;
    align-items: center;
}

.year-selector select {
    border-radius: 999px;
    padding: 0.55rem 1.2rem;
    background: var(--bg-card);
    border: 1px solid var(--border-soft);
    color: var(--text-secondary);
    appearance: none;
    font-size: 0.9rem;
    width: auto;
    min-width: 120px;
}

html[data-theme="light"] .year-selector select {
    border-color: rgba(148, 163, 184, 0.28);
}

.year-selector select:focus {
    outline: none;
    border-color: rgba(56, 189, 248, 0.55);
    box-shadow: 0 0 0 3px rgba(56, 189, 248, 0.15);
}

.details-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 1rem;
}

.detail-item {
    display: flex;
    flex-direction: column;
    gap: 0.3rem;
    padding: 0.75rem 0.9rem;
    border-radius: var(--radius-md);
    border: 1px solid var(--border-soft);
    overflow: hidden;
    background: var(--bg-card);
}

.detail-label {
    font-size: 0.75rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--text-muted);
}

.detail-value {
    color: var(--text-secondary);
    font-weight: 600;
}

.placeholder-icon {
    width: 48px;
    height: 48px;
    border-radius: 16px;
    background: rgba(56, 189, 248, 0.18);
    display: flex;
    align-items: center;
    justify-content: center;
    color: rgba(186, 230, 253, 0.9);
    font-size: 1.2rem;
}

.dosha-item,
.yoga-item,
.yogas-section,
.doshas-section,
.interpretation-section {
    border-radius: var(--radius-md);
    border: 1px solid var(--border-soft);
    overflow: hidden;
    background: var(--bg-card);
    padding: 1rem 1.1rem;
    color: var(--text-secondary);
}

.planet-item {
    border-radius: var(--radius-md);
    border: 1px solid var(--border-soft);
    overflow: hidden;
    background: var(--bg-card);
    padding: 0.85rem 1rem;
    color: var(--text-secondary);
}

.planet-name,
.yoga-name,
.dosha-name {
    font-weight: 600;
    color: var(--text-primary);
}

.positive {
    color: rgba(134, 239, 172, 0.9);
}

.negative {
    color: rgba(252, 165, 165, 0.9);
}

.status-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    border-radius: 999px;
    padding: 0.3rem 0.75rem;
    font-size: 0.78rem;
}

.status-generated {
    background: rgba(34, 197, 94, 0.18);
    color: rgba(187, 247, 208, 0.9);
    border: 1px solid rgba(34, 197, 94, 0.35);
}

html[data-theme="light"] .status-generated {
    background: rgba(74, 222, 128, 0.16);
    color: #15803d;
    border-color: rgba(74, 222, 128, 0.35);
}

::-webkit-scrollbar {
    width: 10px;
    height: 10px;
}

::-webkit-scrollbar-track {
    background: rgba(15, 23, 42, 0.5);
}

::-webkit-scrollbar-thumb {
    background: rgba(148, 163, 184, 0.4);
    border-radius: 999px;
}

::-webkit-scrollbar-thumb:hover {
    background: rgba(148, 163, 184, 0.6);
}

html[data-theme="light"] ::-webkit-scrollbar-track {
    background: rgba(226, 232, 240, 0.65);
}

html[data-theme="light"] ::-webkit-scrollbar-thumb {
    background: rgba(148, 163, 184, 0.55);
}

html[data-theme="light"] ::-webkit-scrollbar-thumb:hover {
    background: rgba(148, 163, 184, 0.75);
}

@media (min-width: 1024px) {
    .chat-layout {
        grid-template-columns: minmax(0, 2.1fr) minmax(260px, 0.9fr);
    }

    .header-wrapper {
        flex-direction: row;
        justify-content: space-between;
        align-items: center;
    }

    .profile-main {
        grid-template-columns: minmax(280px, 340px) minmax(0, 1fr);
    }
}

@media (max-width: 900px) {
    .app-main {
        padding-inline: clamp(1rem, 4vw, 2rem);
    }

    .app-header {
        padding-inline: clamp(1rem, 4vw, 2rem);
    }

    .app-footer {
        padding-inline: clamp(1rem, 4vw, 2rem);
    }

    .card {
        padding: clamp(1.6rem, 5vw, 2.4rem);
    }

    .profile-main {
        grid-template-columns: 1fr;
    }

    .profile-info {
        flex-direction: column;
        align-items: flex-start;
    }

    .profile-card--sticky {
        position: static;
    }

    .kundali-hero__body {
        flex-direction: column;
        align-items: stretch;
    }

    .cosmic-section-header {
        flex-direction: column;
        align-items: stretch;
    }

    .family-scroll {
        max-height: none;
        padding-right: 0;
        margin-right: 0;
    }

    .calendar-months {
        grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    }

    .welcome-layout {
        grid-template-columns: 1fr;
        gap: 1.2rem;
    }

    .tab-link {
        min-height: 110px;
        padding: 1rem;
    }
}

@media (max-width: 640px) {
    .cosmic-shell {
        padding-block: 32px 72px;
    }

    .brand-tagline {
        letter-spacing: 0.12em;
        font-size: 0.78rem;
    }

    .app-header {
        align-items: center;
    }

    .app-header__actions {
        gap: 0.5rem;
    }

    .app-header__actions .btn-sm {
        padding: 0.45rem 0.8rem;
        font-size: 0.75rem;
    }

    .app-header__actions .theme-toggle {
        width: 38px;
        height: 38px;
    }

    .app-header__actions .theme-toggle .theme-toggle__icon {
        font-size: 1rem;
    }

    .container {
        gap: 20px;
    }

    .login-card, .welcome-card, .form-container, .profile-header, .family-section {
        padding: clamp(1.4rem, 6vw, 1.9rem);
    }

    .actions,
    .form-actions,
    .header-actions,
    .kundali-actions,
    .member-kundali-actions {
        flex-direction: column;
        align-items: stretch;
    }

    .btn, .login-btn {
        width: 100%;
    }

    .profile-avatar, .profile-avatar-placeholder {
        width: 80px;
        height: 80px;
    }

    .family-grid {
        grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    }

    .chat-layout {
        grid-template-columns: 1fr;
    }

    .cosmic-section-header__actions {
        width: 100%;
        justify-content: flex-start;
    }

    .calendar-months {
        grid-template-columns: 1fr;
    }

    .tab-link-grid {
        grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    }

    .kundali-hero__grid {
        grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    }

    .chat-input-area {
        flex-direction: column;
        align-items: stretch;
        gap: 0.75rem;
    }

    .chat-input-area textarea {
        min-height: 120px;
    }

    .chat-input-area button {
        width: 100%;
    }

    .welcome-highlights li {
        padding-left: 1.2rem;
        font-size: 0.95rem;
    }

    .admin-header-card {
        flex-direction: column;
        align-items: stretch;
    }

    .admin-header-card__meta {
        justify-content: flex-start;
        text-align: left;
    }

    .admin-stats-grid,
    .admin-stats-grid--compact {
        grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    }

    .admin-stat-card {
        min-height: 0;
    }

    .admin-feedback-card header {
        flex-direction: column;
        align-items: flex-start;
    }
}

@media (max-width: 560px) {
    .admin-stats-grid,
    .admin-stats-grid--compact {
        grid-template-columns: 1fr;
    }

    .admin-feedback-card__meta {
        flex-direction: column;
        align-items: flex-start;
        gap: 0.4rem;
    }

    .admin-feedback-card__ratings {
        flex-direction: column;
        gap: 0.6rem;
    }
}

@media (max-width: 480px) {
    body {
        letter-spacing: 0.005em;
    }

    h1, h2 {
        letter-spacing: 0.06em;
    }

    .app-header__actions {
        gap: 0.35rem;
    }

    .app-header__actions .btn-sm {
        padding: 0.4rem 0.6rem;
        font-size: 0.7rem;
    }

    .app-header__actions .theme-toggle {
        width: 34px;
        height: 34px;
    }

    .brand {
        font-size: clamp(1.4rem, 5vw, 1.8rem);
    }

    .brand-tagline {
        font-size: 0.65rem;
        letter-spacing: 0.08em;
    }

    .tab-link {
        min-height: 96px;
        gap: 0.25rem;
    }

    .tab-link__icon {
        font-size: 1.3rem;
    }

    .tab-link__title {
        font-size: 0.88rem;
    }

.tab-link__subtitle {
        font-size: 0.72rem;
    }

    .calendar-legend__grid,
    .calendar-months {
        grid-template-columns: 1fr;
    }

    .calendar-month {
        padding: 0.75rem;
    }

    .welcome-card,
    .welcome-aside {
        padding: 1.4rem;
    }

    .welcome-highlights li::before {
        top: 0.2rem;
    }
}

/* Matchmaking */
.matchmaking-page {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
    padding-bottom: 2rem;
}

.matchmaking-hero,
.matchmaking-card,
.partners-card,
.breakdown-card {
    padding: clamp(1.5rem, 4vw, 2rem);
}

.matchmaking-results {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.matchmaking-hero {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: center;
}

.matchmaking-hero__actions {
    display: flex;
    gap: 0.75rem;
}

.matchmaking-form {
    display: flex;
    flex-direction: column;
    gap: 1.2rem;
}

.partner-selection-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 1rem;
}

.partner-select label {
    display: block;
    font-weight: 600;
    margin-bottom: 0.4rem;
}

.partner-select select {
    width: 100%;
    padding: 0.75rem 0.95rem;
    border-radius: 14px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    background: rgba(255, 255, 255, 0.05);
    color: inherit;
}

.role-label {
    margin-top: 0.8rem;
}

.matchmaking-form__footer {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    gap: 0.75rem;
}

.matchmaking-form__footer .checkbox-inline {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.9rem;
}

.form-note {
    font-size: 0.85rem;
    color: rgba(255, 255, 255, 0.7);
    margin: 0;
}

.score-card {
    display: flex;
    gap: 1.5rem;
    align-items: center;
}

.score-ring {
    width: 160px;
    height: 160px;
    border-radius: 50%;
    border: 8px solid rgba(45, 255, 196, 0.35);
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    background: radial-gradient(circle, rgba(45, 255, 196, 0.2), transparent);
}

.score-value {
    font-size: 2.8rem;
    font-weight: 700;
}

.score-max {
    font-size: 0.9rem;
    opacity: 0.7;
}

.score-content {
    flex: 1;
}

.score-label {
    font-size: 1rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    opacity: 0.8;
    margin-bottom: 0.3rem;
}

.score-summary {
    font-size: 1.2rem;
    margin-bottom: 0.6rem;
}

.score-tags {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.insight-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 1rem;
}

.insight-card {
    border-radius: 16px;
    background: var(--bg-card);
    padding: 1.25rem;
    border: 1px solid var(--border-soft);
}

.insight-card.caution {
    background: linear-gradient(135deg, rgba(251, 113, 133, 0.18), rgba(250, 204, 21, 0.08));
    border-color: rgba(251, 113, 133, 0.35);
}

.insight-card ul {
    margin: 0.6rem 0 0;
    padding-left: 1.2rem;
}

.alert {
    border-radius: 16px;
    padding: 1rem 1.2rem;
    border: 1px solid transparent;
}

.alert-info {
    background: rgba(45, 182, 255, 0.08);
    border-color: rgba(45, 182, 255, 0.3);
}

.alert-warning {
    background: rgba(255, 197, 110, 0.08);
    border-color: rgba(255, 197, 110, 0.4);
}

.breakdown-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.95rem;
}

.breakdown-table th,
.breakdown-table td {
    padding: 0.9rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
    text-align: left;
    vertical-align: top;
}

.breakdown-table tr:last-child td {
    border-bottom: none;
}

.breakdown-table tr.status-strong {
    background: rgba(45, 255, 196, 0.05);
}

.breakdown-table tr.status-needs-attention {
    background: rgba(255, 110, 110, 0.05);
}

.partners-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 1rem;
}

.partner-panel {
    border-radius: 16px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    padding: 1.25rem;
    background: rgba(255, 255, 255, 0.02);
}

.partner-role {
    text-transform: uppercase;
    letter-spacing: 0.12em;
    font-size: 0.75rem;
    opacity: 0.7;
}

.partner-panel ul {
    list-style: none;
    margin: 0.8rem 0 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

.matchmaking-actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1.25rem;
    padding: 1.25rem;
}

.matchmaking-actions__icon {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: linear-gradient(135deg, rgba(168, 85, 247, 0.2), rgba(59, 130, 246, 0.25));
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.4rem;
}

.matchmaking-actions__body {
    flex: 1;
}

.matchmaking-actions__body h3 {
    margin: 0;
    font-size: 1.05rem;
    letter-spacing: 0.05em;
}

.matchmaking-actions__body p {
    margin: 0.25rem 0 0;
    color: var(--text-secondary);
    font-size: 0.95rem;
}

.btn-pill {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    border-radius: 999px;
    padding-inline: 1.4rem;
    font-weight: 600;
}

.btn-pill svg {
    display: block;
}

.matchmaking-status {
    padding: 1.2rem;
    border-radius: 16px;
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

.matchmaking-status p {
    margin: 0;
    color: var(--text-muted);
    font-size: 0.9rem;
}

.muhurat-finder {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    border: 1px solid rgba(148, 163, 184, 0.2);
}

.muhurat-finder__header {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 1rem;
}

.muhurat-form__grid {
    display: grid;
    gap: 1rem;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.muhurat-form__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    align-items: center;
}

.muhurat-status {
    font-size: 0.9rem;
    color: var(--text-muted);
}

.muhurat-status--info {
    color: #38bdf8;
}

.muhurat-status--success {
    color: #34d399;
}

.muhurat-status--warning {
    color: #facc15;
}

.muhurat-status--error {
    color: #f87171;
}

.muhurat-results {
    display: grid;
    gap: 1rem;
    margin-top: 0.5rem;
}

.muhurat-slot-card {
    border: 1px solid rgba(148, 163, 184, 0.25);
    border-radius: 16px;
    padding: 1rem;
    background: var(--bg-card);
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    box-shadow: 0 16px 40px -28px rgba(15, 23, 42, 0.4);
}

html[data-theme="light"] .muhurat-slot-card {
    border-color: rgba(99, 102, 241, 0.18);
    box-shadow: 0 16px 36px -20px rgba(15, 23, 42, 0.15);
}

.muhurat-slot-card__header {
    display: flex;
    justify-content: space-between;
    gap: 0.75rem;
    align-items: flex-start;
}

.muhurat-slot-card__header h4 {
    margin: 0;
    font-size: 1rem;
}

.muhurat-slot-card__subtitle {
    margin: 0.1rem 0 0;
    color: var(--text-muted);
    font-size: 0.9rem;
}

.muhurat-slot-card__score {
    font-size: 0.9rem;
    color: var(--text-muted);
}

.muhurat-rating {
    border-radius: 999px;
    padding: 0.1rem 0.75rem;
    font-size: 0.85rem;
    font-weight: 600;
    background: rgba(59, 130, 246, 0.15);
    color: #60a5fa;
    white-space: nowrap;
}

.muhurat-slot-card[data-rating="excellent"] .muhurat-rating {
    background: rgba(34, 197, 94, 0.15);
    color: #4ade80;
}

.muhurat-slot-card[data-rating="good"] .muhurat-rating {
    background: rgba(59, 130, 246, 0.15);
    color: #60a5fa;
}

.muhurat-slot-card[data-rating="manageable"] .muhurat-rating {
    background: rgba(250, 204, 21, 0.15);
    color: #facc15;
}

.muhurat-slot-card[data-rating="avoid"] .muhurat-rating {
    background: rgba(239, 68, 68, 0.15);
    color: #f87171;
}

.muhurat-detail {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}

.muhurat-detail__list {
    margin: 0;
    padding-left: 1.25rem;
    color: var(--text-muted);
    font-size: 0.92rem;
}

@media (max-width: 640px) {
    .matchmaking-actions {
        flex-direction: column;
        align-items: flex-start;
    }

    .matchmaking-actions__icon {
        width: 42px;
        height: 42px;
        font-size: 1.2rem;
    }

    .btn-pill {
        width: 100%;
        justify-content: center;
    }
}

@media (max-width: 900px) {
    .matchmaking-hero {
        flex-direction: column;
        align-items: flex-start;
    }

    .score-card {
        flex-direction: column;
        align-items: flex-start;
    }
}

/* Compact Kundali Hero Header */
.kundali-hero-compact {
    padding: 1.5rem 0 1rem;
    border-bottom: 1px solid var(--border-soft);
    margin-bottom: 2rem;
    position: sticky;
    top: calc(var(--app-header-height, 72px) + 0.5rem);
    z-index: 3;
    background: var(--bg-page);
    box-shadow: 0 12px 24px -24px rgba(0,0,0,0.5);
}

.kundali-hero-compact__header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 2rem;
    flex-wrap: wrap;
}

.tab-footer-link {
    margin-top: 2rem;
    text-align: right;
}

.tab-footer-link--double {
    display: flex;
    justify-content: space-between;
    align-items: center;
    text-align: left;
}

.tab-footer-link__action {
    font-weight: 600;
    text-decoration: none;
    color: var(--accent-primary);
    transition: color var(--transition-fast);
}

.tab-footer-link__action:hover {
    color: var(--accent-strong);
}

.kundali-hero-compact__title h1 {
    font-size: 1.75rem;
    font-weight: 600;
    margin: 0 0 0.5rem 0;
    color: var(--text-primary);
}

.birth-info-compact {
    font-size: 0.9rem;
    color: var(--text-muted);
    display: block;
    line-height: 1.5;
}

.birth-info-compact .edit-link {
    margin-left: 0.5rem;
    text-decoration: none;
    opacity: 0.6;
    transition: opacity var(--transition-fast);
}

.birth-info-compact .edit-link:hover {
    opacity: 1;
}

.kundali-hero-compact__actions {
    display: flex;
    gap: 0.75rem;
    flex-shrink: 0;
}

@media (max-width: 768px) {
    .kundali-hero-compact__header {
        flex-direction: column;
        align-items: flex-start;
    }
    
    .kundali-hero-compact__title h1 {
        font-size: 1.5rem;
    }
    
    .birth-info-compact {
        font-size: 0.85rem;
    }
    
    .kundali-hero-compact__actions {
        width: 100%;
        justify-content: flex-start;
    }
}

/* Star indicator for recommended tab */
.tab-link__subtitle {
    font-size: 0.75rem;
    opacity: 0.8;
}

/* Glossary Tooltips */
.glossary-term {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    cursor: help;
    color: inherit;
    text-decoration: none;
    border: none;
    position: relative;
}

.glossary-term__text {
    border-bottom: 1px dotted transparent;
}

.glossary-term__hint {
    font-size: 0.65rem;
    font-weight: 600;
    width: 1.05rem;
    height: 1.05rem;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(148, 163, 184, 0.25);
    color: var(--text-secondary);
    border: 1px solid rgba(148, 163, 184, 0.4);
    transition: background var(--transition-fast), color var(--transition-fast), border var(--transition-fast);
}

.glossary-term:hover .glossary-term__hint,
.glossary-term:focus-within .glossary-term__hint {
    background: rgba(63, 131, 248, 0.2);
    color: var(--accent-primary);
    border-color: rgba(63, 131, 248, 0.5);
}

.glossary-term:hover .glossary-term__text,
.glossary-term:focus-within .glossary-term__text {
    border-color: rgba(148, 163, 184, 0.5);
}

.glossary-tooltip {
    position: absolute;
    background: var(--bg-card-strong);
    backdrop-filter: blur(var(--blur-amount));
    border: 1px solid var(--border-strong);
    border-radius: var(--radius-sm);
    padding: 0.75rem 1rem;
    max-width: 320px;
    font-size: 0.875rem;
    line-height: 1.5;
    color: var(--text-secondary);
    z-index: 10000;
    box-shadow: var(--shadow-lg);
    pointer-events: none;
    animation: tooltipFadeIn 0.2s ease;
}

@keyframes tooltipFadeIn {
    from {
        opacity: 0;
        transform: translateY(-4px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Mobile adjustments for tooltips */
@media (max-width: 768px) {
    .glossary-tooltip {
        max-width: 280px;
        font-size: 0.8125rem;
        padding: 0.625rem 0.875rem;
    }
}

/* Light theme adjustments */
html[data-theme="light"] .glossary-tooltip {
    background: rgba(255, 255, 255, 0.98);
    border-color: rgba(168, 85, 247, 0.3);
    color: var(--text-primary);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

html[data-theme="light"] .glossary-term__hint {
    background: rgba(96, 165, 250, 0.12);
    border-color: rgba(37, 99, 235, 0.3);
}

/* Autocomplete Styles */
.location-suggestions {
    position: absolute;
    background: var(--bg-elevated);
    border: 1px solid var(--border-soft);
    border-radius: 0 0 8px 8px;
    width: 100%;
    max-height: 200px;
    overflow-y: auto;
    z-index: 1000;
    margin-top: 2px;
    box-shadow: var(--shadow-md);
    left: 0; /* Align with input */
    top: 100%; /* Position below input */
}

.location-suggestion-item {
    padding: 0.75rem 1rem;
    cursor: pointer;
    color: var(--text-primary);
    border-bottom: 1px solid var(--border-soft);
    transition: background-color 0.2s;
}

.location-suggestion-item:last-child {
    border-bottom: none;
}

.location-suggestion-item:hover {
    background-color: var(--bg-card-highlight);
    color: var(--accent-secondary);
}

/* Ensure form-group has relative positioning for absolute child */
.form-group {
    position: relative;
}
