/* MeroVPS — custom supplemental styles */
/* Primary framework: Tailwind CSS via CDN */

/* Hide Alpine-controlled elements until Alpine boots */
[x-cloak] { display: none !important; }

/* ===========================
   Critical base styles
   (applied immediately before Tailwind CDN runs)
   =========================== */
*, *::before, *::after { box-sizing: border-box; }

html, body {
    height: 100%;
    margin: 0;
    padding: 0;
}

body {
    background-color: #030712;
    color: #f8fafc;
    font-family: 'Epilogue', system-ui, sans-serif;
    font-optical-sizing: auto;
    font-feature-settings: "kern" 1, "liga" 1, "calt" 1;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
    line-height: 1.6;
    overflow-x: hidden;
}

/* Ensure the full-height flex layout works before Tailwind */
body > div.flex {
    display: flex;
    height: 100vh;
    overflow: hidden;
}

/* Sidebar base — ensures sidebar is visible on desktop without Alpine/Tailwind */
@media (min-width: 1024px) {
    aside {
        position: static !important;
        transform: none !important;
        flex-shrink: 0;
    }
}

/* ===========================
   Global typography scale
   =========================== */
h1, h2, h3, h4, h5, h6 {
    font-feature-settings: "kern" 1, "liga" 1, "calt" 1;
    text-rendering: optimizeLegibility;
    letter-spacing: -0.025em;
    line-height: 1.15;
}

/* Numeric figures — tabular by default for aligned columns */
.tabular-nums,
[class*="text-3xl"],
[class*="text-2xl"],
[class*="text-xl"] {
    font-variant-numeric: tabular-nums;
    font-feature-settings: "kern" 1, "tnum" 1;
}

/* Small uppercase labels (e.g. section headers like "Resource Usage") */
.uppercase {
    font-feature-settings: "kern" 1, "liga" 0;
}

/* Better paragraph readability */
p {
    line-height: 1.7;
}

/* Scrollbar */
::-webkit-scrollbar {
    width: 6px;
    height: 6px;
}
::-webkit-scrollbar-track {
    background: rgba(255,255,255,0.03);
}
::-webkit-scrollbar-thumb {
    background: rgba(255,255,255,0.12);
    border-radius: 3px;
}
::-webkit-scrollbar-thumb:hover {
    background: rgba(255,255,255,0.2);
}

/* ===========================
   StablePanel API form resets
   =========================== */
.is-required {
    border-color: rgba(239,68,68,0.5) !important;
}

/* ===========================
   Markdown content
   =========================== */
.markdown-content,
.bb-content {
    line-height: 1.7;
    font-size: 0.875rem;
    color: #cbd5e1;
}
.markdown-content p,
.bb-content p {
    margin-bottom: 0.75rem;
}
.markdown-content code,
.bb-content code {
    background: rgba(255,255,255,0.06);
    border: 1px solid rgba(255,255,255,0.1);
    border-radius: 4px;
    padding: 0.1em 0.4em;
    font-size: 0.8em;
    font-family: 'JetBrains Mono', 'Fira Code', monospace;
}
.markdown-content pre,
.bb-content pre {
    background: rgba(0,0,0,0.3);
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 8px;
    padding: 1rem;
    overflow-x: auto;
    margin: 0.75rem 0;
}
.markdown-content a,
.bb-content a {
    color: #818cf8;
    text-decoration: underline;
    text-underline-offset: 3px;
}

/* ===========================
   Print styles
   =========================== */
@media print {
    body {
        background: white;
        color: black;
    }
    aside, header, footer, nav {
        display: none !important;
    }
}

/* ===========================
   Gradient text utility
   =========================== */
