/* Shared styles for SMARTO Brain Skills Olympiad (SBSO) */

:root {
    --sbso-font-family: 'Outfit', 'Inter', -apple-system, sans-serif;
    --sbso-radius: 12px;
    --sbso-shadow: 0 4px 30px rgba(0, 0, 0, 0.4);

    /* Default Theme Mode Variables (Dark) */
    --bg-page: #070a13;
    --bg-card: rgba(30, 41, 59, 0.45);
    --bg-card-hover: rgba(30, 41, 59, 0.7);
    --bg-card-solid: #1e293b;
    --text-primary: #f3f4f6;
    --text-secondary: #94a3b8;
    --border-color: rgba(255, 255, 255, 0.08);
    --border-card: rgba(255, 255, 255, 0.05);

    --grad-glow: radial-gradient(circle at 50% 0%, rgba(99, 102, 241, 0.25), transparent 70%);
    --grad-glow-dynamic: radial-gradient(circle at top, #0f172a 0%, #070a13 100%);
    --glass-shadow: 0 10px 40px rgba(0, 0, 0, 0.5);
}

/* Light Theme Variables Override */
body.light-theme {
    --bg-page: #f1f5f9;
    --bg-card: rgba(255, 255, 255, 0.7);
    --bg-card-hover: rgba(248, 250, 252, 0.9);
    --bg-card-solid: #ffffff;
    --text-primary: #0f172a;
    --text-secondary: #475569;
    --border-color: rgba(15, 23, 42, 0.08);
    --border-card: rgba(15, 23, 42, 0.05);

    --grad-glow: radial-gradient(circle at 50% 0%, rgba(99, 102, 241, 0.08), transparent 70%);
    --grad-glow-dynamic: none !important;
    --glass-shadow: 0 8px 30px rgba(15, 23, 42, 0.05);
}

.sbso-card {
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.sbso-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 30px rgba(59, 130, 246, 0.15);
}

/* Glassmorphism containers */
.sbso-glass {
    background: rgba(21, 29, 48, 0.75);
    -webkit-backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    backdrop-filter: blur(12px);
    border: 1px solid rgba(255, 255, 255, 0.08);
}

/* ==========================================================================
   FORCED DARK MODE & READABILITY OVERRIDES
   These rules ensure premium dynamic styling across all themes.
   ========================================================================== */

/* Force dynamic theme background on all plugin page wrappers */
.sbso-login-wrapper,
.sbso-registration-wrapper,
.sbso-dashboard-wrapper {
    background-color: var(--bg-page) !important;
    background-image: var(--grad-glow-dynamic) !important;
    background-attachment: fixed !important;
    padding: 60px 20px !important;
    color: var(--text-primary) !important;
    min-height: 100vh !important;
    display: block !important;
    box-sizing: border-box !important;
}

/* Force dark/light backgrounds on all container cards */
.sbso-glass-card,
.sbso-card,
.kpi-card,
.portal-card,
.sbso-header-glass,
.sbso-dashboard-container > div,
#sbso-multistep-reg-form,
#sbso-school-reg-form,
#sbso-profile-edit-form {
    background-color: var(--bg-card-solid) !important;
    background-image: none !important;
    border: 1px solid var(--border-color) !important;
    box-shadow: var(--glass-shadow) !important;
    color: var(--text-primary) !important;
    border-radius: 16px !important;
}

/* Fix text colors inside dashboard/form cards to ensure high readability */
.sbso-login-wrapper h1, .sbso-login-wrapper h2, .sbso-login-wrapper h3,
.sbso-registration-wrapper h1, .sbso-registration-wrapper h2, .sbso-registration-wrapper h3,
.sbso-dashboard-wrapper h1, .sbso-dashboard-wrapper h2, .sbso-dashboard-wrapper h3,
.sbso-dashboard-container h1, .sbso-dashboard-container h2, .sbso-dashboard-container h3,
.sbso-header-info h1, .sbso-header-info h2, .sbso-header-info h3,
.sbso-glass-card h1, .sbso-glass-card h2, .sbso-glass-card h3 {
    color: var(--text-primary) !important;
}

/* Description texts, headings and titles */
.sbso-login-wrapper p, .sbso-login-wrapper span,
.sbso-registration-wrapper p, .sbso-registration-wrapper span,
.sbso-dashboard-wrapper p, .sbso-dashboard-wrapper span,
.sbso-dashboard-container p, .sbso-dashboard-container span,
.step-node span {
    color: var(--text-secondary) !important;
}

/* Labels configuration */
.sbso-glass-card label,
#sbso-multistep-reg-form label,
#sbso-school-reg-form label,
#sbso-profile-edit-form label,
form label {
    color: var(--text-secondary) !important;
    font-weight: 600 !important;
    font-size: 12px !important;
    letter-spacing: 0.5px !important;
    text-transform: uppercase !important;
}

/* High contrast inputs */
input[type="text"],
input[type="email"],
input[type="password"],
input[type="date"],
input[type="number"],
input[type="url"],
select,
textarea {
    background-color: var(--bg-page) !important;
    color: var(--text-primary) !important;
    border: 1px solid var(--border-color) !important;
}

input[type="text"]:focus,
input[type="email"]:focus,
input[type="password"]:focus,
input[type="date"]:focus,
input[type="number"]:focus,
input[type="url"]:focus,
select:focus,
textarea:focus {
    border-color: #3b82f6 !important;
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.35) !important;
    background-color: var(--bg-card-solid) !important;
}

select option {
    background-color: var(--bg-page) !important;
    color: var(--text-primary) !important;
}

/* Table header & row styling overrides */
table th {
    background-color: var(--bg-page) !important;
    color: var(--text-primary) !important;
    border-bottom: 2px solid var(--border-color) !important;
}

table td {
    background-color: var(--bg-card-solid) !important;
    color: var(--text-secondary) !important;
    border-bottom: 1px solid var(--border-color) !important;
}

/* Responsive tables horizontal scroll */
@media (max-width: 768px) {
    .sbso-login-wrapper,
    .sbso-registration-wrapper,
    .sbso-dashboard-wrapper {
        padding: 30px 10px !important;
    }
    
    .sbso-glass-card,
    .sbso-header-glass {
        padding: 20px 15px !important;
    }

    .sbso-dashboard-container table, 
    .sbso-tab-content table {
        display: block !important;
        width: 100% !important;
        overflow-x: auto !important;
        white-space: nowrap !important;
    }
}
