/* =====================================================
   KCDA — Premium Design System v2
   ===================================================== */

/* ---------- CSS Custom Properties ---------- */
:root {
    /* Medical AI Palette — Clean Corporate Blue & Green */
    --primary-500: #3b82f6;
    --primary-600: #2563eb;
    --primary: #1d4ed8;
    --primary-dark: #1e3a8a;
    
    --accent-mint: #059669;
    --accent-cyan: #0891b2;
    --accent-indigo: #4338ca;

    /* Surfaces — Soft, Professional, Deep */
    --bg-body: #ffffff;
    --bg-card: rgba(255, 255, 255, 0.9);
    --bg-elevated: #ffffff;
    --bg-subtle: #f8fafc;
    
    /* Text */
    --text-heading: #0f172a;
    --text-body: #334155;
    --text-secondary: #64748b;
    --text-muted: #94a3b8;
    --text-inverse: #ffffff;

    /* Advanced Shadows & Glass */
    --glass-blur: blur(16px) saturate(180%);
    --shadow-sm: 0 1px 2px 0 rgb(0 0 0 / 0.05);
    --shadow-md: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
    --shadow-lg: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
    --shadow-xl: 0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1);
    --shadow-glow: 0 0 30px rgba(14, 165, 233, 0.2);

    /* Radius */
    --radius-lg: 16px;
    --radius-xl: 24px;
    --radius-2xl: 32px;

    /* Typography */
    --font-sans: 'Plus Jakarta Sans', sans-serif;
    
    /* Transitions */
    --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
    --ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);
}

/* Password reset hardening UI */
.reset-page-shell {
    width: min(1120px, calc(100% - 2rem));
    margin: 0 auto;
    display: grid;
    grid-template-columns: minmax(320px, 0.78fr) minmax(420px, 1fr);
    align-items: stretch;
    border-radius: 34px;
    overflow: hidden;
    background:
        radial-gradient(circle at 84% 16%, rgba(16, 185, 129, 0.10), transparent 30%),
        rgba(255, 255, 255, 0.92);
    border: 1px solid rgba(167, 243, 208, 0.8);
    box-shadow: 0 34px 92px rgba(6, 95, 70, 0.14);
}

.reset-hero-panel {
    position: relative;
    min-height: 430px;
    padding: clamp(2rem, 4vw, 3.4rem);
    color: #ffffff;
    background:
        radial-gradient(circle at 12% 14%, rgba(255, 255, 255, 0.17), transparent 30%),
        radial-gradient(circle at 88% 10%, rgba(52, 211, 153, 0.3), transparent 34%),
        linear-gradient(145deg, #064e3b 0%, #047857 100%);
    display: flex;
    flex-direction: column;
    justify-content: center;
    isolation: isolate;
}

.reset-hero-panel::before,
.reset-hero-panel::after {
    content: "";
    position: absolute;
    pointer-events: none;
    z-index: -1;
}

.reset-hero-panel::before {
    inset: 2rem auto auto -5.5rem;
    width: 16rem;
    height: 16rem;
    border-radius: 50%;
    border: 1px dashed rgba(255, 255, 255, 0.24);
}

.reset-hero-panel::after {
    right: -5rem;
    bottom: -5rem;
    width: 18rem;
    height: 18rem;
    border-radius: 42%;
    background: rgba(255, 255, 255, 0.08);
    transform: rotate(18deg);
}

.reset-hero-top {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    margin-bottom: 1.35rem;
}

.reset-hero-icon {
    width: 64px;
    height: 64px;
    border-radius: 22px;
    display: grid;
    place-items: center;
    color: #ffffff;
    background: rgba(255, 255, 255, 0.14);
    border: 1px solid rgba(255, 255, 255, 0.28);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.22);
    font-size: 1.6rem;
}

.reset-hero-top span {
    display: inline-flex;
    padding: 0.45rem 0.85rem;
    border-radius: 999px;
    color: rgba(255, 255, 255, 0.94);
    background: rgba(255, 255, 255, 0.15);
    font-size: 0.78rem;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.reset-hero-panel h1 {
    max-width: 12ch;
    margin: 0 0 1rem;
    color: #ffffff;
    font-size: clamp(2.4rem, 4vw, 4rem);
    font-weight: 900;
    line-height: 1.02;
    letter-spacing: 0;
}

.reset-hero-panel p {
    max-width: 34rem;
    margin: 0 0 1.7rem;
    color: rgba(236, 253, 245, 0.86);
    font-size: 1.06rem;
    line-height: 1.65;
}

.reset-security-list {
    display: grid;
    gap: 0.7rem;
    max-width: 34rem;
}

.reset-security-list span {
    display: flex;
    align-items: center;
    gap: 0.7rem;
    min-height: 44px;
    padding: 0.6rem 0.85rem;
    border-radius: 999px;
    color: rgba(255, 255, 255, 0.94);
    background: rgba(255, 255, 255, 0.13);
    font-weight: 800;
    line-height: 1.25;
}

.reset-security-list i {
    color: #bbf7d0;
    font-size: 1.05rem;
}

.reset-form-card {
    padding: clamp(2rem, 4.4vw, 3.8rem);
    display: flex;
    flex-direction: column;
    justify-content: center;
    background:
        radial-gradient(circle at 92% 0%, rgba(209, 250, 229, 0.45), transparent 32%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.94), rgba(248, 255, 253, 0.94));
}

.reset-form-header {
    margin-bottom: 1.7rem;
}

.reset-form-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.43rem 0.78rem;
    margin-bottom: 0.85rem;
    border-radius: 999px;
    color: var(--primary-800);
    background: rgba(209, 250, 229, 0.72);
    border: 1px solid rgba(16, 185, 129, 0.2);
    font-size: 0.76rem;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.reset-form-badge-warning {
    color: #92400e;
    background: rgba(254, 243, 199, 0.9);
    border-color: rgba(245, 158, 11, 0.2);
}

.reset-form-header h2 {
    margin: 0 0 0.45rem;
    color: #0f172a;
    font-size: clamp(2rem, 3vw, 3rem);
    font-weight: 900;
    line-height: 1.05;
    letter-spacing: 0;
}

.reset-form-header p {
    max-width: 34rem;
    margin: 0;
    color: #64748b;
    font-size: 1.04rem;
    line-height: 1.55;
}

.reset-password-form {
    display: grid;
    gap: 1.05rem;
}

.reset-field {
    display: grid;
    gap: 0.5rem;
}

.reset-field .form-label {
    display: flex;
    align-items: center;
    gap: 0.55rem;
    margin: 0;
    color: #334155;
    font-size: 0.93rem;
    font-weight: 900;
}

.reset-field .form-label i {
    color: var(--primary-700);
}

.reset-field .form-control {
    width: 100%;
    min-height: 60px;
    padding: 0.95rem 1.05rem;
    border-radius: 20px;
    border: 1.5px solid rgba(16, 185, 129, 0.18);
    background: rgba(255, 255, 255, 0.96);
    color: #0f172a;
    font-size: 1rem;
    font-weight: 700;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.96), 0 12px 26px rgba(6, 95, 70, 0.05);
    transition: border-color 180ms ease, box-shadow 180ms ease, transform 180ms ease;
}

.reset-field .form-control:focus {
    border-color: rgba(16, 185, 129, 0.78);
    box-shadow: 0 0 0 5px rgba(16, 185, 129, 0.12), 0 16px 34px rgba(6, 95, 70, 0.1);
    transform: translateY(-1px);
}

.reset-password-form .invalid-feedback {
    margin-top: 0.1rem;
    padding: 0.7rem 0.85rem;
    border-radius: 14px;
    color: #991b1b;
    background: rgba(254, 226, 226, 0.72);
    font-weight: 750;
}

.reset-submit-btn {
    min-height: 62px;
    margin-top: 0.55rem;
    border-radius: 20px;
    font-weight: 900;
    letter-spacing: 0.02em;
    box-shadow: 0 20px 42px rgba(6, 95, 70, 0.2);
}

@media (max-width: 991.98px) {
    .reset-page-shell {
        width: min(92vw, 720px);
        grid-template-columns: 1fr;
    }

    .reset-hero-panel {
        min-height: auto;
        padding: 2rem;
    }

    .reset-hero-panel h1 {
        max-width: 14ch;
        font-size: clamp(2rem, 7vw, 3rem);
    }
}

@media (max-width: 575.98px) {
    .reset-page-shell {
        width: min(100%, 348px);
        border-radius: 32px;
    }

    .reset-hero-panel {
        padding: 1.35rem;
    }

    .reset-hero-top {
        gap: 0.7rem;
        margin-bottom: 1rem;
    }

    .reset-hero-icon {
        width: 54px;
        height: 54px;
        border-radius: 18px;
        font-size: 1.35rem;
    }

    .reset-hero-top span {
        font-size: 0.66rem;
        padding: 0.36rem 0.62rem;
    }

    .reset-hero-panel h1 {
        max-width: none;
        margin-bottom: 0.7rem;
        font-size: clamp(1.55rem, 8vw, 2rem);
        line-height: 1.08;
    }

    .reset-hero-panel p {
        margin-bottom: 1rem;
        font-size: 0.88rem;
        line-height: 1.48;
    }

    .reset-security-list {
        gap: 0.48rem;
    }

    .reset-security-list span {
        min-height: 38px;
        padding: 0.48rem 0.64rem;
        font-size: 0.78rem;
    }

    .reset-form-card {
        padding: 1.35rem;
    }

    .reset-form-header {
        margin-bottom: 1.2rem;
    }

    .reset-form-header h2 {
        font-size: clamp(1.55rem, 8vw, 2rem);
    }

    .reset-form-header p {
        font-size: 0.9rem;
        line-height: 1.45;
    }

    .reset-field .form-control {
        min-height: 54px;
        border-radius: 18px;
        font-size: 0.95rem;
    }

    .reset-submit-btn {
        min-height: 56px;
        border-radius: 18px;
        font-size: 0.98rem;
    }
}

/* Distributor portal */
.distributor-auth-section,
.distributor-dashboard-section {
    padding: clamp(2.5rem, 6vw, 5rem) 0;
    background:
        radial-gradient(circle at 10% 10%, rgba(16, 185, 129, 0.13), transparent 28%),
        radial-gradient(circle at 92% 18%, rgba(37, 99, 235, 0.08), transparent 32%),
        linear-gradient(180deg, #f8fffd 0%, #ecfdf5 100%);
}

.distributor-hero-card,
.distributor-dashboard-hero,
.distributor-form-shell,
.distributor-login-shell,
.approval-wait-card,
.tool-card,
.distributor-company-list {
    border: 1px solid rgba(167, 243, 208, 0.76);
    background: rgba(255, 255, 255, 0.88);
    box-shadow: 0 28px 78px rgba(6, 95, 70, 0.12);
    backdrop-filter: blur(16px) saturate(150%);
}

.distributor-hero-card,
.distributor-dashboard-hero {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1.5rem;
    padding: clamp(1.6rem, 4vw, 3rem);
    border-radius: 34px;
    margin-bottom: 1.35rem;
    background:
        radial-gradient(circle at 86% 0%, rgba(52, 211, 153, 0.22), transparent 34%),
        linear-gradient(135deg, rgba(255,255,255,0.94), rgba(236, 253, 245, 0.84));
}

.distributor-dashboard-hero {
    position: relative;
    overflow: hidden;
    isolation: isolate;
}

.distributor-dashboard-hero::before {
    content: "";
    position: absolute;
    inset: auto -6rem -7rem auto;
    width: 24rem;
    height: 24rem;
    border-radius: 50%;
    background:
        radial-gradient(circle, rgba(16, 185, 129, 0.18), transparent 68%);
    z-index: -1;
}

.distributor-identity {
    min-width: 0;
}

.distributor-kicker {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.45rem 0.82rem;
    border-radius: 999px;
    color: var(--primary-800);
    background: rgba(209, 250, 229, 0.72);
    border: 1px solid rgba(16, 185, 129, 0.2);
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-size: 0.76rem;
}

.distributor-hero-card h1,
.distributor-dashboard-hero h1 {
    margin: 0.9rem 0 0.55rem;
    color: #0f172a;
    font-size: clamp(2rem, 4vw, 4rem);
    line-height: 1.03;
    font-weight: 900;
    letter-spacing: 0;
}

.distributor-hero-card p,
.distributor-dashboard-hero p {
    margin: 0;
    max-width: 780px;
    color: #64748b;
    font-size: 1.05rem;
    line-height: 1.65;
}

.distributor-identity-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    margin-top: 1rem;
}

.distributor-identity-meta span {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    align-items: center;
    gap: 0.05rem 0.6rem;
    min-height: 58px;
    padding: 0.72rem 0.95rem;
    border-radius: 20px;
    background:
        linear-gradient(135deg, rgba(255, 255, 255, 0.96), rgba(236, 253, 245, 0.72));
    border: 1px solid rgba(16, 185, 129, 0.16);
    box-shadow: 0 12px 28px rgba(6, 95, 70, 0.07);
}

.distributor-identity-meta i {
    grid-row: span 2;
    width: 36px;
    height: 36px;
    display: grid;
    place-items: center;
    color: #047857;
    border-radius: 14px;
    background: rgba(209, 250, 229, 0.86);
}

.distributor-identity-meta small {
    color: #64748b;
    font-size: 0.7rem;
    font-weight: 900;
    letter-spacing: 0.06em;
    line-height: 1;
    text-transform: uppercase;
}

.distributor-identity-meta strong {
    color: #0f172a;
    font-size: 0.98rem;
    font-weight: 900;
    line-height: 1.2;
}

.distributor-ghost-btn,
.catalog-distributor-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    min-height: 46px;
    padding: 0.75rem 1.1rem;
    border-radius: 999px;
    color: var(--primary-900);
    background: rgba(255, 255, 255, 0.86);
    border: 1px solid rgba(5, 150, 105, 0.18);
    font-weight: 900;
    text-decoration: none;
}

.distributor-form-shell {
    padding: clamp(1.2rem, 3vw, 2rem);
    border-radius: 34px;
}

.distributor-form-section {
    padding: clamp(1rem, 2.4vw, 1.6rem);
    margin-bottom: 1rem;
    border-radius: 26px;
    background:
        radial-gradient(circle at 100% 0%, rgba(167, 243, 208, 0.22), transparent 30%),
        rgba(255, 255, 255, 0.72);
    border: 1px solid rgba(16, 185, 129, 0.12);
}

.section-mini-heading {
    display: flex;
    align-items: center;
    gap: 0.55rem;
    margin-bottom: 1rem;
    color: var(--primary-900);
    font-size: 1.05rem;
    font-weight: 900;
}

.section-mini-heading i {
    width: 38px;
    height: 38px;
    display: grid;
    place-items: center;
    border-radius: 14px;
    background: rgba(209, 250, 229, 0.85);
    color: var(--primary-700);
}

.field-wrap label,
.distributor-form-shell .form-label {
    margin-bottom: 0.45rem;
    color: #334155;
    font-weight: 850;
    font-size: 0.9rem;
}

.field-wrap .form-control,
.field-wrap .form-select,
.distributor-form-shell .form-control,
.distributor-form-shell .form-select,
.tool-card .form-control,
.tool-card .form-select {
    min-height: 52px;
    border-radius: 18px;
    border: 1px solid rgba(16, 185, 129, 0.18);
    background: rgba(255,255,255,0.94);
    box-shadow: 0 10px 24px rgba(6, 95, 70, 0.04);
}

.stockist-grid,
.sales-grid {
    display: grid;
    gap: 0.65rem;
}

.stockist-builder-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 0.8rem;
}

.stockist-builder-head p {
    margin: 0;
    color: #64748b;
    font-size: 0.9rem;
    font-weight: 650;
}

.stockist-add-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.45rem;
    min-height: 44px;
    padding: 0.65rem 1rem;
    border: 1px solid rgba(16, 185, 129, 0.28);
    border-radius: 999px;
    background: linear-gradient(135deg, rgba(236, 253, 245, 0.98), rgba(209, 250, 229, 0.92));
    color: #047857;
    font-weight: 850;
    box-shadow: 0 14px 28px rgba(6, 95, 70, 0.08);
}

.stockist-builder {
    display: grid;
    gap: 0.9rem;
}

.stockist-record {
    padding: 0.9rem;
    border: 1px solid rgba(16, 185, 129, 0.18);
    border-radius: 24px;
    background:
        linear-gradient(135deg, rgba(236, 253, 245, 0.94), rgba(255, 255, 255, 0.98));
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.92),
        0 16px 34px rgba(6, 95, 70, 0.07);
}

.stockist-record-header {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin-bottom: 0.75rem;
}

.stockist-record-badge {
    width: 38px;
    height: 38px;
    display: inline-grid;
    place-items: center;
    flex: 0 0 auto;
    border-radius: 14px;
    background: linear-gradient(135deg, #064e3b, #10b981);
    color: #ffffff;
    font-weight: 900;
    box-shadow: 0 12px 22px rgba(5, 150, 105, 0.22);
}

.stockist-record-header strong,
.stockist-record-header small {
    display: block;
}

.stockist-record-header strong {
    color: #0f172a;
    font-size: 0.98rem;
    font-weight: 900;
}

.stockist-record-header small {
    color: #64748b;
    font-size: 0.82rem;
    font-weight: 650;
}

.stockist-remove-btn {
    width: 40px;
    height: 40px;
    display: inline-grid;
    place-items: center;
    flex: 0 0 auto;
    margin-left: auto;
    border: 1px solid rgba(239, 68, 68, 0.18);
    border-radius: 14px;
    background: rgba(254, 226, 226, 0.75);
    color: #dc2626;
    transition: opacity 180ms ease, transform 180ms ease;
}

.stockist-remove-btn:disabled {
    opacity: 0.38;
    cursor: not-allowed;
}

.stockist-remove-btn:not(:disabled):hover {
    transform: translateY(-1px);
}

.stockist-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.65rem;
}

.document-check-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.75rem;
}

.document-check-grid label,
.tool-check {
    display: flex;
    align-items: flex-start;
    gap: 0.65rem;
    padding: 0.85rem;
    border-radius: 18px;
    background: rgba(236, 253, 245, 0.7);
    border: 1px solid rgba(16, 185, 129, 0.12);
    color: #334155;
    font-weight: 750;
}

.document-check-grid label:last-child:nth-child(odd) {
    grid-column: 1 / -1;
}

.document-final-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.15fr) minmax(0, 0.85fr);
    gap: 0.85rem;
    margin-top: 1rem;
    align-items: stretch;
}

.document-upload-card,
.document-declaration-card {
    display: flex;
    align-items: flex-start;
    gap: 0.85rem;
    min-height: 124px;
    padding: 1rem;
    border-radius: 22px;
    background:
        radial-gradient(circle at 100% 0%, rgba(167, 243, 208, 0.18), transparent 36%),
        rgba(255, 255, 255, 0.8);
    border: 1px solid rgba(16, 185, 129, 0.14);
    box-shadow: 0 14px 34px rgba(6, 95, 70, 0.06);
}

.document-card-icon {
    width: 46px;
    height: 46px;
    flex: 0 0 auto;
    display: grid;
    place-items: center;
    border-radius: 16px;
    color: var(--primary-800);
    background: rgba(209, 250, 229, 0.9);
    font-size: 1.25rem;
}

.document-card-content {
    min-width: 0;
    width: 100%;
}

.document-card-content p {
    margin: 0 0 0.6rem;
    color: #64748b;
    font-size: 0.86rem;
    font-weight: 650;
}

.document-declaration-card {
    align-items: center;
}

.document-declaration-card label {
    display: flex;
    align-items: flex-start;
    gap: 0.7rem;
    margin: 0;
    color: #334155;
    font-weight: 850;
    line-height: 1.35;
}

.document-declaration-card input {
    margin-top: 0.18rem;
    flex: 0 0 auto;
}

.distributor-submit-btn,
.tool-submit {
    width: 100%;
    min-height: 58px;
    border: 0;
    border-radius: 20px;
    color: #ffffff;
    background: linear-gradient(135deg, #10b981, #047857);
    box-shadow: 0 20px 42px rgba(6, 95, 70, 0.2);
    font-weight: 900;
    font-size: 1rem;
}

/* ── Distributor signup hero redesign ── */
.dist-signup-hero {
    align-items: flex-start;
    gap: 1.5rem;
}

.dist-signup-hero-body {
    flex: 1 1 0;
    min-width: 0;
}

.dist-signup-title {
    margin: 0.75rem 0 0.5rem;
    color: #0f172a;
    font-size: clamp(1.45rem, 2.6vw, 2.1rem);
    line-height: 1.18;
    font-weight: 900;
    letter-spacing: -0.02em;
}

.dist-signup-title span {
    color: var(--primary-700);
}

/* Distributor login pill */
.dist-login-pill {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    flex: 0 0 auto;
    padding: 0.85rem 1.1rem;
    border-radius: 22px;
    color: var(--primary-900);
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.98), rgba(236, 253, 245, 0.92));
    border: 1.5px solid rgba(16, 185, 129, 0.28);
    box-shadow: 0 6px 22px rgba(6, 95, 70, 0.1);
    text-decoration: none;
    transition: box-shadow 0.2s ease, transform 0.2s ease;
}

.dist-login-pill:hover {
    box-shadow: 0 12px 32px rgba(6, 95, 70, 0.18);
    transform: translateY(-2px);
    color: var(--primary-800);
    text-decoration: none;
}

.dist-login-pill-icon {
    width: 44px;
    height: 44px;
    flex: 0 0 auto;
    display: grid;
    place-items: center;
    border-radius: 14px;
    background: rgba(209, 250, 229, 0.9);
    color: var(--primary-700);
    font-size: 1.2rem;
}

.dist-login-pill-text {
    display: flex;
    flex-direction: column;
    gap: 0.1rem;
    font-size: 0.78rem;
    color: #64748b;
    font-weight: 700;
    line-height: 1.25;
}

.dist-login-pill-text strong {
    display: block;
    color: #0f172a;
    font-weight: 900;
    font-size: 0.95rem;
}

/* ── Signup accordion sections ── */
.dist-accordion {
    margin-bottom: 0.65rem;
    border-radius: 22px;
    background:
        radial-gradient(circle at 100% 0%, rgba(167, 243, 208, 0.22), transparent 30%),
        rgba(255, 255, 255, 0.72);
    border: 1px solid rgba(16, 185, 129, 0.12);
    overflow: hidden;
    transition: box-shadow 0.22s ease, border-color 0.22s ease;
}

.dist-accordion.is-open {
    border-color: rgba(16, 185, 129, 0.28);
    box-shadow: 0 8px 28px rgba(6, 95, 70, 0.09);
}

.dist-accordion-toggle {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    width: 100%;
    padding: 1rem clamp(1rem, 2.4vw, 1.4rem);
    background: none;
    border: none;
    cursor: pointer;
    text-align: left;
    color: var(--primary-900);
    font-size: 1rem;
    font-weight: 900;
    transition: background 0.15s ease;
}

.dist-accordion-toggle:hover {
    background: rgba(209, 250, 229, 0.25);
}

.dist-accordion.is-open .dist-accordion-toggle {
    background: rgba(209, 250, 229, 0.18);
}

.dist-accordion-icon {
    width: 36px;
    height: 36px;
    flex: 0 0 auto;
    display: grid;
    place-items: center;
    border-radius: 12px;
    background: rgba(209, 250, 229, 0.85);
    color: var(--primary-700);
    font-size: 1rem;
    transition: background 0.2s ease;
}

.dist-accordion.is-open .dist-accordion-icon {
    background: rgba(16, 185, 129, 0.18);
}

.dist-accordion-label {
    flex: 1;
}

.dist-accordion-chevron {
    font-size: 0.88rem;
    color: #94a3b8;
    transition: transform 0.25s ease, color 0.2s ease;
}

.dist-accordion.is-open .dist-accordion-chevron {
    transform: rotate(180deg);
    color: var(--primary-600);
}

.dist-accordion-body {
    display: none;
    padding: 0 clamp(1rem, 2.4vw, 1.4rem) clamp(1rem, 2.4vw, 1.4rem);
}

.dist-accordion.is-open .dist-accordion-body {
    display: block;
}

.distributor-login-shell {
    display: grid;
    grid-template-columns: 0.9fr 1fr;
    border-radius: 34px;
    overflow: hidden;
}

.distributor-login-panel {
    padding: clamp(2rem, 4vw, 3.4rem);
    color: #ffffff;
    background: linear-gradient(145deg, #064e3b, #047857);
}

.distributor-login-panel h1 {
    color: #ffffff;
    margin: 1rem 0;
    font-size: clamp(2rem, 4vw, 3.4rem);
    line-height: 1.04;
}

.distributor-login-panel p {
    color: rgba(236, 253, 245, 0.84);
}

.distributor-login-card {
    padding: clamp(2rem, 4vw, 3.4rem);
    background: rgba(255, 255, 255, 0.94);
}

.distributor-login-card h2 {
    margin-bottom: 1.3rem;
    font-weight: 900;
    font-size: clamp(1.8rem, 3vw, 2.8rem);
}

.dist-login-apply-hint {
    margin: 0.5rem 0 0;
    text-align: center;
    font-size: 0.87rem;
    color: #64748b;
}

.dist-login-apply-hint a {
    color: var(--primary-700);
    font-weight: 800;
    text-decoration: none;
}

.dist-login-apply-hint a:hover {
    text-decoration: underline;
}

/* Brand row — icon + kicker inline */
.dist-login-brand-row {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    margin-bottom: 0.75rem;
}

.dist-login-brand-icon {
    width: 44px;
    height: 44px;
    flex: 0 0 auto;
    display: grid;
    place-items: center;
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.15);
    border: 1.5px solid rgba(255, 255, 255, 0.28);
    color: #ffffff;
    font-size: 1.2rem;
}

/* Card header with subtitle */
.dist-login-card-header {
    border-bottom: 1px solid rgba(16, 185, 129, 0.1);
    padding-bottom: 0.85rem;
    margin-bottom: 0.25rem;
}

.dist-login-card-header h2 {
    margin: 0 0 0.2rem;
    font-size: clamp(1.4rem, 2.5vw, 1.9rem);
    font-weight: 900;
    letter-spacing: -0.02em;
    color: #0f172a;
}

.dist-login-card-header p {
    margin: 0;
    font-size: 0.86rem;
    color: #64748b;
    font-weight: 600;
}

/* Password label row with forgot link */
.dist-pw-label-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 0.45rem;
}

.dist-pw-label-row label {
    margin: 0 !important;
}

.dist-forgot-link {
    font-size: 0.82rem;
    font-weight: 800;
    color: var(--primary-700);
    text-decoration: none;
    transition: color 0.15s ease;
}

.dist-forgot-link:hover {
    color: var(--primary-900);
    text-decoration: underline;
}

.distributor-status {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.45rem;
    padding: 0.72rem 1rem;
    border-radius: 999px;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.distributor-status-panel {
    display: grid;
    justify-items: center;
    gap: 0.55rem;
    flex: 0 0 auto;
    padding: 1rem;
    border-radius: 24px;
    background: rgba(255, 255, 255, 0.58);
    border: 1px solid rgba(255, 255, 255, 0.7);
    box-shadow: 0 16px 34px rgba(6, 95, 70, 0.08);
}

.status-label {
    color: #64748b;
    font-size: 0.68rem;
    font-weight: 950;
    letter-spacing: 0.08em;
    line-height: 1;
    text-transform: uppercase;
}

.status-pending { color: #92400e; background: #fef3c7; }
.status-approved { color: #065f46; background: #d1fae5; }
.status-rejected { color: #991b1b; background: #fee2e2; }

.approval-wait-card {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: clamp(1.2rem, 3vw, 2rem);
    border-radius: 30px;
    margin-bottom: 1.35rem;
}

.approval-wait-card i {
    width: 62px;
    height: 62px;
    display: grid;
    place-items: center;
    border-radius: 22px;
    color: var(--primary-800);
    background: #d1fae5;
    font-size: 1.6rem;
}

.approval-wait-card h2 {
    margin: 0 0 0.25rem;
    font-weight: 900;
}

.approval-wait-card p {
    margin: 0;
    color: #64748b;
}

.approval-preview-strip {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem;
    margin-top: 0.95rem;
}

.approval-preview-strip span {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.5rem 0.72rem;
    border-radius: 999px;
    color: #065f46;
    background: rgba(209, 250, 229, 0.74);
    border: 1px solid rgba(16, 185, 129, 0.18);
    font-size: 0.82rem;
    font-weight: 850;
}

.distributor-profile-details {
    overflow: hidden;
    margin-bottom: 1.35rem;
    border-radius: 30px;
    border: 1px solid rgba(167, 243, 208, 0.76);
    background:
        radial-gradient(circle at 92% 0%, rgba(52, 211, 153, 0.14), transparent 34%),
        rgba(255, 255, 255, 0.9);
    box-shadow: 0 24px 64px rgba(6, 95, 70, 0.1);
}

.distributor-profile-details summary {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 1.1rem 1.25rem;
    cursor: pointer;
    list-style: none;
}

.distributor-profile-details summary::-webkit-details-marker {
    display: none;
}

.distributor-profile-details summary > span {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    align-items: center;
    gap: 0.1rem 0.75rem;
}

.distributor-profile-details summary > span > i {
    grid-row: span 2;
    width: 46px;
    height: 46px;
    display: grid;
    place-items: center;
    border-radius: 16px;
    color: #047857;
    background: rgba(209, 250, 229, 0.86);
}

.distributor-profile-details summary strong {
    color: #0f172a;
    font-size: 1.08rem;
    font-weight: 950;
}

.distributor-profile-details summary small {
    color: #64748b;
    font-weight: 700;
}

.distributor-profile-details summary > i {
    width: 38px;
    height: 38px;
    display: grid;
    place-items: center;
    border-radius: 14px;
    color: #065f46;
    background: rgba(209, 250, 229, 0.8);
    transition: transform 180ms ease;
}

.distributor-profile-details[open] summary > i {
    transform: rotate(180deg);
}

.distributor-profile-body {
    display: grid;
    gap: 1rem;
    padding: 0 1.25rem 1.25rem;
}

.distributor-basic-edit-card {
    padding: 1rem;
    border-radius: 24px;
    background: rgba(255, 255, 255, 0.78);
    border: 1px solid rgba(16, 185, 129, 0.12);
}

.distributor-profile-edit-form {
    display: grid;
    gap: 1.15rem;
}

.distributor-basic-edit-card h2 {
    display: flex;
    align-items: center;
    gap: 0.55rem;
    margin: 0 0 1rem;
    color: #0f172a;
    font-size: 1.15rem;
    font-weight: 950;
}

.dist-profile-section {
    border: 1px solid rgba(5, 150, 105, 0.12);
    border-radius: 20px;
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.86), rgba(236, 253, 245, 0.46));
    padding: 1rem;
}

.dist-profile-section-head {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    margin-bottom: 1rem;
}

.dist-profile-section-head > span {
    width: 42px;
    height: 42px;
    display: grid;
    place-items: center;
    border-radius: 14px;
    background: rgba(16, 185, 129, 0.14);
    color: #047857;
    flex: 0 0 auto;
}

.dist-profile-section-head h3 {
    margin: 0;
    color: var(--text-heading);
    font-size: 1rem;
    font-weight: 900;
}

.dist-profile-section-head p {
    margin: 0.15rem 0 0;
    color: var(--text-secondary);
    font-size: 0.82rem;
    font-weight: 650;
}

.dist-pc-entries {
    display: grid;
    gap: 0.9rem;
}

.dist-pc-entry {
    border: 1px solid rgba(5, 150, 105, 0.12);
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.72);
    padding: 1rem;
}

.distributor-basic-grid,
.distributor-submitted-info {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.85rem;
}

.distributor-basic-grid .wide,
.submitted-info-card.wide {
    grid-column: 1 / -1;
}

.submitted-info-card {
    padding: 0.95rem;
    border-radius: 20px;
    background:
        radial-gradient(circle at 100% 0%, rgba(209, 250, 229, 0.46), transparent 34%),
        rgba(255, 255, 255, 0.82);
    border: 1px solid rgba(16, 185, 129, 0.1);
}

.submitted-info-card span {
    display: block;
    margin-bottom: 0.35rem;
    color: #64748b;
    font-size: 0.72rem;
    font-weight: 950;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.submitted-info-card strong {
    display: block;
    color: #0f172a;
    font-weight: 850;
    line-height: 1.45;
}

.submitted-checks {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.submitted-checks em {
    padding: 0.48rem 0.7rem;
    border-radius: 999px;
    color: #64748b;
    background: rgba(226, 232, 240, 0.78);
    font-style: normal;
    font-weight: 850;
}

.submitted-checks em.is-yes {
    color: #065f46;
    background: rgba(209, 250, 229, 0.86);
}

/* ── Distributor President Welcome Banner ── */
.dist-president-banner {
    border-radius: 30px;
    border: 1px solid rgba(167, 243, 208, 0.76);
    background:
        radial-gradient(circle at 92% 0%, rgba(52, 211, 153, 0.14), transparent 34%),
        rgba(255, 255, 255, 0.9);
    box-shadow: 0 24px 64px rgba(6, 95, 70, 0.1);
    padding: 2rem;
    margin-bottom: 1.35rem;
    position: relative;
    overflow: hidden;
}

.dist-president-banner::before {
    content: '';
    position: absolute;
    top: -50px;
    right: -50px;
    width: 200px;
    height: 200px;
    background: radial-gradient(circle, rgba(16, 185, 129, 0.12) 0%, transparent 70%);
    border-radius: 50%;
}

.dist-president-inner {
    display: flex;
    align-items: center;
    gap: 2rem;
    position: relative;
    z-index: 2;
}

.dist-president-photo-wrap {
    position: relative;
    flex-shrink: 0;
}

.dist-president-photo,
.dist-president-photo-placeholder {
    width: 110px;
    height: 110px;
    border-radius: 50%;
    object-fit: cover;
    border: 4px solid white;
    box-shadow: 0 10px 25px rgba(0, 0, 0, 0.1);
}

.dist-president-photo-placeholder {
    background: linear-gradient(135deg, #10b981, #047857);
    color: white;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2.8rem;
    font-weight: 700;
    font-family: var(--font-display);
}

.dist-president-badge {
    position: absolute;
    bottom: -10px;
    left: 50%;
    transform: translateX(-50%);
    background: linear-gradient(135deg, #fbbf24, #d97706);
    color: white;
    font-size: 0.72rem;
    font-weight: 700;
    padding: 0.25rem 0.7rem;
    border-radius: var(--radius-full);
    white-space: nowrap;
    box-shadow: 0 4px 10px rgba(217, 119, 6, 0.3);
    border: 2px solid white;
    display: flex;
    align-items: center;
    gap: 0.2rem;
}

.dist-president-msg {
    flex: 1;
}

.dist-president-greeting {
    font-size: 1.2rem;
    font-family: var(--font-display);
    color: var(--text-heading);
    font-weight: 600;
    line-height: 1.5;
    margin-bottom: 0.75rem;
    font-style: italic;
}

.dist-president-name {
    font-weight: 700;
    color: #047857;
    margin: 0;
    font-size: 0.92rem;
}

/* ── Hero v2: proprietor inline with name + store image card ── */
.dist-hero-v2 {
    display: flex;
    align-items: stretch;
    justify-content: space-between;
    gap: 1.5rem;
}

.dist-identity-meta-v2 {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    margin-top: 1rem;
}

.dist-meta-proprietor {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    padding: 0.65rem 1rem 0.65rem 0.65rem;
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.85);
    border: 1px solid rgba(16, 185, 129, 0.18);
    box-shadow: 0 6px 20px rgba(6, 95, 70, 0.08);
}

.dist-meta-photo {
    flex-shrink: 0;
}

.dist-meta-photo img,
.dist-meta-photo em {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 56px;
    height: 56px;
    border-radius: 50%;
    object-fit: cover;
    border: 3px solid white;
    box-shadow: 0 6px 16px rgba(6, 95, 70, 0.18);
}

.dist-meta-photo em {
    background: linear-gradient(135deg, #10b981, #047857);
    color: white;
    font-style: normal;
    font-size: 1.3rem;
    font-weight: 800;
    font-family: var(--font-display);
}

.dist-meta-text {
    display: flex;
    flex-direction: column;
    min-width: 0;
}

.dist-meta-text small {
    font-size: 0.68rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: #64748b;
}

.dist-meta-text strong {
    color: #0f172a;
    font-weight: 900;
    font-size: 0.98rem;
    margin-top: 0.1rem;
}

.dist-meta-id {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem 0.85rem;
    padding: 0.65rem 1rem;
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.85);
    border: 1px solid rgba(16, 185, 129, 0.18);
    box-shadow: 0 6px 20px rgba(6, 95, 70, 0.08);
    flex-wrap: wrap;
}

.dist-meta-id i {
    width: 36px;
    height: 36px;
    display: grid;
    place-items: center;
    border-radius: 12px;
    background: rgba(209, 250, 229, 0.86);
    color: #047857;
}

.dist-meta-id small {
    font-size: 0.68rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: #64748b;
    display: block;
}

.dist-meta-id strong {
    color: #0f172a;
    font-weight: 900;
    font-size: 0.98rem;
}

/* Shop image card */
.dist-hero-shop-card {
    position: relative;
    flex-shrink: 0;
    width: 220px;
    border-radius: 24px;
    overflow: hidden;
    border: 3px solid white;
    box-shadow: 0 16px 40px rgba(6, 95, 70, 0.18);
    background: linear-gradient(135deg, #ecfdf5, #d1fae5);
}

.dist-hero-shop-card img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    min-height: 160px;
}

.dist-hero-shop-placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    min-height: 160px;
    color: #047857;
    font-size: 3.2rem;
    background: linear-gradient(135deg, #ecfdf5, #a7f3d0);
}

.dist-hero-shop-tag {
    position: absolute;
    bottom: 0.6rem;
    left: 0.6rem;
    background: rgba(6, 95, 70, 0.86);
    color: white;
    font-size: 0.7rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    padding: 0.32rem 0.65rem;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    backdrop-filter: blur(6px);
}

/* Per-section save bar */
.dist-section-save {
    display: flex;
    justify-content: flex-end;
    margin-top: 1.1rem;
    padding-top: 1rem;
    border-top: 1px dashed rgba(16, 185, 129, 0.25);
}

.dist-section-save-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.7rem 1.4rem;
    border: none;
    border-radius: 999px;
    background: linear-gradient(135deg, #10b981, #047857);
    color: white;
    font-weight: 800;
    font-size: 0.92rem;
    cursor: pointer;
    box-shadow: 0 8px 20px rgba(6, 95, 70, 0.2);
    transition: transform 180ms ease, box-shadow 180ms ease, filter 180ms ease;
}

.dist-section-save-btn:hover {
    transform: translateY(-1px);
    filter: brightness(1.05);
    box-shadow: 0 12px 28px rgba(6, 95, 70, 0.26);
}

.dist-section-save-btn:active {
    transform: translateY(0);
}

/* ── Collapsible Accordion Stack ── */
.dist-accordion-stack {
    display: grid;
    gap: 0.85rem;
    margin-bottom: 1.35rem;
}

/* ── License lifecycle alert (mirror of member dashboard) ── */
.dist-license-alert {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1.1rem 1.3rem;
    border-radius: 22px;
    margin-bottom: 1rem;
    border: 1px solid transparent;
    box-shadow: 0 16px 36px rgba(15, 23, 42, 0.06);
    flex-wrap: wrap;
}

.dist-license-alert .dla-icon {
    width: 52px;
    height: 52px;
    display: grid;
    place-items: center;
    border-radius: 16px;
    font-size: 1.4rem;
    flex-shrink: 0;
}

.dist-license-alert .dla-body {
    flex: 1 1 280px;
    min-width: 0;
}

.dist-license-alert .dla-body strong {
    display: block;
    font-size: 1.05rem;
    font-weight: 950;
    margin-bottom: 0.15rem;
}

.dist-license-alert .dla-body span {
    font-size: 0.9rem;
    font-weight: 650;
    line-height: 1.45;
}

.dist-license-alert .dla-cta {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.7rem 1.3rem;
    border-radius: 999px;
    border: none;
    font-weight: 900;
    font-size: 0.9rem;
    cursor: pointer;
    box-shadow: 0 10px 22px rgba(15, 23, 42, 0.18);
    transition: transform 160ms ease, filter 160ms ease;
}

.dist-license-alert .dla-cta:hover {
    transform: translateY(-1px);
    filter: brightness(1.05);
}

.dist-license-alert-expired {
    background: linear-gradient(135deg, rgba(254, 226, 226, 0.95), rgba(254, 242, 242, 0.7));
    border-color: rgba(220, 38, 38, 0.32);
}
.dist-license-alert-expired .dla-icon {
    background: rgba(220, 38, 38, 0.14);
    color: #b91c1c;
}
.dist-license-alert-expired .dla-body strong { color: #991b1b; }
.dist-license-alert-expired .dla-body span { color: #7f1d1d; }
.dist-license-alert-expired .dla-cta { background: #dc2626; color: white; }

.dist-license-alert-critical {
    background: linear-gradient(135deg, rgba(254, 243, 199, 0.95), rgba(255, 251, 235, 0.7));
    border-color: rgba(217, 119, 6, 0.32);
}
.dist-license-alert-critical .dla-icon {
    background: rgba(217, 119, 6, 0.16);
    color: #b45309;
}
.dist-license-alert-critical .dla-body strong { color: #78350f; }
.dist-license-alert-critical .dla-body span { color: #92400e; }
.dist-license-alert-critical .dla-cta { background: #f59e0b; color: #1e293b; }

.dist-license-alert-warning {
    background: linear-gradient(135deg, rgba(207, 250, 254, 0.85), rgba(236, 254, 255, 0.6));
    border-color: rgba(14, 165, 233, 0.32);
}
.dist-license-alert-warning .dla-icon {
    background: rgba(14, 165, 233, 0.14);
    color: #0369a1;
}
.dist-license-alert-warning .dla-body strong { color: #0c4a6e; }
.dist-license-alert-warning .dla-body span { color: #075985; }
.dist-license-alert-warning .dla-cta-soft {
    background: white;
    color: #0369a1;
    border: 1px solid rgba(14, 165, 233, 0.45);
    box-shadow: 0 6px 14px rgba(14, 165, 233, 0.18);
}

.distributor-license-panel {
    margin-bottom: 1rem;
    padding: 1.2rem;
    border: 1px solid rgba(167, 243, 208, 0.76);
    border-radius: 24px;
    background:
        radial-gradient(circle at 94% 0%, rgba(52, 211, 153, 0.12), transparent 34%),
        rgba(255, 255, 255, 0.92);
    box-shadow: 0 14px 38px rgba(6, 95, 70, 0.08);
}

.distributor-license-panel .license-overview-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

/* ── Active / Inactive toggle card for the distributor account ── */
.dist-active-toggle-card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.95rem 1.2rem;
    margin-bottom: 1rem;
    border-radius: 22px;
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.96), rgba(236, 253, 245, 0.6));
    border: 1px solid rgba(167, 243, 208, 0.76);
    box-shadow: 0 14px 34px rgba(6, 95, 70, 0.08);
    flex-wrap: wrap;
}

.dist-active-toggle-card .datc-status {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    min-width: 0;
}

.dist-active-toggle-card .datc-dot {
    width: 14px;
    height: 14px;
    border-radius: 50%;
    flex-shrink: 0;
    box-shadow: 0 0 0 4px rgba(0, 0, 0, 0.04);
}

.dist-active-toggle-card .dot-on {
    background: radial-gradient(circle, #10b981 30%, #047857 90%);
    box-shadow: 0 0 0 4px rgba(16, 185, 129, 0.18), 0 0 12px rgba(16, 185, 129, 0.45);
    animation: distDotPulse 2.4s ease-in-out infinite;
}

.dist-active-toggle-card .dot-off {
    background: radial-gradient(circle, #94a3b8 30%, #475569 90%);
    box-shadow: 0 0 0 4px rgba(148, 163, 184, 0.18);
}

@keyframes distDotPulse {
    0%, 100% { box-shadow: 0 0 0 4px rgba(16, 185, 129, 0.18), 0 0 12px rgba(16, 185, 129, 0.45); }
    50% { box-shadow: 0 0 0 7px rgba(16, 185, 129, 0.08), 0 0 18px rgba(16, 185, 129, 0.65); }
}

.dist-active-toggle-card strong {
    display: block;
    font-weight: 900;
    color: #0f172a;
    font-size: 1rem;
}

.dist-active-toggle-card small {
    color: #64748b;
    font-weight: 650;
    font-size: 0.82rem;
    line-height: 1.4;
}

.dist-active-toggle-card .datc-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.7rem 1.3rem;
    border-radius: 999px;
    border: none;
    font-weight: 850;
    font-size: 0.88rem;
    cursor: pointer;
    transition: transform 160ms ease, filter 160ms ease, box-shadow 160ms ease;
}

.dist-active-toggle-card .datc-btn-deactivate {
    background: white;
    color: #b91c1c;
    border: 1px solid rgba(220, 38, 38, 0.32);
    box-shadow: 0 6px 14px rgba(220, 38, 38, 0.1);
}

.dist-active-toggle-card .datc-btn-deactivate:hover {
    background: rgba(254, 226, 226, 0.78);
    border-color: rgba(220, 38, 38, 0.55);
    transform: translateY(-1px);
}

.dist-active-toggle-card .datc-btn-activate {
    background: linear-gradient(135deg, #10b981, #047857);
    color: white;
    box-shadow: 0 10px 22px rgba(6, 95, 70, 0.22);
}

.dist-active-toggle-card .datc-btn-activate:hover {
    transform: translateY(-1px);
    filter: brightness(1.05);
    box-shadow: 0 14px 30px rgba(6, 95, 70, 0.28);
}

@media (max-width: 575.98px) {
    .dist-license-alert,
    .dist-active-toggle-card {
        flex-direction: column;
        align-items: stretch;
    }
    .dist-license-alert .dla-cta,
    .dist-active-toggle-card .datc-btn {
        justify-content: center;
    }

    /* ── Distributor dashboard hero — proprietor pill mobile fix ── */
    .dist-identity-meta-v2 {
        gap: 0.55rem;
        margin-top: 0.85rem;
    }
    .dist-meta-proprietor,
    .dist-meta-id {
        width: 100%;
        padding: 0.6rem 0.85rem 0.6rem 0.6rem;
        border-radius: 16px;
    }
    .dist-meta-photo img,
    .dist-meta-photo em {
        width: 46px !important;
        height: 46px !important;
    }
    .dist-meta-photo em {
        font-size: 1.05rem !important;
    }
    .dist-meta-text strong {
        font-size: 0.95rem;
        line-height: 1.25;
        overflow-wrap: anywhere;
        word-spacing: normal;
        max-width: 100%;
    }
    .dist-meta-text small {
        font-size: 0.64rem;
    }
    .dist-meta-id {
        padding: 0.55rem 0.85rem;
    }
    .dist-meta-id i {
        width: 32px;
        height: 32px;
        border-radius: 10px;
    }

    /* ── License Details collapsed header — mobile ── */
    .license-dashboard-header {
        grid-template-columns: auto minmax(0, 1fr) auto;
        gap: 0.6rem;
        padding: 0.85rem 0.95rem;
    }
    .license-dashboard-header .license-status-chip {
        grid-column: 1 / -1;
        grid-row: 2;
        justify-self: start;
        margin-top: 0.2rem;
    }
    .license-dashboard-chevron {
        grid-row: 1;
        width: 32px;
        height: 32px;
        border-radius: 10px;
        font-size: 0.85rem;
    }
    .license-dashboard-icon {
        width: 38px;
        height: 38px;
        border-radius: 12px;
    }
    .license-dashboard-header h5 {
        font-size: 1rem;
    }
    .license-dashboard-header small {
        font-size: 0.7rem;
    }
    .license-dashboard-body {
        padding: 0 0.85rem 0.85rem;
    }
}

/* "Update your profile" master toggle */
.update-profile-trigger {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    align-items: center;
    gap: 1rem;
    width: 100%;
    padding: 1.15rem 1.4rem;
    margin-bottom: 1.1rem;
    border: 1px solid rgba(167, 243, 208, 0.76);
    border-radius: 24px;
    background:
        radial-gradient(circle at 92% 0%, rgba(52, 211, 153, 0.18), transparent 38%),
        linear-gradient(135deg, rgba(255, 255, 255, 0.96), rgba(236, 253, 245, 0.78));
    box-shadow: 0 18px 44px rgba(6, 95, 70, 0.1);
    cursor: pointer;
    text-align: left;
    transition: transform 200ms ease, box-shadow 200ms ease, border-color 200ms ease, background 200ms ease;
}

.update-profile-trigger:hover {
    transform: translateY(-1px);
    border-color: rgba(16, 185, 129, 0.45);
    box-shadow: 0 22px 52px rgba(6, 95, 70, 0.16);
}

.update-profile-trigger.is-active {
    border-color: rgba(16, 185, 129, 0.55);
    background:
        radial-gradient(circle at 92% 0%, rgba(52, 211, 153, 0.28), transparent 38%),
        linear-gradient(135deg, rgba(236, 253, 245, 0.96), rgba(209, 250, 229, 0.7));
    box-shadow: 0 24px 60px rgba(6, 95, 70, 0.2);
}

.upt-icon {
    width: 56px;
    height: 56px;
    display: grid;
    place-items: center;
    border-radius: 18px;
    background: linear-gradient(135deg, #10b981, #047857);
    color: white;
    font-size: 1.4rem;
    box-shadow: 0 10px 24px rgba(6, 95, 70, 0.28);
    flex-shrink: 0;
}

.upt-body {
    display: grid;
    gap: 0.2rem;
    min-width: 0;
}

.upt-title {
    color: #0f172a;
    font-weight: 950;
    font-size: 1.12rem;
    letter-spacing: -0.005em;
}

.upt-sub {
    color: #475569;
    font-weight: 650;
    font-size: 0.86rem;
    line-height: 1.4;
}

.upt-chev {
    width: 42px;
    height: 42px;
    display: grid;
    place-items: center;
    border-radius: 14px;
    background: rgba(209, 250, 229, 0.82);
    color: #047857;
    font-size: 1rem;
    transition: transform 240ms cubic-bezier(0.2, 0.8, 0.2, 1), background 200ms ease;
    flex-shrink: 0;
}

.update-profile-trigger.is-active .upt-chev {
    transform: rotate(180deg);
    background: rgba(16, 185, 129, 0.25);
}

/* Collapsed state — keep the section in the DOM but invisible & non-interactive */
.update-profile-wrap {
    overflow: hidden;
    transition: max-height 380ms cubic-bezier(0.2, 0.8, 0.2, 1), opacity 280ms ease, margin 320ms ease;
    max-height: 9000px;
    opacity: 1;
}

.update-profile-wrap.is-collapsed {
    max-height: 0;
    opacity: 0;
    margin-bottom: 0 !important;
    pointer-events: none;
}

@media (max-width: 575.98px) {
    .update-profile-trigger {
        padding: 0.95rem 1rem;
        gap: 0.7rem;
        border-radius: 20px;
    }
    .upt-icon {
        width: 46px;
        height: 46px;
        border-radius: 14px;
        font-size: 1.15rem;
    }
    .upt-title {
        font-size: 1rem;
    }
    .upt-sub {
        font-size: 0.78rem;
    }
    .upt-chev {
        width: 36px;
        height: 36px;
        border-radius: 12px;
    }
}

.dist-collapse-card {
    border-radius: 24px;
    border: 1px solid rgba(167, 243, 208, 0.76);
    background:
        radial-gradient(circle at 92% 0%, rgba(52, 211, 153, 0.08), transparent 34%),
        rgba(255, 255, 255, 0.92);
    box-shadow: 0 8px 32px rgba(6, 95, 70, 0.06);
    overflow: hidden;
    transition: box-shadow 250ms ease, border-color 250ms ease;
}

.dist-collapse-card:hover {
    border-color: rgba(16, 185, 129, 0.35);
    box-shadow: 0 12px 42px rgba(6, 95, 70, 0.1);
}

.dist-collapse-card.is-open {
    border-color: rgba(16, 185, 129, 0.5);
    box-shadow: 0 16px 52px rgba(6, 95, 70, 0.12);
}

.dist-collapse-toggle {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    width: 100%;
    padding: 1.1rem 1.25rem;
    border: none;
    background: none;
    cursor: pointer;
    text-align: left;
    color: inherit;
}

.dist-collapse-toggle:hover {
    background: rgba(236, 253, 245, 0.5);
}

.dist-collapse-icon {
    width: 46px;
    height: 46px;
    display: grid;
    place-items: center;
    border-radius: 16px;
    color: #047857;
    background: rgba(209, 250, 229, 0.86);
    flex-shrink: 0;
    font-size: 1.15rem;
    transition: background 200ms ease, color 200ms ease;
}

.dist-collapse-card.is-open .dist-collapse-icon {
    background: linear-gradient(135deg, #10b981, #059669);
    color: white;
}

.dist-collapse-label {
    flex: 1;
    min-width: 0;
}

.dist-collapse-label strong {
    display: block;
    color: #0f172a;
    font-size: 1.02rem;
    font-weight: 900;
}

.dist-collapse-label small {
    display: block;
    color: #64748b;
    font-weight: 650;
    font-size: 0.8rem;
    margin-top: 0.1rem;
}

.dist-collapse-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem;
    flex-shrink: 0;
}

.dist-collapse-meta em {
    font-style: normal;
    font-size: 0.75rem;
    font-weight: 750;
    padding: 0.3rem 0.65rem;
    border-radius: 999px;
    background: rgba(209, 250, 229, 0.7);
    color: #065f46;
    white-space: nowrap;
    max-width: 160px;
    overflow: hidden;
    text-overflow: ellipsis;
}

.dist-collapse-chevron {
    width: 36px;
    height: 36px;
    display: grid;
    place-items: center;
    border-radius: 12px;
    color: #065f46;
    background: rgba(209, 250, 229, 0.6);
    flex-shrink: 0;
    transition: transform 250ms ease, background 250ms ease;
}

.dist-collapse-card.is-open .dist-collapse-chevron {
    transform: rotate(180deg);
    background: rgba(16, 185, 129, 0.2);
}

.dist-collapse-body {
    max-height: 0;
    overflow: hidden;
    transition: max-height 350ms ease;
    padding: 0 1.25rem;
}

.dist-collapse-card.is-open .dist-collapse-body {
    padding: 0 1.25rem 1.25rem;
}

/* ── Pharmacist photo cards ── */
.dist-pharmacist-cards {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    margin-bottom: 1rem;
}

.dist-pharmacist-card {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.65rem 1rem;
    border-radius: 18px;
    background: linear-gradient(135deg, rgba(236, 253, 245, 0.9), rgba(209, 250, 229, 0.5));
    border: 1px solid rgba(16, 185, 129, 0.15);
}

.dist-pharmacist-card img {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    object-fit: cover;
    border: 2px solid white;
    box-shadow: 0 4px 12px rgba(6, 95, 70, 0.12);
}

.dist-pharmacist-card strong {
    display: block;
    font-size: 0.88rem;
    font-weight: 800;
    color: #0f172a;
}

.dist-pharmacist-card small {
    display: block;
    font-size: 0.74rem;
    font-weight: 650;
    color: #64748b;
    margin-top: 0.1rem;
}

/* ── Mobile Responsive ── */
@media (max-width: 991.98px) {
    .dist-collapse-meta {
        display: none;
    }
    .dist-hero-v2 {
        flex-direction: column;
        align-items: stretch;
    }
    .dist-hero-shop-card {
        width: 100%;
        max-height: 200px;
    }
    .dist-hero-shop-card img,
    .dist-hero-shop-placeholder {
        max-height: 200px;
    }
}

@media (max-width: 767.98px) {
    .dist-president-inner {
        flex-direction: column;
        text-align: center;
        gap: 1.2rem;
    }
    .dist-president-greeting {
        font-size: 1.05rem;
    }
    .dist-president-photo,
    .dist-president-photo-placeholder {
        width: 90px;
        height: 90px;
    }
    .dist-identity-meta-v2 {
        flex-direction: column;
        gap: 0.55rem;
    }
    .dist-meta-proprietor,
    .dist-meta-id {
        width: 100%;
    }
    .dist-section-save-btn {
        width: 100%;
        justify-content: center;
    }
}

@media (max-width: 575.98px) {
    .dist-president-banner {
        padding: 1.25rem;
        border-radius: 22px;
    }
    .dist-collapse-card {
        border-radius: 20px;
    }
    .dist-collapse-toggle {
        padding: 0.85rem 1rem;
        gap: 0.65rem;
    }
    .dist-collapse-icon {
        width: 40px;
        height: 40px;
        border-radius: 13px;
        font-size: 1rem;
    }
    .dist-collapse-label strong {
        font-size: 0.92rem;
    }
    .dist-collapse-label small {
        font-size: 0.72rem;
        line-height: 1.3;
    }
    .dist-collapse-chevron {
        width: 32px;
        height: 32px;
        border-radius: 10px;
    }
    .dist-collapse-body {
        padding: 0 0.85rem;
    }
    .dist-collapse-card.is-open .dist-collapse-body {
        padding: 0 0.85rem 0.85rem;
    }
    .dist-meta-photo img,
    .dist-meta-photo em {
        width: 48px;
        height: 48px;
    }
    .dist-meta-photo em {
        font-size: 1.1rem;
    }
    .dist-pharmacist-cards {
        flex-direction: column;
    }
}

/* ════════════════════════════════════════════════
   Premium glass-blur modal backdrop (all modals)
   ════════════════════════════════════════════════ */
.modal-backdrop {
    background:
        radial-gradient(circle at 18% 12%, rgba(16, 185, 129, 0.32), transparent 42%),
        radial-gradient(circle at 84% 88%, rgba(5, 150, 105, 0.32), transparent 46%),
        linear-gradient(135deg, rgba(6, 78, 59, 0.62), rgba(6, 95, 70, 0.7));
    -webkit-backdrop-filter: blur(14px) saturate(140%);
    backdrop-filter: blur(14px) saturate(140%);
    opacity: 0;
    transition: opacity 280ms ease, backdrop-filter 280ms ease;
}

.modal-backdrop.show {
    opacity: 1;
}

/* Soft floating sheen for any modal sitting on the blurred backdrop */
.modal-content {
    box-shadow:
        0 28px 80px rgba(6, 78, 59, 0.32),
        0 6px 22px rgba(6, 78, 59, 0.18),
        inset 0 1px 0 rgba(255, 255, 255, 0.5);
}

.modal.fade .modal-dialog {
    transform: translate3d(0, 12px, 0) scale(0.985);
    transition: transform 320ms cubic-bezier(0.2, 0.8, 0.2, 1), opacity 240ms ease;
}

.modal.show .modal-dialog {
    transform: translate3d(0, 0, 0) scale(1);
}

@media (prefers-reduced-motion: reduce) {
    .modal-backdrop,
    .modal.fade .modal-dialog {
        transition: none;
    }
}

/* ════════════════════════════════════════════════
   LOA Application — Distributor Dashboard + Admin
   ════════════════════════════════════════════════ */

/* Apply LOA hero card */
.loa-hero-card {
    position: relative;
    overflow: hidden;
    border-radius: 32px;
    padding: clamp(1.6rem, 3.5vw, 2.6rem);
    margin-bottom: 1.5rem;
    background:
        radial-gradient(circle at 0% 0%, rgba(255, 255, 255, 0.18), transparent 40%),
        radial-gradient(circle at 100% 100%, rgba(255, 255, 255, 0.12), transparent 45%),
        linear-gradient(135deg, #047857 0%, #10b981 60%, #34d399 100%);
    color: white;
    box-shadow: 0 28px 60px rgba(6, 95, 70, 0.28);
    isolation: isolate;
}

.loa-hero-bg {
    position: absolute;
    inset: auto -4rem -6rem auto;
    width: 18rem;
    height: 18rem;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(255, 255, 255, 0.18), transparent 70%);
    z-index: -1;
}

.loa-hero-content {
    position: relative;
    z-index: 2;
    max-width: 720px;
}

.loa-hero-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.45rem 0.9rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.22);
    border: 1px solid rgba(255, 255, 255, 0.35);
    color: white;
    font-weight: 800;
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    backdrop-filter: blur(8px);
}

.loa-hero-card h2 {
    color: white;
    font-weight: 900;
    margin: 0.9rem 0 0.6rem;
    font-size: clamp(1.4rem, 2.6vw, 2rem);
    line-height: 1.15;
    letter-spacing: -0.01em;
}

.loa-hero-card p {
    color: rgba(255, 255, 255, 0.92);
    font-weight: 600;
    margin: 0 0 1.4rem;
    font-size: 0.98rem;
    line-height: 1.55;
}

.loa-hero-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.6rem;
    padding: 0.9rem 1.6rem;
    border: none;
    border-radius: 999px;
    background: white;
    color: #047857;
    font-weight: 900;
    font-size: 1rem;
    cursor: pointer;
    box-shadow: 0 14px 32px rgba(0, 0, 0, 0.18);
    transition: transform 200ms ease, box-shadow 200ms ease, filter 200ms ease;
}

.loa-hero-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 20px 42px rgba(0, 0, 0, 0.25);
    filter: brightness(1.04);
}

.loa-hero-btn i {
    font-size: 1.1rem;
}

/* LOA applications list */
.loa-list-card {
    border-radius: 28px;
    border: 1px solid rgba(167, 243, 208, 0.76);
    background:
        radial-gradient(circle at 100% 0%, rgba(52, 211, 153, 0.12), transparent 34%),
        rgba(255, 255, 255, 0.92);
    box-shadow: 0 22px 56px rgba(6, 95, 70, 0.1);
    padding: 1.3rem;
    margin-bottom: 1.5rem;
}

.loa-list-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.85rem;
    margin-bottom: 1rem;
    padding-bottom: 0.85rem;
    border-bottom: 1px dashed rgba(16, 185, 129, 0.25);
}

.loa-list-count {
    font-size: 0.78rem;
    font-weight: 850;
    padding: 0.35rem 0.7rem;
    border-radius: 999px;
    color: #065f46;
    background: rgba(209, 250, 229, 0.86);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.loa-list-body {
    display: grid;
    gap: 0.85rem;
}

.loa-app-card {
    border-radius: 22px;
    padding: 0;
    overflow: hidden;
    border: 1px solid rgba(16, 185, 129, 0.18);
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.92), rgba(236, 253, 245, 0.6));
    transition: transform 180ms ease, box-shadow 180ms ease;
}

.loa-app-card:hover {
    transform: translateY(-1px);
    box-shadow: 0 14px 38px rgba(6, 95, 70, 0.1);
}

.loa-app-card.loa-status-approved {
    border-color: rgba(16, 185, 129, 0.4);
    background: linear-gradient(135deg, rgba(236, 253, 245, 0.9), rgba(209, 250, 229, 0.55));
}

.loa-app-card.loa-status-pending {
    border-color: rgba(245, 158, 11, 0.34);
    background: linear-gradient(135deg, rgba(255, 251, 235, 0.96), rgba(254, 243, 199, 0.56));
}

.loa-app-card.loa-status-rejected {
    border-color: rgba(220, 38, 38, 0.28);
    background: linear-gradient(135deg, rgba(254, 242, 242, 0.9), rgba(255, 255, 255, 0.7));
}

.loa-app-head {
    width: 100%;
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    min-height: 78px;
    padding: 1rem 1.1rem;
    border: 0;
    color: inherit;
    background: transparent;
    text-align: left;
    cursor: pointer;
    transition: background 180ms ease;
}

.loa-app-head:hover {
    background: rgba(255, 255, 255, 0.42);
}

.loa-app-head:not(.collapsed) {
    background: rgba(255, 255, 255, 0.52);
}

.loa-app-title {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    min-width: 0;
}

.loa-app-icon {
    width: 46px;
    height: 46px;
    display: grid;
    place-items: center;
    border-radius: 14px;
    background: rgba(209, 250, 229, 0.86);
    color: #047857;
    font-size: 1.2rem;
    flex-shrink: 0;
}

.loa-status-approved .loa-app-icon {
    background: linear-gradient(135deg, #10b981, #047857);
    color: white;
}

.loa-status-rejected .loa-app-icon {
    background: rgba(254, 226, 226, 0.86);
    color: #b91c1c;
}

.loa-status-pending .loa-app-icon {
    background: rgba(254, 243, 199, 0.92);
    color: #b45309;
}

.loa-app-title h4 {
    margin: 0;
    color: #0f172a;
    font-size: 1.05rem;
    font-weight: 900;
}

.loa-app-title small {
    color: #64748b;
    font-weight: 650;
    font-size: 0.8rem;
}

.loa-app-status {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.45rem 0.85rem;
    border-radius: 999px;
    font-size: 0.78rem;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    white-space: nowrap;
    flex-shrink: 0;
}

.loa-app-chevron {
    width: 34px;
    height: 34px;
    display: grid;
    place-items: center;
    flex: 0 0 auto;
    border-radius: 999px;
    color: #047857;
    background: rgba(255, 255, 255, 0.68);
    border: 1px solid rgba(16, 185, 129, 0.16);
    transition: transform 180ms ease, color 180ms ease, background 180ms ease;
}

.loa-app-head:not(.collapsed) .loa-app-chevron {
    transform: rotate(180deg);
    color: #065f46;
    background: rgba(209, 250, 229, 0.88);
}

.loa-status-rejected .loa-app-chevron {
    color: #b91c1c;
    border-color: rgba(220, 38, 38, 0.18);
}

.loa-status-pending .loa-app-chevron {
    color: #b45309;
    border-color: rgba(217, 119, 6, 0.18);
}

.loa-status-pending .loa-app-status {
    color: #92400e;
    background: rgba(254, 243, 199, 0.86);
    border: 1px solid rgba(217, 119, 6, 0.3);
}

.loa-status-approved .loa-app-status {
    color: #065f46;
    background: rgba(209, 250, 229, 0.86);
    border: 1px solid rgba(16, 185, 129, 0.35);
}

.loa-status-rejected .loa-app-status {
    color: #b91c1c;
    background: rgba(254, 226, 226, 0.86);
    border: 1px solid rgba(220, 38, 38, 0.3);
}

.loa-app-details {
    padding: 0 1.1rem 1.1rem;
}

.loa-app-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem 1rem;
    margin-bottom: 0.65rem;
    font-size: 0.82rem;
    color: #64748b;
    font-weight: 700;
}

.loa-app-meta i {
    margin-right: 0.35rem;
    color: #047857;
}

.loa-app-meta a {
    color: #047857;
    font-weight: 800;
    text-decoration: none;
}

.loa-app-meta a:hover {
    text-decoration: underline;
}

.loa-app-notes {
    padding: 0.7rem 0.9rem;
    border-radius: 14px;
    background: rgba(255, 251, 235, 0.86);
    border: 1px dashed rgba(217, 119, 6, 0.32);
    font-size: 0.86rem;
    color: #78350f;
    margin-top: 0.55rem;
}

.loa-status-rejected .loa-app-notes {
    background: rgba(254, 242, 242, 0.86);
    border-color: rgba(220, 38, 38, 0.3);
    color: #991b1b;
}

.loa-app-notes strong {
    display: block;
    margin-bottom: 0.2rem;
    font-weight: 900;
    text-transform: uppercase;
    font-size: 0.72rem;
    letter-spacing: 0.06em;
}

.loa-app-foot {
    margin-top: 0.7rem;
    padding: 0.7rem 0.9rem;
    border-radius: 14px;
    background: rgba(209, 250, 229, 0.65);
    color: #065f46;
    font-weight: 700;
    font-size: 0.88rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.loa-app-foot i {
    color: #047857;
    font-size: 1.1rem;
}

/* Re-apply CTA on rejected LOA cards */
.loa-app-cta {
    margin-top: 0.85rem;
    padding: 0.95rem 1rem;
    border-radius: 16px;
    background: linear-gradient(135deg, rgba(255, 247, 237, 0.95), rgba(254, 226, 226, 0.4));
    border: 1px dashed rgba(220, 38, 38, 0.32);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    flex-wrap: wrap;
}

.loa-app-cta p {
    margin: 0;
    color: #7c2d12;
    font-size: 0.88rem;
    font-weight: 700;
    line-height: 1.45;
    display: flex;
    align-items: center;
    gap: 0.45rem;
}

.loa-app-cta p i {
    color: #b91c1c;
    font-size: 1rem;
}

.loa-reapply-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.65rem 1.3rem;
    border: none;
    border-radius: 999px;
    background: linear-gradient(135deg, #10b981, #047857);
    color: white;
    font-weight: 900;
    font-size: 0.88rem;
    cursor: pointer;
    box-shadow: 0 10px 22px rgba(6, 95, 70, 0.22);
    transition: transform 180ms ease, filter 180ms ease, box-shadow 180ms ease;
    white-space: nowrap;
}

.loa-reapply-btn:hover {
    transform: translateY(-1px);
    filter: brightness(1.06);
    box-shadow: 0 14px 30px rgba(6, 95, 70, 0.28);
}

.loa-reapply-banner {
    padding: 0.85rem 1rem;
    border-radius: 14px;
    background: linear-gradient(135deg, rgba(209, 250, 229, 0.85), rgba(167, 243, 208, 0.6));
    border: 1px solid rgba(16, 185, 129, 0.32);
    color: #065f46;
    font-size: 0.9rem;
    font-weight: 700;
    line-height: 1.5;
    display: flex;
    align-items: center;
    gap: 0.55rem;
}

.loa-reapply-banner i {
    font-size: 1.15rem;
    color: #047857;
    flex-shrink: 0;
}

.loa-reapply-banner strong {
    font-weight: 900;
    margin-right: 0.2rem;
}

/* Make the admin-rejection notes more prominent and easier to read on the distributor dashboard */
.loa-app-card.loa-status-rejected .loa-app-notes {
    background: rgba(254, 226, 226, 0.92);
    border: 1px solid rgba(220, 38, 38, 0.32);
    box-shadow: inset 0 0 0 3px rgba(254, 242, 242, 0.6);
    padding: 0.85rem 1rem;
    border-radius: 14px;
}

.loa-app-card.loa-status-rejected .loa-app-notes strong {
    color: #991b1b;
    font-size: 0.74rem;
    letter-spacing: 0.06em;
}

.loa-app-card.loa-status-rejected .loa-app-notes span {
    color: #7f1d1d;
    font-weight: 700;
    line-height: 1.5;
    display: block;
}

@media (max-width: 575.98px) {
    .loa-app-cta {
        flex-direction: column;
        align-items: stretch;
    }
    .loa-reapply-btn {
        justify-content: center;
    }
}

/* LOA Modal */
.loa-modal {
    border-radius: 30px;
    border: none;
    overflow: hidden;
    background: linear-gradient(180deg, #f8fffd 0%, #ecfdf5 100%);
}

.loa-modal-hero {
    position: relative;
    display: flex;
    align-items: flex-start;
    gap: 1rem;
    padding: 1.4rem 1.6rem;
    background:
        radial-gradient(circle at 100% 0%, rgba(52, 211, 153, 0.28), transparent 40%),
        linear-gradient(135deg, #047857, #10b981);
    color: white;
}

.loa-modal-icon {
    width: 56px;
    height: 56px;
    display: grid;
    place-items: center;
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.22);
    border: 1px solid rgba(255, 255, 255, 0.35);
    font-size: 1.5rem;
    flex-shrink: 0;
    backdrop-filter: blur(8px);
}

.loa-modal-hero .distributor-kicker {
    background: rgba(255, 255, 255, 0.22);
    border-color: rgba(255, 255, 255, 0.35);
    color: white;
}

.loa-modal-hero h2 {
    color: white;
    margin: 0.4rem 0 0.25rem;
    font-size: 1.4rem;
    font-weight: 900;
}

.loa-modal-hero p {
    color: rgba(255, 255, 255, 0.92);
    font-size: 0.9rem;
    margin: 0;
    font-weight: 600;
}

.loa-modal-close {
    background: rgba(255, 255, 255, 0.22);
    border: 1px solid rgba(255, 255, 255, 0.35);
    color: white;
    width: 38px;
    height: 38px;
    display: grid;
    place-items: center;
    border-radius: 12px;
    cursor: pointer;
    transition: background 200ms ease;
    margin-left: auto;
    flex-shrink: 0;
}

.loa-modal-close:hover {
    background: rgba(255, 255, 255, 0.35);
}

.loa-modal-body {
    padding: 1.4rem 1.6rem;
    display: grid;
    gap: 1.2rem;
    overflow-y: auto;
    flex: 1 1 auto;
    min-height: 0;
}

.loa-modal {
    display: flex;
    flex-direction: column;
    max-height: calc(100vh - 2rem);
}

.loa-form-section {
    border-radius: 22px;
    border: 1px solid rgba(16, 185, 129, 0.18);
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.94), rgba(236, 253, 245, 0.5));
    padding: 1.2rem;
}

.loa-form-section h3 {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    margin: 0 0 1rem;
    color: #0f172a;
    font-size: 1rem;
    font-weight: 900;
}

.loa-form-section h3 span {
    width: 38px;
    height: 38px;
    display: grid;
    place-items: center;
    border-radius: 12px;
    background: rgba(209, 250, 229, 0.86);
    color: #047857;
}

.loa-modal-footer {
    display: flex;
    justify-content: flex-end;
    gap: 0.75rem;
    padding: 1.2rem 1.6rem;
    border-top: 1px solid rgba(16, 185, 129, 0.18);
    background: rgba(255, 255, 255, 0.6);
}

.loa-cancel-btn {
    padding: 0.75rem 1.4rem;
    border: 1px solid rgba(100, 116, 139, 0.3);
    background: white;
    color: #475569;
    border-radius: 999px;
    font-weight: 800;
    cursor: pointer;
    transition: background 180ms ease;
}

.loa-cancel-btn:hover {
    background: #f1f5f9;
}

.loa-submit-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.75rem 1.6rem;
    border: none;
    border-radius: 999px;
    background: linear-gradient(135deg, #10b981, #047857);
    color: white;
    font-weight: 900;
    font-size: 0.95rem;
    cursor: pointer;
    box-shadow: 0 10px 24px rgba(6, 95, 70, 0.25);
    transition: transform 180ms ease, box-shadow 180ms ease, filter 180ms ease;
}

.loa-submit-btn:hover {
    transform: translateY(-1px);
    filter: brightness(1.04);
    box-shadow: 0 14px 32px rgba(6, 95, 70, 0.32);
}

/* Admin LOA review tab */
.admin-loa-queue .pending-summary-icon {
    background: linear-gradient(135deg, #10b981, #047857);
    color: white;
}

.admin-loa-list {
    display: grid;
    gap: 1rem;
}

.admin-loa-card {
    border-radius: 22px;
    padding: 1.2rem;
    border: 1px solid rgba(16, 185, 129, 0.2);
    background:
        radial-gradient(circle at 100% 0%, rgba(52, 211, 153, 0.1), transparent 40%),
        rgba(255, 255, 255, 0.95);
    box-shadow: 0 12px 32px rgba(6, 95, 70, 0.08);
}

.admin-loa-card-head {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 1rem;
    align-items: start;
    margin-bottom: 1rem;
    padding-bottom: 1rem;
    border-bottom: 1px dashed rgba(16, 185, 129, 0.25);
}

.admin-loa-company {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    min-width: 0;
}

.admin-loa-icon {
    width: 50px;
    height: 50px;
    display: grid;
    place-items: center;
    border-radius: 16px;
    background: linear-gradient(135deg, #10b981, #047857);
    color: white;
    font-size: 1.3rem;
    flex-shrink: 0;
}

.admin-loa-company h5 {
    margin: 0;
    color: #0f172a;
    font-weight: 900;
    font-size: 1.1rem;
}

.admin-loa-company small {
    color: #64748b;
    font-weight: 650;
}

.admin-loa-distributor {
    text-align: right;
    display: grid;
    gap: 0.15rem;
    font-size: 0.85rem;
    color: #475569;
}

.admin-loa-distributor small {
    text-transform: uppercase;
    font-size: 0.68rem;
    font-weight: 850;
    letter-spacing: 0.06em;
    color: #94a3b8;
}

.admin-loa-distributor strong {
    color: #0f172a;
    font-weight: 900;
    font-size: 0.96rem;
}

.admin-loa-details {
    margin-bottom: 1rem;
    border-radius: 18px;
    background: rgba(248, 252, 250, 0.7);
    border: 1px solid rgba(16, 185, 129, 0.12);
    overflow: hidden;
}

.admin-loa-details summary {
    cursor: pointer;
    padding: 0.7rem 1rem;
    list-style: none;
    font-weight: 800;
    color: #047857;
    display: flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 0.88rem;
}

.admin-loa-details summary::-webkit-details-marker {
    display: none;
}

.admin-loa-details summary i {
    transition: transform 200ms ease;
}

.admin-loa-details[open] summary i {
    transform: rotate(180deg);
}

.admin-loa-details-body {
    padding: 0.5rem 1rem 1rem;
    border-top: 1px dashed rgba(16, 185, 129, 0.2);
}

.admin-loa-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.75rem;
    margin-bottom: 0.85rem;
}

.admin-loa-grid > div {
    padding: 0.7rem 0.85rem;
    background: white;
    border-radius: 14px;
    border: 1px solid rgba(16, 185, 129, 0.1);
}

.admin-loa-grid span {
    display: block;
    color: #94a3b8;
    font-weight: 800;
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin-bottom: 0.2rem;
}

.admin-loa-grid strong {
    color: #0f172a;
    font-weight: 800;
    font-size: 0.88rem;
    line-height: 1.4;
}

.admin-loa-list-block {
    background: white;
    border-radius: 14px;
    padding: 0.8rem 1rem;
    border: 1px solid rgba(16, 185, 129, 0.1);
    margin-bottom: 0.75rem;
}

.admin-loa-list-block > span {
    display: block;
    color: #94a3b8;
    font-weight: 800;
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin-bottom: 0.5rem;
}

.admin-loa-list-block ul {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    gap: 0.3rem;
}

.admin-loa-list-block li {
    font-size: 0.86rem;
    color: #334155;
}

.admin-loa-list-block strong {
    color: #0f172a;
    font-weight: 800;
}

.admin-loa-checks {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
    margin: 0.75rem 0;
}

.admin-loa-checks em {
    font-style: normal;
    padding: 0.4rem 0.7rem;
    border-radius: 999px;
    font-size: 0.78rem;
    font-weight: 800;
    color: #64748b;
    background: rgba(226, 232, 240, 0.7);
}

.admin-loa-checks em.is-yes {
    color: #065f46;
    background: rgba(209, 250, 229, 0.86);
}

.admin-loa-doc-link a {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.5rem 0.9rem;
    border-radius: 999px;
    background: rgba(209, 250, 229, 0.7);
    color: #047857;
    font-weight: 800;
    font-size: 0.85rem;
    text-decoration: none;
    border: 1px solid rgba(16, 185, 129, 0.2);
}

.admin-loa-doc-link a:hover {
    background: rgba(167, 243, 208, 0.8);
}

.admin-loa-admin-note {
    margin: 0;
    color: #64748b;
    font-size: 0.82rem;
    font-weight: 650;
    line-height: 1.4;
}

.admin-loa-history {
    margin-top: 1rem;
    border-top: 1px dashed rgba(16, 185, 129, 0.25);
    padding-top: 1rem;
}

.admin-loa-history summary {
    cursor: pointer;
    color: #475569;
    font-weight: 800;
    font-size: 0.88rem;
    list-style: none;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.admin-loa-history summary::-webkit-details-marker {
    display: none;
}

.admin-loa-history-body {
    margin-top: 0.85rem;
    display: grid;
    gap: 0.55rem;
}

.admin-loa-history-row {
    display: grid;
    grid-template-columns: auto 1fr auto;
    gap: 0.65rem;
    align-items: center;
    padding: 0.6rem 0.9rem;
    border-radius: 14px;
    background: rgba(248, 252, 250, 0.7);
    border: 1px solid rgba(16, 185, 129, 0.12);
    font-size: 0.85rem;
}

.admin-loa-history-row.admin-loa-history-rejected {
    background: rgba(254, 242, 242, 0.6);
    border-color: rgba(220, 38, 38, 0.18);
}

.admin-loa-history-status {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    font-weight: 900;
    font-size: 0.75rem;
    text-transform: uppercase;
}

.admin-loa-history-approved .admin-loa-history-status {
    color: #047857;
}

.admin-loa-history-rejected .admin-loa-history-status {
    color: #b91c1c;
}

.admin-loa-history-main strong {
    display: block;
    color: #0f172a;
    font-weight: 900;
}

.admin-loa-history-main small {
    color: #64748b;
    font-weight: 700;
    font-size: 0.78rem;
}

.admin-loa-history-meta {
    color: #94a3b8;
    font-weight: 700;
    font-size: 0.78rem;
}

.admin-loa-history-notes {
    grid-column: 1 / -1;
    color: #64748b;
    font-size: 0.82rem;
    padding-top: 0.4rem;
    border-top: 1px dashed rgba(148, 163, 184, 0.3);
    margin-top: 0.3rem;
}

/* LOA Mobile responsive */
@media (max-width: 991.98px) {
    .admin-loa-card-head {
        grid-template-columns: 1fr;
    }
    .admin-loa-distributor {
        text-align: left;
    }
    .admin-loa-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 767.98px) {
    .loa-hero-card {
        padding: 1.3rem;
        border-radius: 24px;
    }
    .loa-hero-btn {
        width: 100%;
        justify-content: center;
    }
    .loa-app-head {
        flex-direction: column;
    }
    .loa-app-status {
        align-self: flex-start;
    }
    .loa-modal-hero {
        flex-wrap: wrap;
        padding: 1.1rem;
    }
    .loa-modal-body {
        padding: 1rem;
    }
    .loa-modal-footer {
        flex-direction: column-reverse;
        padding: 1rem;
    }
    .loa-cancel-btn,
    .loa-submit-btn {
        width: 100%;
        justify-content: center;
    }
    .admin-loa-history-row {
        grid-template-columns: 1fr;
    }
    .admin-loa-history-meta {
        font-size: 0.74rem;
    }
}

@media (max-width: 575.98px) {
    .loa-list-card {
        padding: 1rem;
        border-radius: 22px;
    }
    .loa-app-card {
        border-radius: 18px;
        padding: 0.9rem;
    }

    /* ── LOA modal — mobile redesign ── */
    .loa-modal {
        border-radius: 22px;
    }
    .loa-modal-hero {
        padding: 0.95rem 1rem;
        gap: 0.65rem;
        flex-wrap: nowrap;
    }
    .loa-modal-icon {
        width: 42px;
        height: 42px;
        border-radius: 12px;
        font-size: 1.15rem;
    }
    .loa-modal-hero .distributor-kicker {
        font-size: 0.62rem;
        padding: 0.28rem 0.6rem;
        letter-spacing: 0.06em;
    }
    .loa-modal-hero h2 {
        font-size: 1.05rem;
        line-height: 1.18;
        margin: 0.35rem 0 0.15rem;
    }
    .loa-modal-hero p {
        font-size: 0.74rem;
        line-height: 1.4;
    }
    .loa-modal-close {
        width: 32px;
        height: 32px;
        border-radius: 10px;
        font-size: 0.85rem;
    }
    .loa-modal-body {
        padding: 0.9rem;
        gap: 0.85rem;
    }
    .loa-form-section {
        padding: 0.85rem;
        border-radius: 16px;
    }
    .loa-form-section h3 {
        font-size: 0.88rem;
        gap: 0.5rem;
        margin: 0 0 0.7rem;
    }
    .loa-form-section h3 span {
        width: 30px;
        height: 30px;
        border-radius: 10px;
        font-size: 0.8rem;
    }
    .loa-form-section .form-control,
    .loa-form-section .form-select,
    .loa-form-section textarea {
        font-size: 0.85rem !important;
        padding: 0.55rem 0.7rem !important;
        border-radius: 10px !important;
    }
    .loa-form-section textarea {
        min-height: 64px !important;
    }
    .loa-form-section .form-label {
        font-size: 0.74rem !important;
        font-weight: 800 !important;
        margin-bottom: 0.28rem !important;
        color: #334155 !important;
    }
    .loa-form-section .row.g-3,
    .loa-form-section .row {
        --bs-gutter-y: 0.55rem !important;
        --bs-gutter-x: 0.55rem !important;
    }
    .loa-form-section .col-md-4,
    .loa-form-section .col-md-6,
    .loa-form-section .col-md-8,
    .loa-form-section .col-md-3 {
        width: 100% !important;
        flex: 0 0 100% !important;
        max-width: 100% !important;
    }
    .stockist-builder-head {
        flex-direction: column !important;
        align-items: stretch !important;
        gap: 0.5rem !important;
    }
    .stockist-add-btn {
        align-self: flex-start;
        font-size: 0.78rem !important;
        padding: 0.5rem 0.85rem !important;
    }
    .stockist-record {
        padding: 0.7rem !important;
        border-radius: 14px !important;
    }
    .stockist-row {
        grid-template-columns: 1fr !important;
        gap: 0.45rem !important;
    }
    .stockist-row input,
    .sales-grid .stockist-row input {
        font-size: 0.85rem !important;
        padding: 0.5rem 0.7rem !important;
    }
    .stockist-record-header {
        gap: 0.5rem !important;
    }
    .stockist-record-header strong {
        font-size: 0.85rem !important;
    }
    .stockist-record-header small {
        font-size: 0.7rem !important;
    }
    .document-check-grid {
        grid-template-columns: 1fr !important;
        gap: 0.45rem !important;
    }
    .document-check-grid label {
        font-size: 0.82rem !important;
        padding: 0.5rem 0.65rem !important;
    }
    .document-final-grid {
        grid-template-columns: 1fr !important;
        gap: 0.65rem !important;
    }
    .document-upload-card,
    .document-declaration-card {
        padding: 0.85rem !important;
        border-radius: 14px !important;
    }
    .loa-modal-footer {
        flex-direction: column-reverse !important;
        gap: 0.5rem !important;
        padding: 0.85rem;
    }
    .loa-cancel-btn,
    .loa-submit-btn {
        width: 100% !important;
        justify-content: center;
        font-size: 0.92rem !important;
        padding: 0.7rem 1.1rem !important;
    }
}

.distributor-metrics {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
    margin-bottom: 1rem;
}

.distributor-metrics div {
    padding: 1.25rem;
    border-radius: 24px;
    background: linear-gradient(135deg, #064e3b, #10b981);
    color: #ffffff;
    box-shadow: 0 20px 42px rgba(6, 95, 70, 0.16);
}

.distributor-metrics strong {
    display: block;
    font-size: 2.1rem;
    line-height: 1;
}

.distributor-tools-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
    margin-bottom: 1rem;
}

.csv-tool-card {
    grid-column: 1 / -1;
}

.csv-option-card {
    grid-column: 1 / -1;
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    align-items: center;
    gap: 1rem;
    width: 100%;
    text-align: left;
    border: 1px solid rgba(16, 185, 129, 0.16);
    background:
        radial-gradient(circle at 92% 0%, rgba(16, 185, 129, 0.14), transparent 34%),
        rgba(255, 255, 255, 0.9);
    color: #0f172a;
}

.csv-option-card:hover {
    border-color: rgba(16, 185, 129, 0.35);
    box-shadow: 0 24px 58px rgba(6, 95, 70, 0.14);
    transform: translateY(-1px);
}

.csv-option-icon,
.csv-modal-icon {
    width: 58px;
    height: 58px;
    display: grid;
    place-items: center;
    border-radius: 20px;
    color: #065f46;
    background: rgba(209, 250, 229, 0.9);
    font-size: 1.55rem;
    flex: 0 0 auto;
}

.csv-option-content strong {
    display: block;
    margin-bottom: 0.25rem;
    color: #0f172a;
    font-size: 1.15rem;
    font-weight: 950;
}

.csv-option-content small {
    display: block;
    max-width: 720px;
    color: #64748b;
    font-size: 0.93rem;
    font-weight: 700;
    line-height: 1.45;
}

.csv-option-action {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.72rem 0.95rem;
    border-radius: 999px;
    color: #ffffff;
    background: linear-gradient(135deg, #10b981, #047857);
    font-weight: 900;
    white-space: nowrap;
}

.csv-import-modal {
    overflow: hidden;
    border: 1px solid rgba(167, 243, 208, 0.78);
    border-radius: 32px;
    background:
        radial-gradient(circle at 90% 0%, rgba(52, 211, 153, 0.18), transparent 36%),
        rgba(255, 255, 255, 0.97);
    box-shadow: 0 34px 96px rgba(2, 44, 34, 0.25);
}

.csv-modal-hero {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1.45rem 1.55rem;
    color: #ffffff;
    background:
        radial-gradient(circle at 94% 0%, rgba(110, 231, 183, 0.28), transparent 34%),
        linear-gradient(135deg, #064e3b, #10b981);
}

.csv-modal-hero .distributor-kicker {
    margin-bottom: 0.55rem;
    color: #ecfdf5;
    background: rgba(255, 255, 255, 0.14);
    border-color: rgba(255, 255, 255, 0.2);
}

.csv-modal-hero h2 {
    margin: 0 0 0.35rem;
    color: #ffffff;
    font-size: clamp(1.7rem, 4vw, 2.4rem);
    font-weight: 950;
    line-height: 1.06;
}

.csv-modal-hero p {
    margin: 0;
    color: rgba(236, 253, 245, 0.84);
    line-height: 1.5;
}

.csv-modal-body {
    padding: 1.35rem 1.55rem;
    display: grid;
    gap: 1rem;
}

.csv-upload-zone {
    padding: 1rem;
    border-radius: 24px;
    background: rgba(236, 253, 245, 0.72);
    border: 1px dashed rgba(16, 185, 129, 0.34);
}

.csv-upload-zone span {
    display: block;
    margin-top: 0.45rem;
    color: #64748b;
    font-size: 0.85rem;
    font-weight: 700;
}

.csv-column-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.85rem;
}

.csv-clear-check {
    margin: 0;
}

.csv-modal-footer {
    display: grid;
    grid-template-columns: 0.45fr 1fr;
    gap: 0.8rem;
    padding: 0 1.55rem 1.55rem;
}

.csv-cancel-btn {
    min-height: 54px;
    border-radius: 18px;
    border: 1px solid rgba(5, 150, 105, 0.18);
    color: #065f46;
    background: rgba(255, 255, 255, 0.86);
    font-weight: 900;
}

.csv-import-submit {
    min-height: 54px;
}

.tool-card {
    padding: 1.25rem;
    border-radius: 28px;
}

.tool-card h2 {
    display: flex;
    align-items: center;
    gap: 0.55rem;
    margin-bottom: 1rem;
    font-size: 1.2rem;
    font-weight: 900;
}

.tool-note {
    color: #64748b;
    font-weight: 650;
}

.distributor-company-list {
    padding: 1.25rem;
    border-radius: 28px;
}

.catalog-preview-heading {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    flex-wrap: wrap;
    margin-bottom: 0.7rem;
}

.catalog-preview-heading .section-mini-heading {
    margin-bottom: 0;
}

.catalog-lock-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.55rem 0.82rem;
    border-radius: 999px;
    color: #92400e;
    background: rgba(254, 243, 199, 0.88);
    border: 1px solid rgba(245, 158, 11, 0.18);
    font-size: 0.82rem;
    font-weight: 950;
}

.distributor-company-list.is-readonly-catalog {
    background:
        radial-gradient(circle at 92% 0%, rgba(251, 191, 36, 0.12), transparent 30%),
        radial-gradient(circle at 8% 100%, rgba(16, 185, 129, 0.12), transparent 34%),
        rgba(255, 255, 255, 0.9);
}

.distributor-company-accordion {
    margin-top: 0.85rem;
    border-radius: 24px;
    overflow: hidden;
    background: rgba(255, 255, 255, 0.78);
    border: 1px solid rgba(16, 185, 129, 0.16);
    box-shadow: 0 14px 34px rgba(6, 95, 70, 0.06);
    transition: background 260ms ease, box-shadow 260ms ease, border-color 260ms ease;
}

.distributor-company-accordion[open] {
    background:
        radial-gradient(circle at 100% 0%, rgba(167, 243, 208, 0.18), transparent 34%),
        rgba(255, 255, 255, 0.92);
}

.distributor-company-accordion.is-closing {
    background:
        radial-gradient(circle at 100% 0%, rgba(167, 243, 208, 0.18), transparent 34%),
        rgba(255, 255, 255, 0.92);
}

.distributor-company-accordion.is-company-inactive:not([open]) {
    border-color: rgba(168, 85, 247, 0.36);
    box-shadow: 0 12px 30px rgba(88, 28, 135, 0.08);
}

.distributor-company-accordion.is-company-inactive:not([open]) .distributor-company-row {
    background:
        radial-gradient(circle at 92% 0%, rgba(221, 214, 254, 0.34), transparent 34%),
        linear-gradient(135deg, #581c87, #7c3aed);
}

.distributor-company-accordion summary {
    list-style: none;
}

.distributor-company-accordion summary::-webkit-details-marker {
    display: none;
}

.distributor-company-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 1rem 1.1rem;
    border-radius: 0;
    color: #ffffff;
    background:
        radial-gradient(circle at 92% 0%, rgba(110, 231, 183, 0.3), transparent 34%),
        linear-gradient(135deg, #065f46, #10b981);
    border: 0;
    margin-top: 0;
    cursor: pointer;
    user-select: none;
    transition: background 280ms ease, color 240ms ease, border-color 240ms ease;
}

.distributor-company-accordion[open] .distributor-company-row {
    color: #0f172a;
    background:
        radial-gradient(circle at 96% 0%, rgba(209, 250, 229, 0.65), transparent 34%),
        rgba(255, 255, 255, 0.94);
    border-bottom: 1px solid rgba(16, 185, 129, 0.12);
}

.distributor-company-accordion.is-closing .distributor-company-row {
    color: #0f172a;
    background:
        radial-gradient(circle at 96% 0%, rgba(209, 250, 229, 0.65), transparent 34%),
        rgba(255, 255, 255, 0.94);
    border-bottom: 1px solid rgba(16, 185, 129, 0.12);
}

.company-summary-main,
.company-summary-meta {
    display: flex;
    align-items: center;
    gap: 0.85rem;
}

.company-summary-main {
    min-width: 0;
}

.company-summary-icon {
    width: 44px;
    height: 44px;
    flex: 0 0 auto;
    display: grid;
    place-items: center;
    border-radius: 16px;
    color: #065f46;
    background: rgba(255, 255, 255, 0.86);
    font-weight: 950;
}

.company-summary-meta {
    flex: 0 0 auto;
    font-weight: 900;
}

.company-status-form {
    margin: 0;
}

.company-active-toggle {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.48rem 0.72rem;
    border-radius: 999px;
    color: #065f46;
    background: rgba(255, 255, 255, 0.86);
    border: 1px solid rgba(255, 255, 255, 0.32);
    font-size: 0.82rem;
    font-weight: 950;
    cursor: pointer;
}

.company-active-toggle input {
    width: 1rem;
    height: 1rem;
    margin: 0;
    accent-color: #059669;
}

.distributor-company-accordion[open] .company-active-toggle,
.distributor-company-accordion.is-closing .company-active-toggle {
    color: #065f46;
    background: rgba(209, 250, 229, 0.84);
    border-color: rgba(16, 185, 129, 0.18);
}

.company-summary-meta i {
    width: 34px;
    height: 34px;
    display: grid;
    place-items: center;
    border-radius: 12px;
    background: rgba(255, 255, 255, 0.16);
    transition: transform 200ms ease, background 200ms ease;
}

.distributor-company-accordion[open] .company-summary-meta i {
    color: #065f46;
    background: rgba(209, 250, 229, 0.82);
    transform: rotate(180deg);
}

.distributor-company-accordion.is-closing .company-summary-meta i {
    color: #065f46;
    background: rgba(209, 250, 229, 0.82);
    transform: rotate(180deg);
}

.distributor-company-row h3 {
    margin: 0;
    font-size: 1.05rem;
    font-weight: 900;
    color: inherit;
}

.distributor-company-row p {
    margin: 0.25rem 0 0;
    color: rgba(255, 255, 255, 0.76);
    transition: color 240ms ease;
}

.distributor-company-accordion[open] .distributor-company-row p {
    color: #64748b;
}

.distributor-company-accordion.is-closing .distributor-company-row p {
    color: #64748b;
}

/* ── Per-company inline add-product + CSV import bar ── */
.company-action-bar {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 0.65rem;
    padding: 0.85rem 0.85rem 0;
    align-items: stretch;
}

.company-add-product {
    display: grid;
    grid-template-columns: auto minmax(0, 1.6fr) minmax(0, 1fr) minmax(0, 1fr) auto;
    gap: 0.5rem;
    align-items: center;
    padding: 0.55rem 0.7rem;
    border-radius: 16px;
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.94), rgba(236, 253, 245, 0.65));
    border: 1px solid rgba(16, 185, 129, 0.2);
    box-shadow: 0 8px 22px rgba(6, 95, 70, 0.06);
}

.company-add-icon {
    width: 36px;
    height: 36px;
    display: grid;
    place-items: center;
    border-radius: 12px;
    background: linear-gradient(135deg, #10b981, #047857);
    color: white;
    font-size: 1.05rem;
    flex-shrink: 0;
}

.company-add-product .form-control {
    border: 1px solid rgba(16, 185, 129, 0.18);
    background: white;
    border-radius: 12px;
    padding: 0.55rem 0.75rem;
    font-size: 0.9rem;
    font-weight: 650;
    color: #0f172a;
    min-width: 0;
}

.company-add-product .form-control:focus {
    border-color: #10b981;
    box-shadow: 0 0 0 3px rgba(16, 185, 129, 0.18);
    outline: none;
}

.company-add-submit {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.6rem 1.1rem;
    border: none;
    border-radius: 12px;
    background: linear-gradient(135deg, #10b981, #047857);
    color: white;
    font-weight: 850;
    font-size: 0.9rem;
    cursor: pointer;
    box-shadow: 0 6px 16px rgba(6, 95, 70, 0.18);
    transition: transform 160ms ease, filter 160ms ease, box-shadow 160ms ease;
    white-space: nowrap;
}

.company-add-submit:hover {
    transform: translateY(-1px);
    filter: brightness(1.05);
    box-shadow: 0 10px 24px rgba(6, 95, 70, 0.24);
}

.company-csv-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.65rem 1.1rem;
    border: 1px dashed rgba(16, 185, 129, 0.4);
    border-radius: 16px;
    background: rgba(255, 255, 255, 0.78);
    color: #047857;
    font-weight: 850;
    font-size: 0.88rem;
    cursor: pointer;
    transition: background 160ms ease, border-color 160ms ease, transform 160ms ease;
}

.company-csv-btn:hover {
    background: rgba(209, 250, 229, 0.7);
    border-color: rgba(16, 185, 129, 0.6);
    border-style: solid;
    transform: translateY(-1px);
}

/* Inline flash / toast bar after the add-product form */
.inline-flash {
    margin: 0.55rem 0.85rem 0;
    padding: 0.6rem 0.9rem;
    border-radius: 14px;
    font-size: 0.88rem;
    font-weight: 800;
    display: flex;
    align-items: center;
    gap: 0.5rem;
    opacity: 0;
    transform: translateY(-4px);
    transition: opacity 240ms ease, transform 240ms ease;
    pointer-events: none;
}

.inline-flash.is-visible {
    opacity: 1;
    transform: translateY(0);
}

.inline-flash-success {
    color: #065f46;
    background: rgba(209, 250, 229, 0.78);
    border: 1px solid rgba(16, 185, 129, 0.28);
}

.inline-flash-error {
    color: #991b1b;
    background: rgba(254, 226, 226, 0.78);
    border: 1px solid rgba(220, 38, 38, 0.28);
}

/* Highlight pulse for newly added product row */
.product-edit-row.product-just-added {
    animation: productJustAdded 1100ms ease-out;
}

@keyframes productJustAdded {
    0% {
        background: rgba(167, 243, 208, 0.6);
        box-shadow: 0 0 0 3px rgba(16, 185, 129, 0.35);
        transform: translateY(-4px);
        opacity: 0.4;
    }
    40% {
        background: rgba(209, 250, 229, 0.5);
        transform: translateY(0);
        opacity: 1;
    }
    100% {
        background: transparent;
        box-shadow: none;
    }
}

.company-csv-btn i {
    font-size: 1.05rem;
}

/* Per-company CSV modal */
.company-csv-modal {
    border-radius: 28px;
    border: none;
    overflow: hidden;
    background: linear-gradient(180deg, #f8fffd 0%, #ecfdf5 100%);
}

.company-csv-hero {
    display: flex;
    align-items: flex-start;
    gap: 1rem;
    padding: 1.3rem 1.5rem;
    background:
        radial-gradient(circle at 100% 0%, rgba(52, 211, 153, 0.28), transparent 40%),
        linear-gradient(135deg, #047857, #10b981);
    color: white;
}

.company-csv-icon {
    width: 52px;
    height: 52px;
    display: grid;
    place-items: center;
    border-radius: 16px;
    background: rgba(255, 255, 255, 0.22);
    border: 1px solid rgba(255, 255, 255, 0.35);
    color: white;
    font-size: 1.5rem;
    flex-shrink: 0;
}

.company-csv-hero .distributor-kicker {
    background: rgba(255, 255, 255, 0.22);
    border-color: rgba(255, 255, 255, 0.35);
    color: white;
}

.company-csv-hero h2 {
    color: white;
    margin: 0.4rem 0 0.25rem;
    font-size: 1.25rem;
    font-weight: 900;
}

.company-csv-hero p {
    color: rgba(255, 255, 255, 0.92);
    font-size: 0.88rem;
    margin: 0;
    font-weight: 600;
}

.company-csv-close {
    background: rgba(255, 255, 255, 0.22);
    border: 1px solid rgba(255, 255, 255, 0.35);
    color: white;
    width: 36px;
    height: 36px;
    display: grid;
    place-items: center;
    border-radius: 12px;
    cursor: pointer;
    margin-left: auto;
    flex-shrink: 0;
}

.company-csv-close:hover {
    background: rgba(255, 255, 255, 0.35);
}

.company-csv-body {
    padding: 1.3rem 1.5rem;
    display: grid;
    gap: 1rem;
}

.company-csv-upload .form-control {
    padding: 0.7rem;
}

.company-csv-columns {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.75rem;
}

.company-csv-clear {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    padding: 0.75rem 1rem;
    border-radius: 14px;
    background: rgba(255, 251, 235, 0.6);
    border: 1px dashed rgba(217, 119, 6, 0.32);
    font-size: 0.88rem;
    color: #78350f;
    font-weight: 700;
    cursor: pointer;
}

.company-csv-clear .form-check-input {
    margin: 0;
}

.company-csv-footer {
    display: flex;
    justify-content: flex-end;
    gap: 0.75rem;
    padding: 1.1rem 1.5rem;
    border-top: 1px solid rgba(16, 185, 129, 0.18);
    background: rgba(255, 255, 255, 0.6);
}

.company-csv-cancel {
    padding: 0.7rem 1.3rem;
    border: 1px solid rgba(100, 116, 139, 0.3);
    background: white;
    color: #475569;
    border-radius: 999px;
    font-weight: 800;
    cursor: pointer;
}

.company-csv-cancel:hover {
    background: #f1f5f9;
}

.company-csv-submit {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.7rem 1.5rem;
    border: none;
    border-radius: 999px;
    background: linear-gradient(135deg, #10b981, #047857);
    color: white;
    font-weight: 900;
    font-size: 0.92rem;
    cursor: pointer;
    box-shadow: 0 10px 24px rgba(6, 95, 70, 0.25);
    transition: transform 180ms ease, filter 180ms ease, box-shadow 180ms ease;
}

.company-csv-submit:hover {
    transform: translateY(-1px);
    filter: brightness(1.05);
    box-shadow: 0 14px 32px rgba(6, 95, 70, 0.32);
}

/* Mobile responsive */
@media (max-width: 991.98px) {
    .company-action-bar {
        grid-template-columns: 1fr;
    }
    .company-add-product {
        grid-template-columns: auto minmax(0, 1fr) auto;
        row-gap: 0.5rem;
    }
    .company-add-product .form-control:nth-of-type(2),
    .company-add-product .form-control:nth-of-type(3) {
        grid-column: 1 / -1;
    }
    .company-csv-btn {
        justify-content: center;
    }
}

@media (max-width: 575.98px) {
    .company-add-product {
        grid-template-columns: 1fr;
        padding: 0.7rem;
    }
    .company-add-icon {
        display: none;
    }
    .company-add-submit {
        width: 100%;
        justify-content: center;
    }
    .company-csv-columns {
        grid-template-columns: 1fr;
    }
    .company-csv-footer {
        flex-direction: column-reverse;
    }
    .company-csv-cancel,
    .company-csv-submit {
        width: 100%;
        justify-content: center;
    }
}

.distributor-product-editor {
    display: grid;
    gap: 0.6rem;
    margin: 0;
    padding: 0.85rem;
    background:
        linear-gradient(180deg, rgba(255,255,255,0.94), rgba(236, 253, 245, 0.55));
    overflow: hidden;
    opacity: 0;
    transform: translateY(-8px);
    transition: opacity 260ms ease, transform 260ms ease;
    will-change: max-height, opacity, transform;
}

.distributor-company-accordion[open] .distributor-product-editor {
    opacity: 1;
    transform: translateY(0);
}

.product-edit-row {
    display: grid;
    grid-template-columns: auto 1.4fr 0.75fr 1fr auto;
    gap: 0.55rem;
    align-items: center;
    padding: 0.65rem;
    border-radius: 18px;
    background: rgba(236, 253, 245, 0.62);
    border: 1px solid rgba(16, 185, 129, 0.1);
    opacity: 0;
    transform: translateY(8px);
    transition: opacity 280ms ease, transform 280ms ease, background 200ms ease, border-color 200ms ease, box-shadow 200ms ease;
}

.product-edit-row.is-selected {
    background: rgba(209, 250, 229, 0.85);
    border-color: rgba(16, 185, 129, 0.45);
    box-shadow: 0 4px 14px rgba(6, 95, 70, 0.1);
}

.product-edit-row.product-just-updated {
    animation: productJustUpdated 1100ms ease-out;
}

@keyframes productJustUpdated {
    0% {
        background: rgba(167, 243, 208, 0.85);
        box-shadow: 0 0 0 3px rgba(16, 185, 129, 0.35);
    }
    100% {
        background: rgba(236, 253, 245, 0.62);
        box-shadow: none;
    }
}

.product-edit-row.product-being-deleted {
    transition: opacity 240ms ease, transform 240ms ease, margin 240ms ease, padding 240ms ease, max-height 240ms ease;
    opacity: 0;
    transform: translateX(20px) scale(0.96);
    max-height: 0;
    padding-top: 0;
    padding-bottom: 0;
    margin-top: -0.6rem;
    overflow: hidden;
    border-color: transparent;
}

.row-select-wrap {
    display: grid;
    place-items: center;
    width: 36px;
    height: 36px;
    border-radius: 12px;
    background: rgba(255, 255, 255, 0.7);
    border: 1px solid rgba(16, 185, 129, 0.18);
    cursor: pointer;
    transition: background 160ms ease, border-color 160ms ease;
}

.row-select-wrap:hover {
    background: rgba(209, 250, 229, 0.7);
    border-color: rgba(16, 185, 129, 0.45);
}

.row-select-wrap input[type="checkbox"] {
    width: 18px;
    height: 18px;
    accent-color: #10b981;
    cursor: pointer;
    margin: 0;
}

.product-list-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    padding: 0.4rem 0.75rem;
    margin-bottom: 0.15rem;
}

.select-all-wrap {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    color: #475569;
    font-weight: 800;
    font-size: 0.82rem;
    cursor: pointer;
    user-select: none;
}

.select-all-wrap input[type="checkbox"] {
    width: 18px;
    height: 18px;
    accent-color: #10b981;
    cursor: pointer;
}

.select-count-pill {
    font-size: 0.76rem;
    font-weight: 850;
    color: #047857;
    background: rgba(209, 250, 229, 0.78);
    border: 1px solid rgba(16, 185, 129, 0.25);
    padding: 0.3rem 0.65rem;
    border-radius: 999px;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.select-count-pill .select-count {
    color: #065f46;
    font-weight: 900;
}

/* Bulk action bar (one Update + one Delete button per company) */
.bulk-action-bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 0.75rem;
    margin-top: 0.4rem;
    padding: 0.85rem 1rem;
    border-radius: 18px;
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.95), rgba(236, 253, 245, 0.65));
    border: 1px dashed rgba(16, 185, 129, 0.32);
}

.bulk-action-hint {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    color: #475569;
    font-size: 0.86rem;
    font-weight: 700;
    min-width: 0;
}

.bulk-action-hint i {
    color: #047857;
    font-size: 1.1rem;
    flex-shrink: 0;
}

.bulk-action-hint strong {
    color: #047857;
    font-weight: 900;
}

.bulk-action-buttons {
    display: inline-flex;
    gap: 0.55rem;
    flex-wrap: wrap;
}

.bulk-update-btn,
.bulk-delete-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.65rem 1.2rem;
    border-radius: 999px;
    font-weight: 850;
    font-size: 0.88rem;
    cursor: pointer;
    border: none;
    transition: transform 160ms ease, filter 160ms ease, box-shadow 160ms ease, opacity 160ms ease;
}

.bulk-update-btn {
    background: linear-gradient(135deg, #10b981, #047857);
    color: white;
    box-shadow: 0 8px 20px rgba(6, 95, 70, 0.2);
}

.bulk-update-btn:hover:not(:disabled) {
    transform: translateY(-1px);
    filter: brightness(1.05);
    box-shadow: 0 12px 28px rgba(6, 95, 70, 0.28);
}

.bulk-delete-btn {
    background: white;
    color: #b91c1c;
    border: 1px solid rgba(220, 38, 38, 0.32);
    box-shadow: 0 4px 14px rgba(220, 38, 38, 0.08);
}

.bulk-delete-btn:hover:not(:disabled) {
    background: rgba(254, 226, 226, 0.78);
    border-color: rgba(220, 38, 38, 0.55);
    transform: translateY(-1px);
}

.bulk-update-btn:disabled,
.bulk-delete-btn:disabled {
    opacity: 0.45;
    cursor: not-allowed;
    box-shadow: none;
    transform: none;
    filter: grayscale(0.4);
}

@media (max-width: 767.98px) {
    .product-edit-row {
        grid-template-columns: auto 1fr;
        row-gap: 0.4rem;
    }
    .product-edit-row .row-name,
    .product-edit-row .row-packing,
    .product-edit-row .row-notes {
        grid-column: 1 / -1;
    }
    .product-edit-row .product-active-check {
        grid-column: 1 / -1;
        justify-content: flex-end;
    }
    .bulk-action-bar {
        flex-direction: column;
        align-items: stretch;
    }
    .bulk-action-buttons {
        justify-content: space-between;
    }
    .bulk-update-btn,
    .bulk-delete-btn {
        flex: 1 1 auto;
        justify-content: center;
    }
}

.distributor-company-accordion[open] .product-edit-row {
    opacity: 1;
    transform: translateY(0);
}

.distributor-company-accordion[open] .product-edit-row:nth-child(2) {
    transition-delay: 40ms;
}

.distributor-company-accordion[open] .product-edit-row:nth-child(3) {
    transition-delay: 80ms;
}

.distributor-company-accordion[open] .product-edit-row:nth-child(4) {
    transition-delay: 120ms;
}

.product-edit-row .form-control {
    min-height: 42px;
    border-radius: 14px;
}

.product-active-check {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    color: #334155;
    font-weight: 800;
    white-space: nowrap;
}

.tool-submit.compact,
.product-delete-btn {
    min-height: 42px;
    padding: 0 0.85rem;
    border-radius: 14px;
    font-size: 0.85rem;
}

.product-delete-btn {
    border: 1px solid rgba(220, 38, 38, 0.18);
    color: #b91c1c;
    background: rgba(254, 226, 226, 0.72);
}

.distributor-company-row-shell {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: stretch;
    gap: 0.75rem;
    padding: 0.7rem;
    background:
        radial-gradient(circle at 92% 0%, rgba(110, 231, 183, 0.3), transparent 34%),
        linear-gradient(135deg, #065f46, #10b981);
    transition: background 280ms ease, border-color 240ms ease;
}

.distributor-company-accordion:has(.distributor-product-collapse.show) .distributor-company-row-shell,
.distributor-company-accordion:has(.distributor-product-collapse.collapsing) .distributor-company-row-shell {
    background:
        radial-gradient(circle at 96% 0%, rgba(209, 250, 229, 0.65), transparent 34%),
        rgba(255, 255, 255, 0.94);
    border-bottom: 1px solid rgba(16, 185, 129, 0.12);
}

.distributor-company-accordion.is-company-inactive .distributor-company-row-shell {
    background:
        radial-gradient(circle at 92% 0%, rgba(221, 214, 254, 0.34), transparent 34%),
        linear-gradient(135deg, #581c87, #7c3aed);
}

.distributor-company-accordion.is-company-inactive:has(.distributor-product-collapse.show) .distributor-company-row-shell,
.distributor-company-accordion.is-company-inactive:has(.distributor-product-collapse.collapsing) .distributor-company-row-shell {
    background:
        radial-gradient(circle at 96% 0%, rgba(237, 233, 254, 0.82), transparent 34%),
        rgba(255, 255, 255, 0.95);
}

.distributor-company-row {
    width: 100%;
    min-width: 0;
    text-align: left;
    border-radius: 18px;
    background: transparent;
}

.distributor-company-row:hover {
    background: rgba(255, 255, 255, 0.08);
}

.distributor-company-row:not(.collapsed),
.distributor-company-row:not(.collapsed):hover {
    color: #0f172a;
    background: rgba(255, 255, 255, 0.72);
}

.distributor-company-row:not(.collapsed) p {
    color: #64748b;
}

.distributor-company-row:not(.collapsed) .company-summary-meta i {
    color: #065f46;
    background: rgba(209, 250, 229, 0.82);
    transform: rotate(180deg);
}

.distributor-company-row-shell .company-status-form {
    display: flex;
    align-items: center;
}

.distributor-company-row-shell .company-active-toggle {
    height: 100%;
    min-height: 52px;
    color: #ffffff;
    background: rgba(255, 255, 255, 0.16);
    border-color: rgba(255, 255, 255, 0.24);
}

.distributor-company-accordion:has(.distributor-product-collapse.show) .company-active-toggle,
.distributor-company-accordion:has(.distributor-product-collapse.collapsing) .company-active-toggle {
    color: #065f46;
    background: rgba(209, 250, 229, 0.84);
    border-color: rgba(16, 185, 129, 0.18);
}

.distributor-product-collapse {
    background:
        linear-gradient(180deg, rgba(255,255,255,0.94), rgba(236, 253, 245, 0.55));
}

.distributor-product-collapse .distributor-product-editor {
    opacity: 1;
    transform: none;
    will-change: auto;
}

.distributor-product-collapse .product-edit-row {
    opacity: 1;
    transform: none;
    transition: background 200ms ease, border-color 200ms ease, box-shadow 200ms ease;
}

.readonly-toggle {
    min-width: 128px;
    justify-content: center;
    pointer-events: none;
}

.product-readonly-row {
    grid-template-columns: minmax(220px, 1.35fr) minmax(130px, 0.65fr) minmax(190px, 1fr) auto auto;
    color: #334155;
    background:
        radial-gradient(circle at 100% 0%, rgba(209, 250, 229, 0.5), transparent 34%),
        rgba(255, 255, 255, 0.78);
}

.readonly-product-name,
.readonly-product-pack,
.readonly-product-notes,
.readonly-product-status,
.readonly-product-lock {
    display: inline-flex;
    align-items: center;
    min-height: 42px;
    padding: 0.55rem 0.75rem;
    border-radius: 14px;
    border: 1px solid rgba(16, 185, 129, 0.1);
    background: rgba(255, 255, 255, 0.78);
    font-weight: 800;
}

.readonly-product-name {
    gap: 0.5rem;
    color: #0f172a;
    font-weight: 900;
}

.readonly-product-name i {
    color: #059669;
}

.readonly-product-pack,
.readonly-product-notes {
    color: #64748b;
}

.readonly-product-status {
    justify-content: center;
    color: #065f46;
    background: rgba(209, 250, 229, 0.8);
}

.readonly-product-status.is-inactive {
    color: #475569;
    background: rgba(226, 232, 240, 0.82);
}

.readonly-product-lock {
    gap: 0.4rem;
    justify-content: center;
    color: #92400e;
    background: rgba(254, 243, 199, 0.86);
    border-color: rgba(245, 158, 11, 0.15);
}

.admin-distributor-link-card,
.admin-distributor-hero,
.admin-distributor-filter,
.admin-distributor-card {
    border: 1px solid rgba(167, 243, 208, 0.76);
    background:
        radial-gradient(circle at 90% 0%, rgba(52, 211, 153, 0.16), transparent 34%),
        rgba(255, 255, 255, 0.9);
    box-shadow: 0 28px 78px rgba(6, 95, 70, 0.1);
}

.admin-distributor-link-card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1.2rem;
    padding: clamp(1.25rem, 3vw, 1.8rem);
    border-radius: 28px;
}

.admin-distributor-kicker {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    width: fit-content;
    padding: 0.42rem 0.78rem;
    border-radius: 999px;
    color: #065f46;
    background: rgba(209, 250, 229, 0.78);
    border: 1px solid rgba(16, 185, 129, 0.2);
    font-size: 0.76rem;
    font-weight: 950;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.admin-distributor-link-copy h3 {
    margin: 0.75rem 0 0.35rem;
    color: #0f172a;
    font-size: clamp(1.45rem, 3vw, 2rem);
    font-weight: 950;
    line-height: 1.08;
}

.admin-distributor-link-copy p {
    margin: 0;
    color: #64748b;
    font-weight: 700;
}

.admin-distributor-link-btn,
.admin-distributor-back {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    min-height: 44px;
    padding: 0.7rem 1rem;
    border-radius: 16px;
    color: #065f46;
    background: rgba(209, 250, 229, 0.9);
    border: 1px solid rgba(16, 185, 129, 0.24);
    box-shadow: 0 12px 28px rgba(6, 95, 70, 0.1);
    font-weight: 900;
    text-decoration: none;
}

.admin-distributor-link-btn:hover,
.admin-distributor-back:hover {
    color: #064e3b;
    background: rgba(167, 243, 208, 0.94);
    transform: translateY(-1px);
}

.admin-distributor-page {
    padding: clamp(2rem, 5vw, 4.5rem) 0;
    background:
        radial-gradient(circle at 12% 10%, rgba(16, 185, 129, 0.13), transparent 30%),
        radial-gradient(circle at 90% 14%, rgba(37, 99, 235, 0.08), transparent 32%),
        linear-gradient(180deg, #f8fffd 0%, #ecfdf5 100%);
}

.admin-distributor-hero {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1.2rem;
    padding: clamp(1.5rem, 4vw, 2.6rem);
    border-radius: 34px;
    margin-bottom: 1rem;
}

.admin-distributor-hero-copy {
    min-width: 0;
}

.admin-distributor-hero h1 {
    margin: 0.85rem 0 0.45rem;
    color: #0f172a;
    font-size: clamp(2rem, 4vw, 3.8rem);
    font-weight: 950;
    line-height: 1.04;
}

.admin-distributor-hero p {
    margin: 0;
    max-width: 760px;
    color: #64748b;
    font-size: 1.04rem;
    font-weight: 700;
}

.admin-distributor-stats {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.8rem;
    margin-bottom: 1rem;
}

.admin-distributor-stats div {
    padding: 1rem;
    border-radius: 22px;
    color: #ffffff;
    background: linear-gradient(135deg, #064e3b, #10b981);
    box-shadow: 0 18px 38px rgba(6, 95, 70, 0.14);
}

.admin-distributor-stats strong {
    display: block;
    font-size: 2rem;
    line-height: 1;
    font-weight: 950;
}

.admin-distributor-stats span {
    display: block;
    margin-top: 0.35rem;
    color: rgba(236, 253, 245, 0.86);
    font-weight: 800;
}

.admin-distributor-filter {
    display: grid;
    grid-template-columns: minmax(260px, 1fr) minmax(180px, 220px) auto auto;
    align-items: center;
    gap: 0.75rem;
    padding: 1rem;
    border-radius: 26px;
    margin-bottom: 1rem;
}

.admin-distributor-search {
    display: grid;
    grid-template-columns: auto 1fr;
    align-items: center;
    gap: 0.65rem;
    min-height: 54px;
    padding: 0 0.9rem;
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.9);
    border: 1px solid rgba(16, 185, 129, 0.16);
}

.admin-distributor-search i {
    color: #059669;
}

.admin-distributor-search input {
    width: 100%;
    border: 0;
    outline: 0;
    background: transparent;
    color: #0f172a;
    font-weight: 750;
}

.admin-distributor-zone {
    min-height: 54px;
    border-radius: 18px;
    border: 1px solid rgba(16, 185, 129, 0.16);
    background-color: rgba(255, 255, 255, 0.92);
    color: #0f172a;
    font-weight: 800;
}

.admin-distributor-list {
    display: grid;
    gap: 0.9rem;
}

.admin-distributor-card {
    overflow: hidden;
    border-radius: 28px;
}

.admin-distributor-card.is-inactive {
    border-color: rgba(148, 163, 184, 0.38);
    box-shadow: 0 18px 46px rgba(51, 65, 85, 0.08);
}

.admin-distributor-card.status-row-approved {
    border-color: rgba(16, 185, 129, 0.34);
    box-shadow: 0 26px 68px rgba(6, 95, 70, 0.12);
}

.admin-distributor-card.status-row-approved .admin-distributor-summary {
    background:
        radial-gradient(circle at 94% 0%, rgba(52, 211, 153, 0.26), transparent 34%),
        linear-gradient(135deg, rgba(236, 253, 245, 0.96), rgba(255, 255, 255, 0.9));
}

.admin-distributor-card.status-row-pending {
    border-color: rgba(245, 158, 11, 0.32);
}

.admin-distributor-card.status-row-pending .admin-distributor-summary {
    background:
        radial-gradient(circle at 94% 0%, rgba(251, 191, 36, 0.22), transparent 34%),
        linear-gradient(135deg, rgba(255, 251, 235, 0.96), rgba(255, 255, 255, 0.9));
}

.admin-distributor-card.status-row-rejected {
    border-color: rgba(239, 68, 68, 0.26);
}

.admin-distributor-card.status-row-rejected .admin-distributor-summary {
    background:
        radial-gradient(circle at 94% 0%, rgba(248, 113, 113, 0.18), transparent 34%),
        linear-gradient(135deg, rgba(254, 242, 242, 0.96), rgba(255, 255, 255, 0.9));
}

.admin-distributor-summary {
    display: grid;
    grid-template-columns: auto minmax(220px, 1fr) minmax(220px, 0.9fr) auto auto auto;
    align-items: center;
    gap: 0.85rem;
    width: 100%;
    padding: 1rem;
    border: 0;
    color: #0f172a;
    background:
        radial-gradient(circle at 94% 0%, rgba(52, 211, 153, 0.3), transparent 34%),
        linear-gradient(135deg, #065f46 0%, #059669 58%, #10b981 100%);
    text-align: left;
}

.admin-distributor-card.is-inactive .admin-distributor-summary {
    background:
        radial-gradient(circle at 94% 0%, rgba(203, 213, 225, 0.28), transparent 34%),
        linear-gradient(135deg, #334155 0%, #64748b 100%);
}

.admin-distributor-avatar,
.admin-company-mark {
    width: 48px;
    height: 48px;
    display: grid;
    place-items: center;
    flex: 0 0 auto;
    border-radius: 18px;
    color: #065f46;
    background: rgba(209, 250, 229, 0.9);
    font-weight: 950;
}

.admin-distributor-avatar {
    overflow: hidden;
    color: #ffffff;
    background: rgba(255, 255, 255, 0.18);
    border: 1px solid rgba(255, 255, 255, 0.2);
}

.admin-distributor-avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.admin-distributor-main strong {
    display: block;
    color: #ffffff;
    font-size: 1.05rem;
    font-weight: 950;
}

.admin-distributor-main small,
.admin-company-detail summary small {
    display: block;
    color: rgba(255, 255, 255, 0.86);
    font-weight: 700;
}

.admin-distributor-contact {
    display: grid;
    gap: 0.28rem;
    color: rgba(255, 255, 255, 0.9);
    font-size: 0.86rem;
    font-weight: 800;
}

.admin-distributor-contact span {
    display: inline-flex;
    align-items: center;
    gap: 0.42rem;
}

.admin-distributor-contact i {
    color: rgba(255, 255, 255, 0.92);
}

.admin-distributor-count {
    padding: 0.58rem 0.76rem;
    border-radius: 999px;
    color: #ffffff;
    background: rgba(255, 255, 255, 0.16);
    border: 1px solid rgba(255, 255, 255, 0.18);
    font-size: 0.86rem;
    font-weight: 950;
    white-space: nowrap;
}

.admin-row-status {
    padding: 0.58rem 0.78rem;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    color: #ffffff;
    background: rgba(255, 255, 255, 0.16);
    border: 1px solid rgba(255, 255, 255, 0.18);
    font-size: 0.8rem;
    font-weight: 950;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    white-space: nowrap;
}

.admin-row-status.is-inactive {
    color: #f8fafc;
    background: rgba(15, 23, 42, 0.14);
}

.admin-distributor-chevron {
    width: 38px;
    height: 38px;
    display: grid;
    place-items: center;
    border-radius: 14px;
    color: #ffffff;
    background: rgba(255, 255, 255, 0.16);
    border: 1px solid rgba(255, 255, 255, 0.18);
    transition: transform 220ms ease;
}

.admin-distributor-summary:not(.collapsed) .admin-distributor-chevron {
    transform: rotate(180deg);
}

.admin-distributor-body {
    display: grid;
    gap: 1rem;
    padding: 1rem;
    border-top: 1px solid rgba(16, 185, 129, 0.12);
    background:
        linear-gradient(180deg, rgba(255,255,255,0.9), rgba(236, 253, 245, 0.7));
}

.admin-dist-section {
    overflow: hidden;
    border-radius: 22px;
    background: rgba(255, 255, 255, 0.82);
    border: 1px solid rgba(16, 185, 129, 0.12);
}

.admin-dist-section summary {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    padding: 0.85rem 1rem;
    cursor: pointer;
    list-style: none;
    color: #065f46;
    font-weight: 950;
}

.admin-dist-section summary::-webkit-details-marker {
    display: none;
}

.admin-dist-section summary span {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
}

.admin-dist-section summary > i {
    width: 34px;
    height: 34px;
    display: grid;
    place-items: center;
    border-radius: 12px;
    color: #065f46;
    background: rgba(209, 250, 229, 0.72);
    transition: transform 180ms ease;
}

.admin-dist-section[open] summary > i {
    transform: rotate(180deg);
}

.admin-distributor-profile-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.7rem;
    padding: 0 0.85rem 0.85rem;
}

.admin-distributor-profile-grid div {
    padding: 0.85rem;
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.82);
    border: 1px solid rgba(16, 185, 129, 0.1);
}

.admin-distributor-profile-grid span {
    display: block;
    color: #64748b;
    font-size: 0.7rem;
    font-weight: 950;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.admin-distributor-profile-grid strong {
    display: block;
    margin-top: 0.28rem;
    color: #0f172a;
    font-weight: 850;
    overflow-wrap: anywhere;
}

.admin-distributor-profile-grid .wide {
    grid-column: span 2;
}

.admin-distributor-license-grid {
    padding: 0 0.85rem 0.85rem;
}

.admin-company-stack {
    display: grid;
    gap: 0.75rem;
    padding: 0 0.85rem 0.85rem;
}

.admin-company-detail {
    overflow: hidden;
    border-radius: 22px;
    background: rgba(255, 255, 255, 0.8);
    border: 1px solid rgba(16, 185, 129, 0.13);
}

.admin-company-detail.is-inactive {
    border-color: rgba(168, 85, 247, 0.24);
    background: rgba(250, 245, 255, 0.86);
}

.admin-company-detail summary {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto auto auto;
    align-items: center;
    gap: 0.65rem;
    padding: 0.85rem 1rem;
    cursor: pointer;
    list-style: none;
}

.admin-company-title {
    min-width: 0;
}

.admin-company-title strong {
    display: block;
    color: #0f172a;
    font-weight: 900;
    font-size: 1rem;
    line-height: 1.2;
    overflow-wrap: anywhere;
}

.admin-company-count i {
    margin-right: 0.3rem;
    font-size: 0.85rem;
    opacity: 0.85;
}

.admin-company-detail summary::-webkit-details-marker {
    display: none;
}

.admin-company-detail summary > i {
    width: 34px;
    height: 34px;
    display: grid;
    place-items: center;
    border-radius: 12px;
    color: #065f46;
    background: rgba(209, 250, 229, 0.72);
    transition: transform 180ms ease;
}

.admin-company-detail[open] summary > i {
    transform: rotate(180deg);
}

.admin-company-count,
.admin-company-state,
.admin-product-chip em {
    padding: 0.5rem 0.68rem;
    border-radius: 999px;
    font-style: normal;
    font-size: 0.78rem;
    font-weight: 950;
    white-space: nowrap;
}

.admin-company-count {
    color: #065f46;
    background: rgba(209, 250, 229, 0.78);
}

.admin-company-state.is-active,
.admin-product-chip em {
    color: #065f46;
    background: rgba(209, 250, 229, 0.78);
}

.admin-company-state.is-inactive,
.admin-product-chip.is-inactive em {
    color: #475569;
    background: rgba(226, 232, 240, 0.86);
}

.admin-product-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.65rem;
    padding: 0 0.85rem 0.85rem;
}

.admin-product-chip {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    align-items: center;
    gap: 0.6rem;
    padding: 0.72rem;
    border-radius: 18px;
    background: rgba(236, 253, 245, 0.68);
    border: 1px solid rgba(16, 185, 129, 0.1);
}

.admin-product-chip > i {
    width: 38px;
    height: 38px;
    display: grid;
    place-items: center;
    border-radius: 14px;
    color: #047857;
    background: rgba(255, 255, 255, 0.82);
}

.admin-product-chip strong,
.admin-product-chip small {
    display: block;
}

.admin-product-chip strong {
    color: #0f172a;
    font-weight: 900;
}

.admin-product-chip small {
    color: #64748b;
    font-weight: 700;
}

.admin-product-chip.is-inactive {
    background: rgba(248, 250, 252, 0.86);
}

.admin-product-empty {
    padding: 1rem;
    border-radius: 18px;
    color: #64748b;
    background: rgba(255, 255, 255, 0.74);
    border: 1px dashed rgba(16, 185, 129, 0.2);
    font-weight: 800;
}

@media (max-width: 991.98px) {
    .distributor-hero-card,
    .distributor-dashboard-hero,
    .distributor-login-shell,
    .distributor-tools-grid,
    .csv-option-card {
        grid-template-columns: 1fr;
    }

    .product-edit-row {
        grid-template-columns: 1fr 1fr;
    }

    .product-readonly-row {
        grid-template-columns: 1fr 1fr;
    }

    .distributor-hero-card,
    .distributor-dashboard-hero {
        display: grid;
    }

    .dist-signup-hero {
        flex-direction: column;
        align-items: stretch;
    }

    .dist-login-pill {
        align-self: flex-start;
    }

    .distributor-status-panel {
        justify-items: start;
        width: fit-content;
    }

    .admin-distributor-link-card,
    .admin-distributor-hero,
    .admin-distributor-summary {
        grid-template-columns: 1fr;
        align-items: start;
    }

    .admin-distributor-link-card,
    .admin-distributor-hero {
        display: grid;
    }

    .admin-distributor-stats {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .admin-distributor-filter,
    .distributor-basic-grid,
    .distributor-submitted-info,
    .admin-distributor-profile-grid,
    .admin-company-detail summary,
    .admin-product-grid {
        grid-template-columns: 1fr;
    }

    .admin-distributor-count,
    .admin-distributor-chevron {
        justify-self: start;
    }

    /* ── Tablet polish (576–991px) for distributor catalog summary card ── */
    .admin-distributor-summary {
        display: grid !important;
        grid-template-columns: 56px minmax(0, 1.4fr) minmax(0, 1fr) auto auto auto !important;
        grid-template-areas: "avatar main contact status count chevron" !important;
        gap: 0.75rem !important;
        padding: 0.95rem 1rem !important;
    }
    .admin-distributor-avatar { grid-area: avatar; }
    .admin-distributor-main { grid-area: main; min-width: 0; }
    .admin-distributor-contact { grid-area: contact; min-width: 0; }
    .admin-row-status { grid-area: status; align-self: center; }
    .admin-distributor-count { grid-area: count; align-self: center; }
    .admin-distributor-chevron { grid-area: chevron; align-self: center; }

    .admin-distributor-contact span {
        font-size: 0.78rem !important;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
    }
}

@media (max-width: 575.98px) {
    .distributor-auth-section,
    .distributor-dashboard-section {
        padding: 1.5rem 0 2.5rem;
    }

    .distributor-hero-card,
    .distributor-dashboard-hero,
    .distributor-form-shell,
    .distributor-login-shell,
    .approval-wait-card,
    .tool-card,
    .distributor-company-list {
        border-radius: 28px;
    }

    .stockist-row,
    .document-check-grid,
    .document-final-grid,
    .distributor-metrics {
        grid-template-columns: 1fr;
    }

    .product-edit-row {
        grid-template-columns: 1fr;
    }

    .product-readonly-row {
        grid-template-columns: 1fr;
    }

    .csv-modal-hero {
        align-items: flex-start;
        flex-direction: column;
    }

    .csv-column-grid,
    .csv-modal-footer {
        grid-template-columns: 1fr;
    }

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

    .distributor-company-row,
    .company-summary-main,
    .company-summary-meta {
        align-items: flex-start;
    }

    .distributor-company-row-shell {
        grid-template-columns: 1fr;
    }

    .distributor-company-row-shell .company-status-form {
        justify-content: stretch;
    }

    .distributor-company-row-shell .company-active-toggle {
        width: 100%;
        justify-content: center;
    }

    .distributor-company-row {
        flex-direction: column;
    }

    .distributor-identity-meta {
        display: grid;
        grid-template-columns: 1fr;
        gap: 0.6rem;
    }

    .distributor-identity-meta span {
        min-height: 54px;
        padding: 0.65rem 0.78rem;
        border-radius: 18px;
    }

    .distributor-dashboard-hero h1 {
        font-size: clamp(2rem, 10vw, 3rem);
    }

    .company-summary-meta {
        width: 100%;
        justify-content: space-between;
    }

    .distributor-profile-body {
        padding: 0 0.85rem 0.85rem;
    }

    .distributor-basic-edit-card,
    .dist-profile-section,
    .dist-pc-entry {
        border-radius: 18px;
        padding: 0.85rem;
    }

    .dist-profile-section-head {
        align-items: flex-start;
        gap: 0.65rem;
    }

    .dist-profile-section-head > span {
        width: 38px;
        height: 38px;
        border-radius: 13px;
    }

    .dist-profile-section-head h3 {
        font-size: 0.94rem;
    }

    .dist-profile-section-head p {
        font-size: 0.74rem;
        line-height: 1.35;
    }

    /* ── Distributor signup single-screen mobile layout ── */
    .distributor-auth-section:has(.dist-signup-hero) {
        padding: 0.75rem 0 1rem;
    }

    .dist-signup-hero {
        flex-direction: row !important;
        align-items: center;
        gap: 0.75rem;
        padding: 0.9rem 1rem;
        border-radius: 20px;
        margin-bottom: 0.6rem;
    }

    .dist-signup-hero-body p {
        display: none;
    }

    .dist-signup-hero-body .distributor-kicker {
        font-size: 0.68rem;
        padding: 0.32rem 0.65rem;
    }

    .dist-signup-title {
        font-size: 1.1rem;
        margin: 0.35rem 0 0;
        line-height: 1.2;
    }

    .dist-login-pill {
        flex-direction: column;
        align-items: center;
        gap: 0.3rem;
        padding: 0.6rem 0.75rem;
        border-radius: 16px;
        min-width: 72px;
        text-align: center;
    }

    .dist-login-pill-icon {
        width: 34px;
        height: 34px;
        border-radius: 10px;
        font-size: 1rem;
    }

    .dist-login-pill-text {
        font-size: 0.68rem;
    }

    .dist-login-pill-text strong {
        font-size: 0.78rem;
    }

    .distributor-form-shell {
        padding: 0.65rem;
        border-radius: 20px;
    }

    .dist-accordion {
        margin-bottom: 0.4rem;
        border-radius: 14px;
    }

    .dist-accordion-toggle {
        padding: 0.65rem 0.85rem;
        font-size: 0.9rem;
        gap: 0.55rem;
    }

    .dist-accordion-icon {
        width: 30px;
        height: 30px;
        border-radius: 10px;
        font-size: 0.85rem;
    }

    .dist-accordion-chevron {
        font-size: 0.8rem;
    }

    .distributor-submit-btn {
        min-height: 48px;
        border-radius: 16px;
        font-size: 0.92rem;
        margin-top: 0.4rem !important;
    }

    /* ── Distributor login — full-screen premium mobile ── */
    .distributor-login-section {
        min-height: calc(100dvh - 56px);
        padding: 0;
        background:
            radial-gradient(circle at 10% 15%, rgba(52, 211, 153, 0.22), transparent 40%),
            radial-gradient(circle at 90% 80%, rgba(6, 78, 59, 0.6), transparent 50%),
            linear-gradient(160deg, #064e3b 0%, #065f46 55%, #047857 100%) !important;
        display: flex;
        flex-direction: column;
        justify-content: center;
    }

    .distributor-login-section .container {
        padding: 1.5rem 1.25rem 2rem;
    }

    /* Strip the default card shell — background is now the section itself */
    .distributor-login-shell {
        display: flex;
        flex-direction: column;
        gap: 1.5rem;
        background: none !important;
        border: none !important;
        box-shadow: none !important;
        border-radius: 0 !important;
        overflow: visible !important;
        backdrop-filter: none !important;
        -webkit-backdrop-filter: none !important;
    }

    /* Top branding block — fully transparent, sits on section gradient */
    .distributor-login-panel {
        background: none !important;
        padding: 0 !important;
        display: flex;
        flex-direction: column;
        align-items: flex-start;
        gap: 0.5rem;
    }

    .dist-login-brand-row {
        margin-bottom: 0.55rem;
    }

    .dist-login-brand-icon {
        width: 40px;
        height: 40px;
        border-radius: 12px;
        font-size: 1.1rem;
        background: rgba(255, 255, 255, 0.15) !important;
        border: 1.5px solid rgba(255, 255, 255, 0.28) !important;
    }

    .distributor-login-panel .distributor-kicker {
        background: rgba(110, 231, 183, 0.18) !important;
        border: 1.5px solid rgba(110, 231, 183, 0.45) !important;
        color: #6ee7b7 !important;
        font-size: 0.72rem;
        padding: 0.38rem 0.75rem;
        letter-spacing: 0.08em;
    }

    .distributor-login-panel h1 {
        color: #ffffff;
        font-size: 1.5rem;
        line-height: 1.2;
        margin: 0;
        font-weight: 900;
        letter-spacing: -0.02em;
        text-shadow: 0 2px 12px rgba(0, 0, 0, 0.2);
    }

    .distributor-login-panel p {
        color: rgba(209, 250, 229, 0.82);
        font-size: 0.84rem;
        margin: 0;
        line-height: 1.55;
    }

    .distributor-login-panel .distributor-ghost-btn {
        display: none;
    }

    /* Floating card — frosted glass blending over the green */
    .distributor-login-card {
        background: rgba(255, 255, 255, 0.92) !important;
        backdrop-filter: blur(24px) saturate(160%) !important;
        -webkit-backdrop-filter: blur(24px) saturate(160%) !important;
        border-radius: 28px !important;
        padding: 1.75rem 1.5rem !important;
        box-shadow: 0 24px 60px rgba(0, 0, 0, 0.22), 0 1px 0 rgba(255,255,255,0.8) inset !important;
        display: flex;
        flex-direction: column;
        gap: 1rem;
        border: 1px solid rgba(255, 255, 255, 0.55) !important;
    }

    .distributor-login-card h2 {
        font-size: 1.4rem;
        font-weight: 900;
        color: #0f172a;
        margin: 0;
        letter-spacing: -0.02em;
    }

    .distributor-login-card .field-wrap {
        margin: 0;
    }

    .distributor-login-card .distributor-submit-btn {
        margin-top: 0 !important;
        background: linear-gradient(135deg, #10b981, #047857) !important;
        box-shadow: 0 12px 28px rgba(6, 95, 70, 0.35) !important;
        min-height: 52px;
        font-size: 1rem;
        letter-spacing: 0.01em;
    }

    .dist-login-apply-hint {
        margin: 0;
        text-align: center;
        font-size: 0.84rem;
        color: #64748b;
    }

    .dist-login-apply-hint a {
        color: var(--primary-700);
    }

}

/* ---------- Reset & Base ---------- */
*, *::before, *::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

html {
    min-height: 100%;
    background: #052e22;
    overscroll-behavior-y: none;
    scroll-behavior: smooth;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* Stop the admin-panel page (and any other wide-card page) from horizontally
   overflowing the viewport on mobile. We clip at the section level too so
   rogue gradients / decorative pseudo-elements can't push the body wider. */
@media (max-width: 991.98px) {
    .admin-panel-section,
    .admin-distributor-page,
    .distributor-dashboard-section {
        overflow-x: clip;
        max-width: 100vw;
    }
}

/* ════════════════════════════════════════════════
   MEMBER DASHBOARD HUB — premium logged-in homepage
   ════════════════════════════════════════════════ */
.member-hub-shell {
    width: 100%;
    max-width: 1180px;
    margin: 0 auto;
    padding: clamp(1.25rem, 2.5vw, 2rem) 0;
    text-align: left;
}

.member-hub-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.4fr) minmax(280px, 1fr);
    gap: 1.4rem;
    align-items: stretch;
    margin-bottom: 1.5rem;
}

/* Left column — greeting */
.member-hub-headline {
    position: relative;
    padding: clamp(1.5rem, 3vw, 2.4rem);
    border-radius: 32px;
    background:
        radial-gradient(circle at 95% 0%, rgba(52, 211, 153, 0.22), transparent 38%),
        radial-gradient(circle at 0% 100%, rgba(16, 185, 129, 0.14), transparent 40%),
        linear-gradient(135deg, rgba(255, 255, 255, 0.96), rgba(236, 253, 245, 0.78));
    border: 1px solid rgba(167, 243, 208, 0.7);
    box-shadow: 0 22px 56px rgba(6, 95, 70, 0.1);
    overflow: hidden;
    isolation: isolate;
}

.member-hub-kicker {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.42rem 0.85rem;
    border-radius: 999px;
    background: linear-gradient(135deg, #10b981, #047857);
    color: white;
    font-weight: 900;
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    box-shadow: 0 8px 18px rgba(6, 95, 70, 0.25);
}

.member-hub-title {
    margin: 0.95rem 0 0.55rem;
    font-size: clamp(1.7rem, 3.5vw, 2.6rem);
    font-weight: 950;
    line-height: 1.12;
    color: #0f172a;
    letter-spacing: -0.012em;
    text-align: left;
}

.member-hub-sub {
    margin: 0;
    color: #475569;
    font-weight: 700;
    font-size: 0.95rem;
    line-height: 1.5;
}

.member-hub-sub code {
    background: rgba(16, 185, 129, 0.14);
    color: #047857;
    padding: 0.08rem 0.42rem;
    border-radius: 6px;
    font-weight: 900;
    font-size: 0.88rem;
}

/* KPI strip inside greeting */
.member-hub-kpis {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.7rem;
    margin-top: 1.3rem;
}

.member-hub-kpis > div {
    padding: 0.85rem 0.9rem;
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.85);
    border: 1px solid rgba(16, 185, 129, 0.16);
    box-shadow: 0 6px 18px rgba(6, 95, 70, 0.05);
    display: grid;
    gap: 0.15rem;
    align-content: center;
    transition: transform 200ms ease, box-shadow 200ms ease;
}

.member-hub-kpis > div:hover {
    transform: translateY(-2px);
    box-shadow: 0 14px 28px rgba(6, 95, 70, 0.12);
}

.member-hub-kpis i {
    color: #047857;
    font-size: 1.05rem;
}

.member-hub-kpis strong {
    color: #0f172a;
    font-size: 1.4rem;
    font-weight: 950;
    line-height: 1;
}

.member-hub-kpis span {
    color: #64748b;
    font-size: 0.74rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

/* Right column — license status card */
.member-hub-status-card {
    display: flex;
    flex-direction: column;
    padding: 1.3rem;
    border-radius: 28px;
    border: 1px solid rgba(16, 185, 129, 0.2);
    box-shadow: 0 22px 50px rgba(6, 95, 70, 0.1);
    background: linear-gradient(180deg, white 0%, rgba(236, 253, 245, 0.7) 100%);
    text-align: left;
}

.member-hub-status-card.status-valid {
    background: linear-gradient(165deg, #ecfdf5 0%, #d1fae5 100%);
    border-color: rgba(16, 185, 129, 0.45);
}
.member-hub-status-card.status-warning {
    background: linear-gradient(165deg, #ecfeff 0%, #cffafe 100%);
    border-color: rgba(14, 165, 233, 0.42);
}
.member-hub-status-card.status-critical {
    background: linear-gradient(165deg, #fffbeb 0%, #fef3c7 100%);
    border-color: rgba(217, 119, 6, 0.45);
}
.member-hub-status-card.status-expired {
    background: linear-gradient(165deg, #fef2f2 0%, #fee2e2 100%);
    border-color: rgba(220, 38, 38, 0.45);
}
.member-hub-status-card.status-pending {
    background: linear-gradient(165deg, #f8fafc 0%, #f1f5f9 100%);
    border-color: rgba(100, 116, 139, 0.35);
}

.status-card-head {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    margin-bottom: 1rem;
}

.status-card-icon {
    width: 56px;
    height: 56px;
    display: grid;
    place-items: center;
    border-radius: 18px;
    font-size: 1.6rem;
    background: white;
    box-shadow: 0 10px 22px rgba(15, 23, 42, 0.08);
    flex-shrink: 0;
}

.status-valid    .status-card-icon { color: #047857; }
.status-warning  .status-card-icon { color: #0369a1; }
.status-critical .status-card-icon { color: #b45309; }
.status-expired  .status-card-icon { color: #b91c1c; }
.status-pending  .status-card-icon { color: #475569; }

.status-card-head small {
    display: block;
    color: #64748b;
    font-size: 0.74rem;
    font-weight: 850;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.status-card-head strong {
    display: block;
    color: #0f172a;
    font-weight: 950;
    font-size: 1.25rem;
    margin-top: 0.15rem;
}

.status-card-body {
    flex: 1;
    display: grid;
    gap: 0.55rem;
    padding: 0.9rem 1rem;
    border-radius: 16px;
    background: rgba(255, 255, 255, 0.65);
    border: 1px solid rgba(255, 255, 255, 0.85);
    margin-bottom: 1rem;
}

.status-line {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 0.6rem;
    font-size: 0.88rem;
}

.status-line span {
    color: #64748b;
    font-weight: 700;
}

.status-line strong {
    color: #0f172a;
    font-weight: 900;
}

.status-empty {
    margin: 0;
    color: #475569;
    font-size: 0.88rem;
    font-weight: 700;
    line-height: 1.45;
}

.status-card-cta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.4rem;
    padding: 0.78rem 1.3rem;
    border-radius: 999px;
    background: linear-gradient(135deg, #10b981, #047857);
    color: white;
    font-weight: 900;
    font-size: 0.92rem;
    text-decoration: none;
    box-shadow: 0 12px 26px rgba(6, 95, 70, 0.25);
    transition: transform 180ms ease, filter 180ms ease, box-shadow 180ms ease;
}

.status-card-cta:hover {
    color: white;
    transform: translateY(-1px);
    filter: brightness(1.06);
    box-shadow: 0 18px 36px rgba(6, 95, 70, 0.32);
}

/* Quick action tiles */
.member-hub-quick-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 0.85rem;
    margin-bottom: 1.4rem;
}

.member-hub-tile {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    align-items: center;
    gap: 0.85rem;
    padding: 1rem 1.1rem;
    border-radius: 22px;
    background: linear-gradient(135deg, white, rgba(236, 253, 245, 0.85));
    border: 1px solid rgba(167, 243, 208, 0.7);
    color: #0f172a;
    text-decoration: none;
    box-shadow: 0 12px 28px rgba(6, 95, 70, 0.06);
    transition: transform 200ms ease, box-shadow 200ms ease, border-color 200ms ease;
}

.member-hub-tile:hover {
    color: #0f172a;
    transform: translateY(-3px);
    box-shadow: 0 22px 44px rgba(6, 95, 70, 0.16);
    border-color: rgba(16, 185, 129, 0.55);
}

.member-hub-tile .tile-icon {
    width: 48px;
    height: 48px;
    display: grid;
    place-items: center;
    border-radius: 16px;
    background: rgba(16, 185, 129, 0.14);
    color: #047857;
    font-size: 1.3rem;
    transition: background 200ms ease, color 200ms ease;
}

.member-hub-tile:hover .tile-icon {
    background: linear-gradient(135deg, #10b981, #047857);
    color: white;
}

.member-hub-tile strong {
    display: block;
    color: #0f172a;
    font-weight: 900;
    font-size: 1rem;
    line-height: 1.2;
}

.member-hub-tile small {
    color: #64748b;
    font-weight: 700;
    font-size: 0.78rem;
}

.member-hub-tile .tile-arrow {
    color: #047857;
    transition: transform 200ms ease;
}

.member-hub-tile:hover .tile-arrow {
    transform: translateX(4px);
}

.member-hub-tile.tile-primary {
    background: linear-gradient(135deg, #10b981, #047857);
    border-color: rgba(6, 95, 70, 0.45);
    color: white;
    box-shadow: 0 18px 40px rgba(6, 95, 70, 0.28);
}

.member-hub-tile.tile-primary strong,
.member-hub-tile.tile-primary small,
.member-hub-tile.tile-primary .tile-arrow {
    color: white;
}

.member-hub-tile.tile-primary .tile-icon {
    background: rgba(255, 255, 255, 0.22);
    color: white;
    border: 1px solid rgba(255, 255, 255, 0.32);
}

.member-hub-tile.tile-admin {
    background: linear-gradient(135deg, rgba(254, 243, 199, 0.8), rgba(253, 230, 138, 0.42));
    border-color: rgba(217, 119, 6, 0.42);
}

.member-hub-tile.tile-admin .tile-icon {
    background: rgba(217, 119, 6, 0.18);
    color: #b45309;
}

.member-hub-tile.tile-admin:hover .tile-icon {
    background: linear-gradient(135deg, #f59e0b, #b45309);
}

/* Announcement banner */
.member-hub-announcement {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    align-items: center;
    gap: 1rem;
    padding: 0.95rem 1.2rem;
    border-radius: 22px;
    background:
        radial-gradient(circle at 100% 0%, rgba(255, 255, 255, 0.2), transparent 40%),
        linear-gradient(135deg, #065f46 0%, #10b981 100%);
    color: white;
    text-decoration: none;
    box-shadow: 0 18px 42px rgba(6, 95, 70, 0.28);
    transition: transform 200ms ease, box-shadow 200ms ease;
}

.member-hub-announcement:hover {
    color: white;
    transform: translateY(-2px);
    box-shadow: 0 24px 52px rgba(6, 95, 70, 0.34);
}

.hub-announcement-icon {
    width: 46px;
    height: 46px;
    display: grid;
    place-items: center;
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.22);
    border: 1px solid rgba(255, 255, 255, 0.32);
    font-size: 1.2rem;
}

.member-hub-announcement small {
    display: block;
    font-size: 0.72rem;
    color: rgba(255, 255, 255, 0.78);
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.member-hub-announcement strong {
    display: block;
    color: white;
    font-weight: 900;
    font-size: 1rem;
    margin-top: 0.15rem;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.hub-announcement-arrow {
    font-size: 1.1rem;
    transition: transform 200ms ease;
}

.member-hub-announcement:hover .hub-announcement-arrow {
    transform: translateX(5px);
}

/* Hub announcement variants */
.member-hub-announcement.priority-important {
    background:
        radial-gradient(circle at 100% 0%, rgba(255, 255, 255, 0.22), transparent 40%),
        linear-gradient(135deg, #0c4a6e 0%, #0369a1 100%);
}
.member-hub-announcement.priority-urgent {
    background:
        radial-gradient(circle at 100% 0%, rgba(255, 255, 255, 0.22), transparent 40%),
        linear-gradient(135deg, #7c2d12 0%, #b91c1c 60%, #dc2626 100%);
}

.hub-announcement-body {
    min-width: 0;
}

.hub-announcement-priority {
    font-style: normal;
    text-transform: uppercase;
    font-weight: 900;
    letter-spacing: 0.05em;
}

/* Responsive — tablet */
@media (max-width: 991.98px) {
    .member-hub-grid {
        grid-template-columns: 1fr;
    }
    .member-hub-kpis {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

/* Mobile */
@media (max-width: 575.98px) {
    .member-hub-shell {
        padding: 0.75rem 0 1.4rem;
    }
    .member-hub-grid {
        gap: 1rem;
        margin-bottom: 1rem;
    }
    .member-hub-headline {
        padding: 1.15rem 1.1rem 1.2rem;
        border-radius: 24px;
    }
    .member-hub-kicker {
        font-size: 0.62rem;
        padding: 0.35rem 0.7rem;
        letter-spacing: 0.06em;
    }
    .member-hub-title {
        font-size: clamp(1.45rem, 7vw, 1.85rem);
        margin: 0.65rem 0 0.4rem;
        line-height: 1.15;
    }
    .member-hub-sub {
        font-size: 0.82rem;
        line-height: 1.5;
        display: flex;
        flex-wrap: wrap;
        align-items: center;
        gap: 0.4rem;
    }
    .member-hub-sub strong,
    .member-hub-sub code {
        white-space: nowrap;
    }
    .member-hub-sub code {
        font-size: 0.78rem;
        padding: 0.12rem 0.45rem;
    }
    .member-hub-status-card {
        padding: 1rem;
        border-radius: 22px;
    }
    .status-card-icon {
        width: 46px;
        height: 46px;
        font-size: 1.25rem;
        border-radius: 14px;
    }
    .status-card-head strong {
        font-size: 1.05rem;
    }
    .status-card-head small {
        font-size: 0.68rem;
    }
    .status-card-body {
        padding: 0.75rem 0.85rem;
        margin-bottom: 0.85rem;
    }
    .status-line {
        font-size: 0.82rem;
    }
    .status-card-cta {
        font-size: 0.85rem;
        padding: 0.7rem 1rem;
    }
    .member-hub-kpis {
        gap: 0.5rem;
        margin-top: 1.1rem;
    }
    .member-hub-kpis > div {
        padding: 0.7rem 0.7rem;
        border-radius: 14px;
        gap: 0.1rem;
    }
    .member-hub-kpis i {
        font-size: 0.92rem;
    }
    .member-hub-kpis strong {
        font-size: 1.18rem;
    }
    .member-hub-kpis span {
        font-size: 0.62rem;
        letter-spacing: 0.04em;
        line-height: 1.3;
    }
    .member-hub-quick-grid {
        gap: 0.6rem;
        margin-bottom: 1rem;
    }
    .member-hub-tile {
        padding: 0.8rem 0.9rem;
        border-radius: 18px;
        gap: 0.7rem;
    }
    .member-hub-tile .tile-icon {
        width: 42px;
        height: 42px;
        border-radius: 13px;
        font-size: 1.05rem;
    }
    .member-hub-tile strong {
        font-size: 0.92rem;
    }
    .member-hub-tile small {
        font-size: 0.72rem;
    }
    .member-hub-announcement {
        padding: 0.85rem 1rem;
        border-radius: 18px;
        grid-template-columns: auto minmax(0, 1fr);
        gap: 0.7rem;
    }
    .member-hub-announcement strong {
        font-size: 0.9rem;
        white-space: normal;
    }
    .member-hub-announcement small {
        font-size: 0.66rem;
    }
    .hub-announcement-arrow {
        display: none;
    }
    .hub-announcement-icon {
        width: 40px;
        height: 40px;
        font-size: 1rem;
    }
}

/* Defensive: the fixed navbar (and its hamburger toggler on mobile) must always
   sit above every sticky/glass panel on the page. */
.navbar.navbar-custom.fixed-top {
    z-index: 1040 !important;
}
.navbar.navbar-custom.fixed-top .navbar-toggler {
    position: relative;
    z-index: 2;
    pointer-events: auto;
}
/* Show hamburger ONLY on mobile/tablet (below Bootstrap's lg breakpoint) */
@media (max-width: 991.98px) {
    .navbar.navbar-custom.fixed-top .navbar-toggler {
        display: flex !important;
        visibility: visible !important;
        opacity: 1 !important;
    }
}
/* On desktop (lg+), the navbar-expand-lg rule already hides .navbar-toggler.
   This guarantees it even if any other rule tried to show it. */
@media (min-width: 992px) {
    .navbar.navbar-custom.fixed-top .navbar-toggler {
        display: none !important;
    }
}

/* Page-wide horizontal overflow guard.
   We use `overflow-x: clip` (not `hidden`) on html and body — `clip` prevents
   horizontal page scroll WITHOUT forcing `overflow-y: auto`, so the body
   stays a normal in-flow element and `position: sticky` still anchors to the
   viewport (e.g. the admin search/filter bar and the fixed navbar). */
html {
    overflow-x: clip;
}

body {
    min-height: 100vh;
    min-height: 100dvh;
    font-family: var(--font-sans);
    background: #052e22;
    overscroll-behavior-y: none;
    color: var(--text-body);
    line-height: 1.65;
    font-size: 0.9375rem;
    padding-top: 70px;
    letter-spacing: -0.01em;
    overflow-x: clip;
    max-width: 100vw;
}

a {
    color: var(--primary-600);
    text-decoration: none;
    transition: all var(--duration-fast) var(--ease-out);
}
a:hover { color: var(--accent-cyan); }

::selection {
    background: var(--primary-100);
    color: var(--primary-900);
}

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

/* ---------- Scrollbar ---------- */
::-webkit-scrollbar { width: 6px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb {
    background: var(--primary-200);
    border-radius: var(--radius-full);
}
::-webkit-scrollbar-thumb:hover { background: var(--primary-400); }

/* ---------- Glass Card ---------- */
.glass-card {
    background: var(--bg-card);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    border: 1px solid rgba(255, 255, 255, 0.4);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-md);
    transition: all var(--duration-normal) var(--ease-spring);
}

.glass-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-xl);
    border-color: rgba(255, 255, 255, 0.6);
}

.dashboard-role-badge {
    position: absolute;
    bottom: -15px;
    left: 50%;
    transform: translateX(-50%);
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.5rem 0.85rem;
    border-radius: 999px;
    border: 2px solid #ffffff;
    box-shadow: var(--shadow-sm);
    font-size: 0.85rem;
    font-weight: 850;
    white-space: nowrap;
}

.dashboard-role-admin {
    color: #ffffff;
    background: linear-gradient(135deg, #047857, #10b981);
}

.dashboard-account-note {
    width: fit-content;
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    margin: 1.35rem auto 0.4rem;
    padding: 0.32rem 0.68rem;
    border-radius: 999px;
    color: #065f46;
    background: rgba(209, 250, 229, 0.78);
    border: 1px solid rgba(16, 185, 129, 0.22);
    font-size: 0.78rem;
    font-weight: 800;
}

/* ==============================
   NAVBAR
   ============================== */
.navbar-custom {
    background: rgba(255, 255, 255, 0.7);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    border-bottom: 1px solid rgba(255, 255, 255, 0.3);
    padding: 0.65rem 0;
    z-index: 1030;
    transition: all var(--duration-normal) var(--ease-out);
}


.brand-icon {
    font-size: 1.4rem;
    color: var(--primary-500);
    filter: drop-shadow(0 0 10px rgba(14, 165, 233, 0.4));
}


.brand-text {
    background: linear-gradient(135deg, var(--primary-dark), var(--primary));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.navbar-custom .nav-link {
    color: var(--text-heading);
    font-weight: 600;
    font-size: 0.825rem;
    padding: 0.45rem 1.15rem !important;
    border-radius: 999px !important;
    transition: all var(--duration-normal) var(--ease-spring);
    letter-spacing: -0.015em;
    border: 1px solid transparent;
    display: flex;
    align-items: center;
    gap: 0.4rem;
}



.navbar-custom .nav-link:hover {
    color: var(--primary-600);
    background: rgba(14, 165, 233, 0.08);
    transform: translateY(-1px);
}

.navbar-custom .nav-link.active {
    color: var(--primary-600) !important;
    background: rgba(255, 255, 255, 0.55);
    backdrop-filter: blur(14px) saturate(220%);
    -webkit-backdrop-filter: blur(14px) saturate(220%);
    border: 1px solid rgba(255, 255, 255, 0.4);
    border-radius: 999px !important;
    box-shadow: 
        0 8px 16px rgba(0, 0, 0, 0.05),
        inset 0 0 0 1px rgba(255, 255, 255, 0.2);
}

.btn-login {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 0.5rem;
    background: rgba(255, 255, 255, 0.2) !important;
    backdrop-filter: blur(8px) !important;
    color: var(--text-heading) !important;
    border-radius: var(--radius-lg) !important;
    padding: 0.6rem 1.5rem !important;
    font-weight: 700 !important;
    border: 1px solid rgba(14, 165, 233, 0.3) !important;
    transition: all var(--duration-normal) var(--ease-spring) !important;
}

.btn-register {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 0.5rem;
    background: linear-gradient(135deg, var(--primary-500), var(--primary-700)) !important;
    color: #ffffff !important;
    border-radius: var(--radius-lg) !important;
    padding: 0.6rem 1.35rem !important;
    font-weight: 800 !important;
    border: 1px solid rgba(5, 150, 105, 0.3) !important;
    box-shadow: 0 14px 28px rgba(6, 95, 70, 0.16);
    transition: all var(--duration-normal) var(--ease-spring) !important;
}

.btn-register:hover {
    transform: translateY(-2px);
    color: #ffffff !important;
    box-shadow: var(--shadow-glow) !important;
}

.btn-register i { color: inherit !important; }

.btn-login:hover {
    background: var(--primary-600) !important;
    color: #ffffff !important;
    transform: translateY(-2px);
    box-shadow: var(--shadow-glow) !important;
    border-color: var(--primary-600) !important;
}

.btn-login:hover i {
    color: #ffffff !important;
}

.glass-dropdown {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-xl);
    padding: 0.35rem;
}

.glass-dropdown .dropdown-item {
    font-size: 0.875rem;
    font-weight: 500;
    padding: 0.5rem 0.85rem;
    border-radius: var(--radius-sm);
    transition: all var(--duration-fast);
}

.glass-dropdown .dropdown-item:hover {
    background: var(--primary-50);
    color: var(--primary);
}

/* ==============================
   BUTTONS — Global System
   ============================== */
.btn {
    font-family: var(--font-sans);
    font-weight: 700;
    letter-spacing: -0.01em;
    border-radius: var(--radius-lg);
    transition: all var(--duration-normal) var(--ease-spring);
    position: relative;
    overflow: hidden;
    text-transform: none;
}

.btn-glow {
    background: linear-gradient(135deg, var(--primary-600), var(--primary-dark));
    color: white !important;
    border: none;
    padding: 0.75rem 1.75rem;
    box-shadow: var(--shadow-glow);
}

.btn-glow::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, var(--primary-dark), #046a5c);
    opacity: 0;
    transition: opacity var(--duration-normal);
    z-index: -1;
    border-radius: inherit;
}

.btn-glow:hover {
    color: var(--text-inverse);
    transform: translateY(-2px);
    box-shadow: var(--shadow-glow), var(--shadow-lg);
}

.btn-glow:hover::before { opacity: 1; }

.btn-glow:active {
    transform: translateY(0);
    box-shadow: var(--shadow-sm);
}

.btn-outline-primary {
    border-width: 1.5px;
    font-weight: 600;
}

.btn-outline-primary:hover {
    transform: translateY(-1px);
    box-shadow: var(--shadow-md);
}

.btn-outline-secondary {
    border-color: var(--border);
    color: var(--text-secondary);
    font-weight: 500;
}

.btn-outline-secondary:hover {
    background: var(--bg-muted);
    border-color: var(--border);
    color: var(--text-heading);
}

/* ==============================
   HERO SECTION
   ============================== */
.hero-section {
    position: relative;
    min-height: 85vh;
    display: flex;
    align-items: center;
    /* Ultra-Modern Mesh Gradient 2026 */
    background-color: #ffffff;
    background-image: 
        radial-gradient(at 0% 0%, rgba(59, 130, 246, 0.05) 0, transparent 40%),
        radial-gradient(at 100% 100%, rgba(5, 150, 105, 0.05) 0, transparent 40%);
    overflow: hidden;
    margin-top: -70px;
    padding-top: 70px;
}

.hero-overlay {
    position: absolute;
    inset: 0;
    background: transparent;
}

.hero-particles {
    position: absolute;
    inset: 0;
    overflow: hidden;
    pointer-events: none;
}

.hero-content {
    position: relative;
    z-index: 2;
    color: var(--text-heading);
    padding: 2rem 0 5rem;
}

.hero-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    background: rgba(255,255,255,0.12);
    backdrop-filter: blur(8px);
    padding: 0.4rem 1.25rem;
    border-radius: var(--radius-full);
    font-weight: 600;
    font-size: 0.8rem;
    margin-bottom: 1.75rem;
    border: 1px solid rgba(255,255,255,0.15);
    letter-spacing: 0.02em;
    text-transform: uppercase;
}

.hero-title {
    font-family: var(--font-display);
    font-size: clamp(2.25rem, 5.5vw, 3.75rem);
    font-weight: 800;
    line-height: 1.12;
    margin-bottom: 1.25rem;
    letter-spacing: -0.04em;
}

.gradient-text {
    background: none;
    color: var(--accent-mint);
    -webkit-text-fill-color: var(--accent-mint);
    filter: none;
}

.hero-subtitle {
    font-size: 1.15rem;
    opacity: 0.85;
    max-width: 540px;
    margin: 0 auto 3rem;
    font-weight: 400;
    line-height: 1.6;
}

/* ---------- Choice Cards ---------- */
.choice-cards {
    max-width: 760px;
    margin: 0 auto;
}

.choice-card {
    display: flex;
    flex-direction: column;
    height: 100%;
    background: rgba(255,255,255,0.08);
    backdrop-filter: blur(24px);
    -webkit-backdrop-filter: blur(24px);
    border: 1px solid rgba(255,255,255,0.14);
    border-radius: var(--radius-xl);
    padding: 2.5rem 2rem 2rem;
    text-align: center;
    color: var(--text-inverse);
    text-decoration: none;
    position: relative;
    overflow: hidden;
    transition: all var(--duration-slow) var(--ease-spring);
}

.choice-card::after {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: inherit;
    background: linear-gradient(180deg, rgba(255,255,255,0.05) 0%, rgba(255,255,255,0) 100%);
    pointer-events: none;
}

.choice-card:hover {
    transform: translateY(-10px) scale(1.02);
    background: rgba(255,255,255,0.16);
    border-color: rgba(255,255,255,0.35);
    box-shadow: 0 30px 60px rgba(0,0,0,0.25), inset 0 1px 0 rgba(255,255,255,0.1);
    color: var(--text-inverse);
}

.choice-icon {
    position: relative;
    width: 72px;
    height: 72px;
    margin: 0 auto 1.5rem;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2rem;
    background: rgba(255,255,255,0.12);
    border-radius: var(--radius-lg);
    border: 1px solid rgba(255,255,255,0.1);
}

.choice-icon-pulse {
    position: absolute;
    inset: -5px;
    border-radius: var(--radius-lg);
    border: 2px solid rgba(255,255,255,0.2);
    animation: pulse-ring 2.5s var(--ease-out) infinite;
}

@keyframes pulse-ring {
    0% { transform: scale(1); opacity: 0.8; }
    100% { transform: scale(1.25); opacity: 0; }
}

.choice-card h3 {
    font-family: var(--font-display);
    font-size: 1.2rem;
    font-weight: 700;
    margin-bottom: 0.6rem;
    letter-spacing: -0.02em;
}

.choice-card p {
    font-size: 0.875rem;
    opacity: 0.75;
    margin-bottom: 1.5rem;
    line-height: 1.55;
}

.choice-cta {
    margin-top: auto;
    align-self: center;
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    font-weight: 600;
    font-size: 0.85rem;
    padding: 0.45rem 1.25rem;
    border: 1.5px solid rgba(255,255,255,0.35);
    border-radius: var(--radius-full);
    transition: all var(--duration-normal) var(--ease-out);
    letter-spacing: -0.01em;
}

.choice-card:hover .choice-cta {
    background: rgba(255,255,255,0.15);
    border-color: rgba(255,255,255,0.5);
}

.choice-card:hover .choice-cta i {
    transform: translateX(3px);
    transition: transform var(--duration-normal) var(--ease-spring);
}

.hero-wave {
    position: absolute;
    bottom: -2px;
    left: 0;
    right: 0;
    z-index: 3;
}

.hero-wave svg {
    display: block;
    width: 100%;
    height: 80px;
}

/* ==============================
   STATS SECTION
   ============================== */
.stats-section {
    padding: 6rem 0;
    position: relative;
    background: radial-gradient(circle at 10% 20%, rgba(14, 165, 233, 0.02) 0%, transparent 50%),
                radial-gradient(circle at 90% 80%, rgba(16, 185, 129, 0.02) 0%, transparent 50%);
}


.stat-card {
    background: rgba(255, 255, 255, 0.12);
    backdrop-filter: blur(40px) saturate(220%);
    -webkit-backdrop-filter: blur(40px) saturate(220%);
    border: 1px solid rgba(255, 255, 255, 0.25);
    border-radius: var(--radius-2xl);
    padding: 3rem 2rem;
    box-shadow: 
        0 8px 32px rgba(0, 0, 0, 0.05),
        inset 0 0 0 1px rgba(255, 255, 255, 0.2);
    transition: all var(--duration-normal) var(--ease-spring);
    position: relative;
    overflow: hidden;
}

/* Glass Shimmer Swipe */
.stat-card::before {
    content: '';
    position: absolute;
    top: -100%;
    left: -100%;
    width: 200%;
    height: 200%;
    background: linear-gradient(
        135deg,
        transparent 0%,
        rgba(255, 255, 255, 0.15) 50%,
        transparent 100%
    );
    transform: rotate(45deg);
    transition: all 0.75s ease;
    pointer-events: none;
    z-index: 1;
}

.stat-card:hover::before {
    top: 50%;
    left: 50%;
}

.stat-card:hover {
    transform: translateY(-12px) scale(1.03);
    background: rgba(255, 255, 255, 0.18);
    border-color: rgba(255, 255, 255, 0.5);
    box-shadow: 
        0 40px 80px rgba(0, 0, 0, 0.15),
        inset 0 0 0 2px rgba(255, 255, 255, 0.3);
}

/* Atmospheric Glow Behind Numbers */
.stat-card::after {
    content: '';
    position: absolute;
    bottom: -20px;
    right: -20px;
    width: 140px;
    height: 140px;
    background: radial-gradient(circle, rgba(14, 165, 233, 0.1) 0%, transparent 70%);
    border-radius: 50%;
    z-index: 0;
    pointer-events: none;
    filter: blur(10px);
}


.stat-icon {
    width: 64px;
    height: 64px;
    margin: 0 auto 1.25rem;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.75rem;
    color: var(--primary-500);
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.2), rgba(255, 255, 255, 0.1));
    border-radius: var(--radius-xl);
    border: 1px solid rgba(255, 255, 255, 0.1);
    box-shadow: inset 0 0 12px rgba(255, 255, 255, 0.2);
}



.stat-number {
    font-family: var(--font-display);
    font-size: 3.5rem;
    font-weight: 800;
    line-height: 1;
    margin-bottom: 0.5rem;
    letter-spacing: -0.05em;
    position: relative;
    z-index: 2;
    /* High-Fidelity Liquid Gradient Number */
    background: linear-gradient(135deg, var(--text-heading) 0%, var(--primary-600) 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    filter: drop-shadow(0 0 15px rgba(14, 165, 233, 0.15));
}


.stat-label {
    font-size: 0.85rem;
    color: var(--text-secondary);
    font-weight: 500;
    letter-spacing: 0.01em;
}

/* ==============================
   FEATURES SECTION
   ============================== */
.features-section {
    padding: 6rem 0;
    background: transparent;
    position: relative;
    /* Blend and Professional 2026 */
    background: linear-gradient(180deg, transparent 0%, rgba(14, 165, 233, 0.03) 50%, transparent 100%);
}

.leadership-showcase-section,
.testimonials-section,
.gallery-loop-section {
    padding: 5rem 0;
    position: relative;
    overflow: hidden;
}

.leadership-showcase-section {
    background:
        linear-gradient(135deg, rgba(255,255,255,0.94), rgba(236,253,245,0.72)),
        radial-gradient(circle at 15% 20%, rgba(16,185,129,0.13), transparent 34%);
}

.leadership-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1.35rem;
}

/* Leadership card — full-bleed photo with overlay text */
.leadership-card {
    border-radius: 20px;
    overflow: hidden;
    box-shadow: 0 20px 50px rgba(15, 23, 42, 0.12);
    transition: transform 0.35s ease, box-shadow 0.35s ease;
    position: relative;
    background: linear-gradient(160deg, rgba(5,150,105,0.15), rgba(14,165,233,0.12));
}

.leadership-card:hover {
    transform: translateY(-8px);
    box-shadow: 0 36px 72px rgba(15, 23, 42, 0.18);
}

/* Photo frame fills the whole card */
.leadership-photo-frame {
    width: 100%;
    aspect-ratio: 3 / 4;
    overflow: hidden;
    background: linear-gradient(160deg, rgba(5,150,105,0.18) 0%, rgba(14,165,233,0.14) 100%);
    display: grid;
    place-items: center;
    position: relative;
}

.leadership-photo-frame img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: top center;
    display: block;
    transition: transform 0.45s ease;
}

.leadership-card:hover .leadership-photo-frame img {
    transform: scale(1.05);
}

/* Dark gradient overlay so text is always readable */
.leadership-photo-frame::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(
        to bottom,
        transparent 35%,
        rgba(5, 20, 15, 0.35) 60%,
        rgba(5, 20, 15, 0.82) 100%
    );
    pointer-events: none;
}

/* Placeholder avatar for missing photos */
.leadership-placeholder {
    width: 110px;
    height: 110px;
    border-radius: 50%;
    display: grid;
    place-items: center;
    background: rgba(255,255,255,0.92);
    color: var(--primary);
    font-size: 2.6rem;
    font-weight: 800;
    box-shadow: 0 14px 35px rgba(5, 150, 105, 0.2);
    z-index: 1;
}

/* Card body sits at the bottom of the photo frame */
.leadership-card-body {
    position: absolute;
    inset: auto 0 0;
    padding: 1.4rem 1.35rem 1.3rem;
    z-index: 2;
}

.leadership-role {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    color: rgba(110, 231, 183, 0.95);
    font-size: 0.75rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.07em;
    margin-bottom: 0.4rem;
}

.leadership-card h3 {
    font-size: 1.2rem;
    font-weight: 800;
    color: #fff;
    margin: 0 0 0.2rem;
    text-shadow: 0 1px 4px rgba(0,0,0,0.3);
}

.leadership-card p {
    color: rgba(255, 255, 255, 0.72);
    margin: 0;
    font-size: 0.88rem;
}

.testimonials-section {
    background: linear-gradient(180deg, #fff, rgba(240, 253, 250, 0.64));
}

.testimonial-carousel {
    overflow: hidden;
    padding: 0.25rem;
}

.testimonial-track {
    display: flex;
    gap: 1.125rem;
    transition: transform 700ms var(--ease-out);
    will-change: transform;
}

.testimonial-card {
    min-width: calc((100% - 2.25rem) / 3);
    border: 1px solid rgba(5, 150, 105, 0.14);
    border-radius: 18px;
    background: rgba(255,255,255,0.9);
    padding: 1.35rem;
    box-shadow: 0 18px 45px rgba(15, 23, 42, 0.07);
}

.testimonial-quote-icon {
    display: inline-flex;
    color: var(--primary);
    font-size: 1.7rem;
    margin-bottom: 0.8rem;
}

.testimonial-card p {
    color: var(--text-body);
    line-height: 1.65;
    font-weight: 500;
    min-height: 6.5rem;
}

.testimonial-person {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin-top: 1rem;
}

.testimonial-person img,
.testimonial-person span {
    width: 46px;
    height: 46px;
    border-radius: 50%;
    object-fit: cover;
    display: grid;
    place-items: center;
    background: rgba(5, 150, 105, 0.12);
    color: var(--primary);
    font-weight: 800;
}

.testimonial-person strong {
    display: block;
    color: var(--text-heading);
}

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

.gallery-loop-section {
    background: linear-gradient(180deg, #f0fdf7 0%, #fff 40%, #f0fdf7 100%);
    padding-block: 6rem;
}

.gallery-marquee {
    width: 100%;
    overflow: hidden;
    padding: 1.35rem 0 2rem;
    -webkit-mask-image: linear-gradient(90deg, transparent, #000 6%, #000 94%, transparent);
    mask-image: linear-gradient(90deg, transparent, #000 6%, #000 94%, transparent);
}

.gallery-track {
    display: flex;
    gap: 2rem;
    width: max-content;
    animation: gallery-loop 65s linear infinite;
    will-change: transform;
}

.gallery-marquee:hover .gallery-track { animation-play-state: paused; }

.gallery-item {
    position: relative;
    width: clamp(440px, 42vw, 680px);
    aspect-ratio: 16 / 9;
    border-radius: 24px;
    overflow: hidden;
    margin: 0;
    background: rgba(5, 150, 105, 0.08);
    box-shadow: 0 20px 50px rgba(15, 23, 42, 0.13);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    cursor: zoom-in;
}

.gallery-item:hover,
.gallery-item:focus-visible {
    transform: translateY(-5px) scale(1.015);
    box-shadow: 0 30px 64px rgba(15, 23, 42, 0.18);
}

.gallery-item:focus-visible {
    outline: 3px solid rgba(16, 185, 129, 0.38);
    outline-offset: 4px;
}

.gallery-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.5s ease;
}

.gallery-item:hover img {
    transform: scale(1.06);
}

.gallery-item figcaption {
    position: absolute;
    inset: auto 0 0;
    padding: 3.2rem 1.55rem 1.35rem;
    color: #fff;
    font-size: 1.08rem;
    font-weight: 800;
    background: linear-gradient(180deg, transparent, rgba(0,0,0,0.75));
    letter-spacing: 0.01em;
}

.gallery-item figcaption span,
.gallery-item figcaption small {
    display: block;
}

.gallery-item figcaption small {
    margin-top: 0.2rem;
    font-size: 0.78rem;
    font-weight: 650;
    opacity: 0.86;
}

.gallery-lightbox {
    position: fixed;
    inset: 0;
    z-index: 10050;
    display: none;
    align-items: center;
    justify-content: center;
    padding: clamp(1rem, 3vw, 2.25rem);
    background:
        radial-gradient(circle at 18% 16%, rgba(16, 185, 129, 0.22), transparent 30%),
        rgba(3, 20, 17, 0.84);
    backdrop-filter: blur(18px) saturate(145%);
    -webkit-backdrop-filter: blur(18px) saturate(145%);
}

.gallery-lightbox.open {
    display: flex;
}

.gallery-lightbox-stage {
    position: relative;
    width: min(1080px, 88vw);
    max-height: 86vh;
    margin: 0;
    overflow: hidden;
    border: 1px solid rgba(255, 255, 255, 0.24);
    border-radius: 28px;
    background: rgba(255, 255, 255, 0.08);
    box-shadow: 0 34px 110px rgba(0, 0, 0, 0.42);
}

.gallery-lightbox-stage img {
    display: block;
    width: 100%;
    max-height: 76vh;
    object-fit: contain;
    background: rgba(2, 6, 23, 0.34);
}

.gallery-lightbox-stage figcaption {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 1rem 1.2rem;
    color: #ffffff;
    background: rgba(4, 47, 46, 0.92);
}

.gallery-lightbox-stage figcaption span {
    font-weight: 800;
}

.gallery-lightbox-stage figcaption small {
    color: rgba(255, 255, 255, 0.72);
    font-weight: 700;
    white-space: nowrap;
}

.gallery-lightbox-close,
.gallery-lightbox-nav {
    position: absolute;
    z-index: 2;
    display: grid;
    place-items: center;
    border: 1px solid rgba(255, 255, 255, 0.28);
    color: #ffffff;
    background: rgba(255, 255, 255, 0.14);
    box-shadow: 0 18px 44px rgba(0, 0, 0, 0.24);
    backdrop-filter: blur(14px) saturate(160%);
    -webkit-backdrop-filter: blur(14px) saturate(160%);
    transition: transform 220ms var(--ease-out), background 220ms var(--ease-out);
}

.gallery-lightbox-close:hover,
.gallery-lightbox-nav:hover,
.gallery-lightbox-close:focus-visible,
.gallery-lightbox-nav:focus-visible {
    transform: scale(1.06);
    background: rgba(16, 185, 129, 0.74);
}

.gallery-lightbox-close {
    top: clamp(1rem, 3vw, 1.8rem);
    right: clamp(1rem, 3vw, 1.8rem);
    width: 48px;
    height: 48px;
    border-radius: 16px;
}

.gallery-lightbox-nav {
    top: 50%;
    width: 54px;
    height: 54px;
    border-radius: 50%;
    transform: translateY(-50%);
}

.gallery-lightbox-nav:hover,
.gallery-lightbox-nav:focus-visible {
    transform: translateY(-50%) scale(1.06);
}

.gallery-lightbox-nav.prev {
    left: clamp(1rem, 3vw, 2rem);
}

.gallery-lightbox-nav.next {
    right: clamp(1rem, 3vw, 2rem);
}

@keyframes gallery-loop {
    from { transform: translateX(0); }
    to { transform: translateX(-50%); }
}

/* Centered mode: few photos that don't fill the viewport */
.gallery-marquee--centered {
    -webkit-mask-image: none;
    mask-image: none;
}
.gallery-marquee--centered .gallery-track {
    animation: none;
    width: 100%;
    flex-wrap: wrap;
    justify-content: center;
    gap: 2rem;
    padding: 0.5rem 0;
}
.gallery-marquee--centered .gallery-item[aria-hidden="true"] {
    display: none;
}

@media (max-width: 991px) {
    .login-premium-section {
        padding: 1.5rem 0 2rem;
        min-height: auto;
    }

    .login-shell {
        grid-template-columns: 1fr;
        max-width: 620px;
    }

    .login-brand-panel {
        padding: 1.4rem 1.5rem;
    }

    .login-brand-panel p,
    .login-benefits {
        display: none;
    }

    .login-brand-mark {
        width: 48px;
        height: 48px;
        margin-bottom: 0.8rem;
    }

    .login-brand-panel h1 {
        font-size: 1.55rem;
        margin-bottom: 0;
    }

    .login-form-panel {
        padding: 1.5rem;
    }

    .leadership-grid {
        grid-template-columns: repeat(3, minmax(180px, 1fr));
        overflow-x: auto;
        scroll-snap-type: x mandatory;
        padding-bottom: 0.5rem;
    }

    .leadership-card { scroll-snap-align: start; }

    .testimonial-card { min-width: calc((100% - 1.125rem) / 2); }
}

@media (max-width: 639px) {
    .payment-qr-grid {
        grid-template-columns: 1fr;
    }

    .login-actions {
        grid-template-columns: 1fr;
    }

    .login-header h2 {
        font-size: 1.55rem;
    }

    .login-form-panel {
        padding: 1.25rem;
    }

    .leadership-showcase-section,
    .testimonials-section,
    .gallery-loop-section {
        padding: 3.25rem 0;
    }

    .leadership-grid {
        grid-template-columns: repeat(3, 78vw);
    }

    .testimonial-card {
        min-width: 100%;
        padding: 1.1rem;
    }

    .testimonial-card p { min-height: 7.5rem; }

    .gallery-item {
        width: min(82vw, 620px);
        border-radius: 22px;
    }

    .gallery-lightbox-stage {
        width: 86vw;
        border-radius: 24px;
    }

    .gallery-lightbox-nav {
        width: 48px;
        height: 48px;
    }
}

@media (max-width: 767.98px) {
    .gallery-lightbox {
        display: none !important;
    }
}


.section-header {
    margin-bottom: 3rem;
}

.section-title {
    font-family: var(--font-display);
    font-size: 1.85rem;
    font-weight: 800;
    letter-spacing: -0.03em;
    margin-bottom: 0.5rem;
    color: var(--text-heading);
}

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

.feature-card {
    background: rgba(255, 255, 255, 0.08);
    backdrop-filter: blur(24px) saturate(180%);
    -webkit-backdrop-filter: blur(24px) saturate(180%);
    border: 1px solid rgba(255, 255, 255, 0.15);
    border-radius: var(--radius-2xl);
    padding: 2.5rem;
    height: 100%;
    display: flex;
    flex-direction: column;
    transition: all var(--duration-normal) var(--ease-spring);
    box-shadow: 
        0 4px 12px rgba(0, 0, 0, 0.03),
        inset 0 0 0 1px rgba(255, 255, 255, 0.05);
}

.feature-card:hover {
    transform: translateY(-10px);
    background: rgba(255, 255, 255, 0.12);
    border-color: rgba(14, 165, 233, 0.3);
    box-shadow: 
        0 30px 60px rgba(0, 0, 0, 0.12),
        inset 0 0 0 2px rgba(255, 255, 255, 0.1);
}

.feature-icon-wrap {
    width: 56px;
    height: 56px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, rgba(14, 165, 233, 0.1), rgba(6, 182, 212, 0.05));
    border-radius: var(--radius-lg);
    font-size: 1.5rem;
    color: var(--primary-500);
    margin-bottom: 1.5rem;
    border: 1px solid rgba(14, 165, 233, 0.1);
    box-shadow: 0 4px 10px rgba(14, 165, 233, 0.15);
}



.feature-card h4 {
    font-family: var(--font-display);
    font-size: 1.05rem;
    font-weight: 700;
    margin-bottom: 0.6rem;
    color: var(--text-heading);
    letter-spacing: -0.02em;
}

.feature-card p {
    color: var(--text-secondary);
    font-size: 0.9rem;
    flex: 1;
    line-height: 1.6;
}

.feature-link {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    font-weight: 600;
    font-size: 0.875rem;
    color: var(--primary);
    margin-top: 1rem;
    transition: gap var(--duration-normal) var(--ease-spring);
}

.feature-link:hover { gap: 0.6rem; color: var(--primary-dark); }

/* ==============================
   CTA SECTION
   ============================== */
.cta-section {
    padding: 5rem 0;
}

.cta-card {
    padding: 4rem 3rem;
    background: linear-gradient(135deg, #0c0a09, #1c1917) !important;
    border: 1px solid rgba(14, 165, 233, 0.2) !important;
    border-radius: var(--radius-2xl) !important;
    position: relative;
    overflow: hidden;
    box-shadow: var(--shadow-xl);
}


.cta-card::before {
    content: '';
    position: absolute;
    top: -50%;
    right: -30%;
    width: 400px;
    height: 400px;
    background: radial-gradient(circle, rgba(29,228,195,0.15) 0%, transparent 70%);
    pointer-events: none;
}

.cta-card h2 {
    font-family: var(--font-display);
    font-size: 1.85rem;
    font-weight: 800;
    margin-bottom: 0.75rem;
    letter-spacing: -0.03em;
    color: #ffffff !important;
    filter: drop-shadow(0 0 10px rgba(255, 255, 255, 0.2));
}

.cta-card p {
    font-size: 1.1rem;
    color: rgba(255, 255, 255, 0.7) !important;
    margin-bottom: 2rem;
    font-weight: 500;
}


.cta-buttons {
    display: flex;
    gap: 0.75rem;
    justify-content: center;
    flex-wrap: wrap;
}

.cta-buttons .btn-glow {
    background: linear-gradient(135deg, var(--primary-400), var(--primary)) !important;
}

/* ==============================
   PAGE HEADER
   ============================== */
.page-header {
    background: linear-gradient(135deg, #0c0a09 0%, #075985 60%, var(--primary-dark) 100%);
    color: var(--text-inverse);
    padding: 2.5rem 0 2rem;
    margin-top: -70px;
    padding-top: calc(70px + 2rem);
    position: relative;
    border-bottom: 2px solid rgba(14, 165, 233, 0.2);
}


.page-header-compact {
    padding: 1.5rem 0 1.25rem;
    padding-top: calc(70px + 1.25rem);
}

.page-title {
    font-family: var(--font-display);
    font-size: 1.75rem;
    font-weight: 800;
    letter-spacing: -0.03em;
    margin-bottom: 0.2rem;
}

.page-subtitle {
    opacity: 0.75;
    font-size: 0.95rem;
    font-weight: 400;
}

.breadcrumb-custom {
    margin-bottom: 0;
}
.breadcrumb-custom .breadcrumb-item a { color: rgba(255,255,255,0.6); }
.breadcrumb-custom .breadcrumb-item.active { color: var(--text-inverse); }
.breadcrumb-custom .breadcrumb-item + .breadcrumb-item::before { color: rgba(255,255,255,0.4); }

/* ==============================
   CONTENT SECTION
   ============================== */
.content-section {
    padding: 2.5rem 0 4rem;
}

/* ==============================
   FILTER CARD
   ============================== */
.filter-card {
    padding: 1.5rem;
}

.filter-title {
    font-family: var(--font-display);
    font-size: 0.95rem;
    font-weight: 700;
    margin-bottom: 1.25rem;
    color: var(--text-heading);
    letter-spacing: -0.01em;
}

.sticky-filter {
    position: sticky;
    top: 85px;
}

/* ==============================
   HIERARCHY
   ============================== */
.hierarchy-card {
    padding: 2rem;
    border-left: 4px solid var(--accent-cyan);
}


.hierarchy-header {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin-bottom: 1.25rem;
    flex-wrap: wrap;
}

.rank-badge {
    background: var(--primary-50);
    color: var(--primary-dark);
    font-size: 0.7rem;
    font-weight: 700;
    padding: 0.2rem 0.65rem;
    border-radius: var(--radius-full);
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.hierarchy-title {
    font-family: var(--font-display);
    font-size: 1.1rem;
    font-weight: 700;
    margin: 0;
    flex: 1;
    color: var(--text-heading);
    letter-spacing: -0.02em;
}

.member-count-badge {
    font-size: 0.8rem;
    color: var(--text-muted);
    font-weight: 500;
    background: var(--bg-muted);
    padding: 0.2rem 0.6rem;
    border-radius: var(--radius-full);
}

.member-mini-card {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    padding: 0.85rem 1rem;
    background: var(--bg-subtle);
    border-radius: var(--radius-md);
    border: 1px solid var(--border-light);
    transition: all var(--duration-normal) var(--ease-out);
}



.member-mini-card:hover {
    background: var(--primary-50);
    border-color: var(--primary-200);
    transform: translateX(4px);
}

.member-mini-avatar img {
    width: 44px;
    height: 44px;
    border-radius: var(--radius-full);
    object-fit: cover;
}

.avatar-placeholder {
    width: 44px;
    height: 44px;
    border-radius: var(--radius-full);
    background: linear-gradient(135deg, var(--primary), var(--accent-cyan));
    color: var(--text-inverse);
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 1rem;
    text-transform: uppercase;
    flex-shrink: 0;
    box-shadow: var(--shadow-sm);
}


.avatar-large {
    width: 72px;
    height: 72px;
    font-size: 1.6rem;
}

.avatar-store {
    border-radius: 50%;
    width: 56px;
    height: 56px;
    font-size: 1.2rem;
}

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


.member-mini-info h6 {
    margin-bottom: 0.15rem;
    font-family: var(--font-display);
    font-weight: 600;
    font-size: 0.9rem;
    letter-spacing: -0.01em;
}

.member-mini-info h6 a {
    color: var(--text-heading);
}
.member-mini-info h6 a:hover { color: var(--primary); }

.member-mini-info p {
    font-size: 0.8rem;
    color: var(--text-secondary);
    margin: 0;
}

.admin-extra {
    padding-top: 0.4rem;
    border-top: 1px dashed var(--border);
    margin-top: 0.4rem;
}

.admin-extra small {
    color: var(--text-secondary);
    font-size: 0.78rem;
}

/* ==============================
   STORE CARDS
   ============================== */
.results-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.results-count {
    font-weight: 600;
    color: var(--text-secondary);
    font-size: 0.875rem;
}

.store-card {
    padding: 0;
    overflow: hidden;
    height: 100%;
    display: flex;
    flex-direction: column;
    transition: transform var(--duration-normal) var(--ease-spring),
                box-shadow var(--duration-normal) var(--ease-out);
}

.store-card:hover {
    transform: translateY(-4px);
}

.store-card-header {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    padding: 1.25rem 1.25rem 0;
}

.store-avatar img {
    width: 56px;
    height: 56px;
    border-radius: 50%;
    object-fit: cover;
    object-position: top center;
}

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

.store-name {
    font-family: var(--font-display);
    font-size: 0.95rem;
    font-weight: 700;
    margin-bottom: 0.1rem;
    letter-spacing: -0.01em;
}

.store-name a { color: var(--text-heading); }
.store-name a:hover { color: var(--primary); }

.store-owner {
    font-size: 0.8rem;
    color: var(--text-secondary);
}

.store-card-body {
    padding: 0.85rem 1.25rem;
    flex: 1;
}

.store-detail-row {
    display: flex;
    align-items: flex-start;
    gap: 0.45rem;
    margin-bottom: 0.4rem;
    font-size: 0.835rem;
    color: var(--text-secondary);
    line-height: 1.45;
}

.store-detail-row i {
    color: var(--primary);
    margin-top: 0.12rem;
    flex-shrink: 0;
    font-size: 0.85rem;
}

.store-badges {
    display: flex;
    gap: 0.4rem;
    flex-wrap: wrap;
    margin-top: 0.65rem;
}

.store-card-footer {
    padding: 0 1.25rem 1.25rem;
    margin-top: auto;
}

.store-card-footer .btn {
    font-size: 0.8rem;
    padding: 0.35rem 0.85rem;
}

.store-card-inactive {
    opacity: 0.94;
    border: 1px solid rgba(217, 119, 6, 0.24) !important;
    background:
        linear-gradient(135deg, rgba(255, 251, 235, 0.88), rgba(255, 255, 255, 0.9) 48%, rgba(236, 253, 245, 0.72)),
        var(--bg-card);
}

.store-card-inactive .store-avatar,
.store-card-inactive .store-card-body {
    filter: grayscale(0.08);
}

.store-card-distributor {
    position: relative;
    overflow: hidden;
    border: 1px solid rgba(20, 184, 166, 0.55) !important;
    background:
        linear-gradient(135deg, rgba(236, 253, 245, 0.98) 0%, rgba(240, 253, 250, 0.9) 48%, rgba(217, 249, 231, 0.72) 100%) !important;
    box-shadow:
        0 18px 38px rgba(6, 95, 70, 0.14),
        inset 0 0 0 1px rgba(255, 255, 255, 0.72);
}

.store-card-distributor::before {
    content: "";
    position: absolute;
    inset: 0 auto 0 0;
    width: 6px;
    background: linear-gradient(180deg, #0f766e, #10b981, #84cc16);
}

.store-card-distributor::after {
    content: "";
    position: absolute;
    right: -52px;
    top: -52px;
    width: 140px;
    height: 140px;
    border-radius: 999px;
    background: rgba(16, 185, 129, 0.14);
    pointer-events: none;
}

.store-card-distributor .store-card-header,
.store-card-distributor .store-card-body {
    position: relative;
    z-index: 1;
}

.store-card-distributor .avatar-placeholder,
.store-card-distributor .store-avatar img {
    border: 3px solid rgba(167, 243, 208, 0.95);
    box-shadow: 0 10px 22px rgba(5, 150, 105, 0.2);
}

.store-type-badge,
.distributor-id-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    width: fit-content;
    margin: 0.15rem 0 0.2rem;
    padding: 0.22rem 0.55rem;
    border-radius: 999px;
    color: #065f46;
    background: rgba(209, 250, 229, 0.92);
    border: 1px solid rgba(16, 185, 129, 0.26);
    font-weight: 850;
    font-size: 0.7rem;
}

.distributor-id-badge {
    margin: 0;
    color: #075985;
    background: rgba(224, 242, 254, 0.92);
    border-color: rgba(14, 165, 233, 0.24);
}

.inactive-store-link,
.inactive-owner-link {
    border: 0;
    padding: 0;
    background: transparent;
    color: inherit;
    font: inherit;
    text-align: left;
}

.inactive-store-link {
    font-weight: 800;
}

.inactive-store-link:hover,
.inactive-owner-link:hover {
    color: var(--primary-800);
    text-decoration: underline;
}

.inactive-store-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    color: #92400e;
    background: linear-gradient(135deg, #fff7ed, #ffedd5);
    border: 1px solid #fdba74;
    box-shadow: 0 8px 18px rgba(217, 119, 6, 0.12);
    text-transform: uppercase;
    letter-spacing: 0.015em;
    font-weight: 800;
}

.inactive-store-badge i {
    color: #d97706;
}

.inactive-store-button {
    border-radius: var(--radius-full);
    font-weight: 700;
    color: #92400e !important;
    background: rgba(255, 247, 237, 0.9) !important;
    border-color: rgba(217, 119, 6, 0.28) !important;
}

.inactive-store-button:hover {
    color: #78350f !important;
    background: #ffedd5 !important;
    border-color: rgba(217, 119, 6, 0.42) !important;
    box-shadow: 0 10px 24px rgba(217, 119, 6, 0.12);
}

.inactive-store-modal {
    position: relative;
    overflow: hidden;
    border: 1px solid rgba(217, 119, 6, 0.22);
    border-radius: 22px;
    background:
        linear-gradient(180deg, rgba(255, 251, 235, 0.96) 0, #ffffff 42%),
        #ffffff;
    box-shadow: 0 32px 90px rgba(15, 23, 42, 0.24);
}

.inactive-store-modal .modal-header {
    align-items: flex-start;
    padding: 1.25rem 3.8rem 0.85rem 1.35rem;
}

.inactive-store-modal .modal-title {
    color: var(--text-heading);
    font-weight: 800;
    letter-spacing: -0.02em;
}

.inactive-modal-heading {
    display: flex;
    align-items: center;
    gap: 0.85rem;
}

.inactive-modal-icon {
    width: 42px;
    height: 42px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
    color: #b45309;
    background: linear-gradient(135deg, #fffbeb, #fed7aa);
    border: 1px solid rgba(217, 119, 6, 0.22);
    border-radius: 14px;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.72), 0 12px 28px rgba(217, 119, 6, 0.14);
}

.inactive-modal-close {
    position: absolute;
    top: 1.15rem;
    right: 1.15rem;
    width: 34px;
    height: 34px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--text-secondary);
    background: rgba(255, 255, 255, 0.72);
    border: 1px solid rgba(148, 163, 184, 0.22);
    border-radius: 50%;
    z-index: 2;
    transition: all var(--duration-normal) var(--ease-out);
}

.inactive-modal-close:hover {
    color: var(--text-heading);
    background: #ffffff;
    box-shadow: var(--shadow-sm);
}

.inactive-store-modal .modal-body {
    padding: 0 1.35rem 0.8rem;
}

.inactive-modal-summary {
    padding: 1rem;
    border: 1px solid rgba(217, 119, 6, 0.18);
    border-radius: 16px;
    background: rgba(255, 247, 237, 0.72);
}

.inactive-summary-label {
    color: #b45309;
    font-size: 0.72rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    margin-bottom: 0.35rem;
}

.inactive-modal-summary p {
    color: var(--text-body);
    font-size: 0.94rem;
    line-height: 1.65;
    margin: 0;
}

.inactive-modal-summary strong {
    color: var(--text-heading);
}

.inactive-modal-note {
    color: var(--text-secondary);
    font-size: 0.88rem;
    line-height: 1.6;
    margin: 0.85rem 0 0;
}

.inactive-store-modal .modal-footer {
    gap: 0.5rem;
    padding: 0.25rem 1.35rem 1.3rem;
}

.modal-kicker {
    display: inline-flex;
    align-items: center;
    color: #b45309;
    font-size: 0.72rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    margin-bottom: 0.15rem;
}

/* ==============================
   PRODUCT CATALOG
   ============================== */
.catalog-shell {
    min-height: 100vh;
    padding: 2.5rem 0 4rem;
    background:
        linear-gradient(rgba(5, 150, 105, 0.035) 1px, transparent 1px),
        linear-gradient(90deg, rgba(37, 99, 235, 0.035) 1px, transparent 1px),
        radial-gradient(circle at 14% 12%, rgba(16, 185, 129, 0.13), transparent 30%),
        radial-gradient(circle at 86% 10%, rgba(59, 130, 246, 0.11), transparent 28%),
        #f8fafc;
    background-size: 34px 34px, 34px 34px, auto, auto, auto;
}

.catalog-toolbar {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 1.5rem;
    margin-bottom: 1.25rem;
}

.catalog-kicker {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    color: var(--primary-800);
    font-size: 0.78rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    margin-bottom: 0.35rem;
}

.catalog-title {
    color: var(--text-heading);
    font-size: clamp(1.85rem, 4vw, 3rem);
    font-weight: 800;
    letter-spacing: -0.02em;
    margin: 0;
}

.catalog-stats {
    display: flex;
    gap: 0.65rem;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.catalog-stats span {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    padding: 0.55rem 0.85rem;
    color: var(--text-secondary);
    background: rgba(255, 255, 255, 0.78);
    border: 1px solid rgba(5, 150, 105, 0.14);
    border-radius: var(--radius-full);
    box-shadow: 0 12px 28px rgba(15, 23, 42, 0.05);
}

.catalog-stats strong {
    color: var(--primary-800);
}

.catalog-controls {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 0.85rem;
    align-items: center;
    margin-bottom: 1.2rem;
}

.catalog-search {
    min-height: 54px;
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0 1rem;
    background: rgba(255, 255, 255, 0.86);
    border: 1px solid rgba(5, 150, 105, 0.16);
    border-radius: 18px;
    box-shadow: 0 18px 42px rgba(15, 23, 42, 0.06);
}

.catalog-search i {
    color: var(--primary-600);
}

.catalog-search input {
    min-width: 0;
    width: 100%;
    color: var(--text-heading);
    background: transparent;
    border: 0;
    outline: 0;
    font-weight: 600;
}

.catalog-search input::placeholder {
    color: var(--text-muted);
}

.catalog-clear {
    width: 30px;
    height: 30px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
    color: var(--text-secondary);
    background: rgba(241, 245, 249, 0.9);
    border-radius: 50%;
}

.catalog-actions {
    display: flex;
    gap: 0.55rem;
}

.catalog-action-btn {
    min-height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.45rem;
    padding: 0 0.9rem;
    color: var(--primary-800);
    background: rgba(255, 255, 255, 0.78);
    border: 1px solid rgba(5, 150, 105, 0.18);
    border-radius: var(--radius-full);
    font-weight: 800;
    box-shadow: 0 12px 28px rgba(15, 23, 42, 0.05);
    transition: all var(--duration-normal) var(--ease-out);
}

.catalog-action-btn:hover {
    color: #ffffff;
    background: var(--primary-700);
    border-color: var(--primary-700);
    transform: translateY(-1px);
}

.catalog-list {
    display: grid;
    gap: 0.9rem;
}

.catalog-company {
    overflow: hidden;
    background: rgba(255, 255, 255, 0.88);
    border: 1px solid rgba(5, 150, 105, 0.14);
    border-radius: 20px;
    box-shadow: 0 18px 45px rgba(15, 23, 42, 0.07);
}

.catalog-company-header {
    width: 100%;
    display: grid;
    grid-template-columns: 48px minmax(0, 1fr) 34px;
    gap: 0.85rem;
    align-items: center;
    padding: 1rem 1.05rem;
    text-align: left;
    background: transparent;
    border: 0;
}

.catalog-company-mark {
    width: 48px;
    height: 48px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #ffffff;
    background: linear-gradient(135deg, var(--primary-700), var(--accent-mint));
    border-radius: 16px;
    font-weight: 900;
    box-shadow: 0 16px 30px rgba(5, 150, 105, 0.2);
}

.catalog-company-meta {
    min-width: 0;
    display: grid;
    gap: 0.1rem;
}

.catalog-company-name {
    color: var(--text-heading);
    font-size: 1rem;
    font-weight: 850;
}

.catalog-company-count {
    color: var(--text-secondary);
    font-size: 0.82rem;
    font-weight: 650;
}

.catalog-chevron {
    width: 34px;
    height: 34px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--primary-800);
    background: rgba(236, 253, 245, 0.92);
    border-radius: 50%;
    transition: transform var(--duration-normal) var(--ease-out);
}

.catalog-company-header[aria-expanded="true"] .catalog-chevron {
    transform: rotate(180deg);
}

.catalog-products {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(315px, 1fr));
    gap: 0.75rem;
    padding: 0 1.05rem 1.15rem;
}

.catalog-product {
    min-height: 76px;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    gap: 0.75rem;
    padding: 0.86rem 0.95rem;
    color: var(--text-body);
    background:
        radial-gradient(circle at 92% 0%, rgba(167, 243, 208, 0.2), transparent 38%),
        linear-gradient(135deg, rgba(255, 255, 255, 0.94), rgba(236, 253, 245, 0.68));
    border: 1px solid rgba(5, 150, 105, 0.12);
    border-radius: 16px;
    font-weight: 700;
    text-decoration: none;
    transition: transform var(--duration-normal) var(--ease-out), border-color var(--duration-normal), box-shadow var(--duration-normal);
}

.catalog-product:hover {
    color: var(--text-heading);
    transform: translateY(-2px);
    border-color: rgba(5, 150, 105, 0.28);
    box-shadow: 0 16px 34px rgba(6, 95, 70, 0.09);
}

.catalog-product-main {
    min-width: 0;
    display: inline-flex;
    align-items: center;
    gap: 0.7rem;
}

.catalog-product .catalog-product-main > i {
    width: 2.2rem;
    height: 2.2rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #ffffff;
    background: linear-gradient(135deg, var(--primary-700), var(--primary-500));
    border-radius: 50%;
    box-shadow: 0 10px 22px rgba(5, 150, 105, 0.18);
}

.catalog-product-name {
    min-width: 0;
    display: block;
    overflow: hidden;
    color: var(--text-heading);
    font-size: 0.96rem;
    font-weight: 850;
    line-height: 1.25;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.catalog-product i {
    color: var(--primary-600);
    flex: 0 0 auto;
}

.catalog-product-distributors {
    display: inline-flex;
    align-items: center;
    gap: 0.32rem;
    flex: 0 0 auto;
    justify-self: end;
    min-height: 2rem;
    padding: 0.34rem 0.62rem;
    color: var(--primary-800);
    background: rgba(209, 250, 229, 0.78);
    border: 1px solid rgba(5, 150, 105, 0.14);
    border-radius: 999px;
    font-size: 0.72rem;
    font-weight: 850;
    white-space: nowrap;
}

.catalog-product-distributors i {
    color: var(--primary-700);
}

.catalog-empty {
    padding: 4rem 1rem;
    text-align: center;
    background: rgba(255, 255, 255, 0.82);
    border: 1px solid rgba(5, 150, 105, 0.12);
    border-radius: 22px;
    box-shadow: 0 18px 45px rgba(15, 23, 42, 0.06);
}

.catalog-empty i {
    color: var(--primary-600);
    font-size: 2rem;
}

.catalog-empty h3 {
    color: var(--text-heading);
    margin: 0.75rem 0 0.25rem;
    font-weight: 800;
}

.catalog-empty p {
    color: var(--text-secondary);
    margin: 0;
}

@media (max-width: 767.98px) {
    .catalog-shell {
        padding: 1.5rem 0 3rem;
    }

    .catalog-toolbar,
    .catalog-controls {
        grid-template-columns: 1fr;
        display: grid;
    }

    .catalog-stats,
    .catalog-actions {
        justify-content: flex-start;
    }

    .catalog-actions {
        overflow-x: auto;
        padding-bottom: 0.15rem;
    }

    .catalog-action-btn {
        white-space: nowrap;
    }

    .catalog-products {
        grid-template-columns: 1fr;
    }

    .catalog-product {
        grid-template-columns: minmax(0, 1fr) auto;
        min-height: 68px;
    }

    .catalog-product-distributors {
        font-size: 0.68rem;
        padding-inline: 0.5rem;
    }
}

.product-detail-shell {
    min-height: 100vh;
    padding: 2.5rem 0 4rem;
    background:
        linear-gradient(rgba(5, 150, 105, 0.035) 1px, transparent 1px),
        linear-gradient(90deg, rgba(5, 150, 105, 0.035) 1px, transparent 1px),
        radial-gradient(circle at 12% 12%, rgba(16, 185, 129, 0.14), transparent 30%),
        #f8fafc;
    background-size: 34px 34px, 34px 34px, auto, auto;
}

.product-detail-hero {
    margin-bottom: 1.1rem;
    padding: clamp(1.15rem, 2.6vw, 1.8rem);
    background:
        radial-gradient(circle at 88% 8%, rgba(167, 243, 208, 0.28), transparent 32%),
        rgba(255, 255, 255, 0.88);
    border: 1px solid rgba(5, 150, 105, 0.14);
    border-radius: 24px;
    box-shadow: 0 22px 58px rgba(6, 95, 70, 0.09);
}

.product-back-link {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    margin-bottom: 1.15rem;
    color: var(--primary-800);
    font-weight: 800;
    text-decoration: none;
}

.product-detail-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 1.2rem;
    align-items: center;
}

.product-company-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    max-width: 100%;
    padding: 0.58rem 0.85rem;
    color: var(--primary-900);
    background:
        linear-gradient(135deg, rgba(209, 250, 229, 0.96), rgba(255, 255, 255, 0.82));
    border: 1px solid rgba(5, 150, 105, 0.18);
    border-radius: 999px;
    box-shadow: 0 12px 28px rgba(6, 95, 70, 0.08);
    font-size: 0.82rem;
    font-weight: 900;
    text-transform: uppercase;
}

.product-company-badge i {
    color: var(--primary-600);
}

.product-company-badge span {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.product-detail-title {
    max-width: 920px;
    margin: 0.85rem 0 0;
    color: var(--text-heading);
    font-size: clamp(2rem, 4.3vw, 3.25rem);
    font-weight: 900;
    line-height: 1.08;
}

.product-detail-copy {
    max-width: 620px;
    margin: 0.85rem 0 0;
    color: var(--text-secondary);
    font-size: 1rem;
    line-height: 1.65;
}

.product-detail-stat {
    min-width: 142px;
    padding: 0.95rem;
    display: grid;
    justify-items: center;
    gap: 0.15rem;
    color: var(--primary-900);
    background: linear-gradient(135deg, var(--primary-50), #ffffff);
    border: 1px solid rgba(5, 150, 105, 0.14);
    border-radius: 20px;
}

.product-detail-stat i {
    color: var(--primary-600);
    font-size: 1.3rem;
}

.product-detail-stat strong {
    font-size: 2rem;
    line-height: 1;
}

.product-detail-stat span {
    color: var(--text-secondary);
    font-weight: 800;
    text-align: center;
}

.distributor-filter-bar {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 0.65rem;
    margin: 0 0 1rem;
    padding: 0.75rem;
    background: rgba(255, 255, 255, 0.86);
    border: 1px solid rgba(5, 150, 105, 0.12);
    border-radius: 18px;
    box-shadow: 0 16px 38px rgba(15, 23, 42, 0.05);
}

.distributor-filter-bar label {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    margin: 0;
    color: var(--primary-900);
    font-size: 0.82rem;
    font-weight: 900;
}

.distributor-filter-bar select {
    min-width: 190px;
    min-height: 42px;
    padding: 0 0.85rem;
    color: var(--text-heading);
    background: var(--primary-50);
    border: 1px solid rgba(5, 150, 105, 0.18);
    border-radius: 999px;
    font-weight: 800;
}

.distributor-filter-bar a {
    color: var(--primary-700);
    font-weight: 850;
    text-decoration: none;
}

.distributor-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 340px), 1fr));
    gap: 1.1rem;
    max-width: 1280px;
}

.distributor-card {
    position: relative;
    display: grid;
    grid-template-rows: auto 1fr auto;
    gap: 1.05rem;
    min-height: 100%;
    padding: 1.1rem;
    overflow: hidden;
    background:
        radial-gradient(circle at 100% 0%, rgba(167, 243, 208, 0.32), transparent 34%),
        linear-gradient(135deg, rgba(236, 253, 245, 0.98) 0%, rgba(255, 255, 255, 0.94) 52%, rgba(240, 253, 250, 0.9) 100%);
    border: 1px solid rgba(20, 184, 166, 0.44);
    border-radius: 22px;
    box-shadow: 0 18px 45px rgba(6, 95, 70, 0.1);
    transition: transform var(--duration-normal) var(--ease-out), box-shadow var(--duration-normal), border-color var(--duration-normal);
}

.distributor-card::before {
    content: "";
    position: absolute;
    inset: 0 auto 0 0;
    width: 6px;
    background: linear-gradient(180deg, #0f766e, #10b981, #84cc16);
}

.distributor-card::after {
    content: "";
    position: absolute;
    right: -50px;
    top: -50px;
    width: 140px;
    height: 140px;
    border-radius: 999px;
    background: rgba(16, 185, 129, 0.12);
    pointer-events: none;
}

.distributor-card:hover {
    transform: translateY(-3px);
    border-color: rgba(5, 150, 105, 0.34);
    box-shadow: 0 24px 58px rgba(6, 95, 70, 0.12);
}

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

.distributor-card-top {
    display: grid;
    grid-template-columns: 64px minmax(0, 1fr);
    gap: 0.85rem;
    align-items: center;
}

.distributor-avatar {
    width: 64px;
    height: 64px;
    display: grid;
    place-items: center;
    overflow: hidden;
    color: #ffffff;
    background: linear-gradient(135deg, var(--primary-700), var(--primary-400));
    border-radius: 18px;
    border: 3px solid rgba(167, 243, 208, 0.95);
    font-size: 1.4rem;
    font-weight: 900;
    box-shadow: 0 14px 28px rgba(6, 95, 70, 0.2);
}

.distributor-avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.distributor-heading {
    min-width: 0;
}

.distributor-heading-badges {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.35rem;
    margin-bottom: 0.3rem;
}

.distributor-member-id {
    display: inline-flex;
    margin: 0;
    padding: 0.22rem 0.5rem;
    color: var(--primary-800);
    background: rgba(209, 250, 229, 0.82);
    border: 1px solid rgba(16, 185, 129, 0.24);
    border-radius: 999px;
    font-size: 0.68rem;
    font-weight: 900;
}

.distributor-heading h2 {
    margin: 0;
    color: var(--text-heading);
    font-size: 1.02rem;
    font-weight: 900;
}

.distributor-heading p {
    margin: 0.18rem 0 0;
    color: var(--text-secondary);
    font-size: 0.86rem;
    font-weight: 700;
}

.distributor-info-list {
    display: grid;
    gap: 0.5rem;
    align-content: start;
}

.distributor-info {
    display: grid;
    grid-template-columns: 28px minmax(0, 1fr);
    gap: 0.55rem;
    align-items: start;
    color: var(--text-body);
    font-size: 0.88rem;
    line-height: 1.5;
}

.distributor-info i {
    color: var(--primary-600);
}

.distributor-actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.55rem;
}

.distributor-action {
    min-height: 46px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.45rem;
    padding: 0 0.85rem;
    color: var(--primary-800);
    text-decoration: none;
    background: var(--primary-50);
    border: 1px solid rgba(5, 150, 105, 0.14);
    border-radius: 999px;
    font-size: 0.9rem;
    font-weight: 850;
    white-space: nowrap;
}

.distributor-action.primary {
    color: #ffffff;
    background: var(--primary-700);
    border-color: var(--primary-700);
}

.distributor-empty {
    margin-top: 1rem;
    position: relative;
    overflow: hidden;
    padding: clamp(3rem, 7vw, 5rem) 1.5rem;
    background:
        radial-gradient(circle at 50% 0%, rgba(167, 243, 208, 0.26), transparent 34%),
        linear-gradient(135deg, rgba(255,255,255,0.94), rgba(236, 253, 245, 0.76));
    border-style: solid;
}

.distributor-empty::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,0.4), transparent);
    transform: translateX(-120%);
    animation: distributorEmptySheen 3.6s ease-in-out infinite;
}

.distributor-empty-icon {
    width: 4rem;
    height: 4rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #ffffff;
    background: linear-gradient(135deg, var(--primary-700), var(--primary-500));
    border-radius: 50%;
    box-shadow: 0 18px 38px rgba(6, 95, 70, 0.18);
}

.distributor-empty-icon i {
    color: #ffffff;
    font-size: 1.55rem;
}

@keyframes distributorEmptySheen {
    0%, 46% { transform: translateX(-120%); }
    78%, 100% { transform: translateX(120%); }
}

@media (max-width: 767.98px) {
    .product-detail-grid {
        grid-template-columns: 1fr;
    }

    .product-detail-stat {
        justify-items: start;
    }

    .distributor-filter-bar {
        align-items: stretch;
        flex-direction: column;
    }

    .distributor-filter-bar select {
        width: 100%;
    }

    .distributor-grid {
        grid-template-columns: 1fr;
        max-width: none;
    }

    .distributor-actions {
        grid-template-columns: 1fr;
    }
}

/* ==============================
   DETAIL PAGE
   ============================== */
.detail-card {
    padding: 2.5rem;
}

.detail-header {
    display: flex;
    align-items: center;
    gap: 1.5rem;
    flex-wrap: wrap;
}

.detail-avatar img {
    width: 90px;
    height: 90px;
    border-radius: var(--radius-lg);
    object-fit: cover;
    border: 3px solid var(--border);
}

.detail-title h1 {
    font-family: var(--font-display);
    font-size: 1.4rem;
    font-weight: 800;
    margin-bottom: 0.2rem;
    letter-spacing: -0.02em;
    color: var(--text-heading);
}

.detail-title h5 { margin-bottom: 0.5rem; color: var(--text-secondary); font-weight: 500; }

.detail-badges { display: flex; gap: 0.4rem; }

.detail-divider {
    margin: 1.5rem 0;
    border-color: var(--border);
}

.detail-section { margin-bottom: 1.75rem; }

.detail-section-title {
    font-family: var(--font-display);
    font-size: 0.9rem;
    font-weight: 700;
    color: var(--primary);
    margin-bottom: 1rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
    letter-spacing: -0.01em;
}

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

.detail-item {
    padding: 0.65rem 0.85rem;
    background: var(--bg-subtle);
    border-radius: var(--radius-sm);
    border: 1px solid var(--border-light);
}

.detail-item.full-width { grid-column: 1 / -1; }

.detail-label {
    display: block;
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--text-muted);
    font-weight: 600;
    margin-bottom: 0.15rem;
}

.detail-value {
    font-weight: 600;
    color: var(--text-heading);
    font-size: 0.9rem;
}

.admin-section {
    background: rgba(251,191,36,0.06);
    padding: 1.25rem;
    border-radius: var(--radius-md);
    border: 1px solid rgba(251,191,36,0.2);
}

.detail-actions {
    margin-top: 2rem;
    padding-top: 1.5rem;
    border-top: 1px solid var(--border);
}

/* ==============================
   AUTH PAGES
   ============================== */
.auth-section {
    padding: 3rem 0 5rem;
    min-height: 80vh;
    display: flex;
    align-items: center;
}

.signup-section { padding-top: 2rem; }

.auth-card {
    padding: 2.5rem;
    border-radius: var(--radius-xl);
}

.auth-header {
    margin-bottom: 2rem;
    text-align: center;
}

.auth-icon {
    width: 64px;
    height: 64px;
    margin: 0 auto 1rem;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, var(--primary-50), var(--primary-100));
    border-radius: var(--radius-lg);
    font-size: 1.6rem;
    color: var(--primary);
}

.auth-icon-verify {
    background: linear-gradient(135deg, #ede9fe, #ddd6fe);
    color: var(--secondary);
}

.auth-icon-signup {
    background: linear-gradient(135deg, #dcfce7, #bbf7d0);
    color: #16a34a;
}

.auth-header h2 {
    font-family: var(--font-display);
    font-size: 1.35rem;
    font-weight: 800;
    margin-bottom: 0.35rem;
    letter-spacing: -0.02em;
    color: var(--text-heading);
}

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

.auth-footer {
    margin-top: 1.75rem;
    padding-top: 1.5rem;
    border-top: 1px solid var(--border);
    text-align: center;
}

.auth-footer p {
    color: var(--text-muted);
    margin-bottom: 0.6rem;
    font-size: 0.875rem;
}

/* Steps Indicator */
.steps-indicator {
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 1.75rem;
}

.step {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.2rem;
}

.step-number {
    width: 34px;
    height: 34px;
    border-radius: var(--radius-full);
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 0.8rem;
    background: var(--bg-muted);
    color: var(--text-muted);
    border: 2px solid var(--border);
    transition: all var(--duration-normal);
}

.step.active .step-number {
    background: var(--primary);
    color: var(--text-inverse);
    border-color: var(--primary);
    box-shadow: 0 0 0 4px var(--primary-100);
}

.step.completed .step-number {
    background: #16a34a;
    color: var(--text-inverse);
    border-color: #16a34a;
}

.step span {
    font-size: 0.7rem;
    color: var(--text-muted);
    font-weight: 500;
}

.step.active span { color: var(--primary); font-weight: 600; }
.step.completed span { color: #16a34a; }

.step-line {
    width: 50px;
    height: 2px;
    background: var(--border);
    margin: 0 0.4rem 1rem;
}

.step-line.active {
    background: linear-gradient(90deg, #16a34a, var(--primary));
}

/* Form Sections */
.form-section {
    margin-bottom: 1.5rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid var(--border-light);
}

.form-section:last-of-type { border-bottom: none; }

.form-section-title {
    font-family: var(--font-display);
    font-size: 0.9rem;
    font-weight: 700;
    color: var(--primary);
    margin-bottom: 1rem;
    display: flex;
    align-items: center;
    gap: 0.45rem;
    letter-spacing: -0.01em;
}

.pc-entry {
    padding: 1rem 0;
    border-bottom: 1px solid var(--border-light);
}

.pc-entry:first-child { padding-top: 0; }

.pc-entry:last-child {
    padding-bottom: 0;
    border-bottom: 0;
}

.undertaking-box {
    padding: 1rem 1.1rem;
    border: 1.5px solid rgba(5, 150, 105, 0.18);
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.72);
}

.undertaking-box .form-check {
    display: flex;
    gap: 0.75rem;
    align-items: flex-start;
    padding-left: 0;
}

.undertaking-box .form-check-input {
    float: none;
    margin: 0.2rem 0 0;
    width: 1.1rem;
    height: 1.1rem;
    flex: 0 0 auto;
}

.undertaking-box .form-check-label {
    color: var(--text-body);
    font-weight: 600;
    line-height: 1.55;
}

.login-premium-section {
    min-height: calc(100vh - 86px);
    padding: 2.25rem 0;
    align-items: center;
}

.login-shell {
    width: min(1040px, 100%);
    margin: 0 auto;
    display: grid;
    grid-template-columns: 0.92fr 1.08fr;
    border: 1px solid rgba(5, 150, 105, 0.14);
    border-radius: 24px;
    overflow: hidden;
    background: rgba(255, 255, 255, 0.88);
    box-shadow: 0 26px 70px rgba(6, 95, 70, 0.12);
}

.login-brand-panel {
    padding: 2.2rem;
    background:
        linear-gradient(145deg, rgba(4, 120, 87, 0.96), rgba(6, 95, 70, 0.92)),
        radial-gradient(circle at 15% 15%, rgba(255,255,255,0.2), transparent 32%);
    color: #fff;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.login-brand-mark {
    width: 58px;
    height: 58px;
    border-radius: 18px;
    display: grid;
    place-items: center;
    background: rgba(255,255,255,0.14);
    border: 1px solid rgba(255,255,255,0.22);
    font-size: 1.55rem;
    margin-bottom: 1.1rem;
}

.login-kicker {
    display: inline-flex;
    width: fit-content;
    padding: 0.35rem 0.7rem;
    border-radius: 999px;
    background: rgba(255,255,255,0.13);
    font-size: 0.75rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin-bottom: 0.85rem;
}

.login-brand-panel h1 {
    font-size: clamp(1.8rem, 2.7vw, 2.8rem);
    line-height: 1.04;
    font-weight: 850;
    letter-spacing: 0;
    margin-bottom: 0.85rem;
}

.login-brand-panel p {
    color: rgba(255,255,255,0.82);
    line-height: 1.65;
    margin-bottom: 1.35rem;
}

.login-benefits {
    display: grid;
    gap: 0.65rem;
}

.login-benefits span {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    color: rgba(255,255,255,0.9);
    font-weight: 700;
    font-size: 0.92rem;
}

.login-form-panel {
    padding: 2.15rem 2.4rem;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.login-header {
    text-align: left;
    margin-bottom: 1.35rem;
}

.login-header h2 {
    font-size: 1.8rem;
    margin-bottom: 0.25rem;
}

.login-form .login-field {
    margin-bottom: 1rem;
}

.login-form .form-control {
    min-height: 50px;
}

.login-form input[type="email"],
.login-form input[type="password"] {
    min-height: 50px;
    border-radius: var(--radius-lg);
}

.login-forgot-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    margin: -0.2rem 0 1rem;
    color: var(--text-muted);
    font-size: 0.86rem;
    font-weight: 650;
}

.login-forgot-row a {
    color: var(--primary-700);
    font-weight: 850;
    text-decoration: none;
}

.login-forgot-row a:hover {
    color: var(--primary-900);
    text-decoration: underline;
}

.login-submit {
    min-height: 52px;
    margin: 0.25rem 0 1rem;
}

.login-actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.8rem;
}

.login-action-card {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.9rem;
    border: 1.5px solid rgba(5, 150, 105, 0.16);
    border-radius: 16px;
    background: rgba(255,255,255,0.76);
    color: var(--text-heading);
    text-decoration: none;
    transition: all var(--duration-normal) var(--ease-out);
}

.login-action-card:hover {
    transform: translateY(-2px);
    border-color: rgba(5, 150, 105, 0.34);
    box-shadow: 0 12px 28px rgba(6, 95, 70, 0.1);
    color: var(--primary-800);
}

.login-action-card i {
    width: 38px;
    height: 38px;
    border-radius: 12px;
    display: grid;
    place-items: center;
    background: rgba(5, 150, 105, 0.1);
    color: var(--primary);
    flex: 0 0 auto;
    font-size: 1.05rem;
}

.login-action-primary {
    background: rgba(209, 250, 229, 0.58);
}

.login-action-card strong {
    display: block;
    font-size: 0.9rem;
    line-height: 1.15;
}

.login-action-card span span,
.login-action-card span {
    font-size: 0.82rem;
    color: var(--text-secondary);
}

.account-type-switch {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.45rem;
    padding: 0.42rem;
    margin: 0 0 1rem;
    border: 1px solid rgba(15, 23, 42, 0.08);
    border-radius: 16px;
    background: rgba(248, 250, 252, 0.86);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.85);
}

.account-type-option {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.45rem;
    min-height: 44px;
    padding: 0.62rem 0.75rem;
    border-radius: 12px;
    color: #475569;
    font-weight: 850;
    text-decoration: none;
    transition: all 0.18s ease;
}

.account-type-option i {
    font-size: 1rem;
}

.account-type-option:hover {
    color: var(--primary-800);
    background: rgba(5, 150, 105, 0.08);
    text-decoration: none;
}

.account-type-option.active {
    color: #ffffff;
    background: linear-gradient(135deg, #059669, #0f766e);
    box-shadow: 0 10px 24px rgba(5, 150, 105, 0.22);
}

.account-type-switch-form {
    max-width: 420px;
    margin-left: auto;
    margin-right: auto;
}

.nms-account-switch {
    width: min(420px, 100%);
    margin: 1.1rem auto 1rem;
    background: rgba(255, 255, 255, 0.92);
}

.license-card-stack {
    display: grid;
    gap: 0.9rem;
    margin-bottom: 1rem;
}

.license-card {
    border: 1.5px solid rgba(5, 150, 105, 0.18);
    border-radius: 18px;
    overflow: hidden;
    background: rgba(255, 255, 255, 0.74);
    box-shadow: 0 14px 32px rgba(6, 95, 70, 0.07);
}

.license-card-toggle {
    width: 100%;
    min-height: 68px;
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto auto auto;
    align-items: center;
    gap: 0.8rem;
    padding: 0.85rem 1rem;
    border: 0;
    background: linear-gradient(135deg, rgba(209, 250, 229, 0.96), rgba(236, 253, 245, 0.98));
    color: #064e3b;
    text-align: left;
    transition: all 0.18s ease;
}

.license-card-toggle.collapsed {
    background: linear-gradient(135deg, #059669, #0f766e);
    color: #ffffff;
}

.license-card-toggle:hover {
    filter: saturate(1.05);
}

.license-card-icon {
    width: 42px;
    height: 42px;
    display: grid;
    place-items: center;
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.22);
    color: currentColor;
    font-size: 1.08rem;
    flex: 0 0 auto;
}

.license-card-title {
    min-width: 0;
    font-size: 1rem;
    font-weight: 900;
    line-height: 1.15;
}

.license-card-summary {
    justify-self: end;
    color: currentColor;
    opacity: 0.78;
    font-size: 0.78rem;
    font-weight: 750;
    white-space: nowrap;
}

.license-card-chevron {
    transition: transform 0.18s ease;
}

.license-card-toggle:not(.collapsed) .license-card-chevron {
    transform: rotate(180deg);
}

.license-card-body {
    padding: 1rem;
    background: rgba(255, 255, 255, 0.86);
    border-top: 1px solid rgba(5, 150, 105, 0.12);
}

.license-card-toggle .license-status-chip {
    justify-self: end;
}

.license-card-toggle.collapsed .license-status-valid {
    color: #dcfce7;
    background: rgba(5, 46, 34, 0.32);
    border-color: rgba(220, 252, 231, 0.28);
}

.license-card-toggle.collapsed .license-status-warning {
    color: #fef3c7;
    background: rgba(120, 53, 15, 0.38);
    border-color: rgba(254, 243, 199, 0.28);
}

.license-card-toggle.collapsed .license-status-critical {
    color: #fee2e2;
    background: rgba(127, 29, 29, 0.4);
    border-color: rgba(254, 226, 226, 0.26);
}

.license-card-toggle.collapsed .license-status-expired {
    color: #ffffff;
    background: rgba(127, 29, 29, 0.88);
    border-color: rgba(254, 202, 202, 0.28);
}

.license-card-toggle.collapsed .license-status-pending {
    color: #f8fafc;
    background: rgba(71, 85, 105, 0.38);
    border-color: rgba(226, 232, 240, 0.24);
}

.payment-qr-grid {
    display: grid;
    grid-template-columns: 0.75fr 1.25fr;
    gap: 1rem;
}

.payment-qr-card,
.payment-help-card {
    border: 1.5px solid rgba(5, 150, 105, 0.16);
    border-radius: 16px;
    background: rgba(255,255,255,0.74);
    padding: 1rem;
}

.payment-qr-card {
    text-align: center;
    display: grid;
    justify-items: center;
    gap: 0.55rem;
}

.membership-fee-badge {
    width: 100%;
    display: grid;
    gap: 0.1rem;
    padding: 0.85rem 1rem;
    color: #ffffff;
    background:
        radial-gradient(circle at 90% 10%, rgba(167, 243, 208, 0.32), transparent 32%),
        linear-gradient(135deg, var(--primary-800), var(--primary-600));
    border-radius: 16px;
    box-shadow: 0 16px 34px rgba(6, 95, 70, 0.18);
}

.membership-fee-badge span {
    font-size: 0.72rem;
    font-weight: 850;
    text-transform: uppercase;
    opacity: 0.82;
}

.membership-fee-badge strong {
    font-size: clamp(1.55rem, 4vw, 2.3rem);
    line-height: 1;
}

.payment-qr-box {
    width: 156px;
    height: 156px;
    display: grid;
    place-items: center;
    border-radius: 14px;
    background:
        linear-gradient(90deg, #0f5132 10px, transparent 10px) 0 0 / 22px 22px,
        linear-gradient(#0f5132 10px, transparent 10px) 0 0 / 22px 22px,
        #fff;
    border: 10px solid #fff;
    box-shadow: inset 0 0 0 2px rgba(5, 150, 105, 0.2), 0 12px 28px rgba(6, 95, 70, 0.1);
}

.payment-qr-image {
    width: min(100%, 260px);
    height: auto;
    object-fit: contain;
    border-radius: 14px;
    background: #fff;
    padding: 0.55rem;
    box-shadow: inset 0 0 0 2px rgba(5, 150, 105, 0.16), 0 12px 28px rgba(6, 95, 70, 0.1);
}

.payment-qr-box i {
    font-size: 3rem;
    color: var(--primary-800);
    background: #fff;
    padding: 0.4rem;
    border-radius: 10px;
}

.payment-help-card ol {
    margin: 0.55rem 0 1rem;
    padding-left: 1.2rem;
    color: var(--text-secondary);
}

.pending-approval-form {
    min-width: 180px;
}

/* ==============================
   DASHBOARD
   ============================== */
.dashboard-card {
    padding: 1.5rem;
    text-align: center;
    height: 100%;
}

.dashboard-card-icon { margin-bottom: 1rem; }

.dashboard-avatar {
    width: 72px;
    height: 72px;
    border-radius: var(--radius-full);
    object-fit: cover;
    border: 3px solid var(--border);
}

.dashboard-card-header {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    margin-bottom: 1rem;
    text-align: left;
}

.dashboard-card-header i {
    font-size: 1.3rem;
    color: var(--primary);
}

.dashboard-card-header h5 {
    margin: 0;
    font-family: var(--font-display);
    font-weight: 700;
    font-size: 0.95rem;
    letter-spacing: -0.01em;
    color: var(--text-heading);
}

.dashboard-info { text-align: left; }

.info-row {
    display: flex;
    justify-content: space-between;
    padding: 0.5rem 0;
    border-bottom: 1px solid var(--border-light);
    font-size: 0.85rem;
}

.info-row:last-child { border-bottom: none; }

.info-label { color: var(--text-muted); font-weight: 500; }

.info-value {
    color: var(--text-heading);
    font-weight: 600;
    text-align: right;
    max-width: 60%;
}

.license-dashboard-card,
.distributor-license-panel {
    position: relative;
    overflow: hidden;
    text-align: left;
}

.license-dashboard-card::before,
.distributor-license-panel::before {
    content: "";
    position: absolute;
    inset: 0 0 auto 0;
    height: 4px;
    background: linear-gradient(90deg, #10b981, #22c55e);
}

.license-dashboard-warning::before { background: linear-gradient(90deg, #f59e0b, #facc15); }
.license-dashboard-critical::before { background: linear-gradient(90deg, #f97316, #ef4444); }
.license-dashboard-expired::before { background: linear-gradient(90deg, #991b1b, #ef4444); }
.license-dashboard-pending::before { background: linear-gradient(90deg, #64748b, #94a3b8); }

.license-dashboard-header {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto auto;
    align-items: center;
    gap: 0.7rem;
    margin-bottom: 0;
    padding: 1rem 1.1rem;
    cursor: pointer;
    list-style: none;
    user-select: none;
}

.distributor-license-panel.license-dashboard-card {
    padding: 0; /* details wrapper — body has its own padding */
}

details.distributor-license-panel > summary.license-dashboard-header::-webkit-details-marker {
    display: none;
}

.license-dashboard-chevron {
    width: 36px;
    height: 36px;
    display: grid;
    place-items: center;
    border-radius: 12px;
    background: rgba(16, 185, 129, 0.14);
    color: #047857;
    font-size: 0.95rem;
    transition: transform 220ms ease, background 200ms ease;
    flex-shrink: 0;
}

details.distributor-license-panel[open] .license-dashboard-chevron {
    transform: rotate(180deg);
    background: linear-gradient(135deg, #10b981, #047857);
    color: white;
}

.license-dashboard-body {
    padding: 0 1.1rem 1.1rem;
    display: grid;
    gap: 1rem;
    animation: licenseBodyFadeIn 280ms cubic-bezier(0.2, 0.8, 0.2, 1);
}

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

.license-dashboard-header h5 {
    line-height: 1.1;
}

.license-dashboard-header small {
    display: block;
    margin-top: 0.16rem;
    color: #64748b;
    font-size: 0.74rem;
    font-weight: 700;
}

.license-dashboard-icon {
    width: 42px;
    height: 42px;
    display: grid;
    place-items: center;
    border-radius: 14px;
    color: #047857;
    background: rgba(209, 250, 229, 0.9);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.85);
}

.license-status-chip {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.24rem;
    width: fit-content;
    min-height: 24px;
    padding: 0.18rem 0.55rem;
    border-radius: 999px;
    font-size: 0.66rem;
    font-weight: 950;
    line-height: 1;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    white-space: nowrap;
    border: 1px solid transparent;
}

.license-status-valid {
    color: #047857;
    background: rgba(187, 247, 208, 0.82);
    border-color: rgba(34, 197, 94, 0.24);
}

.license-status-warning {
    color: #92400e;
    background: rgba(254, 243, 199, 0.94);
    border-color: rgba(245, 158, 11, 0.28);
}

.license-status-critical {
    color: #991b1b;
    background: rgba(254, 226, 226, 0.95);
    border-color: rgba(239, 68, 68, 0.26);
}

.license-status-expired {
    color: #ffffff;
    background: #991b1b;
    border-color: rgba(127, 29, 29, 0.32);
}

.license-status-pending {
    color: #475569;
    background: rgba(226, 232, 240, 0.95);
    border-color: rgba(148, 163, 184, 0.3);
}

.license-owner-strip {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.65rem;
    margin-bottom: 0.75rem;
}

.license-owner-strip div,
.license-identity-row {
    min-width: 0;
    padding: 0.68rem 0.75rem;
    border: 1px solid rgba(16, 185, 129, 0.13);
    border-radius: 14px;
    background: rgba(248, 250, 252, 0.76);
}

.license-owner-strip span,
.license-identity-row span {
    display: flex;
    align-items: center;
    gap: 0.35rem;
    color: #64748b;
    font-size: 0.67rem;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.license-owner-strip strong,
.license-identity-row strong {
    display: block;
    margin-top: 0.18rem;
    color: #0f172a;
    font-size: 0.82rem;
    font-weight: 850;
    overflow-wrap: anywhere;
}

.license-overview-grid {
    display: grid;
    gap: 0.58rem;
}

.license-overview-card {
    display: grid;
    gap: 0.34rem;
    padding: 0.72rem;
    border-radius: 16px;
    border: 1px solid rgba(148, 163, 184, 0.2);
    background: rgba(248, 250, 252, 0.82);
}

.license-overview-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.6rem;
}

.license-overview-title {
    color: #475569;
    font-size: 0.7rem;
    font-weight: 950;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.license-overview-card strong {
    color: #0f172a;
    font-size: 0.92rem;
    font-weight: 900;
    overflow-wrap: anywhere;
}

.license-overview-card small {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
    color: #475569;
    font-size: 0.76rem;
    font-weight: 650;
    line-height: 1.35;
}

.license-overview-card em {
    flex: 0 0 auto;
    font-style: normal;
    font-weight: 900;
}

.license-overview-valid {
    background: rgba(220, 252, 231, 0.7);
    border-color: rgba(34, 197, 94, 0.22);
}

.license-overview-warning {
    background: rgba(254, 243, 199, 0.78);
    border-color: rgba(245, 158, 11, 0.28);
}

.license-overview-critical {
    background: rgba(254, 226, 226, 0.84);
    border-color: rgba(239, 68, 68, 0.26);
}

.license-overview-expired {
    background: rgba(254, 242, 242, 0.95);
    border-color: rgba(153, 27, 27, 0.3);
}

.license-overview-pending {
    background: rgba(248, 250, 252, 0.9);
    border-color: rgba(148, 163, 184, 0.22);
}

.license-overview-valid em { color: #047857; }
.license-overview-warning em { color: #92400e; }
.license-overview-critical em,
.license-overview-expired em { color: #991b1b; }
.license-overview-pending em { color: #475569; }

.license-identity-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    margin-top: 0.75rem;
}

.license-identity-row strong {
    margin-top: 0;
    text-align: right;
}

.license-update-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.45rem;
    width: 100%;
    min-height: 40px;
    margin-top: 0.85rem;
    padding: 0.56rem 0.85rem;
    border: 1.5px solid rgba(5, 150, 105, 0.26);
    border-radius: 999px;
    color: #065f46;
    background: rgba(255, 255, 255, 0.86);
    font-size: 0.86rem;
    font-weight: 900;
    text-decoration: none;
    box-shadow: 0 10px 22px rgba(6, 95, 70, 0.08);
    transition: transform 160ms ease, border-color 160ms ease, background 160ms ease;
}

.license-update-btn:hover {
    color: #064e3b;
    background: rgba(236, 253, 245, 0.98);
    border-color: rgba(5, 150, 105, 0.42);
    transform: translateY(-1px);
}

button.license-update-btn {
    cursor: pointer;
}

.pc-dashboard-row {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.75rem 0;
    border-bottom: 1px solid var(--border-light);
}

.pc-dashboard-row:last-child { border-bottom: 0; }

.pc-dashboard-row > div {
    min-width: 0;
    flex: 1;
}

.pc-dashboard-row .info-value { max-width: none; }

.pc-dashboard-person {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.pc-dashboard-photo {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    object-fit: cover;
    border: 2px solid rgba(5, 150, 105, 0.18);
    flex: 0 0 auto;
}

.quick-link-card {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    padding: 1rem 1.25rem;
    color: var(--text-heading);
    transition: all var(--duration-normal) var(--ease-spring);
}

.quick-link-card:hover {
    color: var(--primary);
    transform: translateX(6px);
    box-shadow: var(--shadow-md);
}

.quick-link-card i {
    font-size: 1.4rem;
    color: var(--primary-600);
}


.quick-link-card span {
    font-weight: 600;
    font-size: 0.9rem;
}

/* ==============================
   MESSAGES
   ============================== */
.messages-container {
    position: fixed;
    top: 78px;
    right: 16px;
    z-index: 9999;
    max-width: 380px;
    width: 100%;
}

.glass-alert {
    backdrop-filter: blur(12px);
    border-radius: var(--radius-md);
    display: flex;
    align-items: center;
    gap: 0.6rem;
    margin-bottom: 0.4rem;
    font-size: 0.875rem;
    font-weight: 500;
    animation: slideInRight 0.35s var(--ease-spring);
    box-shadow: var(--shadow-lg);
}

.glass-alert.alert-error,
.glass-alert.alert-danger {
    color: #7f1d1d;
    background:
        linear-gradient(135deg, rgba(255, 255, 255, 0.98), rgba(254, 226, 226, 0.96));
    border: 1px solid rgba(248, 113, 113, 0.42);
    box-shadow:
        0 20px 48px rgba(127, 29, 29, 0.18),
        0 8px 18px rgba(127, 29, 29, 0.1),
        inset 0 1px 0 rgba(255, 255, 255, 0.9);
}

.glass-alert.alert-error i,
.glass-alert.alert-danger i {
    color: #dc2626;
}

.glass-alert.alert-error .btn-close,
.glass-alert.alert-danger .btn-close {
    filter: none;
    opacity: 0.72;
}

@keyframes slideInRight {
    from { transform: translateX(100%); opacity: 0; }
    to { transform: translateX(0); opacity: 1; }
}

/* ==============================
   FOOTER
   ============================== */
.footer-custom {
    background: var(--primary-dark);
    color: rgba(255,255,255,0.7);
    padding: 3rem 0 1.25rem;
}

.footer-brand {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    margin-bottom: 0.85rem;
}

.footer-brand i {
    font-size: 1.3rem;
    color: var(--primary-light);
}

.footer-brand h5 {
    margin: 0;
    font-family: var(--font-display);
    font-weight: 700;
    font-size: 1rem;
    color: var(--text-inverse);
    letter-spacing: -0.01em;
}

.footer-desc {
    font-size: 0.835rem;
    line-height: 1.6;
}

.footer-heading {
    color: var(--text-inverse);
    font-family: var(--font-display);
    font-weight: 700;
    font-size: 0.8rem;
    margin-bottom: 0.85rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.footer-links {
    list-style: none;
    padding: 0;
}

.footer-links li {
    margin-bottom: 0.4rem;
    font-size: 0.835rem;
}

.footer-links a {
    color: rgba(255,255,255,0.55);
    transition: color var(--duration-fast);
}

.footer-links a:hover { color: var(--primary-light); }

.footer-contact-links li {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    min-width: 0;
}

.footer-contact-links i {
    flex: 0 0 1.05rem;
    color: rgba(255, 255, 255, 0.58);
    font-size: 0.88rem;
    line-height: 1;
}

.footer-contact-links a {
    overflow-wrap: anywhere;
    line-height: 1.45;
}

.footer-divider {
    border-color: rgba(255,255,255,0.08);
    margin: 1.75rem 0 1rem;
}

.footer-bottom {
    display: grid;
    align-items: center;
    justify-items: center;
    gap: 0.72rem;
    font-size: 0.8rem;
    text-align: center;
}

.footer-copyright {
    margin: 0;
    color: rgba(255,255,255,0.46);
}

.footer-credit {
    position: relative;
    display: inline-flex;
    align-items: center;
    gap: 0.72rem;
    max-width: 100%;
    padding: 0.42rem 0.52rem 0.42rem 0.44rem;
    color: var(--text-inverse);
    text-decoration: none;
    border: 1px solid rgba(167, 243, 208, 0.18);
    border-radius: 999px;
    background: rgba(255,255,255,0.035);
    box-shadow: none;
    overflow: hidden;
    transition: transform 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
}

.footer-credit::before {
    content: none;
}

.footer-credit:hover {
    color: #ffffff;
    transform: translateY(-1px);
    border-color: rgba(167, 243, 208, 0.34);
    background: rgba(255,255,255,0.065);
    box-shadow: 0 8px 22px rgba(0, 0, 0, 0.1);
}

.footer-credit-icon {
    position: relative;
    z-index: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
    width: 2.15rem;
    height: 2.15rem;
    padding: 0.08rem;
    background: rgba(255,255,255,0.84);
    border-radius: 50%;
    box-shadow: 0 6px 14px rgba(0, 0, 0, 0.12);
}

.footer-credit-photo {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: 50% 30%;
    border: 2px solid rgba(255,255,255,0.88);
    border-radius: 50%;
}

.footer-credit-copy {
    position: relative;
    z-index: 1;
    display: grid;
    gap: 0.03rem;
    text-align: left;
    line-height: 1.08;
}

.footer-credit-label {
    color: rgba(209, 250, 229, 0.5);
    font-size: 0.52rem;
    font-weight: 750;
    letter-spacing: 0;
    text-transform: uppercase;
}

.footer-credit-name {
    color: rgba(255,255,255,0.86);
    font-family: var(--font-display);
    font-size: 0.88rem;
    font-weight: 800;
    text-shadow: none;
}

.footer-credit-actions {
    position: relative;
    z-index: 1;
    display: inline-flex;
    align-items: center;
    gap: 0.38rem;
}

.footer-credit-social {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
    width: 1.45rem;
    height: 1.45rem;
    color: rgba(209, 250, 229, 0.76);
    font-size: 0.72rem;
    text-decoration: none;
    border: 1px solid rgba(167, 243, 208, 0.22);
    border-radius: 50%;
    background: rgba(6, 95, 70, 0.3);
    transition: transform 0.2s ease, color 0.2s ease, background 0.2s ease, border-color 0.2s ease;
}

.footer-credit-social:hover {
    color: #064e3b;
    background: #d1fae5;
    border-color: rgba(255,255,255,0.72);
    transform: translateY(-2px);
}

.footer-credit-whatsapp {
    color: rgba(209, 250, 229, 0.82);
    background: rgba(6, 95, 70, 0.3);
    border-color: rgba(167, 243, 208, 0.22);
}

.footer-credit-whatsapp:hover {
    color: #ffffff;
    background: #16a34a;
}

/* ==============================
   EMPTY STATE
   ============================== */
.empty-state { padding: 3rem !important; }
.empty-state i { opacity: 0.25; }

/* ==============================
   CONTACT & ENQUIRY
   ============================== */
.contact-network-section .container {
    display: grid;
    gap: 1.5rem;
}

.contact-network-hero {
    position: relative;
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    align-items: center;
    gap: 1.4rem;
    min-height: 18rem;
    padding: 2rem;
    overflow: hidden;
}

.contact-network-hero::before {
    content: "";
    position: absolute;
    inset: -30% -10% auto auto;
    width: 42rem;
    height: 20rem;
    pointer-events: none;
    background: radial-gradient(circle, rgba(16, 185, 129, 0.2), transparent 65%);
    filter: blur(8px);
}

.executive-filter-card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1.25rem;
    padding: 1.25rem 1.45rem;
    overflow: hidden;
    background:
        radial-gradient(circle at 100% 10%, rgba(187, 247, 208, 0.34), transparent 34%),
        rgba(255,255,255,0.84);
}

.contact-hero-orbit {
    position: relative;
    width: 10rem;
    height: 10rem;
    flex: 0 0 auto;
}

.contact-hero-orbit::before {
    content: "";
    position: absolute;
    inset: 0.55rem;
    border: 1px dashed rgba(5, 150, 105, 0.28);
    border-radius: 50%;
    animation: contact-orbit 18s linear infinite;
}

.orbit-node {
    position: absolute;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--primary-dark);
    border: 1px solid rgba(167, 243, 208, 0.8);
    border-radius: 50%;
    background: rgba(255,255,255,0.82);
    box-shadow: 0 14px 34px rgba(6, 95, 70, 0.12);
}

.orbit-node-main {
    inset: 50% auto auto 50%;
    width: 4.4rem;
    height: 4.4rem;
    color: #fff;
    font-size: 1.75rem;
    background: linear-gradient(135deg, var(--primary), var(--accent-cyan));
    transform: translate(-50%, -50%);
}

.node-a,
.node-b,
.node-c {
    width: 2.4rem;
    height: 2.4rem;
}

.node-a { top: 0.3rem; left: 3.8rem; }
.node-b { right: 0.4rem; top: 5.8rem; }
.node-c { left: 0.55rem; bottom: 1.2rem; }

.contact-hero-copy,
.contact-hero-action {
    position: relative;
    z-index: 1;
}

.contact-hero-action {
    display: grid;
    gap: 0.65rem;
    justify-items: end;
    min-width: 13rem;
}

.contact-hero-action small {
    color: var(--text-muted);
    text-align: right;
    max-width: 16rem;
}

.contact-hero-points {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-top: 1rem;
}

.contact-hero-points span {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.35rem 0.7rem;
    color: var(--primary-dark);
    font-size: 0.78rem;
    font-weight: 800;
    border: 1px solid var(--primary-200);
    border-radius: var(--radius-full);
    background: rgba(236, 253, 245, 0.72);
}

.contact-kicker {
    display: inline-flex;
    color: var(--primary-dark);
    font-size: 0.76rem;
    font-weight: 850;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.contact-network-hero h2,
.enquiry-info-panel h2 {
    margin: 0.35rem 0 0.55rem;
    color: var(--text-heading);
    font-family: var(--font-display);
    font-weight: 900;
    letter-spacing: -0.03em;
}

.contact-network-hero p,
.executive-filter-card p,
.enquiry-info-panel p {
    margin: 0;
    color: var(--text-secondary);
}

.contact-officer-grid,
.executive-grid {
    display: grid;
    gap: 1rem;
}

.contact-officer-grid {
    grid-template-columns: repeat(auto-fit, minmax(310px, 1fr));
}

.executive-grid {
    grid-template-columns: repeat(auto-fill, minmax(280px, 360px));
}

.contact-person-card {
    position: relative;
    display: grid;
    gap: 0.9rem;
    padding: 1.05rem;
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    background:
        radial-gradient(circle at 100% 0%, rgba(187, 247, 208, 0.42), transparent 42%),
        rgba(255,255,255,0.86);
    box-shadow: var(--shadow-sm);
    overflow: hidden;
    cursor: pointer;
    min-height: 17.5rem;
    align-content: start;
    transition: transform 0.28s var(--ease-out), box-shadow 0.28s var(--ease-out), border-color 0.28s var(--ease-out);
}

.contact-card-profile-link {
    position: absolute;
    inset: 0;
    z-index: 1;
}

.contact-person-card > *:not(.contact-card-profile-link) {
    position: relative;
    z-index: 2;
}

.contact-person-card::after {
    content: "";
    position: absolute;
    inset: auto -20% -45% 20%;
    height: 7rem;
    pointer-events: none;
    background: radial-gradient(circle, rgba(16, 185, 129, 0.16), transparent 68%);
    transition: transform 0.28s var(--ease-out), opacity 0.28s var(--ease-out);
    opacity: 0;
}

.contact-person-card:hover {
    transform: translateY(-5px);
    border-color: rgba(5, 150, 105, 0.34);
    box-shadow: 0 24px 60px rgba(6, 95, 70, 0.14);
}

.contact-person-card:hover::after {
    opacity: 1;
    transform: translateY(-0.8rem);
}

.officer-card {
    border-color: rgba(5, 150, 105, 0.28);
    box-shadow: var(--shadow-md);
}

.contact-role-pill {
    justify-self: start;
    padding: 0.25rem 0.65rem;
    color: var(--primary-dark);
    font-size: 0.72rem;
    font-weight: 850;
    border: 1px solid var(--primary-200);
    border-radius: var(--radius-full);
    background: var(--primary-50);
}

.contact-person-top {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    min-height: 4.25rem;
}

.contact-person-top img,
.contact-avatar {
    width: 4rem;
    height: 4rem;
    border-radius: 1.1rem;
    flex: 0 0 auto;
}

.contact-person-top img {
    object-fit: cover;
}

.contact-avatar {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-weight: 900;
    font-size: 1.25rem;
    background: linear-gradient(135deg, var(--primary), var(--accent-cyan));
}

.contact-person-top h3 {
    margin: 0;
    color: var(--text-heading);
    font-family: var(--font-display);
    font-size: 1rem;
    font-weight: 850;
}

.contact-person-top p,
.contact-line {
    margin: 0;
    color: var(--text-secondary);
    font-size: 0.86rem;
}

.contact-line {
    display: flex;
    gap: 0.55rem;
}

.contact-line i {
    color: var(--primary);
}

.contact-actions {
    display: flex;
    gap: 0.6rem;
    flex-wrap: wrap;
    margin-top: auto;
}

.contact-call-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.4rem;
    min-height: 2.35rem;
    padding: 0.48rem 0.9rem;
    color: #fff;
    font-size: 0.86rem;
    font-weight: 850;
    text-decoration: none;
    border-radius: var(--radius-full);
    background: linear-gradient(135deg, var(--primary), var(--primary-dark));
    box-shadow: 0 12px 26px rgba(6, 95, 70, 0.16);
    position: relative;
    z-index: 3;
}

.contact-call-btn:hover {
    color: #fff;
    transform: translateY(-1px);
    box-shadow: 0 16px 32px rgba(6, 95, 70, 0.2);
}

.contact-profile-hint {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    width: fit-content;
    color: var(--text-muted);
    font-size: 0.72rem;
    font-weight: 750;
    pointer-events: none;
}

.contact-route {
    border: 1px solid rgba(5, 150, 105, 0.12);
    border-radius: var(--radius-md);
    background: rgba(236, 253, 245, 0.46);
}

.contact-route summary {
    display: flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.58rem 0.7rem;
    color: var(--primary-dark);
    font-size: 0.78rem;
    font-weight: 850;
    cursor: pointer;
    list-style: none;
}

.contact-route summary::-webkit-details-marker {
    display: none;
}

.contact-route-list {
    display: grid;
    gap: 0.35rem;
    padding: 0 0.65rem 0.65rem;
}

.contact-route-list a {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    padding: 0.48rem 0.55rem;
    color: var(--text-heading);
    text-decoration: none;
    border-radius: 12px;
    background: rgba(255,255,255,0.74);
}

.contact-route-list span {
    color: var(--text-muted);
    font-size: 0.68rem;
    font-weight: 800;
    text-transform: uppercase;
}

.contact-route-list strong {
    font-size: 0.78rem;
    text-align: right;
}

.executive-filter-form {
    display: flex;
    align-items: center;
    gap: 0.7rem;
    min-width: min(100%, 520px);
}

.executive-filter-control {
    position: relative;
    display: grid;
    grid-template-columns: auto 1fr;
    align-items: center;
    gap: 0.1rem 0.6rem;
    flex: 1;
    padding: 0.58rem 0.75rem;
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    background: rgba(255,255,255,0.72);
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.78);
}

.executive-filter-control > i {
    grid-row: span 2;
    color: var(--primary);
    font-size: 1rem;
}

.executive-filter-control label {
    margin: 0;
    color: var(--text-muted);
    font-size: 0.64rem;
    font-weight: 850;
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

.executive-filter-control .form-select {
    padding: 0;
    min-height: 1.6rem;
    border: 0;
    border-radius: 0;
    background-color: transparent;
    box-shadow: none;
}

.contact-clear-filter {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.4rem;
    min-height: 3.4rem;
    padding: 0.55rem 0.9rem;
    color: var(--primary-dark);
    font-weight: 850;
    text-decoration: none;
    border: 1px solid var(--primary-200);
    border-radius: var(--radius-full);
    background: rgba(236, 253, 245, 0.72);
    box-shadow: 0 10px 24px rgba(6, 95, 70, 0.08);
}

.contact-clear-filter:hover {
    color: #fff;
    background: var(--primary);
    border-color: var(--primary);
}

.enquiry-info-panel,
.enquiry-form-card {
    height: 100%;
    padding: 2rem;
}

.enquiry-contact-line {
    display: flex;
    gap: 0.65rem;
    margin-top: 1rem;
    color: var(--text-heading);
    font-weight: 750;
}

.enquiry-contact-line i {
    color: var(--primary);
}

.enquiry-success-modal .modal-content {
    border: 1px solid var(--primary-200);
    border-radius: var(--radius-xl);
    background:
        radial-gradient(circle at 100% 0%, rgba(187, 247, 208, 0.45), transparent 38%),
        rgba(255,255,255,0.96);
    box-shadow: var(--shadow-xl);
}

.success-ring {
    width: 4rem;
    height: 4rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 1rem;
    color: #fff;
    font-size: 1.8rem;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--primary), var(--accent-cyan));
    box-shadow: 0 16px 38px rgba(6, 95, 70, 0.18);
}

.enquiry-success-modal h5 {
    color: var(--text-heading);
    font-family: var(--font-display);
    font-weight: 900;
}

.enquiry-success-modal p {
    color: var(--text-secondary);
}

@keyframes contact-orbit {
    to { transform: rotate(360deg); }
}

/* ==============================
   FORM STYLING
   ============================== */
.form-control, .form-select {
    font-family: var(--font-sans);
    border: 1.5px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 0.55rem 0.85rem;
    font-size: 0.875rem;
    color: var(--text-body);
    transition: all var(--duration-fast) var(--ease-out);
    background: var(--bg-card);
}

.form-control:focus, .form-select:focus {
    border-color: var(--primary);
    box-shadow: 0 0 0 3px rgba(0,161,140,0.12);
}

.form-label {
    font-weight: 600;
    font-size: 0.8rem;
    color: var(--text-secondary);
    margin-bottom: 0.3rem;
    letter-spacing: 0.01em;
}

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

.invalid-feedback {
    font-size: 0.8rem;
    font-weight: 500;
}

.input-group-text {
    border: 1.5px solid var(--border);
    background: var(--bg-subtle);
    font-size: 0.875rem;
    color: var(--text-muted);
}

/* ==============================
   BADGES
   ============================== */
.badge {
    font-weight: 700;
    font-size: 0.7rem;
    padding: 0.35rem 0.75rem;
    border-radius: var(--radius-full);
    letter-spacing: 0.03em;
    text-transform: uppercase;
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    background: rgba(255, 255, 255, 0.35);
    backdrop-filter: blur(8px) saturate(160%);
    -webkit-backdrop-filter: blur(8px) saturate(160%);
    border: 1px solid rgba(255, 255, 255, 0.25);
    color: var(--text-heading);
    box-shadow: 0 2px 4px rgba(0,0,0,0.02);
}

.bg-primary { background: var(--primary-500) !important; color: white !important; }
.bg-secondary { background: rgba(100, 116, 139, 0.15) !important; color: #475569 !important; border-color: rgba(100, 116, 139, 0.1) !important; }
.bg-success { background: rgba(34, 197, 94, 0.15) !important; color: #166534 !important; border-color: rgba(34, 197, 94, 0.1) !important; }
.bg-warning { background: rgba(245, 158, 11, 0.15) !important; color: #92400e !important; border-color: rgba(245, 158, 11, 0.1) !important; }
.bg-danger { background: rgba(239, 68, 68, 0.15) !important; color: #991b1b !important; border-color: rgba(239, 68, 68, 0.1) !important; }
.bg-info { background: rgba(6, 182, 212, 0.15) !important; color: #155e75 !important; border-color: rgba(6, 182, 212, 0.1) !important; }


/* ==============================
   ANIMATIONS
   ============================== */
.animate-fade-in { animation: fadeIn 0.5s var(--ease-out) both; }
.animate-slide-up { animation: slideUp 0.5s var(--ease-out) both; }
.animate-slide-up-delay { animation: slideUp 0.5s var(--ease-out) 0.15s both; }
.animate-card-left { animation: cardSlide 0.6s var(--ease-spring) 0.3s both; }
.animate-card-right { animation: cardSlide 0.6s var(--ease-spring) 0.5s both; }

.animate-on-scroll {
    opacity: 0;
    transform: translateY(24px);
    transition: opacity var(--duration-slow) var(--ease-out),
                transform var(--duration-slow) var(--ease-out);
}

.animate-on-scroll.animate-visible {
    opacity: 1;
    transform: translateY(0);
}

@keyframes fadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}

@keyframes slideUp {
    from { opacity: 0; transform: translateY(24px); }
    to { opacity: 1; transform: translateY(0); }
}

@keyframes cardSlide {
    from { opacity: 0; transform: translateY(32px) scale(0.96); }
    to { opacity: 1; transform: translateY(0) scale(1); }
}

/* ==============================
   RESPONSIVE
   ============================== */
@media (max-width: 991.98px) {
    .hero-section { min-height: 72vh; }
    .hero-title { font-size: 2.2rem; }
    .page-title { font-size: 1.5rem; }
    .auth-card { padding: 2rem; }
    .detail-card { padding: 1.75rem; }
    .filter-card { position: static; }
    .sticky-filter { position: static; }
}

@media (max-width: 767.98px) {
    body { padding-top: 62px; }
    .hero-section {
        min-height: auto;
        padding-bottom: 2.5rem;
        margin-top: -62px;
        padding-top: 62px;
    }
    .hero-content { padding: 2rem 0; }
    .hero-title { font-size: 1.75rem; }
    .hero-subtitle { font-size: 1rem; margin-bottom: 2rem; }
    .choice-icon { width: 56px; height: 56px; font-size: 1.5rem; }
    .choice-card { padding: 1.75rem 1.25rem 1.5rem; }
    .choice-card h3 { font-size: 1.05rem; }
    .stats-section { padding: 2.5rem 0; }
    .stat-number { font-size: 2rem; }
    .features-section { padding: 3rem 0; }
    .cta-card { padding: 2rem 1.5rem; }
    .auth-card { padding: 1.5rem; }
    .detail-card { padding: 1.25rem; }
    .detail-header { flex-direction: column; text-align: center; }
    .detail-grid { grid-template-columns: 1fr; }
    .page-header { padding-top: calc(62px + 1.5rem); }
    .page-header-compact { padding-top: calc(62px + 1rem); }
    .messages-container { right: 8px; left: 8px; max-width: none; }
    .step-line { width: 24px; }
    .section-title { font-size: 1.5rem; }
    .footer-bottom {
        justify-items: center;
        text-align: center;
    }
    .footer-credit {
        width: 100%;
        justify-content: center;
    }
    .footer-credit-copy {
        text-align: left;
    }
}

@media (max-width: 575.98px) {
    .hero-title { font-size: 1.5rem; }
    .cta-buttons { flex-direction: column; }
    .cta-buttons .btn { width: 100%; }
    .navbar-custom .navbar-brand { font-size: 1.1rem; }
    .footer-credit {
        gap: 0.5rem;
        padding: 0.42rem 0.5rem;
    }
    .footer-credit-icon {
        width: 2rem;
        height: 2rem;
    }
    .footer-credit-name {
        font-size: 0.8rem;
    }
    .footer-credit-label {
        font-size: 0.48rem;
    }
    .footer-credit-actions {
        gap: 0.35rem;
    }
}

/* ==============================
   ADMIN PANEL
   ============================== */
.admin-panel-section {
    padding: 2rem 0 4rem;
    background:
        radial-gradient(circle at 6% 4%, rgba(16, 185, 129, 0.14), transparent 30%),
        radial-gradient(circle at 96% 22%, rgba(52, 211, 153, 0.1), transparent 32%),
        radial-gradient(circle at 80% 92%, rgba(5, 150, 105, 0.1), transparent 36%),
        linear-gradient(180deg, #f6fefb 0%, #ecfdf5 50%, #f0fdf4 100%);
    min-height: 100vh;
}

/* ── Premium section header (Overview / Quick Actions / Review Queue / etc) ── */
.adm-section-header {
    position: relative;
    display: flex;
    align-items: center;
    gap: 1rem;
    margin: 2.25rem 0 1.1rem;
    padding: 1rem 1.3rem 1rem 1rem;
    border-radius: 22px;
    background:
        radial-gradient(circle at 96% 0%, rgba(52, 211, 153, 0.18), transparent 40%),
        linear-gradient(135deg, rgba(255, 255, 255, 0.94), rgba(236, 253, 245, 0.72));
    border: 1px solid rgba(167, 243, 208, 0.7);
    box-shadow: 0 16px 38px rgba(6, 95, 70, 0.08);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    overflow: hidden;
    isolation: isolate;
}

/* Decorative left rail */
.adm-section-header::before {
    content: '';
    position: absolute;
    inset: 0 auto 0 0;
    width: 6px;
    background: linear-gradient(180deg, #10b981, #047857);
    border-radius: 4px;
    margin: 0.65rem 0;
    z-index: 1;
}

/* Soft right-edge wash */
.adm-section-header::after {
    content: '';
    position: absolute;
    top: -50%;
    right: -8rem;
    width: 22rem;
    height: 22rem;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(16, 185, 129, 0.16), transparent 70%);
    z-index: 0;
    pointer-events: none;
}

.adm-section-header > i {
    position: relative;
    z-index: 2;
    flex-shrink: 0;
    width: 56px;
    height: 56px;
    display: grid;
    place-items: center;
    border-radius: 18px;
    background: linear-gradient(135deg, #10b981, #047857);
    color: white;
    font-size: 1.5rem;
    box-shadow:
        0 12px 28px rgba(6, 95, 70, 0.28),
        inset 0 1px 0 rgba(255, 255, 255, 0.3);
    margin-left: 0.65rem;
}

.adm-section-header > div {
    position: relative;
    z-index: 2;
    min-width: 0;
}

.adm-section-header h3 {
    margin: 0;
    color: #0f172a;
    font-weight: 950;
    font-size: clamp(1.1rem, 2vw, 1.45rem);
    line-height: 1.2;
    letter-spacing: -0.01em;
}

.adm-section-header p {
    margin: 0.2rem 0 0;
    color: #475569;
    font-weight: 700;
    font-size: 0.88rem;
    line-height: 1.4;
}

/* Tablet */
@media (max-width: 991.98px) {
    .adm-section-header {
        padding: 0.9rem 1.1rem 0.9rem 0.85rem;
        gap: 0.85rem;
        margin-top: 1.85rem;
        border-radius: 20px;
    }
    .adm-section-header > i {
        width: 48px;
        height: 48px;
        border-radius: 16px;
        font-size: 1.3rem;
        margin-left: 0.55rem;
    }
    .adm-section-header h3 {
        font-size: 1.15rem;
    }
    .adm-section-header p {
        font-size: 0.82rem;
    }
}

/* Mobile */
@media (max-width: 575.98px) {
    .adm-section-header {
        padding: 0.8rem 1rem 0.8rem 0.75rem;
        gap: 0.7rem;
        border-radius: 18px;
        margin-top: 1.55rem;
    }
    .adm-section-header::before {
        width: 4px;
    }
    .adm-section-header > i {
        width: 44px;
        height: 44px;
        border-radius: 14px;
        font-size: 1.15rem;
        margin-left: 0.45rem;
    }
    .adm-section-header h3 {
        font-size: 1.02rem;
    }
    .adm-section-header p {
        font-size: 0.76rem;
        line-height: 1.35;
    }
}

.admin-search-bar {
    position: sticky;
    top: 96px;
    z-index: 1015;
    isolation: isolate;
    padding: 1.25rem 1.5rem;
    margin-bottom: 1.5rem;
    overflow: hidden;
    border: 1px solid rgba(255,255,255,0.58);
    backdrop-filter: blur(34px) saturate(210%) contrast(1.04);
    -webkit-backdrop-filter: blur(34px) saturate(210%) contrast(1.04);
    background:
        linear-gradient(135deg, rgba(255,255,255,0.34), rgba(236,253,245,0.16)),
        rgba(255,255,255,0.18);
    box-shadow:
        0 18px 46px rgba(6, 95, 70, 0.08),
        inset 0 1px 0 rgba(255,255,255,0.78),
        inset 0 -1px 0 rgba(5, 150, 105, 0.08);
}

.admin-search-bar::before,
.admin-search-bar::after {
    content: "";
    position: absolute;
    pointer-events: none;
    z-index: 0;
    border-radius: 999px;
    filter: blur(22px);
    opacity: 0.82;
    mix-blend-mode: soft-light;
}

.admin-search-bar::before {
    width: 30rem;
    height: 8rem;
    left: -8rem;
    top: -3.6rem;
    background: radial-gradient(circle at 35% 45%, rgba(255,255,255,0.88), rgba(16, 185, 129, 0.26) 42%, transparent 72%);
    animation: admin-filter-liquid 11s ease-in-out infinite alternate;
}

.admin-search-bar::after {
    width: 34rem;
    height: 9rem;
    right: -9rem;
    bottom: -5rem;
    background: radial-gradient(circle at 55% 50%, rgba(255,255,255,0.7), rgba(45, 212, 191, 0.25) 46%, transparent 76%);
    animation: admin-filter-liquid 13s ease-in-out infinite alternate-reverse;
}

.admin-search-bar .input-group,
.admin-filters {
    position: relative;
    z-index: 2;
}

.admin-search-bar:hover {
    transform: none;
}

.admin-search-bar form {
    position: relative;
    z-index: 2;
}

.admin-search-bar .input-group .form-control {
    font-size: 1rem;
    padding: 0.7rem 1rem;
    border-radius: 0 var(--radius-md) var(--radius-md) 0;
    border-color: rgba(5, 150, 105, 0.32);
    background: rgba(255,255,255,0.66);
    backdrop-filter: blur(18px) saturate(160%);
    -webkit-backdrop-filter: blur(18px) saturate(160%);
}

.admin-search-bar .input-group-text {
    background: rgba(5, 150, 105, 0.78);
    border-color: rgba(5, 150, 105, 0.48);
    color: white;
    border-radius: var(--radius-md) 0 0 var(--radius-md);
    font-size: 1.1rem;
    padding: 0.7rem 1rem;
    backdrop-filter: blur(18px) saturate(160%);
    -webkit-backdrop-filter: blur(18px) saturate(160%);
}

.admin-filters {
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
    margin-top: 1rem;
    align-items: end;
}

.admin-filters .form-select {
    max-width: 200px;
    font-size: 0.85rem;
    border-color: rgba(5, 150, 105, 0.24);
    background-color: rgba(255,255,255,0.54);
    backdrop-filter: blur(18px) saturate(160%);
    -webkit-backdrop-filter: blur(18px) saturate(160%);
}

@keyframes admin-filter-liquid {
    0% {
        transform: translate3d(0, 0, 0) scale(1);
    }
    100% {
        transform: translate3d(2.8rem, 0.65rem, 0) scale(1.08);
    }
}

.admin-stats-row {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(155px, 1fr));
    gap: 1rem;
    margin-bottom: 1.75rem;
}

.admin-stat {
    padding: 1.15rem;
    text-align: center;
    border-left: 3px solid var(--primary);
}

.admin-stat.warning { border-left-color: #f59e0b; }
.admin-stat.danger { border-left-color: #ef4444; }
.admin-stat.success { border-left-color: #22c55e; }

.admin-stat-number {
    font-family: var(--font-display);
    font-size: 1.75rem;
    font-weight: 800;
    color: var(--text-heading);
    letter-spacing: -0.03em;
    line-height: 1;
    margin-bottom: 0.2rem;
}

.admin-stat-label {
    font-size: 0.72rem;
    color: var(--text-muted);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.designation-rank-card {
    overflow: hidden;
    padding: 0;
}

.desig-details {
    display: block;
}

.desig-summary {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 1.05rem 1.35rem;
    cursor: pointer;
    list-style: none;
    border-bottom: 1px solid transparent;
    transition: background 0.2s ease, border-color 0.2s ease;
}

.desig-summary::-webkit-details-marker { display: none; }

.desig-details[open] .desig-summary {
    border-bottom-color: var(--border);
    background: rgba(236, 253, 245, 0.48);
}

.desig-summary-left {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.desig-summary-icon {
    width: 38px;
    height: 38px;
    display: grid;
    place-items: center;
    border-radius: 12px;
    background: linear-gradient(135deg, #ecfdf5, #d1fae5);
    color: #059669;
    font-size: 1.05rem;
    flex: 0 0 auto;
}

.desig-summary-title {
    display: block;
    font-family: var(--font-display);
    font-weight: 850;
    font-size: 1rem;
    color: var(--text-heading);
}

.desig-summary-sub {
    display: block;
    font-size: 0.76rem;
    color: var(--text-muted);
    font-weight: 600;
    margin-top: 0.1rem;
}

.desig-summary-right {
    display: flex;
    align-items: center;
    gap: 0.6rem;
}

.desig-pill {
    padding: 0.3rem 0.7rem;
    border-radius: 999px;
    background: rgba(16, 185, 129, 0.1);
    color: #059669;
    font-size: 0.72rem;
    font-weight: 800;
}

.desig-chevron {
    font-size: 0.85rem;
    color: var(--text-muted);
    transition: transform 0.25s ease;
}

.desig-details[open] .desig-chevron {
    transform: rotate(180deg);
}

.designation-rank-strip {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 0.75rem;
    padding: 1rem;
}

.designation-rank-chip {
    display: grid;
    gap: 0.25rem;
    min-height: 6.2rem;
    padding: 0.9rem;
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    background: linear-gradient(135deg, rgba(255,255,255,0.88), rgba(236,253,245,0.58));
    box-shadow: 0 12px 30px rgba(6, 95, 70, 0.06);
}

.designation-rank-chip .rank-number {
    width: 2rem;
    height: 2rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-weight: 900;
    border-radius: var(--radius-full);
    background: var(--primary);
}

.designation-rank-chip .rank-title {
    color: var(--text-heading);
    font-family: var(--font-display);
    font-weight: 850;
    line-height: 1.15;
}

.designation-rank-chip .rank-count {
    color: var(--text-muted);
    font-size: 0.76rem;
    font-weight: 650;
}

.designation-success .rank-number { background: #059669; }
.designation-warning .rank-number { background: #d97706; }
.designation-danger .rank-number { background: #dc2626; }
.designation-info .rank-number { background: #0891b2; }
.designation-dark .rank-number { background: #0f172a; }
.designation-secondary .rank-number { background: #64748b; }

.pending-queue-card {
    padding: 0;
    overflow: hidden;
}

.pending-queue {
    display: block;
}

.pending-queue-summary {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 1.05rem 1.35rem;
    cursor: pointer;
    list-style: none;
    border-bottom: 1px solid transparent;
    transition: background var(--duration-normal) var(--ease-out), border-color var(--duration-normal) var(--ease-out);
}

.pending-queue-summary::-webkit-details-marker {
    display: none;
}

.pending-queue[open] .pending-queue-summary {
    border-bottom-color: var(--border);
    background: rgba(236, 253, 245, 0.48);
}

.pending-summary-main {
    display: inline-flex;
    align-items: center;
    gap: 0.85rem;
    min-width: 0;
}

.pending-summary-icon {
    width: 2.35rem;
    height: 2.35rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
    color: var(--primary-dark);
    border: 1px solid var(--primary-200);
    border-radius: var(--radius-full);
    background: linear-gradient(135deg, rgba(236, 253, 245, 0.95), rgba(255,255,255,0.92));
}

.pending-summary-title {
    display: block;
    color: var(--text-heading);
    font-family: var(--font-display);
    font-size: 1rem;
    font-weight: 800;
    line-height: 1.1;
}

.pending-summary-subtitle {
    display: block;
    margin-top: 0.15rem;
    color: var(--text-muted);
    font-size: 0.78rem;
    font-weight: 500;
}

.pending-summary-actions {
    display: inline-flex;
    align-items: center;
    gap: 0.65rem;
    flex: 0 0 auto;
}

.pending-count-pill,
.pending-expand-label {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 2.2rem;
    padding: 0.35rem 0.78rem;
    border-radius: var(--radius-full);
    font-size: 0.78rem;
    font-weight: 800;
    white-space: nowrap;
}

.pending-count-pill {
    color: var(--primary-dark);
    background: var(--primary-50);
    border: 1px solid var(--primary-200);
}

.pending-expand-label {
    color: var(--text-heading);
    background: #ffffff;
    border: 1px solid var(--border);
    text-decoration: none;
}

.pending-close-text,
.pending-queue[open] .pending-open-text {
    display: none;
}

.pending-queue[open] .pending-close-text {
    display: inline-flex;
    align-items: center;
    gap: 0.28rem;
}

.pending-open-text {
    display: inline-flex;
    align-items: center;
    gap: 0.28rem;
}

.pending-queue-body {
    padding: 1rem;
}

.pending-review-scroll {
    display: grid;
    gap: 0.9rem;
    max-height: 34rem;
    overflow-y: auto;
    padding-right: 0.25rem;
    scrollbar-width: thin;
    scrollbar-color: rgba(5, 150, 105, 0.35) transparent;
}

.pending-application-card {
    display: grid;
    grid-template-columns: minmax(210px, 0.9fr) minmax(300px, 1.45fr) minmax(280px, 0.85fr);
    gap: 1rem;
    align-items: start;
    padding: 1rem;
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    background: rgba(255,255,255,0.86);
    box-shadow: 0 10px 28px rgba(15, 23, 42, 0.04);
}

.pending-applicant {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    min-width: 0;
}

.pending-avatar {
    width: 3rem;
    height: 3rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
    color: #ffffff;
    font-weight: 800;
    font-size: 1rem;
    text-transform: uppercase;
    border-radius: var(--radius-lg);
    background: linear-gradient(135deg, var(--primary), var(--accent-cyan));
}

.pending-applicant h6 {
    margin: 0 0 0.25rem;
    color: var(--text-heading);
    font-family: var(--font-display);
    font-weight: 800;
    font-size: 0.98rem;
}

.pending-applicant p {
    margin: 0.08rem 0;
    color: var(--text-secondary);
    font-size: 0.82rem;
    overflow-wrap: anywhere;
}

.pending-details-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.65rem;
}

.pending-detail-block {
    min-width: 0;
    padding: 0.75rem;
    border: 1px solid rgba(209, 250, 229, 0.9);
    border-radius: var(--radius-md);
    background: rgba(236, 253, 245, 0.45);
}

.pending-detail-block span {
    display: block;
    margin-bottom: 0.22rem;
    color: var(--text-muted);
    font-size: 0.66rem;
    font-weight: 800;
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

.pending-detail-block strong,
.pending-detail-block code {
    display: block;
    color: var(--text-heading);
    font-size: 0.85rem;
    font-weight: 800;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.pending-detail-block small {
    display: block;
    margin-top: 0.22rem;
    color: var(--text-secondary);
    font-size: 0.75rem;
}

.pending-shop-block {
    grid-row: span 2;
}

.pending-review-actions {
    display: grid;
    gap: 0.6rem;
}

.pending-action-form {
    display: grid;
    gap: 0.45rem;
}

.pending-action-form .form-control {
    min-height: 2.35rem;
    font-size: 0.8rem;
    border-radius: var(--radius-md);
}

.pending-action-form textarea.form-control {
    resize: vertical;
}

.pending-empty-state {
    padding: 2.4rem 1rem;
    text-align: center;
    border: 1px dashed var(--primary-200);
    border-radius: var(--radius-lg);
    background: rgba(236, 253, 245, 0.45);
}

.pending-empty-state i {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 3rem;
    height: 3rem;
    margin-bottom: 0.75rem;
    color: var(--primary-dark);
    font-size: 1.35rem;
    border-radius: var(--radius-full);
    background: #ffffff;
    box-shadow: var(--shadow-sm);
}

.pending-empty-state h6 {
    margin: 0 0 0.25rem;
    color: var(--text-heading);
    font-family: var(--font-display);
    font-weight: 800;
}

.pending-empty-state p {
    margin: 0;
    color: var(--text-muted);
    font-size: 0.85rem;
}

.admin-table-card {
    padding: 0;
    overflow: hidden;
    border: 1px solid rgba(16, 185, 129, 0.28);
    background:
        radial-gradient(circle at 92% 8%, rgba(52, 211, 153, 0.2), transparent 28%),
        linear-gradient(145deg, rgba(236, 253, 245, 0.98), rgba(209, 250, 229, 0.78));
    box-shadow:
        0 24px 58px rgba(6, 95, 70, 0.13),
        inset 0 1px 0 rgba(255, 255, 255, 0.92);
}

.admin-table-header {
    padding: 1rem 1.5rem;
    border-bottom: 1px solid rgba(16, 185, 129, 0.18);
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 0.5rem;
    background:
        linear-gradient(135deg, rgba(255, 255, 255, 0.92), rgba(236, 253, 245, 0.72));
}

.admin-table-header h5 {
    font-family: var(--font-display);
    font-weight: 900;
    font-size: 1rem;
    margin: 0;
    color: #063f32;
}

.admin-table-scroll-top {
    display: none;
    overflow-x: auto;
    overflow-y: hidden;
    height: 18px;
    padding: 4px 1rem 2px;
    border-bottom: 1px solid rgba(16, 185, 129, 0.14);
    background:
        linear-gradient(90deg, rgba(5, 150, 105, 0.1), rgba(16, 185, 129, 0.03));
}

.admin-table-scroll-top.is-scrollable {
    display: block;
}

.admin-table-scroll-spacer {
    height: 1px;
}

.admin-table-scroll-top::-webkit-scrollbar,
.table-responsive::-webkit-scrollbar {
    height: 9px;
}

.admin-table-scroll-top::-webkit-scrollbar-track,
.table-responsive::-webkit-scrollbar-track {
    background: rgba(209, 250, 229, 0.7);
    border-radius: 999px;
}

.admin-table-scroll-top::-webkit-scrollbar-thumb,
.table-responsive::-webkit-scrollbar-thumb {
    background: linear-gradient(90deg, #10b981, #047857);
    border-radius: 999px;
    border: 2px solid rgba(236, 253, 245, 0.95);
}

.license-mini-grid {
    display: grid;
    gap: 0.45rem;
}

.license-mini-card,
.license-detail-card {
    display: grid;
    gap: 0.12rem;
    padding: 0.55rem 0.65rem;
    border-radius: 12px;
    border: 1px solid rgba(148, 163, 184, 0.22);
    background: rgba(248, 250, 252, 0.72);
}

.license-mini-summary {
    width: 100%;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto auto;
    align-items: center;
    gap: 0.45rem;
    padding: 0;
    border: 0;
    color: inherit;
    background: transparent;
    text-align: left;
}

.license-mini-chevron {
    display: none;
}

.license-mini-details {
    display: grid;
    gap: 0.12rem;
}

.license-mini-card .license-mini-title,
.license-detail-card > span {
    color: #64748b;
    font-size: 0.66rem;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.license-mini-card strong,
.license-detail-card strong {
    color: #0f172a;
    font-size: 0.82rem;
    font-weight: 850;
    overflow-wrap: anywhere;
}

.license-mini-card small,
.license-detail-card small {
    color: #475569;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
}

.license-mini-card em,
.license-detail-card em {
    font-style: normal;
    font-size: 0.68rem;
    font-weight: 900;
    white-space: nowrap;
}

.license-mini-valid em { color: #047857; }
.license-mini-warning em { color: #a16207; }
.license-mini-critical em { color: #dc2626; }
.license-mini-expired em { color: #991b1b; }
.license-mini-pending em { color: #64748b; }

.license-mini-valid { background: rgba(220, 252, 231, 0.72); border-color: rgba(34, 197, 94, 0.22); }
.license-mini-warning { background: rgba(254, 243, 199, 0.72); border-color: rgba(245, 158, 11, 0.24); }
.license-mini-critical { background: rgba(254, 226, 226, 0.72); border-color: rgba(220, 38, 38, 0.24); }
.license-mini-expired { background: rgba(254, 242, 242, 0.9); border-color: rgba(153, 27, 27, 0.28); }
.license-mini-pending { background: rgba(248, 250, 252, 0.84); border-color: rgba(148, 163, 184, 0.2); }

.license-detail-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.75rem;
}

.detail-alert-soft {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.55rem 0.75rem;
    border-radius: 999px;
    color: #065f46;
    background: rgba(209, 250, 229, 0.84);
    border: 1px solid rgba(16, 185, 129, 0.24);
    font-size: 0.85rem;
    font-weight: 750;
}

.table-responsive {
    overflow-x: auto;
    background:
        linear-gradient(180deg, rgba(240, 253, 244, 0.98), rgba(236, 253, 245, 0.84));
}

.admin-table {
    width: 100%;
    font-size: 0.85rem;
    margin: 0;
    min-width: 980px;
    border-collapse: separate;
    border-spacing: 0;
}

.admin-table thead {
    background: linear-gradient(135deg, #064e3b, #059669);
}

.admin-table th {
    font-weight: 850;
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: rgba(255, 255, 255, 0.86);
    padding: 0.7rem 1rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.14);
    white-space: nowrap;
}

.admin-table td {
    padding: 0.8rem 1rem;
    border-bottom: 1px solid rgba(16, 185, 129, 0.13);
    vertical-align: middle;
    color: #12372f;
    background: rgba(255, 255, 255, 0.72);
}

.admin-table tbody tr {
    transition: transform var(--duration-fast), filter var(--duration-fast);
}

.admin-table tbody tr:nth-child(even) td {
    background: rgba(236, 253, 245, 0.88);
}

.admin-table tbody tr:hover {
    filter: saturate(1.05);
}

.admin-table tbody tr:hover td {
    background: rgba(209, 250, 229, 0.96);
}

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

.admin-table .member-cell {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    min-width: 180px;
}

.admin-table .member-cell .avatar-placeholder {
    width: 34px;
    height: 34px;
    font-size: 0.8rem;
    flex-shrink: 0;
}

.admin-table .member-name {
    font-weight: 600;
    color: #0f2f2a;
    font-size: 0.85rem;
}

.admin-table .member-name a {
    color: #0f2f2a;
}

.admin-table .member-name a:hover {
    color: var(--primary);
}

.admin-table .member-shop {
    font-size: 0.75rem;
    color: rgba(15, 47, 42, 0.58);
}

.license-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    padding: 0.2rem 0.55rem;
    border-radius: var(--radius-full);
    font-weight: 700;
    font-size: 0.68rem;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    white-space: nowrap;
}

.license-badge.valid {
    background: #dcfce7;
    color: #15803d;
}

.license-badge.warning {
    background: #fef3c7;
    color: #a16207;
}

.license-badge.critical {
    background: #fee2e2;
    color: #dc2626;
}

.license-badge.expired {
    background: #1f2937;
    color: #fca5a5;
}

.admin-table .days-cell {
    font-weight: 700;
    font-size: 0.85rem;
    white-space: nowrap;
}

.admin-table .days-cell.text-danger { color: #dc2626 !important; }
.admin-table .days-cell.text-warning { color: #d97706 !important; }
.admin-table .days-cell.text-success { color: #16a34a !important; }

.admin-license-stack {
    display: grid;
    grid-template-columns: repeat(3, minmax(120px, 1fr));
    gap: 0.45rem;
    min-width: 430px;
}

.admin-license-pill {
    display: grid;
    gap: 0.12rem;
    padding: 0.5rem 0.6rem;
    border-radius: 12px;
    border: 1px solid rgba(148, 163, 184, 0.2);
    background: rgba(248, 250, 252, 0.78);
}

.admin-license-pill span {
    color: #64748b;
    font-size: 0.64rem;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.admin-license-pill code {
    display: block;
    color: #0f172a;
    font-size: 0.78rem;
    font-weight: 850;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.admin-license-pill small {
    color: #475569;
    font-size: 0.72rem;
}

.admin-license-pill em {
    font-style: normal;
    width: fit-content;
    padding: 0.16rem 0.45rem;
    border-radius: 999px;
    font-size: 0.64rem;
    font-weight: 900;
}

.admin-license-valid { background: rgba(220, 252, 231, 0.72); border-color: rgba(34, 197, 94, 0.22); }
.admin-license-valid em { color: #047857; background: rgba(187, 247, 208, 0.72); }
.admin-license-warning { background: rgba(254, 243, 199, 0.78); border-color: rgba(245, 158, 11, 0.24); }
.admin-license-warning em { color: #92400e; background: rgba(253, 230, 138, 0.72); }
.admin-license-critical { background: rgba(254, 226, 226, 0.78); border-color: rgba(220, 38, 38, 0.24); }
.admin-license-critical em { color: #991b1b; background: rgba(254, 202, 202, 0.72); }
.admin-license-expired { background: rgba(254, 242, 242, 0.9); border-color: rgba(153, 27, 27, 0.28); }
.admin-license-expired em { color: #7f1d1d; background: rgba(254, 202, 202, 0.82); }
.admin-license-pending em { color: #475569; background: rgba(226, 232, 240, 0.9); }

@media (max-width: 991.98px) {
    .distributor-license-panel .license-overview-grid {
        grid-template-columns: 1fr;
    }

    .license-detail-grid {
        grid-template-columns: 1fr;
    }

    .admin-search-bar {
        top: 70px; /* matches body's padding-top under the fixed navbar */
        z-index: 1015;
    }
    .admin-filters .form-select {
        max-width: none;
        width: 100%;
    }
    .admin-stats-row {
        grid-template-columns: repeat(2, 1fr);
    }
    .pending-application-card {
        grid-template-columns: 1fr;
    }
    .pending-review-actions {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 575.98px) {
    .license-dashboard-card,
    .distributor-license-panel {
        padding: 1rem;
    }

    .license-dashboard-header {
        grid-template-columns: auto minmax(0, 1fr);
    }

    .license-dashboard-header > .license-status-chip {
        grid-column: 1 / -1;
        width: 100%;
        min-height: 30px;
    }

    .license-owner-strip {
        grid-template-columns: 1fr;
    }

    .license-overview-card small,
    .license-identity-row {
        align-items: flex-start;
        flex-direction: column;
    }

    .license-identity-row strong {
        text-align: left;
    }

    .license-card-toggle {
        grid-template-columns: auto minmax(0, 1fr) auto;
        gap: 0.65rem;
    }

    .license-card-toggle .license-card-summary {
        grid-column: 2 / -1;
        justify-self: start;
        white-space: normal;
    }

    .license-card-toggle .license-status-chip {
        grid-column: 1 / 3;
        justify-self: start;
    }

    .license-card-toggle .license-card-chevron {
        grid-column: 3;
        grid-row: 1;
    }

    .contact-network-hero {
        grid-template-columns: 1fr;
        min-height: 0;
        padding: 1.5rem 1.25rem;
        text-align: center;
        justify-items: center;
        gap: 0.6rem;
        border-radius: 24px;
        background:
            radial-gradient(circle at 50% 0%, rgba(167, 243, 208, 0.35), transparent 55%),
            linear-gradient(160deg, rgba(255, 255, 255, 0.98), rgba(236, 253, 245, 0.92));
    }
    .contact-network-hero::before {
        inset: -20% auto auto -15%;
        width: 18rem;
        height: 12rem;
        opacity: 0.5;
    }
    .contact-hero-orbit {
        width: 6.5rem;
        height: 6.5rem;
        margin-bottom: 0.2rem;
    }
    .contact-hero-orbit::before {
        border-width: 1px;
    }
    .orbit-node-main {
        width: 3.2rem;
        height: 3.2rem;
        font-size: 1.3rem;
    }
    .node-a, .node-b, .node-c {
        width: 1.8rem;
        height: 1.8rem;
        font-size: 0.7rem;
    }
    .node-a { top: 0.15rem; left: 2.8rem; }
    .node-b { right: 0.2rem; top: 4.2rem; }
    .node-c { left: 0.3rem; bottom: 0.7rem; }
    .contact-kicker {
        font-size: 0.65rem;
        letter-spacing: 0.06em;
    }
    .contact-network-hero h2 {
        font-size: 1.3rem;
        line-height: 1.18;
        margin: 0.15rem 0 0.35rem;
    }
    .contact-network-hero p {
        font-size: 0.82rem;
        line-height: 1.5;
        max-width: 320px;
    }
    .contact-hero-points {
        justify-content: center;
        gap: 0.35rem;
        margin-top: 0.6rem;
    }
    .contact-hero-points span {
        font-size: 0.68rem;
        padding: 0.28rem 0.55rem;
    }
    .contact-hero-action {
        justify-items: stretch;
        width: 100%;
        gap: 0.45rem;
    }
    .contact-hero-action .btn {
        font-size: 0.88rem;
    }
    .contact-hero-action small {
        text-align: center;
        font-size: 0.72rem;
    }
    .contact-network-hero,
    .executive-filter-card,
    .executive-filter-form {
        flex-direction: column;
        align-items: stretch;
    }
    .executive-filter-card {
        padding: 1.1rem;
        border-radius: 20px;
        text-align: center;
    }
    .executive-filter-card h3 {
        font-size: 1.05rem;
    }
    .executive-filter-card p {
        font-size: 0.78rem;
    }
    .contact-officer-grid,
    .executive-grid {
        grid-template-columns: 1fr;
    }
    .contact-person-card {
        min-height: auto;
        padding: 0.9rem;
        gap: 0.7rem;
        border-radius: 20px;
    }
    .contact-person-top img,
    .contact-avatar {
        width: 3.2rem;
        height: 3.2rem;
        border-radius: 0.85rem;
    }
    .contact-person-top h3 {
        font-size: 0.9rem;
    }
    .contact-person-top p,
    .contact-line {
        font-size: 0.78rem;
    }
    .contact-role-pill {
        font-size: 0.65rem;
        padding: 0.2rem 0.5rem;
    }
    .contact-call-btn {
        font-size: 0.78rem;
        min-height: 2.1rem;
        padding: 0.38rem 0.75rem;
    }
    .admin-stats-row {
        grid-template-columns: 1fr 1fr;
    }
    .pending-queue-summary,
    .pending-summary-actions {
        align-items: stretch;
    }
    .pending-queue-summary {
        flex-direction: column;
    }
    .pending-summary-actions {
        width: 100%;
        justify-content: space-between;
    }
    .pending-details-grid,
    .pending-review-actions {
        grid-template-columns: 1fr;
    }
    .pending-review-scroll {
        max-height: 38rem;
    }
}

/* ==============================
   3D ANNOUNCEMENT CAROUSEL
   ============================== */
.announcements-section {
    padding: 6rem 0 4rem;
    position: relative;
    overflow: hidden;
    /* Soft blending background 2026 */
    background-color: #f8fafc;
    background-image: 
        radial-gradient(at 100% 100%, rgba(14, 165, 233, 0.05) 0, transparent 50%),
        radial-gradient(at 0% 0%, rgba(16, 185, 129, 0.05) 0, transparent 50%);
}

.announcements-section::before {
    content: '';
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 100%;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(14, 165, 233, 0.2), transparent);
}


.carousel-3d {
    position: relative;
    perspective: 1200px;
    height: 420px;
    max-width: 900px;
    margin: 0 auto;
}

.carousel-3d-track {
    position: relative;
    width: 100%;
    height: 100%;
    transform-style: preserve-3d;
}

.carousel-3d-card {
    position: absolute;
    top: 50%;
    left: 50%;
    width: 340px;
    transform: translate(-50%, -50%) rotateY(0deg) translateZ(0px) scale(0.7);
    opacity: 0;
    pointer-events: none;
    transition: all 0.7s cubic-bezier(0.23, 1, 0.32, 1);
    cursor: pointer;
    border-radius: var(--radius-xl);
    overflow: hidden;
    background: var(--bg-card);
    border: 1px solid var(--border);
    box-shadow: var(--shadow-md);
}

.carousel-3d-card.active {
    transform: translate(-50%, -50%) rotateY(0deg) translateZ(120px) scale(1.05);
    opacity: 1;
    pointer-events: auto;
    z-index: 10;
    box-shadow: 
        0 40px 100px rgba(0,0,0,0.25), 
        0 0 0 1px rgba(14, 165, 233, 0.3),
        inset 0 0 0 1px rgba(255,255,255,0.4);
}

/* Glass Reflection Effect */
.carousel-3d-card.active::after {
    content: '';
    position: absolute;
    top: 102%;
    left: 5%;
    width: 90%;
    height: 40%;
    background: linear-gradient(to bottom, rgba(255,255,255,0.15), transparent);
    filter: blur(8px);
    border-radius: inherit;
    pointer-events: none;
    transform: scaleY(-0.4);
    mask-image: linear-gradient(to bottom, black, transparent);
    -webkit-mask-image: linear-gradient(to bottom, black, transparent);
}


.carousel-3d-card.prev {
    transform: translate(calc(-50% - 280px), -50%) rotateY(25deg) translateZ(-50px) scale(0.82);
    opacity: 0.55;
    pointer-events: auto;
    z-index: 5;
    filter: brightness(0.85);
}

.carousel-3d-card.next {
    transform: translate(calc(-50% + 280px), -50%) rotateY(-25deg) translateZ(-50px) scale(0.82);
    opacity: 0.55;
    pointer-events: auto;
    z-index: 5;
    filter: brightness(0.85);
}

.carousel-3d-card.far-prev {
    transform: translate(calc(-50% - 450px), -50%) rotateY(40deg) translateZ(-120px) scale(0.6);
    opacity: 0;
    z-index: 1;
}

.carousel-3d-card.far-next {
    transform: translate(calc(-50% + 450px), -50%) rotateY(-40deg) translateZ(-120px) scale(0.6);
    opacity: 0;
    z-index: 1;
}

.carousel-card-image {
    height: 160px;
    overflow: hidden;
    background: linear-gradient(135deg, var(--primary-100), var(--primary-50));
}

.carousel-card-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.5s ease;
}

.carousel-3d-card:hover .carousel-card-image img {
    transform: scale(1.08);
}

.carousel-card-placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 3rem;
    color: var(--primary);
    opacity: 0.3;
}

.carousel-card-body {
    padding: 1.15rem 1.25rem 1.25rem;
}

.read-more-hint {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    font-size: 0.78rem;
    color: var(--primary);
    font-weight: 600;
    margin-top: 0.5rem;
    opacity: 0;
    transform: translateY(4px);
    transition: all 0.3s ease;
}

.carousel-3d-card.active:hover .read-more-hint {
    opacity: 1;
    transform: translateY(0);
}

/* Navigation Buttons */
.carousel-3d-btn {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 52px;
    height: 52px;
    border-radius: var(--radius-full);
    border: 1px solid rgba(14, 165, 233, 0.2);
    background: rgba(255, 255, 255, 0.7);
    backdrop-filter: blur(8px);
    color: var(--primary-dark);
    font-size: 1.25rem;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    z-index: 25;
    transition: all var(--duration-normal) var(--ease-spring);
    box-shadow: var(--shadow-md);
}

.carousel-3d-btn:hover {
    background: var(--primary-600);
    color: white;
    border-color: var(--primary-600);
    transform: translateY(-50%) scale(1.15);
    box-shadow: var(--shadow-glow);
}


.carousel-3d-btn.prev { left: 0; }
.carousel-3d-btn.next { right: 0; }

/* Dots */
.carousel-3d-dots {
    display: flex;
    justify-content: center;
    gap: 0.5rem;
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
}

.carousel-dot {
    width: 10px;
    height: 10px;
    border-radius: var(--radius-full);
    border: 2px solid var(--border);
    background: transparent;
    cursor: pointer;
    transition: all 0.3s ease;
    padding: 0;
}

.carousel-dot.active {
    background: var(--primary);
    border-color: var(--primary);
    transform: scale(1.3);
}

/* Announcement Meta (shared) */
.announcement-meta {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    margin-bottom: 0.6rem;
    flex-wrap: wrap;
}

.announcement-priority {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    padding: 0.2rem 0.55rem;
    border-radius: var(--radius-full);
    font-weight: 700;
    font-size: 0.68rem;
    text-transform: uppercase;
    letter-spacing: 0.03em;
}

.announcement-priority.urgent {
    background: #fee2e2;
    color: #dc2626;
}

.announcement-priority.important {
    background: #fef3c7;
    color: #a16207;
}

.announcement-date {
    font-size: 0.78rem;
    color: var(--text-muted);
    font-weight: 500;
    display: flex;
    align-items: center;
    gap: 0.3rem;
}

.announcement-title {
    font-family: var(--font-display);
    font-size: 1.02rem;
    font-weight: 700;
    color: var(--text-heading);
    margin-bottom: 0.4rem;
    letter-spacing: -0.02em;
    line-height: 1.3;
}

.announcement-content {
    color: var(--text-body);
    font-size: 0.84rem;
    line-height: 1.55;
}

/* AI Hub Decorative Atmos */
.announcement-glow-top {
    position: absolute;
    top: -100px;
    right: -50px;
    width: 400px;
    height: 400px;
    background: radial-gradient(circle, rgba(14, 165, 233, 0.1) 0%, transparent 70%);
    pointer-events: none;
    z-index: 1;
}

.announcement-glow-bottom {
    position: absolute;
    bottom: -100px;
    left: -50px;
    width: 400px;
    height: 400px;
    background: radial-gradient(circle, rgba(16, 185, 129, 0.1) 0%, transparent 70%);
    pointer-events: none;
    z-index: 1;
}

.announcement-particles {
    position: absolute;
    inset: 0;
    pointer-events: none;
    z-index: 2;
}

.particle {
    position: absolute;
    background: var(--primary-500);
    border-radius: 50%;
    filter: blur(2px);
    opacity: 0.3;
    animation: float-particle 10s infinite linear;
}

.p-1 { width: 4px; height: 4px; top: 20%; left: 10%; animation-delay: 0s; }
.p-2 { width: 6px; height: 6px; top: 60%; left: 85%; animation-delay: -2s; }
.p-3 { width: 8px; height: 8px; top: 40%; left: 50%; animation-delay: -5s; opacity: 0.2; }

@keyframes float-particle {
    0% { transform: translate(0, 0) scale(1); opacity: 0.3; }
    50% { transform: translate(20px, -30px) scale(1.2); opacity: 0.6; }
    100% { transform: translate(0, 0) scale(1); opacity: 0.3; }
}

.announcement-modal-overlay {
    position: fixed;
    inset: 0;
    background: rgba(15, 23, 42, 0.7);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    z-index: 9999;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.35s ease;
}

.announcement-modal-overlay.open {
    opacity: 1;
    pointer-events: auto;
}

.announcement-modal {
    position: relative;
    max-width: 680px;
    width: 92%;
    max-height: 85vh;
    background: var(--bg-card);
    border-radius: var(--radius-xl);
    overflow: hidden;
    box-shadow: 0 30px 80px rgba(0,0,0,0.3);
    transform: translateY(30px) scale(0.95);
    transition: transform 0.4s cubic-bezier(0.23, 1, 0.32, 1);
}

.announcement-modal-overlay.open .announcement-modal {
    transform: translateY(0) scale(1);
}

.announcement-modal-close {
    position: absolute;
    top: 1rem;
    right: 1rem;
    width: 36px;
    height: 36px;
    border-radius: var(--radius-full);
    border: none;
    background: rgba(255,255,255,0.9);
    color: var(--text-heading);
    font-size: 0.9rem;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    z-index: 10;
    transition: all 0.2s ease;
    box-shadow: 0 2px 8px rgba(0,0,0,0.15);
}

.announcement-modal-close:hover {
    background: #ef4444;
    color: white;
    transform: scale(1.1);
}

.announcement-modal-nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 40px;
    height: 40px;
    border-radius: var(--radius-full);
    border: none;
    background: rgba(255,255,255,0.9);
    color: var(--text-heading);
    font-size: 1rem;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    z-index: 10;
    transition: all 0.25s ease;
    box-shadow: 0 2px 8px rgba(0,0,0,0.1);
}

.announcement-modal-nav.prev { left: 1rem; }
.announcement-modal-nav.next { right: 1rem; }

.announcement-modal-nav:hover {
    background: var(--primary);
    color: white;
    transform: translateY(-50%) scale(1.1);
}

.announcement-modal-content {
    overflow-y: auto;
    max-height: 85vh;
}

.modal-announcement-image {
    height: 260px;
    overflow: hidden;
}

.modal-announcement-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.modal-announcement-body {
    padding: 1.75rem 2rem 2rem;
}

.modal-announcement-title {
    font-family: var(--font-display);
    font-size: 1.5rem;
    font-weight: 800;
    color: var(--text-heading);
    margin-bottom: 1rem;
    letter-spacing: -0.03em;
    line-height: 1.3;
}

.modal-announcement-text {
    color: var(--text-body);
    font-size: 0.95rem;
    line-height: 1.75;
}

.announcement-modal-counter {
    text-align: center;
    padding: 0.75rem;
    font-size: 0.8rem;
    color: var(--text-muted);
    font-weight: 600;
    border-top: 1px solid var(--border-light);
    letter-spacing: 0.04em;
}

@media (max-width: 767.98px) {
    .carousel-3d {
        height: 380px;
        perspective: none;
    }
    .carousel-3d-card {
        width: min(320px, 84vw);
    }
    .carousel-3d-card.active {
        transform: translate(-50%, -50%) scale(1);
        box-shadow: 0 20px 60px rgba(6, 95, 70, 0.18);
    }
    .carousel-3d-card.prev,
    .carousel-3d-card.next {
        opacity: 0;
        pointer-events: none;
    }
    .carousel-3d-btn { width: 36px; height: 36px; font-size: 0.9rem; }
    .modal-announcement-body { padding: 1.25rem; }
    .modal-announcement-title { font-size: 1.2rem; }
}

/* ==============================
   IMPROVED TEXT CONTRAST
   ============================== */
.feature-card p,
.section-subtitle {
    color: var(--text-body);
}

.feature-card h4 {
    color: var(--text-heading);
    font-weight: 800;
}

.stat-label {
    color: var(--text-body);
    font-weight: 600;
}

/* ==============================
   DASHBOARD ENHANCEMENTS
   ============================== */

/* President Welcome Banner */
.president-welcome-banner {
    background: linear-gradient(135deg, rgba(var(--primary-rgb), 0.05), rgba(var(--primary-rgb), 0.1));
    border: 1px solid rgba(var(--primary-rgb), 0.15);
    padding: 2rem;
    position: relative;
    overflow: hidden;
}

.president-welcome-banner::before {
    content: '';
    position: absolute;
    top: -50px;
    right: -50px;
    width: 200px;
    height: 200px;
    background: radial-gradient(circle, rgba(var(--primary-rgb), 0.1) 0%, transparent 70%);
    border-radius: 50%;
}

.president-welcome-inner {
    display: flex;
    align-items: center;
    gap: 2rem;
    position: relative;
    z-index: 2;
}

.president-photo-wrap {
    position: relative;
    flex-shrink: 0;
}

.president-photo, .president-photo-placeholder {
    width: 120px;
    height: 120px;
    border-radius: 50%;
    object-fit: cover;
    border: 4px solid white;
    box-shadow: 0 10px 25px rgba(0,0,0,0.1);
}

.president-photo-placeholder {
    background: linear-gradient(135deg, var(--primary), var(--primary-dark));
    color: white;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 3rem;
    font-weight: 700;
    font-family: var(--font-display);
}

.president-badge {
    position: absolute;
    bottom: -10px;
    left: 50%;
    transform: translateX(-50%);
    background: linear-gradient(135deg, #fbbf24, #d97706);
    color: white;
    font-size: 0.75rem;
    font-weight: 700;
    padding: 0.25rem 0.75rem;
    border-radius: var(--radius-full);
    white-space: nowrap;
    box-shadow: 0 4px 10px rgba(217,119,6,0.3);
    border: 2px solid white;
    display: flex;
    align-items: center;
    gap: 0.2rem;
}

.president-message {
    flex: 1;
}

.president-greeting {
    font-size: 1.25rem;
    font-family: var(--font-display);
    color: var(--text-heading);
    font-weight: 600;
    line-height: 1.5;
    margin-bottom: 0.75rem;
    font-style: italic;
}

.president-name {
    font-weight: 700;
    color: var(--primary);
    margin: 0;
    font-size: 0.95rem;
}

@media (max-width: 767.98px) {
    .president-welcome-inner {
        flex-direction: column;
        text-align: center;
        gap: 1.5rem;
    }
    .president-greeting {
        font-size: 1.1rem;
    }
}

/* Circular Profile Photos */
.profile-photo-container {
    position: relative;
    width: 140px;
    height: 140px;
    margin: 0 auto 1.5rem;
}

.profile-photo-circle, .profile-photo-placeholder {
    width: 100%;
    height: 100%;
    border-radius: 50%;
    object-fit: cover;
    border: 4px solid white;
    box-shadow: var(--shadow-md);
}

.profile-photo-placeholder {
    background: linear-gradient(135deg, var(--primary-light), var(--primary));
    color: white;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 4rem;
    font-weight: 700;
    font-family: var(--font-display);
}

.profile-role-tag {
    position: absolute;
    bottom: -10px;
    left: 50%;
    transform: translateX(-50%);
    color: white;
    font-size: 0.8rem;
    font-weight: 700;
    padding: 0.35rem 1rem;
    border-radius: var(--radius-full);
    white-space: nowrap;
    border: 2px solid white;
    box-shadow: var(--shadow-sm);
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
}

.role-leader { background: linear-gradient(135deg, #fbbf24, #d97706); }  /* Gold */
.role-officer { background: linear-gradient(135deg, #38bdf8, #0284c7); } /* Blue */
.role-member { background: linear-gradient(135deg, var(--primary-500), var(--primary-700)); } /* Teal */

/* Hierarchy Role Tags */
.hierarchy-role-tag {
    position: absolute;
    bottom: -8px;
    left: 50%;
    transform: translateX(-50%);
    font-size: 0.65rem;
    font-weight: 700;
    padding: 0.2rem 0.6rem;
    border-radius: var(--radius-full);
    white-space: nowrap;
    color: white;
    border: 2px solid white;
    box-shadow: 0 2px 5px rgba(0,0,0,0.1);
    display: inline-flex;
    align-items: center;
    gap: 0.2rem;
    z-index: 2;
}

.tag-president { background: linear-gradient(135deg, #fbbf24, #d97706); }
.tag-vice { background: linear-gradient(135deg, #38bdf8, #0284c7); }
.tag-officer { background: linear-gradient(135deg, var(--primary), var(--primary-dark)); }

.member-avatar-circle {
    width: 60px;
    height: 60px;
    border-radius: 50%;
    object-fit: cover;
    border: 2px solid white;
    box-shadow: var(--shadow-sm);
}

.avatar-leader .member-avatar-circle,
.avatar-leader .avatar-placeholder {
    width: 75px;
    height: 75px;
    font-size: 2rem;
    border-width: 3px;
    border-color: #fef3c7;
}

.member-leader-card {
    background: linear-gradient(to right, rgba(251, 191, 36, 0.05), transparent);
    border-left: 4px solid #f59e0b;
}


/* Header Navbar User Photo */
.nav-user-photo {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    object-fit: cover;
    margin-right: 0.5rem;
    border: 1px solid rgba(255,255,255,0.2);
}

.nav-user-placeholder {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: rgba(255,255,255,0.2);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 600;
    font-size: 14px;
    margin-right: 0.5rem;
}

/* ==============================
   AUTH PAGES
   ============================== */
.auth-section {
    min-height: calc(100vh - 80px - 250px);
    display: flex;
    align-items: center;
    padding: 6rem 0;
    position: relative;
    background: radial-gradient(circle at top right, rgba(14, 165, 233, 0.08) 0%, transparent 40%),
                radial-gradient(circle at bottom left, rgba(14, 165, 233, 0.05) 0%, transparent 40%);
}

.auth-card {
    background: #ffffff;
    border-radius: 24px;
    box-shadow: 0 20px 60px rgba(0,0,0,0.06), 0 0 0 1px rgba(0,161,140,0.05);
    padding: 3.5rem 3rem;
    position: relative;
    overflow: hidden;
}

.auth-card::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0; height: 6px;
    background: linear-gradient(90deg, var(--primary), var(--primary-light));
}

.auth-icon {
    width: 72px;
    height: 72px;
    margin: 0 auto 1.5rem;
    background: var(--primary-50);
    color: var(--primary);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2.2rem;
    box-shadow: 0 10px 25px rgba(0,161,140,0.15);
}

.auth-icon-verify { color: #f59e0b; background: rgba(245, 158, 11, 0.1); }
.auth-icon-signup { color: #3b82f6; background: rgba(59, 130, 246, 0.1); box-shadow: 0 10px 25px rgba(59,130,246,0.15); }

.auth-header h2 {
    font-family: var(--font-display);
    font-weight: 800;
    font-size: 2rem;
    color: var(--text-heading);
    margin-bottom: 0.5rem;
    letter-spacing: -0.02em;
}

.auth-header p {
    color: var(--text-secondary);
    font-size: 1rem;
    margin-bottom: 2.5rem;
}

.auth-form .form-label {
    font-weight: 600;
    font-size: 0.9rem;
    color: var(--text-color);
    margin-bottom: 0.5rem;
}

.auth-form .form-control,
.auth-form .form-select {
    border-radius: 12px;
    padding: 0.85rem 1.25rem;
    border: 2px solid var(--border);
    background: #f8fafc;
    transition: all var(--duration-normal) var(--ease-out);
    font-size: 1rem;
    min-height: 54px;
}

.auth-form .form-control:focus,
.auth-form .form-select:focus {
    background: #ffffff;
    border-color: var(--primary-light);
    box-shadow: 0 0 0 4px rgba(14, 165, 233, 0.1);
}

.auth-submit-btn {
    border-radius: 12px !important;
    padding: 1rem !important;
    font-size: 1.1rem !important;
    font-weight: 700 !important;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-top: 1rem;
}

.btn-outline-auth {
    border: 2px solid rgba(14, 165, 233, 0.3);
    color: var(--primary-dark);
    border-radius: 12px;
    padding: 0.85rem 1rem;
    font-weight: 600;
    transition: all var(--duration-normal) var(--ease-spring);
    background: white;
}

.btn-outline-auth:hover {
    background: var(--primary-50);
    border-color: var(--primary);
    color: var(--primary-dark);
    transform: translateY(-2px);
}

.auth-alt-link {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    color: var(--text-secondary);
    font-weight: 500;
    transition: all 0.2s ease;
}

.auth-alt-link:hover {
    color: var(--primary);
}

/* Steps Indicator */
.steps-indicator {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 3rem;
}

.step {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.5rem;
    position: relative;
    z-index: 2;
}

.step-number {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: #f1f5f9;
    color: #94a3b8;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 1rem;
    border: 2px solid transparent;
    transition: all 0.3s ease;
}

.step span {
    font-size: 0.8rem;
    font-weight: 600;
    color: #94a3b8;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.step.active .step-number {
    background: var(--primary);
    color: white;
    box-shadow: 0 0 0 4px var(--primary-50);
}

.step.active span { color: var(--primary-dark); }

.step.completed .step-number {
    background: white;
    color: var(--primary);
    border-color: var(--primary);
}

.step.completed span { color: var(--primary); }

.step-line {
    flex-grow: 1;
    height: 3px;
    background: #e2e8f0;
    margin: 0 1rem;
    transform: translateY(-12px);
    z-index: 1;
    transition: all 0.3s ease;
}

.step-line.active { background: var(--primary); }

/* Dashboard Custom Buttons */
.btn-outline-teal {
    color: var(--primary);
    border-color: rgba(0, 161, 140, 0.4);
    background: transparent;
    transition: all 0.2s ease;
}

.btn-outline-teal:hover {
    color: #ffffff;
    background: var(--primary);
    border-color: var(--primary);
}

/* =====================================================
   Premium Green Redesign Override
   White, light-green, smooth 3D association interface
   ===================================================== */
:root {
    --primary-50: #ecfdf5;
    --primary-100: #d1fae5;
    --primary-200: #a7f3d0;
    --primary-300: #6ee7b7;
    --primary-400: #34d399;
    --primary-500: #10b981;
    --primary-600: #059669;
    --primary-700: #047857;
    --primary-800: #065f46;
    --primary-900: #064e3b;
    --primary-rgb: 5, 150, 105;
    --primary: var(--primary-600);
    --primary-dark: var(--primary-900);
    --primary-light: var(--primary-300);
    --accent-mint: #13b981;
    --accent-cyan: #0ea5a3;
    --accent-gold: #d89d24;
    --bg-body: #f7fcf9;
    --bg-card: rgba(255, 255, 255, 0.84);
    --bg-muted: #edf8f1;
    --surface: #ffffff;
    --border: rgba(5, 150, 105, 0.16);
    --border-light: rgba(5, 150, 105, 0.09);
    --radius-sm: 12px;
    --radius-md: 16px;
    --radius-lg: 20px;
    --radius-xl: 28px;
    --radius-2xl: 34px;
    --radius-full: 999px;
    --duration-fast: 160ms;
    --duration-normal: 280ms;
    --duration-slow: 700ms;
    --font-display: var(--font-sans);
    --shadow-sm: 0 6px 16px rgba(6, 95, 70, 0.06);
    --shadow-md: 0 14px 36px rgba(6, 95, 70, 0.1);
    --shadow-lg: 0 24px 60px rgba(6, 95, 70, 0.14);
    --shadow-xl: 0 34px 90px rgba(6, 95, 70, 0.18);
    --shadow-glow: 0 18px 44px rgba(16, 185, 129, 0.26);
}

main {
    background:
        linear-gradient(180deg, rgba(236, 253, 245, 0.9), rgba(255, 255, 255, 0.84) 34%, rgba(240, 253, 244, 0.72)),
        radial-gradient(circle at 8% 4%, rgba(167, 243, 208, 0.42), transparent 28%),
        radial-gradient(circle at 92% 18%, rgba(187, 247, 208, 0.35), transparent 26%);
    background-color: var(--bg-body);
}

body::before {
    content: "";
    position: fixed;
    inset: 0;
    z-index: -2;
    pointer-events: none;
    background-image:
        linear-gradient(rgba(6, 95, 70, 0.035) 1px, transparent 1px),
        linear-gradient(90deg, rgba(6, 95, 70, 0.035) 1px, transparent 1px);
    background-size: 42px 42px;
    mask-image: linear-gradient(to bottom, black, transparent 72%);
    -webkit-mask-image: linear-gradient(to bottom, black, transparent 72%);
}

.brand-logo {
    height: 130px;
    width: auto;
    object-fit: contain;
    margin-top: -30px;
    margin-bottom: -30px;
    position: relative;
    z-index: 10;
    filter: drop-shadow(0 10px 18px rgba(6, 95, 70, 0.12));
}

.footer-logo {
    height: 80px;
    width: auto;
    object-fit: contain;
    filter: drop-shadow(0 10px 22px rgba(0, 0, 0, 0.16));
}

.navbar-custom {
    background: rgba(255, 255, 255, 0.82) !important;
    border-bottom: 1px solid rgba(5, 150, 105, 0.12);
    box-shadow: 0 14px 40px rgba(6, 95, 70, 0.06);
}

.navbar-custom .nav-link {
    color: #12362b;
    background: transparent;
}

.navbar-custom .nav-link:hover,
.navbar-custom .nav-link.active {
    color: var(--primary-800) !important;
    background: rgba(209, 250, 229, 0.7);
    border-color: rgba(5, 150, 105, 0.16);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.86), 0 8px 22px rgba(6, 95, 70, 0.08);
}

.glass-card,
.filter-card,
.store-card,
.hierarchy-card,
.dashboard-card,
.detail-card,
.auth-card,
.empty-state,
.president-welcome-banner {
    background:
        linear-gradient(145deg, rgba(255, 255, 255, 0.94), rgba(246, 255, 250, 0.78)) !important;
    border: 1px solid rgba(5, 150, 105, 0.14) !important;
    box-shadow:
        0 1px 0 rgba(255, 255, 255, 0.9) inset,
        0 24px 60px rgba(6, 95, 70, 0.1),
        0 8px 18px rgba(6, 95, 70, 0.05) !important;
    transform-style: preserve-3d;
}

.glass-card:hover,
.store-card:hover,
.hierarchy-card:hover,
.dashboard-card:hover,
.detail-card:hover,
.feature-card:hover,
.stat-card:hover {
    border-color: rgba(5, 150, 105, 0.28) !important;
    box-shadow:
        0 1px 0 rgba(255, 255, 255, 0.95) inset,
        0 34px 90px rgba(6, 95, 70, 0.16),
        0 0 0 1px rgba(167, 243, 208, 0.32) !important;
}

.btn-glow,
.btn-primary,
.auth-submit-btn {
    background: linear-gradient(135deg, var(--primary-500), var(--primary-700)) !important;
    border: 0 !important;
    color: #ffffff !important;
    box-shadow: 0 16px 32px rgba(5, 150, 105, 0.26), inset 0 1px 0 rgba(255, 255, 255, 0.28) !important;
}

.btn-glow:hover,
.btn-primary:hover,
.auth-submit-btn:hover {
    transform: translateY(-3px) scale(1.01);
    box-shadow: 0 24px 44px rgba(5, 150, 105, 0.32), inset 0 1px 0 rgba(255, 255, 255, 0.36) !important;
}

.btn-soft,
.btn-outline-primary,
.btn-login,
.btn-outline-auth,
.btn-outline-teal {
    background: rgba(255, 255, 255, 0.82) !important;
    border: 1.5px solid rgba(5, 150, 105, 0.24) !important;
    color: var(--primary-800) !important;
    box-shadow: 0 12px 28px rgba(6, 95, 70, 0.08);
}

.btn-soft:hover,
.btn-outline-primary:hover,
.btn-login:hover,
.btn-outline-auth:hover,
.btn-outline-teal:hover {
    background: var(--primary-50) !important;
    color: var(--primary-900) !important;
    transform: translateY(-2px);
    border-color: rgba(5, 150, 105, 0.42) !important;
}

.btn-register {
    background: linear-gradient(135deg, var(--primary-500), var(--primary-700)) !important;
    color: #ffffff !important;
    border-color: rgba(5, 150, 105, 0.3) !important;
}

.btn-register:hover {
    background: linear-gradient(135deg, var(--primary-600), var(--primary-800)) !important;
    color: #ffffff !important;
}

.hero-section {
    min-height: 92vh;
    background:
        radial-gradient(circle at 8% 18%, rgba(167, 243, 208, 0.42), transparent 24%),
        radial-gradient(circle at 84% 28%, rgba(220, 252, 231, 0.9), transparent 34%),
        linear-gradient(135deg, #ffffff 0%, #f5fff9 46%, #ebfff4 100%);
}

.hero-section::before,
.page-header::before,
.content-section::before {
    content: "";
    position: absolute;
    pointer-events: none;
}

.hero-section::before {
    inset: 9% 5% auto auto;
    width: 44vw;
    height: 44vw;
    max-width: 620px;
    max-height: 620px;
    border: 1px solid rgba(5, 150, 105, 0.1);
    border-radius: 50%;
    background: conic-gradient(from 160deg, rgba(5, 150, 105, 0.18), transparent, rgba(167, 243, 208, 0.36), transparent);
    filter: blur(0.2px);
    animation: slow-orbit 18s linear infinite;
}

.public-hero-layout {
    text-align: left;
}

.hero-kicker {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.48rem 0.9rem;
    margin-bottom: 1.15rem;
    color: var(--primary-800);
    background: rgba(209, 250, 229, 0.62);
    border: 1px solid rgba(5, 150, 105, 0.18);
    border-radius: var(--radius-full);
    font-weight: 800;
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.public-hero-title,
.hero-title {
    font-size: clamp(2.8rem, 6vw, 5.4rem);
    font-weight: 800;
    color: #0b2f25;
    line-height: 1.02;
    margin-bottom: 1.4rem;
    letter-spacing: 0;
}

.gradient-text {
    background: linear-gradient(135deg, var(--primary-500), var(--primary-800));
    background-clip: text;
    -webkit-background-clip: text;
    color: transparent;
    -webkit-text-fill-color: transparent;
}

.public-hero-copy,
.hero-subtitle {
    color: #416157;
    font-size: 1.12rem;
    max-width: 560px;
    margin-bottom: 2rem;
    font-weight: 600;
    line-height: 1.7;
}

.hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.9rem;
    margin-bottom: 1.4rem;
}

.hero-actions .btn {
    border-radius: var(--radius-full);
    padding: 0.95rem 1.55rem;
}

.hero-trust-strip {
    display: flex;
    flex-wrap: wrap;
    gap: 0.7rem;
    color: #315449;
    font-weight: 700;
    font-size: 0.86rem;
}

.hero-trust-strip span {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.52rem 0.78rem;
    background: rgba(255, 255, 255, 0.72);
    border: 1px solid rgba(5, 150, 105, 0.12);
    border-radius: var(--radius-full);
    box-shadow: 0 10px 24px rgba(6, 95, 70, 0.06);
}

.hero-visual-shell {
    position: relative;
    max-width: 600px;
    margin-inline: auto;
    padding: 1rem;
    border-radius: 42px;
    background:
        linear-gradient(145deg, rgba(255, 255, 255, 0.92), rgba(236, 253, 245, 0.58)),
        linear-gradient(135deg, rgba(255, 255, 255, 0.8), rgba(16, 185, 129, 0.18));
    border: 1px solid rgba(5, 150, 105, 0.16);
    box-shadow: 0 40px 100px rgba(6, 95, 70, 0.16), inset 0 1px 0 rgba(255, 255, 255, 0.9);
    transform: perspective(1200px) rotateX(2deg) rotateY(-5deg);
    transition: transform 450ms var(--ease-out), box-shadow 450ms var(--ease-out);
}

.hero-visual-shell:hover {
    transform: perspective(1200px) rotateX(0deg) rotateY(0deg) translateY(-6px);
    box-shadow: 0 50px 120px rgba(6, 95, 70, 0.2), inset 0 1px 0 rgba(255, 255, 255, 0.95);
}

.hero-visual-image {
    max-height: 640px;
    width: 100%;
    object-fit: contain;
    filter: drop-shadow(0 26px 42px rgba(6, 95, 70, 0.13));
}

.hero-float-card {
    position: absolute;
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.72rem 0.95rem;
    border-radius: var(--radius-full);
    background: rgba(255, 255, 255, 0.86);
    border: 1px solid rgba(5, 150, 105, 0.14);
    color: var(--primary-900);
    font-weight: 800;
    font-size: 0.82rem;
    box-shadow: 0 18px 42px rgba(6, 95, 70, 0.14);
    animation: hover-float 4.8s ease-in-out infinite;
}

.hero-float-card i {
    color: var(--primary-600);
}

.hero-float-card-one {
    left: 0.9rem;
    top: 14%;
}

.hero-float-card-two {
    right: 0.6rem;
    bottom: 18%;
    animation-delay: -1.7s;
}

.choice-card {
    color: var(--text-heading);
    background: rgba(255, 255, 255, 0.74);
    border-color: rgba(5, 150, 105, 0.14);
    box-shadow: 0 24px 60px rgba(6, 95, 70, 0.1);
}

.choice-card:hover {
    color: var(--text-heading);
    background: rgba(255, 255, 255, 0.9);
    transform: translateY(-10px) rotateX(4deg) scale(1.015);
}

.choice-icon,
.feature-icon-wrap,
.stat-icon,
.auth-icon {
    background: linear-gradient(135deg, rgba(209, 250, 229, 0.95), rgba(255, 255, 255, 0.86));
    border-color: rgba(5, 150, 105, 0.15);
    color: var(--primary-700);
}

.stats-section,
.features-section,
.announcements-section,
.cta-section,
.content-section,
.auth-section {
    position: relative;
    background: transparent;
}

.stats-section,
.features-section,
.announcements-section {
    padding: 5.5rem 0;
}

.stat-card,
.feature-card {
    background: linear-gradient(145deg, rgba(255, 255, 255, 0.94), rgba(240, 253, 244, 0.74));
    border-color: rgba(5, 150, 105, 0.13);
}

.stat-card:hover,
.feature-card:hover {
    transform: perspective(900px) translateY(-10px) rotateX(3deg);
}

.stat-number {
    background: linear-gradient(135deg, #0b2f25, var(--primary-600));
    background-clip: text;
    -webkit-background-clip: text;
}

.section-title {
    color: #0b2f25;
    font-size: clamp(1.7rem, 3vw, 2.35rem);
    letter-spacing: 0;
}

.section-subtitle {
    color: #49685e;
}

.page-header {
    background:
        radial-gradient(circle at 84% 12%, rgba(167, 243, 208, 0.34), transparent 26%),
        linear-gradient(135deg, var(--primary-900), var(--primary-700) 58%, #16a36f);
    border-bottom: 0;
    box-shadow: 0 28px 70px rgba(6, 95, 70, 0.18);
    overflow: hidden;
}

.page-header::before {
    inset: auto -8% -110% auto;
    width: 420px;
    height: 420px;
    border-radius: 50%;
    border: 1px solid rgba(255, 255, 255, 0.16);
    background: conic-gradient(from 90deg, rgba(255, 255, 255, 0.22), transparent, rgba(209, 250, 229, 0.24), transparent);
}

.page-title {
    letter-spacing: 0;
}

.filter-card {
    border-radius: 26px;
}

.form-control,
.form-select,
.input-group-text {
    background: rgba(255, 255, 255, 0.78);
    border-color: rgba(5, 150, 105, 0.17);
    border-radius: 14px;
}

.input-group .form-control {
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
}

.input-group-text {
    color: var(--primary-700);
}

.form-control:focus,
.form-select:focus {
    border-color: var(--primary-500);
    box-shadow: 0 0 0 4px rgba(16, 185, 129, 0.13);
}

.store-card {
    border-radius: 28px;
}

.store-card-header {
    padding: 1.35rem 1.35rem 0;
}

.store-card-footer {
    padding: 0 1.35rem 1.35rem;
}

.store-avatar img,
.avatar-store,
.detail-avatar img {
    border-radius: 50%;
    box-shadow: 0 12px 28px rgba(6, 95, 70, 0.13);
}

.store-card:hover {
    transform: perspective(900px) translateY(-8px) rotateX(2deg);
}

.hierarchy-card {
    border-left: 0;
    border-radius: 28px;
    position: relative;
}

.hierarchy-card::before {
    content: "";
    position: absolute;
    inset: 0 auto 0 0;
    width: 5px;
    border-radius: 28px 0 0 28px;
    background: linear-gradient(180deg, var(--primary-300), var(--primary-700));
}

.member-mini-card {
    background: rgba(255, 255, 255, 0.76);
    border-color: rgba(5, 150, 105, 0.12);
    border-radius: 20px;
    box-shadow: 0 10px 26px rgba(6, 95, 70, 0.06);
}

.member-mini-card:hover {
    background: var(--primary-50);
    border-color: rgba(5, 150, 105, 0.24);
    transform: translateX(4px) translateY(-2px);
}

.detail-card {
    border-radius: 32px;
}

.hierarchy-person-photo,
.hierarchy-person-placeholder {
    width: 56px;
    height: 56px;
    flex: 0 0 56px;
    border-radius: 18px;
}

.hierarchy-person-photo {
    overflow: hidden;
    background: rgba(236, 253, 245, 0.9);
    border: 2px solid rgba(255, 255, 255, 0.95);
    box-shadow: 0 12px 28px rgba(6, 95, 70, 0.13);
}

.hierarchy-person-photo img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
    object-position: center top;
}

.hierarchy-person-placeholder {
    display: grid;
    place-items: center;
    color: #ffffff;
    font-size: 1.15rem;
    font-weight: 800;
    background: linear-gradient(135deg, var(--primary), var(--accent-cyan));
    box-shadow: 0 12px 28px rgba(6, 95, 70, 0.13);
}

.hierarchy-person-placeholder-info {
    background: linear-gradient(135deg, #0891b2, #2563eb);
}

.detail-item {
    background: rgba(240, 253, 244, 0.75);
    border-color: rgba(5, 150, 105, 0.12);
    border-radius: 16px;
}

.admin-section {
    background: rgba(255, 251, 235, 0.7);
    border-color: rgba(216, 157, 36, 0.24);
}

.dashboard-card,
.quick-link-card {
    border-radius: 26px;
}

.quick-link-card:hover {
    transform: translateY(-4px);
}

.cta-card {
    background:
        radial-gradient(circle at 86% 8%, rgba(167, 243, 208, 0.3), transparent 28%),
        linear-gradient(135deg, #064e3b, #047857 52%, #10b981) !important;
    border-color: rgba(255, 255, 255, 0.22) !important;
}

.footer-custom {
    background:
        radial-gradient(circle at 10% 10%, rgba(167, 243, 208, 0.14), transparent 28%),
        linear-gradient(135deg, #052e22, #064e3b);
}

.carousel-3d-card {
    background: rgba(255, 255, 255, 0.9);
    border-color: rgba(5, 150, 105, 0.14);
}

.carousel-3d-card.active {
    box-shadow: 0 44px 100px rgba(6, 95, 70, 0.22), 0 0 0 1px rgba(16, 185, 129, 0.22);
}

.carousel-card-image {
    background: linear-gradient(135deg, var(--primary-50), var(--primary-200));
}

.carousel-3d-btn {
    border-color: rgba(5, 150, 105, 0.18);
    color: var(--primary-900);
}

.carousel-3d-btn:hover {
    background: var(--primary-600);
    border-color: var(--primary-600);
}

.badge.bg-primary-subtle,
.text-primary,
.hover-primary:hover {
    color: var(--primary-700) !important;
}

.bg-primary-subtle {
    background: var(--primary-50) !important;
}

@keyframes slow-orbit {
    from { transform: rotate(0deg); }
    to { transform: rotate(360deg); }
}

@keyframes hover-float {
    0%, 100% { transform: translateY(0) translateZ(20px); }
    50% { transform: translateY(-12px) translateZ(34px); }
}

@media (max-width: 991.98px) {
    .brand-logo {
        height: 90px;
        margin-top: -18px;
        margin-bottom: -18px;
    }

    .public-hero-layout,
    .hero-content {
        text-align: center !important;
    }

    .public-hero-copy,
    .hero-subtitle {
        margin-inline: auto;
    }

    .hero-actions,
    .hero-trust-strip {
        justify-content: center;
    }

    .hero-section::before {
        width: 70vw;
        height: 70vw;
        inset: 8% -18% auto auto;
    }
}

@media (max-width: 767.98px) {
    .public-hero-title,
    .hero-title {
        font-size: clamp(2.2rem, 12vw, 3.3rem);
    }

    .hero-section {
        min-height: auto;
    }

    .hero-visual-shell {
        border-radius: 28px;
        padding: 0.7rem;
        transform: none;
    }

    .hero-float-card {
        position: static;
        margin: 0.35rem;
    }

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

    .stats-section,
    .features-section,
    .announcements-section {
        padding: 3.5rem 0;
    }
}

/* =====================================================
   Hero Fit Pass
   Keep the first-page experience fully visible on desktop
   and compact, readable, and ordered on mobile.
   ===================================================== */
@media (min-width: 992px) {
    body {
        padding-top: 86px;
    }

    .navbar-custom {
        padding: 0.38rem 0;
    }

    .brand-logo {
        height: 82px;
        margin-top: -8px;
        margin-bottom: -8px;
    }

    .navbar-custom .nav-link {
        padding: 0.38rem 0.95rem !important;
        font-size: 0.78rem;
    }

    .btn-login,
    .btn-register {
        padding: 0.48rem 1.25rem !important;
        border-radius: var(--radius-full) !important;
    }

    .hero-section {
        min-height: calc(100vh - 86px);
        margin-top: -86px;
        padding-top: 86px;
        align-items: center;
    }

    .hero-content {
        padding: 1.35rem 0 1.75rem;
    }

    .public-hero-layout {
        min-height: calc(100vh - 122px);
    }

    .hero-kicker {
        margin-bottom: 0.85rem;
        padding: 0.42rem 0.82rem;
        font-size: 0.72rem;
    }

    .public-hero-title,
    .hero-title {
        font-size: clamp(3.15rem, 4.65vw, 4.45rem);
        line-height: 1.01;
        margin-bottom: 1rem;
    }

    .public-hero-copy,
    .hero-subtitle {
        font-size: 1rem;
        line-height: 1.55;
        margin-bottom: 1.15rem;
        max-width: 520px;
    }

    .hero-actions {
        gap: 0.75rem;
        margin-bottom: 0.85rem;
    }

    .hero-actions .btn {
        padding: 0.78rem 1.28rem;
        font-size: 0.95rem;
    }

    .hero-trust-strip {
        gap: 0.5rem;
        font-size: 0.76rem;
    }

    .hero-trust-strip span {
        padding: 0.42rem 0.65rem;
    }

    .hero-visual-shell {
        max-width: min(520px, 42vw);
        padding: 0.72rem;
        border-radius: 32px;
    }

    .hero-visual-image {
        max-height: min(54vh, 500px);
    }

    .hero-float-card {
        padding: 0.58rem 0.78rem;
        font-size: 0.74rem;
    }
}

@media (min-width: 1400px) {
    .public-hero-title,
    .hero-title {
        font-size: clamp(3.35rem, 4.25vw, 4.85rem);
    }

    .hero-visual-shell {
        max-width: min(600px, 43vw);
    }

    .hero-visual-image {
        max-height: min(58vh, 560px);
    }
}

@media (max-width: 991.98px) {
    body {
        padding-top: 72px;
    }

    .navbar-custom {
        padding: 0.35rem 0;
    }

    .brand-logo {
        height: 70px;
        margin-top: -8px;
        margin-bottom: -8px;
    }

    .navbar-collapse {
        padding: 0.75rem 0 0.35rem;
    }

    .navbar-custom .nav-link,
    .btn-login,
    .btn-register {
        width: 100%;
        justify-content: center;
        margin: 0.18rem 0;
    }

    .hero-section {
        margin-top: -72px;
        padding-top: 72px;
        min-height: 100vh;
        display: flex;
        align-items: center;
    }

    .hero-section > .container {
        width: 100%;
    }

    .hero-content {
        padding: 2rem 0 2.5rem;
    }

    .hero-kicker {
        font-size: 0.68rem;
        padding: 0.38rem 0.72rem;
        margin-bottom: 1rem;
    }

    .public-hero-title,
    .hero-title {
        font-size: clamp(2.35rem, 10vw, 3.45rem);
        line-height: 1.08;
        margin-bottom: 1rem;
    }

    .public-hero-copy,
    .hero-subtitle {
        font-size: 0.95rem;
        line-height: 1.55;
        margin-bottom: 1.25rem;
    }

    .hero-actions {
        margin-bottom: 1rem;
    }

    .hero-visual-shell {
        max-width: 520px;
        margin-top: 1.5rem;
    }

    .hero-visual-image {
        max-height: 420px;
    }

    .carousel-3d {
        height: 400px;
        perspective: none;
    }

    .carousel-3d-card {
        width: min(340px, 85vw);
    }

    .carousel-3d-card.active {
        transform: translate(-50%, -50%) scale(1);
        box-shadow: 0 20px 60px rgba(6, 95, 70, 0.18);
    }

    .carousel-3d-card.prev,
    .carousel-3d-card.next {
        opacity: 0;
        pointer-events: none;
    }

    .carousel-3d-card.far-prev,
    .carousel-3d-card.far-next {
        opacity: 0;
        pointer-events: none;
    }
}

@media (max-width: 575.98px) {
    body {
        padding-top: 66px;
    }

    .brand-logo {
        height: 58px;
        margin-top: -6px;
        margin-bottom: -6px;
    }

    .hero-section {
        margin-top: -66px;
        padding-top: 66px;
        min-height: 100vh;
        align-items: flex-start;
    }

    .hero-content {
        padding: 1rem 0 1.5rem;
    }

    .public-hero-title,
    .hero-title {
        font-size: clamp(1.85rem, 10vw, 2.6rem);
        line-height: 1.06;
        margin-bottom: 0.75rem;
    }

    .hero-kicker {
        max-width: 100%;
        justify-content: center;
        white-space: normal;
        letter-spacing: 0.05em;
        margin-bottom: 0.75rem;
        padding: 0.35rem 0.65rem;
        font-size: 0.65rem;
    }

    .public-hero-copy,
    .hero-subtitle {
        font-size: 0.85rem;
        margin-bottom: 0.85rem;
        line-height: 1.5;
    }

    .hero-actions {
        gap: 0.5rem;
        margin-bottom: 0.75rem;
    }

    .hero-actions .btn {
        padding: 0.65rem 0.9rem;
        font-size: 0.85rem;
    }

    .hero-trust-strip {
        display: grid;
        grid-template-columns: 1fr;
        gap: 0.35rem;
        font-size: 0.74rem;
    }

    .hero-trust-strip span {
        justify-content: center;
        padding: 0.38rem 0.6rem;
    }

    .hero-visual-shell {
        max-width: 92vw;
        border-radius: 22px;
        margin-top: 1rem;
    }

    .hero-visual-image {
        max-height: 260px;
    }

    .carousel-3d {
        height: 380px;
    }

    .carousel-3d-card {
        width: min(300px, 82vw);
    }

    .carousel-3d-card.active {
        transform: translate(-50%, -50%) scale(1);
    }
}

@media (max-width: 389.98px) {
    .hero-content {
        padding: 0.6rem 0 1.25rem;
    }

    .hero-kicker {
        font-size: 0.6rem;
        padding: 0.3rem 0.55rem;
        margin-bottom: 0.65rem;
    }

    .public-hero-title,
    .hero-title {
        font-size: clamp(1.7rem, 10vw, 2.3rem);
        margin-bottom: 0.6rem;
    }

    .public-hero-copy,
    .hero-subtitle {
        font-size: 0.82rem;
        margin-bottom: 0.7rem;
    }

    .hero-actions .btn {
        padding: 0.58rem 0.8rem;
        font-size: 0.82rem;
    }

    .hero-visual-shell {
        margin-top: 0.85rem;
    }

    .hero-visual-image {
        max-height: 220px;
    }
}

/* =====================================================
   Premium Announcement Carousel
   Larger desktop stage, intentional glass depth, and a
   full announcement reader modal.
   ===================================================== */
.announcements-section {
    padding: 6.25rem 0 5.25rem;
    min-height: auto;
    background:
        linear-gradient(rgba(5, 150, 105, 0.035) 1px, transparent 1px),
        linear-gradient(90deg, rgba(5, 150, 105, 0.035) 1px, transparent 1px),
        radial-gradient(circle at 16% 72%, rgba(167, 243, 208, 0.34), transparent 19%),
        radial-gradient(circle at 86% 22%, rgba(186, 230, 253, 0.28), transparent 22%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.92), rgba(240, 253, 244, 0.68));
    background-size: 48px 48px, 48px 48px, auto, auto, auto;
}

.announcements-section .section-header {
    margin-bottom: 2.4rem;
}

.carousel-3d {
    height: 560px;
    max-width: 1220px;
    perspective: 1700px;
}

.carousel-3d::before {
    content: "";
    position: absolute;
    left: 50%;
    bottom: 54px;
    width: min(760px, 70vw);
    height: 90px;
    transform: translateX(-50%);
    background: radial-gradient(ellipse, rgba(6, 95, 70, 0.16), transparent 70%);
    filter: blur(18px);
    pointer-events: none;
}

.carousel-3d-track {
    transform-style: preserve-3d;
}

.carousel-3d-card {
    width: 450px;
    min-height: 430px;
    border-radius: 34px;
    background:
        linear-gradient(150deg, rgba(255, 255, 255, 0.84), rgba(240, 253, 244, 0.52)),
        rgba(255, 255, 255, 0.72);
    backdrop-filter: blur(28px) saturate(180%);
    -webkit-backdrop-filter: blur(28px) saturate(180%);
    border: 1px solid rgba(5, 150, 105, 0.18);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.88),
        0 32px 80px rgba(6, 95, 70, 0.12);
}

.carousel-3d-card.active {
    transform: translate(-50%, -50%) rotateY(0deg) translateZ(170px) scale(1.08);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.95),
        0 48px 110px rgba(6, 95, 70, 0.23),
        0 0 0 1px rgba(16, 185, 129, 0.28);
}

.carousel-3d-card.prev {
    transform: translate(calc(-50% - 360px), -50%) rotateY(28deg) translateZ(-70px) scale(0.86);
    opacity: 0.58;
}

.carousel-3d-card.next {
    transform: translate(calc(-50% + 360px), -50%) rotateY(-28deg) translateZ(-70px) scale(0.86);
    opacity: 0.58;
}

.carousel-3d-card.far-prev {
    transform: translate(calc(-50% - 560px), -50%) rotateY(44deg) translateZ(-170px) scale(0.68);
}

.carousel-3d-card.far-next {
    transform: translate(calc(-50% + 560px), -50%) rotateY(-44deg) translateZ(-170px) scale(0.68);
}

.carousel-card-image {
    height: 205px;
    background:
        radial-gradient(circle at 52% 34%, rgba(16, 185, 129, 0.26), transparent 11%),
        linear-gradient(145deg, rgba(236, 253, 245, 0.84), rgba(255, 255, 255, 0.44));
    border-bottom: 1px solid rgba(5, 150, 105, 0.08);
}

.carousel-card-image img {
    filter: saturate(1.04) contrast(1.02);
}

.carousel-card-placeholder {
    color: rgba(5, 150, 105, 0.32);
    font-size: 3.8rem;
}

.carousel-card-body {
    padding: 1.45rem 1.65rem 1.7rem;
}

.announcement-title {
    font-size: 1.18rem;
    line-height: 1.28;
}

.announcement-content {
    font-size: 0.94rem;
    color: #4a5f73;
}

.read-more-hint {
    opacity: 1;
    transform: none;
    margin-top: 1rem;
    color: var(--primary-700);
    font-size: 0.9rem;
}

.carousel-3d-btn {
    width: 62px;
    height: 62px;
    background: rgba(255, 255, 255, 0.8);
    border-color: rgba(5, 150, 105, 0.18);
    box-shadow: 0 24px 56px rgba(6, 95, 70, 0.14);
}

.carousel-3d-btn.prev {
    left: 4.5rem;
}

.carousel-3d-btn.next {
    right: 4.5rem;
}

.carousel-3d-dots {
    bottom: 28px;
}

.announcement-modal-overlay {
    background:
        radial-gradient(circle at 18% 16%, rgba(167, 243, 208, 0.28), transparent 30%),
        rgba(5, 34, 26, 0.72);
    backdrop-filter: blur(18px) saturate(150%);
    -webkit-backdrop-filter: blur(18px) saturate(150%);
    padding: 2rem;
}

.announcement-modal {
    width: min(1120px, 94vw);
    max-width: none;
    max-height: 88vh;
    border-radius: 34px;
    background:
        linear-gradient(145deg, rgba(255, 255, 255, 0.92), rgba(236, 253, 245, 0.78));
    border: 1px solid rgba(209, 250, 229, 0.56);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.92),
        0 44px 120px rgba(0, 0, 0, 0.34);
}

.announcement-modal-content {
    max-height: 88vh;
}

.announcement-modal-content:has(.modal-announcement-image) {
    display: grid;
    grid-template-columns: minmax(340px, 0.9fr) minmax(420px, 1.1fr);
    align-items: stretch;
}

.modal-announcement-image {
    height: auto;
    min-height: 560px;
    background: var(--primary-50);
}

.modal-announcement-image img {
    object-fit: cover;
}

.modal-announcement-body {
    padding: 3.4rem 3.6rem 3.2rem;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.modal-announcement-title {
    font-size: clamp(2rem, 3vw, 3.2rem);
    line-height: 1.08;
    color: #082f25;
    margin-bottom: 1.25rem;
}

.modal-announcement-text {
    font-size: 1.08rem;
    color: #334155;
    line-height: 1.85;
}

.announcement-modal-close {
    width: 46px;
    height: 46px;
    top: 1.25rem;
    right: 1.25rem;
}

.announcement-modal-nav {
    width: 48px;
    height: 48px;
    top: 50%;
    transform: translateY(-50%);
    background: rgba(255, 255, 255, 0.86);
    color: var(--primary-900);
    border: 1px solid rgba(5, 150, 105, 0.14);
    box-shadow: 0 16px 38px rgba(6, 95, 70, 0.18);
}

.announcement-modal-nav.prev {
    left: 1.25rem;
}

.announcement-modal-nav.next {
    right: 1.25rem;
}

.announcement-modal-nav:hover {
    transform: translateY(-50%) scale(1.08);
}

.announcement-modal-counter {
    position: absolute;
    right: 1.5rem;
    bottom: 1.2rem;
    border: 0;
    padding: 0.45rem 0.78rem;
    border-radius: var(--radius-full);
    background: rgba(255, 255, 255, 0.74);
    color: var(--primary-800);
    box-shadow: 0 10px 28px rgba(6, 95, 70, 0.12);
}

.announcement-modal-overlay.no-image .announcement-modal {
    width: min(1050px, 90vw);
}

.announcement-modal-overlay.no-image .announcement-modal-content {
    min-height: 390px;
    display: flex;
    align-items: center;
}

.announcement-modal-overlay.no-image .modal-announcement-body {
    width: 100%;
    padding: 4rem 7rem 4.3rem;
}

.announcement-modal-overlay.no-image .modal-announcement-title,
.announcement-modal-overlay.no-image .modal-announcement-text,
.announcement-modal-overlay.no-image .announcement-meta {
    max-width: 820px;
}

.announcement-modal-overlay.no-image .announcement-modal-nav {
    width: 46px;
    height: 46px;
    background: rgba(255, 255, 255, 0.9);
}

.announcement-modal-overlay.no-image .announcement-modal-nav.prev {
    left: 1.4rem;
}

.announcement-modal-overlay.no-image .announcement-modal-nav.next {
    right: 1.4rem;
}

@media (max-width: 1199.98px) {
    .carousel-3d {
        max-width: 960px;
        height: 520px;
    }

    .carousel-3d-card {
        width: 400px;
    }

    .carousel-3d-card.prev {
        transform: translate(calc(-50% - 300px), -50%) rotateY(24deg) translateZ(-70px) scale(0.82);
    }

    .carousel-3d-card.next {
        transform: translate(calc(-50% + 300px), -50%) rotateY(-24deg) translateZ(-70px) scale(0.82);
    }

    .carousel-3d-btn.prev {
        left: 1rem;
    }

    .carousel-3d-btn.next {
        right: 1rem;
    }
}

@media (max-width: 991.98px) {
    .carousel-3d {
        height: 460px;
        max-width: 100%;
        perspective: none;
    }

    .carousel-3d-card {
        width: min(360px, 85vw);
        min-height: 400px;
    }

    .carousel-3d-card.active {
        transform: translate(-50%, -50%) scale(1);
        box-shadow: 0 20px 60px rgba(6, 95, 70, 0.18);
    }

    .carousel-3d-card.prev,
    .carousel-3d-card.next {
        opacity: 0;
        pointer-events: none;
    }

    .carousel-3d-card.far-prev,
    .carousel-3d-card.far-next {
        opacity: 0;
        pointer-events: none;
    }

    .announcement-modal-content:has(.modal-announcement-image) {
        display: block;
    }

    .modal-announcement-image {
        min-height: 260px;
        height: 34vh;
    }

    .modal-announcement-body {
        padding: 2rem 1.5rem 4.2rem;
    }

    .announcement-modal-overlay.no-image .modal-announcement-body {
        padding: 2.4rem 4.8rem 4.6rem;
    }
}

@media (max-width: 575.98px) {
    .announcements-section {
        padding: 3.5rem 0 3.2rem;
    }

    .carousel-3d {
        height: 420px;
        perspective: none;
    }

    .carousel-3d-card {
        width: min(300px, 84vw);
        min-height: 370px;
        border-radius: 26px;
    }

    .carousel-3d-card.active {
        transform: translate(-50%, -50%) scale(1);
    }

    .carousel-card-image {
        height: 170px;
    }

    .carousel-card-body {
        padding: 1.1rem 1.2rem 1.35rem;
    }

    .carousel-3d-card.prev,
    .carousel-3d-card.next,
    .carousel-3d-card.far-prev,
    .carousel-3d-card.far-next {
        opacity: 0;
        pointer-events: none;
    }

    .carousel-3d-btn {
        width: 42px;
        height: 42px;
    }

    .carousel-3d-btn.prev {
        left: 0.25rem;
    }

    .carousel-3d-btn.next {
        right: 0.25rem;
    }

    .announcement-modal-overlay {
        padding: 0.75rem;
        align-items: flex-start;
        overflow-y: auto;
    }

    .announcement-modal {
        width: 100%;
        max-height: none;
        border-radius: 24px;
        margin: 1rem 0;
    }

    .announcement-modal-content {
        max-height: none;
    }

    .modal-announcement-image {
        height: 220px;
        min-height: 220px;
    }

    .modal-announcement-title {
        font-size: 1.65rem;
    }

    .modal-announcement-text {
        font-size: 0.96rem;
        line-height: 1.7;
    }

    .announcement-modal-nav {
        top: auto;
        bottom: 1.1rem;
        transform: none;
    }

    .announcement-modal-nav:hover {
        transform: scale(1.05);
    }

    .announcement-modal-nav.prev {
        left: 1rem;
    }

    .announcement-modal-nav.next {
        right: 1rem;
    }

    .announcement-modal-counter {
        left: 50%;
        right: auto;
        transform: translateX(-50%);
    }

    .announcement-modal-overlay.no-image .announcement-modal {
        width: 100%;
    }

    .announcement-modal-overlay.no-image .announcement-modal-content {
        min-height: 420px;
        display: block;
    }

    .announcement-modal-overlay.no-image .modal-announcement-body {
        padding: 2rem 1.25rem 5.25rem;
    }
}

/* =====================================================
   Impact Stats Section
   Make association scale feel memorable and credible.
   ===================================================== */
.stats-section {
    padding: 7rem 0 6.5rem;
    overflow: hidden;
    background:
        radial-gradient(circle at 12% 22%, rgba(16, 185, 129, 0.16), transparent 22%),
        radial-gradient(circle at 86% 72%, rgba(14, 165, 163, 0.13), transparent 24%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.65), rgba(236, 253, 245, 0.82));
}

.stats-section::before {
    content: "";
    position: absolute;
    inset: 5rem auto auto 50%;
    width: min(980px, 86vw);
    height: min(980px, 86vw);
    transform: translateX(-50%);
    border-radius: 50%;
    background: repeating-conic-gradient(from 18deg, rgba(5, 150, 105, 0.09) 0 8deg, transparent 8deg 18deg);
    mask-image: radial-gradient(circle, transparent 0 42%, black 43% 44%, transparent 45%);
    -webkit-mask-image: radial-gradient(circle, transparent 0 42%, black 43% 44%, transparent 45%);
    opacity: 0.7;
    animation: slow-orbit 36s linear infinite;
    pointer-events: none;
}

.stats-impact-header {
    position: relative;
    z-index: 2;
    max-width: 760px;
    margin: 0 auto 2.6rem;
    text-align: center;
}

.stats-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.46rem 0.86rem;
    margin-bottom: 1rem;
    border-radius: var(--radius-full);
    color: var(--primary-800);
    background: rgba(209, 250, 229, 0.72);
    border: 1px solid rgba(5, 150, 105, 0.18);
    font-size: 0.76rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.stats-impact-header h2 {
    color: #082f25;
    font-size: clamp(2rem, 4vw, 3.55rem);
    font-weight: 800;
    line-height: 1.05;
    margin-bottom: 0.85rem;
    letter-spacing: 0;
}

.stats-impact-header p {
    color: #49685e;
    font-size: 1.05rem;
    font-weight: 600;
    margin: 0 auto;
    max-width: 640px;
}

.stat-card-impact {
    min-height: 390px;
    padding: 2rem;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    border-radius: 36px;
    overflow: hidden;
    position: relative;
    isolation: isolate;
    background:
        linear-gradient(145deg, rgba(255, 255, 255, 0.9), rgba(236, 253, 245, 0.72)),
        radial-gradient(circle at 78% 14%, rgba(16, 185, 129, 0.18), transparent 28%) !important;
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.95),
        0 34px 90px rgba(6, 95, 70, 0.14),
        0 12px 28px rgba(6, 95, 70, 0.08) !important;
}

.stat-card-impact::before {
    content: "";
    position: absolute;
    inset: 1.1rem;
    border-radius: 30px;
    border: 1px solid rgba(5, 150, 105, 0.1);
    pointer-events: none;
    z-index: -1;
}

.stat-card-impact::after {
    content: "";
    position: absolute;
    width: 250px;
    height: 250px;
    right: -74px;
    top: -74px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(167, 243, 208, 0.52), rgba(16, 185, 129, 0.04) 62%, transparent 63%);
    filter: blur(1px);
    z-index: -2;
}

.stat-card-impact:hover {
    transform: perspective(1000px) translateY(-12px) rotateX(3deg) !important;
}

.stat-card-impact .stat-card-orbit {
    position: absolute;
    top: 1.7rem;
    right: 1.7rem;
    width: 118px;
    height: 118px;
    border-radius: 50%;
    border: 1px dashed rgba(5, 150, 105, 0.25);
    animation: slow-orbit 20s linear infinite;
}

.stat-card-impact .stat-card-orbit::before,
.stat-card-impact .stat-card-orbit::after {
    content: "";
    position: absolute;
    border-radius: 50%;
    background: var(--primary-500);
    box-shadow: 0 0 24px rgba(16, 185, 129, 0.45);
}

.stat-card-impact .stat-card-orbit::before {
    width: 12px;
    height: 12px;
    top: 8px;
    left: 18px;
}

.stat-card-impact .stat-card-orbit::after {
    width: 8px;
    height: 8px;
    right: 10px;
    bottom: 20px;
    opacity: 0.55;
}

.stat-card-impact .stat-icon {
    position: absolute;
    top: 2.65rem;
    left: 2rem;
    width: 74px;
    height: 74px;
    margin: 0;
    border-radius: 24px;
    font-size: 1.75rem;
    color: var(--primary-800);
    background: linear-gradient(145deg, rgba(255, 255, 255, 0.92), rgba(209, 250, 229, 0.78));
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.95),
        0 18px 44px rgba(6, 95, 70, 0.12);
}

.stat-number-wrap {
    display: flex;
    align-items: flex-start;
    gap: 0.15rem;
    margin-bottom: 0.25rem;
}

.stat-card-impact .stat-number {
    font-size: clamp(4.2rem, 7vw, 6.7rem);
    line-height: 0.88;
    letter-spacing: 0;
    background: linear-gradient(135deg, #052e22 10%, #059669 70%, #34d399);
    background-clip: text;
    -webkit-background-clip: text;
    filter: drop-shadow(0 16px 26px rgba(6, 95, 70, 0.12));
}

.stat-plus {
    color: var(--primary-600);
    font-size: 2.1rem;
    line-height: 1;
    font-weight: 800;
    margin-top: 0.35rem;
}

.stat-card-impact .stat-label {
    color: #102f29;
    font-size: 1.05rem;
    font-weight: 800;
    margin-bottom: 0.45rem;
}

.stat-caption {
    color: #5f716c;
    font-size: 0.9rem;
    line-height: 1.55;
    font-weight: 600;
    min-height: 2.8rem;
}

.stat-meter {
    height: 8px;
    margin-top: 1.3rem;
    border-radius: var(--radius-full);
    background: rgba(6, 95, 70, 0.08);
    overflow: hidden;
}

.stat-meter span {
    display: block;
    width: var(--meter);
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, var(--primary-300), var(--primary-700));
    box-shadow: 0 0 20px rgba(16, 185, 129, 0.42);
}

.mobile-stats-loop {
    display: none;
}

@media (max-width: 991.98px) {
    .stats-section {
        padding: 5rem 0 4.4rem;
    }

    .stat-card-impact {
        min-height: 330px;
    }

    .stat-card-impact .stat-number {
        font-size: clamp(3.6rem, 12vw, 5rem);
    }
}

@media (max-width: 767.98px) {
    .stats-impact-header {
        margin-bottom: 1.5rem;
    }

    .stats-impact-header h2 {
        font-size: 2rem;
    }

    .stats-impact-header p {
        font-size: 0.94rem;
    }

    .stat-card-impact {
        min-height: 295px;
        padding: 1.45rem;
        border-radius: 28px;
    }

    .stat-card-impact .stat-icon {
        top: 1.55rem;
        left: 1.45rem;
        width: 58px;
        height: 58px;
        border-radius: 18px;
        font-size: 1.35rem;
    }

    .stat-card-impact .stat-card-orbit {
        width: 88px;
        height: 88px;
        top: 1.3rem;
        right: 1.3rem;
    }

    .stat-caption {
        min-height: 0;
    }
}

/* =====================================================
   Unified Section Rhythm
   Consistent typography, compact desktop spacing, and a
   single premium visual language across homepage sections.
   ===================================================== */
:root {
    --section-pad-y: 4.75rem;
    --section-title-size: clamp(2rem, 2.45vw, 2.7rem);
    --section-title-line: 1.08;
    --section-copy-size: 0.98rem;
}

.announcements-section,
.stats-section,
.features-section {
    padding-top: var(--section-pad-y) !important;
    padding-bottom: var(--section-pad-y) !important;
}

.section-header,
.stats-impact-header {
    max-width: 720px;
    margin: 0 auto 2rem !important;
    text-align: center;
}

.section-title,
.stats-impact-header h2,
.cta-card h2 {
    color: #082f25;
    font-size: var(--section-title-size) !important;
    line-height: var(--section-title-line) !important;
    font-weight: 800;
    letter-spacing: 0 !important;
    margin-bottom: 0.65rem;
}

.section-title .gradient-text,
.stats-impact-header h2 .gradient-text {
    background: linear-gradient(135deg, #082f25 0%, var(--primary-600) 78%);
    background-clip: text;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}

.section-subtitle,
.stats-impact-header p {
    color: #526b62 !important;
    font-size: var(--section-copy-size) !important;
    line-height: 1.55;
    font-weight: 600 !important;
    max-width: 620px;
    margin-inline: auto;
}

.stats-eyebrow,
.hero-kicker {
    font-size: 0.7rem;
    letter-spacing: 0.07em;
}

.announcements-section .section-title i {
    color: var(--primary-600) !important;
    font-size: 0.9em !important;
}

.stats-section {
    min-height: auto;
}

.stats-section::before {
    width: min(760px, 70vw);
    height: min(760px, 70vw);
    inset: 7.25rem auto auto 50%;
    opacity: 0.46;
}

.stat-card-impact {
    min-height: 310px;
    padding: 1.55rem;
    border-radius: 28px;
}

.stat-card-impact .stat-icon {
    top: 1.55rem;
    left: 1.55rem;
    width: 58px;
    height: 58px;
    border-radius: 18px;
    font-size: 1.35rem;
}

.stat-card-impact .stat-card-orbit {
    top: 1.25rem;
    right: 1.25rem;
    width: 92px;
    height: 92px;
}

.stat-card-impact .stat-number {
    font-size: clamp(3.8rem, 4.8vw, 5.25rem);
}

.stat-card-impact .stat-label {
    font-size: 0.92rem;
    margin-bottom: 0.35rem;
}

.stat-caption,
.feature-card p,
.announcement-content {
    font-size: 0.84rem;
}

.stat-caption {
    min-height: 2.55rem;
}

.stat-meter {
    height: 6px;
    margin-top: 1rem;
}

.feature-card {
    padding: 1.65rem;
    border-radius: 26px;
}

.feature-icon-wrap {
    width: 52px;
    height: 52px;
    border-radius: 17px;
    font-size: 1.22rem;
    margin-bottom: 1.2rem;
}

.feature-card h4 {
    font-size: 0.98rem;
}

.carousel-3d {
    height: 500px;
}

.carousel-3d-card {
    width: 400px;
    min-height: 390px;
}

.carousel-card-image {
    height: 180px;
}

.announcement-title {
    font-size: 1.02rem;
}

.carousel-card-body {
    padding: 1.2rem 1.35rem 1.35rem;
}

@media (min-width: 1400px) {
    :root {
        --section-pad-y: 4.4rem;
        --section-title-size: 2.55rem;
    }

    .stats-section .container,
    .features-section .container {
        max-width: 1180px;
    }
}

@media (max-width: 991.98px) {
    :root {
        --section-pad-y: 3.5rem;
        --section-title-size: clamp(1.75rem, 6vw, 2.25rem);
    }

    .section-header,
    .stats-impact-header {
        margin-bottom: 1.5rem !important;
    }

    .stat-card-impact {
        min-height: 285px;
    }

    .carousel-3d {
        height: 460px;
        perspective: none;
    }

    .carousel-3d-card.active {
        transform: translate(-50%, -50%) scale(1);
    }

    .carousel-3d-card.prev,
    .carousel-3d-card.next,
    .carousel-3d-card.far-prev,
    .carousel-3d-card.far-next {
        opacity: 0;
        pointer-events: none;
    }
}

@media (max-width: 575.98px) {
    :root {
        --section-pad-y: 3rem;
        --section-copy-size: 0.9rem;
    }

    .stat-card-impact {
        min-height: 270px;
    }

    .stat-card-impact .stat-number {
        font-size: 3.45rem;
    }
}

/* =====================================================
   Hero Network Map Refresh
   Replace single-store feeling with a transparent Odisha
   medical network composition and better left alignment.
   ===================================================== */
.hero-text-stack {
    max-width: 650px;
    padding-left: clamp(0rem, 2.2vw, 2.3rem);
}

.hero-text-stack .hero-kicker {
    margin-bottom: 1.05rem;
}

.hero-text-stack .public-hero-title {
    max-width: 640px;
}

.hero-text-stack .public-hero-copy {
    max-width: 590px;
}

.hero-network-shell {
    padding: 1.25rem;
    border-radius: 42px;
    background:
        linear-gradient(145deg, rgba(255, 255, 255, 0.72), rgba(236, 253, 245, 0.48)),
        radial-gradient(circle at 70% 14%, rgba(16, 185, 129, 0.18), transparent 34%);
    overflow: hidden;
}

.hero-network-shell::before {
    content: "";
    position: absolute;
    inset: 1rem;
    border-radius: 34px;
    background:
        linear-gradient(rgba(5, 150, 105, 0.05) 1px, transparent 1px),
        linear-gradient(90deg, rgba(5, 150, 105, 0.05) 1px, transparent 1px);
    background-size: 34px 34px;
    mask-image: radial-gradient(circle at center, black 0 58%, transparent 78%);
    -webkit-mask-image: radial-gradient(circle at center, black 0 58%, transparent 78%);
    pointer-events: none;
    z-index: 0;
}

.hero-network-shell::after {
    content: "ODISHA NETWORK";
    position: absolute;
    left: 2rem;
    bottom: 1.35rem;
    padding: 0.45rem 0.75rem;
    border-radius: var(--radius-full);
    background: rgba(255, 255, 255, 0.72);
    border: 1px solid rgba(5, 150, 105, 0.14);
    color: rgba(6, 95, 70, 0.78);
    font-size: 0.68rem;
    font-weight: 800;
    letter-spacing: 0.12em;
    z-index: 4;
    box-shadow: 0 14px 34px rgba(6, 95, 70, 0.1);
}

.hero-network-shell .hero-visual-image {
    position: relative;
    z-index: 2;
    max-height: 560px;
    border-radius: 30px;
    opacity: 0.92;
    mix-blend-mode: multiply;
    filter:
        saturate(0.92)
        contrast(1.02)
        drop-shadow(0 26px 42px rgba(6, 95, 70, 0.16));
}

.odisha-network-map {
    position: absolute;
    inset: 5% 2% 0 auto;
    width: 58%;
    height: 96%;
    z-index: 1;
    opacity: 0.62;
    pointer-events: none;
}

.odisha-network-map svg {
    width: 100%;
    height: 100%;
    overflow: visible;
}

.odisha-network-map path {
    fill: rgba(209, 250, 229, 0.32);
    stroke: rgba(5, 150, 105, 0.28);
    stroke-width: 3;
    filter: drop-shadow(0 22px 34px rgba(6, 95, 70, 0.13));
}

.map-node {
    position: absolute;
    width: 13px;
    height: 13px;
    border-radius: 50%;
    background: var(--primary-500);
    box-shadow: 0 0 0 8px rgba(16, 185, 129, 0.14), 0 0 26px rgba(16, 185, 129, 0.5);
    animation: pulse-map-node 2.8s ease-in-out infinite;
}

.node-one {
    top: 26%;
    left: 46%;
}

.node-two {
    top: 52%;
    left: 68%;
    animation-delay: -0.9s;
}

.node-three {
    top: 71%;
    left: 42%;
    animation-delay: -1.8s;
}

.map-line {
    position: absolute;
    height: 2px;
    transform-origin: left center;
    background: linear-gradient(90deg, rgba(5, 150, 105, 0), rgba(5, 150, 105, 0.46), rgba(5, 150, 105, 0));
}

.line-one {
    top: 38%;
    left: 48%;
    width: 120px;
    transform: rotate(30deg);
}

.line-two {
    top: 62%;
    left: 46%;
    width: 140px;
    transform: rotate(-22deg);
}

.hero-float-card-three {
    left: 52%;
    top: 8%;
    animation-delay: -2.8s;
}

@keyframes pulse-map-node {
    0%, 100% { transform: scale(1); opacity: 0.82; }
    50% { transform: scale(1.28); opacity: 1; }
}

@media (min-width: 992px) {
    .hero-text-stack {
        transform: translateY(0.35rem);
    }

    .hero-network-shell {
        max-width: min(620px, 45vw);
    }

    .hero-network-shell .hero-visual-image {
        max-height: min(56vh, 560px);
    }
}

@media (max-width: 991.98px) {
    .hero-text-stack {
        max-width: 680px;
        margin-inline: auto;
        padding-left: 0;
    }

    .hero-network-shell .hero-visual-image {
        mix-blend-mode: normal;
    }

    .odisha-network-map {
        width: 70%;
        right: -8%;
        opacity: 0.46;
    }
}

@media (max-width: 575.98px) {
    .hero-network-shell {
        padding: 0.75rem;
    }

    .hero-network-shell::after {
        left: 1rem;
        bottom: 1rem;
        font-size: 0.58rem;
    }

    .hero-float-card-three {
        display: none;
    }

    .odisha-network-map {
        inset: 2% -18% 0 auto;
        width: 88%;
    }
}

/* =====================================================
   Premium Odisha Map Hero
   Reference-inspired map composition with current glass
   animation language.
   ===================================================== */
.hero-map-shell {
    min-height: 580px;
    display: grid;
    place-items: center;
    background:
        radial-gradient(circle at 58% 45%, rgba(219, 234, 254, 0.72), transparent 42%),
        radial-gradient(circle at 70% 72%, rgba(167, 243, 208, 0.42), transparent 34%),
        linear-gradient(145deg, rgba(255, 255, 255, 0.7), rgba(236, 253, 245, 0.36));
}

.hero-map-shell::before {
    background:
        linear-gradient(rgba(37, 99, 235, 0.045) 1px, transparent 1px),
        linear-gradient(90deg, rgba(5, 150, 105, 0.045) 1px, transparent 1px);
    background-size: 30px 30px;
    opacity: 0.8;
}

.hero-map-shell::after {
    content: "ODISHA MEDICAL NETWORK";
    left: 2.2rem;
    bottom: 1.5rem;
    color: rgba(4, 120, 87, 0.82);
}

.hero-map-shell .hero-odisha-map {
    inset: 2.4rem 1.4rem 2.4rem auto;
    width: 82%;
    height: auto;
    opacity: 1;
    filter: drop-shadow(0 30px 45px rgba(37, 99, 235, 0.12));
}

.hero-odisha-map svg {
    transform: rotate(-3deg);
}

.hero-odisha-map .odisha-shape {
    fill: url(#odishaMapFill);
    stroke: rgba(59, 130, 246, 0.44);
    stroke-width: 3.5;
}

.hero-odisha-map .district-line {
    fill: none;
    stroke: rgba(59, 130, 246, 0.22);
    stroke-width: 2;
    stroke-linecap: round;
    stroke-dasharray: 8 9;
    animation: district-flow 7s linear infinite;
}

.hero-store-preview {
    position: absolute;
    right: 1.65rem;
    bottom: 2.2rem;
    width: 46%;
    max-width: 340px;
    z-index: 4;
    border-radius: 28px;
    padding: 0.65rem;
    background: rgba(255, 255, 255, 0.78);
    border: 1px solid rgba(5, 150, 105, 0.16);
    box-shadow:
        0 32px 70px rgba(6, 95, 70, 0.18),
        inset 0 1px 0 rgba(255, 255, 255, 0.9);
    transform: perspective(900px) rotateY(-8deg) rotateX(3deg);
}

.hero-store-preview .hero-visual-image {
    display: block;
    width: 100%;
    max-height: none;
    border-radius: 22px;
    mix-blend-mode: normal;
    opacity: 0.96;
}

.map-central-pin {
    position: absolute;
    left: 54%;
    top: 47%;
    z-index: 5;
    width: 72px;
    height: 72px;
    border-radius: 26px 26px 26px 6px;
    transform: translate(-50%, -50%) rotate(-45deg);
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(145deg, var(--primary-400), var(--primary-700));
    color: white;
    box-shadow:
        0 22px 40px rgba(5, 150, 105, 0.28),
        0 0 0 12px rgba(16, 185, 129, 0.12);
    animation: map-pin-float 4s ease-in-out infinite;
}

.map-central-pin i {
    transform: rotate(45deg);
    font-size: 2.1rem;
    font-weight: 800;
}

.hero-map-shell .map-node {
    width: 12px;
    height: 12px;
    background: #2563eb;
    box-shadow:
        0 0 0 7px rgba(37, 99, 235, 0.12),
        0 0 24px rgba(37, 99, 235, 0.42);
}

.hero-map-shell .node-one { top: 19%; left: 40%; }
.hero-map-shell .node-two { top: 31%; left: 61%; }
.hero-map-shell .node-three { top: 47%; left: 35%; }
.hero-map-shell .node-four { top: 59%; left: 55%; animation-delay: -0.45s; }
.hero-map-shell .node-five { top: 67%; left: 27%; animation-delay: -0.9s; }
.hero-map-shell .node-six { top: 41%; left: 74%; animation-delay: -1.3s; }
.hero-map-shell .node-seven { top: 25%; left: 78%; animation-delay: -1.8s; }
.hero-map-shell .node-eight { top: 74%; left: 45%; animation-delay: -2.3s; }

.hero-map-shell .map-line {
    background: linear-gradient(90deg, rgba(37, 99, 235, 0), rgba(37, 99, 235, 0.44), rgba(5, 150, 105, 0));
}

.hero-map-shell .line-one {
    top: 36%;
    left: 42%;
    width: 210px;
    transform: rotate(14deg);
}

.hero-map-shell .line-two {
    top: 57%;
    left: 36%;
    width: 245px;
    transform: rotate(-11deg);
}

.hero-map-shell .line-three {
    top: 49%;
    left: 52%;
    width: 175px;
    transform: rotate(47deg);
}

@keyframes district-flow {
    from { stroke-dashoffset: 0; }
    to { stroke-dashoffset: -34; }
}

@keyframes map-pin-float {
    0%, 100% { transform: translate(-50%, -50%) rotate(-45deg) translateY(0); }
    50% { transform: translate(-50%, -50%) rotate(-45deg) translateY(-10px); }
}

@media (min-width: 992px) {
    .hero-map-shell {
        max-width: min(680px, 48vw);
        min-height: min(62vh, 610px);
    }
}

@media (max-width: 991.98px) {
    .hero-map-shell {
        min-height: 470px;
    }

    .hero-map-shell .hero-odisha-map {
        width: 92%;
        inset: 1rem -4% 1rem auto;
    }

    .hero-store-preview {
        width: 44%;
        right: 1rem;
        bottom: 1.5rem;
    }
}

@media (max-width: 575.98px) {
    .hero-map-shell {
        min-height: 340px;
        border-radius: 24px;
    }

    .hero-map-shell .hero-odisha-map {
        width: 112%;
        inset: 0 -18% 0 auto;
    }

    .hero-store-preview {
        width: 48%;
        right: 0.7rem;
        bottom: 0.9rem;
        border-radius: 18px;
        padding: 0.4rem;
    }

    .hero-store-preview .hero-visual-image {
        border-radius: 14px;
    }

    .map-central-pin {
        width: 50px;
        height: 50px;
        border-radius: 18px 18px 18px 5px;
    }

    .map-central-pin i {
        font-size: 1.45rem;
    }

    .hero-map-shell .map-node {
        width: 9px;
        height: 9px;
    }
}

/* Real Odisha outline asset */
.hero-map-shell .hero-odisha-map {
    inset: 1.35rem auto 1.9rem 1.25rem;
    width: 76%;
    height: 84%;
}

.odisha-real-map {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: contain;
    object-position: center;
    opacity: 0.94;
    filter:
        drop-shadow(0 24px 36px rgba(37, 99, 235, 0.13))
        drop-shadow(0 0 28px rgba(96, 165, 250, 0.2));
}

.hero-odisha-map::before,
.hero-odisha-map::after {
    content: "";
    position: absolute;
    z-index: 1;
    border: 2px dashed rgba(37, 99, 235, 0.22);
    border-radius: 54% 46% 56% 44%;
    pointer-events: none;
    animation: slow-orbit 26s linear infinite;
}

.hero-odisha-map::before {
    inset: 18% 24% 16% 22%;
}

.hero-odisha-map::after {
    inset: 30% 16% 26% 34%;
    animation-duration: 34s;
    animation-direction: reverse;
}

.hero-odisha-map svg,
.hero-odisha-map .odisha-shape,
.hero-odisha-map .district-line {
    display: none;
}

.hero-map-shell .map-node,
.hero-map-shell .map-line {
    z-index: 3;
}

.hero-map-shell .node-one { top: 25%; left: 50%; }
.hero-map-shell .node-two { top: 33%; left: 64%; }
.hero-map-shell .node-three { top: 47%; left: 34%; }
.hero-map-shell .node-four { top: 55%; left: 52%; }
.hero-map-shell .node-five { top: 66%; left: 24%; }
.hero-map-shell .node-six { top: 42%; left: 71%; }
.hero-map-shell .node-seven { top: 25%; left: 68%; }
.hero-map-shell .node-eight { top: 74%; left: 42%; }

.map-central-pin {
    left: 48%;
    top: 48%;
}

@media (max-width: 991.98px) {
    .hero-map-shell .hero-odisha-map {
        width: 86%;
        height: 84%;
        inset: 0.8rem auto 1rem 0.6rem;
    }
}

@media (max-width: 575.98px) {
    .hero-map-shell .hero-odisha-map {
        width: 92%;
        height: 80%;
        inset: 0.6rem auto 0.8rem 0.2rem;
    }
}

.hero-store-preview {
    right: 1.4rem;
    bottom: 2rem;
    width: 40%;
    max-width: 300px;
}

@media (max-width: 991.98px) {
    .hero-store-preview {
        width: 38%;
        right: 1rem;
        bottom: 1.4rem;
    }
}

@media (max-width: 575.98px) {
    .hero-store-preview {
        width: 42%;
        right: 0.7rem;
        bottom: 0.8rem;
    }
}

/* =====================================================
   MOBILE LAYOUT FIXES — must be last to override all
   prior rules.
   ===================================================== */

.hero-trust-ticker {
    display: none;
}

@media (max-width: 991.98px) {

    /* ── Hero fills viewport ── */
    .hero-section {
        min-height: 100vh !important;
        min-height: 100dvh !important;
        display: flex !important;
        align-items: center;
    }

    .hero-section > .container {
        width: 100%;
    }

    .hero-content {
        padding: 1.5rem 0 1rem;
    }

    .public-hero-layout {
        min-height: auto;
    }

    /* ── Sections: fit content, don't force viewport ── */
    .announcements-section,
    .stats-section,
    .features-section,
    .cta-section {
        min-height: auto !important;
        padding: 3rem 0 !important;
    }

    /* Hide stacked trust strip, show ticker */
    .hero-trust-strip {
        display: none !important;
    }

    .hero-trust-ticker {
        display: block;
        overflow: hidden;
        margin: 0 -1rem 0.75rem;
        -webkit-mask-image: linear-gradient(90deg, transparent, black 8%, black 92%, transparent);
        mask-image: linear-gradient(90deg, transparent, black 8%, black 92%, transparent);
    }

    .ticker-track {
        display: flex;
        gap: 0.6rem;
        width: max-content;
        animation: ticker-scroll 18s linear infinite;
    }

    .ticker-track span {
        display: inline-flex;
        align-items: center;
        gap: 0.4rem;
        padding: 0.45rem 0.8rem;
        background: rgba(255, 255, 255, 0.72);
        border: 1px solid rgba(5, 150, 105, 0.12);
        border-radius: 100px;
        box-shadow: 0 8px 20px rgba(6, 95, 70, 0.06);
        color: #315449;
        font-weight: 700;
        font-size: 0.78rem;
        white-space: nowrap;
        flex-shrink: 0;
    }

    .ticker-track span i {
        color: var(--primary-600);
    }

    /* ── Carousel — flat single card ── */
    .carousel-3d {
        perspective: none !important;
        height: 480px !important;
    }

    .carousel-3d-card {
        width: min(380px, 88vw) !important;
        min-height: 420px !important;
    }

    .carousel-3d-card.active {
        transform: translate(-50%, -50%) scale(1) !important;
        box-shadow: 0 20px 60px rgba(6, 95, 70, 0.18) !important;
    }

    .carousel-3d-card.prev,
    .carousel-3d-card.next,
    .carousel-3d-card.far-prev,
    .carousel-3d-card.far-next {
        opacity: 0 !important;
        pointer-events: none !important;
    }

    .carousel-card-image {
        height: 180px !important;
    }

    .carousel-card-body {
        padding: 1.15rem 1.3rem 1.4rem !important;
    }

    .announcement-title {
        font-size: 1.1rem !important;
    }

    .announcement-content {
        font-size: 0.9rem !important;
        line-height: 1.55 !important;
    }

    /* Carousel nav buttons — below the card */
    .carousel-3d-btn {
        top: auto !important;
        bottom: -8px !important;
        transform: none !important;
        width: 40px !important;
        height: 40px !important;
        font-size: 0.9rem !important;
    }

    .carousel-3d-btn.prev {
        left: calc(50% - 60px) !important;
    }

    .carousel-3d-btn.next {
        right: calc(50% - 60px) !important;
    }

    .carousel-3d-dots {
        bottom: 0 !important;
    }

    .announcements-section .section-header {
        margin-bottom: 1rem !important;
    }

    /* ── Stat cards — compact to fit 3 ── */
    .stat-card-impact {
        min-height: auto !important;
        padding: 1.2rem !important;
        border-radius: 22px !important;
    }

    .stat-card-impact .stat-icon {
        width: 42px !important;
        height: 42px !important;
        border-radius: 14px !important;
        font-size: 1.1rem !important;
        margin-bottom: 0.6rem !important;
    }

    .stat-card-impact .stat-number {
        font-size: clamp(2.2rem, 10vw, 3rem) !important;
        line-height: 1.1 !important;
    }

    .stat-card-impact .stat-label {
        font-size: 0.85rem !important;
        margin-bottom: 0.25rem !important;
    }

    .stat-card-impact .stat-caption {
        font-size: 0.78rem !important;
        line-height: 1.4 !important;
        margin-bottom: 0.5rem !important;
    }

    .stat-card-impact .stat-card-orbit {
        display: none !important;
    }

    .stats-section .row {
        gap: 0 !important;
    }

    .stats-section .row > [class*="col-"] {
        padding-top: 0.35rem !important;
        padding-bottom: 0.35rem !important;
    }

    .stats-section .section-header {
        margin-bottom: 1rem !important;
    }

    /* ── Feature cards — compact to fit 3 ── */
    .feature-card {
        padding: 1.2rem !important;
        border-radius: 20px !important;
    }

    .feature-icon-wrap {
        width: 42px !important;
        height: 42px !important;
        border-radius: 14px !important;
        font-size: 1.1rem !important;
        margin-bottom: 0.6rem !important;
    }

    .feature-card h4 {
        font-size: 0.92rem !important;
        margin-bottom: 0.3rem !important;
    }

    .feature-card p {
        font-size: 0.8rem !important;
        line-height: 1.4 !important;
        margin-bottom: 0.4rem !important;
    }

    .feature-link {
        font-size: 0.82rem !important;
    }

    .features-section .row {
        gap: 0 !important;
    }

    .features-section .row > [class*="col-"] {
        padding-top: 0.35rem !important;
        padding-bottom: 0.35rem !important;
    }

    .features-section .section-header {
        margin-bottom: 1rem !important;
    }

    /* ── CTA section ── */
    .cta-card {
        padding: 2.5rem 1.5rem !important;
    }

    /* ── Unified section titles ── */
    .section-title {
        font-size: clamp(1.35rem, 5.5vw, 1.7rem) !important;
    }

    .section-subtitle {
        font-size: 0.85rem !important;
        margin-top: 0.5rem !important;
    }
}

@media (max-width: 575.98px) {

    .hero-section {
        min-height: 100vh !important;
        min-height: 100dvh !important;
        align-items: flex-start !important;
    }

    .hero-content {
        padding: 0.6rem 0 0.5rem;
    }

    .hero-kicker {
        margin-bottom: 0.5rem !important;
        font-size: 0.62rem !important;
        padding: 0.32rem 0.6rem !important;
    }

    .public-hero-title,
    .hero-title {
        font-size: clamp(1.85rem, 9.5vw, 2.5rem) !important;
        margin-bottom: 0.5rem !important;
    }

    .public-hero-copy,
    .hero-subtitle {
        font-size: 0.82rem !important;
        margin-bottom: 0.5rem !important;
    }

    .hero-actions {
        gap: 0.4rem !important;
        margin-bottom: 0.4rem !important;
    }

    .hero-actions .btn {
        padding: 0.58rem 0.85rem !important;
        font-size: 0.82rem !important;
    }

    .hero-trust-ticker {
        margin: 0 -1rem 0.4rem;
    }

    .ticker-track span {
        padding: 0.35rem 0.65rem;
        font-size: 0.7rem;
    }

    .hero-visual-shell {
        margin-top: 0.25rem !important;
    }

    .hero-map-shell {
        min-height: 240px !important;
    }

    /* ── Announcement card ── */
    .carousel-3d {
        height: 440px !important;
    }

    .carousel-3d-card {
        width: min(320px, 88vw) !important;
        min-height: 380px !important;
    }

    .carousel-card-image {
        height: 160px !important;
    }

    .announcements-section {
        padding: 2rem 0 !important;
    }

    .announcements-section .section-header {
        margin-bottom: 0.75rem !important;
    }

    /* ── Stat cards — even smaller ── */
    .stat-card-impact {
        padding: 1rem !important;
        border-radius: 18px !important;
    }

    .stat-card-impact .stat-icon {
        width: 36px !important;
        height: 36px !important;
        border-radius: 12px !important;
        font-size: 1rem !important;
        margin-bottom: 0.4rem !important;
    }

    .stat-card-impact .stat-number {
        font-size: clamp(1.8rem, 9vw, 2.5rem) !important;
    }

    .stat-card-impact .stat-label {
        font-size: 0.8rem !important;
    }

    .stat-card-impact .stat-caption {
        font-size: 0.72rem !important;
        display: -webkit-box;
        -webkit-line-clamp: 2;
        -webkit-box-orient: vertical;
        overflow: hidden;
    }

    .stats-section {
        padding: 2rem 0 !important;
    }

    /* ── Feature cards — even smaller ── */
    .feature-card {
        padding: 1rem !important;
        border-radius: 16px !important;
    }

    .feature-icon-wrap {
        width: 36px !important;
        height: 36px !important;
        border-radius: 12px !important;
        font-size: 0.95rem !important;
        margin-bottom: 0.5rem !important;
    }

    .feature-card h4 {
        font-size: 0.88rem !important;
        margin-bottom: 0.2rem !important;
    }

    .feature-card p {
        font-size: 0.76rem !important;
        line-height: 1.35 !important;
        margin-bottom: 0.3rem !important;
        display: -webkit-box;
        -webkit-line-clamp: 2;
        -webkit-box-orient: vertical;
        overflow: hidden;
    }

    .feature-link {
        font-size: 0.78rem !important;
        margin-top: auto !important;
    }

    .features-section {
        padding: 2rem 0 !important;
    }

    /* ── CTA ── */
    .cta-section {
        padding: 2rem 0 !important;
    }

    .cta-card {
        padding: 2rem 1.25rem !important;
    }

    .cta-card h2 {
        font-size: 1.25rem !important;
    }

    /* ── Section titles — unified ── */
    .section-title {
        font-size: clamp(1.25rem, 5vw, 1.5rem) !important;
    }

    .section-subtitle {
        font-size: 0.8rem !important;
    }
}

@keyframes ticker-scroll {
    0% { transform: translateX(0); }
    100% { transform: translateX(-50%); }
}

/* =====================================================
   Contact profile cards - premium action treatment
   ===================================================== */
.contact-network-section .contact-route {
    display: none;
}

.contact-network-section .contact-person-card {
    isolation: isolate;
    border-color: rgba(5, 150, 105, 0.18);
    background:
        linear-gradient(145deg, rgba(255, 255, 255, 0.98), rgba(240, 253, 244, 0.88)),
        linear-gradient(135deg, rgba(16, 185, 129, 0.1), rgba(14, 165, 163, 0.08));
    box-shadow:
        0 1px 0 rgba(255, 255, 255, 0.95) inset,
        0 18px 46px rgba(6, 95, 70, 0.09);
}

.contact-network-section .contact-person-card::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 0;
    border-radius: inherit;
    background: linear-gradient(120deg, transparent 0%, rgba(255, 255, 255, 0.78) 42%, transparent 62%);
    transform: translateX(-120%);
    transition: transform 700ms var(--ease-out);
    pointer-events: none;
}

.contact-network-section .contact-person-card:hover {
    transform: perspective(900px) translateY(-8px) rotateX(2deg);
    border-color: rgba(5, 150, 105, 0.34);
    box-shadow:
        0 1px 0 rgba(255, 255, 255, 0.98) inset,
        0 30px 78px rgba(6, 95, 70, 0.16),
        0 0 0 1px rgba(167, 243, 208, 0.34);
}

.contact-network-section .contact-person-card:hover::before {
    transform: translateX(120%);
}

.contact-network-section .contact-person-top img,
.contact-network-section .contact-avatar {
    border: 3px solid rgba(255, 255, 255, 0.95);
    box-shadow: 0 16px 34px rgba(6, 95, 70, 0.14);
    transition: transform 320ms var(--ease-spring), box-shadow 320ms var(--ease-out);
}

.contact-network-section .contact-person-card:hover .contact-person-top img,
.contact-network-section .contact-person-card:hover .contact-avatar {
    transform: scale(1.04);
    box-shadow: 0 20px 42px rgba(6, 95, 70, 0.19);
}

.contact-network-section .contact-profile-hint {
    position: relative;
    z-index: 3;
    width: fit-content;
    min-width: min(100%, 16.5rem);
    min-height: 2.95rem;
    display: inline-flex;
    align-items: center;
    justify-content: flex-start;
    gap: 0.72rem;
    padding: 0.42rem 0.52rem;
    margin-top: 0.2rem;
    color: var(--primary-900);
    font-size: 0.84rem;
    font-weight: 850;
    letter-spacing: 0;
    border-radius: var(--radius-full);
    border: 1px solid rgba(5, 150, 105, 0.18);
    background:
        linear-gradient(145deg, rgba(255, 255, 255, 0.98), rgba(236, 253, 245, 0.9));
    box-shadow:
        0 14px 32px rgba(6, 95, 70, 0.1),
        inset 0 1px 0 rgba(255, 255, 255, 0.94);
    transition:
        transform 280ms var(--ease-spring),
        box-shadow 280ms var(--ease-out),
        color 280ms var(--ease-out),
        background 280ms var(--ease-out),
        border-color 280ms var(--ease-out);
    pointer-events: auto;
    text-decoration: none;
}

.contact-network-section .contact-profile-icon,
.contact-network-section .contact-profile-arrow {
    width: 2rem;
    height: 2rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
    border-radius: 50%;
    transition:
        transform 280ms var(--ease-spring),
        background 280ms var(--ease-out),
        color 280ms var(--ease-out),
        box-shadow 280ms var(--ease-out);
}

.contact-network-section .contact-profile-icon {
    color: #ffffff;
    background: linear-gradient(135deg, var(--primary-500), var(--primary-700));
    box-shadow: 0 10px 22px rgba(5, 150, 105, 0.2), inset 0 1px 0 rgba(255, 255, 255, 0.28);
}

.contact-network-section .contact-profile-arrow {
    margin-left: auto;
    color: var(--primary-700);
    background: rgba(209, 250, 229, 0.78);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.72);
}

.contact-network-section .contact-profile-hint span:not(.contact-profile-icon) {
    flex: 1;
    min-width: 0;
}

.contact-network-section .contact-profile-hint:hover,
.contact-network-section .contact-profile-hint:focus-visible {
    color: #ffffff;
    border-color: rgba(255, 255, 255, 0.22);
    background: linear-gradient(135deg, var(--primary-500), var(--primary-700) 58%, var(--accent-cyan));
    transform: translateY(-3px);
    box-shadow:
        0 22px 46px rgba(5, 150, 105, 0.28),
        inset 0 1px 0 rgba(255, 255, 255, 0.38);
}

.contact-network-section .contact-profile-hint:hover .contact-profile-icon,
.contact-network-section .contact-profile-hint:focus-visible .contact-profile-icon {
    color: var(--primary-800);
    background: rgba(255, 255, 255, 0.94);
    box-shadow: 0 12px 24px rgba(6, 95, 70, 0.2), inset 0 1px 0 rgba(255, 255, 255, 0.8);
}

.contact-network-section .contact-profile-hint:hover .contact-profile-arrow,
.contact-network-section .contact-profile-hint:focus-visible .contact-profile-arrow {
    color: #ffffff;
    transform: translate(4px, -4px);
    background: rgba(255, 255, 255, 0.2);
}

.contact-network-section .contact-call-btn {
    border: 1px solid rgba(5, 150, 105, 0.18);
    background: rgba(255, 255, 255, 0.92);
    color: var(--primary-800);
    box-shadow: 0 12px 28px rgba(6, 95, 70, 0.08);
}

.contact-network-section .contact-call-btn:hover {
    color: #ffffff;
    border-color: transparent;
    background: linear-gradient(135deg, var(--primary-500), var(--primary-700));
}

@media (max-width: 575px) {
    .contact-network-section .contact-profile-hint {
        font-size: 0.78rem;
        min-height: 2.65rem;
        min-width: 100%;
    }

    .contact-network-section .contact-profile-icon,
    .contact-network-section .contact-profile-arrow {
        width: 1.85rem;
        height: 1.85rem;
    }
}

/* Navbar login button needs a high-contrast hover over the translucent header. */
.navbar-custom .btn-login:hover,
.navbar-custom .btn-login:focus-visible {
    color: #ffffff !important;
    border-color: transparent !important;
    background: linear-gradient(135deg, var(--primary-500), var(--primary-700)) !important;
    box-shadow:
        0 18px 36px rgba(5, 150, 105, 0.3),
        inset 0 1px 0 rgba(255, 255, 255, 0.28) !important;
    transform: translateY(-2px);
}

.navbar-custom .btn-login:hover i,
.navbar-custom .btn-login:hover span,
.navbar-custom .btn-login:focus-visible i,
.navbar-custom .btn-login:focus-visible span {
    color: #ffffff !important;
}

/* Premium zone filter control on the contact page. */
.contact-network-section .executive-filter-card {
    align-items: center;
    padding: 1.45rem 1.7rem;
    border-radius: 30px;
    background:
        radial-gradient(circle at 88% 10%, rgba(167, 243, 208, 0.34), transparent 30%),
        linear-gradient(145deg, rgba(255, 255, 255, 0.96), rgba(240, 253, 244, 0.82)) !important;
    box-shadow:
        0 1px 0 rgba(255, 255, 255, 0.96) inset,
        0 28px 72px rgba(6, 95, 70, 0.11) !important;
}

.contact-network-section .executive-filter-card h3 {
    color: #102033;
    font-weight: 900;
    letter-spacing: 0;
}

.contact-network-section .executive-filter-form {
    gap: 0.85rem;
    min-width: min(100%, 610px);
}

.contact-network-section .executive-filter-control {
    grid-template-columns: 2.35rem minmax(0, 1fr);
    gap: 0.12rem 0.75rem;
    min-height: 4.55rem;
    padding: 0.75rem 1rem;
    border: 1px solid rgba(5, 150, 105, 0.18);
    border-radius: 24px;
    background:
        linear-gradient(145deg, rgba(255, 255, 255, 0.98), rgba(248, 255, 251, 0.9));
    box-shadow:
        0 16px 38px rgba(6, 95, 70, 0.08),
        inset 0 1px 0 rgba(255, 255, 255, 0.96);
    transition:
        border-color 220ms var(--ease-out),
        box-shadow 220ms var(--ease-out),
        transform 220ms var(--ease-spring);
}

.contact-network-section .executive-filter-control:hover,
.contact-network-section .executive-filter-control:focus-within {
    border-color: rgba(5, 150, 105, 0.34);
    transform: translateY(-2px);
    box-shadow:
        0 22px 48px rgba(6, 95, 70, 0.12),
        0 0 0 4px rgba(16, 185, 129, 0.08),
        inset 0 1px 0 rgba(255, 255, 255, 0.96);
}

.contact-network-section .executive-filter-control > i {
    width: 2.35rem;
    height: 2.35rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #ffffff;
    font-size: 1rem;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--primary-500), var(--primary-700));
    box-shadow:
        0 12px 24px rgba(5, 150, 105, 0.2),
        inset 0 1px 0 rgba(255, 255, 255, 0.28);
}

.contact-network-section .executive-filter-control label {
    color: #8a9ab3;
    font-size: 0.72rem;
    font-weight: 900;
    letter-spacing: 0.055em;
}

.contact-network-section .executive-filter-control .form-select {
    color: #293854;
    font-size: 1rem;
    font-weight: 700;
    cursor: pointer;
}

.contact-network-section .executive-filter-control .form-select:focus {
    box-shadow: none;
}

.contact-network-section .contact-clear-filter {
    min-height: 4.55rem;
    gap: 0.55rem;
    padding: 0.8rem 1.25rem;
    color: var(--primary-900);
    border: 1px solid rgba(5, 150, 105, 0.2);
    border-radius: 24px;
    background:
        linear-gradient(145deg, rgba(255, 255, 255, 0.98), rgba(236, 253, 245, 0.86));
    box-shadow:
        0 16px 38px rgba(6, 95, 70, 0.09),
        inset 0 1px 0 rgba(255, 255, 255, 0.95);
    transition:
        color 220ms var(--ease-out),
        background 220ms var(--ease-out),
        border-color 220ms var(--ease-out),
        transform 220ms var(--ease-spring),
        box-shadow 220ms var(--ease-out);
}

.contact-network-section .contact-clear-filter i {
    width: 2rem;
    height: 2rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    color: var(--primary-700);
    background: rgba(209, 250, 229, 0.78);
    transition: transform 220ms var(--ease-spring), color 220ms var(--ease-out), background 220ms var(--ease-out);
}

.contact-network-section .contact-clear-filter:hover,
.contact-network-section .contact-clear-filter:focus-visible {
    color: #ffffff;
    border-color: transparent;
    background: linear-gradient(135deg, var(--primary-500), var(--primary-700));
    transform: translateY(-2px);
    box-shadow:
        0 22px 48px rgba(5, 150, 105, 0.28),
        inset 0 1px 0 rgba(255, 255, 255, 0.3);
}

.contact-network-section .contact-clear-filter:hover i,
.contact-network-section .contact-clear-filter:focus-visible i {
    color: var(--primary-800);
    background: rgba(255, 255, 255, 0.94);
    transform: rotate(90deg);
}

@media (max-width: 767.98px) {
    .contact-network-section .executive-filter-card {
        padding: 1.25rem;
    }

    .contact-network-section .executive-filter-form {
        width: 100%;
    }

    .contact-network-section .executive-filter-control,
    .contact-network-section .contact-clear-filter {
        width: 100%;
        min-height: 4.15rem;
        border-radius: 22px;
    }
}

/* Premium contact member cards. */
.contact-network-section .contact-person-card {
    gap: 1.05rem;
    min-height: 22rem;
    padding: 1.45rem;
    border-radius: 30px;
    border: 1px solid rgba(5, 150, 105, 0.18);
    background:
        linear-gradient(145deg, rgba(255, 255, 255, 0.98), rgba(247, 255, 250, 0.9) 52%, rgba(236, 253, 245, 0.88)),
        radial-gradient(circle at 100% 0%, rgba(16, 185, 129, 0.2), transparent 38%) !important;
    box-shadow:
        0 1px 0 rgba(255, 255, 255, 0.98) inset,
        0 24px 64px rgba(6, 95, 70, 0.1),
        0 8px 20px rgba(6, 95, 70, 0.05) !important;
}

.contact-network-section .contact-person-card::after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 0;
    pointer-events: none;
    border-radius: inherit;
    background:
        linear-gradient(90deg, var(--primary-500), var(--accent-cyan)) 0 0 / 100% 4px no-repeat,
        radial-gradient(circle at 92% 14%, rgba(16, 185, 129, 0.15), transparent 30%),
        linear-gradient(135deg, transparent 0 68%, rgba(209, 250, 229, 0.34) 68% 100%);
    opacity: 0.82;
    transition: opacity 280ms var(--ease-out), transform 280ms var(--ease-out);
}

.contact-network-section .contact-person-card:hover {
    transform: perspective(1000px) translateY(-9px) rotateX(1.5deg);
    border-color: rgba(5, 150, 105, 0.32);
    box-shadow:
        0 1px 0 rgba(255, 255, 255, 0.98) inset,
        0 38px 92px rgba(6, 95, 70, 0.16),
        0 0 0 1px rgba(167, 243, 208, 0.38) !important;
}

.contact-network-section .contact-person-card:hover::after {
    opacity: 1;
    transform: translateY(-1px);
}

.contact-network-section .officer-card {
    border-color: rgba(5, 150, 105, 0.24);
}

.contact-network-section .contact-role-pill {
    min-height: 2.15rem;
    display: inline-flex;
    align-items: center;
    padding: 0.4rem 0.85rem;
    color: var(--primary-900);
    font-size: 0.78rem;
    letter-spacing: 0;
    border-color: rgba(16, 185, 129, 0.34);
    background:
        linear-gradient(145deg, rgba(236, 253, 245, 0.96), rgba(255, 255, 255, 0.92));
    box-shadow:
        0 10px 24px rgba(6, 95, 70, 0.08),
        inset 0 1px 0 rgba(255, 255, 255, 0.94);
}

.contact-network-section .contact-person-top {
    gap: 1rem;
    min-height: 5.25rem;
}

.contact-network-section .contact-person-top img,
.contact-network-section .contact-avatar {
    width: 4.9rem;
    height: 4.9rem;
    border-radius: 1.35rem;
}

.contact-network-section .contact-avatar {
    font-size: 1.45rem;
    background:
        radial-gradient(circle at 25% 20%, rgba(255, 255, 255, 0.34), transparent 34%),
        linear-gradient(135deg, var(--primary-500), var(--primary-800));
}

.contact-network-section .contact-person-top h3 {
    font-size: 1.08rem;
    line-height: 1.15;
    margin-bottom: 0.25rem;
}

.contact-network-section .contact-person-top p {
    color: #718198;
    font-size: 0.91rem;
    font-weight: 650;
    line-height: 1.3;
}

.contact-network-section .contact-line {
    align-items: center;
    gap: 0.7rem;
    min-height: 2.65rem;
    padding: 0.58rem 0.72rem;
    color: #64748b;
    font-size: 0.88rem;
    font-weight: 600;
    border: 1px solid rgba(5, 150, 105, 0.1);
    border-radius: 17px;
    background: rgba(255, 255, 255, 0.58);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.78);
}

.contact-network-section .contact-line i {
    width: 1.8rem;
    height: 1.8rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
    color: var(--primary-700);
    border-radius: 50%;
    background: rgba(209, 250, 229, 0.78);
}

.contact-network-section .contact-actions {
    align-items: center;
    margin-top: 0.15rem;
}

.contact-network-section .contact-call-btn {
    min-height: 2.7rem;
    padding: 0.58rem 1.05rem;
}

@media (max-width: 575px) {
    .contact-network-section .contact-person-card {
        min-height: 0;
        padding: 1.15rem;
        border-radius: 24px;
    }

    .contact-network-section .contact-person-top img,
    .contact-network-section .contact-avatar {
        width: 4.25rem;
        height: 4.25rem;
        border-radius: 1.15rem;
    }

    .contact-network-section .contact-line {
        font-size: 0.82rem;
    }
}

/* Premium enquiry form experience. */
.content-section:has(.enquiry-form-card) {
    overflow: hidden;
}

.content-section:has(.enquiry-form-card) .container {
    position: relative;
}

.content-section:has(.enquiry-form-card) .container::before {
    content: "";
    position: absolute;
    inset: -3rem auto auto 54%;
    width: min(620px, 52vw);
    height: min(620px, 52vw);
    pointer-events: none;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(16, 185, 129, 0.16), transparent 68%);
    filter: blur(6px);
}

.enquiry-info-panel,
.enquiry-form-card {
    position: relative;
    overflow: hidden;
    border-radius: 34px !important;
    border: 1px solid rgba(5, 150, 105, 0.16) !important;
    background:
        linear-gradient(145deg, rgba(255, 255, 255, 0.98), rgba(246, 255, 250, 0.9) 54%, rgba(236, 253, 245, 0.84)) !important;
    box-shadow:
        0 1px 0 rgba(255, 255, 255, 0.98) inset,
        0 34px 90px rgba(6, 95, 70, 0.13),
        0 10px 24px rgba(6, 95, 70, 0.06) !important;
    animation: enquiry-rise 520ms var(--ease-out) both;
}

.enquiry-form-card {
    padding: 2.35rem !important;
    animation-delay: 90ms;
}

.enquiry-info-panel {
    padding: 2.45rem !important;
}

.enquiry-info-panel::before,
.enquiry-form-card::before {
    content: "";
    position: absolute;
    inset: 0 0 auto;
    height: 7px;
    background: linear-gradient(90deg, var(--primary-700), var(--primary-400), var(--accent-cyan));
}

.enquiry-info-panel::after,
.enquiry-form-card::after {
    content: "";
    position: absolute;
    inset: auto -10% -26% auto;
    width: 17rem;
    height: 17rem;
    pointer-events: none;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(16, 185, 129, 0.16), transparent 70%);
    transition: transform 520ms var(--ease-out), opacity 520ms var(--ease-out);
    opacity: 0.8;
}

.enquiry-info-panel:hover::after,
.enquiry-form-card:hover::after {
    transform: translate(-1rem, -1rem) scale(1.08);
    opacity: 1;
}

.enquiry-panel-icon,
.enquiry-form-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #ffffff;
    border-radius: 22px;
    background:
        radial-gradient(circle at 28% 18%, rgba(255, 255, 255, 0.32), transparent 34%),
        linear-gradient(135deg, var(--primary-500), var(--primary-800));
    box-shadow:
        0 18px 38px rgba(5, 150, 105, 0.24),
        inset 0 1px 0 rgba(255, 255, 255, 0.28);
}

.enquiry-panel-icon {
    width: 4.4rem;
    height: 4.4rem;
    margin-bottom: 1.3rem;
    font-size: 1.75rem;
}

.enquiry-form-header {
    position: relative;
    z-index: 1;
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-bottom: 1.65rem;
}

.enquiry-form-icon {
    width: 3.7rem;
    height: 3.7rem;
    flex: 0 0 auto;
    font-size: 1.35rem;
}

.enquiry-form-header h2 {
    margin: 0.2rem 0 0;
    color: #102033;
    font-size: clamp(1.45rem, 2.2vw, 2rem);
    font-weight: 900;
    letter-spacing: 0;
}

.enquiry-info-panel .contact-kicker,
.enquiry-form-header .contact-kicker {
    color: var(--primary-800);
}

.enquiry-info-panel h2 {
    max-width: 12ch;
    font-size: clamp(2rem, 4vw, 3.05rem);
    line-height: 1.12;
    letter-spacing: 0;
}

.enquiry-info-panel p {
    max-width: 34rem;
    font-size: 1.02rem;
    font-weight: 600;
    line-height: 1.75;
}

.enquiry-info-panel .enquiry-contact-line {
    width: fit-content;
    min-width: min(100%, 18rem);
    align-items: center;
    gap: 0.85rem;
    margin-top: 1.1rem;
    padding: 0.72rem 0.9rem;
    color: #102033;
    border: 1px solid rgba(5, 150, 105, 0.12);
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.62);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.86);
    transition: transform 240ms var(--ease-spring), border-color 240ms var(--ease-out), box-shadow 240ms var(--ease-out);
}

.enquiry-info-panel .enquiry-contact-line:hover {
    transform: translateX(4px);
    border-color: rgba(5, 150, 105, 0.24);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.9),
        0 14px 30px rgba(6, 95, 70, 0.08);
}

.enquiry-info-panel .enquiry-contact-line i {
    width: 2.1rem;
    height: 2.1rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
    color: var(--primary-700);
    border-radius: 50%;
    background: rgba(209, 250, 229, 0.82);
}

.enquiry-form-card form {
    position: relative;
    z-index: 1;
}

.enquiry-field {
    display: grid;
    gap: 0.5rem;
}

.enquiry-form-card .form-label {
    margin: 0 0 0 0.1rem;
    color: #34425a;
    font-size: 0.84rem;
    font-weight: 900;
}

.enquiry-input-wrap {
    position: relative;
    display: flex;
    align-items: center;
    min-height: 4.1rem;
    border: 1px solid rgba(5, 150, 105, 0.15);
    border-radius: 22px;
    background:
        linear-gradient(145deg, rgba(255, 255, 255, 0.98), rgba(248, 255, 251, 0.9));
    box-shadow:
        0 14px 34px rgba(6, 95, 70, 0.07),
        inset 0 1px 0 rgba(255, 255, 255, 0.96);
    transition:
        transform 220ms var(--ease-spring),
        border-color 220ms var(--ease-out),
        box-shadow 220ms var(--ease-out);
}

.enquiry-input-wrap:hover,
.enquiry-input-wrap:focus-within {
    transform: translateY(-2px);
    border-color: rgba(5, 150, 105, 0.34);
    box-shadow:
        0 22px 48px rgba(6, 95, 70, 0.12),
        0 0 0 4px rgba(16, 185, 129, 0.08),
        inset 0 1px 0 rgba(255, 255, 255, 0.98);
}

.enquiry-input-wrap > i {
    width: 2.25rem;
    height: 2.25rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
    margin-left: 0.8rem;
    color: var(--primary-700);
    border-radius: 50%;
    background: rgba(209, 250, 229, 0.8);
    transition: color 220ms var(--ease-out), background 220ms var(--ease-out), transform 220ms var(--ease-spring);
}

.enquiry-input-wrap:focus-within > i {
    color: #ffffff;
    background: linear-gradient(135deg, var(--primary-500), var(--primary-700));
    transform: scale(1.04);
}

.enquiry-form-card .auth-form .form-control,
.enquiry-form-card .auth-form .form-select {
    min-height: 4rem;
    width: 100%;
    padding: 0.9rem 1rem 0.9rem 0.8rem;
    color: #24324a;
    border: 0 !important;
    border-radius: 0;
    background: transparent !important;
    box-shadow: none !important;
    font-size: 1rem;
    font-weight: 650;
}

.enquiry-form-card .auth-form textarea.form-control {
    min-height: 12rem;
    padding-top: 1.1rem;
    resize: vertical;
}

.enquiry-input-wrap-textarea {
    align-items: flex-start;
    min-height: 12.4rem;
}

.enquiry-input-wrap-textarea > i {
    margin-top: 0.95rem;
}

.enquiry-form-card .auth-form .form-control::placeholder {
    color: #8a95a6;
    font-weight: 500;
}

.enquiry-submit-btn {
    min-height: 4.15rem;
    border-radius: 24px !important;
    font-size: 1.08rem;
    overflow: hidden;
    isolation: isolate;
}

.enquiry-submit-btn::after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 1;
    pointer-events: none;
    background: linear-gradient(120deg, transparent 0%, rgba(255, 255, 255, 0.28) 45%, transparent 64%);
    transform: translateX(-120%);
    transition: transform 620ms var(--ease-out);
}

.enquiry-submit-btn:hover::after,
.enquiry-submit-btn:focus-visible::after {
    transform: translateX(120%);
}

.enquiry-submit-btn i {
    position: relative;
    z-index: 2;
    transition: transform 260ms var(--ease-spring);
}

.enquiry-submit-btn:hover i,
.enquiry-submit-btn:focus-visible i {
    transform: translate(4px, -4px) rotate(8deg);
}

@keyframes enquiry-rise {
    from {
        opacity: 0;
        transform: translateY(18px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@media (prefers-reduced-motion: reduce) {
    .enquiry-info-panel,
    .enquiry-form-card,
    .enquiry-submit-btn::after {
        animation: none;
        transition: none;
    }
}

@media (max-width: 767.98px) {
    .enquiry-info-panel,
    .enquiry-form-card {
        padding: 1.35rem !important;
        border-radius: 26px !important;
    }

    .enquiry-form-header {
        align-items: flex-start;
    }

    .enquiry-info-panel h2 {
        max-width: none;
        font-size: 1.8rem;
    }

    .enquiry-input-wrap,
    .enquiry-submit-btn {
        border-radius: 20px !important;
    }
}

/* Enquiry page refinement: balanced, compact, uniform. */
.content-section:has(.enquiry-form-card) {
    padding-top: 2.6rem;
}

.content-section:has(.enquiry-form-card) .row {
    align-items: stretch;
}

.enquiry-info-panel,
.enquiry-form-card {
    min-height: auto;
    padding: 1.75rem !important;
    border-radius: 28px !important;
}

.enquiry-form-card {
    padding-bottom: 2.4rem !important;
}

.enquiry-info-panel {
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.enquiry-panel-icon,
.enquiry-form-icon {
    border-radius: 18px;
}

.enquiry-panel-icon {
    width: 3.2rem;
    height: 3.2rem;
    margin-bottom: 1rem;
    font-size: 1.25rem;
}

.enquiry-info-panel h2 {
    max-width: 16ch;
    margin-top: 0.55rem;
    margin-bottom: 0.75rem;
    font-size: clamp(1.7rem, 3vw, 2.25rem);
    line-height: 1.16;
}

.enquiry-info-panel p {
    max-width: 31rem;
    margin-bottom: 0.7rem;
    font-size: 0.95rem;
    line-height: 1.65;
}

.enquiry-info-panel .enquiry-contact-line {
    min-width: 0;
    width: 100%;
    max-width: 21rem;
    min-height: 3.15rem;
    padding: 0.58rem 0.72rem;
    margin-top: 0.75rem;
    border-radius: 16px;
    font-size: 0.92rem;
}

.enquiry-info-panel .enquiry-contact-line i {
    width: 1.9rem;
    height: 1.9rem;
}

.enquiry-form-header {
    gap: 0.85rem;
    margin-bottom: 1.15rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid rgba(5, 150, 105, 0.1);
}

.enquiry-form-icon {
    width: 3rem;
    height: 3rem;
    font-size: 1.05rem;
}

.enquiry-form-header h2 {
    font-size: clamp(1.35rem, 2vw, 1.75rem);
    line-height: 1.15;
}

.enquiry-form-card .row.g-3 {
    --bs-gutter-y: 1rem;
    --bs-gutter-x: 1rem;
}

.enquiry-form-card .form-label {
    font-size: 0.79rem;
    margin-left: 0;
}

.enquiry-input-wrap {
    min-height: 3.45rem;
    border-radius: 17px;
    box-shadow:
        0 10px 24px rgba(6, 95, 70, 0.055),
        inset 0 1px 0 rgba(255, 255, 255, 0.96);
}

.enquiry-input-wrap > i {
    width: 1.9rem;
    height: 1.9rem;
    margin-left: 0.68rem;
    font-size: 0.88rem;
}

.enquiry-form-card .auth-form .form-control,
.enquiry-form-card .auth-form .form-select {
    min-height: 3.35rem;
    padding: 0.72rem 0.85rem 0.72rem 0.65rem;
    font-size: 0.95rem;
}

.enquiry-input-wrap-textarea {
    min-height: 9.8rem;
}

.enquiry-form-card .auth-form textarea.form-control {
    min-height: 9.4rem;
    padding-top: 0.9rem;
}

.enquiry-input-wrap-textarea > i {
    margin-top: 0.75rem;
}

.enquiry-submit-btn {
    min-height: 3.55rem;
    margin-bottom: 0.2rem;
    border-radius: 18px !important;
    font-size: 1rem;
}

.enquiry-form-card .auth-form {
    padding-bottom: 0.25rem;
}

@media (min-width: 992px) {
    .content-section:has(.enquiry-form-card) .col-lg-5 {
        width: 38%;
    }

    .content-section:has(.enquiry-form-card) .col-lg-7 {
        width: 62%;
    }
}

@media (max-width: 767.98px) {
    .enquiry-info-panel,
    .enquiry-form-card {
        padding: 1.2rem !important;
        border-radius: 22px !important;
    }

    .enquiry-form-card {
        padding-bottom: 1.6rem !important;
    }

    .enquiry-panel-icon,
    .enquiry-form-icon {
        width: 2.75rem;
        height: 2.75rem;
    }

    .enquiry-info-panel h2 {
        max-width: none;
        font-size: 1.55rem;
    }

    .enquiry-form-header {
        margin-bottom: 1rem;
    }
}

/* Final navbar polish: roomier hover/active pills. */
.navbar-custom .navbar-nav {
    gap: 0.28rem;
}

.navbar-custom .nav-link {
    min-height: 2.55rem;
    padding: 0.62rem 1rem !important;
    border-radius: var(--radius-full) !important;
    border: 1px solid transparent;
    color: #173a31 !important;
    font-size: 0.88rem;
    font-weight: 750;
    line-height: 1;
    white-space: nowrap;
}

.navbar-custom .nav-link i {
    font-size: 0.95rem;
    color: currentColor;
    transition: transform 220ms var(--ease-spring);
}

.navbar-custom .nav-link:hover {
    color: var(--primary-900) !important;
    background:
        linear-gradient(145deg, rgba(255, 255, 255, 0.96), rgba(236, 253, 245, 0.86)) !important;
    border-color: rgba(5, 150, 105, 0.18) !important;
    box-shadow:
        0 14px 30px rgba(6, 95, 70, 0.1),
        inset 0 1px 0 rgba(255, 255, 255, 0.94) !important;
    transform: translateY(-2px);
}

.navbar-custom .nav-link:hover i {
    transform: translateY(-1px);
}

.navbar-custom .nav-link.active {
    color: var(--primary-900) !important;
    background:
        linear-gradient(145deg, rgba(209, 250, 229, 0.95), rgba(255, 255, 255, 0.9)) !important;
    border-color: rgba(5, 150, 105, 0.24) !important;
    box-shadow:
        0 16px 34px rgba(6, 95, 70, 0.12),
        inset 0 1px 0 rgba(255, 255, 255, 0.96) !important;
}

/* Form-only enquiry page layout. */
.enquiry-clean-section {
    padding: 4rem 0 4.5rem;
    min-height: calc(100vh - 70px);
    display: flex;
    align-items: center;
}

.enquiry-clean-section .enquiry-form-card {
    padding: 2rem !important;
    padding-bottom: 2.45rem !important;
}

.enquiry-clean-section .enquiry-form-header {
    align-items: center;
    margin-bottom: 1.25rem;
}

.enquiry-form-header p {
    margin: 0.3rem 0 0;
    color: #6b7c92;
    font-size: 0.94rem;
    font-weight: 600;
    line-height: 1.5;
}

.enquiry-support-panel {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
    margin-top: 1rem;
}

.enquiry-support-intro {
    display: none;
}

.enquiry-support-item {
    display: flex;
    align-items: flex-start;
    gap: 0.8rem;
    min-height: 104px;
    padding: 1rem;
    border: 1px solid rgba(5, 150, 105, 0.14);
    border-radius: 20px;
    background: rgba(255, 255, 255, 0.8);
    box-shadow: 0 18px 42px rgba(6, 95, 70, 0.08);
}

.enquiry-support-item i {
    display: inline-grid;
    place-items: center;
    flex: 0 0 auto;
    width: 2.5rem;
    height: 2.5rem;
    color: #ffffff;
    border-radius: 14px;
    background: linear-gradient(135deg, #10b981, #047857);
    box-shadow: 0 12px 24px rgba(5, 150, 105, 0.18);
}

.enquiry-support-item strong {
    display: block;
    margin-bottom: 0.25rem;
    color: var(--text-heading);
    font-size: 0.95rem;
}

.enquiry-support-item span {
    display: block;
    color: #64748b;
    font-size: 0.84rem;
    line-height: 1.55;
}

@media (min-width: 992px) {
    .enquiry-clean-section {
        min-height: calc(100vh - 70px);
        padding: 4.75rem 0 5rem;
        align-items: center;
        background:
            radial-gradient(circle at 18% 24%, rgba(16, 185, 129, 0.13), transparent 30%),
            radial-gradient(circle at 78% 32%, rgba(59, 130, 246, 0.1), transparent 28%),
            linear-gradient(180deg, rgba(236, 253, 245, 0.78), rgba(255, 255, 255, 0.96));
    }

    .enquiry-desktop-grid {
        display: grid;
        grid-template-columns: minmax(0, 1.12fr) minmax(320px, 0.72fr);
        align-items: stretch;
        gap: 1.4rem;
        width: min(1120px, 100%);
        margin-inline: auto;
    }

    .enquiry-desktop-grid .enquiry-form-card {
        margin: 0;
        min-height: 610px;
    }

    .enquiry-support-panel {
        grid-template-columns: 1fr;
        align-content: stretch;
        gap: 1rem;
        margin-top: 0;
    }

    .enquiry-support-intro {
        position: relative;
        display: grid;
        align-content: end;
        min-height: 270px;
        padding: 1.65rem;
        overflow: hidden;
        color: #ffffff;
        border: 1px solid rgba(255, 255, 255, 0.22);
        border-radius: 28px;
        background:
            radial-gradient(circle at 82% 10%, rgba(167, 243, 208, 0.34), transparent 30%),
            linear-gradient(135deg, #064e3b, #047857 54%, #10b981);
        box-shadow: 0 30px 78px rgba(6, 95, 70, 0.16);
    }

    .enquiry-support-intro::before {
        content: "";
        position: absolute;
        right: -4rem;
        top: -4rem;
        width: 12rem;
        height: 12rem;
        border: 1px solid rgba(255, 255, 255, 0.22);
        border-radius: 50%;
    }

    .enquiry-support-intro .contact-kicker,
    .enquiry-support-intro h3,
    .enquiry-support-intro p {
        position: relative;
        z-index: 1;
        color: #ffffff;
    }

    .enquiry-support-intro h3 {
        max-width: 18rem;
        margin: 0.45rem 0 0.65rem;
        font-size: 1.8rem;
        line-height: 1.12;
        font-weight: 850;
    }

    .enquiry-support-intro p {
        margin: 0;
        color: rgba(255, 255, 255, 0.78);
        font-size: 0.96rem;
        line-height: 1.65;
    }

    .enquiry-support-panel .enquiry-support-item {
        min-height: 0;
        padding: 1.25rem;
        border-radius: 24px;
    }
}

@media (max-width: 991.98px) {
    .navbar-custom .navbar-nav {
        gap: 0.45rem;
        align-items: stretch !important;
        padding-top: 0.75rem;
    }

    .navbar-custom .nav-link {
        justify-content: center;
    }

    .enquiry-clean-section {
        align-items: flex-start;
        padding: 2.25rem 0 3rem;
    }
}

@media (max-width: 575px) {
    .enquiry-clean-section .enquiry-form-card {
        padding: 1.2rem !important;
        padding-bottom: 1.65rem !important;
    }

    .enquiry-clean-section .enquiry-form-header {
        align-items: flex-start;
    }

    .enquiry-support-panel {
        grid-template-columns: 1fr;
    }
}

/* Compact contact cards: use zone as a highlight, not a second text row. */
.contact-network-section .contact-person-card {
    min-height: 19.25rem;
    gap: 0.85rem;
    padding: 1.25rem;
}

.contact-network-section .contact-person-top {
    min-height: 4.6rem;
}

.contact-network-section .contact-person-top img,
.contact-network-section .contact-avatar {
    width: 4.35rem;
    height: 4.35rem;
    border-radius: 1.22rem;
}

.contact-network-section .contact-role-pill {
    min-height: 1.9rem;
    padding: 0.32rem 0.72rem;
    font-size: 0.74rem;
}

.contact-zone-highlight {
    position: relative;
    z-index: 2;
    display: inline-flex;
    align-items: center;
    width: fit-content;
    max-width: 100%;
    gap: 0.42rem;
    padding: 0.38rem 0.68rem;
    color: var(--primary-900);
    font-size: 0.78rem;
    font-weight: 850;
    line-height: 1.1;
    border: 1px solid rgba(5, 150, 105, 0.2);
    border-radius: var(--radius-full);
    background:
        linear-gradient(145deg, rgba(209, 250, 229, 0.92), rgba(255, 255, 255, 0.88));
    box-shadow:
        0 10px 22px rgba(6, 95, 70, 0.08),
        inset 0 1px 0 rgba(255, 255, 255, 0.94);
}

.contact-zone-highlight i {
    color: var(--primary-700);
    font-size: 0.88rem;
}

.contact-network-section .contact-line {
    min-height: 2.35rem;
    padding: 0.48rem 0.62rem;
    font-size: 0.84rem;
    border-radius: 15px;
}

.contact-network-section .contact-line i {
    width: 1.65rem;
    height: 1.65rem;
}

.contact-network-section .contact-profile-hint {
    min-height: 2.6rem;
}

.contact-network-section .contact-profile-icon,
.contact-network-section .contact-profile-arrow {
    width: 1.8rem;
    height: 1.8rem;
}

.contact-network-section .contact-call-btn {
    min-height: 2.45rem;
}

@media (max-width: 575px) {
    .contact-network-section .contact-person-card {
        min-height: 0;
        padding: 1rem;
    }
}

/* Store directory sticky filter spacing. */
@media (min-width: 768px) {
    .content-section .sticky-filter {
        top: 118px;
        margin-top: 0.4rem;
    }

    .content-section .sticky-filter.filter-card {
        border-radius: 28px;
        box-shadow:
            0 1px 0 rgba(255, 255, 255, 0.96) inset,
            0 26px 66px rgba(6, 95, 70, 0.13),
            0 8px 18px rgba(6, 95, 70, 0.06) !important;
    }
}

/* Home hero: highlight Kalahandi directly on the Odisha map. */
.hero-map-shell {
    overflow: visible;
}

.hero-store-preview,
.hero-3d-network {
    display: none !important;
}

.kalahandi-district-highlight {
    position: absolute;
    left: 21%;
    top: 48%;
    z-index: 6;
    width: 23%;
    aspect-ratio: 1.35 / 1;
    pointer-events: none;
    transform: rotate(-18deg);
}

.kalahandi-district-highlight::before {
    content: "";
    position: absolute;
    inset: 8% 7% 16% 5%;
    border-radius: 42% 58% 52% 48% / 50% 38% 62% 50%;
    background:
        radial-gradient(circle at 38% 34%, rgba(255, 255, 255, 0.46), transparent 28%),
        linear-gradient(135deg, rgba(52, 211, 153, 0.92), rgba(5, 150, 105, 0.78));
    border: 2px solid rgba(255, 255, 255, 0.82);
    box-shadow:
        0 18px 34px rgba(5, 150, 105, 0.24),
        0 0 0 9px rgba(16, 185, 129, 0.13),
        inset 0 1px 0 rgba(255, 255, 255, 0.6);
    clip-path: polygon(8% 42%, 22% 18%, 44% 13%, 61% 23%, 78% 17%, 94% 38%, 86% 59%, 96% 78%, 70% 92%, 48% 81%, 29% 91%, 12% 70%);
    animation: kalahandi-district-glow 3.8s ease-in-out infinite;
}

.kalahandi-pulse {
    position: absolute;
    inset: 4% 0 10%;
    border-radius: 50%;
    border: 2px solid rgba(16, 185, 129, 0.26);
    animation: kalahandi-map-pulse 2.8s ease-out infinite;
}

.kalahandi-label {
    position: absolute;
    left: 55%;
    bottom: -0.65rem;
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.42rem 0.75rem;
    color: var(--primary-900);
    font-size: 0.78rem;
    font-weight: 900;
    letter-spacing: 0.02em;
    white-space: nowrap;
    border: 1px solid rgba(5, 150, 105, 0.18);
    border-radius: var(--radius-full);
    background: rgba(255, 255, 255, 0.9);
    box-shadow: 0 14px 28px rgba(6, 95, 70, 0.13), inset 0 1px 0 rgba(255, 255, 255, 0.95);
    transform: translateX(-50%) rotate(18deg);
}

.kalahandi-label::before {
    content: "";
    width: 0.48rem;
    height: 0.48rem;
    border-radius: 50%;
    background: var(--primary-500);
    box-shadow: 0 0 0 4px rgba(16, 185, 129, 0.13);
}

@keyframes kalahandi-district-glow {
    0%, 100% {
        filter: drop-shadow(0 0 0 rgba(16, 185, 129, 0));
        transform: translateY(0) scale(1);
    }
    50% {
        filter: drop-shadow(0 10px 18px rgba(16, 185, 129, 0.24));
        transform: translateY(-2px) scale(1.03);
    }
}

@keyframes kalahandi-map-pulse {
    0% {
        opacity: 0.72;
        transform: scale(0.78);
    }
    100% {
        opacity: 0;
        transform: scale(1.38);
    }
}

@media (max-width: 991.98px) {
    .kalahandi-district-highlight {
        left: 20%;
        top: 48%;
        width: 25%;
    }
}

@media (max-width: 575.98px) {
    .kalahandi-district-highlight {
        left: 19%;
        top: 48%;
        width: 28%;
    }

    .kalahandi-label {
        font-size: 0.66rem;
        padding: 0.32rem 0.55rem;
        bottom: -0.65rem;
    }
}

.map-central-pin {
    display: none !important;
}

/* Final hero map alignment: keep Odisha centered and labels clear. */
.hero-map-shell {
    overflow: hidden;
}

.hero-map-shell .hero-odisha-map {
    left: 50% !important;
    top: 50% !important;
    right: auto !important;
    bottom: auto !important;
    width: 78% !important;
    height: 82% !important;
    transform: translate(-50%, -50%) !important;
}

.kalahandi-district-highlight {
    left: 23% !important;
    top: 49% !important;
    width: 22% !important;
}

.kalahandi-label {
    left: 94% !important;
    bottom: auto !important;
    top: 58% !important;
    transform: translate(0, -50%) rotate(18deg) !important;
}

@media (min-width: 992px) {
    .hero-map-shell .hero-odisha-map {
        width: 80% !important;
        height: 84% !important;
    }
}

@media (max-width: 991.98px) {
    .hero-map-shell .hero-odisha-map {
        width: 84% !important;
        height: 84% !important;
    }

    .kalahandi-district-highlight {
        left: 23% !important;
        top: 49% !important;
        width: 24% !important;
    }
}

@media (max-width: 575.98px) {
    .hero-map-shell .hero-odisha-map {
        width: 90% !important;
        height: 82% !important;
    }

    .kalahandi-district-highlight {
        left: 22% !important;
        width: 27% !important;
    }

    .kalahandi-label {
        top: 66% !important;
        left: 62% !important;
        transform: translateX(-50%) rotate(18deg) !important;
    }
}

/* =====================================================
   TABLET EXPERIENCE PASS
   Tablet should feel intentional, not like stretched mobile.
   ===================================================== */
@media (min-width: 768px) and (max-width: 991.98px) {
    body {
        padding-top: 78px;
    }

    .navbar-custom {
        padding: 0.45rem 0;
    }

    .navbar-custom > .container,
    main > section > .container,
    .footer-custom > .container {
        max-width: 720px;
    }

    .brand-logo {
        height: 74px;
        margin-top: -8px;
        margin-bottom: -8px;
    }

    .navbar-toggler {
        width: 48px;
        height: 42px;
        border-radius: 12px;
        border-color: rgba(5, 150, 105, 0.16);
        background: rgba(255, 255, 255, 0.78);
        box-shadow: 0 10px 24px rgba(6, 95, 70, 0.08);
    }

    .navbar-collapse {
        margin-top: 0.7rem;
        padding: 0.85rem;
        border: 1px solid rgba(5, 150, 105, 0.12);
        border-radius: 20px;
        background: rgba(255, 255, 255, 0.9);
        box-shadow: 0 18px 44px rgba(6, 95, 70, 0.1);
    }

    .navbar-custom .navbar-nav {
        display: flex;
        gap: 0.45rem;
        padding-top: 0;
    }

    .navbar-custom .nav-item,
    .navbar-custom .btn-login,
    .navbar-custom .btn-register {
        width: 100%;
        margin: 0 !important;
    }

    .navbar-custom .nav-link,
    .navbar-custom .btn-login,
    .navbar-custom .btn-register {
        min-height: 44px;
        justify-content: center;
        border-radius: 14px !important;
    }

    .hero-section {
        min-height: auto !important;
        margin-top: -78px;
        padding-top: 118px;
        padding-bottom: 4rem;
        align-items: flex-start;
    }

    .hero-content {
        padding: 1rem 0 1.5rem;
    }

    .public-hero-layout {
        gap: 2rem;
        min-height: auto;
    }

    .public-hero-title,
    .hero-title {
        font-size: clamp(2.75rem, 7vw, 3.65rem) !important;
        max-width: 700px;
    }

    .public-hero-copy,
    .hero-subtitle {
        max-width: 620px;
        font-size: 1rem;
    }

    .hero-actions {
        flex-wrap: wrap;
    }

    .hero-actions .btn {
        width: auto;
        min-width: 190px;
    }

    .hero-visual-shell,
    .hero-map-shell {
        max-width: 620px;
        margin-inline: auto;
    }

    .announcements-section,
    .stats-section,
    .features-section,
    .cta-section,
    .content-section,
    .contact-network-section,
    .enquiry-clean-section {
        padding-top: 4.25rem !important;
        padding-bottom: 4.25rem !important;
    }

    .announcements-section .section-header {
        max-width: 620px;
        margin: 0 auto 1.75rem !important;
    }

    .carousel-3d {
        height: 600px !important;
        max-width: 720px;
        margin-inline: auto;
        overflow: visible;
        perspective: none !important;
    }

    .carousel-3d::before {
        bottom: 80px;
        width: min(600px, 80vw);
    }

    .carousel-3d-card {
        width: min(500px, 78vw) !important;
        min-height: 460px !important;
        border-radius: 28px !important;
    }

    .carousel-3d-card.active {
        transform: translate(-50%, -52%) scale(1) !important;
    }

    .carousel-card-image {
        height: 220px !important;
    }

    .carousel-card-body {
        padding: 1.35rem 1.6rem 1.6rem !important;
    }

    .carousel-card-placeholder {
        font-size: 4rem !important;
    }

    .announcement-title {
        font-size: 1.2rem !important;
    }

    .announcement-content {
        font-size: 0.96rem !important;
        line-height: 1.62 !important;
    }

    .carousel-3d-btn {
        top: auto !important;
        bottom: 18px !important;
        z-index: 8;
        width: 46px !important;
        height: 46px !important;
        transform: none !important;
        border-radius: 50% !important;
        background: rgba(255, 255, 255, 0.94) !important;
        border: 1px solid rgba(5, 150, 105, 0.18) !important;
        box-shadow: 0 16px 34px rgba(6, 95, 70, 0.16) !important;
    }

    .carousel-3d-btn.prev {
        left: calc(50% - 118px) !important;
        right: auto !important;
    }

    .carousel-3d-btn.next {
        left: calc(50% + 72px) !important;
        right: auto !important;
    }

    .carousel-3d-dots {
        left: 50%;
        bottom: 32px !important;
        z-index: 7;
        min-width: 104px;
        justify-content: center;
        padding: 0.35rem 0.65rem;
        border: 1px solid rgba(5, 150, 105, 0.12);
        border-radius: 999px;
        background: rgba(255, 255, 255, 0.82);
        box-shadow: 0 12px 28px rgba(6, 95, 70, 0.1);
        transform: translateX(-50%);
    }

    .stats-section .row,
    .features-section .row {
        justify-content: center;
        row-gap: 1.25rem;
    }

    .stats-section .section-header {
        max-width: 620px;
        margin-inline: auto !important;
    }

    .stats-section .section-title {
        font-size: 2.05rem !important;
        line-height: 1.15;
    }

    .stats-section .section-subtitle {
        max-width: 520px;
        margin-inline: auto;
        line-height: 1.55;
    }

    .stats-section .row {
        max-width: 680px;
        margin-inline: auto;
    }

    .stats-section .row > [class*="col-"] {
        width: 50%;
        flex: 0 0 50%;
    }

    .stat-card-impact,
    .feature-card {
        height: 100%;
        border-radius: 24px !important;
    }

    .stat-card-impact {
        min-height: 280px !important;
        padding: 1.45rem !important;
        justify-content: flex-end !important;
    }

    .stat-card-impact .stat-icon {
        top: 1.25rem !important;
        left: 1.25rem !important;
        width: 52px !important;
        height: 52px !important;
        border-radius: 18px !important;
        font-size: 1.2rem !important;
    }

    .stat-card-impact .stat-card-orbit {
        width: 92px !important;
        height: 92px !important;
        top: 1.35rem !important;
        right: 1.35rem !important;
    }

    .stat-card-impact .stat-number {
        font-size: clamp(3.15rem, 8vw, 4.1rem) !important;
        line-height: 0.95 !important;
    }

    .stat-card-impact .stat-label {
        font-size: 0.98rem !important;
    }

    .stat-number-wrap {
        margin-top: 5.6rem;
        margin-bottom: 0.45rem;
        align-items: flex-start;
    }

    .stat-plus {
        font-size: 1.45rem;
        margin-top: 0.12rem;
    }

    .stat-caption {
        min-height: 3.25rem;
        font-size: 0.84rem;
        line-height: 1.45;
    }

    .leadership-grid {
        display: flex;
        gap: 1rem;
        overflow-x: auto;
        padding: 0.25rem 0.2rem 1rem;
        scroll-snap-type: x mandatory;
        -webkit-overflow-scrolling: touch;
    }

    .leadership-card {
        flex: 0 0 260px;
        scroll-snap-align: center;
    }

    .login-premium-section,
    .auth-section {
        min-height: auto;
        align-items: flex-start;
        padding: 3.5rem 0 4.25rem !important;
    }

    .login-shell {
        max-width: 700px;
        grid-template-columns: 1fr;
        border-radius: 26px;
    }

    .login-brand-panel {
        display: grid;
        grid-template-columns: auto minmax(0, 1fr);
        align-items: center;
        gap: 0.9rem 1rem;
        padding: 1.45rem 1.6rem;
    }

    .login-brand-mark {
        margin: 0;
    }

    .login-kicker {
        margin: 0 0 0.35rem;
    }

    .login-brand-panel h1 {
        margin: 0;
        font-size: 1.72rem;
        line-height: 1.12;
    }

    .login-brand-panel p {
        display: block;
        grid-column: 1 / -1;
        max-width: 620px;
        margin: 0.1rem 0 0;
    }

    .login-benefits {
        display: flex;
        grid-column: 1 / -1;
        flex-wrap: wrap;
        gap: 0.55rem;
        margin-top: 0.1rem;
    }

    .login-benefits span {
        padding: 0.45rem 0.65rem;
        border-radius: 999px;
        background: rgba(255, 255, 255, 0.12);
        font-size: 0.82rem;
    }

    .login-form-panel {
        padding: 1.9rem 2rem 2rem;
    }

    .login-actions {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .signup-section .col-md-10,
    .signup-section .col-md-11,
    .profile-section .col-md-10,
    .profile-section .col-md-11 {
        width: 100%;
        max-width: 100%;
    }

    .signup-section .auth-card,
    .profile-section .auth-card,
    .enquiry-form-card {
        padding: 2rem !important;
        border-radius: 26px !important;
    }

    .auth-header h2 {
        font-size: 1.85rem;
    }

    .auth-header p {
        margin-bottom: 1.5rem;
    }

    .steps-indicator {
        margin-inline: 0 !important;
        margin-bottom: 2rem !important;
    }

    .form-section {
        padding: 1.35rem;
        border-radius: 20px;
    }

    .auth-form .row {
        --bs-gutter-x: 1rem;
        --bs-gutter-y: 1rem;
    }

    .auth-form .form-control,
    .auth-form .form-select {
        min-height: 50px;
        padding: 0.75rem 1rem;
    }

    .pc-entry {
        padding: 1rem;
        border-radius: 18px;
    }

    .payment-qr-grid {
        grid-template-columns: 1fr;
    }

    .payment-qr-card,
    .payment-help-card {
        padding: 1.25rem;
    }

    .contact-network-hero,
    .executive-filter-card {
        grid-template-columns: 1fr;
        text-align: center;
        justify-items: center;
    }

    .contact-hero-action {
        justify-items: center;
        min-width: 0;
    }

    .contact-hero-action small {
        text-align: center;
    }

    .contact-network-section .contact-officer-grid,
    .contact-network-section .executive-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        justify-content: center;
        max-width: 680px;
        gap: 1rem;
    }

    .enquiry-clean-section .enquiry-form-card {
        padding: 2rem !important;
        padding-bottom: 2.25rem !important;
    }

    .enquiry-clean-section {
        align-items: flex-start;
        background:
            radial-gradient(circle at 18% 20%, rgba(16, 185, 129, 0.12), transparent 32%),
            radial-gradient(circle at 82% 28%, rgba(59, 130, 246, 0.1), transparent 30%),
            linear-gradient(180deg, rgba(236, 253, 245, 0.78), rgba(255, 255, 255, 0.96));
    }

    .enquiry-clean-section .col-md-10 {
        width: 100%;
        max-width: 680px;
    }

    .enquiry-support-panel {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 1rem;
        margin-top: 1rem;
    }

    .enquiry-support-item {
        display: flex;
        align-items: flex-start;
        gap: 0.8rem;
        min-height: 112px;
        padding: 1.05rem;
        border: 1px solid rgba(5, 150, 105, 0.14);
        border-radius: 20px;
        background: rgba(255, 255, 255, 0.78);
        box-shadow: 0 18px 42px rgba(6, 95, 70, 0.08);
    }

    .enquiry-support-item i {
        display: inline-grid;
        place-items: center;
        flex: 0 0 auto;
        width: 2.5rem;
        height: 2.5rem;
        color: #ffffff;
        border-radius: 14px;
        background: linear-gradient(135deg, #10b981, #047857);
        box-shadow: 0 12px 24px rgba(5, 150, 105, 0.18);
    }

    .enquiry-support-item strong {
        display: block;
        margin-bottom: 0.25rem;
        color: var(--text-heading);
        font-size: 0.95rem;
    }

    .enquiry-support-item span {
        display: block;
        color: #64748b;
        font-size: 0.84rem;
        line-height: 1.55;
    }
}

/* Home hero emphasis and animated 3D network preview. */
.hero-kalahandi-word {
    display: inline-block;
    color: transparent;
    background:
        linear-gradient(135deg, #059669 0%, #10b981 38%, #0ea5a3 72%, #065f46 100%);
    background-clip: text;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    filter: drop-shadow(0 14px 24px rgba(5, 150, 105, 0.14));
    animation: kalahandi-glow 4.8s ease-in-out infinite;
}

.hero-store-preview {
    display: grid;
    place-items: center;
    aspect-ratio: 1.22 / 1;
    background:
        radial-gradient(circle at 52% 40%, rgba(209, 250, 229, 0.92), transparent 42%),
        linear-gradient(145deg, rgba(255, 255, 255, 0.9), rgba(236, 253, 245, 0.72));
}

.hero-3d-network {
    position: relative;
    width: 100%;
    height: 100%;
    min-height: 190px;
    transform-style: preserve-3d;
    transform: perspective(850px) rotateX(58deg) rotateZ(-26deg);
    animation: network-stage-float 6s ease-in-out infinite;
}

.hero-3d-network::before {
    content: "";
    position: absolute;
    inset: 18% 13% 12%;
    border-radius: 34px;
    background:
        linear-gradient(rgba(5, 150, 105, 0.09) 1px, transparent 1px),
        linear-gradient(90deg, rgba(37, 99, 235, 0.07) 1px, transparent 1px),
        linear-gradient(145deg, rgba(255, 255, 255, 0.66), rgba(167, 243, 208, 0.26));
    background-size: 22px 22px, 22px 22px, auto;
    box-shadow:
        0 26px 42px rgba(6, 95, 70, 0.16),
        inset 0 1px 0 rgba(255, 255, 255, 0.92);
    transform: translateZ(-16px);
}

.network-core,
.network-store {
    position: absolute;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #ffffff;
    transform-style: preserve-3d;
    box-shadow:
        0 18px 32px rgba(6, 95, 70, 0.2),
        inset 0 1px 0 rgba(255, 255, 255, 0.32);
}

.network-core {
    left: 50%;
    top: 48%;
    width: 76px;
    height: 76px;
    border-radius: 24px;
    font-size: 2.1rem;
    background:
        radial-gradient(circle at 24% 18%, rgba(255, 255, 255, 0.34), transparent 30%),
        linear-gradient(145deg, #34d399, #047857);
    transform: translate(-50%, -50%) translateZ(58px);
    animation: network-core-pulse 3.6s ease-in-out infinite;
}

.network-store {
    width: 48px;
    height: 48px;
    border-radius: 18px;
    font-size: 1.25rem;
    background:
        radial-gradient(circle at 24% 18%, rgba(255, 255, 255, 0.28), transparent 30%),
        linear-gradient(145deg, #0ea5a3, #059669);
    transform: translateZ(42px);
    animation: network-node-float 4.2s ease-in-out infinite;
}

.store-a { left: 18%; top: 27%; }
.store-b { right: 18%; top: 26%; animation-delay: -1.2s; }
.store-c { left: 35%; bottom: 12%; animation-delay: -2.1s; }

.network-link {
    position: absolute;
    height: 4px;
    border-radius: 999px;
    background: linear-gradient(90deg, rgba(14, 165, 163, 0), rgba(14, 165, 163, 0.7), rgba(16, 185, 129, 0));
    transform-origin: left center;
    transform: translateZ(24px);
    animation: network-link-flow 2.8s ease-in-out infinite;
}

.link-a {
    left: 31%;
    top: 38%;
    width: 98px;
    transform: rotate(24deg) translateZ(24px);
}

.link-b {
    left: 52%;
    top: 39%;
    width: 94px;
    transform: rotate(-25deg) translateZ(24px);
    animation-delay: -0.9s;
}

.link-c {
    left: 45%;
    top: 56%;
    width: 84px;
    transform: rotate(86deg) translateZ(24px);
    animation-delay: -1.6s;
}

.network-orbit {
    position: absolute;
    inset: 23%;
    border: 2px dashed rgba(5, 150, 105, 0.2);
    border-radius: 44% 56% 52% 48%;
    transform: translateZ(8px);
    animation: network-orbit 16s linear infinite;
}

.orbit-b {
    inset: 30% 18% 18% 28%;
    border-color: rgba(37, 99, 235, 0.18);
    animation-duration: 22s;
    animation-direction: reverse;
}

@keyframes kalahandi-glow {
    0%, 100% { filter: drop-shadow(0 12px 22px rgba(5, 150, 105, 0.12)); }
    50% { filter: drop-shadow(0 18px 30px rgba(16, 185, 129, 0.28)); }
}

@keyframes network-stage-float {
    0%, 100% { transform: perspective(850px) rotateX(58deg) rotateZ(-26deg) translateY(0); }
    50% { transform: perspective(850px) rotateX(58deg) rotateZ(-26deg) translateY(-8px); }
}

@keyframes network-core-pulse {
    0%, 100% { box-shadow: 0 18px 32px rgba(6, 95, 70, 0.2), 0 0 0 0 rgba(16, 185, 129, 0.18), inset 0 1px 0 rgba(255, 255, 255, 0.32); }
    50% { box-shadow: 0 26px 44px rgba(6, 95, 70, 0.26), 0 0 0 16px rgba(16, 185, 129, 0.08), inset 0 1px 0 rgba(255, 255, 255, 0.38); }
}

@keyframes network-node-float {
    0%, 100% { translate: 0 0; }
    50% { translate: 0 -8px; }
}

@keyframes network-link-flow {
    0%, 100% { opacity: 0.42; filter: blur(0); }
    50% { opacity: 1; filter: drop-shadow(0 0 10px rgba(16, 185, 129, 0.34)); }
}

@keyframes network-orbit {
    to { rotate: 360deg; }
}

@media (max-width: 991.98px) {
    .hero-3d-network {
        min-height: 150px;
    }

    .network-core {
        width: 60px;
        height: 60px;
        font-size: 1.65rem;
    }
}

@media (max-width: 575.98px) {
    .hero-kalahandi-word {
        display: inline;
    }

    .hero-3d-network {
        min-height: 118px;
    }

    .network-core {
        width: 46px;
        height: 46px;
        border-radius: 16px;
        font-size: 1.25rem;
    }

    .network-store {
        width: 34px;
        height: 34px;
        border-radius: 12px;
        font-size: 0.95rem;
    }
}

/* Center contact cards cleanly when a row has fewer items. */
.contact-network-section .contact-officer-grid,
.contact-network-section .executive-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(320px, 370px));
    justify-content: center;
    align-items: stretch;
    gap: 1.15rem;
    max-width: calc((370px * 3) + (1.15rem * 2));
    margin-inline: auto;
}

.contact-network-section .contact-officer-grid .contact-person-card,
.contact-network-section .executive-grid .contact-person-card {
    width: 100%;
}

.contact-network-section .empty-state {
    width: 100%;
}

@media (min-width: 1200px) {
    .contact-network-section .contact-officer-grid,
    .contact-network-section .executive-grid {
        grid-template-columns: repeat(3, minmax(0, 370px));
    }
}

@media (max-width: 575.98px) {
    .contact-network-section .contact-officer-grid,
    .contact-network-section .executive-grid {
        gap: 0.9rem;
    }

    .contact-network-section .contact-officer-grid,
    .contact-network-section .executive-grid {
        grid-template-columns: 1fr;
        max-width: none;
    }
}

/* Make the Executive Members band feel like a distinct themed section. */
.contact-network-section .executive-filter-card {
    color: #ffffff;
    border-color: rgba(255, 255, 255, 0.22) !important;
    background:
        radial-gradient(circle at 92% 12%, rgba(167, 243, 208, 0.28), transparent 30%),
        linear-gradient(135deg, #064e3b 0%, #047857 52%, #10b981 100%) !important;
    box-shadow:
        0 1px 0 rgba(255, 255, 255, 0.22) inset,
        0 30px 78px rgba(6, 95, 70, 0.18) !important;
}

.contact-network-section .executive-filter-card .contact-kicker,
.contact-network-section .executive-filter-card h3,
.contact-network-section .executive-filter-card p {
    color: #ffffff;
}

.contact-network-section .executive-filter-card .contact-kicker {
    opacity: 0.92;
}

.contact-network-section .executive-filter-card p {
    opacity: 0.78;
}

.contact-network-section .executive-filter-card .executive-filter-control,
.contact-network-section .executive-filter-card .contact-clear-filter {
    background: rgba(255, 255, 255, 0.92);
    border-color: rgba(255, 255, 255, 0.34);
}

.contact-network-section .executive-filter-card .contact-clear-filter {
    color: var(--primary-900) !important;
}

.contact-network-section .executive-filter-card .contact-clear-filter i {
    color: var(--primary-700);
    background: rgba(209, 250, 229, 0.92);
}

.contact-network-section .executive-filter-card .contact-clear-filter:hover,
.contact-network-section .executive-filter-card .contact-clear-filter:focus-visible {
    color: #ffffff !important;
    background: linear-gradient(135deg, #065f46, #047857) !important;
    border-color: rgba(255, 255, 255, 0.3) !important;
}

.contact-network-section .executive-filter-card .contact-clear-filter:hover i,
.contact-network-section .executive-filter-card .contact-clear-filter:focus-visible i {
    color: var(--primary-900);
    background: #ffffff;
}

/* Final tablet lock: keep shared tablet layouts from being overridden above. */
@media (min-width: 768px) and (max-width: 991.98px) {
    .carousel-3d {
        height: 600px !important;
        max-width: 720px !important;
        margin-inline: auto !important;
        overflow: visible !important;
    }

    .carousel-3d-card {
        width: min(500px, 78vw) !important;
        min-height: 460px !important;
    }

    .carousel-3d-card.active {
        transform: translate(-50%, -52%) scale(1) !important;
    }

    .carousel-3d-btn {
        top: auto !important;
        bottom: 18px !important;
        width: 46px !important;
        height: 46px !important;
        transform: none !important;
    }

    .carousel-3d-btn.prev {
        left: calc(50% - 118px) !important;
        right: auto !important;
    }

    .carousel-3d-btn.next {
        left: calc(50% + 72px) !important;
        right: auto !important;
    }

    .carousel-3d-dots {
        bottom: 32px !important;
    }

    .contact-network-section .contact-officer-grid,
    .contact-network-section .executive-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        justify-content: center !important;
        max-width: 680px !important;
        gap: 1rem !important;
    }

    .login-shell,
    .signup-section .auth-card,
    .enquiry-form-card {
        max-width: 700px;
        margin-inline: auto;
    }

    .contact-network-section .executive-filter-card {
        display: grid !important;
        grid-template-columns: 1fr !important;
        justify-items: stretch !important;
        gap: 1rem !important;
        width: min(100%, 680px);
        margin-inline: auto;
        padding: 1.5rem !important;
        text-align: left !important;
    }

    .contact-network-section .executive-filter-card h3 {
        max-width: none;
        font-size: 1.7rem;
    }

    .contact-network-section .executive-filter-card p {
        max-width: 34rem;
    }

    .contact-network-section .executive-filter-form {
        display: grid !important;
        grid-template-columns: minmax(0, 1fr) auto;
        gap: 0.75rem !important;
        width: 100%;
    }

    .contact-network-section .executive-filter-control,
    .contact-network-section .contact-clear-filter {
        min-width: 0 !important;
        width: 100% !important;
    }

    .navbar-custom .navbar-nav {
        display: flex !important;
        grid-template-columns: none !important;
        gap: 0.45rem !important;
    }
}

/* Final phone hero pass: keep the animated network readable on narrow screens only. */
@media (max-width: 575.98px) {
    .hero-section {
        min-height: 100vh !important;
        min-height: 100svh !important;
        margin-top: -66px !important;
        padding-top: 66px !important;
        padding-bottom: 1rem !important;
        display: flex !important;
        align-items: flex-start !important;
    }

    .public-hero-layout {
        gap: 0.75rem !important;
    }

    .hero-section > .container {
        width: 100% !important;
    }

    .hero-content {
        padding: 0.5rem 0 0.75rem !important;
    }

    .hero-text-stack {
        display: flex !important;
        flex-direction: column !important;
        gap: 0.58rem !important;
        max-width: 100% !important;
        margin-inline: auto !important;
        padding-inline: 0.8rem !important;
        text-align: center !important;
    }

    .hero-kicker {
        width: min(100%, 315px) !important;
        margin-inline: auto !important;
        justify-content: center !important;
        white-space: normal !important;
        text-align: center !important;
        font-size: 0.58rem !important;
        line-height: 1.35 !important;
        padding: 0.38rem 0.58rem !important;
        gap: 0.36rem !important;
    }

    .public-hero-title,
    .hero-title {
        max-width: 345px !important;
        margin-inline: auto !important;
        font-size: clamp(2.02rem, 10.45vw, 2.48rem) !important;
        line-height: 1.05 !important;
        letter-spacing: 0 !important;
        text-align: center !important;
    }

    .public-hero-copy,
    .hero-subtitle {
        max-width: 310px !important;
        margin-inline: auto !important;
        font-size: 0.78rem !important;
        line-height: 1.42 !important;
        text-align: center !important;
    }

    .hero-actions {
        display: grid !important;
        grid-template-columns: 1fr !important;
        width: min(100%, 310px) !important;
        margin-inline: auto !important;
        gap: 0.48rem !important;
    }

    .hero-actions .btn {
        width: 100% !important;
        min-height: 47px !important;
        justify-content: center !important;
        padding: 0.62rem 0.88rem !important;
        font-size: 0.9rem !important;
    }

    .hero-trust-ticker {
        display: none !important;
    }

    .hero-trust-strip {
        display: none !important;
        flex-wrap: wrap !important;
        justify-content: center !important;
        width: min(100%, 310px) !important;
        margin: 0.12rem auto 0 !important;
        gap: 0.36rem !important;
        overflow: visible !important;
    }

    .hero-trust-strip span {
        flex: 0 1 auto !important;
        max-width: 100% !important;
        white-space: nowrap !important;
        font-size: 0.66rem !important;
        line-height: 1.2 !important;
        padding: 0.34rem 0.5rem !important;
    }

    .hero-map-shell {
        width: min(100%, 342px) !important;
        max-width: 342px !important;
        min-height: 305px !important;
        margin: 0.58rem auto 0 !important;
        border-radius: 22px !important;
        overflow: hidden !important;
        padding: 0 !important;
    }

    .public-hero-layout > .col-lg-6.position-relative {
        margin-top: 0.15rem !important;
    }

    .hero-map-shell::after {
        display: none !important;
    }

    .hero-map-shell .hero-odisha-map {
        width: 86% !important;
        height: 80% !important;
        left: 50% !important;
        top: 50% !important;
        transform: translate(-50%, -50%) !important;
    }

    .hero-odisha-map::before,
    .hero-odisha-map::after {
        opacity: 0.32 !important;
    }

    .hero-map-shell .map-line {
        opacity: 0.24 !important;
    }

    .hero-map-shell .map-node {
        width: 9px !important;
        height: 9px !important;
        box-shadow: 0 0 0 5px rgba(37, 99, 235, 0.12) !important;
    }

    .hero-map-shell .hero-float-card {
        display: none !important;
    }

    .kalahandi-district-highlight {
        left: 22% !important;
        top: 50% !important;
        width: 25% !important;
        height: 18% !important;
    }

    .kalahandi-label {
        left: 50% !important;
        top: calc(100% + 0.48rem) !important;
        bottom: auto !important;
        transform: translateX(-50%) rotate(18deg) !important;
        font-size: 0.68rem !important;
        line-height: 1 !important;
        padding: 0.34rem 0.58rem !important;
        border-radius: 999px !important;
        white-space: nowrap !important;
        z-index: 8 !important;
    }

    .kalahandi-label::before {
        width: 0.42rem !important;
        height: 0.42rem !important;
        flex: 0 0 0.42rem !important;
    }

    .leadership-showcase-section {
        padding: 4rem 0 4.25rem !important;
        overflow: hidden !important;
    }

    .leadership-showcase-section .section-header {
        width: min(100%, 340px) !important;
        margin-inline: auto !important;
        margin-bottom: 2rem !important;
        padding-inline: 0.25rem !important;
    }

    .leadership-showcase-section .section-title {
        font-size: clamp(1.55rem, 8vw, 1.95rem) !important;
        line-height: 1.15 !important;
    }

    .leadership-showcase-section .section-subtitle {
        max-width: 320px !important;
        margin-inline: auto !important;
        font-size: 0.95rem !important;
        line-height: 1.45 !important;
    }

    .leadership-grid {
        display: flex !important;
        grid-template-columns: none !important;
        width: min(100%, 340px) !important;
        max-width: 340px !important;
        margin-inline: auto !important;
        gap: 0 !important;
        overflow-x: auto !important;
        overflow-y: hidden !important;
        padding: 0 0 0.95rem !important;
        scroll-snap-type: x mandatory !important;
        scroll-padding-inline: 0 !important;
        -webkit-overflow-scrolling: touch !important;
        overscroll-behavior-x: contain !important;
        scrollbar-width: thin !important;
        scrollbar-color: rgba(16, 185, 129, 0.42) rgba(209, 250, 229, 0.74) !important;
    }

    .leadership-grid::-webkit-scrollbar {
        height: 7px !important;
    }

    .leadership-grid::-webkit-scrollbar-track {
        background: rgba(209, 250, 229, 0.74) !important;
        border-radius: 999px !important;
    }

    .leadership-grid::-webkit-scrollbar-thumb {
        background: linear-gradient(90deg, #6ee7b7, #10b981) !important;
        border-radius: 999px !important;
    }

    .leadership-card {
        flex: 0 0 100% !important;
        width: 100% !important;
        min-width: 100% !important;
        max-width: 100% !important;
        border-radius: 28px !important;
        scroll-snap-align: center !important;
        scroll-snap-stop: always !important;
        box-shadow: 0 24px 60px rgba(6, 95, 70, 0.18) !important;
    }

    .leadership-card + .leadership-card {
        margin-left: 0 !important;
    }

    .leadership-photo-frame {
        aspect-ratio: 0.76 / 1 !important;
    }

    .leadership-card-body {
        padding: 1.55rem 1.35rem 1.45rem !important;
    }

    .leadership-role {
        font-size: 0.82rem !important;
        margin-bottom: 0.48rem !important;
    }

    .leadership-card h3 {
        font-size: 1.42rem !important;
        line-height: 1.15 !important;
    }

    .leadership-card p {
        font-size: 1rem !important;
        line-height: 1.35 !important;
    }

    .leadership-showcase-section .section-title,
    .announcements-section .section-title,
    .stats-section .section-title,
    .features-section .section-title,
    .testimonials-section .section-title,
    .gallery-loop-section .section-title {
        font-size: clamp(1.72rem, 8.2vw, 1.95rem) !important;
        line-height: 1.16 !important;
        letter-spacing: 0 !important;
    }

    .leadership-showcase-section .section-subtitle,
    .announcements-section .section-subtitle,
    .stats-section .section-subtitle,
    .features-section .section-subtitle,
    .testimonials-section .section-subtitle,
    .gallery-loop-section .section-subtitle {
        max-width: 330px !important;
        margin-inline: auto !important;
        font-size: 0.95rem !important;
        line-height: 1.45 !important;
    }

    .announcements-section {
        padding: 4.2rem 0 3.5rem !important;
        overflow: hidden !important;
    }

    .announcements-section .section-header {
        width: min(100%, 340px) !important;
        margin-inline: auto !important;
        margin-bottom: 1.65rem !important;
        padding-inline: 0.25rem !important;
    }

    .carousel-3d {
        width: min(100%, 350px) !important;
        max-width: 350px !important;
        height: 570px !important;
        margin-inline: auto !important;
        overflow: visible !important;
        perspective: 900px !important;
    }

    .carousel-3d::before {
        content: "" !important;
        position: absolute !important;
        inset: 1.3rem 0.2rem 4.8rem !important;
        border-radius: 34px !important;
        background:
            radial-gradient(circle at 72% 16%, rgba(16, 185, 129, 0.16), transparent 34%),
            linear-gradient(145deg, rgba(255, 255, 255, 0.62), rgba(236, 253, 245, 0.42)) !important;
        filter: blur(0) !important;
        box-shadow: 0 28px 72px rgba(6, 95, 70, 0.12) !important;
        pointer-events: none !important;
    }

    .carousel-3d-card {
        width: min(100%, 332px) !important;
        min-height: 455px !important;
        border-radius: 30px !important;
        box-shadow: 0 22px 60px rgba(6, 95, 70, 0.16) !important;
    }

    .carousel-3d-card.active {
        transform: translate(-50%, -54%) rotateY(0deg) translateZ(0) scale(1) !important;
        opacity: 1 !important;
        filter: none !important;
        box-shadow:
            0 28px 76px rgba(6, 95, 70, 0.2),
            0 0 0 1px rgba(167, 243, 208, 0.84),
            inset 0 1px 0 rgba(255, 255, 255, 0.95) !important;
    }

    .carousel-3d-card.prev,
    .carousel-3d-card.next,
    .carousel-3d-card.far-prev,
    .carousel-3d-card.far-next {
        opacity: 0 !important;
        pointer-events: none !important;
        transform: translate(-50%, -54%) scale(0.88) !important;
    }

    .carousel-card-image {
        height: 185px !important;
    }

    .carousel-card-placeholder {
        font-size: 3.35rem !important;
        background:
            radial-gradient(circle at 58% 60%, rgba(16, 185, 129, 0.24), transparent 22%),
            linear-gradient(135deg, rgba(255, 255, 255, 0.78), rgba(236, 253, 245, 0.72)) !important;
    }

    .carousel-card-body {
        padding: 1.35rem 1.35rem 1.55rem !important;
    }

    .announcement-title {
        font-size: 1.22rem !important;
        line-height: 1.28 !important;
        margin-bottom: 0.55rem !important;
    }

    .announcement-content {
        font-size: 0.98rem !important;
        line-height: 1.55 !important;
    }

    .read-more-hint {
        opacity: 1 !important;
        transform: none !important;
        margin-top: 0.9rem !important;
        font-size: 0.92rem !important;
    }

    .carousel-3d-btn {
        top: auto !important;
        bottom: 0.72rem !important;
        width: 46px !important;
        height: 46px !important;
        border-radius: 16px !important;
        transform: none !important;
        background: rgba(255, 255, 255, 0.92) !important;
        border: 1px solid rgba(16, 185, 129, 0.2) !important;
        color: var(--primary-900) !important;
        box-shadow: 0 14px 34px rgba(6, 95, 70, 0.14) !important;
    }

    .carousel-3d-btn:hover,
    .carousel-3d-btn:focus-visible {
        transform: translateY(-2px) !important;
        background: linear-gradient(135deg, #10b981, #047857) !important;
        color: #ffffff !important;
        box-shadow: 0 18px 44px rgba(6, 95, 70, 0.2) !important;
    }

    .carousel-3d-btn.prev {
        left: calc(50% - 96px) !important;
        right: auto !important;
    }

    .carousel-3d-btn.next {
        left: calc(50% + 50px) !important;
        right: auto !important;
    }

    .carousel-3d-dots {
        bottom: 1.35rem !important;
        gap: 0.42rem !important;
        padding: 0.36rem 0.58rem !important;
        border-radius: 999px !important;
        background: rgba(255, 255, 255, 0.76) !important;
        box-shadow: 0 12px 26px rgba(6, 95, 70, 0.1) !important;
    }

    .carousel-dot {
        width: 8px !important;
        height: 8px !important;
    }

    .stats-section {
        padding: 4.1rem 0 4.35rem !important;
        overflow: hidden !important;
        background:
            radial-gradient(circle at 12% 22%, rgba(16, 185, 129, 0.16), transparent 30%),
            linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(236, 253, 245, 0.72)) !important;
    }

    .stats-section .section-header {
        width: min(100%, 340px) !important;
        margin-inline: auto !important;
        margin-bottom: 1.55rem !important;
        padding-inline: 0.25rem !important;
    }

    .stats-section .row {
        display: none !important;
    }

    .mobile-stats-loop {
        display: block !important;
        width: min(100%, 342px) !important;
        max-width: 342px !important;
        margin: 0 auto !important;
        overflow: hidden !important;
        border-radius: 34px !important;
        position: relative !important;
        isolation: isolate !important;
    }

    .mobile-stats-loop::before,
    .mobile-stats-loop::after {
        content: "" !important;
        position: absolute !important;
        top: 0 !important;
        bottom: 0 !important;
        width: 24px !important;
        z-index: 3 !important;
        pointer-events: none !important;
    }

    .mobile-stats-loop::before {
        left: 0 !important;
        background: linear-gradient(90deg, rgba(236, 253, 245, 0.92), transparent) !important;
    }

    .mobile-stats-loop::after {
        right: 0 !important;
        background: linear-gradient(270deg, rgba(236, 253, 245, 0.92), transparent) !important;
    }

    .mobile-stats-track {
        display: flex !important;
        width: max-content !important;
        gap: 0 !important;
        animation: mobile-stat-loop 12s linear infinite !important;
        will-change: transform !important;
    }

    .mobile-stats-loop:hover .mobile-stats-track,
    .mobile-stats-loop:focus-within .mobile-stats-track {
        animation-play-state: paused !important;
    }

    .mobile-stat-card {
        flex: 0 0 342px !important;
        width: 342px !important;
        min-height: 330px !important;
        padding: 1.55rem !important;
        border-radius: 30px !important;
        position: relative !important;
        overflow: hidden !important;
        background:
            radial-gradient(circle at 78% 14%, rgba(16, 185, 129, 0.2), transparent 31%),
            linear-gradient(145deg, rgba(255, 255, 255, 0.94), rgba(236, 253, 245, 0.76)) !important;
        box-shadow:
            inset 0 1px 0 rgba(255, 255, 255, 0.96),
            0 28px 72px rgba(6, 95, 70, 0.16),
            0 0 0 1px rgba(167, 243, 208, 0.72) !important;
    }

    .mobile-stat-card::before {
        content: "" !important;
        position: absolute !important;
        inset: 0.85rem !important;
        border-radius: 24px !important;
        border: 1px solid rgba(5, 150, 105, 0.1) !important;
        pointer-events: none !important;
    }

    .mobile-stat-card::after {
        content: "" !important;
        position: absolute !important;
        width: 210px !important;
        height: 210px !important;
        right: -64px !important;
        top: -54px !important;
        border-radius: 50% !important;
        background: radial-gradient(circle, rgba(167, 243, 208, 0.54), rgba(16, 185, 129, 0.04) 62%, transparent 63%) !important;
        z-index: 0 !important;
    }

    .mobile-stat-icon {
        top: 1.25rem !important;
        right: 1.25rem !important;
        position: absolute !important;
        display: grid !important;
        place-items: center !important;
        width: 62px !important;
        height: 62px !important;
        border-radius: 20px !important;
        color: var(--primary-800) !important;
        font-size: 1.45rem !important;
        background: linear-gradient(145deg, rgba(255, 255, 255, 0.94), rgba(209, 250, 229, 0.82)) !important;
        box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.96), 0 18px 44px rgba(6, 95, 70, 0.12) !important;
        z-index: 2 !important;
    }

    .mobile-stat-value {
        position: relative !important;
        z-index: 2 !important;
        display: flex !important;
        align-items: flex-start !important;
        gap: 0.15rem !important;
        margin: 0 4.8rem 1.2rem 0 !important;
        color: var(--primary-800) !important;
    }

    .mobile-stat-value span {
        font-size: clamp(4rem, 18vw, 5.2rem) !important;
        line-height: 0.86 !important;
        font-weight: 900 !important;
        letter-spacing: 0 !important;
        background: linear-gradient(135deg, #052e22 10%, #059669 70%, #34d399) !important;
        background-clip: text !important;
        -webkit-background-clip: text !important;
        color: transparent !important;
    }

    .mobile-stat-value sup {
        font-size: 1.9rem !important;
        line-height: 1 !important;
        font-weight: 900 !important;
        color: var(--primary-600) !important;
        margin-top: 0.2rem !important;
    }

    .mobile-stat-card h3 {
        position: relative !important;
        z-index: 2 !important;
        margin: 0 0 0.58rem !important;
        color: #102f29 !important;
        font-size: 1.1rem !important;
        line-height: 1.2 !important;
        font-weight: 900 !important;
    }

    .mobile-stat-card p {
        position: relative !important;
        z-index: 2 !important;
        margin: 0 !important;
        max-width: 260px !important;
        color: #5f716c !important;
        font-size: 0.92rem !important;
        line-height: 1.5 !important;
        font-weight: 650 !important;
    }

    .mobile-stat-meter {
        position: absolute !important;
        left: 1.55rem !important;
        right: 1.55rem !important;
        bottom: 1.45rem !important;
        height: 9px !important;
        border-radius: 999px !important;
        background: rgba(6, 95, 70, 0.08) !important;
        overflow: hidden !important;
        z-index: 2 !important;
    }

    .mobile-stat-meter span {
        display: block !important;
        width: var(--meter) !important;
        height: 100% !important;
        border-radius: inherit !important;
        background: linear-gradient(90deg, var(--primary-300), var(--primary-700)) !important;
        box-shadow: 0 0 20px rgba(16, 185, 129, 0.42) !important;
    }

    .features-section {
        padding: 4.25rem 0 4.5rem !important;
        overflow: hidden !important;
        background:
            radial-gradient(circle at 82% 12%, rgba(16, 185, 129, 0.14), transparent 30%),
            radial-gradient(circle at 5% 82%, rgba(14, 165, 233, 0.08), transparent 28%),
            linear-gradient(180deg, rgba(255, 255, 255, 0.97), rgba(236, 253, 245, 0.68)) !important;
    }

    .features-section .section-header {
        width: min(100%, 340px) !important;
        margin-inline: auto !important;
        margin-bottom: 1.75rem !important;
        padding-inline: 0.25rem !important;
    }

    .features-section .row {
        display: grid !important;
        grid-template-columns: 1fr !important;
        width: min(100%, 342px) !important;
        max-width: 342px !important;
        margin-inline: auto !important;
        gap: 1rem !important;
    }

    .features-section .row > [class*="col-"] {
        width: 100% !important;
        max-width: 100% !important;
        padding: 0 !important;
    }

    .feature-card {
        min-height: 245px !important;
        padding: 1.45rem !important;
        border-radius: 30px !important;
        position: relative !important;
        isolation: isolate !important;
        overflow: hidden !important;
        background:
            radial-gradient(circle at 86% 12%, rgba(16, 185, 129, 0.16), transparent 34%),
            linear-gradient(145deg, rgba(255, 255, 255, 0.96), rgba(240, 253, 250, 0.78)) !important;
        border: 1px solid rgba(167, 243, 208, 0.76) !important;
        box-shadow:
            inset 0 1px 0 rgba(255, 255, 255, 0.98),
            0 26px 68px rgba(6, 95, 70, 0.13),
            0 10px 24px rgba(6, 95, 70, 0.06) !important;
    }

    .feature-card::before {
        content: "" !important;
        position: absolute !important;
        inset: 0.8rem !important;
        border-radius: 24px !important;
        border: 1px solid rgba(5, 150, 105, 0.09) !important;
        pointer-events: none !important;
        z-index: -1 !important;
    }

    .feature-card::after {
        position: absolute !important;
        top: 1.25rem !important;
        right: 1.35rem !important;
        color: rgba(5, 150, 105, 0.12) !important;
        font-family: var(--font-display) !important;
        font-size: 3.2rem !important;
        line-height: 1 !important;
        font-weight: 900 !important;
        letter-spacing: 0 !important;
        z-index: -1 !important;
    }

    .features-section .row > [class*="col-"]:nth-child(1) .feature-card::after {
        content: "01" !important;
    }

    .features-section .row > [class*="col-"]:nth-child(2) .feature-card::after {
        content: "02" !important;
    }

    .features-section .row > [class*="col-"]:nth-child(3) .feature-card::after {
        content: "03" !important;
    }

    .feature-icon-wrap {
        width: 64px !important;
        height: 64px !important;
        border-radius: 22px !important;
        font-size: 1.55rem !important;
        margin-bottom: 1.15rem !important;
        color: var(--primary-800) !important;
        background:
            radial-gradient(circle at 34% 28%, rgba(255, 255, 255, 0.9), transparent 35%),
            linear-gradient(145deg, rgba(209, 250, 229, 0.96), rgba(255, 255, 255, 0.72)) !important;
        border: 1px solid rgba(16, 185, 129, 0.18) !important;
        box-shadow:
            inset 0 1px 0 rgba(255, 255, 255, 0.96),
            0 16px 36px rgba(6, 95, 70, 0.12) !important;
    }

    .feature-card h4 {
        font-size: 1.25rem !important;
        line-height: 1.18 !important;
        margin-bottom: 0.6rem !important;
        color: #0f172a !important;
        font-weight: 900 !important;
    }

    .feature-card p {
        max-width: 280px !important;
        margin-bottom: 1.1rem !important;
        color: #52665f !important;
        font-size: 0.96rem !important;
        line-height: 1.52 !important;
        font-weight: 600 !important;
    }

    .feature-link {
        width: fit-content !important;
        margin-top: auto !important;
        padding: 0.52rem 0.78rem !important;
        border-radius: 999px !important;
        gap: 0.45rem !important;
        color: var(--primary-900) !important;
        font-size: 0.9rem !important;
        font-weight: 850 !important;
        background: rgba(209, 250, 229, 0.78) !important;
        border: 1px solid rgba(16, 185, 129, 0.16) !important;
        box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.84) !important;
    }

    .feature-link i {
        display: inline-grid !important;
        place-items: center !important;
        width: 1.25rem !important;
        height: 1.25rem !important;
        border-radius: 999px !important;
        color: #ffffff !important;
        background: linear-gradient(135deg, #10b981, #047857) !important;
    }
}

@keyframes mobile-stat-loop {
    0%, 42% {
        transform: translateX(0);
    }
    50%, 92% {
        transform: translateX(-342px);
    }
    100% {
        transform: translateX(-684px);
    }
}

/* Final mobile Live Footprint redesign: use the animated desktop counters, not the loop clone. */
@media (max-width: 575.98px) {
    .mobile-stats-loop {
        display: none !important;
    }

    .stats-section {
        padding: 4.35rem 0 4.6rem !important;
        position: relative !important;
        overflow: hidden !important;
        color: #ffffff !important;
        background:
            linear-gradient(rgba(209, 250, 229, 0.055) 1px, transparent 1px),
            linear-gradient(90deg, rgba(209, 250, 229, 0.055) 1px, transparent 1px),
            radial-gradient(circle at 18% 18%, rgba(52, 211, 153, 0.28), transparent 34%),
            radial-gradient(circle at 82% 78%, rgba(20, 184, 166, 0.2), transparent 34%),
            linear-gradient(145deg, #042f27 0%, #064e3b 48%, #021f1a 100%) !important;
        background-size: 34px 34px, 34px 34px, auto, auto, auto !important;
    }

    .stats-section::before {
        content: "" !important;
        position: absolute !important;
        inset: 0 !important;
        background:
            linear-gradient(135deg, rgba(255, 255, 255, 0.1), transparent 36%),
            radial-gradient(circle at 50% 0%, rgba(255, 255, 255, 0.12), transparent 32%) !important;
        pointer-events: none !important;
    }

    .stats-section .container {
        position: relative !important;
        z-index: 1 !important;
    }

    .stats-section .section-header {
        width: min(100%, 340px) !important;
        margin-inline: auto !important;
        margin-bottom: 1.65rem !important;
        padding-inline: 0.25rem !important;
    }

    .stats-section .section-title {
        color: #ffffff !important;
        text-shadow: 0 14px 34px rgba(0, 0, 0, 0.24) !important;
    }

    .stats-section .section-title .gradient-text {
        background: linear-gradient(135deg, #ffffff, #6ee7b7) !important;
        -webkit-background-clip: text !important;
        -webkit-text-fill-color: transparent !important;
    }

    .stats-section .section-title i,
    .stats-section .section-subtitle {
        color: rgba(209, 250, 229, 0.88) !important;
    }

    .stats-section .section-title span span {
        background: rgba(110, 231, 183, 0.82) !important;
    }

    .stats-section .row {
        display: grid !important;
        grid-template-columns: 1fr !important;
        width: min(100%, 342px) !important;
        max-width: 342px !important;
        margin-inline: auto !important;
        gap: 1rem !important;
        padding: 0 !important;
        overflow: visible !important;
    }

    .stats-section .row > [class*="col-"] {
        width: 100% !important;
        max-width: 100% !important;
        padding: 0 !important;
    }

    .stat-card-impact {
        min-height: 236px !important;
        padding: 1.35rem !important;
        display: grid !important;
        grid-template-columns: minmax(0, 1fr) auto !important;
        grid-template-areas:
            "number icon"
            "label icon"
            "caption caption"
            "meter meter" !important;
        align-items: start !important;
        gap: 0.35rem 0.9rem !important;
        border-radius: 28px !important;
        overflow: hidden !important;
        color: #ffffff !important;
        background:
            radial-gradient(circle at 88% 12%, rgba(110, 231, 183, 0.24), transparent 32%),
            linear-gradient(145deg, rgba(255, 255, 255, 0.14), rgba(255, 255, 255, 0.06)) !important;
        border: 1px solid rgba(167, 243, 208, 0.2) !important;
        box-shadow:
            inset 0 1px 0 rgba(255, 255, 255, 0.18),
            0 26px 60px rgba(0, 0, 0, 0.24) !important;
        backdrop-filter: blur(18px) saturate(150%) !important;
    }

    .stat-card-impact::before {
        inset: 0.75rem !important;
        border-radius: 22px !important;
        border-color: rgba(209, 250, 229, 0.12) !important;
    }

    .stat-card-impact::after {
        width: 190px !important;
        height: 190px !important;
        right: -66px !important;
        top: -72px !important;
        background: radial-gradient(circle, rgba(110, 231, 183, 0.25), rgba(16, 185, 129, 0.02) 62%, transparent 63%) !important;
    }

    .stat-card-impact .stat-card-orbit {
        top: auto !important;
        right: -28px !important;
        bottom: -36px !important;
        width: 118px !important;
        height: 118px !important;
        border-color: rgba(209, 250, 229, 0.16) !important;
        opacity: 0.76 !important;
    }

    .stat-card-impact .stat-icon {
        grid-area: icon !important;
        position: static !important;
        width: 58px !important;
        height: 58px !important;
        border-radius: 20px !important;
        color: #d1fae5 !important;
        font-size: 1.35rem !important;
        background: rgba(255, 255, 255, 0.12) !important;
        box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.2), 0 16px 32px rgba(0, 0, 0, 0.14) !important;
    }

    .stat-number-wrap {
        grid-area: number !important;
        margin: 0 !important;
        min-height: 0 !important;
        align-items: flex-start !important;
    }

    .stat-card-impact .stat-number {
        font-size: clamp(3.35rem, 16vw, 4.35rem) !important;
        line-height: 0.88 !important;
        color: #ffffff !important;
        background: linear-gradient(135deg, #ffffff 0%, #6ee7b7 72%, #10b981 100%) !important;
        background-clip: text !important;
        -webkit-background-clip: text !important;
        -webkit-text-fill-color: transparent !important;
        filter: drop-shadow(0 16px 26px rgba(0, 0, 0, 0.18)) !important;
    }

    .stat-plus {
        color: #6ee7b7 !important;
        font-size: 1.7rem !important;
        margin-top: 0.12rem !important;
    }

    .stat-card-impact .stat-label {
        grid-area: label !important;
        color: #ffffff !important;
        font-size: 1.08rem !important;
        line-height: 1.18 !important;
        margin: 0.1rem 0 0 !important;
    }

    .stat-caption {
        grid-area: caption !important;
        max-width: none !important;
        min-height: 0 !important;
        color: rgba(209, 250, 229, 0.82) !important;
        font-size: 0.9rem !important;
        line-height: 1.45 !important;
        margin: 0.4rem 0 0 !important;
    }

    .stat-meter {
        grid-area: meter !important;
        height: 8px !important;
        margin-top: 0.8rem !important;
        background: rgba(255, 255, 255, 0.12) !important;
    }

    .stat-meter span {
        background: linear-gradient(90deg, #6ee7b7, #10b981, #ffffff) !important;
        box-shadow: 0 0 22px rgba(110, 231, 183, 0.48) !important;
    }
}

/* Final mobile Testimonials redesign: editorial proof section, distinct from cards/gallery. */
@media (max-width: 575.98px) {
    .testimonials-section {
        padding: 4.6rem 0 4.8rem !important;
        position: relative !important;
        overflow: hidden !important;
        background:
            radial-gradient(circle at 14% 18%, rgba(16, 185, 129, 0.16), transparent 30%),
            radial-gradient(circle at 88% 72%, rgba(14, 165, 233, 0.12), transparent 30%),
            linear-gradient(180deg, #f8fffd 0%, #ffffff 48%, #eefdf7 100%) !important;
    }

    .testimonials-section::before {
        content: "" !important;
        position: absolute !important;
        left: 50% !important;
        top: 1.4rem !important;
        width: 320px !important;
        height: 320px !important;
        transform: translateX(-50%) !important;
        border-radius: 50% !important;
        background: conic-gradient(from 180deg, rgba(16, 185, 129, 0.18), transparent 34%, rgba(14, 165, 233, 0.1), transparent 72%, rgba(16, 185, 129, 0.18)) !important;
        filter: blur(18px) !important;
        opacity: 0.8 !important;
        pointer-events: none !important;
    }

    .testimonials-section .container {
        position: relative !important;
        z-index: 1 !important;
    }

    .testimonials-section .section-header {
        width: min(100%, 340px) !important;
        margin-inline: auto !important;
        margin-bottom: 1.8rem !important;
        padding-inline: 0.25rem !important;
    }

    .testimonials-section .section-title {
        font-size: clamp(1.82rem, 8.5vw, 2.05rem) !important;
    }

    .testimonial-carousel {
        width: min(100%, 344px) !important;
        max-width: 344px !important;
        margin-inline: auto !important;
        padding: 0.25rem 0 0.8rem !important;
        overflow: hidden !important;
        border-radius: 34px !important;
    }

    .testimonial-track {
        gap: 18px !important;
    }

    .testimonial-card {
        flex: 0 0 344px !important;
        min-width: 344px !important;
        min-height: 390px !important;
        padding: 1.55rem !important;
        display: grid !important;
        align-content: space-between !important;
        border: 1px solid rgba(6, 95, 70, 0.16) !important;
        border-radius: 32px !important;
        color: #ffffff !important;
        background:
            radial-gradient(circle at 84% 16%, rgba(110, 231, 183, 0.2), transparent 32%),
            linear-gradient(145deg, #07372f 0%, #0f766e 58%, #064e3b 100%) !important;
        box-shadow:
            0 28px 74px rgba(6, 95, 70, 0.22),
            inset 0 1px 0 rgba(255, 255, 255, 0.18) !important;
        position: relative !important;
        overflow: hidden !important;
    }

    .testimonial-card::before {
        content: "Member voice" !important;
        position: absolute !important;
        top: 1.25rem !important;
        right: 1.25rem !important;
        padding: 0.42rem 0.7rem !important;
        border-radius: 999px !important;
        color: rgba(236, 253, 245, 0.92) !important;
        font-size: 0.64rem !important;
        line-height: 1 !important;
        font-weight: 900 !important;
        letter-spacing: 0.08em !important;
        text-transform: uppercase !important;
        background: rgba(255, 255, 255, 0.11) !important;
        border: 1px solid rgba(255, 255, 255, 0.12) !important;
    }

    .testimonial-card::after {
        content: "" !important;
        position: absolute !important;
        right: -70px !important;
        bottom: -85px !important;
        width: 220px !important;
        height: 220px !important;
        border-radius: 50% !important;
        border: 1px dashed rgba(209, 250, 229, 0.18) !important;
        pointer-events: none !important;
    }

    .testimonial-quote-icon {
        width: 58px !important;
        height: 58px !important;
        display: inline-grid !important;
        place-items: center !important;
        margin: 0 0 1.25rem !important;
        border-radius: 20px !important;
        color: #064e3b !important;
        font-size: 1.8rem !important;
        background: linear-gradient(145deg, #ffffff, #d1fae5) !important;
        box-shadow: 0 16px 34px rgba(0, 0, 0, 0.14), inset 0 1px 0 rgba(255, 255, 255, 0.92) !important;
    }

    .testimonial-card p {
        min-height: 0 !important;
        margin: 0 !important;
        color: rgba(255, 255, 255, 0.92) !important;
        font-size: 1.04rem !important;
        line-height: 1.65 !important;
        font-weight: 650 !important;
        letter-spacing: 0 !important;
    }

    .testimonial-person {
        margin-top: 1.45rem !important;
        padding: 0.85rem !important;
        gap: 0.78rem !important;
        border-radius: 22px !important;
        background: rgba(255, 255, 255, 0.11) !important;
        border: 1px solid rgba(255, 255, 255, 0.13) !important;
        box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.14) !important;
    }

    .testimonial-person img,
    .testimonial-person span {
        width: 52px !important;
        height: 52px !important;
        flex: 0 0 52px !important;
        color: #064e3b !important;
        background: #d1fae5 !important;
        box-shadow: 0 10px 24px rgba(0, 0, 0, 0.16) !important;
    }

    .testimonial-person strong {
        color: #ffffff !important;
        font-size: 1rem !important;
        line-height: 1.18 !important;
    }

    .testimonial-person small {
        display: block !important;
        margin-top: 0.22rem !important;
        color: rgba(209, 250, 229, 0.72) !important;
        font-size: 0.82rem !important;
        line-height: 1.25 !important;
    }
}

/* Final mobile gallery pass: keep the marquee, restore tap-to-expand lightbox. */
@media (max-width: 575.98px) {
    .gallery-loop-section {
        padding: 4.6rem 0 4.25rem !important;
        position: relative !important;
        overflow: hidden !important;
        background:
            linear-gradient(rgba(6, 95, 70, 0.045) 1px, transparent 1px),
            linear-gradient(90deg, rgba(6, 95, 70, 0.045) 1px, transparent 1px),
            radial-gradient(circle at 16% 20%, rgba(16, 185, 129, 0.16), transparent 30%),
            radial-gradient(circle at 92% 62%, rgba(59, 130, 246, 0.1), transparent 30%),
            linear-gradient(180deg, #f8fffd 0%, #eafff7 100%) !important;
        background-size: 34px 34px, 34px 34px, auto, auto, auto !important;
    }

    .gallery-loop-section .section-header {
        width: min(100%, 340px) !important;
        margin-inline: auto !important;
        margin-bottom: 1.8rem !important;
        padding-inline: 0.25rem !important;
    }

    .gallery-loop-section .section-title {
        font-size: clamp(1.82rem, 8.5vw, 2.05rem) !important;
    }

    .gallery-marquee {
        width: 100% !important;
        padding: 1.1rem 0 1.55rem !important;
        overflow: hidden !important;
        -webkit-mask-image: linear-gradient(90deg, transparent, #000 10%, #000 90%, transparent) !important;
        mask-image: linear-gradient(90deg, transparent, #000 10%, #000 90%, transparent) !important;
    }

    .gallery-track {
        gap: 1rem !important;
        align-items: stretch !important;
        animation-duration: 26s !important;
    }

    .gallery-item {
        width: min(76vw, 300px) !important;
        height: 205px !important;
        flex: 0 0 min(76vw, 300px) !important;
        border-radius: 28px !important;
        border: 1px solid rgba(167, 243, 208, 0.62) !important;
        box-shadow:
            0 24px 60px rgba(6, 95, 70, 0.18),
            inset 0 1px 0 rgba(255, 255, 255, 0.28) !important;
        cursor: pointer !important;
    }

    .gallery-item::before {
        content: "Tap to view" !important;
        position: absolute !important;
        top: 0.78rem !important;
        right: 0.78rem !important;
        z-index: 2 !important;
        padding: 0.34rem 0.58rem !important;
        border-radius: 999px !important;
        color: #064e3b !important;
        font-size: 0.64rem !important;
        line-height: 1 !important;
        font-weight: 900 !important;
        background: rgba(255, 255, 255, 0.86) !important;
        border: 1px solid rgba(255, 255, 255, 0.72) !important;
        box-shadow: 0 10px 24px rgba(6, 95, 70, 0.16) !important;
    }

    .gallery-item figcaption {
        right: 0.85rem !important;
        bottom: 0.85rem !important;
        left: 0.85rem !important;
        font-size: 0.98rem !important;
        line-height: 1.15 !important;
        text-shadow: 0 2px 14px rgba(0, 0, 0, 0.42) !important;
    }

    .gallery-lightbox {
        display: none !important;
        padding: 1rem !important;
        background:
            radial-gradient(circle at 50% 20%, rgba(16, 185, 129, 0.18), transparent 34%),
            rgba(2, 12, 10, 0.92) !important;
    }

    .gallery-lightbox.open {
        display: flex !important;
    }

    .gallery-lightbox-stage {
        width: calc(100vw - 2rem) !important;
        max-width: 430px !important;
        max-height: 76vh !important;
        border-radius: 26px !important;
        background: rgba(255, 255, 255, 0.08) !important;
        box-shadow: 0 28px 90px rgba(0, 0, 0, 0.46) !important;
    }

    .gallery-lightbox-stage img {
        width: 100% !important;
        max-height: 62vh !important;
        object-fit: contain !important;
    }

    .gallery-lightbox-stage figcaption {
        align-items: flex-start !important;
        padding: 0.85rem 0.95rem !important;
        gap: 0.35rem !important;
        flex-direction: column !important;
        background: rgba(4, 47, 46, 0.96) !important;
    }

    .gallery-lightbox-stage figcaption span {
        font-size: 0.95rem !important;
        line-height: 1.2 !important;
    }

    .gallery-lightbox-stage figcaption small {
        font-size: 0.78rem !important;
    }

    .gallery-lightbox-close {
        top: 1rem !important;
        right: 1rem !important;
        width: 44px !important;
        height: 44px !important;
        border-radius: 16px !important;
        z-index: 5 !important;
    }

    .gallery-lightbox-nav {
        top: auto !important;
        bottom: 1rem !important;
        width: 46px !important;
        height: 46px !important;
        transform: none !important;
        z-index: 5 !important;
        background: rgba(255, 255, 255, 0.18) !important;
    }

    .gallery-lightbox-nav:hover,
    .gallery-lightbox-nav:focus-visible {
        transform: translateY(-2px) !important;
    }

    .gallery-lightbox-nav.prev {
        left: calc(50% - 58px) !important;
    }

    .gallery-lightbox-nav.next {
        right: calc(50% - 58px) !important;
    }
}

/* Final mobile CTA redesign: lighter premium membership prompt before footer. */
@media (max-width: 575.98px) {
    .cta-section {
        padding: 4.4rem 0 4.8rem !important;
        position: relative !important;
        overflow: hidden !important;
        background:
            radial-gradient(circle at 16% 24%, rgba(16, 185, 129, 0.16), transparent 30%),
            radial-gradient(circle at 88% 78%, rgba(14, 165, 233, 0.09), transparent 32%),
            linear-gradient(180deg, #f8fffd 0%, #ecfdf5 100%) !important;
    }

    .cta-card {
        width: min(100%, 342px) !important;
        margin-inline: auto !important;
        padding: 1.5rem !important;
        border-radius: 32px !important;
        text-align: left !important;
        color: #052e22 !important;
        background:
            radial-gradient(circle at 86% 14%, rgba(16, 185, 129, 0.2), transparent 34%),
            linear-gradient(145deg, rgba(255, 255, 255, 0.98), rgba(236, 253, 245, 0.86)) !important;
        border: 1px solid rgba(167, 243, 208, 0.82) !important;
        box-shadow:
            inset 0 1px 0 rgba(255, 255, 255, 0.98),
            0 30px 78px rgba(6, 95, 70, 0.17) !important;
        isolation: isolate !important;
    }

    .cta-card::before {
        content: "Member access" !important;
        position: static !important;
        display: inline-flex !important;
        width: auto !important;
        height: auto !important;
        margin-bottom: 1rem !important;
        padding: 0.42rem 0.72rem !important;
        border-radius: 999px !important;
        color: var(--primary-900) !important;
        font-size: 0.68rem !important;
        line-height: 1 !important;
        font-weight: 900 !important;
        letter-spacing: 0.08em !important;
        text-transform: uppercase !important;
        background: rgba(209, 250, 229, 0.88) !important;
        border: 1px solid rgba(16, 185, 129, 0.18) !important;
        box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.88) !important;
    }

    .cta-card::after {
        content: "" !important;
        position: absolute !important;
        right: -74px !important;
        bottom: -82px !important;
        width: 210px !important;
        height: 210px !important;
        border-radius: 50% !important;
        background: radial-gradient(circle, rgba(16, 185, 129, 0.18), transparent 64%) !important;
        border: 1px dashed rgba(5, 150, 105, 0.12) !important;
        z-index: -1 !important;
    }

    .cta-card h2 {
        max-width: 290px !important;
        margin: 0 0 0.7rem !important;
        color: #052e22 !important;
        font-size: clamp(1.55rem, 7.8vw, 1.9rem) !important;
        line-height: 1.08 !important;
        letter-spacing: 0 !important;
        filter: none !important;
        text-align: left !important;
    }

    .cta-card p {
        max-width: 290px !important;
        margin: 0 0 1.35rem !important;
        color: #52665f !important;
        font-size: 0.96rem !important;
        line-height: 1.52 !important;
        font-weight: 650 !important;
        text-align: left !important;
    }

    .cta-buttons {
        display: grid !important;
        grid-template-columns: 1fr !important;
        gap: 0.72rem !important;
        width: 100% !important;
        justify-content: stretch !important;
    }

    .cta-buttons .btn {
        width: 100% !important;
        min-height: 54px !important;
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 0.45rem !important;
        border-radius: 18px !important;
        font-size: 1rem !important;
        font-weight: 850 !important;
        letter-spacing: 0 !important;
        box-shadow: none !important;
    }

    .cta-buttons .btn-glow {
        color: #ffffff !important;
        background: linear-gradient(135deg, #10b981 0%, #047857 100%) !important;
        border: 0 !important;
        box-shadow: 0 18px 38px rgba(6, 95, 70, 0.22) !important;
    }

    .cta-buttons .btn-outline-light {
        color: var(--primary-900) !important;
        background: rgba(255, 255, 255, 0.78) !important;
        border: 1px solid rgba(5, 150, 105, 0.2) !important;
    }

    .cta-buttons .btn i {
        font-size: 1.05rem !important;
    }
}

/* Mobile navbar open state: blur page content behind the menu. */
@media (max-width: 991.98px) {
    body.nav-menu-open {
        overflow: hidden;
    }

    .nav-backdrop {
        position: fixed;
        inset: 0;
        z-index: 1020;
        background:
            radial-gradient(circle at 82% 12%, rgba(16, 185, 129, 0.16), transparent 34%),
            rgba(2, 12, 10, 0.22);
        backdrop-filter: blur(14px) saturate(125%);
        -webkit-backdrop-filter: blur(14px) saturate(125%);
        opacity: 0;
        pointer-events: none;
        transition: opacity 240ms ease;
    }

    body.nav-menu-open .nav-backdrop {
        opacity: 1;
        pointer-events: auto;
        cursor: pointer;
    }

    body.nav-menu-closing .nav-backdrop,
    body.nav-menu-opening .nav-backdrop {
        opacity: 0.78;
    }

    .navbar-custom {
        z-index: 1035;
    }

    .navbar-collapse.show,
    .navbar-collapse.collapsing {
        position: relative;
        z-index: 1036;
        background:
            radial-gradient(circle at 18% 0%, rgba(209, 250, 229, 0.86), transparent 34%),
            rgba(255, 255, 255, 0.82) !important;
        border: 1px solid rgba(167, 243, 208, 0.72);
        box-shadow: 0 28px 78px rgba(6, 95, 70, 0.18);
        backdrop-filter: blur(18px) saturate(150%);
        -webkit-backdrop-filter: blur(18px) saturate(150%);
    }
}

/* Final mobile auth redesign: login, verify/register, and signup forms. */
@media (max-width: 575.98px) {
    .auth-section,
    .login-premium-section,
    .signup-section {
        min-height: auto !important;
        padding: 2rem 0 3.25rem !important;
        display: block !important;
        background:
            radial-gradient(circle at 12% 18%, rgba(16, 185, 129, 0.16), transparent 30%),
            radial-gradient(circle at 92% 82%, rgba(59, 130, 246, 0.08), transparent 32%),
            linear-gradient(180deg, #f8fffd 0%, #ecfdf5 100%) !important;
    }

    .login-premium-section .container,
    .signup-section .container {
        padding-inline: 1rem !important;
    }

    .login-shell,
    .verify-shell {
        width: min(100%, 348px) !important;
        max-width: 348px !important;
        margin-inline: auto !important;
        display: grid !important;
        grid-template-columns: 1fr !important;
        border-radius: 32px !important;
        overflow: hidden !important;
        background: rgba(255, 255, 255, 0.94) !important;
        border: 1px solid rgba(167, 243, 208, 0.76) !important;
        box-shadow: 0 28px 78px rgba(6, 95, 70, 0.15) !important;
    }

    .login-brand-panel {
        display: grid !important;
        grid-template-columns: auto minmax(0, 1fr) !important;
        gap: 0.85rem 0.9rem !important;
        align-items: center !important;
        padding: 1.3rem !important;
        min-height: auto !important;
        background:
            radial-gradient(circle at 86% 0%, rgba(110, 231, 183, 0.24), transparent 36%),
            linear-gradient(145deg, #064e3b 0%, #0f766e 100%) !important;
    }

    .login-brand-mark {
        width: 52px !important;
        height: 52px !important;
        margin: 0 !important;
        border-radius: 18px !important;
        font-size: 1.35rem !important;
    }

    .login-kicker {
        margin: 0 0 0.2rem !important;
        padding: 0.34rem 0.62rem !important;
        font-size: 0.62rem !important;
        line-height: 1 !important;
    }

    .login-brand-panel h1 {
        grid-column: 2 !important;
        margin: 0 !important;
        color: #ffffff !important;
        font-size: clamp(1.28rem, 6.8vw, 1.62rem) !important;
        line-height: 1.08 !important;
        letter-spacing: 0 !important;
    }

    .login-brand-panel p {
        grid-column: 1 / -1 !important;
        margin: 0.1rem 0 0 !important;
        color: rgba(236, 253, 245, 0.82) !important;
        font-size: 0.86rem !important;
        line-height: 1.48 !important;
    }

    .login-benefits {
        grid-column: 1 / -1 !important;
        display: grid !important;
        grid-template-columns: 1fr !important;
        gap: 0.48rem !important;
        margin-top: 0.25rem !important;
    }

    .login-benefits span {
        display: flex !important;
        align-items: center !important;
        gap: 0.5rem !important;
        padding: 0.46rem 0.62rem !important;
        border-radius: 999px !important;
        color: rgba(255, 255, 255, 0.9) !important;
        background: rgba(255, 255, 255, 0.11) !important;
        font-size: 0.78rem !important;
        line-height: 1.25 !important;
    }

    .login-form-panel {
        padding: 1.35rem !important;
        display: block !important;
    }

    .login-header {
        margin-bottom: 1.15rem !important;
        text-align: left !important;
    }

    .login-header h2 {
        margin-bottom: 0.35rem !important;
        color: #0f172a !important;
        font-size: clamp(1.55rem, 7.5vw, 1.9rem) !important;
        line-height: 1.08 !important;
        letter-spacing: 0 !important;
    }

    .login-header p {
        margin: 0 !important;
        color: #64748b !important;
        font-size: 0.9rem !important;
        line-height: 1.45 !important;
    }

    .login-form .login-field {
        margin-bottom: 0.9rem !important;
    }

    .login-form .form-label,
    .auth-form .form-label {
        display: flex !important;
        align-items: center !important;
        gap: 0.4rem !important;
        margin-bottom: 0.45rem !important;
        color: #334155 !important;
        font-size: 0.82rem !important;
        font-weight: 850 !important;
    }

    .login-form .form-control,
    .login-form input[type="email"],
    .login-form input[type="password"],
    .auth-form .form-control,
    .auth-form .form-select {
        width: 100% !important;
        min-height: 52px !important;
        padding: 0.78rem 0.9rem !important;
        border-radius: 18px !important;
        font-size: 0.95rem !important;
        background: rgba(255, 255, 255, 0.94) !important;
        border: 1px solid rgba(16, 185, 129, 0.16) !important;
        box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.94), 0 10px 24px rgba(6, 95, 70, 0.05) !important;
    }

    .login-form .form-control:focus,
    .login-form input[type="email"]:focus,
    .login-form input[type="password"]:focus,
    .auth-form .form-control:focus,
    .auth-form .form-select:focus {
        border-color: rgba(16, 185, 129, 0.72) !important;
        box-shadow: 0 0 0 4px rgba(16, 185, 129, 0.12), 0 12px 28px rgba(6, 95, 70, 0.08) !important;
    }

    .login-forgot-row {
        align-items: flex-start !important;
        flex-direction: column !important;
        gap: 0.28rem !important;
        margin: -0.15rem 0 0.95rem !important;
        font-size: 0.82rem !important;
    }

    .login-submit,
    .auth-submit-btn {
        min-height: 54px !important;
        margin: 0.2rem 0 1rem !important;
        border-radius: 18px !important;
        font-size: 0.98rem !important;
        font-weight: 900 !important;
        white-space: normal !important;
        background: linear-gradient(135deg, #10b981, #047857) !important;
        box-shadow: 0 18px 38px rgba(6, 95, 70, 0.2) !important;
    }

    .login-actions,
    .verify-actions {
        display: grid !important;
        grid-template-columns: 1fr !important;
        gap: 0.72rem !important;
    }

    .login-action-card {
        min-height: 72px !important;
        padding: 0.78rem !important;
        border-radius: 20px !important;
        gap: 0.72rem !important;
        background: rgba(255, 255, 255, 0.78) !important;
        border: 1px solid rgba(16, 185, 129, 0.14) !important;
    }

    .login-action-primary {
        background: rgba(209, 250, 229, 0.75) !important;
    }

    .login-action-card i {
        width: 44px !important;
        height: 44px !important;
        border-radius: 16px !important;
        font-size: 1.12rem !important;
    }

    .login-action-card strong {
        font-size: 0.93rem !important;
    }

    .login-action-card span {
        font-size: 0.82rem !important;
        line-height: 1.25 !important;
    }

    .signup-section .row,
    .signup-section .col-lg-9,
    .signup-section .col-md-11,
    .signup-section .col-md-10 {
        display: block !important;
        width: 100% !important;
        max-width: none !important;
        margin: 0 !important;
    }

    .signup-section .auth-card,
    .profile-section .auth-card {
        width: min(100%, 348px) !important;
        max-width: 348px !important;
        margin-inline: auto !important;
        padding: 1.35rem !important;
        border-radius: 32px !important;
        background:
            radial-gradient(circle at 86% 10%, rgba(16, 185, 129, 0.14), transparent 34%),
            rgba(255, 255, 255, 0.95) !important;
        border: 1px solid rgba(167, 243, 208, 0.76) !important;
        box-shadow: 0 28px 78px rgba(6, 95, 70, 0.14) !important;
    }

    .auth-header {
        margin-bottom: 1.2rem !important;
    }

    .auth-icon {
        width: 58px !important;
        height: 58px !important;
        margin-bottom: 0.85rem !important;
        border-radius: 20px !important;
    }

    .auth-header h2 {
        font-size: clamp(1.5rem, 7.2vw, 1.9rem) !important;
        line-height: 1.12 !important;
    }

    .auth-header p {
        margin-bottom: 0 !important;
        font-size: 0.9rem !important;
        line-height: 1.45 !important;
    }

    .form-section {
        padding: 1rem !important;
        border-radius: 22px !important;
        margin-bottom: 1rem !important;
        background: rgba(248, 255, 253, 0.82) !important;
        border: 1px solid rgba(16, 185, 129, 0.1) !important;
    }

    .form-section-title {
        font-size: 0.98rem !important;
        line-height: 1.25 !important;
        margin-bottom: 0.9rem !important;
    }

    .auth-form .row {
        --bs-gutter-x: 0 !important;
        --bs-gutter-y: 0.85rem !important;
    }

    .pc-entry {
        padding: 0.95rem !important;
        border-radius: 20px !important;
    }

    .payment-qr-grid {
        grid-template-columns: 1fr !important;
        gap: 0.9rem !important;
    }

    .payment-qr-card,
    .payment-help-card,
    .undertaking-box {
        padding: 1rem !important;
        border-radius: 20px !important;
    }
}

/* Keep password reset screens isolated from generic auth overrides. */
.login-premium-section .reset-page-shell {
    width: min(1120px, calc(100% - 2rem));
    max-width: 1120px;
}

.reset-page-shell .reset-password-form .reset-field .form-control {
    width: 100%;
    min-height: 60px;
    padding: 0.95rem 1.05rem;
    border-radius: 20px;
}

.reset-page-shell .reset-submit-btn {
    width: 100%;
    min-height: 62px;
    border-radius: 20px;
}

@media (max-width: 991.98px) {
    .login-premium-section .reset-page-shell {
        width: min(92vw, 720px);
    }
}

@media (max-width: 575.98px) {
    .login-premium-section .reset-page-shell {
        width: min(100%, 348px);
    }

    .reset-page-shell .reset-password-form .reset-field .form-control {
        min-height: 54px;
        border-radius: 18px;
    }

    .reset-page-shell .reset-submit-btn {
        min-height: 56px;
        border-radius: 18px;
    }
}

/* ── Password reset page — premium mobile redesign ── */
@media (max-width: 575.98px) {
    section.pw-reset-page {
        min-height: calc(100dvh - 56px) !important;
        padding: 0 !important;
        display: flex !important;
        flex-direction: column !important;
        justify-content: center !important;
        align-items: stretch !important;
        background:
            radial-gradient(circle at 10% 15%, rgba(52, 211, 153, 0.2), transparent 40%),
            radial-gradient(circle at 90% 80%, rgba(6, 78, 59, 0.55), transparent 50%),
            linear-gradient(160deg, #064e3b 0%, #065f46 55%, #047857 100%) !important;
    }

    section.pw-reset-page .container {
        padding: 1.5rem 1.25rem 2rem !important;
    }

    /* Strip shell card — only form panel shows as floating card */
    section.pw-reset-page .login-shell {
        width: 100% !important;
        max-width: 100% !important;
        background: none !important;
        border: none !important;
        box-shadow: none !important;
        backdrop-filter: none !important;
        -webkit-backdrop-filter: none !important;
        border-radius: 0 !important;
        overflow: visible !important;
        display: flex !important;
        flex-direction: column !important;
        gap: 1.25rem !important;
    }

    /* Brand panel — transparent on dark green */
    section.pw-reset-page .login-brand-panel {
        background: none !important;
        padding: 0 !important;
        display: grid !important;
        grid-template-columns: auto minmax(0, 1fr) !important;
        gap: 0.6rem 0.75rem !important;
        align-items: center !important;
    }

    section.pw-reset-page .login-brand-mark {
        background: rgba(255, 255, 255, 0.15) !important;
        border: 1.5px solid rgba(255, 255, 255, 0.28) !important;
        box-shadow: none !important;
        width: 44px !important;
        height: 44px !important;
        border-radius: 14px !important;
        font-size: 1.15rem !important;
        margin: 0 !important;
    }

    section.pw-reset-page .login-kicker {
        background: rgba(110, 231, 183, 0.18) !important;
        border: 1.5px solid rgba(110, 231, 183, 0.42) !important;
        color: #6ee7b7 !important;
        margin: 0 !important;
        font-size: 0.68rem !important;
    }

    section.pw-reset-page .login-brand-panel h1 {
        grid-column: 2 !important;
        color: #ffffff !important;
        font-size: 1.3rem !important;
        line-height: 1.18 !important;
        margin: 0 !important;
        text-shadow: 0 2px 10px rgba(0, 0, 0, 0.18) !important;
    }

    section.pw-reset-page .login-brand-panel p,
    section.pw-reset-page .login-benefits {
        display: none !important;
    }

    /* Frosted white card for the form */
    section.pw-reset-page .login-form-panel {
        background: rgba(255, 255, 255, 0.93) !important;
        backdrop-filter: blur(24px) saturate(160%) !important;
        -webkit-backdrop-filter: blur(24px) saturate(160%) !important;
        border-radius: 28px !important;
        padding: 1.5rem 1.4rem !important;
        box-shadow: 0 24px 60px rgba(0, 0, 0, 0.22) !important;
        border: 1px solid rgba(255, 255, 255, 0.55) !important;
        display: flex !important;
        flex-direction: column !important;
        gap: 0.9rem !important;
    }

    section.pw-reset-page .login-header {
        margin-bottom: 0 !important;
        padding-bottom: 0.85rem !important;
        border-bottom: 1px solid rgba(16, 185, 129, 0.1) !important;
    }

    section.pw-reset-page .login-header h2 {
        font-size: 1.35rem !important;
        margin-bottom: 0.2rem !important;
    }

    section.pw-reset-page .login-header p {
        font-size: 0.82rem !important;
        color: #64748b !important;
        margin: 0 !important;
    }

    section.pw-reset-page .login-field {
        margin-bottom: 0 !important;
    }

    .pw-reset-email-note {
        display: flex;
        align-items: flex-start;
        gap: 0.6rem;
        padding: 0.75rem 0.9rem;
        border-radius: 14px;
        background: rgba(209, 250, 229, 0.55);
        border: 1px solid rgba(16, 185, 129, 0.18);
        font-size: 0.82rem;
        color: #374151;
        line-height: 1.4;
    }

    .pw-reset-email-note i {
        flex: 0 0 auto;
        font-size: 1rem;
        color: #059669;
        margin-top: 0.05rem;
    }

    .pw-reset-email-note strong {
        color: #0f172a;
        font-weight: 800;
    }

    section.pw-reset-page .login-submit {
        margin: 0 !important;
        min-height: 50px !important;
    }

    /* Action cards — side by side in 2 columns */
    section.pw-reset-page .login-actions {
        display: grid !important;
        grid-template-columns: 1fr 1fr !important;
        gap: 0.6rem !important;
        margin: 0 !important;
    }

    section.pw-reset-page .login-action-card {
        min-height: auto !important;
        flex-direction: column !important;
        align-items: flex-start !important;
        padding: 0.75rem !important;
        border-radius: 16px !important;
        gap: 0.45rem !important;
    }

    section.pw-reset-page .login-action-card i {
        width: 32px !important;
        height: 32px !important;
        border-radius: 10px !important;
        font-size: 0.9rem !important;
    }

    section.pw-reset-page .login-action-card strong {
        display: block !important;
        font-size: 0.8rem !important;
        color: #0f172a !important;
        line-height: 1.2 !important;
    }

    section.pw-reset-page .login-action-card span {
        font-size: 0.72rem !important;
        color: #64748b !important;
        line-height: 1.3 !important;
    }
}

/* ── Store directory — sticky filter on mobile ── */
@media (max-width: 767.98px) {
    /* Switch row to block so the filter col spans full row height */
    .store-filter-row {
        display: block !important;
    }

    /* Make the filter col sticky within the full-height row */
    .store-filter-col {
        position: sticky !important;
        top: 60px !important;
        z-index: 300 !important;
        margin-bottom: 0 !important;
        padding-bottom: 0 !important;
    }

    /* Liquid glass effect — matches the navbar style */
    .store-filter-col .sticky-filter {
        position: static !important;
        background: rgba(255, 255, 255, 0.78) !important;
        backdrop-filter: blur(22px) saturate(180%) !important;
        -webkit-backdrop-filter: blur(22px) saturate(180%) !important;
        border: 1px solid rgba(255, 255, 255, 0.45) !important;
        border-top: none !important;
        border-radius: 0 0 22px 22px !important;
        box-shadow: 0 8px 32px rgba(6, 95, 70, 0.1), 0 1px 0 rgba(255, 255, 255, 0.6) inset !important;
        padding: 0.9rem 1rem !important;
        margin: 0 -0.75rem !important;
    }

    .store-filter-col .filter-title {
        font-size: 0.82rem !important;
        margin-bottom: 0.75rem !important;
        color: #047857 !important;
    }

    /* Compact the form fields in a single row on mobile */
    .store-filter-col #storeFilterForm {
        display: flex !important;
        align-items: flex-end !important;
        gap: 0.5rem !important;
        flex-wrap: wrap !important;
    }

    .store-filter-col #storeFilterForm .mb-3 {
        flex: 1 1 120px !important;
        margin-bottom: 0 !important;
    }

    .store-filter-col #storeFilterForm .form-label {
        font-size: 0.72rem !important;
        margin-bottom: 0.3rem !important;
        display: block !important;
    }

    .store-filter-col #storeFilterForm .form-control,
    .store-filter-col #storeFilterForm .form-select {
        min-height: 40px !important;
        font-size: 0.85rem !important;
        border-radius: 12px !important;
        padding: 0.4rem 0.7rem !important;
    }

    .store-filter-col #storeFilterForm .input-group .form-control {
        border-radius: 0 12px 12px 0 !important;
    }

    .store-filter-col #storeFilterForm .input-group-text {
        border-radius: 12px 0 0 12px !important;
        padding: 0.4rem 0.6rem !important;
        font-size: 0.85rem !important;
    }

    .store-filter-col #storeFilterForm button[type="submit"] {
        flex: 0 0 auto !important;
        min-height: 40px !important;
        padding: 0.4rem 1rem !important;
        font-size: 0.85rem !important;
        border-radius: 12px !important;
        align-self: flex-end !important;
        margin-bottom: 0 !important;
        white-space: nowrap !important;
    }

    /* Clear link stays below the row */
    .store-filter-col #storeFilterForm .text-center {
        flex: 0 0 100% !important;
        margin-top: 0.4rem !important;
    }

    /* Add top padding to stores so first card isn't hidden under sticky filter */
    .store-filter-row .col-lg-9,
    .store-filter-row .col-md-8 {
        padding-top: 0.75rem !important;
    }
}

/* ── Verify / Register page — mobile layout ── */
.verify-mobile-wrap {
    display: none;
}

@media (max-width: 575.98px) {
    section.verify-page {
        min-height: calc(100dvh - 56px) !important;
        padding: 0 !important;
        display: flex !important;
        flex-direction: column !important;
        justify-content: center !important;
        background:
            radial-gradient(circle at 10% 15%, rgba(52, 211, 153, 0.22), transparent 40%),
            radial-gradient(circle at 90% 80%, rgba(6, 78, 59, 0.6), transparent 50%),
            linear-gradient(160deg, #064e3b 0%, #065f46 55%, #047857 100%) !important;
    }

    section.verify-page .container {
        padding: 1.75rem 1.25rem 2.5rem !important;
    }

    .verify-mobile-wrap {
        display: flex !important;
        flex-direction: column;
        gap: 1.25rem;
    }

    .verify-desktop-shell {
        display: none !important;
    }

    /* ── Brand section ── */
    .verify-brand {
        display: flex;
        flex-direction: column;
        align-items: flex-start;
        gap: 0.35rem;
    }

    .verify-brand-icon {
        width: 44px;
        height: 44px;
        display: grid;
        place-items: center;
        border-radius: 14px;
        background: rgba(255, 255, 255, 0.15);
        border: 1.5px solid rgba(255, 255, 255, 0.28);
        color: #ffffff;
        font-size: 1.15rem;
        margin-bottom: 0.35rem;
    }

    .verify-brand .login-kicker {
        background: rgba(110, 231, 183, 0.18) !important;
        border: 1.5px solid rgba(110, 231, 183, 0.42) !important;
        color: #6ee7b7 !important;
        margin: 0 !important;
        font-size: 0.68rem !important;
    }

    .verify-brand h1 {
        color: #ffffff;
        font-size: 1.65rem;
        font-weight: 900;
        line-height: 1.12;
        letter-spacing: -0.02em;
        margin: 0.25rem 0 0;
        text-shadow: 0 2px 10px rgba(0, 0, 0, 0.18);
    }

    .verify-brand p {
        color: rgba(209, 250, 229, 0.82);
        font-size: 0.84rem;
        line-height: 1.5;
        margin: 0.25rem 0 0;
    }

    /* ── Form card ── */
    .verify-form-card {
        background: rgba(255, 255, 255, 0.94);
        backdrop-filter: blur(24px) saturate(160%);
        -webkit-backdrop-filter: blur(24px) saturate(160%);
        border-radius: 28px;
        padding: 1.5rem 1.35rem;
        box-shadow: 0 24px 60px rgba(0, 0, 0, 0.22), 0 1px 0 rgba(255,255,255,0.8) inset;
        border: 1px solid rgba(255, 255, 255, 0.55);
        display: flex;
        flex-direction: column;
        gap: 1rem;
    }

    .verify-form-header {
        padding-bottom: 0.85rem;
        border-bottom: 1px solid rgba(16, 185, 129, 0.1);
    }

    .verify-form-header h2 {
        margin: 0 0 0.2rem;
        font-size: 1.35rem;
        font-weight: 900;
        color: #0f172a;
        letter-spacing: -0.02em;
    }

    .verify-form-header p {
        margin: 0;
        font-size: 0.82rem;
        color: #64748b;
        font-weight: 600;
    }

    .verify-form-card .login-field {
        margin-bottom: 0 !important;
    }

    .verify-form-card .login-submit {
        margin: 0.25rem 0 0 !important;
        min-height: 52px !important;
    }

    /* ── Action buttons ── */
    .verify-alt-actions {
        display: flex;
        flex-direction: column;
        gap: 0.6rem;
    }

    .verify-alt-btn {
        display: flex;
        align-items: center;
        gap: 0.75rem;
        padding: 0.85rem 1rem;
        border-radius: 18px;
        background: linear-gradient(135deg, rgba(16, 185, 129, 0.25), rgba(5, 150, 105, 0.35));
        border: 1.5px solid rgba(110, 231, 183, 0.32);
        color: #ffffff;
        text-decoration: none;
        transition: all 0.2s ease;
        backdrop-filter: blur(8px);
    }

    .verify-alt-btn:hover {
        background: linear-gradient(135deg, rgba(16, 185, 129, 0.35), rgba(5, 150, 105, 0.45));
        transform: translateY(-1px);
        color: #ffffff;
        text-decoration: none;
    }

    .verify-alt-icon {
        width: 40px;
        height: 40px;
        flex: 0 0 auto;
        display: grid;
        place-items: center;
        border-radius: 13px;
        background: rgba(255, 255, 255, 0.18);
        border: 1px solid rgba(255, 255, 255, 0.22);
        font-size: 1.05rem;
        color: #ffffff;
    }

    .verify-alt-text {
        flex: 1;
        min-width: 0;
    }

    .verify-alt-text strong {
        display: block;
        font-size: 0.88rem;
        font-weight: 900;
        color: #ffffff;
        line-height: 1.2;
    }

    .verify-alt-text span {
        display: block;
        font-size: 0.75rem;
        color: rgba(209, 250, 229, 0.85);
        font-weight: 600;
        line-height: 1.35;
        margin-top: 0.1rem;
    }

    .verify-alt-arrow {
        flex: 0 0 auto;
        font-size: 0.8rem;
        color: rgba(167, 243, 208, 0.7);
    }
}

/* ==============================
   DISTRIBUTOR SIGNUP REDESIGN
   ============================== */
.dsignup-section {
    min-height: 100vh;
    padding: clamp(2rem, 5vw, 4rem) 0 clamp(3rem, 6vw, 5rem);
    background:
        radial-gradient(ellipse at 15% 0%, rgba(16, 185, 129, 0.12), transparent 45%),
        radial-gradient(ellipse at 85% 20%, rgba(14, 165, 233, 0.07), transparent 40%),
        radial-gradient(ellipse at 50% 100%, rgba(167, 243, 208, 0.1), transparent 50%),
        linear-gradient(180deg, #f0fdf8 0%, #f8fafc 40%, #ecfdf5 100%);
}

.dsignup-hero {
    position: relative;
    overflow: hidden;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    gap: clamp(1.25rem, 4vw, 3rem);
    text-align: left;
    padding: clamp(2rem, 5vw, 3.5rem) clamp(1.5rem, 4vw, 3rem);
    margin-bottom: 1.5rem;
    border-radius: 32px;
    background:
        radial-gradient(circle at 88% 8%, rgba(167, 243, 208, 0.42), transparent 34%),
        linear-gradient(135deg, rgba(255, 255, 255, 0.94), rgba(236, 253, 245, 0.78));
    border: 1px solid rgba(16, 185, 129, 0.3);
    box-shadow:
        0 30px 72px rgba(6, 95, 70, 0.12),
        0 12px 24px rgba(6, 95, 70, 0.06),
        inset 0 1px 0 rgba(255, 255, 255, 0.94);
}

.dsignup-hero-copy {
    position: relative;
    z-index: 1;
    max-width: 780px;
}

.dsignup-hero-glow {
    position: absolute;
    top: -40%;
    right: -15%;
    width: 55%;
    aspect-ratio: 1;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(52, 211, 153, 0.3), transparent 65%);
    pointer-events: none;
}

.dsignup-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.4rem 0.85rem;
    border-radius: 999px;
    color: #065f46;
    background: rgba(209, 250, 229, 0.72);
    border: 1px solid rgba(16, 185, 129, 0.24);
    font-size: 0.72rem;
    font-weight: 900;
    letter-spacing: 0.07em;
    text-transform: uppercase;
    backdrop-filter: blur(8px);
}

.dsignup-hero h1 {
    margin: 1rem 0 0.65rem;
    color: #111827;
    font-size: clamp(2.6rem, 5.4vw, 4.35rem);
    font-weight: 900;
    line-height: 1.02;
    letter-spacing: -0.045em;
}

.dsignup-hero h1 span {
    background: linear-gradient(135deg, #047857, #10b981);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.dsignup-hero p {
    margin: 0;
    max-width: 760px;
    color: #64748b;
    font-size: 1.05rem;
    line-height: 1.65;
    font-weight: 500;
}

.dsignup-login-link {
    position: relative;
    z-index: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.8rem;
    min-width: 190px;
    min-height: 78px;
    padding: 0.9rem 1.15rem;
    border-radius: 999px;
    color: #064e3b;
    background:
        linear-gradient(145deg, rgba(255, 255, 255, 0.96), rgba(240, 253, 244, 0.86));
    border: 1px solid rgba(5, 150, 105, 0.16);
    text-decoration: none;
    backdrop-filter: blur(8px);
    box-shadow:
        0 18px 42px rgba(6, 95, 70, 0.1),
        inset 0 1px 0 rgba(255, 255, 255, 0.95);
    transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
}

.dsignup-login-link:hover {
    transform: translateY(-3px);
    border-color: rgba(5, 150, 105, 0.3);
    color: #064e3b;
    box-shadow:
        0 24px 54px rgba(6, 95, 70, 0.16),
        inset 0 1px 0 rgba(255, 255, 255, 0.95);
}

.dsignup-login-icon {
    width: 40px;
    height: 40px;
    display: inline-grid;
    place-items: center;
    flex: 0 0 auto;
    border-radius: 50%;
    color: #ffffff;
    background: linear-gradient(135deg, #10b981, #047857);
    box-shadow: 0 12px 24px rgba(5, 150, 105, 0.2);
}

.dsignup-login-link small,
.dsignup-login-link strong {
    display: block;
    line-height: 1.12;
}

.dsignup-login-link small {
    margin-bottom: 0.18rem;
    color: #64748b;
    font-size: 0.72rem;
    font-weight: 800;
}

.dsignup-login-link strong {
    font-weight: 900;
    color: #064e3b;
    font-size: 0.98rem;
}

.dsignup-steps {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.35rem;
    margin-bottom: 1.5rem;
    padding: 0.6rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.82);
    border: 1px solid rgba(16, 185, 129, 0.12);
    box-shadow: 0 8px 24px rgba(6, 95, 70, 0.06);
    position: sticky;
    top: 80px;
    z-index: 20;
    backdrop-filter: blur(16px);
}

.dsignup-step {
    display: flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.45rem 0.75rem;
    border-radius: 999px;
    font-size: 0.72rem;
    font-weight: 800;
    color: #94a3b8;
    letter-spacing: 0.02em;
    text-transform: uppercase;
    transition: all 0.35s ease;
    white-space: nowrap;
}

.dsignup-step span {
    display: grid;
    place-items: center;
    width: 22px;
    height: 22px;
    border-radius: 50%;
    font-size: 0.68rem;
    font-weight: 900;
    color: #94a3b8;
    background: #f1f5f9;
    transition: all 0.35s ease;
}

.dsignup-step.active {
    color: #065f46;
}

.dsignup-step.active span {
    color: #ffffff;
    background: linear-gradient(135deg, #10b981, #059669);
    box-shadow: 0 4px 12px rgba(16, 185, 129, 0.3);
}

.dsignup-form {
    display: grid;
    gap: 1.1rem;
}

.dsignup-card {
    border-radius: 28px;
    background: rgba(255, 255, 255, 0.88);
    border: 1px solid rgba(167, 243, 208, 0.55);
    box-shadow:
        0 20px 56px rgba(6, 95, 70, 0.08),
        0 6px 16px rgba(6, 95, 70, 0.04);
    backdrop-filter: blur(12px);
    overflow: hidden;
    transition: box-shadow 0.3s ease, border-color 0.3s ease, transform 0.3s ease;
}

.dsignup-card:focus-within {
    border-color: rgba(16, 185, 129, 0.35);
    box-shadow:
        0 24px 64px rgba(6, 95, 70, 0.12),
        0 0 0 3px rgba(16, 185, 129, 0.08);
}

.dsignup-card-toggle {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    width: 100%;
    padding: 1.15rem 1.35rem;
    border: 0;
    background: transparent;
    cursor: pointer;
    text-align: left;
    transition: background 0.2s ease;
}

.dsignup-card-toggle:not(.collapsed) {
    background:
        linear-gradient(135deg, rgba(236, 253, 245, 0.92), rgba(255, 255, 255, 0.76));
}

.dsignup-card-toggle:hover {
    background: rgba(236, 253, 245, 0.4);
}

.dsignup-card-icon {
    width: 44px;
    height: 44px;
    flex: 0 0 auto;
    display: grid;
    place-items: center;
    border-radius: 16px;
    color: #047857;
    background: linear-gradient(135deg, rgba(209, 250, 229, 0.9), rgba(167, 243, 208, 0.5));
    font-size: 1.15rem;
    box-shadow: 0 6px 16px rgba(16, 185, 129, 0.12);
}

.dsignup-toggle-text {
    flex: 1;
    min-width: 0;
}

.dsignup-toggle-text h3 {
    margin: 0;
    font-size: 1.05rem;
    font-weight: 900;
    color: #0f172a;
    letter-spacing: -0.01em;
}

.dsignup-toggle-text p {
    margin: 0.1rem 0 0;
    font-size: 0.8rem;
    color: #64748b;
    font-weight: 600;
}

.dsignup-chevron {
    flex: 0 0 auto;
    font-size: 1.1rem;
    color: #94a3b8;
    transition: transform 0.35s cubic-bezier(0.4, 0, 0.2, 1);
}

.dsignup-card-toggle:not(.collapsed) .dsignup-chevron {
    transform: rotate(180deg);
    color: #059669;
}

.dsignup-card-body {
    padding: 1.25rem 1.35rem 1.35rem;
}

.dsignup-card-body .field-wrap label,
.dsignup-card-body .form-label {
    margin-bottom: 0.4rem;
    color: #334155;
    font-weight: 850;
    font-size: 0.85rem;
}

.dsignup-card-body .form-control,
.dsignup-card-body .form-select {
    min-height: 50px;
    border-radius: 16px;
    border: 1.5px solid rgba(16, 185, 129, 0.16);
    background: rgba(255, 255, 255, 0.95);
    box-shadow: 0 4px 12px rgba(6, 95, 70, 0.03);
    font-size: 0.92rem;
    transition: all 0.2s ease;
}

.dsignup-card-body .form-control:focus,
.dsignup-card-body .form-select:focus {
    border-color: #10b981;
    box-shadow: 0 0 0 4px rgba(16, 185, 129, 0.1), 0 4px 12px rgba(6, 95, 70, 0.06);
}

.dsignup-submit {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.65rem;
    width: 100%;
    min-height: 60px;
    border: 0;
    border-radius: 20px;
    color: #ffffff;
    background: linear-gradient(135deg, #059669, #047857, #065f46);
    box-shadow:
        0 20px 48px rgba(6, 95, 70, 0.24),
        0 8px 18px rgba(6, 95, 70, 0.1),
        inset 0 1px 0 rgba(255, 255, 255, 0.15);
    font-size: 1.05rem;
    font-weight: 900;
    letter-spacing: 0.01em;
    cursor: pointer;
    transition: all 0.3s ease;
}

.dsignup-submit:hover {
    transform: translateY(-2px);
    box-shadow:
        0 24px 56px rgba(6, 95, 70, 0.28),
        0 10px 22px rgba(6, 95, 70, 0.12),
        inset 0 1px 0 rgba(255, 255, 255, 0.15);
}

.dsignup-submit:active {
    transform: translateY(0);
}

.dsignup-submit i {
    font-size: 1.1rem;
    transition: transform 0.3s ease;
}

.dsignup-submit:hover i {
    transform: translateX(3px);
}

.dsignup-card .document-check-grid {
    margin-bottom: 0.75rem;
}

.dsignup-card .document-final-grid {
    margin-top: 0.75rem;
}

@media (max-width: 991.98px) {
    .dsignup-hero {
        grid-template-columns: 1fr;
    }

    .dsignup-login-link {
        justify-self: start;
    }

    .dsignup-steps {
        top: 72px;
        gap: 0.15rem;
        padding: 0.45rem;
    }

    .dsignup-step {
        padding: 0.4rem 0.5rem;
        font-size: 0.62rem;
    }

    .dsignup-step span {
        width: 20px;
        height: 20px;
        font-size: 0.62rem;
    }
}

@media (max-width: 575.98px) {
    .dsignup-section {
        padding: 1.1rem 0 2.5rem;
    }

    .dsignup-hero {
        gap: 1.25rem;
        padding: 1.35rem 1.15rem 1.2rem;
        border-radius: 28px;
        margin-bottom: 1.05rem;
        background:
            radial-gradient(circle at 88% 8%, rgba(16, 185, 129, 0.32), transparent 34%),
            radial-gradient(circle at 12% 100%, rgba(14, 165, 233, 0.08), transparent 42%),
            linear-gradient(145deg, rgba(255, 255, 255, 0.98), rgba(220, 252, 231, 0.86));
        box-shadow:
            0 20px 48px rgba(6, 95, 70, 0.12),
            inset 0 1px 0 rgba(255, 255, 255, 0.96);
    }

    .dsignup-badge {
        padding: 0.38rem 0.72rem;
        font-size: 0.62rem;
        letter-spacing: 0.065em;
    }

    .dsignup-hero h1 {
        margin-top: 0.85rem;
        max-width: 16rem;
        font-size: clamp(1.65rem, 8.4vw, 2.15rem);
        line-height: 1.06;
        letter-spacing: -0.035em;
    }

    .dsignup-hero h1 span {
        display: inline;
    }

    .dsignup-hero p {
        max-width: 17.5rem;
        font-size: 0.92rem;
        line-height: 1.55;
    }

    .dsignup-login-link {
        width: 100%;
        min-height: 54px;
        gap: 0.55rem;
        padding: 0.7rem 1rem;
        border-radius: 999px;
    }

    .dsignup-login-link small {
        display: none;
    }

    .dsignup-login-link strong {
        font-size: 0.9rem;
    }

    .dsignup-login-icon {
        width: 30px;
        height: 30px;
        background: transparent;
        color: #047857;
        box-shadow: none;
    }

    .dsignup-steps {
        position: sticky;
        top: 70px;
        z-index: 24;
        display: grid;
        grid-template-columns: repeat(4, minmax(0, 1fr));
        gap: 0.35rem;
        padding: 0.45rem;
        margin: 0 0 1rem;
        border-radius: 20px;
        background:
            linear-gradient(145deg, rgba(255, 255, 255, 0.96), rgba(236, 253, 245, 0.88));
        border: 1px solid rgba(16, 185, 129, 0.18);
        box-shadow:
            0 14px 30px rgba(6, 95, 70, 0.08),
            inset 0 1px 0 rgba(255, 255, 255, 0.94);
        backdrop-filter: blur(16px) saturate(150%);
        -webkit-backdrop-filter: blur(16px) saturate(150%);
    }

    .dsignup-step {
        justify-content: center;
        gap: 0.28rem;
        min-height: 38px;
        padding: 0.34rem 0.22rem;
        border-radius: 15px;
        color: #64748b;
        background: rgba(255, 255, 255, 0.58);
        font-size: 0.52rem;
        line-height: 1.05;
        text-align: center;
        white-space: normal;
    }

    .dsignup-step span {
        width: 20px;
        height: 20px;
        font-size: 0.62rem;
        box-shadow: none;
    }

    .dsignup-step.active {
        color: #ffffff;
        background: linear-gradient(135deg, #065f46, #10b981);
        box-shadow: 0 10px 20px rgba(5, 150, 105, 0.18);
    }

    .dsignup-step.active span {
        color: #065f46;
        background: rgba(255, 255, 255, 0.92);
    }

    .dsignup-card {
        border-radius: 24px;
        background:
            radial-gradient(circle at 100% 0%, rgba(167, 243, 208, 0.25), transparent 36%),
            rgba(255, 255, 255, 0.88);
    }

    .dsignup-card-toggle {
        padding: 0.9rem 0.95rem;
        align-items: center;
    }

    .dsignup-card-icon {
        width: 42px;
        height: 42px;
        border-radius: 14px;
        font-size: 1rem;
    }

    .dsignup-toggle-text h3 {
        font-size: 0.94rem;
    }

    .dsignup-toggle-text p {
        display: none;
    }

    .dsignup-card-toggle.collapsed {
        color: #ffffff;
        background: linear-gradient(135deg, #065f46, #059669 55%, #10b981);
    }

    .dsignup-card-toggle.collapsed .dsignup-card-icon {
        color: #064e3b;
        background: rgba(236, 253, 245, 0.92);
        box-shadow: none;
    }

    .dsignup-card-toggle.collapsed .dsignup-toggle-text h3,
    .dsignup-card-toggle.collapsed .dsignup-chevron {
        color: #ffffff;
    }

    .dsignup-card-toggle:not(.collapsed) {
        background:
            linear-gradient(135deg, rgba(255, 255, 255, 0.98), rgba(236, 253, 245, 0.88));
        border-bottom: 1px solid rgba(16, 185, 129, 0.13);
    }

    .dsignup-card-body {
        padding: 1rem 0.9rem 1.05rem;
    }

    .dsignup-card-body .form-control,
    .dsignup-card-body .form-select {
        min-height: 48px;
        border-radius: 14px;
    }

    .dsignup-card .stockist-row,
    .dsignup-card .document-check-grid,
    .dsignup-card .document-final-grid {
        grid-template-columns: 1fr;
    }

    .dsignup-card .stockist-builder-head {
        display: grid;
        gap: 0.75rem;
    }

    .dsignup-card .stockist-add-btn {
        width: 100%;
    }

    .dsignup-card .stockist-record {
        padding: 0.78rem;
        border-radius: 20px;
    }

    .dsignup-card .stockist-record-header {
        align-items: flex-start;
    }

    .dsignup-submit {
        min-height: 56px;
        border-radius: 16px;
        font-size: 0.98rem;
    }
}

/* ==============================
   NEW MEMBERSHIP SIGNUP REDESIGN
   ============================== */
.nms-section {
    min-height: 100vh;
    padding: clamp(2rem, 5vw, 4rem) 0 clamp(3rem, 6vw, 5rem);
    background:
        radial-gradient(ellipse at 15% 0%, rgba(16, 185, 129, 0.12), transparent 45%),
        radial-gradient(ellipse at 85% 20%, rgba(14, 165, 233, 0.07), transparent 40%),
        radial-gradient(ellipse at 50% 100%, rgba(167, 243, 208, 0.1), transparent 50%),
        linear-gradient(180deg, #f0fdf8 0%, #f8fafc 40%, #ecfdf5 100%);
}

.nms-hero {
    position: relative;
    overflow: hidden;
    text-align: center;
    padding: clamp(2rem, 5vw, 3.5rem) clamp(1.5rem, 4vw, 3rem);
    margin-bottom: 1.5rem;
    border-radius: 32px;
    background:
        linear-gradient(135deg, #065f46 0%, #047857 35%, #059669 70%, #10b981 100%);
    box-shadow:
        0 32px 72px rgba(6, 95, 70, 0.22),
        0 12px 24px rgba(6, 95, 70, 0.1),
        inset 0 1px 0 rgba(255, 255, 255, 0.12);
}

.nms-hero-glow {
    position: absolute;
    top: -40%;
    right: -15%;
    width: 55%;
    aspect-ratio: 1;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(52, 211, 153, 0.3), transparent 65%);
    pointer-events: none;
}

.nms-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.4rem 0.85rem;
    border-radius: 999px;
    color: rgba(255, 255, 255, 0.95);
    background: rgba(255, 255, 255, 0.12);
    border: 1px solid rgba(255, 255, 255, 0.18);
    font-size: 0.72rem;
    font-weight: 900;
    letter-spacing: 0.07em;
    text-transform: uppercase;
    backdrop-filter: blur(8px);
}

.nms-hero h1 {
    margin: 1rem 0 0.65rem;
    color: #ffffff;
    font-size: clamp(1.55rem, 5vw, 2.8rem);
    font-weight: 900;
    line-height: 1.1;
    letter-spacing: -0.02em;
}

.nms-hero h1 span {
    background: linear-gradient(135deg, #a7f3d0, #6ee7b7);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.nms-hero p {
    margin: 0 auto 1.1rem;
    max-width: 420px;
    color: rgba(255, 255, 255, 0.72);
    font-size: 0.92rem;
    line-height: 1.55;
    font-weight: 500;
}

.nms-alt-link {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.6rem 1.2rem;
    border-radius: 999px;
    color: #ffffff;
    background: rgba(255, 255, 255, 0.1);
    border: 1px solid rgba(255, 255, 255, 0.2);
    font-size: 0.85rem;
    font-weight: 600;
    text-decoration: none;
    backdrop-filter: blur(8px);
    transition: all 0.25s ease;
}

.nms-alt-link:hover {
    background: rgba(255, 255, 255, 0.2);
    color: #ffffff;
}

.nms-alt-link strong {
    font-weight: 900;
    text-decoration: underline;
    text-underline-offset: 2px;
}

.nms-form {
    display: grid;
    gap: 1.1rem;
}

.nms-card {
    border-radius: 28px;
    background: rgba(255, 255, 255, 0.88);
    border: 1px solid rgba(167, 243, 208, 0.55);
    box-shadow:
        0 20px 56px rgba(6, 95, 70, 0.08),
        0 6px 16px rgba(6, 95, 70, 0.04);
    backdrop-filter: blur(12px);
    overflow: hidden;
    transition: box-shadow 0.3s ease, border-color 0.3s ease;
}

.nms-card:focus-within {
    border-color: rgba(16, 185, 129, 0.35);
    box-shadow:
        0 24px 64px rgba(6, 95, 70, 0.12),
        0 0 0 3px rgba(16, 185, 129, 0.08);
}

.nms-card-toggle {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    width: 100%;
    padding: 1.15rem 1.35rem;
    border: 0;
    background: transparent;
    cursor: pointer;
    text-align: left;
    transition: background 0.2s ease;
}

.nms-card-toggle:hover {
    background: rgba(236, 253, 245, 0.4);
}

.nms-card-icon {
    width: 44px;
    height: 44px;
    flex: 0 0 auto;
    display: grid;
    place-items: center;
    border-radius: 16px;
    color: #047857;
    background: linear-gradient(135deg, rgba(209, 250, 229, 0.9), rgba(167, 243, 208, 0.5));
    font-size: 1.15rem;
    box-shadow: 0 6px 16px rgba(16, 185, 129, 0.12);
}

.nms-toggle-text {
    flex: 1;
    min-width: 0;
}

.nms-toggle-text h3 {
    margin: 0;
    font-size: 1.05rem;
    font-weight: 900;
    color: #0f172a;
    letter-spacing: -0.01em;
}

.nms-toggle-text p {
    margin: 0.1rem 0 0;
    font-size: 0.8rem;
    color: #64748b;
    font-weight: 600;
}

.nms-chevron {
    flex: 0 0 auto;
    font-size: 1.1rem;
    color: #94a3b8;
    transition: transform 0.35s cubic-bezier(0.4, 0, 0.2, 1);
}

.nms-card-toggle:not(.collapsed) .nms-chevron {
    transform: rotate(180deg);
    color: #059669;
}

.nms-card-body {
    padding: 1.25rem 1.35rem 1.35rem;
}

.nms-card-body .form-label {
    margin-bottom: 0.4rem;
    color: #334155;
    font-weight: 850;
    font-size: 0.85rem;
}

.nms-card-body .form-control,
.nms-card-body .form-select {
    min-height: 50px;
    border-radius: 16px;
    border: 1.5px solid rgba(16, 185, 129, 0.16);
    background: rgba(255, 255, 255, 0.95);
    box-shadow: 0 4px 12px rgba(6, 95, 70, 0.03);
    font-size: 0.92rem;
    transition: all 0.2s ease;
}

.nms-card-body .form-control:focus,
.nms-card-body .form-select:focus {
    border-color: #10b981;
    box-shadow: 0 0 0 4px rgba(16, 185, 129, 0.1), 0 4px 12px rgba(6, 95, 70, 0.06);
}

.nms-card-body .pc-entry {
    padding: 1rem;
    border-radius: 18px;
    background: rgba(248, 255, 253, 0.7);
    border: 1px solid rgba(16, 185, 129, 0.1);
    margin-bottom: 0.75rem;
}

.nms-card-body .payment-qr-grid {
    display: grid;
    grid-template-columns: 0.75fr 1.25fr;
    gap: 1rem;
}

.nms-card-body .payment-qr-card,
.nms-card-body .payment-help-card {
    padding: 1.15rem;
    border-radius: 18px;
    background: rgba(248, 255, 253, 0.7);
    border: 1px solid rgba(16, 185, 129, 0.12);
}

.nms-undertaking-wrap {
    margin-top: 1.25rem;
    padding-top: 1.25rem;
    border-top: 1px solid rgba(16, 185, 129, 0.15);
}

.nms-submit {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.65rem;
    width: 100%;
    min-height: 60px;
    border: 0;
    border-radius: 20px;
    color: #ffffff;
    background: linear-gradient(135deg, #059669, #047857, #065f46);
    box-shadow:
        0 20px 48px rgba(6, 95, 70, 0.24),
        0 8px 18px rgba(6, 95, 70, 0.1),
        inset 0 1px 0 rgba(255, 255, 255, 0.15);
    font-size: 1.05rem;
    font-weight: 900;
    letter-spacing: 0.01em;
    cursor: pointer;
    transition: all 0.3s ease;
}

.nms-submit:hover {
    transform: translateY(-2px);
    box-shadow:
        0 24px 56px rgba(6, 95, 70, 0.28),
        0 10px 22px rgba(6, 95, 70, 0.12),
        inset 0 1px 0 rgba(255, 255, 255, 0.15);
}

.nms-submit:active {
    transform: translateY(0);
}

.nms-submit i {
    font-size: 1.1rem;
    transition: transform 0.3s ease;
}

.nms-submit:hover i {
    transform: translateX(3px);
}

@media (max-width: 575.98px) {
    .nms-section {
        padding: 1.25rem 0 2.5rem;
    }

    .nms-hero {
        padding: 1.8rem 1.25rem;
        border-radius: 24px;
        margin-bottom: 1rem;
    }

    .nms-hero h1 {
        font-size: 1.45rem;
    }

    .nms-hero p {
        font-size: 0.84rem;
    }

    .nms-card {
        border-radius: 22px;
    }

    .nms-card-toggle {
        padding: 1rem;
    }

    .nms-card-icon {
        width: 38px;
        height: 38px;
        border-radius: 13px;
        font-size: 1rem;
    }

    .nms-toggle-text h3 {
        font-size: 0.95rem;
    }

    .nms-toggle-text p {
        font-size: 0.72rem;
    }

    .nms-card-body {
        padding: 1rem;
    }

    .nms-card-body .form-control,
    .nms-card-body .form-select {
        min-height: 48px;
        border-radius: 14px;
    }

    .nms-card-body .payment-qr-grid {
        grid-template-columns: 1fr;
    }

    .nms-submit {
        min-height: 56px;
        border-radius: 16px;
        font-size: 0.98rem;
    }
}

/* ==============================
   LOGIN PAGE — MOBILE REDESIGN
   ============================== */
.login-mobile-wrap {
    display: none;
}

@media (max-width: 575.98px) {
    section.login-page {
        min-height: calc(100dvh - 56px) !important;
        padding: 0 !important;
        display: flex !important;
        flex-direction: column !important;
        justify-content: center !important;
        background:
            radial-gradient(circle at 10% 15%, rgba(52, 211, 153, 0.22), transparent 40%),
            radial-gradient(circle at 90% 80%, rgba(6, 78, 59, 0.6), transparent 50%),
            linear-gradient(160deg, #064e3b 0%, #065f46 55%, #047857 100%) !important;
    }

    section.login-page .container {
        padding: 1.75rem 1.25rem 2.5rem !important;
    }

    .login-mobile-wrap {
        display: flex !important;
        flex-direction: column;
        gap: 1.25rem;
    }

    section.login-page .login-desktop-shell {
        display: none !important;
    }

    /* ── Brand section ── */
    .login-mob-brand {
        display: flex;
        flex-direction: column;
        align-items: flex-start;
        gap: 0.35rem;
    }

    .login-mob-brand-icon {
        width: 44px;
        height: 44px;
        display: grid;
        place-items: center;
        border-radius: 14px;
        background: rgba(255, 255, 255, 0.15);
        border: 1.5px solid rgba(255, 255, 255, 0.28);
        color: #ffffff;
        font-size: 1.15rem;
        margin-bottom: 0.35rem;
    }

    .login-mob-brand .login-kicker {
        background: rgba(110, 231, 183, 0.18) !important;
        border: 1.5px solid rgba(110, 231, 183, 0.42) !important;
        color: #6ee7b7 !important;
        margin: 0 !important;
        font-size: 0.68rem !important;
    }

    .login-mob-brand h1 {
        color: #ffffff;
        font-size: 1.65rem;
        font-weight: 900;
        line-height: 1.12;
        letter-spacing: -0.02em;
        margin: 0.25rem 0 0;
        text-shadow: 0 2px 10px rgba(0, 0, 0, 0.18);
    }

    .login-mob-brand p {
        color: rgba(209, 250, 229, 0.82);
        font-size: 0.84rem;
        line-height: 1.5;
        margin: 0.25rem 0 0;
    }

    /* ── Form card ── */
    .login-mob-card {
        background: rgba(255, 255, 255, 0.94);
        backdrop-filter: blur(24px) saturate(160%);
        -webkit-backdrop-filter: blur(24px) saturate(160%);
        border-radius: 28px;
        padding: 1.5rem 1.35rem;
        box-shadow: 0 24px 60px rgba(0, 0, 0, 0.22), 0 1px 0 rgba(255,255,255,0.8) inset;
        border: 1px solid rgba(255, 255, 255, 0.55);
        display: flex;
        flex-direction: column;
        gap: 1rem;
    }

    .login-mob-card-header {
        padding-bottom: 0.85rem;
        border-bottom: 1px solid rgba(16, 185, 129, 0.1);
    }

    .login-mob-card-header h2 {
        margin: 0 0 0.2rem;
        font-size: 1.35rem;
        font-weight: 900;
        color: #0f172a;
        letter-spacing: -0.02em;
    }

    .login-mob-card-header p {
        margin: 0;
        font-size: 0.82rem;
        color: #64748b;
        font-weight: 600;
    }

    .login-mob-card .login-field {
        margin-bottom: 0 !important;
    }

    .login-mob-card .form-label {
        display: flex !important;
        align-items: center !important;
        gap: 0.4rem !important;
        margin-bottom: 0.45rem !important;
        color: #334155 !important;
        font-size: 0.82rem !important;
        font-weight: 850 !important;
    }

    .login-mob-card .form-label i {
        color: #10b981;
    }

    .login-mob-card .form-control {
        width: 100% !important;
        min-height: 52px !important;
        padding: 0.78rem 0.9rem !important;
        border-radius: 18px !important;
        font-size: 0.95rem !important;
        background: rgba(255, 255, 255, 0.94) !important;
        border: 1px solid rgba(16, 185, 129, 0.16) !important;
        box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.94), 0 10px 24px rgba(6, 95, 70, 0.05) !important;
    }

    .login-mob-card .form-control:focus {
        border-color: rgba(16, 185, 129, 0.72) !important;
        box-shadow: 0 0 0 4px rgba(16, 185, 129, 0.12), 0 12px 28px rgba(6, 95, 70, 0.08) !important;
    }

    .login-mob-forgot {
        text-align: right;
        margin: -0.25rem 0 0.5rem;
    }

    .login-mob-forgot a {
        font-size: 0.8rem;
        font-weight: 700;
        color: #047857;
        text-decoration: none;
        display: inline-flex;
        align-items: center;
        gap: 0.3rem;
    }

    .login-mob-forgot a i {
        font-size: 0.72rem;
    }

    .login-mob-card .login-submit {
        margin: 0.25rem 0 0 !important;
        min-height: 52px !important;
        border-radius: 18px !important;
        font-size: 1rem !important;
        font-weight: 900 !important;
        background: linear-gradient(135deg, #10b981, #047857) !important;
        box-shadow: 0 12px 28px rgba(6, 95, 70, 0.35) !important;
    }

    /* ── Action buttons ── */
    .login-mob-actions {
        display: flex;
        flex-direction: column;
        gap: 0.6rem;
    }

    .login-mob-action {
        display: flex;
        align-items: center;
        gap: 0.75rem;
        padding: 0.85rem 1rem;
        border-radius: 18px;
        background: linear-gradient(135deg, rgba(16, 185, 129, 0.25), rgba(5, 150, 105, 0.35));
        border: 1.5px solid rgba(110, 231, 183, 0.32);
        color: #ffffff;
        text-decoration: none;
        transition: all 0.2s ease;
        backdrop-filter: blur(8px);
    }

    .login-mob-action:hover {
        background: linear-gradient(135deg, rgba(16, 185, 129, 0.35), rgba(5, 150, 105, 0.45));
        transform: translateY(-1px);
        color: #ffffff;
        text-decoration: none;
    }

    .login-mob-action-icon {
        width: 40px;
        height: 40px;
        flex: 0 0 auto;
        display: grid;
        place-items: center;
        border-radius: 13px;
        background: rgba(255, 255, 255, 0.18);
        border: 1px solid rgba(255, 255, 255, 0.22);
        font-size: 1.05rem;
        color: #ffffff;
    }

    .login-mob-action-text {
        flex: 1;
        min-width: 0;
    }

    .login-mob-action-text strong {
        display: block;
        font-size: 0.88rem;
        font-weight: 900;
        color: #ffffff;
        line-height: 1.2;
    }

    .login-mob-action-text span {
        display: block;
        font-size: 0.75rem;
        color: rgba(209, 250, 229, 0.85);
        font-weight: 600;
        line-height: 1.35;
        margin-top: 0.1rem;
    }

    .login-mob-action-arrow {
        flex: 0 0 auto;
        font-size: 0.8rem;
        color: rgba(167, 243, 208, 0.7);
    }
}

/* ==============================
   ADMIN PANEL — MOBILE REDESIGN
   ============================== */
@media (max-width: 575.98px) {

    /* ── Premium stats row ── */
    .admin-stats-row {
        grid-template-columns: 1fr 1fr !important;
        gap: 0.6rem !important;
        margin-bottom: 1.25rem !important;
    }

    .admin-stat {
        padding: 0.85rem 0.75rem !important;
        border-radius: 18px !important;
        border-left: none !important;
        border-top: 3px solid var(--primary) !important;
        background: rgba(255, 255, 255, 0.92) !important;
        backdrop-filter: blur(12px) !important;
        position: relative;
        overflow: hidden;
    }

    .admin-stat::after {
        content: '';
        position: absolute;
        top: 0;
        right: 0;
        width: 40px;
        height: 40px;
        border-radius: 0 0 0 50%;
        opacity: 0.08;
        background: currentColor;
    }

    .admin-stat.success { border-top-color: #22c55e !important; color: #22c55e; }
    .admin-stat.warning { border-top-color: #f59e0b !important; color: #f59e0b; }
    .admin-stat.danger { border-top-color: #ef4444 !important; color: #ef4444; }

    .admin-stat-number {
        font-size: 1.55rem !important;
        margin-bottom: 0.15rem !important;
    }

    .admin-stat-label {
        font-size: 0.65rem !important;
        letter-spacing: 0.05em !important;
    }

    /* ── Collapsible designation — compact on mobile ── */
    .designation-rank-card {
        border-radius: 22px !important;
        margin-bottom: 1rem !important;
    }

    .desig-summary {
        padding: 0.9rem 1rem !important;
        gap: 0.6rem !important;
    }

    .desig-summary-icon {
        width: 34px;
        height: 34px;
        border-radius: 10px;
        font-size: 0.95rem;
    }

    .desig-summary-title {
        font-size: 0.88rem;
    }

    .desig-summary-sub {
        font-size: 0.7rem;
    }

    .desig-pill {
        font-size: 0.65rem;
        padding: 0.25rem 0.55rem;
    }

    .designation-rank-strip {
        grid-template-columns: 1fr !important;
        gap: 0 !important;
        padding: 0 !important;
        max-height: 320px;
        overflow-y: auto;
        -webkit-overflow-scrolling: touch;
    }

    .designation-rank-chip {
        display: flex !important;
        align-items: center;
        gap: 0.65rem;
        min-height: auto !important;
        padding: 0.7rem 1rem !important;
        border-radius: 0 !important;
        border: none !important;
        border-bottom: 1px solid rgba(16, 185, 129, 0.08) !important;
        background: transparent !important;
        box-shadow: none !important;
    }

    .designation-rank-chip:last-child {
        border-bottom: none !important;
    }

    .designation-rank-chip .rank-number {
        width: 1.65rem;
        height: 1.65rem;
        font-size: 0.7rem;
        flex: 0 0 auto;
    }

    .designation-rank-chip .rank-title {
        flex: 1;
        font-size: 0.84rem;
        font-weight: 800;
    }

    .designation-rank-chip .rank-count {
        flex: 0 0 auto;
        font-size: 0.72rem;
        font-weight: 800;
        color: #059669;
        background: rgba(16, 185, 129, 0.1);
        padding: 0.2rem 0.55rem;
        border-radius: 999px;
    }

    /* ── Distributor catalog link card ── */
    .admin-distributor-link-card {
        border-radius: 22px !important;
        padding: 1rem !important;
    }

    .admin-distributor-link-copy h3 {
        font-size: 0.92rem !important;
    }

    .admin-distributor-link-copy p {
        font-size: 0.78rem !important;
    }

    .admin-distributor-hero {
        flex-direction: column;
        align-items: stretch;
        border-radius: 22px !important;
        padding: 1.1rem 1rem !important;
        gap: 0.7rem !important;
    }

    .admin-distributor-hero .admin-distributor-kicker {
        font-size: 0.66rem !important;
        padding: 0.32rem 0.7rem !important;
        align-self: flex-start;
    }

    .admin-distributor-hero h1 {
        font-size: 1.35rem !important;
        line-height: 1.18 !important;
        margin: 0.45rem 0 0.3rem !important;
    }

    .admin-distributor-hero p {
        font-size: 0.82rem !important;
        line-height: 1.45 !important;
    }

    .admin-distributor-back {
        align-self: flex-start !important;
        width: auto !important;
        min-height: 38px !important;
        padding: 0.4rem 0.85rem !important;
        border-radius: 999px !important;
        font-size: 0.78rem !important;
        font-weight: 800 !important;
    }

    .admin-distributor-stats {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        gap: 0.55rem !important;
        margin-bottom: 0.85rem !important;
    }

    .admin-distributor-stats div {
        border-radius: 18px !important;
        padding: 0.85rem 0.85rem !important;
    }

    .admin-distributor-stats strong {
        font-size: 1.5rem !important;
        line-height: 1 !important;
    }

    .admin-distributor-stats span {
        font-size: 0.7rem !important;
        margin-top: 0.25rem !important;
        text-transform: uppercase;
        letter-spacing: 0.04em;
    }

    .admin-distributor-filter {
        grid-template-columns: 1fr !important;
        border-radius: 22px !important;
        padding: 0.85rem !important;
    }

    .admin-distributor-search,
    .admin-distributor-zone,
    .admin-distributor-filter .btn {
        width: 100% !important;
        min-height: 46px !important;
        border-radius: 14px !important;
    }

    /* ── Distributor summary card — mobile (≤575.98px) ── */
    .admin-distributor-summary {
        display: grid !important;
        grid-template-columns: 48px minmax(0, 1fr) 36px !important;
        grid-template-areas:
            "avatar main   chevron"
            "contact contact contact"
            "status  status status"
            "count   count  count" !important;
        gap: 0.55rem 0.7rem !important;
        padding: 0.9rem !important;
        background:
            radial-gradient(circle at 100% 0%, rgba(52, 211, 153, 0.18), transparent 36%),
            linear-gradient(135deg, #ffffff 0%, #ecfdf5 100%) !important;
        color: #0f172a !important;
        border-radius: 22px !important;
    }

    .admin-distributor-avatar {
        grid-area: avatar;
        width: 48px !important;
        height: 48px !important;
        border-radius: 14px !important;
        font-size: 1.05rem !important;
        font-weight: 900 !important;
    }

    .admin-distributor-main {
        grid-area: main;
        min-width: 0;
        display: grid !important;
        gap: 0.1rem !important;
        align-content: center !important;
    }

    .admin-distributor-main strong {
        font-size: 0.95rem !important;
        font-weight: 900 !important;
        color: #0f172a !important;
        line-height: 1.25 !important;
        overflow-wrap: anywhere;
    }

    .admin-distributor-main small {
        font-size: 0.72rem !important;
        color: #475569 !important;
        font-weight: 750 !important;
        line-height: 1.35 !important;
    }

    .admin-distributor-contact {
        grid-area: contact;
        display: grid !important;
        grid-template-columns: 1fr !important;
        gap: 0.35rem !important;
        margin-top: 0.45rem !important;
        padding: 0.55rem 0.7rem !important;
        background: rgba(255, 255, 255, 0.7) !important;
        border-radius: 14px !important;
        border: 1px solid rgba(16, 185, 129, 0.16) !important;
    }

    .admin-distributor-contact span {
        display: flex !important;
        align-items: center !important;
        gap: 0.45rem !important;
        font-size: 0.78rem !important;
        font-weight: 700 !important;
        color: #334155 !important;
        line-height: 1.4 !important;
        overflow-wrap: anywhere !important;
        min-width: 0 !important;
    }

    .admin-distributor-contact i {
        color: #059669 !important;
        font-size: 0.85rem !important;
        width: 18px;
        flex-shrink: 0 !important;
    }

    .admin-row-status {
        grid-area: status;
        justify-self: start !important;
        align-self: center !important;
        font-size: 0.72rem !important;
        font-weight: 900 !important;
        padding: 0.4rem 0.85rem !important;
        border-radius: 999px !important;
        display: inline-flex !important;
        align-items: center !important;
        gap: 0.3rem !important;
        text-transform: uppercase !important;
        letter-spacing: 0.04em !important;
    }

    .admin-row-status.is-active {
        background: linear-gradient(135deg, #10b981, #047857) !important;
        color: white !important;
        box-shadow: 0 6px 14px rgba(6, 95, 70, 0.22) !important;
    }

    .admin-row-status.is-inactive {
        background: rgba(226, 232, 240, 0.8) !important;
        color: #475569 !important;
    }

    .admin-distributor-count {
        grid-area: count;
        justify-self: start !important;
        align-self: center !important;
        font-size: 0.76rem !important;
        font-weight: 850 !important;
        color: #047857 !important;
        background: rgba(209, 250, 229, 0.7) !important;
        border: 1px solid rgba(16, 185, 129, 0.22) !important;
        padding: 0.35rem 0.8rem !important;
        border-radius: 999px !important;
    }

    .admin-distributor-chevron {
        grid-area: chevron;
        width: 36px !important;
        height: 36px !important;
        border-radius: 12px !important;
        display: grid !important;
        place-items: center !important;
        background: rgba(16, 185, 129, 0.14) !important;
        color: #047857 !important;
        font-size: 1rem !important;
        transition: transform 220ms ease, background 200ms ease !important;
    }

    .admin-distributor-summary[aria-expanded="true"] .admin-distributor-chevron {
        background: linear-gradient(135deg, #10b981, #047857) !important;
        color: white !important;
        transform: rotate(180deg) !important;
    }

    .admin-distributor-body {
        padding: 0.75rem !important;
        gap: 0.75rem !important;
    }

    .admin-dist-section,
    .admin-company-detail {
        border-radius: 16px !important;
    }

    .admin-dist-section summary,
    .admin-company-detail summary {
        padding: 0.75rem !important;
    }

    .admin-distributor-profile-grid,
    .admin-distributor-license-grid,
    .admin-company-stack,
    .admin-product-grid {
        grid-template-columns: 1fr !important;
        padding: 0 0.7rem 0.7rem !important;
    }

    .admin-distributor-profile-grid .wide {
        grid-column: auto !important;
    }

    /* ── Distributor catalog: simplified per-company summary row (mobile ≤575.98px) ── */
    .admin-company-detail summary {
        display: grid !important;
        grid-template-columns: minmax(0, 1fr) auto auto auto !important;
        gap: 0.4rem !important;
        padding: 0.7rem 0.85rem !important;
        align-items: center !important;
    }

    .admin-company-title strong {
        font-size: 0.94rem !important;
        line-height: 1.2 !important;
        font-weight: 900 !important;
        overflow-wrap: anywhere !important;
    }

    .admin-company-count {
        font-size: 0.72rem !important;
        padding: 0.32rem 0.6rem !important;
        font-weight: 900 !important;
        display: inline-flex !important;
        align-items: center !important;
    }
    .admin-company-count i {
        margin-right: 0.25rem !important;
        font-size: 0.8rem !important;
    }

    .admin-company-state {
        font-size: 0.66rem !important;
        padding: 0.32rem 0.55rem !important;
        letter-spacing: 0.04em !important;
    }

    .admin-company-detail summary > i {
        width: 28px !important;
        height: 28px !important;
        border-radius: 10px !important;
        background: rgba(16, 185, 129, 0.14) !important;
        color: #047857 !important;
        display: grid !important;
        place-items: center !important;
        font-size: 0.85rem !important;
        transition: transform 200ms ease !important;
    }
    .admin-company-detail[open] summary > i {
        transform: rotate(180deg) !important;
    }

    /* ── Inner section headers (License details / Distributor catalog) on mobile ── */
    .admin-dist-section summary {
        display: flex !important;
        align-items: center !important;
        justify-content: space-between !important;
        gap: 0.65rem !important;
        padding: 0.75rem 0.9rem !important;
        font-size: 0.92rem !important;
        font-weight: 900 !important;
    }
    .admin-dist-section summary > span {
        display: flex !important;
        align-items: center !important;
        gap: 0.55rem !important;
        min-width: 0 !important;
    }
    .admin-dist-section summary > span > i {
        width: 32px !important;
        height: 32px !important;
        border-radius: 10px !important;
        background: linear-gradient(135deg, #10b981, #047857) !important;
        color: white !important;
        display: grid !important;
        place-items: center !important;
        font-size: 0.9rem !important;
        flex-shrink: 0 !important;
    }
    .admin-dist-section summary > i {
        width: 30px !important;
        height: 30px !important;
        border-radius: 10px !important;
        display: grid !important;
        place-items: center !important;
        background: rgba(16, 185, 129, 0.14) !important;
        color: #047857 !important;
        font-size: 0.85rem !important;
        transition: transform 200ms ease !important;
    }
    .admin-dist-section[open] summary > i {
        transform: rotate(180deg) !important;
    }

    /* ── License detail mini-cards on mobile ── */
    .license-detail-card {
        padding: 0.85rem !important;
        border-radius: 16px !important;
    }
    .license-detail-card > span {
        font-size: 0.68rem !important;
        letter-spacing: 0.06em !important;
        text-transform: uppercase !important;
        color: #64748b !important;
        font-weight: 850 !important;
        margin-bottom: 0.3rem !important;
        display: block !important;
    }
    .license-detail-card strong {
        font-size: 0.98rem !important;
        line-height: 1.2 !important;
        color: #0f172a !important;
        font-weight: 900 !important;
        overflow-wrap: anywhere !important;
        display: block !important;
        margin-bottom: 0.2rem !important;
    }
    .license-detail-card small {
        font-size: 0.74rem !important;
        color: #475569 !important;
        font-weight: 700 !important;
        display: block !important;
    }
    .license-detail-card em {
        margin-top: 0.5rem !important;
        display: inline-flex !important;
        align-items: center !important;
        padding: 0.32rem 0.7rem !important;
        border-radius: 999px !important;
        font-style: normal !important;
        font-size: 0.7rem !important;
        font-weight: 900 !important;
        text-transform: uppercase !important;
        letter-spacing: 0.04em !important;
    }

    /* ── Product chip (medicine card) on mobile ── */
    .admin-product-chip {
        display: grid !important;
        grid-template-columns: 38px minmax(0, 1fr) auto !important;
        gap: 0.6rem !important;
        padding: 0.75rem !important;
        border-radius: 16px !important;
        align-items: center !important;
    }
    .admin-product-chip > i {
        width: 38px !important;
        height: 38px !important;
        border-radius: 12px !important;
        flex-shrink: 0 !important;
    }
    .admin-product-chip > span {
        min-width: 0 !important;
    }
    .admin-product-chip strong {
        font-size: 0.9rem !important;
        line-height: 1.25 !important;
        overflow-wrap: anywhere !important;
    }
    .admin-product-chip small {
        font-size: 0.7rem !important;
        line-height: 1.35 !important;
    }
    .admin-product-chip em {
        font-size: 0.66rem !important;
        padding: 0.32rem 0.6rem !important;
    }

    /* ── Profile grid (Firm / Proprietor / Member ID etc) on mobile ── */
    .admin-distributor-profile-grid > div {
        padding: 0.75rem 0.9rem !important;
        border-radius: 14px !important;
        background: white !important;
        border: 1px solid rgba(16, 185, 129, 0.1) !important;
        box-shadow: 0 4px 12px rgba(6, 95, 70, 0.04) !important;
    }
    .admin-distributor-profile-grid span {
        font-size: 0.68rem !important;
        text-transform: uppercase !important;
        letter-spacing: 0.06em !important;
        color: #64748b !important;
        font-weight: 850 !important;
        display: block !important;
        margin-bottom: 0.25rem !important;
    }
    .admin-distributor-profile-grid strong {
        font-size: 0.9rem !important;
        color: #0f172a !important;
        font-weight: 850 !important;
        line-height: 1.4 !important;
        overflow-wrap: anywhere !important;
    }

    /* ── Inner card body padding tightening on mobile ── */
    .admin-distributor-body {
        padding: 0.7rem !important;
        gap: 0.7rem !important;
        display: grid !important;
    }

    .admin-distributor-filter,
    .admin-distributor-filter .mobile-filter-select {
        overflow: visible !important;
    }

    .admin-distributor-filter {
        position: relative;
        z-index: 40;
    }

    .admin-distributor-filter .mobile-filter-select {
        z-index: 1;
    }

    .admin-distributor-filter .mobile-filter-select.is-open {
        z-index: 30;
    }

    .admin-distributor-filter .mobile-filter-menu {
        position: static !important;
        display: none;
        max-height: min(360px, 52vh);
        margin-top: 0.45rem;
        border-radius: 14px;
        opacity: 1 !important;
        pointer-events: auto !important;
        transform: none !important;
        box-shadow:
            inset 0 1px 0 rgba(255, 255, 255, 0.95),
            0 16px 32px rgba(2, 44, 34, 0.15);
    }

    .admin-distributor-filter .mobile-filter-select.is-open .mobile-filter-menu {
        display: grid;
    }

    .admin-distributor-filter .mobile-filter-option {
        min-height: 40px;
        border-radius: 11px;
        font-size: 0.82rem;
    }

    .store-card .license-mini-grid {
        gap: 0.38rem;
        margin-top: 0.35rem;
    }

    .store-card .license-mini-card {
        gap: 0;
        padding: 0;
        overflow: hidden;
        border-radius: 12px;
        box-shadow: none;
    }

    .store-card .license-mini-summary {
        min-height: 42px;
        padding: 0.48rem 0.58rem;
        cursor: pointer;
    }

    .store-card .license-mini-title {
        font-size: 0.62rem !important;
        letter-spacing: 0.04em !important;
    }

    .store-card .license-mini-status em {
        display: inline-flex;
        align-items: center;
        min-height: 24px;
        padding: 0.18rem 0.46rem;
        border-radius: 999px;
        background: rgba(255, 255, 255, 0.72);
        font-size: 0.62rem !important;
    }

    .store-card .license-mini-chevron {
        width: 24px;
        height: 24px;
        display: grid;
        place-items: center;
        border-radius: 999px;
        color: currentColor;
        background: rgba(255, 255, 255, 0.58);
        font-size: 0.72rem;
        transition: transform 160ms ease;
    }

    .store-card .license-mini-details {
        display: none;
        padding: 0 0.58rem 0.55rem;
    }

    .store-card .license-mini-card.is-expanded .license-mini-details {
        display: grid;
    }

    .store-card .license-mini-card.is-expanded .license-mini-chevron {
        transform: rotate(180deg);
    }

    .store-card .license-mini-details strong {
        font-size: 0.76rem !important;
    }

    .store-card .license-mini-details small {
        font-size: 0.68rem !important;
    }

    .store-card .license-mini-valid {
        background: linear-gradient(135deg, rgba(220, 252, 231, 0.95), rgba(187, 247, 208, 0.82));
        border-color: rgba(34, 197, 94, 0.32);
    }

    .store-card .license-mini-warning {
        background: linear-gradient(135deg, rgba(254, 243, 199, 0.96), rgba(253, 230, 138, 0.82));
        border-color: rgba(245, 158, 11, 0.36);
    }

    .store-card .license-mini-critical,
    .store-card .license-mini-expired {
        background: linear-gradient(135deg, rgba(254, 226, 226, 0.96), rgba(254, 202, 202, 0.82));
        border-color: rgba(220, 38, 38, 0.34);
    }

    .store-card .license-mini-pending {
        background: linear-gradient(135deg, rgba(248, 250, 252, 0.96), rgba(226, 232, 240, 0.72));
        border-color: rgba(148, 163, 184, 0.24);
    }

    /* ── Pending queues ── */
    .pending-queue-card {
        border-radius: 22px !important;
        margin-bottom: 1rem !important;
    }

    .pending-queue-summary {
        padding: 0.9rem 1rem !important;
    }

    .pending-summary-icon {
        width: 34px !important;
        height: 34px !important;
        font-size: 0.95rem !important;
    }

    .pending-summary-title {
        font-size: 0.86rem !important;
    }

    .pending-summary-subtitle {
        font-size: 0.68rem !important;
    }

    .pending-count-pill {
        font-size: 0.65rem !important;
        padding: 0.22rem 0.5rem !important;
    }

    /* ── Member table card ── */
    .admin-table-card {
        border-radius: 22px !important;
    }

    .admin-table-header {
        padding: 0.9rem 1rem !important;
    }

    .admin-table-header h5 {
        font-size: 0.92rem !important;
    }
}

/* Mobile/tablet filter dropdown polish
   Keep this late so native selects in every filter surface inherit a readable,
   light themed menu on compact viewports. */
@media (max-width: 991.98px) {
    .admin-filters,
    .executive-filter-form,
    .admin-distributor-filter,
    .distributor-filter-bar,
    .store-filter-col #storeFilterForm,
    .filter-card form {
        gap: 0.75rem !important;
        align-items: stretch !important;
    }

    .admin-filters .form-select,
    .executive-filter-control .form-select,
    .admin-distributor-filter .form-select,
    .distributor-filter-bar select,
    .store-filter-col #storeFilterForm .form-select,
    .filter-card .form-select,
    #filterZone,
    #adminFilterZone,
    #storeFilterZone,
    #contact-zone-filter,
    select[name="status"],
    select[name="zone"] {
        width: 100% !important;
        min-width: 0 !important;
        min-height: 54px !important;
        height: auto !important;
        padding: 0.85rem 2.75rem 0.85rem 1rem !important;
        border-radius: 18px !important;
        border: 1px solid rgba(16, 185, 129, 0.24) !important;
        background-color: rgba(255, 255, 255, 0.96) !important;
        color: #0f172a !important;
        font-size: 16px !important;
        font-weight: 600 !important;
        line-height: 1.35 !important;
        box-shadow:
            inset 0 1px 0 rgba(255, 255, 255, 0.95),
            0 10px 24px rgba(6, 95, 70, 0.06) !important;
        color-scheme: light;
        -webkit-text-size-adjust: 100%;
    }

    .admin-filters .form-select:focus,
    .executive-filter-control .form-select:focus,
    .admin-distributor-filter .form-select:focus,
    .distributor-filter-bar select:focus,
    .store-filter-col #storeFilterForm .form-select:focus,
    .filter-card .form-select:focus,
    #filterZone:focus,
    #adminFilterZone:focus,
    #storeFilterZone:focus,
    #contact-zone-filter:focus,
    select[name="status"]:focus,
    select[name="zone"]:focus {
        border-color: rgba(16, 185, 129, 0.58) !important;
        box-shadow:
            0 0 0 4px rgba(16, 185, 129, 0.12),
            0 14px 30px rgba(6, 95, 70, 0.1) !important;
        outline: none !important;
    }

    .executive-filter-control {
        width: 100% !important;
        min-height: 64px !important;
        padding: 0.72rem 0.9rem !important;
        border-radius: 20px !important;
        align-items: center !important;
    }

    .executive-filter-control .form-select {
        min-height: 34px !important;
        padding-top: 0 !important;
        padding-bottom: 0 !important;
        border: 0 !important;
        background-color: transparent !important;
        box-shadow: none !important;
    }

    select.form-select,
    select.form-control,
    .form-select {
        color-scheme: light;
    }

    select.form-select option,
    select.form-control option,
    .form-select option,
    select.form-select optgroup,
    select.form-control optgroup,
    .form-select optgroup {
        background: #ffffff !important;
        color: #0f172a !important;
        font-size: 16px !important;
        font-weight: 600 !important;
        line-height: 1.65 !important;
        padding: 0.8rem 1rem !important;
    }
}

@media (max-width: 575.98px) {
    .admin-filters .form-select,
    .executive-filter-control .form-select,
    .admin-distributor-filter .form-select,
    .distributor-filter-bar select,
    .store-filter-col #storeFilterForm .form-select,
    .filter-card .form-select,
    #filterZone,
    #adminFilterZone,
    #storeFilterZone,
    #contact-zone-filter,
    select[name="status"],
    select[name="zone"] {
        min-height: 52px !important;
        border-radius: 16px !important;
        padding-left: 0.95rem !important;
        font-size: 16px !important;
    }
}

.mobile-filter-select {
    display: none;
}

@media (max-width: 991.98px) {
    select.mobile-filter-native {
        display: none !important;
    }

    .mobile-filter-select {
        position: relative;
        display: block;
        width: 100%;
        z-index: 25;
    }

    .mobile-filter-trigger {
        width: 100%;
        min-height: 46px;
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 0.75rem;
        padding: 0.55rem 0.85rem;
        border: 1px solid rgba(16, 185, 129, 0.24);
        border-radius: 14px;
        background:
            linear-gradient(135deg, rgba(255, 255, 255, 0.98), rgba(240, 253, 248, 0.94));
        color: #0f172a;
        font-size: 0.88rem;
        font-weight: 700;
        line-height: 1.25;
        text-align: left;
        box-shadow:
            inset 0 1px 0 rgba(255, 255, 255, 0.96),
            0 12px 26px rgba(6, 95, 70, 0.07);
        transition:
            border-color 180ms ease,
            box-shadow 180ms ease,
            transform 180ms ease;
    }

    .mobile-filter-trigger-text {
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
    }

    .mobile-filter-trigger i {
        width: 26px;
        height: 26px;
        display: inline-grid;
        place-items: center;
        flex: 0 0 auto;
        border-radius: 999px;
        color: #047857;
        font-size: 0.8rem;
        background: rgba(16, 185, 129, 0.12);
        transition: transform 180ms ease;
    }

    .mobile-filter-select.is-open {
        z-index: 2000;
    }

    .mobile-filter-select.is-open .mobile-filter-trigger {
        border-color: rgba(16, 185, 129, 0.72);
        box-shadow:
            0 0 0 4px rgba(16, 185, 129, 0.14),
            0 18px 36px rgba(6, 95, 70, 0.16);
    }

    .mobile-filter-select.is-open .mobile-filter-trigger i {
        transform: rotate(180deg);
    }

    .mobile-filter-menu {
        position: absolute;
        left: 0;
        right: 0;
        top: calc(100% + 0.4rem);
        max-height: min(300px, 50vh);
        overflow-y: auto;
        padding: 0.4rem;
        border: 1px solid rgba(16, 185, 129, 0.22);
        border-radius: 16px;
        background:
            linear-gradient(145deg, rgba(255, 255, 255, 0.98), rgba(236, 253, 245, 0.96));
        box-shadow:
            0 24px 50px rgba(2, 44, 34, 0.22),
            inset 0 1px 0 rgba(255, 255, 255, 0.95);
        backdrop-filter: blur(24px) saturate(165%);
        -webkit-backdrop-filter: blur(24px) saturate(165%);
        opacity: 0;
        pointer-events: none;
        transform: translateY(-8px) scale(0.98);
        transform-origin: top center;
        transition:
            opacity 170ms ease,
            transform 170ms ease;
    }

    .mobile-filter-select.is-open .mobile-filter-menu {
        opacity: 1;
        pointer-events: auto;
        transform: translateY(0) scale(1);
    }

    .mobile-filter-option {
        width: 100%;
        min-height: 40px;
        display: flex;
        align-items: center;
        gap: 0.6rem;
        padding: 0.5rem 0.75rem;
        border: 0;
        border-radius: 11px;
        background: transparent;
        color: #12372f;
        font-size: 0.82rem;
        font-weight: 700;
        line-height: 1.25;
        text-align: left;
        transition:
            background-color 150ms ease,
            color 150ms ease,
            transform 150ms ease;
    }

    .mobile-filter-option + .mobile-filter-option {
        margin-top: 0.2rem;
    }

    .mobile-filter-option i {
        width: 20px;
        height: 20px;
        display: inline-grid;
        place-items: center;
        flex: 0 0 auto;
        color: #10b981;
        font-size: 0.82rem;
    }

    .mobile-filter-option[aria-selected="true"] {
        background: linear-gradient(135deg, #10b981, #047857);
        color: #ffffff;
        box-shadow: 0 12px 24px rgba(5, 150, 105, 0.22);
    }

    .mobile-filter-option[aria-selected="true"] i {
        color: #ffffff;
    }

    .mobile-filter-option:active {
        transform: scale(0.985);
    }

    .executive-filter-control .mobile-filter-select {
        grid-column: 1 / -1;
    }

    .executive-filter-control .mobile-filter-trigger {
        min-height: 46px;
        border: 0;
        border-radius: 14px;
        background: rgba(255, 255, 255, 0.64);
        box-shadow: none;
    }
}

@media (min-width: 992px) {
    select.mobile-filter-native {
        display: block;
    }
}

/* Contact page filter needs an in-card mobile menu so the options are not clipped
   by the compact zone-directory panel. */
@media (max-width: 991.98px) {
    .contact-network-section .executive-filter-card,
    .contact-network-section .executive-filter-form,
    .contact-network-section .executive-filter-control {
        overflow: visible !important;
    }

    .contact-network-section .executive-filter-card {
        position: relative;
        z-index: 30;
    }

    .contact-network-section .executive-filter-form {
        width: 100% !important;
        min-width: 0 !important;
        align-items: stretch !important;
    }

    .contact-network-section .executive-filter-control {
        z-index: 40;
        align-items: start !important;
        padding: 0.75rem !important;
    }

    .contact-network-section .executive-filter-control .mobile-filter-select {
        grid-column: 1 / -1;
        width: 100%;
        margin-top: 0.3rem;
    }

    .contact-network-section .executive-filter-control .mobile-filter-trigger {
        min-height: 46px;
        color: #0f172a;
        background:
            linear-gradient(145deg, rgba(255, 255, 255, 0.98), rgba(248, 255, 251, 0.94));
        border: 1px solid rgba(16, 185, 129, 0.22);
        box-shadow:
            inset 0 1px 0 rgba(255, 255, 255, 0.95),
            0 10px 22px rgba(6, 95, 70, 0.08);
    }

    .contact-network-section .executive-filter-control .mobile-filter-menu {
        position: static !important;
        display: none;
        max-height: 260px;
        margin-top: 0.5rem;
        border-radius: 14px;
        opacity: 1 !important;
        pointer-events: auto !important;
        transform: none !important;
        box-shadow:
            inset 0 1px 0 rgba(255, 255, 255, 0.95),
            0 14px 28px rgba(2, 44, 34, 0.14);
    }

    .contact-network-section .executive-filter-control .mobile-filter-select.is-open .mobile-filter-menu {
        display: grid;
    }

    .contact-network-section .executive-filter-control .mobile-filter-option {
        min-height: 40px;
        font-size: 0.82rem;
        color: #12372f;
    }
}

/* Admin filter cards also need in-flow menus on compact screens. Floating menus
   get clipped by the sticky glass search panel and look cramped. */
@media (max-width: 991.98px) {
    .admin-search-bar {
        overflow: visible !important;
        /* Must stay BELOW the fixed navbar (.navbar-custom is z-index:1035) so the
           hamburger toggler is never covered by the sticky search bar on mobile. */
        z-index: 1020 !important;
    }

    .admin-search-bar form,
    .admin-filters,
    .admin-filters .mobile-filter-select {
        overflow: visible !important;
    }

    .admin-filters {
        display: grid !important;
        grid-template-columns: 1fr !important;
        align-items: stretch !important;
        gap: 0.78rem !important;
    }

    .admin-filters .mobile-filter-select {
        z-index: 1;
    }

    .admin-filters .mobile-filter-select.is-open {
        z-index: 20;
    }

    .admin-filters .mobile-filter-trigger {
        min-height: 46px;
        border-radius: 14px;
        background:
            linear-gradient(145deg, rgba(255, 255, 255, 0.98), rgba(247, 255, 251, 0.94));
    }

    .admin-filters .mobile-filter-menu {
        position: static !important;
        display: none;
        max-height: none;
        margin-top: 0.45rem;
        padding: 0.4rem;
        border-radius: 14px;
        opacity: 1 !important;
        pointer-events: auto !important;
        transform: none !important;
        background:
            linear-gradient(145deg, rgba(255, 255, 255, 0.98), rgba(236, 253, 245, 0.96));
        box-shadow:
            inset 0 1px 0 rgba(255, 255, 255, 0.95),
            0 16px 32px rgba(2, 44, 34, 0.15);
    }

    .admin-filters .mobile-filter-select.is-open .mobile-filter-menu {
        display: grid;
    }

    .admin-filters .mobile-filter-option {
        min-height: 40px;
        font-size: 0.82rem;
        border-radius: 11px;
    }

    .admin-filters .btn {
        width: fit-content;
        min-height: 44px;
        padding-inline: 1rem;
    }
}

/* Registration/profile forms use the same custom select UI on mobile/tablet so
   long option lists do not fall back to the cramped browser picker. */
@media (max-width: 991.98px) {
    .signup-section .auth-card,
    .profile-section .auth-card,
    .nms-section .auth-card {
        overflow: visible !important;
    }

    .signup-section .field-wrap,
    .profile-section .field-wrap,
    .nms-section .field-wrap,
    .pharmacist-row {
        overflow: visible !important;
    }

    .signup-section .mobile-filter-select,
    .profile-section .mobile-filter-select,
    .nms-section .mobile-filter-select {
        z-index: 5;
    }

    .signup-section .mobile-filter-select.is-open,
    .profile-section .mobile-filter-select.is-open,
    .nms-section .mobile-filter-select.is-open {
        z-index: 80;
    }

    .signup-section .mobile-filter-menu,
    .profile-section .mobile-filter-menu,
    .nms-section .mobile-filter-menu {
        position: static !important;
        display: none;
        max-height: 280px;
        margin-top: 0.55rem;
        opacity: 1 !important;
        pointer-events: auto !important;
        transform: none !important;
    }

    .signup-section .mobile-filter-select.is-open .mobile-filter-menu,
    .profile-section .mobile-filter-select.is-open .mobile-filter-menu,
    .nms-section .mobile-filter-select.is-open .mobile-filter-menu {
        display: grid;
    }
}

/* Final mobile/tablet navbar guard: keep the hamburger visible on every page,
   including sticky/admin layouts that can otherwise crowd the nav row. */
@media (max-width: 991.98px) {
    .navbar-custom {
        min-height: 68px !important;
        overflow: visible !important;
    }

    .navbar-custom > .container {
        display: flex !important;
        align-items: center !important;
        justify-content: space-between !important;
        flex-wrap: wrap !important;
        gap: 0 !important;
        width: 100% !important;
    }

    .navbar-custom .navbar-brand {
        display: inline-flex !important;
        align-items: center !important;
        flex: 0 0 auto !important;
        margin-right: 0 !important;
        min-width: 0 !important;
    }

    .navbar-custom .brand-logo {
        display: block !important;
        flex: 0 0 auto !important;
    }

    .navbar-custom .navbar-toggler {
        position: relative !important;
        z-index: 1045 !important;
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        flex: 0 0 48px !important;
        width: 48px !important;
        height: 42px !important;
        margin-left: auto !important;
        padding: 0 !important;
        opacity: 1 !important;
        visibility: visible !important;
        border: 1px solid rgba(5, 150, 105, 0.18) !important;
        border-radius: 13px !important;
        background: rgba(255, 255, 255, 0.86) !important;
        box-shadow:
            0 10px 24px rgba(6, 95, 70, 0.1),
            inset 0 1px 0 rgba(255, 255, 255, 0.92) !important;
    }

    .navbar-custom .navbar-toggler:focus {
        box-shadow:
            0 0 0 4px rgba(16, 185, 129, 0.14),
            0 10px 24px rgba(6, 95, 70, 0.1) !important;
    }

    .navbar-custom .navbar-toggler-icon {
        position: relative !important;
        display: block !important;
        width: 24px !important;
        height: 18px !important;
        opacity: 1 !important;
        visibility: visible !important;
        background-image: none !important;
    }

    .navbar-custom .navbar-toggler-icon::before {
        content: "";
        position: absolute;
        left: 0;
        right: 0;
        top: 0;
        height: 2.5px;
        border-radius: 999px;
        background: #173a31;
        box-shadow:
            0 7.5px 0 #173a31,
            0 15px 0 #173a31;
    }

    .navbar-custom .navbar-collapse {
        flex-basis: 100% !important;
        width: 100% !important;
    }
}

@media (max-width: 991.98px) {
    .navbar-custom .kcda-mobile-menu-button {
        position: fixed !important;
        top: calc(env(safe-area-inset-top, 0px) + 12px) !important;
        right: max(14px, env(safe-area-inset-right, 0px)) !important;
        z-index: 1100 !important;
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        width: 50px !important;
        height: 44px !important;
        min-width: 50px !important;
        min-height: 44px !important;
        opacity: 1 !important;
        visibility: visible !important;
        pointer-events: auto !important;
        transform: none !important;
        border: 1px solid rgba(5, 150, 105, 0.2) !important;
        border-radius: 14px !important;
        background:
            linear-gradient(145deg, rgba(255, 255, 255, 0.98), rgba(245, 255, 251, 0.92)) !important;
        box-shadow:
            0 14px 30px rgba(6, 95, 70, 0.16),
            inset 0 1px 0 rgba(255, 255, 255, 0.96) !important;
    }

    .navbar-custom .kcda-mobile-menu-button .navbar-toggler-icon {
        display: none !important;
    }

    .kcda-hamburger-lines {
        display: grid !important;
        gap: 5px;
        width: 24px;
    }

    .kcda-hamburger-lines span {
        display: block;
        width: 24px;
        height: 2.5px;
        border-radius: 999px;
        background: #173a31;
        box-shadow: 0 1px 0 rgba(255, 255, 255, 0.8);
    }
}

@media (min-width: 992px) {
    .kcda-hamburger-lines {
        display: none !important;
    }
}

@media (max-width: 991.98px) {
    .messages-container {
        top: calc(env(safe-area-inset-top, 0px) + 76px) !important;
        left: max(12px, env(safe-area-inset-left, 0px)) !important;
        right: max(12px, env(safe-area-inset-right, 0px)) !important;
        width: auto !important;
        max-width: none !important;
        z-index: 1200 !important;
    }

    .messages-container .glass-alert {
        min-height: 58px;
        align-items: flex-start;
        gap: 0.75rem;
        margin: 0 0 0.65rem;
        padding: 0.88rem 2.75rem 0.88rem 0.95rem;
        border-radius: 18px;
        font-size: 0.94rem;
        font-weight: 850;
        line-height: 1.35;
        animation: mobileAlertIn 260ms var(--ease-out);
    }

    .messages-container .glass-alert i {
        display: inline-grid;
        place-items: center;
        flex: 0 0 30px;
        width: 30px;
        height: 30px;
        margin-top: -0.15rem;
        border-radius: 999px;
        background: rgba(254, 226, 226, 0.9);
    }

    .messages-container .glass-alert .btn-close {
        position: absolute;
        top: 50%;
        right: 0.85rem;
        transform: translateY(-50%);
        width: 0.8rem;
        height: 0.8rem;
        padding: 0.45rem;
    }
}

@keyframes mobileAlertIn {
    from {
        opacity: 0;
        transform: translateY(-10px) scale(0.98);
    }
    to {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

/* ==============================
   UNIFIED MOBILE FORM SIZING
   Production-ready input sizing for all forms on mobile & tablet.
   ============================== */
@media (max-width: 767.98px) {
    .form-control,
    .form-select,
    .auth-form .form-control,
    .auth-form .form-select,
    .login-form .form-control,
    .login-form input[type="email"],
    .login-form input[type="password"],
    .login-mob-card .form-control,
    .verify-form-card .form-control,
    .nms-card-body .form-control,
    .nms-card-body .form-select,
    .dsignup-card-body .form-control,
    .dsignup-card-body .form-select,
    .distributor-login-card .form-control,
    .enquiry-form-card .auth-form .form-control,
    .enquiry-form-card .auth-form .form-select {
        min-height: 46px !important;
        padding: 0.55rem 0.8rem !important;
        border-radius: 12px !important;
        font-size: 0.9rem !important;
    }

    .form-control:focus,
    .form-select:focus,
    .auth-form .form-control:focus,
    .auth-form .form-select:focus,
    .login-form .form-control:focus,
    .login-mob-card .form-control:focus,
    .nms-card-body .form-control:focus,
    .nms-card-body .form-select:focus,
    .dsignup-card-body .form-control:focus,
    .dsignup-card-body .form-select:focus {
        box-shadow: 0 0 0 3px rgba(16, 185, 129, 0.12), 0 4px 12px rgba(6, 95, 70, 0.06) !important;
    }

    .form-label,
    .auth-form .form-label,
    .login-form .form-label,
    .login-mob-card .form-label,
    .nms-card-body .form-label,
    .dsignup-card-body .form-label {
        font-size: 0.78rem !important;
        font-weight: 800 !important;
        margin-bottom: 0.35rem !important;
    }

    textarea.form-control,
    .auth-form textarea.form-control,
    .nms-card-body textarea.form-control,
    .dsignup-card-body textarea.form-control {
        min-height: 80px !important;
    }

    .login-submit,
    .auth-submit-btn,
    .nms-submit,
    .dsignup-submit,
    .distributor-submit-btn {
        min-height: 48px !important;
        border-radius: 14px !important;
        font-size: 0.92rem !important;
        font-weight: 900 !important;
    }

    .form-text,
    .nms-card-body .form-text,
    .dsignup-card-body .form-text {
        font-size: 0.7rem !important;
        margin-top: 0.25rem !important;
    }
}

@media (max-width: 575.98px) {
    .license-card-stack {
        gap: 0.75rem;
        margin-bottom: 0.85rem;
    }

    .license-card {
        border-radius: 16px;
        box-shadow: 0 10px 22px rgba(6, 95, 70, 0.08);
    }

    .license-card-toggle {
        grid-template-columns: 44px minmax(0, 1fr) 18px !important;
        grid-template-areas:
            "icon title chevron"
            "icon summary chevron"
            "status status status";
        column-gap: 0.7rem;
        row-gap: 0.18rem;
        min-height: 74px;
        padding: 0.78rem 0.85rem !important;
        overflow: hidden;
    }

    .license-card-icon {
        grid-area: icon;
        width: 44px;
        height: 44px;
        border-radius: 14px;
        font-size: 1rem;
    }

    .license-card-title {
        grid-area: title;
        align-self: end;
        font-size: 0.94rem;
        line-height: 1.12;
        overflow-wrap: anywhere;
    }

    .license-card-summary {
        grid-area: summary;
        justify-self: start;
        align-self: start;
        max-width: 100%;
        font-size: 0.68rem;
        line-height: 1.2;
        white-space: normal;
        overflow-wrap: anywhere;
    }

    .license-card-chevron {
        grid-area: chevron;
        align-self: center;
        justify-self: end;
        font-size: 0.9rem;
    }

    .license-card-toggle .license-status-chip {
        grid-area: status;
        justify-self: start;
        margin-top: 0.28rem;
    }

    .license-card-body {
        padding: 0.85rem;
    }

    .form-control,
    .form-select,
    .auth-form .form-control,
    .auth-form .form-select,
    .login-form .form-control,
    .login-mob-card .form-control,
    .verify-form-card .form-control,
    .nms-card-body .form-control,
    .nms-card-body .form-select,
    .dsignup-card-body .form-control,
    .dsignup-card-body .form-select,
    .distributor-login-card .form-control,
    .enquiry-form-card .auth-form .form-control,
    .enquiry-form-card .auth-form .form-select {
        min-height: 44px !important;
        padding: 0.5rem 0.75rem !important;
        border-radius: 11px !important;
    }

    .form-label,
    .auth-form .form-label,
    .login-form .form-label,
    .login-mob-card .form-label,
    .nms-card-body .form-label,
    .dsignup-card-body .form-label {
        font-size: 0.75rem !important;
        margin-bottom: 0.3rem !important;
    }

    .login-submit,
    .auth-submit-btn,
    .nms-submit,
    .dsignup-submit,
    .distributor-submit-btn {
        min-height: 46px !important;
        border-radius: 12px !important;
        font-size: 0.9rem !important;
    }
}

/* iOS Safari zooms focused form fields below 16px. Keep this last so page-specific mobile rules cannot override it. */
@media (max-width: 767.98px) {
    html body input,
    html body select,
    html body textarea,
    html body .form-control,
    html body .form-select,
    html body .login-field .form-control,
    html body .login-form input[type="email"],
    html body .login-form input[type="password"],
    html body .login-form input[type="text"],
    html body .verify-form-card .form-control,
    html body .enquiry-form-card .auth-form .form-control,
    html body .store-filter-col #storeFilterForm .form-control {
        font-size: 16px !important;
    }
}