.gradient-text {
    background: linear-gradient(135deg, #818cf8 0%, #a78bfa 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

/* ===========================
   Card glass
   =========================== */
.card-glass {
    background: rgba(255,255,255,0.03);
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 12px;
    backdrop-filter: blur(8px);
}

/* ===========================
   Form elements base
   =========================== */
input[type="text"],
input[type="email"],
input[type="password"],
input[type="tel"],
input[type="number"],
input[type="search"],
textarea,
select {
    background: rgba(255,255,255,0.05);
    border: 1px solid rgba(255,255,255,0.1);
    border-radius: 8px;
    padding: 0.625rem 0.875rem;
    color: white;
    font-size: 0.875rem;
    font-family: inherit;
    transition: border-color 0.15s, box-shadow 0.15s;
    width: 100%;
}
input:focus,
textarea:focus,
select:focus {
    outline: none;
    border-color: rgba(var(--color-primary-rgb),0.7);
    box-shadow: 0 0 0 3px rgba(var(--color-primary-rgb),0.15);
}
select option {
    background: #0f172a;
    color: white;
}

/* ===========================
   Animations
   =========================== */
@keyframes fadeIn {
    from { opacity: 0; transform: translateY(4px); }
    to   { opacity: 1; transform: translateY(0); }
}
@keyframes merovps-free-glow {
    0%, 100% { box-shadow: 0 0 0 0 rgba(16,185,129,0); }
    50%      { box-shadow: 0 0 18px 3px rgba(16,185,129,0.22); }
}
.free-addon-card {
    animation: merovps-free-glow 3s ease-in-out infinite;
}
html[data-theme="light"] .free-addon-card {
    animation: merovps-free-glow 3s ease-in-out infinite;
    box-shadow: 0 2px 12px rgba(16,185,129,0.12);
}
/* ── Logo image ──
   Dark mode: invert to white (SVG has dark text on transparent bg).
   Light mode: render at natural colours (#2B1708 + #FF6B00 are legible on light canvas).
── */
html:not([data-theme="light"]) .logo-img {
    filter: brightness(0) invert(1);
}
html[data-theme="light"] .logo-img {
    filter: none !important;
}

.animate-fade-in {
    animation: fadeIn 0.25s ease-out;
}

/* ===========================
   Light mode
   Toggled by: html[data-theme="light"]

   Color system:
     Canvas            : #eef2ff → radial gradient (indigo-50 base)
     Glass surface     : rgba(255,255,255,0.68) + blur(18px)
     Glass surface-2   : rgba(255,255,255,0.85) + blur(24px)
     Border glass      : rgba(255,255,255,0.75)
     Border line       : rgba(var(--color-primary-rgb),0.12) — indigo-tinted
     Text-900 primary  : #0f172a  slate-900
     Text-700 secondary: #334155  slate-700
     Text-500 muted    : #475569  slate-600
     Text-400 faint    : #64748b  slate-500
     Text-300 ultra    : #94a3b8  slate-400 (labels only)
     Indigo-accent     : #4f46e5  indigo-600
   =========================== */

/* ── Smooth theme transition on toggle ── */
html[data-theme="light"] *,
html[data-theme="light"] *::before,
html[data-theme="light"] *::after {
    transition:
        background-color 0.25s ease,
        border-color     0.25s ease,
        box-shadow       0.25s ease,
        color            0.2s  ease !important;
}
/* But don't transition transforms/opacity (breaks Alpine x-transition).
   Scope to elements that use Alpine show/transition BUT exclude sidebar
   structural elements that need their own width/transform transitions. */
html[data-theme="light"] [x-show]:not(#sidebar):not(#sidebar *):not(.sidebar-overlay),
html[data-theme="light"] [x-transition]:not(#sidebar):not(#sidebar *):not(.sidebar-overlay) {
    transition: none !important;
}
/* Sidebar overlay: restore opacity fade in light mode */
html[data-theme="light"] .sidebar-overlay[x-show] {
    transition: opacity 300ms ease-linear !important;
}
/* Sidebar: restore width + transform transitions in light mode
   (overrides the global !important transition rule above) */
html[data-theme="light"] #sidebar {
    transition:
        width           300ms ease-in-out,
        transform       300ms ease-in-out,
        background-color 0.25s ease,
        border-color    0.25s ease,
        box-shadow      0.25s ease !important;
}
/* Sidebar children: allow opacity/width transitions for collapse labels */
html[data-theme="light"] #sidebar .transition-all,
html[data-theme="light"] #sidebar .transition-opacity {
    transition:
        opacity          200ms ease,
        width            200ms ease,
        background-color 0.25s ease,
        border-color     0.25s ease,
        color            0.2s ease !important;
}

html[data-theme="light"] {
    color-scheme: light;
    /* Improve font rendering in light mode */
    -webkit-font-smoothing: subpixel-antialiased;
    text-rendering: optimizeLegibility;
}

/* ═══════════════════════════════════════════════════
   1. CANVAS — gradient background for glass depth
   ═══════════════════════════════════════════════════ */
html[data-theme="light"] body {
    background-color: #eef2ff !important;
    /* Multi-stop radial gradient — creates ambient light the glass layers sit on top of */
    background-image:
        radial-gradient(ellipse 75% 55% at 12% 0%,   rgba(165,180,252,0.45) 0%, transparent 60%),
        radial-gradient(ellipse 55% 40% at 90% 95%,   rgba(196,181,253,0.28) 0%, transparent 62%),
        radial-gradient(ellipse 45% 35% at 55% 45%,   rgba(224,231,255,0.20) 0%, transparent 70%) !important;
    background-attachment: fixed !important;
    color: #0f172a !important;
    font-variant-numeric: tabular-nums;
}

/* ── Named dark-bg classes ── */
html[data-theme="light"] .bg-\[\#030712\]     { background-color: transparent !important; }
html[data-theme="light"] .bg-\[\#030712\]\/80 {
    background-color: rgba(238,242,255,0.82) !important;
    backdrop-filter: blur(20px) saturate(1.8) !important;
    -webkit-backdrop-filter: blur(20px) saturate(1.8) !important;
}
html[data-theme="light"] .bg-\[\#030712\]\/95 {
    background-color: rgba(238,242,255,0.93) !important;
    backdrop-filter: blur(20px) saturate(1.8) !important;
    -webkit-backdrop-filter: blur(20px) saturate(1.8) !important;
}

/* ═══════════════════════════════════════════════════
   2. STRUCTURAL GLASS — sidebar, header, dropdowns
   ═══════════════════════════════════════════════════ */

/* Sidebar — frosted glass panel (layout nav sidebar only) */
html[data-theme="light"] #sidebar {
    background: rgba(255,255,255,0.78) !important;
    backdrop-filter: blur(28px) saturate(2.2) !important;
    -webkit-backdrop-filter: blur(28px) saturate(2.2) !important;
    border-right: 1px solid rgba(165,180,252,0.25) !important;
    box-shadow: 2px 0 24px rgba(var(--color-primary-rgb),0.07), 1px 0 0 rgba(255,255,255,0.6) !important;
}

/* /order page right sidebar cards — light mode */
html[data-theme="light"] .order-sidebar > div {
    background: rgba(255,255,255,0.80) !important;
    border-color: rgba(165,180,252,0.30) !important;
    box-shadow: 0 2px 12px rgba(var(--color-primary-rgb),0.07) !important;
}
html[data-theme="light"] .order-sidebar > div .text-gray-400 {
    color: #475569 !important;
}
html[data-theme="light"] .order-sidebar > div .text-gray-500 {
    color: #64748b !important;
}
html[data-theme="light"] .order-sidebar > div .text-gray-600 {
    color: #64748b !important;
}

/* Sticky header — glass bar */
html[data-theme="light"] header {
    background: rgba(255,255,255,0.72) !important;
    backdrop-filter: blur(28px) saturate(2.2) !important;
    -webkit-backdrop-filter: blur(28px) saturate(2.2) !important;
    border-bottom: 1px solid rgba(165,180,252,0.20) !important;
    box-shadow: 0 2px 20px rgba(var(--color-primary-rgb),0.08), 0 1px 0 rgba(255,255,255,0.8) !important;
}

/* Footer */
html[data-theme="light"] footer {
    background: rgba(255,255,255,0.55) !important;
    backdrop-filter: blur(16px) !important;
    -webkit-backdrop-filter: blur(16px) !important;
    border-top: 1px solid rgba(165,180,252,0.18) !important;
}

/* Sidebar collapse toggle pill */
html[data-theme="light"] #sidebar-toggle {
    background: rgba(255,255,255,0.88) !important;
    backdrop-filter: blur(12px) !important;
    -webkit-backdrop-filter: blur(12px) !important;
    border: 1px solid rgba(165,180,252,0.30) !important;
    box-shadow: 0 2px 8px rgba(var(--color-primary-rgb),0.12), 0 1px 0 rgba(255,255,255,0.9) inset !important;
    color: #64748b !important;
    transition: left 300ms ease-in-out, background-color 0.25s ease, border-color 0.25s ease, box-shadow 0.25s ease, color 0.2s ease !important;
}
html[data-theme="light"] #sidebar-toggle:hover {
    background: rgba(238,242,255,0.95) !important;
    border-color: rgba(var(--color-primary-rgb),0.35) !important;
    color: #4f46e5 !important;
    box-shadow: 0 4px 12px rgba(var(--color-primary-rgb),0.18) !important;
}

