/* ════════════════════════════════════════════════════
    DARK MODE OVERRIDES FOR PUBLIC PAGES
    Theme from Next.js app: brand greens, dark slate palette, amber accents
    Font: Cabinet Grotesk, Satoshi, Inter
    ════════════════════════════════════════════════════ */

/* Font imports - available for both light and dark mode */
@import url('https://api.fontshare.com/v2/css?f[]=cabinet-grotesk@100,200,300,400,500,700,800,900&f[]=satoshi@300,400,500,700,900&display=swap');

body.dark-mode {
    /* CSS Variables Override - Using Next.js dark theme palette */
    --ic-primary: #22c55e; /* Brand green from Next.js */
    --ic-primary-2: #16a34a; /* Darker green */
    --ic-accent: #f59e0b; /* Amber accent from Next.js */
    --ic-ink: #f1f5f9; /* Light text - dark-100 */
    --ic-muted: #94a3b8; /* Muted text - dark-400 */
    --ic-bg: #0f172a; /* Dark background - dark-900 */
    --ic-card: #1e293b; /* Dark cards - dark-800 */
    --ic-border: rgba(51, 65, 85, 0.5); /* Dark border - dark-700 */
    --bs-primary-rgb: 34, 197, 94; /* Brand green RGB */

    /* Body background - dark gradient from Next.js */
    background: linear-gradient(135deg, #0f172a 0%, #1e293b 50%, #334155 100%) !important;
    color: var(--ic-ink);
    font-family: 'Cabinet Grotesk', 'Satoshi', 'Inter', system-ui, sans-serif;
}

/* Navbar dark overrides */
body.dark-mode .navbar {
    background: rgba(15, 23, 42, 0.95) !important;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    border-bottom: 1px solid rgba(51, 65, 85, 0.5);
}

body.dark-mode .navbar-brand,
body.dark-mode .nav-link {
    color: var(--ic-ink) !important;
}

body.dark-mode .nav-link:hover {
    color: var(--ic-primary) !important;
}

/* Section backgrounds */
body.dark-mode .section {
    /* background: var(--ic-bg); */
    background: transparent;
}

body.dark-mode .section.section-key-service,
body.dark-mode .section.section-how-it-works {
    /* background: linear-gradient(135deg, #0f172a 0%, #1e293b 100%); */
    border-top-color: rgba(51, 65, 85, 0.3);
    border-bottom-color: rgba(51, 65, 85, 0.3);
    background:transparent;
}

/* Prevent body diagonal gradient from bleeding through section containers */
body.dark-mode section.section-padding:not(.soft-section) {
    background: var(--ic-bg);
}

body.dark-mode .trust {
    background: var(--ic-bg);
    border-top-color: rgba(51, 65, 85, 0.3);
    border-bottom-color: rgba(51, 65, 85, 0.3);
}

/* Cards */
body.dark-mode .card-soft {
    background: var(--ic-card) !important;
    border-color: var(--ic-border) !important;
    box-shadow: 0 10px 28px rgba(0, 0, 0, 0.3) !important;
}

body.dark-mode .icon-pill {
    background: rgba(34, 197, 94, 0.15);
    border-color: rgba(34, 197, 94, 0.3);
}

/* Text colors */
body.dark-mode .text-muted {
    color: var(--ic-muted) !important;
}

body.dark-mode .category-card p,
body.dark-mode .test-card p {
    color: var(--ic-muted) !important;
}

body.dark-mode .badge-price {
    background: rgba(34, 197, 94, 0.15);
    color: var(--ic-primary);
    border-color: rgba(34, 197, 94, 0.3);
}

/* Buttons */
body.dark-mode .btn-ic {
    background: linear-gradient(180deg, var(--ic-primary) 0%, var(--ic-primary-2) 100%);
    box-shadow: 0 12px 26px rgba(34, 197, 94, 0.3);
}

body.dark-mode .btn-primary {
    background-color: var(--ic-primary) !important;
    border-color: var(--ic-primary) !important;
}
body.dark-mode .btn-primary:hover, body.dark-mode .btn-primary:focus {
    background-color: var(--ic-primary-2) !important;
    border-color: var(--ic-primary-2) !important;
}
body.dark-mode .btn-outline-primary {
    color: var(--ic-primary);
    border-color: var(--ic-primary);
}
body.dark-mode .btn-outline-primary:hover, body.dark-mode .btn-outline-primary:focus {
    background-color: var(--ic-primary);
    border-color: var(--ic-primary);
    color:var(--ic-ink);
}

/* Form elements */
body.dark-mode .form-check-input {
    accent-color: var(--ic-primary);
}
body.dark-mode .form-check-input:checked {
    background-color: var(--ic-primary);
    border-color: var(--ic-primary);
}

body.dark-mode .cta {
    background: linear-gradient(90deg, var(--ic-primary-2) 0%, var(--ic-primary) 55%, #22c55e 100%);
    box-shadow: 0 18px 40px rgba(34, 197, 94, 0.3);
}

body.dark-mode .cta .btn {
    background: #1e293b;
    color: var(--ic-primary);
    border: 1px solid var(--ic-border);
}

/* Footer */
body.dark-mode .site-footer {
    background: #0d2433;
    color: rgba(255, 255, 255, 0.85);
}

body.dark-mode .site-footer a {
    color: rgba(255, 255, 255, 0.78);
}

body.dark-mode .site-footer a:hover {
    color: #fff;
}

body.dark-mode .footer-bottom {
    border-top-color: rgba(255, 255, 255, 0.1);
    color: rgba(255, 255, 255, 0.65);
}

/* Forms */
body.dark-mode .auth-wrap {
    background: var(--ic-bg);
}

body.dark-mode .auth-card {
    background: var(--ic-card);
    border: 1px solid var(--ic-border);
}

body.dark-mode .form-control,
body.dark-mode .form-select {
    background: rgba(15, 23, 42, 0.6);
    border-color: var(--ic-border);
    color: var(--ic-ink);
}

body.dark-mode .form-control:focus,
body.dark-mode .form-select:focus {
    background: var(--ic-card);
    border-color: var(--ic-primary);
    box-shadow: 0 0 0 0.25rem rgba(34, 197, 94, 0.25);
    color: var(--ic-ink);
}

/* Date input styling for dark mode */
body.dark-mode input[type="date"] {
    color-scheme: dark;
}

body.dark-mode input[type="date"]::-webkit-calendar-picker-indicator {
    filter: brightness(0) invert(1);
    opacity: 0.85;
    cursor: pointer;
}

body.dark-mode input[type="date"]::-webkit-datetime-edit {
    color: var(--ic-ink);
}

body.dark-mode input[type="date"]::-webkit-datetime-edit-fields-wrapper {
    color: var(--ic-ink);
}

body.dark-mode input[type="date"]::-webkit-datetime-edit-text {
    color: var(--ic-ink);
}

body.dark-mode input[type="date"]::-webkit-datetime-edit-month-field,
body.dark-mode input[type="date"]::-webkit-datetime-edit-day-field,
body.dark-mode input[type="date"]::-webkit-datetime-edit-year-field {
    color: var(--ic-ink);
}

/* Hero */
body.dark-mode .hero {
    background: radial-gradient(1200px 600px at 20% 50%, rgba(34,197,94,0.1) 0%, rgba(34,197,94,0.05) 40%, rgba(15,23,42,0) 70%),
                linear-gradient(180deg, var(--ic-bg) 0%, #1e293b 100%);
}

body.dark-mode .hero p {
    color: var(--ic-muted);
}

/* Carousel arrows - invert(0) to show white arrows on dark background */
body.dark-mode .carousel-control-next-icon,
body.dark-mode .carousel-control-prev-icon {
    filter: invert(0);
}

/* Checkout specific */
body.dark-mode .checkout-steps::before {
    background: #475569;
}

body.dark-mode .checkout-step-number {
    background: #475569;
    color: var(--ic-muted);
}

body.dark-mode .checkout-step.active .checkout-step-number,
body.dark-mode .checkout-step.completed .checkout-step-number {
    background: var(--ic-primary);
    color: #fff;
}

body.dark-mode .checkout-step-label {
    color: var(--ic-muted);
}

body.dark-mode .checkout-step.active .checkout-step-label {
    color: var(--ic-primary);
}

/* Floating cart bar dark mode */
body.dark-mode .cart-floating-bar {
    background: var(--ic-card);
    border-color: var(--ic-border);
    box-shadow: 0 10px 30px rgba(0,0,0,0.5);
}

/* Card hover effects - distinctive and bold */
body.dark-mode .card-soft {
    transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

body.dark-mode .card-soft:hover {
    /* transform: translateY(-8px) rotate(1deg) scale(1.02); */
    box-shadow: 0 20px 40px rgba(34,197,94,0.3), 0 0 20px rgba(34,197,94,0.1);
    border-color: rgba(34,197,94,0.5);
    background: linear-gradient(135deg, var(--ic-card) 0%, rgba(34,197,94,0.05) 100%);
}

/* ID Upload */
body.dark-mode .id-upload-zone {
    background: var(--ic-card);
    border-color: var(--ic-border);
}

body.dark-mode .id-upload-zone:hover {
    background: rgba(34, 197, 94, 0.05);
}

/* Transitions */
body.dark-mode * {
    transition: background-color 0.3s ease, color 0.3s ease, border-color 0.3s ease;
}

/* PGx page specific dark mode overrides */
body.dark-mode .hero h1 {
    color: #f1f5f9;
}

body.dark-mode .section-title {
    color: #f1f5f9;
}

body.dark-mode .section-subtitle,
body.dark-mode .section-subtitle p {
    color: #94a3b8;
}

body.dark-mode .info-card {
    background: var(--ic-card);
    border-color: var(--ic-border);
}

body.dark-mode .info-card h5 {
    color: #f1f5f9;
}

body.dark-mode .info-card p,
body.dark-mode .info-card li {
    color: #94a3b8;
}

body.dark-mode .soft-section {
    background: linear-gradient(180deg, #0f172a 0%, #1e293b 100%);
}

body.dark-mode .cta-box {
    background: linear-gradient(135deg, #0a7a8c 0%, #0d9db5 50%, #0a7a8c 100%);
}

body.dark-mode .cta-box h2,
body.dark-mode .cta-box p {
    color: #fff;
}

body.dark-mode .step-box {
    background: var(--ic-card);
    border-color: var(--ic-border);
}

body.dark-mode .step-box h5 {
    color: #f1f5f9;
}

body.dark-mode .step-box p {
    color: #94a3b8;
}

body.dark-mode .step-number {
    background: linear-gradient(135deg, rgba(34,197,94,0.3), rgba(34,197,94,0.1));
    color: var(--ic-primary);
    border-color: var(--ic-border);
    box-shadow: 0 4px 12px rgba(34,197,94,0.3);
}

body.dark-mode .accordion-item {
    background-color: var(--ic-card);
    border-color: var(--ic-border);
}

body.dark-mode .accordion-button {
    background: var(--ic-card);
    color: #f1f5f9;
    border-color: var(--ic-border);
}

body.dark-mode .accordion-button:not(.collapsed) {
    background: linear-gradient(135deg, rgba(34,197,94,0.1), rgba(34,197,94,0.05));
    color: var(--ic-primary);
}

body.dark-mode .accordion-body {
    background: rgba(15,23,42,0.5);
    color: #94a3b8;
}

body.dark-mode .accordion-body strong {
    color: #f1f5f9;
}

body.dark-mode .category-card {
    background: var(--ic-card);
    border-color: var(--ic-border);
}

body.dark-mode .category-card h5 {
    color: #f1f5f9;
}

body.dark-mode .category-card p {
    color: #94a3b8;
}

body.dark-mode .antidepressant-card {
    background: linear-gradient(135deg, rgba(34,197,94,0.1), rgba(34,197,94,0.05));
    border-color: rgba(34,197,94,0.3);
}

body.dark-mode .antidepressant-card::before {
    background: linear-gradient(135deg, rgba(34,197,94,0.1), rgba(34,197,94,0.1));
}

body.dark-mode .antidepressant-card h3 {
    color: var(--ic-primary);
}

body.dark-mode .antidepressant-card .med-item {
    background: var(--ic-card);
    color: #f1f5f9;
    box-shadow: 0 2px 4px rgba(0,0,0,0.3);
}

body.dark-mode .stat-item .stat-number {
    background: linear-gradient(135deg, #22c55e, #4ade80);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

body.dark-mode .stat-item .stat-label {
    color: #94a3b8;
}

body.dark-mode .btn-ic {
    background: linear-gradient(135deg, var(--ic-primary), var(--ic-primary-2)) !important;
}

body.dark-mode .btn-ic.btn-outline {
    background: transparent;
    border-color: rgba(255,255,255,0.5);
    color:#fff;
}

body.dark-mode .btn-ic.btn-outline:hover {
    background: rgba(255,255,255,0.1);
    border-color: #fff;
}

body.dark-mode .small-note {
    color: #94a3b8;
}

/* Understanding Pharmacogenomics section */
body.dark-mode .section-padding div[style*="background: linear-gradient(135deg, #f0f9ff, #e0f2fe)"] {
    background: linear-gradient(135deg, rgba(34,197,94,0.1), rgba(34,197,94,0.05)) !important;
}

body.dark-mode .icon-wrapper[style*="background: #e0f2fe"] {
    background: rgba(34,197,94,0.2) !important;
}

body.dark-mode .icon-wrapper[style*="background: #dcfce7"] {
    background: rgba(34,197,94,0.2) !important;
}

body.dark-mode .icon-wrapper[style*="background: #f3e8ff"] {
    background: rgba(147,51,234,0.2) !important;
}

body.dark-mode .text-muted {
    color: #94a3b8 !important;
}

body.dark-mode .text-dark {
    color: #ccc !important;
}

/* PGx intro box - class-based override (reliable fallback) */
body.dark-mode .pgx-intro-box {
    background: linear-gradient(135deg, rgba(34,197,94,0.12), rgba(34,197,94,0.06)) !important;
    border: 1px solid rgba(34,197,94,0.25) !important;
    box-shadow: 0 8px 24px rgba(0,0,0,0.25) !important;
}

body.dark-mode .pgx-intro-box .bi-dna {
    color: #22c55e !important;
}

body.dark-mode .pgx-intro-box-title {
    color: #f1f5f9 !important;
}

/* PGx intro feature icon wrappers */
body.dark-mode .d-flex .icon-wrapper[style*="#e0f2fe"],
body.dark-mode .d-flex .icon-wrapper[style*="background: #e0f2fe"] {
    background: rgba(34,197,94,0.18) !important;
    color: #4ade80 !important;
}

body.dark-mode .d-flex .icon-wrapper[style*="#dcfce7"],
body.dark-mode .d-flex .icon-wrapper[style*="background: #dcfce7"] {
    background: rgba(34,197,94,0.18) !important;
    color: #4ade80 !important;
}

body.dark-mode .d-flex .icon-wrapper[style*="#f3e8ff"],
body.dark-mode .d-flex .icon-wrapper[style*="background: #f3e8ff"] {
    background: rgba(147,51,234,0.18) !important;
    color: #c084fc !important;
}

/* Feature item headings in pgx intro */
body.dark-mode .d-flex h6.fw-semibold {
    color: #f1f5f9;
}

/* ════════════════════════════════════════════════════
   GLOBAL BOOTSTRAP UTILITY OVERRIDES
   Covers utility classes not targeted by component-specific rules above.
   ════════════════════════════════════════════════════ */

/* Background utilities */
body.dark-mode .bg-white,
body.dark-mode .bg-light {
    background-color: var(--ic-card) !important;
    color: var(--ic-ink);
}

/* Bootstrap card (non card-soft) */
body.dark-mode .card {
    background-color: var(--ic-card) !important;
    border-color: var(--ic-border) !important;
    color: var(--ic-ink);
}

body.dark-mode .card-body {
    background-color: var(--ic-card) !important;
    color: var(--ic-ink);
}

/* Shadow */
body.dark-mode .shadow-sm {
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.4) !important;
}

/* Tables */
body.dark-mode .table {
    color: var(--ic-ink);
    border-color: var(--ic-border);
}

body.dark-mode .table th,
body.dark-mode .table td {
    border-color: var(--ic-border);
    background-color: var(--ic-card);
    color: var(--ic-ink);
}

body.dark-mode .table-striped > tbody > tr:nth-of-type(odd) > * {
    background-color: rgba(255, 255, 255, 0.03);
    color: var(--ic-ink);
}

/* Nav pills (profile page tabs) */
body.dark-mode .nav-pills .nav-link {
    color: var(--ic-muted);
    background-color: transparent;
}

body.dark-mode .nav-pills .nav-link:hover {
    background-color: rgba(34, 197, 94, 0.08);
    color: var(--ic-ink) !important;
}

body.dark-mode .nav-pills .nav-link.active {
    background-color: rgba(34, 197, 94, 0.15);
    color: var(--ic-primary);
}

/* Input group addon */
body.dark-mode .input-group-text {
    background-color: var(--ic-card);
    border-color: var(--ic-border);
    color: var(--ic-ink);
}

/* Border utility */
body.dark-mode .border-light {
    border-color: var(--ic-border) !important;
}

/* Outline secondary button */
body.dark-mode .btn-outline-secondary {
    color: var(--ic-muted);
    border-color: var(--ic-border);
}

body.dark-mode .btn-outline-secondary:hover {
    background-color: rgba(255, 255, 255, 0.05);
    border-color: var(--ic-muted);
    color: var(--ic-ink);
}

/* Checkout Stripe card element container */
body.dark-mode #card-details {
    background-color: var(--ic-card) !important;
    border-color: var(--ic-border) !important;
}
body.dark-mode #card-element {
    border-color: rgba(255, 255, 255, 0.25) !important;
}

/* Modals */
body.dark-mode .modal-content {
    background-color: var(--ic-card);
    color: var(--ic-ink);
    border-color: var(--ic-border);
}
body.dark-mode .modal-header {
    border-bottom-color: var(--ic-border);
}
body.dark-mode .modal-footer {
    border-top-color: var(--ic-border);
}
body.dark-mode .modal-body {
    color: var(--ic-ink);
}

/* about.php — inline style replacements */
body.dark-mode .about-story-box {
    background: var(--ic-card) !important;
}

body.dark-mode .about-values-section {
    background: linear-gradient(135deg, rgba(34,197,94,0.05), rgba(34,197,94,0.02)) !important;
}

/* Cart item link - ensure readable in dark mode */
body.dark-mode .cart-item-link {
    color: var(--ic-ink) !important;
}

body.dark-mode .cart-item-link:hover {
    color: var(--ic-primary) !important;
}

body.dark-mode span#floating-total {
    color: var(--ic-primary) !important;
}