/* Dropdowns (bg-[#0d1424]) and sidebar-bg (bg-[#0a0f1e]) */
html[data-theme="light"] .bg-\[\#0d1424\],
html[data-theme="light"] .bg-\[\#0a0f1e\] {
    background: rgba(255,255,255,0.88) !important;
    backdrop-filter: blur(28px) saturate(2.2) !important;
    -webkit-backdrop-filter: blur(28px) saturate(2.2) !important;
    border: 1px solid rgba(165,180,252,0.22) !important;
    box-shadow:
        0 8px 32px rgba(var(--color-primary-rgb),0.10),
        0 2px 8px  rgba(15,23,42,0.07),
        inset 0 1px 0 rgba(255,255,255,0.95) !important;
}

/* TLD selector dropdown (bg-gray-900/95) */
html[data-theme="light"] .bg-gray-900\/95 {
    background: rgba(255,255,255,0.92) !important;
    backdrop-filter: blur(28px) saturate(2) !important;
    -webkit-backdrop-filter: blur(28px) saturate(2) !important;
    border-color: rgba(165,180,252,0.25) !important;
    box-shadow:
        0 8px 32px rgba(var(--color-primary-rgb),0.10),
        0 2px 8px  rgba(15,23,42,0.07),
        inset 0 1px 0 rgba(255,255,255,0.95) !important;
}

/* ═══════════════════════════════════════════════════
   3. TYPOGRAPHY — 5-level hierarchy
   ═══════════════════════════════════════════════════ */

/* Level 1 — Headings, primary labels */
html[data-theme="light"] .text-white,
html[data-theme="light"] h1, html[data-theme="light"] h2, html[data-theme="light"] h3 {
    color: #0f172a !important;
    letter-spacing: -0.01em;
}
/* Level 2 — Body text, card content */
html[data-theme="light"] .text-gray-100,
html[data-theme="light"] .text-gray-200 { color: #1e293b !important; }
/* Level 3 — Supporting text */
html[data-theme="light"] .text-gray-300  { color: #334155 !important; }
/* Level 4 — Muted/secondary */
html[data-theme="light"] .text-gray-400  { color: #475569 !important; }
/* Level 5 — Faint / metadata */
html[data-theme="light"] .text-gray-500  { color: #64748b !important; }
/* Level 5b — Ultra-muted labels (only uppercase small caps use this) */
html[data-theme="light"] .text-gray-600  { color: #64748b !important; }
html[data-theme="light"] .text-gray-700  { color: #475569 !important; }

/* Hover states */
html[data-theme="light"] .hover\:text-white:hover       { color: #0f172a !important; }
html[data-theme="light"] .hover\:text-gray-400:hover    { color: #334155 !important; }
html[data-theme="light"] .hover\:text-gray-300:hover    { color: #1e293b !important; }

/* Uppercase section labels — best readability with tracking */
html[data-theme="light"] .uppercase.tracking-wider,
html[data-theme="light"] .uppercase.tracking-widest,
html[data-theme="light"] .uppercase.tracking-wide {
    letter-spacing: 0.08em !important;
    font-weight: 600 !important;
}

/* ── Mono text (IPs, hostnames, usernames) ── */
html[data-theme="light"] .font-mono { color: #1e293b !important; }

/* ── Accent colors: indigo-600 level (fully saturated on light bg) ── */
html[data-theme="light"] .text-indigo-400               { color: #4f46e5 !important; }
html[data-theme="light"] .text-indigo-300               { color: #4f46e5 !important; }
html[data-theme="light"] .text-indigo-200               { color: var(--color-primary) !important; }
html[data-theme="light"] .text-indigo-500               { color: #4338ca !important; }
html[data-theme="light"] .hover\:text-indigo-400:hover  { color: #4338ca !important; }
html[data-theme="light"] .hover\:text-indigo-300:hover  { color: #4f46e5 !important; }

/* ── Status shades: fully saturated deep tones ── */
html[data-theme="light"] .text-green-400   { color: #15803d !important; }
html[data-theme="light"] .text-green-300   { color: #166534 !important; }
html[data-theme="light"] .text-emerald-400 { color: #047857 !important; }
html[data-theme="light"] .text-emerald-300 { color: #065f46 !important; }
html[data-theme="light"] .text-amber-400   { color: #92400e !important; }
html[data-theme="light"] .text-amber-300   { color: #78350f !important; }
html[data-theme="light"] .text-red-400     { color: #b91c1c !important; }
html[data-theme="light"] .text-red-300     { color: #991b1b !important; }
html[data-theme="light"] .hover\:text-red-400:hover  { color: #b91c1c !important; }
html[data-theme="light"] .hover\:text-red-300:hover  { color: #991b1b !important; }
html[data-theme="light"] .text-sky-400     { color: #0369a1 !important; }
html[data-theme="light"] .text-blue-400    { color: #1d4ed8 !important; }
html[data-theme="light"] .text-violet-400  { color: #6d28d9 !important; }
html[data-theme="light"] .text-pink-400    { color: #be185d !important; }
html[data-theme="light"] .text-teal-400    { color: #0f766e !important; }
html[data-theme="light"] .text-orange-400  { color: #c2410c !important; }

/* Opacity-variant accent text used in addon cards and billing notes */
html[data-theme="light"] .text-emerald-500\/70    { color: rgba(5,150,105,0.90)   !important; }
html[data-theme="light"] .text-indigo-300\/60     { color: rgba(79,70,229,0.80)   !important; }
/* Markdown bold text inside [&_strong]:text-gray-300 containers */
html[data-theme="light"] .\[\&_strong\]\:text-gray-300 strong { color: #334155 !important; }

/* ═══════════════════════════════════════════════════
   4. GLASS CARDS — main content surfaces
   ═══════════════════════════════════════════════════ */

/* Tailwind translucent classes — become glass panels */
html[data-theme="light"] .bg-white\/\[0\.015\] { background: rgba(255,255,255,0.30) !important; }
html[data-theme="light"] .bg-white\/\[0\.02\]  { background: rgba(255,255,255,0.40) !important; }
html[data-theme="light"] .bg-white\/\[0\.025\] {
    background: rgba(255,255,255,0.68) !important;
    backdrop-filter: blur(18px) saturate(2) !important;
    -webkit-backdrop-filter: blur(18px) saturate(2) !important;
    border-color: rgba(165,180,252,0.30) !important;
}
html[data-theme="light"] .bg-white\/\[0\.03\] {
    background: rgba(255,255,255,0.68) !important;
    backdrop-filter: blur(18px) saturate(2) !important;
    -webkit-backdrop-filter: blur(18px) saturate(2) !important;
    border-color: rgba(165,180,252,0.30) !important;
}
html[data-theme="light"] .bg-white\/\[0\.04\]  { background: rgba(255,255,255,0.48) !important; }
html[data-theme="light"] .bg-white\/\[0\.05\]  { background: rgba(255,255,255,0.55) !important; }
html[data-theme="light"] .bg-white\/5          { background: rgba(255,255,255,0.50) !important; }

/* Hover backgrounds */
html[data-theme="light"] .hover\:bg-white\/5:hover           { background: rgba(255,255,255,0.65) !important; }
html[data-theme="light"] .hover\:bg-white\/\[0\.04\]:hover   { background: rgba(255,255,255,0.55) !important; }
html[data-theme="light"] .hover\:bg-white\/\[0\.05\]:hover   { background: rgba(255,255,255,0.60) !important; }
html[data-theme="light"] .hover\:bg-white\/\[0\.015\]:hover  { background: rgba(255,255,255,0.45) !important; }

/* Inline-style cards: rgba(255,255,255,0.02), 0.025 and 0.03 — glass panels */
html[data-theme="light"] [style*="rgba(255,255,255,0.025)"],
html[data-theme="light"] [style*="rgba(255,255,255,0.02)"],
html[data-theme="light"] [style*="rgba(255,255,255,0.03)"] {
    background: rgba(255,255,255,0.68) !important;
    border-color: rgba(165,180,252,0.32) !important;
    backdrop-filter: blur(18px) saturate(1.9) !important;
    -webkit-backdrop-filter: blur(18px) saturate(1.9) !important;
}
/* Chip/pill inner items — lighter glass */
html[data-theme="light"] [style*="rgba(255,255,255,0.04)"] {
    background: rgba(255,255,255,0.48) !important;
    border-color: rgba(165,180,252,0.15) !important;
}
/* Addon icon badge / domain-selector pill (0.05) */
html[data-theme="light"] [style*="rgba(255,255,255,0.05)"] {
    background: rgba(255,255,255,0.58) !important;
    border-color: rgba(165,180,252,0.22) !important;
}
/* Secondary card CTA buttons (0.06 / 0.07) */
html[data-theme="light"] [style*="rgba(255,255,255,0.06)"],
html[data-theme="light"] [style*="rgba(255,255,255,0.07)"] {
    background: rgba(var(--color-primary-rgb),0.07) !important;
    border-color: rgba(var(--color-primary-rgb),0.18) !important;
}

/* ── Button hover: accordion rows, nav items ── */
html[data-theme="light"] .hover\:bg-white\/\[0\.015\] {
    background: transparent !important;
}

/* ═══════════════════════════════════════════════════
   5. BORDERS
   ═══════════════════════════════════════════════════ */
html[data-theme="light"] .border-white\/5          { border-color: rgba(165,180,252,0.15) !important; }
html[data-theme="light"] .border-white\/10         { border-color: rgba(165,180,252,0.22) !important; }
html[data-theme="light"] .border-white\/15         { border-color: rgba(165,180,252,0.28) !important; }
html[data-theme="light"] .border-white\/25         { border-color: rgba(var(--color-primary-rgb),0.20)  !important; }
html[data-theme="light"] .border-white\/\[0\.04\]  { border-color: rgba(165,180,252,0.10) !important; }
html[data-theme="light"] .border-white\/\[0\.05\]  { border-color: rgba(165,180,252,0.12) !important; }
html[data-theme="light"] .border-white\/\[0\.06\]  { border-color: rgba(165,180,252,0.18) !important; }
html[data-theme="light"] .border-white\/\[0\.07\]  { border-color: rgba(165,180,252,0.20) !important; }
html[data-theme="light"] .border-white\/\[0\.08\]  { border-color: rgba(165,180,252,0.22) !important; }
html[data-theme="light"] .border-white\/\[0\.12\]  { border-color: rgba(var(--color-primary-rgb),0.18)  !important; }
html[data-theme="light"] .border-white\/\[0\.25\]  { border-color: rgba(var(--color-primary-rgb),0.22)  !important; }
html[data-theme="light"] .border-white\/\[0\.28\]  { border-color: rgba(var(--color-primary-rgb),0.25)  !important; }
html[data-theme="light"] .divide-white\/\[0\.04\] > * + * { border-color: rgba(165,180,252,0.12) !important; }
html[data-theme="light"] .divide-white\/\[0\.06\] > * + * { border-color: rgba(165,180,252,0.18) !important; }
html[data-theme="light"] .border-l.border-white\/10      { border-color: rgba(165,180,252,0.20) !important; }

/* Accent-tinted borders */
html[data-theme="light"] .border-indigo-500\/30 { border-color: rgba(var(--color-primary-rgb),0.28) !important; }
html[data-theme="light"] .border-indigo-500\/40 { border-color: rgba(var(--color-primary-rgb),0.35) !important; }
html[data-theme="light"] .border-green-500\/30  { border-color: rgba(22,163,74,0.28)  !important; }
html[data-theme="light"] .border-green-500\/10  { border-color: rgba(22,163,74,0.14)  !important; }

/* ═══════════════════════════════════════════════════
   6. ACTIVE / SELECTED STATE SURFACES
   ═══════════════════════════════════════════════════ */
html[data-theme="light"] .bg-indigo-500\/20         { background: rgba(var(--color-primary-rgb),0.10) !important; }
html[data-theme="light"] .bg-indigo-500\/15         { background: rgba(var(--color-primary-rgb),0.09) !important; }
html[data-theme="light"] .bg-indigo-500\/10         { background: rgba(var(--color-primary-rgb),0.07) !important; }
html[data-theme="light"] .hover\:bg-indigo-500\/10:hover { background: rgba(var(--color-primary-rgb),0.10) !important; }

/* Emerald / green category tiles in the sidebar */
html[data-theme="light"] .bg-emerald-500\/10  { background: rgba(5,150,105,0.08)  !important; }
html[data-theme="light"] .bg-amber-500\/10    { background: rgba(180,83,9,0.08)   !important; }

/* Status badge surfaces */
html[data-theme="light"] .bg-green-500\/10   { background: rgba(22,163,74,0.09)  !important; }
html[data-theme="light"] .bg-red-500\/10     { background: rgba(220,38,38,0.08)  !important; }
html[data-theme="light"] .hover\:bg-red-500\/10:hover { background: rgba(220,38,38,0.10) !important; }

/* ── Dashboard action buttons ── */
html[data-theme="light"] .dashboard-btn-cpanel {
    background: linear-gradient(135deg, #0ea5e9, #0284c7) !important;
    color: #fff !important;
    box-shadow: 0 1px 3px rgba(14,165,233,0.25) !important;
}
html[data-theme="light"] .dashboard-btn-cpanel:hover {
    opacity: 0.92 !important;
    box-shadow: 0 2px 8px rgba(14,165,233,0.35) !important;
}
html[data-theme="light"] .dashboard-btn-manage {
    background: rgba(255,255,255,0.65) !important;
    border-color: rgba(var(--color-primary-rgb),0.18) !important;
    color: #374151 !important;
    box-shadow: 0 1px 2px rgba(0,0,0,0.06) !important;
}
html[data-theme="light"] .dashboard-btn-manage:hover {
    background: rgba(255,255,255,0.85) !important;
    border-color: rgba(var(--color-primary-rgb),0.28) !important;
    color: #111827 !important;
}

/* ═══════════════════════════════════════════════════
   7. HERO CARDS & SPECIAL INLINE STYLES
   ═══════════════════════════════════════════════════ */

/* Full-width page hero banners (domain-transfer, domain-registration etc.) */
html[data-theme="light"] [data-hero] {
    background-color: transparent !important;
    background-image:
        radial-gradient(ellipse 80% 60% at 50% 0%, rgba(var(--color-primary-rgb),0.14) 0%, transparent 65%),
        radial-gradient(ellipse 55% 40% at 20% 100%, rgba(165,180,252,0.22) 0%, transparent 60%),
        linear-gradient(180deg, rgba(238,242,255,0.92) 0%, rgba(224,231,255,0.70) 100%) !important;
    border-bottom-color: rgba(165,180,252,0.28) !important;
    backdrop-filter: blur(0px) !important;
    -webkit-backdrop-filter: blur(0px) !important;
    box-shadow: 0 4px 24px rgba(var(--color-primary-rgb),0.08) !important;
}
/* Keep glow blobs visible but softer */
html[data-theme="light"] [data-hero] .opacity-20 { opacity: 0.12 !important; }
html[data-theme="light"] [data-hero] .opacity-10 { opacity: 0.08 !important; }

/* Hero card dark gradient → soft glass with indigo aurora */
html[data-theme="light"] [style*="rgba(55,48,163"],
html[data-theme="light"] [style*="rgba(67,56,202"],
html[data-theme="light"] [style*="rgba(79,70,229"] {
    background:
        linear-gradient(135deg,
            rgba(var(--color-primary-rgb),0.12) 0%,
            rgba(165,180,252,0.07) 60%,
            rgba(238,242,255,0) 100%) !important;
    backdrop-filter: blur(20px) saturate(1.8) !important;
    -webkit-backdrop-filter: blur(20px) saturate(1.8) !important;
    border-color: rgba(var(--color-primary-rgb),0.22) !important;
    box-shadow: 0 4px 20px rgba(var(--color-primary-rgb),0.10), inset 0 1px 0 rgba(255,255,255,0.7) !important;
}
/* Hero bottom bar (rgba(0,0,0,0.15)) */
html[data-theme="light"] [style*="rgba(0,0,0,0.15)"] {
    background: rgba(var(--color-primary-rgb),0.05) !important;
    border-top-color: rgba(var(--color-primary-rgb),0.12) !important;
}
/* Footer inline `style="background: #030712;"` */
html[data-theme="light"] [style*="background: #030712"],
html[data-theme="light"] [style*="background:#030712"] {
    background: rgba(238,242,255,0.6) !important;
    backdrop-filter: blur(16px) !important;
    -webkit-backdrop-filter: blur(16px) !important;
}
/* Gradient buttons — keep indigo gradient, ensure white text */
html[data-theme="light"] [style*="linear-gradient(135deg, var(--color-primary)"],
html[data-theme="light"] [style*="linear-gradient(135deg,var(--color-primary)"],
html[data-theme="light"] [style*="background: linear-gradient(135deg, var(--color-primary)"],
html[data-theme="light"] [style*="background:linear-gradient(135deg,var(--color-primary)"] {
    color: #ffffff !important;
    box-shadow: 0 4px 16px rgba(var(--color-primary-rgb),0.30) !important;
}

/* ── Webhosting / VPS "Recommended" plan card (dark gradient bg) ── */
html[data-theme="light"] [style*="rgba(30,41,59"],
html[data-theme="light"] [style*="rgba(23,31,50"] {
    background: rgba(255,255,255,0.80) !important;
    backdrop-filter: blur(20px) saturate(1.9) !important;
    -webkit-backdrop-filter: blur(20px) saturate(1.9) !important;
    border-color: rgba(59,130,246,0.35) !important;
    box-shadow:
        0 0 0 2px rgba(59,130,246,0.30),
        0 8px 32px rgba(59,130,246,0.14),
        inset 0 1px 0 rgba(255,255,255,0.95) !important;
}
/* "Recommended" banner strip */
html[data-theme="light"] [style*="rgba(59,130,246,0.12)"] {
    background: rgba(59,130,246,0.09) !important;
    border-bottom-color: rgba(59,130,246,0.18) !important;
}
html[data-theme="light"] .text-blue-300 { color: #1d4ed8 !important; }
/* Blue CTA button */
html[data-theme="light"] [style*="linear-gradient(90deg, #3b82f6"],
html[data-theme="light"] [style*="background: linear-gradient(90deg, #3b82f6"] {
    color: #ffffff !important;
    box-shadow: 0 4px 16px rgba(59,130,246,0.30) !important;
}
/* ring-blue-500 → stay visible on light bg */
html[data-theme="light"] .ring-blue-500 {
    --tw-ring-color: rgba(59,130,246,0.55) !important;
}
/* ring-indigo-500 → indigo ring visible on light */
html[data-theme="light"] .ring-indigo-500 {
    --tw-ring-color: rgba(var(--color-primary-rgb),0.50) !important;
}
/* Blue shadow glow on recommended card */
html[data-theme="light"] .shadow-\[0_0_40px_-8px_rgba\(59\,130\,246\,0\.4\)\] {
    box-shadow: 0 0 28px -6px rgba(59,130,246,0.22) !important;
}

/* ═══════════════════════════════════════════════════
   8. FORM INPUTS — clean glass style
   ═══════════════════════════════════════════════════ */
html[data-theme="light"] input[type="text"],
html[data-theme="light"] input[type="email"],
html[data-theme="light"] input[type="password"],
html[data-theme="light"] input[type="tel"],
html[data-theme="light"] input[type="number"],
html[data-theme="light"] input[type="search"],
html[data-theme="light"] textarea,
html[data-theme="light"] select {
    background:   rgba(255,255,255,0.75) !important;
    backdrop-filter: blur(8px) !important;
    -webkit-backdrop-filter: blur(8px) !important;
    border:       1px solid rgba(var(--color-primary-rgb),0.20) !important;
    color:        #0f172a !important;
    box-shadow:   0 1px 3px rgba(var(--color-primary-rgb),0.06), inset 0 1px 0 rgba(255,255,255,0.9) !important;
}
html[data-theme="light"] input:focus,
html[data-theme="light"] textarea:focus,
html[data-theme="light"] select:focus {
    background:   rgba(255,255,255,0.90) !important;
    border-color: rgba(var(--color-primary-rgb),0.55) !important;
    box-shadow:   0 0 0 3px rgba(var(--color-primary-rgb),0.14),
                  inset 0 1px 0 rgba(255,255,255,0.9) !important;
}
html[data-theme="light"] select option          { background: #ffffff; color: #0f172a; }
html[data-theme="light"] input::placeholder,
html[data-theme="light"] textarea::placeholder  { color: #94a3b8 !important; opacity: 1 !important; }

/* ═══════════════════════════════════════════════════
   9. SCROLLBARS — matching glass palette
   ═══════════════════════════════════════════════════ */
html[data-theme="light"] ::-webkit-scrollbar-track { background: transparent; }
html[data-theme="light"] ::-webkit-scrollbar-thumb {
    background: rgba(var(--color-primary-rgb),0.18);
    border-radius: 3px;
}
html[data-theme="light"] ::-webkit-scrollbar-thumb:hover {
    background: rgba(var(--color-primary-rgb),0.32);
}

/* ═══════════════════════════════════════════════════
   10. EMAIL VERIFICATION BANNER
   ═══════════════════════════════════════════════════ */
html[data-theme="light"] .email-verify-banner {
    background: rgba(37,99,235,0.07) !important;
    border-color: rgba(37,99,235,0.25) !important;
    color: #1e40af !important;
    box-shadow: 0 1px 4px rgba(37,99,235,0.08), inset 0 1px 0 rgba(255,255,255,0.60) !important;
    backdrop-filter: blur(8px) !important;
    -webkit-backdrop-filter: blur(8px) !important;
}
html[data-theme="light"] .email-verify-banner p,
html[data-theme="light"] .email-verify-banner svg {
    color: #1e40af !important;
}
html[data-theme="light"] .email-verify-banner .text-blue-200 {
    color: #1e3a8a !important;
    font-weight: 600 !important;
}
html[data-theme="light"] .email-verify-banner strong {
    color: #1e3a8a !important;
}
html[data-theme="light"] .email-verify-banner .evb-resend-btn {
    background: rgba(37,99,235,0.12) !important;
    border: 1px solid rgba(37,99,235,0.25) !important;
    color: #1d4ed8 !important;
}
html[data-theme="light"] .email-verify-banner .evb-resend-btn:hover:not(:disabled) {
    background: rgba(37,99,235,0.20) !important;
    border-color: rgba(37,99,235,0.40) !important;
}
html[data-theme="light"] .email-verify-banner .evb-dismiss-btn {
    color: #3b82f6 !important;
}
html[data-theme="light"] .email-verify-banner .evb-dismiss-btn:hover {
    color: #1d4ed8 !important;
}

/* ═══════════════════════════════════════════════════
   11. NOTIFICATION TOASTS
   ═══════════════════════════════════════════════════ */
html[data-theme="light"] #merovps-notif > div {
    background:        rgba(255,255,255,0.90) !important;
    backdrop-filter:   blur(20px) saturate(2) !important;
    -webkit-backdrop-filter: blur(20px) saturate(2) !important;
    border:            1px solid rgba(165,180,252,0.25) !important;
    color:             #0f172a !important;
    box-shadow:        0 8px 32px rgba(var(--color-primary-rgb),0.12), 0 2px 8px rgba(15,23,42,0.08) !important;
}

/* ═══════════════════════════════════════════════════
   11. MARKDOWN / RICH CONTENT
   ═══════════════════════════════════════════════════ */
html[data-theme="light"] .markdown-content,
html[data-theme="light"] .bb-content       { color: #334155 !important; line-height: 1.75 !important; }
html[data-theme="light"] .markdown-content a,
html[data-theme="light"] .bb-content a     { color: #4f46e5 !important; }
html[data-theme="light"] .markdown-content code,
html[data-theme="light"] .bb-content code  {
    background:   rgba(var(--color-primary-rgb),0.08) !important;
    border:       1px solid rgba(var(--color-primary-rgb),0.16) !important;
    color:        #3730a3 !important;
}
html[data-theme="light"] .markdown-content pre,
html[data-theme="light"] .bb-content pre   {
    background:   rgba(255,255,255,0.70) !important;
    backdrop-filter: blur(10px) !important;
    border:       1px solid rgba(165,180,252,0.22) !important;
}

/* ═══════════════════════════════════════════════════
   12. UTILITY CLASSES
   ═══════════════════════════════════════════════════ */
html[data-theme="light"] .card-glass {
    background:        rgba(255,255,255,0.70) !important;
    backdrop-filter:   blur(16px) saturate(2) !important;
    -webkit-backdrop-filter: blur(16px) saturate(2) !important;
    border:            1px solid rgba(165,180,252,0.22) !important;
    box-shadow:        0 4px 20px rgba(var(--color-primary-rgb),0.08), inset 0 1px 0 rgba(255,255,255,0.80) !important;
}
html[data-theme="light"] .gradient-text {
    background: linear-gradient(135deg, #4338ca 0%, #6d28d9 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}
html[data-theme="light"] .is-required { border-color: rgba(185,28,28,0.40) !important; }

/* ── Animate-pulse adjustment (status dot) ── */
html[data-theme="light"] .bg-green-400             { background-color: #16a34a !important; }
html[data-theme="light"] .animate-pulse.bg-green-400 { background-color: #16a34a !important; }

/* ── Contact role toggle — inactive state (bg-gray-700 is too dark on light canvas) ── */
html[data-theme="light"] .contact-role-toggle.bg-gray-700 {
    background-color: rgba(148,163,184,0.40) !important;
    border-color: rgba(165,180,252,0.25) !important;
}

/* ── Shadows ── */
html[data-theme="light"] .shadow-lg          { box-shadow: 0 4px 20px rgba(var(--color-primary-rgb),0.10) !important; }
html[data-theme="light"] .shadow-2xl         { box-shadow: 0 10px 40px rgba(var(--color-primary-rgb),0.12) !important; }
html[data-theme="light"] .shadow-black\/60   { --tw-shadow-color: rgba(var(--color-primary-rgb),0.12) !important; }
html[data-theme="light"] .shadow-indigo-500\/20 { box-shadow: 0 4px 16px rgba(var(--color-primary-rgb),0.18) !important; }
html[data-theme="light"] .shadow-indigo-500\/30 { box-shadow: 0 4px 20px rgba(var(--color-primary-rgb),0.22) !important; }

/* ═══════════════════════════════════════════════════
   13. RENEW MODAL — light-mode overrides
   ═══════════════════════════════════════════════════ */
html[data-theme="light"] .renew-modal-overlay {
    background: rgba(15,23,42,0.50) !important;
    backdrop-filter: blur(8px) saturate(1.5) !important;
    -webkit-backdrop-filter: blur(8px) saturate(1.5) !important;
}
html[data-theme="light"] .renew-modal-card {
    background: rgba(255,255,255,0.94) !important;
    backdrop-filter: blur(24px) saturate(2) !important;
    -webkit-backdrop-filter: blur(24px) saturate(2) !important;
    border-color: rgba(165,180,252,0.30) !important;
    box-shadow:
        0 20px 60px rgba(var(--color-primary-rgb),0.15),
        0 4px 16px rgba(15,23,42,0.10),
        inset 0 1px 0 rgba(255,255,255,1) !important;
}
html[data-theme="light"] .renew-modal-card .border-white\/\[0\.06\] {
    border-color: rgba(165,180,252,0.18) !important;
}
html[data-theme="light"] .renew-modal-card select option {
    background: #ffffff;
    color: #0f172a;
}

/* ═══════════════════════════════════════════════════
   14. EPP / OTP MODAL — light-mode overrides
   ═══════════════════════════════════════════════════ */
html[data-theme="light"] .epp-modal-overlay {
    background: rgba(15,23,42,0.50) !important;
    backdrop-filter: blur(8px) saturate(1.5) !important;
    -webkit-backdrop-filter: blur(8px) saturate(1.5) !important;
}
html[data-theme="light"] .epp-modal-card {
    background: rgba(255,255,255,0.94) !important;
    backdrop-filter: blur(24px) saturate(2) !important;
    -webkit-backdrop-filter: blur(24px) saturate(2) !important;
    border-color: rgba(165,180,252,0.30) !important;
    box-shadow:
        0 20px 60px rgba(var(--color-primary-rgb),0.15),
        0 4px 16px rgba(15,23,42,0.10),
        inset 0 1px 0 rgba(255,255,255,1) !important;
}
/* Header divider */
html[data-theme="light"] .epp-modal-card .border-white\/\[0\.06\] {
    border-color: rgba(165,180,252,0.18) !important;
}
/* Description text */
html[data-theme="light"] .epp-modal-card .text-gray-400 { color: #475569 !important; }
/* Countdown label */
html[data-theme="light"] .epp-modal-card .text-gray-500 { color: #64748b !important; }
/* OTP input */
html[data-theme="light"] .epp-modal-card input[type="text"] {
    background:   rgba(255,255,255,0.80) !important;
    border-color: rgba(var(--color-primary-rgb),0.22)  !important;
    color:        #0f172a !important;
}
html[data-theme="light"] .epp-modal-card input::placeholder { color: #94a3b8 !important; }
/* Close button */
html[data-theme="light"] .epp-modal-card .text-gray-500.hover\:text-white:hover,
html[data-theme="light"] .epp-modal-card button.text-gray-500          { color: #64748b !important; }
html[data-theme="light"] .epp-modal-card button.text-gray-500:hover     { color: #0f172a !important; }

/* ═══════════════════════════════════════════════════
   15. BUTTONS — preserve white text on solid backgrounds
   ═══════════════════════════════════════════════════
   The blanket `.text-white → #0f172a` override in §3 is correct
   for headings and body text, but buttons/badges with opaque
   colored backgrounds still need legible white text.
   ═══════════════════════════════════════════════════ */

/* ── Solid Tailwind bg-{color}-{shade} + text-white ── */
html[data-theme="light"] .bg-indigo-500.text-white,
html[data-theme="light"] .bg-indigo-600.text-white,
html[data-theme="light"] .bg-indigo-600\/80.text-white,
html[data-theme="light"] .bg-blue-500.text-white,
html[data-theme="light"] .bg-blue-600.text-white,
html[data-theme="light"] .bg-emerald-500.text-white,
html[data-theme="light"] .bg-emerald-600.text-white,
html[data-theme="light"] .bg-green-500.text-white,
html[data-theme="light"] .bg-green-600.text-white,
html[data-theme="light"] .bg-violet-500.text-white,
html[data-theme="light"] .bg-violet-600.text-white,
html[data-theme="light"] .bg-red-500.text-white,
html[data-theme="light"] .bg-red-600.text-white,
html[data-theme="light"] .bg-purple-500.text-white,
html[data-theme="light"] .bg-purple-600.text-white,
html[data-theme="light"] .bg-teal-500.text-white,
html[data-theme="light"] .bg-teal-600.text-white,
html[data-theme="light"] .bg-amber-500.text-white,
html[data-theme="light"] .bg-amber-600.text-white {
    color: #ffffff !important;
}

/* ── Inline-style gradient/solid backgrounds with .text-white class ── */
/* Green gradient CTA (contact-us, dashboard) */
html[data-theme="light"] [style*="linear-gradient(135deg, #10b981"].text-white,
html[data-theme="light"] [style*="linear-gradient(135deg,#10b981"].text-white {
    color: #ffffff !important;
    box-shadow: 0 4px 16px rgba(16,185,129,0.30) !important;
}
/* Lime-green sale badge */
html[data-theme="light"] [style*="background: #65a30d"].text-white,
html[data-theme="light"] [style*="background:#65a30d"].text-white {
    color: #ffffff !important;
}

/* ── Children of solid-bg buttons that inherit .text-white ── */
html[data-theme="light"] .bg-indigo-500 .text-white,
html[data-theme="light"] .bg-indigo-600 .text-white,
html[data-theme="light"] .bg-blue-500 .text-white,
html[data-theme="light"] .bg-blue-600 .text-white,
html[data-theme="light"] .bg-emerald-500 .text-white,
html[data-theme="light"] .bg-green-500 .text-white,
html[data-theme="light"] .bg-violet-500 .text-white,
html[data-theme="light"] .bg-red-500 .text-white,
html[data-theme="light"] .bg-purple-500 .text-white {
    color: #ffffff !important;
}

/* ── Pagination active page (bg-indigo-500 text-white) ── */
html[data-theme="light"] a.bg-indigo-500.text-white,
html[data-theme="light"] span.bg-indigo-500.text-white,
html[data-theme="light"] div.bg-indigo-500.text-white {
    color: #ffffff !important;
}

/* §16 ── Compact payment method buttons (light mode) ── */
html[data-theme="light"] .text-emerald-400 {
    color: #059669 !important;
}
html[data-theme="light"] .text-indigo-300 {
    color: #4338ca !important;
}
html[data-theme="light"] .text-indigo-400\/70 {
    color: rgba(79, 70, 229, 0.7) !important;
}

/* §18 ── VPS / Server manage panel ── */
/* Spec pill chips and SSH quick-connect block use rgba(0,0,0,0.18) inner bg — becomes an
   indigo-tinted glass chip on the light canvas so it stays visually inset without going dark */
html[data-theme="light"] [style*="rgba(0,0,0,0.18)"] {
    background: rgba(var(--color-primary-rgb),0.06) !important;
    border-color: rgba(165,180,252,0.20) !important;
}
/* Opacity-variant white text used for hero-card metadata (location, "Next Due" label, days-left) */
html[data-theme="light"] .text-white\/40 { color: #94a3b8 !important; }
html[data-theme="light"] .text-white\/50 { color: #64748b !important; }
html[data-theme="light"] .text-white\/60 { color: #475569 !important; }

/* §17 ── Login modal (light mode) ── */
html[data-theme="light"] .login-modal {
    background: #ffffff !important;
    border-color: rgba(0, 0, 0, 0.1) !important;
    box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.15) !important;
}
html[data-theme="light"] .login-modal-title {
    color: #111827 !important;
}
html[data-theme="light"] .login-modal-label {
    color: #4b5563 !important;
}
html[data-theme="light"] .login-modal-input {
    background: #f9fafb !important;
    border-color: #d1d5db !important;
    color: #111827 !important;
}
html[data-theme="light"] .login-modal-input::placeholder {
    color: #9ca3af !important;
}
html[data-theme="light"] .login-modal-input:focus {
    border-color: var(--color-primary) !important;
    box-shadow: 0 0 0 2px rgba(var(--color-primary-rgb), 0.15) !important;
}

/* ── Category description rich-text rendering ──────────────────────────── */
.category-description h1 {
    font-size: 1.125rem;
    font-weight: 700;
    color: #f1f5f9;
    margin: 0 0 8px;
    line-height: 1.4;
}
.category-description h2 {
    font-size: 1rem;
    font-weight: 600;
    color: #e2e8f0;
    margin: 12px 0 6px;
}
.category-description h3 {
    font-size: 0.875rem;
    font-weight: 600;
    color: #cbd5e1;
    margin: 10px 0 4px;
}
.category-description p {
    font-size: 0.875rem;
    color: #94a3b8;
    line-height: 1.65;
    margin: 0 0 8px;
}
.category-description ul,
.category-description ol {
    margin: 0 0 10px 0;
    padding-left: 1.25rem;
}
.category-description li {
    font-size: 0.8125rem;
    color: #94a3b8;
    line-height: 1.6;
    margin-bottom: 3px;
}
.category-description ul li {
    list-style-type: disc;
}
.category-description ol li {
    list-style-type: decimal;
}
.category-description strong, .category-description b {
    color: #e2e8f0;
    font-weight: 600;
}
.category-description blockquote {
    border-left: 3px solid rgba(99, 102, 241, 0.4);
    padding: 6px 0 6px 14px;
    margin: 0 0 10px;
    background: rgba(99, 102, 241, 0.05);
    border-radius: 0 6px 6px 0;
}
.category-description blockquote h1,
.category-description blockquote h2,
.category-description blockquote h3 {
    font-size: 0.8125rem;
    font-weight: 600;
    color: #a5b4fc;
    margin: 0;
}
.category-description blockquote p {
    font-size: 0.8125rem;
    color: #94a3b8;
    margin: 0;
}
.category-description a {
    color: #818cf8;
    text-decoration: none;
}
.category-description a:hover {
    text-decoration: underline;
}
/* Light mode overrides */
html[data-theme="light"] .category-description h1 { color: #1e293b; }
html[data-theme="light"] .category-description h2 { color: #334155; }
html[data-theme="light"] .category-description h3 { color: #475569; }
html[data-theme="light"] .category-description p  { color: #475569; }
html[data-theme="light"] .category-description li { color: #475569; }
html[data-theme="light"] .category-description strong,
html[data-theme="light"] .category-description b  { color: #1e293b; }
html[data-theme="light"] .category-description blockquote {
    border-left-color: rgba(99, 102, 241, 0.5);
    background: rgba(99, 102, 241, 0.06);
}
html[data-theme="light"] .category-description blockquote h1,
html[data-theme="light"] .category-description blockquote h2,
html[data-theme="light"] .category-description blockquote h3 {
    color: #4338ca;
}
html[data-theme="light"] .category-description blockquote p {
    color: #475569;
}

/* ═══════════════════════════════════════════════════
   Help & Support slide-in panel — dark mode base + light overrides
   =========================== */
.help-panel {
    background: rgba(8, 12, 24, 0.88);
    backdrop-filter: blur(24px) saturate(1.6);
    -webkit-backdrop-filter: blur(24px) saturate(1.6);
    border-right: 1px solid rgba(255,255,255,0.09);
    box-shadow: 6px 0 32px rgba(0,0,0,0.35), inset -1px 0 0 rgba(255,255,255,0.04);
}
.help-panel-header {
    background: linear-gradient(135deg, rgba(var(--color-primary-rgb),0.14), rgba(var(--color-secondary-rgb),0.07));
}
.help-panel-card {
    background: rgba(255,255,255,0.03);
    border: 1px solid rgba(255,255,255,0.07);
}
.help-panel-footer {
    background: rgba(16,185,129,0.05);
}

/* Mobile: full-width panel anchored to left edge, max 18rem wide */
@media (max-width: 1023px) {
    .help-panel {
        left: 0 !important;
        width: min(18rem, 85vw) !important;
    }
}

/* Desktop: panel left tracks sidebar width via data-sb on <html> */
/* Default (expanded sidebar = 16rem) */
@media (min-width: 1024px) {
    #help-panel {
        left: 16rem;
        transition: left 300ms ease-in-out;
    }
    html[data-sb="collapsed"] #help-panel {
        left: 4rem;
    }
}

html[data-theme="light"] .help-panel {
    background: rgba(255,255,255,0.92) !important;
    backdrop-filter: blur(28px) saturate(2) !important;
    -webkit-backdrop-filter: blur(28px) saturate(2) !important;
    border-right: 1px solid rgba(165,180,252,0.28) !important;
    box-shadow: 4px 0 32px rgba(var(--color-primary-rgb),0.10) !important;
}
html[data-theme="light"] .help-panel-header {
    background: linear-gradient(135deg, rgba(var(--color-primary-rgb),0.08), rgba(var(--color-secondary-rgb),0.05)) !important;
    border-bottom-color: rgba(165,180,252,0.22) !important;
}
html[data-theme="light"] .help-panel-card {
    background: rgba(238,242,255,0.55) !important;
    border-color: rgba(165,180,252,0.25) !important;
}
html[data-theme="light"] .help-panel-footer {
    background: rgba(5,150,105,0.06) !important;
    border-top-color: rgba(165,180,252,0.20) !important;
}
/* Restore Alpine transitions in panel (overridden by global light mode !important) */
html[data-theme="light"] .help-panel[x-show],
html[data-theme="light"] .help-panel[x-transition] {
    transition: opacity 200ms ease, transform 200ms ease !important;
}

/* ═══════════════════════════════════════════════════
   FORMBUILDER — light mode
   ═══════════════════════════════════════════════════ */
/* Checkbox & radio borders — visible on light background */
html[data-theme="light"] .formbuilder-check,
html[data-theme="light"] .formbuilder-radio {
    border-color: rgba(var(--color-primary-rgb),0.25) !important;
    background: rgba(255,255,255,0.80) !important;
}
html[data-theme="light"] .formbuilder-check:checked,
html[data-theme="light"] .formbuilder-radio:checked {
    background-color: #4f46e5 !important;
    border-color: #4f46e5 !important;
}
/* Select dropdown — legible on light */
html[data-theme="light"] select[style*="rgba(255,255,255,0.03)"] {
    background: rgba(255,255,255,0.80) !important;
    border-color: rgba(165,180,252,0.30) !important;
    color: #0f172a !important;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3E%3Cpath stroke='%23475569' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3E%3C/svg%3E") !important;
    background-position: right 0.75rem center !important;
    background-repeat: no-repeat !important;
    background-size: 1.25em 1.25em !important;
}
html[data-theme="light"] select option {
    background: #fff !important;
    color: #0f172a !important;
}
/* Required asterisk */
html[data-theme="light"] .text-red-400\/80 { color: rgba(185,28,28,0.90) !important; }

/* ═══════════════════════════════════════════════════
   AUTH MODALS (checkout login/signup) — light mode
   ═══════════════════════════════════════════════════ */
html[data-theme="light"] [style*="rgba(15,15,25,0.95)"] {
    background: rgba(255,255,255,0.95) !important;
    border-color: rgba(165,180,252,0.30) !important;
    backdrop-filter: blur(24px) saturate(2) !important;
    -webkit-backdrop-filter: blur(24px) saturate(2) !important;
    box-shadow:
        0 20px 60px rgba(var(--color-primary-rgb),0.12),
        0 4px 16px rgba(15,23,42,0.08),
        inset 0 1px 0 rgba(255,255,255,1) !important;
}
/* Modal input fields — override inline style bg+border */
html[data-theme="light"] [style*="rgba(15,15,25,0.95)"] input[type="email"],
html[data-theme="light"] [style*="rgba(15,15,25,0.95)"] input[type="password"],
html[data-theme="light"] [style*="rgba(15,15,25,0.95)"] input[type="text"] {
    background: rgba(248,250,252,0.90) !important;
    border: 1px solid rgba(148,163,184,0.35) !important;
    color: #0f172a !important;
    box-shadow: inset 0 1px 3px rgba(15,23,42,0.06) !important;
}
html[data-theme="light"] [style*="rgba(15,15,25,0.95)"] input[type="email"]:focus,
html[data-theme="light"] [style*="rgba(15,15,25,0.95)"] input[type="password"]:focus,
html[data-theme="light"] [style*="rgba(15,15,25,0.95)"] input[type="text"]:focus {
    border-color: rgba(99,102,241,0.60) !important;
    box-shadow: 0 0 0 3px rgba(99,102,241,0.12), inset 0 1px 3px rgba(15,23,42,0.04) !important;
}
html[data-theme="light"] [style*="rgba(15,15,25,0.95)"] input::placeholder {
    color: #94a3b8 !important;
}
/* Modal text overrides in light mode */
html[data-theme="light"] [style*="rgba(15,15,25,0.95)"] h2,
html[data-theme="light"] [style*="rgba(15,15,25,0.95)"] label {
    color: #0f172a !important;
}
html[data-theme="light"] [style*="rgba(15,15,25,0.95)"] .text-gray-300,
html[data-theme="light"] [style*="rgba(15,15,25,0.95)"] .text-gray-400 {
    color: #334155 !important;
}
html[data-theme="light"] [style*="rgba(15,15,25,0.95)"] .text-gray-500 {
    color: #64748b !important;
}
