/* ========== design-tokens.css ========== */
/**
 * 🎨 DESIGN TOKENS — आकाश सहकारी (Phase 1 Uniformity)
 * ═══════════════════════════════════════════════════════════
 * यो file सबै portal मा base token layer को रूपमा load हुन्छ।
 * Public + Member + Admin तीनैमा एउटै font/color/spacing।
 *
 * Admin → Settings → Primary Color बदले `_color-vars.php` ले
 * यी variables override गर्छ (header मा inline <style> inject)।
 * ═══════════════════════════════════════════════════════════
 */

:root {
    /* 🎨 Brand (admin-overridable via _color-vars.php) */
    --primary-color:    #1a5f2a;
    --primary-dark:     #144a21;
    --primary-light:    #2e8b4a;
    --primary-glow:     #4caf6a;
    /* rgba(var(--primary-rgb), α) — _color-vars.php ले Settings अनुसार override गर्छ */
    --primary-rgb:      26, 95, 42;
    --secondary-color:  #c0392b;   /* topbar */
    --header-color:     #c0392b;   /* top utility/header strip */
    --header-dark:      #922b21;
    --secondary-dark:   #922b21;
    --footer-color:     #1a5f2a;
    --footer-dark:      var(--primary-dark);
    --text-on-footer:   #ffffff;
    /* Surface */
    --bg-page:          #f8faf9;
    --bg-card:          #ffffff;
    --bg-soft:          #f5faf6;
    --bg-muted:         #e8f5e9;

    /* Text */
    --text-primary:     #1a2e1f;
    --text-secondary:   #4a5a4f;
    --text-muted:       #6b7280;
    --text-on-primary:  #ffffff;

    /* Border & status */
    --border-color:     #e5e7eb;
    --border-soft:      #f0f0f0;
    --color-success:    #28a745;
    --color-warning:    #ffc107;
    --color-danger:     #dc3545;
    --color-info:       var(--secondary-color);

    /* Shadows */
    --shadow-primary:   0 4px 20px rgba(26,95,42,.16);

    /* Container */
    --container-max:    1280px;
    --container-pad:    20px;

    /* 📝 Unified Font Sizes — base 14px (0.875rem) for consistency */
    --font-base:        14px;
    --font-xs:          12px;   /* 0.75rem */
    --font-sm:          13px;   /* 0.8125rem */
    --font-md:          14px;   /* 0.875rem */
    --font-lg:          16px;   /* 1rem */
    --font-xl:          18px;   /* 1.125rem */
    --font-2xl:         20px;   /* 1.25rem */
    --font-3xl:         24px;   /* 1.5rem */
    --font-4xl:         28px;   /* 1.75rem */
    --font-5xl:         32px;   /* 2rem */

    /* Note: --font-primary, --font-nepali, --space-*, --radius-*, --shadow-*
       base/theme layer मा define भएका values हामी यहाँ overwrite गर्दैनौँ। */
}

/* ── Universal base — सबै pages मा एकै font/bg ── */
html, body {
    font-family: var(--font-primary, 'Mukta', 'Noto Sans Devanagari', 'Segoe UI', sans-serif);
    background: var(--bg-page);
    color: var(--text-primary);
    -webkit-font-smoothing: antialiased;
}

/* Form labels/input typography baseline सबै panel मा एउटै राख्ने */
label, .form-label {
    font-family: inherit;
    letter-spacing: 0;
}
input, select, textarea, button {
    font-family: inherit;
}

/* ── Universal Buttons (.btn-coop) ── */
.btn-coop {
    display: inline-flex; align-items: center; justify-content: center; gap: 8px;
    padding: 10px 22px; border-radius: var(--radius-md, 10px);
    font-family: inherit; font-weight: 600; font-size: .95rem;
    border: none; cursor: pointer; text-decoration: none;
    background: var(--primary-color); color: var(--text-on-primary);
    transition: all .25s ease; box-shadow: var(--shadow-sm, 0 1px 4px rgba(0,0,0,.08));
}
.btn-coop:hover { background: var(--primary-dark); box-shadow: var(--shadow-primary); transform: translateY(-1px); color: var(--text-on-primary); }
.btn-coop.btn-outline { background: transparent; color: var(--primary-color); border: 1.5px solid var(--primary-color); box-shadow: none; }
.btn-coop.btn-outline:hover { background: var(--primary-color); color: var(--text-on-primary); }
.btn-coop.btn-secondary { background: var(--secondary-color); }

/* ── Universal Card (.card-coop) ── */
.card-coop {
    background: var(--bg-card);
    border-radius: var(--radius-lg, 16px);
    box-shadow: var(--shadow-md, 0 4px 16px rgba(0,0,0,.08));
    padding: var(--space-lg, 24px);
    border: 1px solid var(--border-soft);
}

/* ── Universal Form Field (.field-coop) ── */
.field-coop {
    width: 100%;
    padding: 11px 14px;
    border: 1.5px solid var(--border-color);
    border-radius: var(--radius-md, 10px);
    font-family: inherit; font-size: .95rem;
    background: #fafbfa; color: var(--text-primary);
    transition: border .2s, box-shadow .2s;
}
.field-coop:focus {
    outline: none; border-color: var(--primary-color);
    background: #fff;
    box-shadow: 0 0 0 3px rgba(26,95,42,.12);
}

/* ── Container ── */
.container-coop {
    max-width: var(--container-max);
    margin: 0 auto; padding: 0 var(--container-pad);
}

/* ── Bootstrap overrides — site-wide consistency ── */
.btn-primary, .bg-primary { background-color: var(--primary-color) !important; border-color: var(--primary-color) !important; color: var(--text-on-primary) !important; }
.btn-primary:hover { background-color: var(--primary-dark) !important; border-color: var(--primary-dark) !important; color: var(--text-on-primary) !important; }
.text-primary { color: var(--primary-color) !important; }
.btn-success, .bg-success { background-color: var(--color-success) !important; border-color: var(--color-success) !important; }
.text-success { color: var(--color-success) !important; }

/* ════════════════════════════════════════════════════════════════
   🌐 GLOBAL UNIFY PASS v2 — Bootstrap variants → site palette
   Public + Admin + Member सबैमा एकनासको colour/icon/feedback
   Admin (.main-content) र Member (.mem-wrapper) मा यिनको
   higher-specificity scoped overrides अघि नै छन्, त्यसैले
   यो pass मुख्यतः public-side को inconsistency मेटाउँछ।
   ════════════════════════════════════════════════════════════════ */

/* — Buttons (remaining variants) — */
.btn-info {
    background-color: #0e7490 !important;
    border-color: #0e7490 !important;
    color: #fff !important;
    background-image: none !important;
}
.btn-info:hover, .btn-info:focus {
    background-color: #0a5a73 !important; border-color: #0a5a73 !important; color: #fff !important;
}
.btn-warning {
    background-color: #b45309 !important;
    border-color: #b45309 !important;
    color: #fff !important;
    background-image: none !important;
}
.btn-warning:hover, .btn-warning:focus {
    background-color: #92400e !important; border-color: #92400e !important; color: #fff !important;
}
.btn-danger {
    background-color: #b91c1c !important;
    border-color: #b91c1c !important;
    color: #fff !important;
    background-image: none !important;
}
.btn-danger:hover, .btn-danger:focus {
    background-color: #991b1b !important; border-color: #991b1b !important; color: #fff !important;
}
.btn-outline-success { color: var(--color-success) !important; border-color: var(--color-success) !important; background: transparent !important; }
.btn-outline-success:hover { background: var(--color-success) !important; color: #fff !important; }
.btn-outline-info { color: #0e7490 !important; border-color: #0e7490 !important; background: transparent !important; }
.btn-outline-info:hover { background: #0e7490 !important; color: #fff !important; }
.btn-outline-warning { color: #b45309 !important; border-color: #b45309 !important; background: transparent !important; }
.btn-outline-warning:hover { background: #b45309 !important; color: #fff !important; }
.btn-outline-danger { color: #b91c1c !important; border-color: #b91c1c !important; background: transparent !important; }
.btn-outline-danger:hover { background: #b91c1c !important; color: #fff !important; }

/* — Bootstrap badge utilities → soft pill, theme-aligned — */
.badge.bg-success, .badge.bg-primary {
    background: #f0fdf4 !important; color: var(--primary-color) !important;
    border: 1px solid #bbf7d0; font-weight: 700; border-radius: 999px; padding: 4px 10px;
}
.badge.bg-info {
    background: #ecfeff !important; color: #0e7490 !important;
    border: 1px solid #a5f3fc; font-weight: 700; border-radius: 999px; padding: 4px 10px;
}
.badge.bg-warning, .badge.bg-warning.text-dark {
    background: #fffbeb !important; color: #b45309 !important;
    border: 1px solid #fde68a; font-weight: 700; border-radius: 999px; padding: 4px 10px;
}
.badge.bg-danger {
    background: #fef2f2 !important; color: #b91c1c !important;
    border: 1px solid #fecaca; font-weight: 700; border-radius: 999px; padding: 4px 10px;
}
.badge.bg-secondary {
    background: #f1f5f9 !important; color: #475569 !important;
    border: 1px solid #cbd5e1; font-weight: 700; border-radius: 999px; padding: 4px 10px;
}
.badge.bg-light {
    background: #f8fafc !important; color: #334155 !important;
    border: 1px solid #e2e8f0; font-weight: 700; border-radius: 999px; padding: 4px 10px;
}
.badge.bg-dark {
    background: #1e293b !important; color: #fff !important;
    border: 1px solid #1e293b; font-weight: 700; border-radius: 999px; padding: 4px 10px;
}

/* — Bootstrap alerts → theme palette — */
.alert { border-radius: 12px; border-width: 1px; padding: 12px 14px; line-height: 1.5; }
.alert-success, .alert-primary {
    background: #f0fdf4 !important; color: var(--primary-color) !important;
    border-color: #bbf7d0 !important;
}
.alert-info {
    background: #ecfeff !important; color: #0e7490 !important;
    border-color: #a5f3fc !important;
}
.alert-warning {
    background: #fffbeb !important; color: #b45309 !important;
    border-color: #fde68a !important;
}
.alert-danger {
    background: #fef2f2 !important; color: #b91c1c !important;
    border-color: #fecaca !important;
}
.alert-secondary {
    background: #f1f5f9 !important; color: #475569 !important;
    border-color: #cbd5e1 !important;
}
.alert-light {
    background: #f8fafc !important; color: #334155 !important;
    border-color: #e2e8f0 !important;
}

/* — Text utility colours — */
.text-info    { color: #0e7490 !important; }
.text-warning { color: #b45309 !important; }
.text-danger  { color: #b91c1c !important; }
.text-secondary { color: #475569 !important; }

/* — Background utility colours (for inline pill/chip) — */
.bg-info    { background-color: #0e7490 !important; color: #fff !important; }
.bg-warning { background-color: #b45309 !important; color: #fff !important; }
.bg-danger  { background-color: #b91c1c !important; color: #fff !important; }

/* — Modal styling: scoped per-panel (admin: admin-modern.css, member: member.css).
     Public pages keep Bootstrap default — radius polish from public-modern.css. — */

/* — Form focus uses theme — */
.form-control:focus, .form-select:focus, .form-check-input:focus {
    border-color: var(--primary-color);
    box-shadow: 0 0 0 .2rem rgba(var(--primary-rgb, 26,95,42), .18);
}
.form-check-input:checked {
    background-color: var(--primary-color);
    border-color: var(--primary-color);
}

/* ═══════════════════════════════════════════════════
   ✅ CHECKBOX / RADIO / SWITCH — generous gap + clean align
   Bootstrap's default 1.5em padding leaves a tight 4px gap
   between the box and the label. Bump to 1.85em (≈10px gap).
   Switches need more (2.8em) since the track is wider.
   Inline variants get clear horizontal spacing so labels never
   feel glued to checkboxes.
   ═══════════════════════════════════════════════════ */
.form-check {
    padding-left: 1.85em !important;
    min-height: 1.6rem !important;
    margin-bottom: .35rem !important;
}
.form-check .form-check-input {
    margin-left: -1.85em !important;
    margin-top: .2em !important;
    flex-shrink: 0;
}
.form-check-label {
    cursor: pointer;
    line-height: 1.45;
    padding-left: 4px;
}

/* Inline (horizontal) — give breathing room between options */
.form-check-inline {
    display: inline-flex !important;
    align-items: center !important;
    margin-right: 1.1rem !important;
    padding-left: 1.85em !important;
    margin-bottom: .35rem !important;
}
.form-check-inline .form-check-input {
    margin-left: -1.85em !important;
    margin-top: 0 !important;
    margin-right: .55em !important;
}
.form-check-inline .form-check-label { padding-left: 0; margin-bottom: 0; }

/* Switch (toggle) — wider track needs wider gutter */
.form-switch {
    padding-left: 2.8em !important;
    min-height: 1.6rem !important;
}
.form-switch .form-check-input {
    margin-left: -2.8em !important;
    width: 2.2em !important;
    height: 1.15em !important;
    margin-top: .15em !important;
}
.form-switch.form-check-inline {
    padding-left: 2.8em !important;
}
.form-switch.form-check-inline .form-check-input {
    margin-left: -2.8em !important;
    margin-right: .55em !important;
}

/* Disabled state — clear visual cue */
.form-check-input:disabled ~ .form-check-label,
.form-check-input[disabled] ~ .form-check-label {
    opacity: .55;
    cursor: not-allowed;
}

/* Invalid state — keep theme-aligned */
.form-check-input.is-invalid {
    border-color: #b91c1c !important;
}
.form-check-input.is-invalid:checked {
    background-color: #b91c1c !important;
}

/* — List-group active uses theme — */
.list-group-item.active {
    background-color: var(--primary-color);
    border-color: var(--primary-color);
}

/* — Pagination active state — */
.page-item.active .page-link {
    background-color: var(--primary-color);
    border-color: var(--primary-color);
}
.page-link { color: var(--primary-color); }
.page-link:hover { color: var(--primary-dark); }

/* — Nav-pills active uses theme — */
.nav-pills .nav-link.active,
.nav-pills .show > .nav-link {
    background-color: var(--primary-color);
}

/* — Spinner uses theme — */
.spinner-border.text-primary, .spinner-grow.text-primary { color: var(--primary-color) !important; }

/* — Progress bar uses theme — */
.progress-bar { background-color: var(--primary-color); }

/* ── Mobile responsive ── */
@media (max-width: 768px) {
    :root { --container-pad: 14px; }
    .btn-coop { padding: 9px 18px; font-size: .9rem; }
    .card-coop { padding: var(--space-md, 16px); }
}

/* ════════════════════════════════════════════════════════════════
   🆕 DESIGN TOKEN EXPANSIONS — v6.5
   Missing tokens from components/, stat-card, bottom-nav
   ════════════════════════════════════════════════════════════════ */
:root {
    /* Accent — gold/amber: notices, live badges, special highlights */
    --accent-color:         #f59e0b;
    --accent-dark:          #b45309;
    --accent-light:         #fbbf24;

    /* Text on surfaces */
    --text-on-secondary:    #ffffff;
    --text-on-accent:       #1a1a1a;
    --text-on-header:       #ffffff;
    --text-light:           #6b7280;
    --text-color:           #333333;

    /* Admin panel tokens (used in admin-modern.css, readable everywhere) */
    --adm-bg:               #f6f8f7;
    --adm-surface:          #ffffff;
    --adm-border:           #e8edeb;
    --adm-text:             #1a2e1f;
    --adm-muted:            #6b7280;
    --adm-shadow-xs:        0 1px 3px rgba(0,0,0,.06);
    --adm-shadow-sm:        0 2px 8px rgba(0,0,0,.08);
    --adm-shadow-md:        0 6px 24px rgba(0,0,0,.10);
    --adm-radius:           10px;
    --adm-radius-sm:        7px;
    --adm-success-bg:       #f0fdf4;
    --adm-danger-bg:        #fef2f2;
    --adm-warn-bg:          #fffbeb;
    --adm-info-bg:          #f0fdf4;

    /* Font weight helpers (fw-* utility) */
    --fw-normal:            400;
    --fw-medium:            500;
    --fw-semibold:          600;
    --fw-bold:              700;
    --fw-extrabold:         800;

    /* Z-index scale */
    --z-bottom-nav:         800;
    --z-topbar:             900;
    --z-sidebar:            950;
    --z-modal:              1040;
    --z-toast:              1060;
    --z-tooltip:            1070;

    /* Transition defaults */
    --transition-fast:      all .15s ease;
    --transition-base:      all .2s ease;
    --transition-slow:      all .35s ease;
}

/* fw-* font-weight utility (Bootstrap only has fw-bold/normal) */
.fw-500, .fw-medium   { font-weight: 500 !important; }
.fw-600, .fw-semibold { font-weight: 600 !important; }
.fw-700               { font-weight: 700 !important; }
.fw-800, .fw-extrabold{ font-weight: 800 !important; }

/* Stat card animation — generic (used by stat-card.php component) */
.stat-card {
    transition: var(--transition-base);
}
.stat-card:hover {
    transform: translateY(-3px);
    box-shadow: var(--shadow-md, 0 4px 16px rgba(0,0,0,.10));
}

/* Accessible focus ring — consistent across all portals */
:focus-visible {
    outline: 2px solid var(--primary-color);
    outline-offset: 2px;
    border-radius: 4px;
}

/* ════════════════════════════════════════════════════════════════
   📐 UTILITY CLASSES — Inline Style Replacements
   ════════════════════════════════════════════════════════════════
   89 files का सामान्य inline styles क replace गर्ने ready classes।
   प्रयोग:  <div class="coop-flex coop-gap-md coop-mb-lg">
*/

/* Display & flex */
.coop-flex      { display: flex; }
.coop-flex-col  { display: flex; flex-direction: column; }
.coop-flex-wrap { display: flex; flex-wrap: wrap; }
.coop-grid      { display: grid; }
.coop-inline    { display: inline-flex; align-items: center; }
.coop-items-center  { align-items: center; }
.coop-items-start   { align-items: flex-start; }
.coop-justify-between { justify-content: space-between; }
.coop-justify-center  { justify-content: center; }
.coop-justify-end     { justify-content: flex-end; }

/* Gap */
.coop-gap-xs { gap: 4px; } .coop-gap-sm { gap: 8px; }
.coop-gap-md { gap: 16px; } .coop-gap-lg { gap: 24px; }

/* Margin */
.coop-mt-xs { margin-top: 4px; } .coop-mt-sm { margin-top: 8px; }
.coop-mt-md { margin-top: 16px; } .coop-mt-lg { margin-top: 24px; }
.coop-mb-xs { margin-bottom: 4px; } .coop-mb-sm { margin-bottom: 8px; }
.coop-mb-md { margin-bottom: 16px; } .coop-mb-lg { margin-bottom: 24px; }

/* Padding */
.coop-p-sm { padding: 8px; } .coop-p-md { padding: 16px; } .coop-p-lg { padding: 24px; }

/* Text */
.coop-text-primary   { color: var(--primary-color); }
.coop-text-secondary { color: var(--text-secondary); }
.coop-text-muted     { color: var(--text-muted); }
.coop-text-success   { color: var(--color-success); }
.coop-text-danger    { color: var(--color-danger); }
.coop-text-mono      { font-family: 'Courier New', ui-monospace, monospace; }
.coop-text-sm        { font-size: .85rem; } .coop-text-xs { font-size: .75rem; }
.coop-text-lg        { font-size: 1.1rem; }
.coop-font-bold      { font-weight: 700; } .coop-font-medium { font-weight: 500; }

/* Background */
.coop-bg-soft   { background: var(--bg-soft); }
.coop-bg-muted  { background: var(--bg-muted); }
.coop-bg-card   { background: var(--bg-card); }

/* Borders & radius */
.coop-rounded   { border-radius: var(--radius-md, 10px); }
.coop-rounded-lg { border-radius: var(--radius-lg, 16px); }
.coop-bordered  { border: 1px solid var(--border-color); }

/* Width helpers */
.coop-w-full { width: 100%; } .coop-mw-md { max-width: 480px; } .coop-mw-lg { max-width: 720px; }

/* Code/pre uniform — credentials, tracking IDs etc. */
.coop-code {
    font-family: 'Courier New', ui-monospace, monospace;
    background: var(--bg-soft);
    padding: 4px 10px; border-radius: 6px;
    font-size: .85rem; color: var(--text-primary);
    letter-spacing: .5px;
}

/* Modal backdrop (use as: <div class="coop-modal" style="display:flex"...>) */
.coop-modal {
    position: fixed; inset: 0;
    background: rgba(0,0,0,.5);
    z-index: 9999;
    display: none;
    align-items: center; justify-content: center;
    padding: 20px; overflow-y: auto;
}
.coop-modal.is-open { display: flex; }

/* ID-card monospace badge (member panel मा 8+ ठाउँमा छ) */
.coop-id-badge {
    font-family: 'Courier New', monospace;
    font-size: .85rem; letter-spacing: 2px;
    color: var(--primary-color); font-weight: 600;
}

/* Print-safe */
@media print {
    .coop-no-print, .no-print { display: none !important; }
}

/* ========== theme-variables.css ========== */
:root {
    /* ══════════════════════════════════════════════════════════════
       HRM & CMS THEME VARIABLES
       Global color system for consistent theming
       ══════════════════════════════════════════════════════════════ */

    /* Primary Brand Colors */
    --color-primary: #2d5a3d;           /* Dark Green (Cooperative theme) */
    --color-primary-light: #4a7c5a;
    --color-primary-lighter: #e8f5e9;
    --color-primary-dark: #1e3a2c;

    /* Secondary Colors */
    --color-success: #28a745;
    --color-info: #17a2b8;
    --color-warning: #ffc107;
    --color-danger: #dc3545;

    /* Light Variants */
    --color-success-light: #d4edda;
    --color-info-light: #d1ecf1;
    --color-warning-light: #fff3cd;
    --color-danger-light: #f8d7da;

    /* Neutral Colors */
    --color-white: #ffffff;
    --color-black: #000000;
    --color-gray-100: #f8f9fa;
    --color-gray-200: #e9ecef;
    --color-gray-300: #dee2e6;
    --color-gray-400: #ced4da;
    --color-gray-500: #adb5bd;
    --color-gray-600: #6c757d;
    --color-gray-700: #495057;
    --color-gray-800: #343a40;
    --color-gray-900: #212529;

    /* Text Colors */
    --text-primary: #212529;
    --text-secondary: #6c757d;
    --text-muted: #adb5bd;
    --text-light: #f8f9fa;
    --text-dark: #000000;

    /* Background Colors */
    --bg-primary: #ffffff;
    --bg-secondary: #f8f9fa;
    --bg-tertiary: #e9ecef;
    --bg-light: #f5f5f5;
    --bg-dark: #212529;

    /* Borders */
    --border-color: #dee2e6;
    --border-light: #e9ecef;
    --border-dark: #adb5bd;

    /* Shadows */
    --shadow-sm: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.075);
    --shadow-md: 0 0.5rem 1rem rgba(0, 0, 0, 0.15);
    --shadow-lg: 0 1rem 3rem rgba(0, 0, 0, 0.175);

    /* Spacing & Sizing */
    --spacing-xs: 0.25rem;
    --spacing-sm: 0.5rem;
    --spacing-md: 1rem;
    --spacing-lg: 1.5rem;
    --spacing-xl: 2rem;
    --spacing-xxl: 3rem;

    /* Typography */
    --font-family-base: -apple-system, BlinkMacSystemFont, 'Segoe UI', 'Roboto', 'Oxygen', 'Ubuntu', 'Cantarell', 'Fira Sans', 'Droid Sans', 'Helvetica Neue', sans-serif;
    --font-family-nepali: 'Noto Sans Devanagari', 'Mangal', 'Kalimati', sans-serif;
    --font-size-base: 1rem;
    --font-size-sm: 0.875rem;
    --font-size-lg: 1.125rem;
    --font-size-xl: 1.25rem;
    --font-weight-light: 300;
    --font-weight-normal: 400;
    --font-weight-medium: 500;
    --font-weight-bold: 700;
    --line-height-base: 1.5;
    --line-height-heading: 1.2;

    /* Border Radius */
    --radius-sm: 0.25rem;
    --radius-md: 0.375rem;
    --radius-lg: 0.5rem;
    --radius-xl: 1rem;
    --radius-round: 50%;

    /* Transitions */
    --transition-fast: 150ms cubic-bezier(0.4, 0, 0.2, 1);
    --transition-normal: 300ms cubic-bezier(0.4, 0, 0.2, 1);
    --transition-slow: 450ms cubic-bezier(0.4, 0, 0.2, 1);

    /* Z-Index */
    --z-dropdown: 1000;
    --z-sticky: 1020;
    --z-fixed: 1030;
    --z-modal-backdrop: 1040;
    --z-modal: 1050;
    --z-popover: 1060;
    --z-tooltip: 1070;
}

/* ══════════════════════════════════════════════════════════════
   Nepali Typography - Responsive sizing
   ══════════════════════════════════════════════════════════════ */

body {
    font-family: var(--font-family-base);
    color: var(--text-primary);
    background-color: var(--bg-primary);
    line-height: var(--line-height-base);
}

/* Nepali text elements */
.np-text, [lang="np"], [lang="ne"] {
    font-family: var(--font-family-nepali);
    text-align: left;
    word-break: break-word;
}

/* Mobile-first responsive typography */
h1 { font-size: 1.5rem; font-weight: var(--font-weight-bold); line-height: var(--line-height-heading); }
h2 { font-size: 1.25rem; font-weight: var(--font-weight-bold); line-height: var(--line-height-heading); }
h3 { font-size: 1.1rem; font-weight: var(--font-weight-bold); line-height: var(--line-height-heading); }
h4 { font-size: 1rem; font-weight: var(--font-weight-bold); line-height: var(--line-height-heading); }
h5 { font-size: 0.9rem; font-weight: var(--font-weight-bold); line-height: var(--line-height-heading); }
h6 { font-size: 0.85rem; font-weight: var(--font-weight-bold); line-height: var(--line-height-heading); }

/* Tablet and up */
@media (min-width: 768px) {
    h1 { font-size: 2rem; }
    h2 { font-size: 1.5rem; }
    h3 { font-size: 1.25rem; }
}

/* Desktop and up */
@media (min-width: 1024px) {
    h1 { font-size: 2.5rem; }
    h2 { font-size: 2rem; }
    h3 { font-size: 1.5rem; }
}

/* Paragraph spacing - better Nepali text handling */
p {
    margin-bottom: var(--spacing-md);
    line-height: 1.6;
}

.np-text p {
    line-height: 1.7;
    letter-spacing: 0.3px;
}

/* ══════════════════════════════════════════════════════════════
   Utility Classes - Color Helpers
   ══════════════════════════════════════════════════════════════ */

.text-primary { color: var(--color-primary); }
.text-success { color: var(--color-success); }
.text-info { color: var(--color-info); }
.text-warning { color: var(--color-warning); }
.text-danger { color: var(--color-danger); }
.text-secondary { color: var(--text-secondary); }
.text-muted { color: var(--text-muted); }
.text-light { color: var(--text-light); }
.text-dark { color: var(--text-dark); }

.bg-primary { background-color: var(--color-primary); }
.bg-success { background-color: var(--color-success); }
.bg-info { background-color: var(--color-info); }
.bg-warning { background-color: var(--color-warning); }
.bg-danger { background-color: var(--color-danger); }
.bg-light { background-color: var(--bg-light); }
.bg-dark { background-color: var(--bg-dark); }

.border-primary { border-color: var(--color-primary); }
.border-success { border-color: var(--color-success); }
.border-info { border-color: var(--color-info); }
.border-warning { border-color: var(--color-warning); }
.border-danger { border-color: var(--color-danger); }

/* ══════════════════════════════════════════════════════════════
   Button Theming
   ══════════════════════════════════════════════════════════════ */

.btn {
    --bs-btn-padding-y: 0.5rem;
    --bs-btn-padding-x: 1rem;
    --bs-btn-font-size: 0.95rem;
    --bs-btn-border-radius: var(--radius-md);
    transition: all var(--transition-normal);
}

.btn:hover, .btn:focus {
    transform: translateY(-2px);
    box-shadow: var(--shadow-md);
}

.btn-primary {
    --bs-btn-bg: var(--color-primary);
    --bs-btn-hover-bg: var(--color-primary-dark);
    --bs-btn-active-bg: var(--color-primary-dark);
    --bs-btn-border-color: var(--color-primary);
}

/* ══════════════════════════════════════════════════════════════
   Card & Container Styling
   ══════════════════════════════════════════════════════════════ */

.card {
    --bs-card-border-color: var(--border-light);
    --bs-card-border-radius: var(--radius-lg);
    --bs-card-box-shadow: var(--shadow-sm);
    border: 1px solid var(--border-light);
}

.card-header {
    background-color: var(--bg-secondary);
    border-bottom: 1px solid var(--border-light);
    color: var(--text-primary);
    font-weight: var(--font-weight-medium);
}

/* ══════════════════════════════════════════════════════════════
   Alert & Status Helpers
   ══════════════════════════════════════════════════════════════ */

.alert {
    border-radius: var(--radius-md);
    border: 1px solid var(--border-color);
}

.alert-primary { background-color: var(--color-primary-lighter); border-color: var(--color-primary-light); color: var(--color-primary-dark); }
.alert-success { background-color: var(--color-success-light); border-color: var(--color-success); color: #155724; }
.alert-info { background-color: var(--color-info-light); border-color: var(--color-info); color: #0c5460; }
.alert-warning { background-color: var(--color-warning-light); border-color: var(--color-warning); color: #856404; }
.alert-danger { background-color: var(--color-danger-light); border-color: var(--color-danger); color: #721c24; }

/* ══════════════════════════════════════════════════════════════
   Form Elements
   ══════════════════════════════════════════════════════════════ */

.form-control,
.form-select {
    --bs-form-control-border-color: var(--border-color);
    --bs-form-control-focus-border-color: var(--color-primary);
    --bs-form-control-focus-box-shadow: 0 0 0 0.2rem rgba(45, 90, 61, 0.25);
    border-radius: var(--radius-md);
    padding: var(--spacing-sm) var(--spacing-md);
}

.form-control:focus,
.form-select:focus {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 0.2rem rgba(45, 90, 61, 0.25);
}

/* ══════════════════════════════════════════════════════════════
   Tables
   ══════════════════════════════════════════════════════════════ */

.table {
    --bs-table-border-color: var(--border-light);
    color: var(--text-primary);
}

.table-hover tbody tr:hover {
    background-color: var(--bg-secondary);
}

.table thead {
    background-color: var(--bg-secondary);
    color: var(--text-primary);
    font-weight: var(--font-weight-medium);
}

/* ══════════════════════════════════════════════════════════════
   Badge & Badges
   ══════════════════════════════════════════════════════════════ */

.badge {
    --bs-badge-padding-y: 0.35rem;
    --bs-badge-padding-x: 0.65rem;
    font-size: 0.8rem;
    font-weight: var(--font-weight-medium);
    border-radius: var(--radius-lg);
}

/* ══════════════════════════════════════════════════════════════
   Modal & Dropdown
   ══════════════════════════════════════════════════════════════ */

.modal-content {
    border-radius: var(--radius-lg);
    border-color: var(--border-light);
}

.dropdown-menu {
    border-radius: var(--radius-md);
    border-color: var(--border-light);
    box-shadow: var(--shadow-md);
}

.dropdown-item {
    color: var(--text-primary);
    transition: all var(--transition-fast);
}

.dropdown-item:hover {
    background-color: var(--bg-secondary);
    color: var(--color-primary);
}

/* ══════════════════════════════════════════════════════════════
   Accessibility
   ══════════════════════════════════════════════════════════════ */

:focus-visible {
    outline: 2px solid var(--color-primary);
    outline-offset: 2px;
}

@media (prefers-reduced-motion: reduce) {
    * {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
}

/* ══════════════════════════════════════════════════════════════
   Print Styles
   ══════════════════════════════════════════════════════════════ */

@media print {
    body {
        background-color: white;
        color: black;
    }
    .no-print {
        display: none !important;
    }
    .print-only {
        display: block !important;
    }
}

/* ========== animations.css ========== */
/* ══════════════════════════════════════════════════════════════════════════════
   HRM & CMS ANIMATIONS & TRANSITIONS
   Optimized animation speeds, easing functions, and interactive effects
   ══════════════════════════════════════════════════════════════════════════════ */

/* ────────────────────────────────────────────────────────────────────────────
   Animation Speed Variables
   ────────────────────────────────────────────────────────────────────────────  */

:root {
    --anim-fast: 150ms;
    --anim-normal: 250ms;
    --anim-slow: 350ms;
    --ease-in: cubic-bezier(0.4, 0, 1, 1);
    --ease-out: cubic-bezier(0, 0, 0.2, 1);
    --ease-in-out: cubic-bezier(0.4, 0, 0.2, 1);
}

/* ────────────────────────────────────────────────────────────────────────────
   Stat Cards & Dashboard Animations
   ────────────────────────────────────────────────────────────────────────────  */

/* Stat card hover lift effect */
.stat-uniform-card {
    transition: transform var(--anim-normal) var(--ease-out),
                box-shadow var(--anim-normal) var(--ease-out),
                background-color var(--anim-fast) var(--ease-out);
}

.stat-uniform-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 16px rgba(0, 0, 0, 0.12) !important;
}

.stat-uniform-card .stat-value {
    transition: color var(--anim-fast) var(--ease-out),
                transform var(--anim-normal) var(--ease-out);
}

.stat-uniform-card:hover .stat-value {
    transform: scale(1.08);
}

/* Stat card background color animation */
.stat-uniform-card.stat-primary-bg { background-color: var(--color-primary-lighter); }
.stat-uniform-card.stat-success-bg { background-color: var(--color-success-light); }
.stat-uniform-card.stat-info-bg { background-color: var(--color-info-light); }
.stat-uniform-card.stat-warning-bg { background-color: var(--color-warning-light); }
.stat-uniform-card.stat-danger-bg { background-color: var(--color-danger-light); }

/* ────────────────────────────────────────────────────────────────────────────
   Button Animations
   ────────────────────────────────────────────────────────────────────────────  */

.btn {
    transition: all var(--anim-fast) var(--ease-out);
    position: relative;
    overflow: hidden;
}

.btn:not(:disabled):hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.15) !important;
}

.btn:not(:disabled):active {
    transform: translateY(0);
}

/* Ripple effect on click (using CSS) */
.btn::before {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 0;
    height: 0;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.3);
    transform: translate(-50%, -50%);
    pointer-events: none;
}

.btn:active::before {
    animation: ripple-effect var(--anim-slow) ease-out;
}

@keyframes ripple-effect {
    to {
        width: 300px;
        height: 300px;
        opacity: 0;
    }
}

/* ────────────────────────────────────────────────────────────────────────────
   Form Element Animations
   ────────────────────────────────────────────────────────────────────────────  */

.form-control,
.form-select {
    transition: border-color var(--anim-fast) var(--ease-out),
                box-shadow var(--anim-fast) var(--ease-out),
                background-color var(--anim-fast) var(--ease-out);
}

.form-control:focus,
.form-select:focus {
    border-color: var(--color-primary) !important;
    box-shadow: 0 0 0 0.2rem rgba(45, 90, 61, 0.15) !important;
}

.form-control::placeholder {
    transition: color var(--anim-fast) var(--ease-out);
}

.form-control:focus::placeholder {
    color: var(--color-primary);
}

/* ────────────────────────────────────────────────────────────────────────────
   Card & Container Animations
   ────────────────────────────────────────────────────────────────────────────  */

.card {
    transition: transform var(--anim-normal) var(--ease-out),
                box-shadow var(--anim-normal) var(--ease-out),
                border-color var(--anim-fast) var(--ease-out);
}

.card:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-md) !important;
}

.card-header {
    transition: background-color var(--anim-fast) var(--ease-out),
                border-color var(--anim-fast) var(--ease-out);
}

/* ────────────────────────────────────────────────────────────────────────────
   Alert & Badge Animations
   ────────────────────────────────────────────────────────────────────────────  */

.alert {
    animation: slideInDown var(--anim-normal) var(--ease-out);
}

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

.badge {
    transition: transform var(--anim-fast) var(--ease-out),
                box-shadow var(--anim-fast) var(--ease-out);
}

.badge:hover {
    transform: scale(1.05);
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

/* Pulse animation for notification badges */
.badge.pulse {
    animation: pulse 2s var(--ease-in-out) infinite;
}

@keyframes pulse {
    0%, 100% {
        opacity: 1;
    }
    50% {
        opacity: 0.7;
    }
}

/* ────────────────────────────────────────────────────────────────────────────
   Navigation & Dropdown Animations
   ────────────────────────────────────────────────────────────────────────────  */

.dropdown-menu {
    animation: fadeInDropdown var(--anim-fast) var(--ease-out);
}

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

.dropdown-item {
    transition: background-color var(--anim-fast) var(--ease-out),
                color var(--anim-fast) var(--ease-out),
                transform var(--anim-fast) var(--ease-out);
}

.dropdown-item:hover {
    transform: translateX(4px);
}

/* Sidebar toggle animation */
.sidebar {
    transition: transform var(--anim-normal) var(--ease-out),
                opacity var(--anim-normal) var(--ease-out);
}

@media (max-width: 768px) {
    .sidebar.closed {
        transform: translateX(-100%);
        opacity: 0;
        pointer-events: none;
    }
}

/* ────────────────────────────────────────────────────────────────────────────
   Table Row Animations
   ────────────────────────────────────────────────────────────────────────────  */

.table tbody tr {
    transition: background-color var(--anim-fast) var(--ease-out),
                box-shadow var(--anim-fast) var(--ease-out);
}

.table-hover tbody tr:hover {
    background-color: var(--bg-secondary) !important;
    box-shadow: inset 0 0 4px rgba(0, 0, 0, 0.05);
}

/* Fade in animation for table rows on load */
.table tbody tr {
    animation: fadeInRow var(--anim-normal) var(--ease-out) backwards;
}

.table tbody tr:nth-child(1) { animation-delay: 0ms; }
.table tbody tr:nth-child(2) { animation-delay: 30ms; }
.table tbody tr:nth-child(3) { animation-delay: 60ms; }
.table tbody tr:nth-child(4) { animation-delay: 90ms; }
.table tbody tr:nth-child(5) { animation-delay: 120ms; }
.table tbody tr:nth-child(n+6) { animation-delay: 150ms; }

@keyframes fadeInRow {
    from {
        opacity: 0;
        transform: translateY(10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* ────────────────────────────────────────────────────────────────────────────
   Modal & Dialog Animations
   ────────────────────────────────────────────────────────────────────────────  */

.modal.fade .modal-dialog {
    transition: transform var(--anim-normal) var(--ease-out);
}

.modal.show .modal-dialog {
    animation: slideInUp var(--anim-normal) var(--ease-out);
}

@keyframes slideInUp {
    from {
        opacity: 0;
        transform: translateY(30px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.modal-backdrop {
    animation: fadeIn var(--anim-fast) var(--ease-out);
}

@keyframes fadeIn {
    from {
        opacity: 0;
    }
    to {
        opacity: 1;
    }
}

/* ────────────────────────────────────────────────────────────────────────────
   Icon & Spinner Animations
   ────────────────────────────────────────────────────────────────────────────  */

.fa-spinner,
.fa-circle-notch,
.fa-cog,
.fa-refresh,
.fa-rotate {
    animation: spin 1s linear infinite;
}

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

/* Hover animation for icon buttons */
.icon-btn,
.hp-icon {
    transition: all var(--anim-fast) var(--ease-out);
}

.icon-btn:hover,
.hp-icon:hover {
    transform: scale(1.1) rotate(2deg);
    color: var(--color-primary);
}

/* Icon scale effect */
.icon-scale {
    transition: transform var(--anim-fast) var(--ease-out);
}

.icon-scale:hover {
    transform: scale(1.2);
}

/* ────────────────────────────────────────────────────────────────────────────
   Toggle Switch Animations
   ────────────────────────────────────────────────────────────────────────────  */

.toggle-switch,
.form-check-input {
    transition: all var(--anim-fast) var(--ease-out);
}

.form-check-input:checked {
    background-color: var(--color-primary);
    border-color: var(--color-primary);
}

/* ────────────────────────────────────────────────────────────────────────────
   Loading Skeleton Animation
   ────────────────────────────────────────────────────────────────────────────  */

.skeleton,
.placeholder-wave {
    animation: shimmer 2s infinite;
}

@keyframes shimmer {
    0% {
        background-position: -1000px 0;
    }
    100% {
        background-position: 1000px 0;
    }
}

/* ────────────────────────────────────────────────────────────────────────────
   Hover Scale Effects for Interactive Elements
   ────────────────────────────────────────────────────────────────────────────  */

.hover-scale {
    transition: transform var(--anim-fast) var(--ease-out);
}

.hover-scale:hover {
    transform: scale(1.05);
}

.hover-scale-sm:hover {
    transform: scale(1.02);
}

.hover-scale-lg:hover {
    transform: scale(1.1);
}

/* ────────────────────────────────────────────────────────────────────────────
   Smooth Scrolling & Scroll Effects
   ────────────────────────────────────────────────────────────────────────────  */

html {
    scroll-behavior: smooth;
}

/* Fade in on scroll (using AOS library compatibility) */
[data-aos] {
    transition: all var(--anim-normal) var(--ease-out);
    opacity: 0;
}

[data-aos].aos-animate {
    opacity: 1;
}

/* ────────────────────────────────────────────────────────────────────────────
   Print Mode - Disable Animations
   ────────────────────────────────────────────────────────────────────────────  */

@media print {
    * {
        animation-duration: 0 !important;
        transition-duration: 0 !important;
    }
}

/* ────────────────────────────────────────────────────────────────────────────
   Prefers Reduced Motion - Accessibility
   ────────────────────────────────────────────────────────────────────────────  */

@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
        scroll-behavior: auto !important;
    }
}

/* ========== mobile-menu-improvements.css ========== */
/*
  ══════════════════════════════════════════════════════════════
  MOBILE MENU & UI IMPROVEMENTS (v2026-05-20)
  - Fix hamburger menu functionality on desktop
  - Improve mobile bottom nav appearance
  - Add footer icons to mobile views
  - Better responsive transitions
  ══════════════════════════════════════════════════════════════
*/

/* ─────────────────────────────────────────────────────────────
   ADMIN: Mobile Bottom Navigation Enhancement
   ───────────────────────────────────────────────────────────── */

.mob-bottomnav {
  display: flex !important;
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  height: auto;
  background: #ffffff;
  border-top: 1px solid #e5e7eb;
  box-shadow: 0 -8px 24px rgba(15, 23, 42, 0.10);
  z-index: 45;
  justify-content: space-around;
  align-items: stretch;
  padding: 0;
  margin: 0;
}

.mob-bn-item {
  flex: 1;
  display: flex !important;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
  padding: 8px 4px !important;
  text-decoration: none;
  color: #6b7280 !important;
  font-size: 11px;
  font-weight: 600;
  transition: all 0.2s ease;
  border-radius: 0;
  text-align: center;
}

.mob-bn-item i {
  font-size: 18px;
  display: block;
  line-height: 1;
}

.mob-bn-item span {
  font-size: 10px;
  display: block;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 100%;
}

.mob-bn-item:hover,
.mob-bn-item.active {
  color: var(--primary-color, #1a5f2a) !important;
  background: rgba(26, 95, 42, 0.08);
}

.mob-bn-item.active {
  border-top: 3px solid var(--primary-color, #1a5f2a);
  padding-top: 5px !important;
}

/* ─────────────────────────────────────────────────────────────
   ADMIN: Hamburger Menu Fix (Desktop Should NOT Show)
   ───────────────────────────────────────────────────────────── */

.hp-burger {
  display: grid !important;
  place-items: center;
}

/* Hide burger on desktop, show on tablet/mobile */
@media (min-width: 900px) {
  .hp-burger {
    display: none !important;
  }
}

@media (max-width: 899px) {
  .hp-burger {
    display: grid !important;
  }
}

/* ─────────────────────────────────────────────────────────────
   BODY ADJUSTMENTS: Add padding for mobile bottom nav
   ───────────────────────────────────────────────────────────── */

body.has-bottomnav {
  padding-bottom: 65px;
}

.page-content,
.admin-content,
main {
  padding-bottom: 12px;
}

/* ─────────────────────────────────────────────────────────────
   PUBLIC WEBSITE: Mobile Footer with Important Icons
   ───────────────────────────────────────────────────────────── */

.public-mobile-footer {
  display: none;
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  height: 60px;
  background: #ffffff;
  border-top: 1px solid #e5e7eb;
  box-shadow: 0 -8px 24px rgba(15, 23, 42, 0.10);
  z-index: 45;
  justify-content: space-around;
  align-items: center;
  padding: 0;
  margin: 0;
}

@media (max-width: 768px) {
  .public-mobile-footer {
    display: flex !important;
  }
}

.public-mobile-footer a,
.public-mobile-footer button {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2px;
  padding: 8px 4px;
  text-decoration: none;
  color: #6b7280;
  font-size: 10px;
  font-weight: 600;
  background: transparent;
  border: none;
  cursor: pointer;
  transition: all 0.2s ease;
  text-align: center;
}

.public-mobile-footer a i,
.public-mobile-footer button i {
  font-size: 20px;
  line-height: 1;
}

.public-mobile-footer a:hover,
.public-mobile-footer button:hover {
  color: var(--primary-color, #1a5f2a);
  background: rgba(26, 95, 42, 0.08);
}

.public-mobile-footer a.active {
  color: var(--primary-color, #1a5f2a);
  border-top: 3px solid var(--primary-color, #1a5f2a);
  padding-top: 5px;
}

/* ─────────────────────────────────────────────────────────────
   MEMBER PORTAL: Mobile Footer
   ───────────────────────────────────────────────────────────── */

.member-mobile-footer {
  display: none;
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  height: 60px;
  background: #ffffff;
  border-top: 1px solid #e5e7eb;
  box-shadow: 0 -8px 24px rgba(15, 23, 42, 0.10);
  z-index: 45;
  justify-content: space-around;
  align-items: center;
}

@media (max-width: 768px) {
  .member-mobile-footer {
    display: flex !important;
  }

  body.has-member-footer {
    padding-bottom: 65px;
  }
}

.member-mobile-footer a {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2px;
  padding: 8px 4px;
  text-decoration: none;
  color: #6b7280;
  font-size: 10px;
  font-weight: 600;
  transition: all 0.2s ease;
}

.member-mobile-footer a i {
  font-size: 18px;
}

.member-mobile-footer a:hover,
.member-mobile-footer a.active {
  color: var(--primary-color, #1a5f2a);
  background: rgba(26, 95, 42, 0.08);
}

/* ─────────────────────────────────────────────────────────────
   MOBILE MENU ANIMATIONS
   ───────────────────────────────────────────────────────────── */

.mob-bn-item,
.public-mobile-footer a,
.member-mobile-footer a {
  position: relative;
  overflow: hidden;
}

.mob-bn-item::after,
.public-mobile-footer a::after,
.member-mobile-footer a::after {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: rgba(26, 95, 42, 0.05);
  transition: left 0.3s ease;
  z-index: -1;
}

.mob-bn-item:hover::after,
.public-mobile-footer a:hover::after,
.member-mobile-footer a:hover::after {
  left: 0;
}

/* ─────────────────────────────────────────────────────────────
   RESPONSIVE BREAKPOINTS
   ───────────────────────────────────────────────────────────── */

/* Small phones */
@media (max-width: 380px) {
  .mob-bn-item span,
  .public-mobile-footer a span,
  .member-mobile-footer a span {
    font-size: 9px;
  }

  .mob-bn-item i,
  .public-mobile-footer a i,
  .member-mobile-footer a i {
    font-size: 16px;
  }
}

/* Tablets */
@media (min-width: 769px) and (max-width: 899px) {
  .mob-bottomnav,
  .public-mobile-footer,
  .member-mobile-footer {
    display: none !important;
  }

  body.has-bottomnav,
  body.has-member-footer {
    padding-bottom: 0;
  }
}

/* Desktop */
@media (min-width: 900px) {
  .mob-bottomnav,
  .public-mobile-footer,
  .member-mobile-footer {
    display: none !important;
  }

  body.has-bottomnav,
  body.has-member-footer {
    padding-bottom: 0;
  }

  /* Burger menu not visible on desktop */
  .hp-burger {
    display: none !important;
  }
}

/* ─────────────────────────────────────────────────────────────
   MOBILE FAB (Floating Action Button) - Better positioning
   ───────────────────────────────────────────────────────────── */

.admin-fab-msg,
.public-fab-help {
  bottom: 75px !important;
  transition: bottom 0.3s ease;
}

@media (min-width: 900px) {
  .admin-fab-msg,
  .public-fab-help {
    bottom: 24px !important;
  }
}

/* Adjust for when both mobile footer and FAB are visible */
body.has-bottomnav .admin-fab-msg {
  bottom: 75px !important;
}

/* ─────────────────────────────────────────────────────────────
   SMOOTH TRANSITIONS
   ───────────────────────────────────────────────────────────── */

.mob-bottomnav,
.public-mobile-footer,
.member-mobile-footer,
.hp-burger {
  will-change: transform, opacity;
}

/* Print styles - hide mobile nav */
@media print {
  .mob-bottomnav,
  .public-mobile-footer,
  .member-mobile-footer,
  .admin-fab-msg,
  .public-fab-help {
    display: none !important;
  }

  body.has-bottomnav,
  body.has-member-footer {
    padding-bottom: 0;
  }
}

/* ========== mobile-comprehensive-fixes.css ========== */
/* ═══════════════════════════════════════════════════════════════════
   COMPREHENSIVE MOBILE MENU & UI IMPROVEMENTS
   Mobile navigation fixes, icon sizing, animations
   ═══════════════════════════════════════════════════════════════════ */

/* ─────────────────────────────────────────────────────────────────
   1. HAMBURGER MENU - Fixed visibility logic
   ───────────────────────────────────────────────────────────────── */

/* Desktop: Hide hamburger, show sidebar (≥769px) */
@media (min-width: 769px) {
  .hp-burger {
    display: none !important;
  }
  .adminSidebar {
    display: block !important;
    position: relative;
    transform: none !important;
    z-index: auto !important;
  }
}

/* Tablet: Show hamburger, sidebar hidden by default (481px - 768px) */
@media (max-width: 768px) {
  .hp-burger {
    display: grid !important;
    place-items: center;
    cursor: pointer;
    background: var(--hp-soft, #f8fafc);
    border: 1px solid var(--hp-border, #e2e8f0);
    border-radius: 10px;
    width: 40px;
    height: 40px;
    font-size: 16px;
    transition: all 0.2s ease;
  }

  .hp-burger:active,
  .hp-burger:focus {
    background: #e2e8f0;
    box-shadow: 0 0 0 3px rgba(26, 95, 42, 0.1);
    outline: none;
  }

  .hp-burger:hover {
    background: #e2e8f0;
    transform: scale(1.05);
  }

  /* Sidebar toggle animation on mobile */
  .adminSidebar {
    position: fixed;
    left: 0;
    top: 0;
    width: 280px;
    height: 100vh;
    z-index: 1000;
    transform: translateX(-100%);
    transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    background: white;
    box-shadow: 2px 0 8px rgba(0, 0, 0, 0.1);
  }

  .adminSidebar.open {
    transform: translateX(0);
    box-shadow: 2px 0 16px rgba(0, 0, 0, 0.15);
  }

  /* Overlay when sidebar is open */
  .adminSidebar.open::before {
    content: '';
    position: fixed;
    left: 280px;
    top: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.3);
    z-index: -1;
    animation: fadeIn 0.3s ease;
  }
}

/* Mobile: Optimize for very small screens (≤480px) */
@media (max-width: 480px) {
  .hp-burger {
    width: 38px;
    height: 38px;
    font-size: 15px;
  }

  .adminSidebar {
    width: 75vw;
  }
}

/* ─────────────────────────────────────────────────────────────────
   2. MOBILE BOTTOM NAVIGATION - Enhanced styling
   ───────────────────────────────────────────────────────────────── */

.mob-bottomnav {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  display: none;
  flex-wrap: nowrap;
  gap: 0;
  padding: 0;
  margin: 0;
  background: white;
  border-top: 1px solid #e2e8f0;
  z-index: 999;
  box-shadow: 0 -2px 8px rgba(0, 0, 0, 0.08);
}

@media (max-width: 768px) {
  .mob-bottomnav {
    display: flex;
  }

  body.has-bottomnav {
    padding-bottom: 70px;
  }
}

.mob-bn-item {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
  padding: 10px 8px;
  text-decoration: none;
  color: #64748b;
  font-size: 12px;
  font-weight: 500;
  transition: all 0.2s ease;
  border-radius: 0;
  position: relative;
  overflow: hidden;
}

.mob-bn-item:active {
  background: #f1f5f9;
}

.mob-bn-item.active {
  color: var(--primary-color, #1a5f2a);
  border-top: 3px solid var(--primary-color, #1a5f2a);
  padding-top: 7px;
}

.mob-bn-item i {
  font-size: 18px;
  transition: transform 0.2s ease;
}

.mob-bn-item:hover i {
  transform: scale(1.1);
}

.mob-bn-item span {
  line-height: 1.2;
  white-space: nowrap;
}

@media (max-width: 480px) {
  .mob-bn-item span {
    font-size: 10px;
  }

  .mob-bn-item i {
    font-size: 16px;
  }
}

/* ─────────────────────────────────────────────────────────────────
   3. ICON SIZING FIXES - Consistent across system
   ───────────────────────────────────────────────────────────────── */

/* Toggle icons: 1.25rem → 1rem */
.toggle-icon,
.icon-toggle,
[class*="toggle"] i,
.switch-icon {
  font-size: 1rem !important;
  transition: transform 0.2s ease;
}

/* Chat icons sizing */
.chat-icon,
.messenger-icon,
.admin-fab-msg i {
  font-size: 20px;
  transition: transform 0.2s ease;
}

.admin-fab-msg i:hover {
  transform: scale(1.1);
}

/* ─────────────────────────────────────────────────────────────────
   4. ANIMATION SPEED OPTIMIZATIONS
   ───────────────────────────────────────────────────────────────── */

/* AOS animations: 600ms → 900ms for smoothness */
[data-aos] {
  opacity: 0;
  animation-duration: 900ms !important;
  animation-fill-mode: both;
}

[data-aos].aos-animate {
  opacity: 1;
  animation-duration: 900ms !important;
}

/* Faster animations for micro-interactions */
.btn:active,
.card:active,
a:active {
  animation-duration: 150ms;
}

/* ─────────────────────────────────────────────────────────────────
   5. NEPALI TYPOGRAPHY IMPROVEMENTS
   ───────────────────────────────────────────────────────────────── */

/* Better Nepali text rendering */
.nepali-text,
[lang="ne"],
.verify-form label,
.public-content {
  line-height: 1.7;
  letter-spacing: 0.3px;
  font-family: 'Mukta', 'Noto Sans Devanagari', sans-serif;
}

/* Nepali headings */
h1, h2, h3, h4, h5, h6 {
  line-height: 1.4;
  letter-spacing: 0.2px;
}

/* Fix verify.php typography */
.verify-container,
.verify-form {
  font-size: 15px;
  line-height: 1.6;
}

.verify-form input,
.verify-form select,
.verify-form textarea {
  font-family: 'Mukta', sans-serif;
  font-size: 14px;
  line-height: 1.5;
}

/* ─────────────────────────────────────────────────────────────────
   6. QUICK LINKS & PUBLIC PAGE FIXES
   ───────────────────────────────────────────────────────────────── */

.quick-link,
.quick-links a,
.public-quick-actions {
  font-size: 14px;
  font-weight: 500;
  transition: all 0.2s ease;
}

.quick-link:hover {
  transform: translateY(-2px);
}

@media (max-width: 768px) {
  .quick-link {
    font-size: 13px;
  }
}

/* ─────────────────────────────────────────────────────────────────
   7. DESKTOP HOVER MENU STATES
   ───────────────────────────────────────────────────────────────── */

@media (min-width: 769px) {
  /* Desktop: Show full sidebar */
  .adminSidebar {
    display: block !important;
    position: relative;
    transform: none !important;
    width: 260px;
    height: auto;
    box-shadow: none;
  }

  /* Desktop menu hover effects */
  .sidebar-menu-item {
    transition: all 0.2s ease;
  }

  .sidebar-menu-item:hover {
    background: #f1f5f9;
    padding-left: 16px;
  }

  .sidebar-menu-item.active {
    background: var(--primary-color, #1a5f2a);
    color: white;
  }

  .sidebar-menu-item.active::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 4px;
    background: var(--primary-color, #1a5f2a);
  }
}

/* ─────────────────────────────────────────────────────────────────
   8. MOBILE FOOTER NAV - Added navigation icons
   ───────────────────────────────────────────────────────────────── */

@media (max-width: 768px) {
  .mobile-footer-nav {
    position: fixed;
    bottom: 70px;
    left: 0;
    right: 0;
    display: flex;
    gap: 8px;
    padding: 10px;
    background: white;
    border-top: 1px solid #e2e8f0;
    border-bottom: 1px solid #e2e8f0;
  }

  .mobile-footer-nav a {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 8px;
    border-radius: 8px;
    background: #f1f5f9;
    color: #475569;
    text-decoration: none;
    font-size: 13px;
    font-weight: 500;
    transition: all 0.2s ease;
  }

  .mobile-footer-nav a:active {
    background: #e2e8f0;
    transform: scale(0.95);
  }

  .mobile-footer-nav a i {
    font-size: 16px;
  }
}

/* ─────────────────────────────────────────────────────────────────
   9. SIDEBAR MOBILE MENU ITEMS - Better styling
   ───────────────────────────────────────────────────────────────── */

@media (max-width: 768px) {
  .adminSidebar .sidebar-section {
    padding: 12px 0;
    border-bottom: 1px solid #e2e8f0;
  }

  .adminSidebar .sidebar-section-title {
    padding: 8px 16px;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    color: #94a3b8;
    letter-spacing: 0.5px;
  }

  .adminSidebar .sidebar-menu-item {
    padding: 12px 16px;
    display: flex;
    align-items: center;
    gap: 12px;
    color: #475569;
    text-decoration: none;
    transition: all 0.2s ease;
    font-size: 14px;
    font-weight: 500;
  }

  .adminSidebar .sidebar-menu-item:hover {
    background: #f1f5f9;
    color: var(--primary-color, #1a5f2a);
    padding-left: 20px;
  }

  .adminSidebar .sidebar-menu-item.active {
    background: var(--primary-color, #1a5f2a);
    color: white;
  }

  .adminSidebar .sidebar-menu-item i {
    font-size: 16px;
    width: 20px;
    text-align: center;
  }
}

/* ─────────────────────────────────────────────────────────────────
   10. ACCESSIBILITY & TOUCH TARGETS
   ───────────────────────────────────────────────────────────────── */

@media (max-width: 768px) {
  /* Ensure all touch targets are at least 44x44px */
  button,
  a,
  input[type="checkbox"],
  input[type="radio"] {
    min-height: 44px;
    min-width: 44px;
  }

  /* Focus visible for keyboard navigation */
  a:focus-visible,
  button:focus-visible,
  input:focus-visible {
    outline: 2px solid var(--primary-color, #1a5f2a);
    outline-offset: 2px;
  }
}

/* ─────────────────────────────────────────────────────────────────
   11. FADE-IN ANIMATION
   ───────────────────────────────────────────────────────────────── */

@keyframes fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

@keyframes slideInFromLeft {
  from {
    transform: translateX(-100%);
  }
  to {
    transform: translateX(0);
  }
}

/* ─────────────────────────────────────────────────────────────────
   12. PRINT STYLES - Hide mobile nav in print
   ───────────────────────────────────────────────────────────────── */

@media print {
  .mob-bottomnav,
  .mobile-footer-nav,
  .admin-fab-msg,
  .hp-burger {
    display: none !important;
  }

  body.has-bottomnav {
    padding-bottom: 0;
  }
}

/* ========== coop-core.css ========== */
/**
 * ╔══════════════════════════════════════════════════════════════╗
 * ║  COOP CORE — नेपाली सहकारी Platform Unified CSS System     ║
 * ║  Version: 1.0 (Consolidated from 10 scattered CSS files)   ║
 * ║                                                              ║
 * ║  REPLACES:                                                   ║
 * ║   universal.css · global-unify-v2.css · ui-uniformity-fix   ║
 * ║   v9-mobile-fix · v10.6-mobile-audit · public-modern        ║
 * ║   site-banner-logo (partially) · header-v2 (partially)      ║
 * ║                                                              ║
 * ║  LOAD ORDER (in header):                                     ║
 * ║   1. Bootstrap                                               ║
 * ║   2. Google Fonts                                            ║
 * ║   3. Font Awesome                                            ║
 * ║   4. style.css (legacy public layout)                        ║
 * ║   5. design-tokens.css (brand variables)                     ║
 * ║   6. _color-vars.php  (admin dynamic color override)         ║
 * ║   7. THIS FILE  ← one file does the rest                    ║
 * ╚══════════════════════════════════════════════════════════════╝
 *
 * Architecture:
 *  - Section  1: Base reset + fonts
 *  - Section  2: Typography scale (cross-portal)
 *  - Section  3: Scrollbar
 *  - Section  4: Bootstrap overrides (btn, badge, alert, form)
 *  - Section  5: Cards
 *  - Section  6: Tables
 *  - Section  7: Page Banner (.page-banner)
 *  - Section  8: Section headers
 *  - Section  9: Forms
 *  - Section 10: Logo & brand mark
 *  - Section 11: Mobile drawer (public header)
 *  - Section 12: Admin panel integration
 *  - Section 13: Member portal integration
 *  - Section 14: Auth portal login pages
 *  - Section 15: Utility classes (.coop-*)
 *  - Section 16: Mobile-first responsive (all portals)
 *  - Section 17: Print
 */

/* ════════════════════════════════════════════════════════════════
   §1  BASE RESET + FONTS
   ════════════════════════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Mukta:wght@300;400;500;600;700;800&family=Noto+Sans+Devanagari:wght@300;400;500;600;700&display=swap');

html {
    font-size: 14px;
    scroll-behavior: smooth;
    -webkit-text-size-adjust: 100%;
}

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

body,
.mem-wrapper,
.main-content,
.admin-shell {
    font-family: var(--font-primary, 'Mukta', 'Noto Sans Devanagari', 'Segoe UI', sans-serif);
    background: var(--bg-page, #f8faf9);
    color: var(--text-primary, #1a2e1f);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
    font-feature-settings: "liga" 1, "kern" 1;
}

input, select, textarea, button {
    font-family: var(--font-primary, 'Mukta', 'Noto Sans Devanagari', 'Segoe UI', sans-serif);
}

a {
    color: var(--primary-color, #1a5f2a);
    transition: color .18s;
}
a:hover { color: var(--primary-dark, #144a21); }

/* White-on-dark contexts — inherit, don't override */
.btn-primary a, .bg-primary a,
header a, .mem-topbar a,
footer a, .site-footer a { color: inherit; }


/* ════════════════════════════════════════════════════════════════
   §2  TYPOGRAPHY SCALE — cross-portal consistent
   ════════════════════════════════════════════════════════════════ */
h1 { font-size: clamp(1.4rem, 3.5vw, 2rem);   font-weight: 700; line-height: 1.3;  }
h2 { font-size: clamp(1.2rem, 3vw, 1.6rem);   font-weight: 700; line-height: 1.35; }
h3 { font-size: clamp(1rem, 2.5vw, 1.3rem);   font-weight: 600; line-height: 1.4;  }
h4 { font-size: 1.05rem;                        font-weight: 600; }
h5 { font-size: .95rem;                         font-weight: 600; }
h6 { font-size: .88rem;                         font-weight: 600; }

/* Hero / slider headings restored LARGE after global h1 clamp */
.hero-title-modern,
.slider-content h1 {
    font-size: clamp(1.8rem, 5vw, 2.5rem);
    font-weight: 900;
    line-height: 1.2;
}


/* ════════════════════════════════════════════════════════════════
   §3  SCROLLBAR
   ════════════════════════════════════════════════════════════════ */
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: #f1f5f1; }
::-webkit-scrollbar-thumb {
    background: rgba(var(--primary-rgb, 26,95,42), .35);
    border-radius: 4px;
}
::-webkit-scrollbar-thumb:hover {
    background: rgba(var(--primary-rgb, 26,95,42), .6);
}


/* ════════════════════════════════════════════════════════════════
   §4  BOOTSTRAP OVERRIDES — brand palette, cross-portal
   Bootstrap overrides MUST use !important to beat compiled CSS.
   Group by component to keep audits manageable.
   ════════════════════════════════════════════════════════════════ */

/* — Primary button / bg — */
.btn-primary,
.bg-primary {
    background-color: var(--primary-color, #1a5f2a) !important;
    border-color: var(--primary-color, #1a5f2a) !important;
    color: var(--text-on-primary, #fff) !important;
}
.btn-primary:hover,
.btn-primary:focus,
.btn-primary:active {
    background-color: var(--primary-dark, #144a21) !important;
    border-color: var(--primary-dark, #144a21) !important;
    color: var(--text-on-primary, #fff) !important;
}
.btn-outline-primary {
    color: var(--primary-color, #1a5f2a) !important;
    border-color: var(--primary-color, #1a5f2a) !important;
    background: transparent !important;
}
.btn-outline-primary:hover,
.btn-outline-primary:focus {
    background-color: var(--primary-color, #1a5f2a) !important;
    color: var(--text-on-primary, #fff) !important;
}

/* — Secondary button — */
.btn-secondary,
.bg-secondary {
    background-color: var(--secondary-color, #c0392b) !important;
    border-color: var(--secondary-color, #c0392b) !important;
    color: #fff !important;
}
.btn-secondary:hover {
    background-color: var(--secondary-dark, #922b21) !important;
    border-color: var(--secondary-dark, #922b21) !important;
}

/* — Other button variants — */
.btn-info {
    background-color: #0e7490 !important;
    border-color: #0e7490 !important;
    color: #fff !important;
    background-image: none !important;
}
.btn-info:hover { background-color: #0a5a73 !important; border-color: #0a5a73 !important; }
.btn-warning {
    background-color: #b45309 !important;
    border-color: #b45309 !important;
    color: #fff !important;
    background-image: none !important;
}
.btn-warning:hover { background-color: #92400e !important; border-color: #92400e !important; }
.btn-danger {
    background-color: #b91c1c !important;
    border-color: #b91c1c !important;
    color: #fff !important;
    background-image: none !important;
}
.btn-danger:hover { background-color: #991b1b !important; border-color: #991b1b !important; }

.btn-outline-success  { color: var(--color-success, #28a745) !important; border-color: var(--color-success, #28a745) !important; background: transparent !important; }
.btn-outline-success:hover { background: var(--color-success, #28a745) !important; color: #fff !important; }
.btn-outline-info     { color: #0e7490 !important; border-color: #0e7490 !important; background: transparent !important; }
.btn-outline-info:hover  { background: #0e7490 !important; color: #fff !important; }
.btn-outline-warning  { color: #b45309 !important; border-color: #b45309 !important; background: transparent !important; }
.btn-outline-warning:hover { background: #b45309 !important; color: #fff !important; }
.btn-outline-danger   { color: #b91c1c !important; border-color: #b91c1c !important; background: transparent !important; }
.btn-outline-danger:hover  { background: #b91c1c !important; color: #fff !important; }

/* Global .btn polish */
.btn {
    font-family: inherit;
    font-weight: 600;
    border-radius: 8px;
    transition: all .18s ease;
}
.btn:focus-visible {
    box-shadow: 0 0 0 3px rgba(var(--primary-rgb, 26,95,42), .22);
    outline: none;
}

/* — Text utilities — */
.text-primary   { color: var(--primary-color, #1a5f2a) !important; }
.text-info      { color: #0e7490 !important; }
.text-warning   { color: #b45309 !important; }
.text-danger    { color: #b91c1c !important; }
.text-secondary { color: #475569 !important; }
.text-success   { color: var(--color-success, #28a745) !important; }
.text-muted     { color: var(--text-muted, #6b7280) !important; }

/* — BG utilities — */
.bg-info    { background-color: #0e7490 !important; color: #fff !important; }
.bg-warning { background-color: #b45309 !important; color: #fff !important; }
.bg-danger  { background-color: #b91c1c !important; color: #fff !important; }
.bg-success { background-color: var(--color-success, #28a745) !important; color: #fff !important; }

/* — Badges (soft pill style) — */
.badge {
    font-family: inherit;
    font-weight: 600;
    font-size: .72em;
    border-radius: 999px;
    padding: 4px 10px;
    letter-spacing: .02em;
}
.badge.bg-primary, .badge.bg-success {
    background: #f0fdf4 !important; color: var(--primary-color, #1a5f2a) !important;
    border: 1px solid #bbf7d0;
}
.badge.bg-secondary {
    background-color: var(--secondary-color, #c0392b) !important;
    color: #fff !important;
    border: none;
}
.badge.bg-info    { background: #ecfeff !important; color: #0e7490 !important; border: 1px solid #a5f3fc; }
.badge.bg-warning, .badge.bg-warning.text-dark { background: #fffbeb !important; color: #b45309 !important; border: 1px solid #fde68a; }
.badge.bg-danger  { background: #fef2f2 !important; color: #b91c1c !important; border: 1px solid #fecaca; }
.badge.bg-light   { background: #f8fafc !important; color: #334155 !important; border: 1px solid #e2e8f0; }
.badge.bg-dark    { background: #1e293b !important; color: #fff !important; border: 1px solid #1e293b; }

/* Status badges */
.badge-pending  { background: #fff3cd; color: #856404; border: 1px solid #ffe69c; }
.badge-approved { background: #d1e7dd; color: #155724; border: 1px solid #badbcc; }
.badge-rejected { background: #f8d7da; color: #842029; border: 1px solid #f5c2c7; }
.badge-review   { background: #cff4fc; color: #055160; border: 1px solid #b6effb; }

/* — Alerts (soft theme-aligned) — */
.alert {
    border-radius: 10px;
    font-size: .88rem;
    padding: 12px 14px;
    line-height: 1.55;
}
.alert-success,
.alert-primary  { background: #f0fdf4 !important; color: var(--primary-color, #1a5f2a) !important; border-color: #86efac !important; }
.alert-info     { background: #ecfeff !important; color: #0e7490 !important;  border-color: #a5f3fc !important; }
.alert-warning  { background: #fffbeb !important; color: #92400e !important;  border-color: #fde68a !important; }
.alert-danger   { background: #fef2f2 !important; color: #b91c1c !important;  border-color: #fecaca !important; }
.alert-secondary{ background: #f1f5f9 !important; color: #475569 !important;  border-color: #cbd5e1 !important; }
.alert-light    { background: #f8fafc !important; color: #334155 !important;  border-color: #e2e8f0 !important; }

/* — Form focus ring (cross-portal) — */
.form-control:focus,
.form-select:focus,
.form-check-input:focus,
.admin-input:focus,
.admin-select:focus,
.mem-form-control:focus {
    border-color: var(--primary-color, #1a5f2a) !important;
    box-shadow: 0 0 0 3px rgba(var(--primary-rgb, 26,95,42), .15) !important;
    outline: none !important;
}
.form-check-input:checked {
    background-color: var(--primary-color, #1a5f2a) !important;
    border-color: var(--primary-color, #1a5f2a) !important;
}

/* — Form controls — */
.form-control,
.form-select {
    font-family: inherit;
    font-size: .9rem;
    border-radius: 8px;
    border-color: var(--border-color, #d1d5db);
    background: #fafbfa;
    color: var(--text-primary, #1a2e1f);
    min-height: 42px;
    transition: border-color .18s, box-shadow .18s;
}
.form-label, label {
    font-size: .82rem;
    font-weight: 600;
    color: var(--text-secondary, #374151);
    margin-bottom: 4px;
}
/* Readonly / disabled */
.form-control[readonly],
.form-control:disabled,
.form-select:disabled {
    background: color-mix(in srgb, var(--primary-color, #1a5f2a) 5%, #f9fafb);
    color: var(--text-muted, #6b7280);
    border-style: dashed;
}

/* Checkboxes + switches */
.form-check {
    padding-left: 1.85em;
    min-height: 1.6rem;
    margin-bottom: .35rem;
}
.form-check .form-check-input { margin-left: -1.85em; margin-top: .2em; flex-shrink: 0; }
.form-check-label { cursor: pointer; line-height: 1.45; padding-left: 4px; }
.form-switch { padding-left: 2.8em; }
.form-switch .form-check-input { margin-left: -2.8em; width: 2.2em; height: 1.15em; margin-top: .15em; }

/* — Nav pills / tabs — */
.nav-pills .nav-link.active,
.nav-pills .show > .nav-link {
    background-color: var(--primary-color, #1a5f2a) !important;
    border-color: var(--primary-color, #1a5f2a) !important;
    color: var(--text-on-primary, #fff) !important;
}
/* Public + member tabs: filled (admin tabs scoped in admin-modern.css) */
body:not([class*="admin-page-"]) .nav-tabs .nav-link.active {
    background-color: var(--primary-color, #1a5f2a) !important;
    border-color: var(--primary-color, #1a5f2a) !important;
    color: var(--text-on-primary, #fff) !important;
}
.nav-link { color: var(--primary-color, #1a5f2a); }

/* — Pagination — */
.page-item.active .page-link {
    background-color: var(--primary-color, #1a5f2a) !important;
    border-color: var(--primary-color, #1a5f2a) !important;
    color: #fff !important;
}
.page-link { color: var(--primary-color, #1a5f2a); border-radius: 6px; }
.page-link:hover { background: color-mix(in srgb, var(--primary-color, #1a5f2a) 10%, white); }

/* — Progress / spinner — */
.progress-bar { background-color: var(--primary-color, #1a5f2a) !important; }
.spinner-border.text-primary,
.spinner-grow.text-primary { color: var(--primary-color, #1a5f2a) !important; }

/* — List group — */
.list-group-item.active {
    background-color: var(--primary-color, #1a5f2a);
    border-color: var(--primary-color, #1a5f2a);
}

/* — Modal — */
.modal-content { border-radius: 14px !important; border: none !important; }
.modal-header {
    background: linear-gradient(135deg, var(--primary-color, #1a5f2a), var(--primary-light, #2e8b4a)) !important;
    color: var(--text-on-primary, #fff) !important;
    border-radius: 14px 14px 0 0 !important;
}
.modal-header .btn-close { filter: invert(1) brightness(2); }
.modal-title { font-weight: 700 !important; }


/* ════════════════════════════════════════════════════════════════
   §5  CARDS — cross-portal uniform
   ════════════════════════════════════════════════════════════════ */
.card {
    border-radius: 12px;
    border-color: var(--border-color, #e5e7eb);
    box-shadow: 0 1px 4px rgba(0,0,0,.05), 0 4px 16px rgba(var(--primary-rgb, 26,95,42), .05);
    transition: box-shadow .25s, transform .25s;
}
.card:hover { box-shadow: var(--shadow-md, 0 4px 16px rgba(0,0,0,.10)); }
.card-header {
    background: color-mix(in srgb, var(--primary-color, #1a5f2a) 5%, white);
    border-bottom-color: var(--border-color, #e5e7eb);
    font-weight: 600;
    font-size: .9rem;
    border-radius: 12px 12px 0 0 !important;
}
.card-footer {
    background: color-mix(in srgb, var(--primary-color, #1a5f2a) 3%, white);
    border-top-color: var(--border-color, #e5e7eb);
    border-radius: 0 0 12px 12px !important;
}
.card-clickable {
    cursor: pointer; text-decoration: none; color: inherit; display: block;
}
.card-clickable:hover {
    transform: translateY(-3px);
    box-shadow: var(--shadow-lg, 0 8px 32px rgba(0,0,0,.12));
    color: inherit;
}

/* Coop card — custom variant */
.card-coop {
    background: var(--bg-card, #fff);
    border-radius: var(--radius-lg, 16px);
    box-shadow: var(--shadow-md, 0 4px 16px rgba(0,0,0,.08));
    padding: var(--space-lg, 24px);
    border: 1px solid var(--border-soft, #f0f0f0);
}


/* ════════════════════════════════════════════════════════════════
   §6  TABLES
   ════════════════════════════════════════════════════════════════ */
.table {
    font-size: .88rem;
    color: var(--text-primary, #1a2e1f);
}
.table thead th {
    font-size: .72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .04em;
    background: color-mix(in srgb, var(--primary-color, #1a5f2a) 8%, white);
    color: var(--primary-color, #1a5f2a);
    border-color: var(--border-color, #e5e7eb);
    padding: .7rem .9rem;
    white-space: nowrap;
}
.table td {
    padding: .65rem .9rem;
    vertical-align: middle;
    border-color: #f0f0f0;
}
.table-striped > tbody > tr:nth-of-type(odd) > * {
    background-color: rgba(var(--primary-rgb, 26,95,42), .025);
}
.table tbody tr:hover td {
    background: color-mix(in srgb, var(--primary-color, #1a5f2a) 4%, white);
}
/* Admin table head branded */
.admin-table thead th {
    background: var(--primary-color, #1a5f2a);
    color: var(--text-on-primary, #fff);
}

/* Responsive stack — mobile card rows (phone/narrow only; ≤768px) */
@media (max-width: 768px) {
    .table-responsive-stack thead { display: none; }
    .table-responsive-stack tbody td {
        display: flex;
        justify-content: space-between;
        padding: 8px 12px;
        font-size: .85rem;
        border-bottom: 1px solid var(--border-color, #e5e7eb);
    }
    .table-responsive-stack tbody td::before {
        content: attr(data-label);
        font-weight: 700;
        color: var(--text-muted, #6b7280);
        font-size: .72rem;
        text-transform: uppercase;
        letter-spacing: .04em;
        flex-shrink: 0;
        margin-right: 8px;
    }
    .table-responsive-stack tbody tr {
        display: block;
        margin-bottom: 8px;
        border: 1px solid var(--border-color, #e5e7eb);
        border-radius: 10px;
        background: var(--bg-card, #fff);
        box-shadow: 0 1px 4px rgba(0,0,0,.05);
    }
}


/* ════════════════════════════════════════════════════════════════
   §7  PAGE BANNER (.page-banner) — all inner pages
   ════════════════════════════════════════════════════════════════ */
.page-banner {
    background: linear-gradient(135deg, var(--primary-dark, #144a21) 0%, var(--primary-color, #1a5f2a) 100%);
    padding: 24px 0 28px;
    position: relative;
    overflow: hidden;
    text-align: center;
}
.page-banner::before {
    content: '';
    position: absolute; inset: 0;
    background: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none'%3E%3Cg fill='%23ffffff' fill-opacity='0.04'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
    pointer-events: none;
}
.page-banner::after {
    content: '';
    position: absolute; bottom: 0; left: 0; right: 0; height: 3px;
    background: linear-gradient(to right, transparent 0%, #c8860a 15%, #f5c518 40%, #ffd700 50%, #f5c518 60%, #c8860a 85%, transparent 100%);
}
.page-banner .container { position: relative; z-index: 1; }
.page-banner h1 {
    color: #fff;
    font-size: clamp(1.25rem, 3vw, 1.75rem);
    font-weight: 700;
    margin-bottom: 6px;
    text-shadow: 0 1px 6px rgba(0,0,0,.2);
}
.page-banner p { color: rgba(255,255,255,.8); margin-bottom: 0; }
.page-banner .breadcrumb { margin-bottom: 0; background: transparent; padding: 0; justify-content: center; }
.page-banner .breadcrumb-item { font-size: 12.5px; }
.page-banner .breadcrumb-item a { color: rgba(255,255,255,.8); text-decoration: none; transition: color .2s; }
.page-banner .breadcrumb-item a:hover { color: #fff; }
.page-banner .breadcrumb-item.active { color: rgba(255,255,255,.95); }
.page-banner .breadcrumb-item + .breadcrumb-item::before { color: rgba(255,255,255,.45); }


/* ════════════════════════════════════════════════════════════════
   §8  SECTION HEADERS — uniform across all pages
   ════════════════════════════════════════════════════════════════ */
.section-header,
.section-header-unified {
    margin-bottom: 2.25rem;
    text-align: center;
}
.section-header h2,
.section-header h3,
.section-header-unified h2 {
    font-weight: 800;
    color: var(--primary-dark, #144a21);
    margin-bottom: .4rem;
}
.section-header p,
.section-header-unified p {
    color: var(--text-muted, #6b7280);
    font-size: .97rem;
    max-width: 560px;
    margin-left: auto;
    margin-right: auto;
}
.section-header h2::after,
.section-header h3::after { display: none; }


/* ════════════════════════════════════════════════════════════════
   §9  FORMS — uniform field style
   ════════════════════════════════════════════════════════════════ */
.form-card {
    background: #fff;
    border: 1px solid var(--border-color, #e0e0e0);
    border-radius: var(--radius-lg, 16px);
    padding: 1.75rem;
    box-shadow: var(--shadow-sm, 0 1px 4px rgba(0,0,0,.08));
    margin-bottom: 1.5rem;
}
.form-card-title {
    font-size: 1rem;
    font-weight: 600;
    color: var(--primary-dark, #144a21);
    padding-bottom: .6rem;
    border-bottom: 2px solid #f0f8f2;
    margin-bottom: 1.2rem;
}
.form-card-title i { color: var(--primary-color, #1a5f2a); margin-right: .4rem; }

/* Coop field — custom variant */
.field-coop {
    width: 100%;
    padding: 11px 14px;
    border: 1.5px solid var(--border-color, #e5e7eb);
    border-radius: var(--radius-md, 10px);
    font-family: inherit;
    font-size: .95rem;
    background: #fafbfa;
    color: var(--text-primary, #1a2e1f);
    transition: border .2s, box-shadow .2s;
}
.field-coop:focus {
    outline: none;
    border-color: var(--primary-color, #1a5f2a);
    background: #fff;
    box-shadow: 0 0 0 3px rgba(var(--primary-rgb, 26,95,42), .12);
}

/* Prose / WYSIWYG content */
.coop-prose {
    max-width: 42rem;
    margin-inline: auto;
    font-size: 1.0625rem;
    line-height: 1.92;
    color: #3d3d3d;
    overflow-wrap: break-word;
}
.coop-prose p { margin-bottom: 1.05em; }
.coop-prose h1, .coop-prose h2, .coop-prose h3,
.coop-prose h4, .coop-prose h5, .coop-prose h6 {
    margin-top: 1.1em; margin-bottom: .5em;
    color: var(--primary-color, #1a5f2a);
}
.coop-prose ul, .coop-prose ol { padding-left: 1.25rem; margin-bottom: 1rem; }
.coop-prose blockquote {
    background: #f8f9fa;
    border-left: 4px solid var(--primary-color, #1a5f2a);
    padding: 1rem 1.25rem;
    margin: 1.25rem 0;
    border-radius: 0 var(--radius-md, 10px) var(--radius-md, 10px) 0;
    font-style: italic;
}
.coop-prose img { max-width: 100%; height: auto; border-radius: var(--radius-md, 10px); }
.coop-prose table { max-width: 100%; display: block; overflow-x: auto; }
.coop-prose--full { max-width: none; margin-inline: 0; }


/* ════════════════════════════════════════════════════════════════
   §10  LOGO & BRAND MARKS (cross-portal)
   ════════════════════════════════════════════════════════════════ */

/* Hide text when logo image is present */
.pfl-brand-content.has-logo .pfl-brand-text,
.mem-topbar-brand.has-logo .mem-brand-text,
.sidebar-brand.has-logo .sidebar-brand-text,
.admin-topbar-brand.has-logo .brand-text,
.footer-logo.has-logo .footer-sahakari-name { display: none; }

/* :has() fallback for same */
.pfl-brand-content:has(img.pfl-brand-logo) .pfl-brand-text,
.mem-topbar-brand:has(img) .mem-brand-text,
.admin-topbar-brand:has(img) .brand-text,
.sidebar-brand:has(img.sidebar-brand-logo) .sidebar-brand-text { display: none; }

.pfl-brand-content,
.mem-topbar-brand,
.sidebar-brand,
.admin-topbar-brand { display: flex; align-items: center; text-decoration: none; }
.pfl-brand-content { gap: 12px; min-width: 0; }
.pfl-brand-content.has-logo { gap: 0; }
.footer-logo.has-logo { gap: 0 !important; }

/* Fallback logo circles */
.pfl-brand-logo-fallback,
.mem-logo-fallback,
.admin-logo-fallback {
    width: 44px; height: 44px; border-radius: 12px;
    display: inline-flex; align-items: center; justify-content: center;
    background: rgba(var(--primary-rgb, 26,95,42), .12);
    color: var(--primary-color, #1a5f2a); font-size: 18px;
}

/* Sidebar brand */
.sidebar-brand { gap: 10px; color: #fff; }
.sidebar-brand:hover { color: #fff; opacity: .98; }
.sidebar-brand-logo {
    height: 48px; max-width: 100%; display: block;
    object-fit: contain; border-radius: 12px;
    background: rgba(255,255,255,.12); padding: 6px; width: auto;
}
.sidebar-brand-text, .admin-topbar-brand .brand-text { font-weight: 700; line-height: 1.1; }

/* Admin topbar brand */
.admin-topbar-brand { color: var(--primary-color, #1a5f2a); gap: 8px; }
.admin-topbar-brand:hover { color: var(--primary-color, #1a5f2a); }
.admin-topbar-brand img {
    height: 38px; border-radius: 10px;
    background: #f8fafc; padding: 4px;
    box-shadow: 0 1px 2px rgba(15,23,42,.08); width: auto; display: block;
}

/* Member topbar logo */
.mem-topbar-brand img {
    height: 42px; width: auto; max-width: 180px;
    border-radius: 8px; object-fit: contain;
    background: rgba(255,255,255,.12); padding: 4px;
    box-shadow: 0 2px 6px rgba(0,0,0,.15); flex-shrink: 0;
}

/* Public header logo (desktop + mobile) */
.pfl-brand-logo {
    height: auto; max-height: 56px;
    width: auto; object-fit: contain;
    object-position: left center;
}

/* Login panel logo */
.split-left .sl-logo {
    width: auto; min-width: 60px;
    height: auto; border-radius: 12px;
    padding: 6px 10px;
}
.split-left .sl-logo img {
    border-radius: 10px; width: auto;
    height: 68px; max-width: 200px;
    object-fit: contain;
}

/* Topbar / header strip */
.top-bar, .topbar, .header-top, .site-topbar, .quick-links-bar {
    background-color: var(--header-color, var(--secondary-color, #c0392b));
    color: var(--text-on-header, #fff);
}
.top-bar a, .topbar a, .header-top a, .site-topbar a, .quick-links-bar a { color: inherit; }

/* Footer */
footer, .site-footer, .footer, .footer-section {
    background-color: var(--footer-color, var(--primary-color, #1a5f2a));
    color: var(--text-on-footer, #fff);
}
footer a, .site-footer a, .footer a {
    color: color-mix(in srgb, var(--text-on-footer, #fff) 90%, transparent);
}
footer a:hover, .site-footer a:hover, .footer a:hover { color: var(--text-on-footer, #fff); }

/* Hero text safety */
.hero-title-modern,
.slider-content h1,
.hero-title-modern *,
.slider-content h1 * { color: #fff; text-shadow: 0 2px 12px rgba(0,0,0,.4); }
.hero-subtitle-modern,
.slider-content p { color: rgba(255,255,255,.92); }


/* ════════════════════════════════════════════════════════════════
   §11  PUBLIC MOBILE DRAWER
   ════════════════════════════════════════════════════════════════ */
@media (max-width: 991px) {
    /* Raise sticky header stacking context above backdrop */
    body.header-v2 .pfl-header-wrapper { z-index: 200020; }
    body.header-v2 .pfl-main-header,
    body.header-v2 .pfl-nav-area { position: relative; z-index: 200021; }
    body.mobile-nav-open.header-v2 .pfl-top-bar { pointer-events: none; }
    body.mobile-nav-open.header-v2 .pfl-nav-area,
    body.mobile-nav-open.header-v2 #mainNavV2 { pointer-events: auto; }

    .pfl-main-header { position: sticky; top: 0; z-index: 2000; background: #fff; }
    .pfl-brand-area {
        padding: 10px 12px;
        min-width: 0; flex: 1 1 auto;
        max-width: calc(100% - 58px);
    }
    .pfl-brand-logo {
        max-height: 50px;
        max-width: min(calc(100vw - 88px), 380px);
    }
    .pfl-nav-area {
        width: auto; flex: 0 0 auto;
        margin-left: auto; background: transparent;
    }
    .pfl-mobile-toggle {
        display: inline-flex; align-items: center; justify-content: center;
        width: 44px; height: 44px; border-radius: 12px; flex-shrink: 0;
    }

    /* Drawer — dark green branded (matches admin sidebar) */
    body.header-v2 .pfl-nav-area .main-nav,
    body.header-v2 nav.main-nav,
    body.header-v2 #mainNavV2,
    body.header-v2 #mainNav {
        position: fixed; top: 0; left: 0; right: auto;
        width: min(86vw, 320px); max-width: 320px;
        height: 100dvh;
        transform: translate3d(-110%, 0, 0);
        transition: transform .28s ease;
        z-index: 200010;
        background: linear-gradient(180deg, var(--primary-dark, #114b1e) 0%, var(--primary-color, #1a5f2a) 100%);
        box-shadow: 4px 0 28px rgba(0,0,0,.35);
        padding: 0 0 88px; overflow-y: auto; overflow-x: hidden;
        color: #fff; display: flex; flex-direction: column;
        will-change: transform;
    }
    body.header-v2 .pfl-nav-area .main-nav.nav-open,
    body.header-v2 .pfl-nav-area .main-nav.open,
    body.header-v2 .pfl-nav-area .main-nav.active,
    body.header-v2 nav.main-nav.nav-open, body.header-v2 nav.main-nav.open,
    body.header-v2 nav.main-nav.active,
    body.header-v2 #mainNavV2.nav-open, body.header-v2 #mainNavV2.open,
    body.header-v2 #mainNavV2.active,
    body.header-v2 #mainNav.nav-open, body.header-v2 #mainNav.open,
    body.header-v2 #mainNav.active {
        transform: translate3d(0, 0, 0);
    }

    /* Logo banner at top of drawer */
    body.header-v2 .main-nav::before {
        content: '';
        display: block; height: 96px; margin: 0 0 8px;
        background-color: rgba(0,0,0,.22);
        background-image: var(--pfl-mobile-logo);
        background-repeat: no-repeat;
        background-position: 16px center;
        background-size: auto 56px;
        border-bottom: 1px solid rgba(255,255,255,.14);
        flex-shrink: 0;
    }
    /* Close button */
    body.header-v2 .main-nav .close-menu {
        display: inline-flex; position: absolute;
        top: 18px; right: 14px;
        width: 38px; height: 38px;
        align-items: center; justify-content: center;
        border: none; border-radius: 50%;
        background: rgba(255,255,255,.20); color: #fff;
        z-index: 3; cursor: pointer; font-size: 18px;
        transition: background .18s;
    }
    body.header-v2 .main-nav .close-menu:hover { background: rgba(255,255,255,.32); }

    /* Backdrop */
    .menu-overlay, .mobile-nav-backdrop {
        position: fixed; inset: 0;
        background: rgba(15,23,42,.55);
        opacity: 0; visibility: hidden;
        transition: opacity .25s ease, visibility .25s ease;
        z-index: 200000; pointer-events: none;
    }
    .menu-overlay.active, .mobile-nav-backdrop.active {
        opacity: 1; visibility: visible; display: block; pointer-events: auto;
    }

    /* Menu list */
    body.header-v2 .main-nav .nav-menu {
        display: flex; flex-direction: column; gap: 2px;
        padding: 8px 10px; list-style: none; margin: 0;
        width: 100%; background: transparent;
    }
    body.header-v2 .main-nav .nav-menu > li { width: 100%; background: transparent; }
    body.header-v2 .main-nav .nav-menu > li > a,
    body.header-v2 .pfl-nav-area .nav-menu > li > a,
    body.header-v2 .pfl-nav-area .nav-menu > li.active > a {
        display: flex; align-items: center; justify-content: space-between;
        min-height: 44px; padding: 12px 14px;
        color: #fff; background: transparent; text-decoration: none;
        border-radius: 10px; font-weight: 600; font-size: .95rem;
        transition: background .15s, color .15s;
    }
    body.header-v2 .main-nav .nav-menu > li > a:hover,
    body.header-v2 .pfl-nav-area .nav-menu > li > a:hover {
        background: rgba(255,255,255,.12); color: #fff;
    }
    body.header-v2 .main-nav .nav-menu > li.active > a,
    body.header-v2 .pfl-nav-area .nav-menu > li.active > a {
        background: rgba(255,255,255,.18);
        border-left: 3px solid #f5c518;
        padding-left: 11px;
    }
    body.header-v2 .main-nav .nav-menu > li > a::after,
    body.header-v2 .pfl-nav-area .nav-menu > li > a::after { display: none; content: none; }

    /* Chevron */
    body.header-v2 .main-nav .nav-menu > li > a > i.fa-chevron-down {
        transition: transform .22s ease; font-size: .72rem;
        margin-left: auto; opacity: .8; color: rgba(255,255,255,.9);
    }
    body.header-v2 .main-nav .nav-menu .has-dropdown.open > a > i.fa-chevron-down,
    body.header-v2 .main-nav .nav-menu .has-sub.open > a > i.fa-chevron-down {
        transform: rotate(180deg); color: #f5c518;
    }

    /* Sub-menu */
    body.header-v2 .main-nav .nav-menu .dropdown,
    body.header-v2 .main-nav .nav-menu .sub-menu {
        position: static; display: none; width: 100%;
        margin: 4px 0 6px; padding: 4px 0;
        background: rgba(0,0,0,.28); border-radius: 10px;
        list-style: none; box-shadow: none; border: 0;
    }
    body.header-v2 .main-nav .nav-menu .has-dropdown.open > .dropdown,
    body.header-v2 .main-nav .nav-menu .has-sub.open > .sub-menu { display: block; padding: 6px 0; }
    body.header-v2 .main-nav .nav-menu .dropdown li a,
    body.header-v2 .main-nav .nav-menu .sub-menu li a {
        display: flex; align-items: center; gap: 10px;
        padding: 10px 14px 10px 30px;
        color: rgba(255,255,255,.88); background: transparent;
        font-size: .87rem; font-weight: 500; text-decoration: none;
    }
    body.header-v2 .main-nav .nav-menu .dropdown li a i,
    body.header-v2 .main-nav .nav-menu .sub-menu li a i { color: #f5c518; width: 16px; font-size: .8rem; }
    body.header-v2 .main-nav .nav-menu .dropdown li a:hover,
    body.header-v2 .main-nav .nav-menu .sub-menu li a:hover { background: rgba(255,255,255,.12); color: #fff; }
}


/* ════════════════════════════════════════════════════════════════
   §12  ADMIN PANEL
   ════════════════════════════════════════════════════════════════ */
body.admin-nav-open { overflow: hidden; }

/* Admin sidebar active */
.sidebar-nav li.active > a,
.sidebar-nav a.active,
.sidebar-nav a:hover { color: var(--primary-color, #1a5f2a); }
.sidebar-nav li.active > a,
.sidebar-nav a.active { background: color-mix(in srgb, var(--primary-color, #1a5f2a) 10%, white); }

/* Nepali datepicker */
.ndp-container .ndp-header,
.ndp-calendar .ndp-nav-header,
.nepali-datepicker-calendar .header {
    background: var(--primary-color, #1a5f2a) !important; color: #fff !important;
}
.ndp-container .ndp-header *,
.ndp-calendar .ndp-nav-header * { color: #fff !important; opacity: 1 !important; }
.ndp-container .ndp-header select,
.ndp-calendar .ndp-nav-header select {
    background: #fff !important; color: #14532d !important;
    border: 1px solid rgba(20,83,45,.25) !important; border-radius: 8px !important;
}


/* ════════════════════════════════════════════════════════════════
   §13  MEMBER PORTAL
   ════════════════════════════════════════════════════════════════ */
body.mem-wrapper { background: #f6faf7; margin: 0; }
.mem-container { max-width: 1200px; margin: 0 auto; padding: 20px 16px 100px; }
.mem-stats {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: 12px; margin: 0 0 18px; padding: 0; list-style: none;
}


/* ════════════════════════════════════════════════════════════════
   §14  AUTH PORTAL PAGES — login, verify
   ════════════════════════════════════════════════════════════════ */
body.auth-portal-page {
    background: var(--bg-page) !important;
    color: var(--text-primary);
    -webkit-font-smoothing: antialiased;
    --auth-icon-size:  68px;
    --auth-icon-font:  1.55rem;
    --auth-title-size: 1.05rem;
    --auth-sub-size:   0.78rem;
    --auth-tab-height: 38px;
}

body.auth-portal-page .split-wrap {
    width: min(1020px, calc(100% - 52px));
    height: min(760px, calc(100dvh - 16px));
    margin: 8px auto; border-radius: 14px; overflow: hidden;
    border: 1px solid rgba(148,163,184,.24);
    background: #fff; box-shadow: 0 22px 46px rgba(15,23,42,.13);
    grid-template-columns: .94fr 1.06fr;
}
body.auth-portal-page .card-logo-icon,
body.auth-portal-page .vp-page-logo-icon {
    width: 68px; height: 68px; min-width: 68px;
    border-radius: 50%; margin: 0 auto .65rem;
    background: var(--primary-color) !important;
    color: var(--text-on-primary) !important;
    font-size: 1.55rem;
    box-shadow: 0 4px 16px rgba(var(--primary-rgb), .22);
}
body.auth-portal-page .submit-btn,
body.auth-portal-page .vp-btn {
    min-height: 44px; width: 100%;
    border-radius: 10px; font-size: .92rem;
    font-weight: 700; border: none;
    color: var(--text-on-primary) !important;
    background: var(--primary-color) !important;
    box-shadow: 0 2px 10px rgba(var(--primary-rgb), .2);
    transition: background .18s, box-shadow .18s, transform .12s;
}
body.auth-portal-page .submit-btn:hover,
body.auth-portal-page .vp-btn:hover {
    background: var(--primary-dark) !important;
    box-shadow: 0 4px 14px rgba(var(--primary-rgb), .26);
    transform: translateY(-1px);
}
body.auth-portal-page .field input:focus,
body.auth-portal-page .vp-field input:focus {
    border-color: var(--primary-color) !important;
    background: var(--bg-card) !important;
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--primary-color) 18%, transparent) !important;
}
body.auth-portal-page.verify-auth-page {
    min-height: 100dvh; display: flex;
    align-items: center; justify-content: center; padding: 20px 12px;
}
body.auth-portal-page.verify-auth-page .vp-outer { width: 100%; max-width: 560px; margin: 0 auto; }

@media (max-width: 900px) {
    body.auth-portal-page .split-wrap {
        width: 100%; height: auto; margin: 0;
        border-radius: 0; border: 0; box-shadow: none;
        grid-template-columns: 1fr;
    }
}
@media (max-width: 768px) {
    body.auth-portal-page.verify-auth-page { align-items: flex-start; padding-top: 14px; }
}

/* Language toggle + back button */
body.auth-portal-page:not(.verify-auth-page) .page-back,
body.auth-portal-page:not(.verify-auth-page) .auth-lang-toggle {
    position: fixed; top: 18px; z-index: 20;
    display: inline-flex; align-items: center; gap: 6px;
    padding: 7px 15px; border-radius: 999px;
    font-size: .78rem; font-weight: 700;
    background: color-mix(in srgb, var(--bg-card) 92%, transparent);
    backdrop-filter: blur(8px);
    border: 1px solid var(--border-color);
    color: var(--primary-color); text-decoration: none;
    box-shadow: 0 1px 6px color-mix(in srgb, var(--text-primary) 8%, transparent);
    transition: background .15s, transform .15s;
}
body.auth-portal-page:not(.verify-auth-page) .page-back { right: 20px; }
body.auth-portal-page:not(.verify-auth-page) .auth-lang-toggle { left: 20px; }


/* ════════════════════════════════════════════════════════════════
   §15  UTILITY CLASSES (.coop-*)
   ════════════════════════════════════════════════════════════════ */
/* Display & flex */
.coop-flex          { display: flex; }
.coop-flex-col      { display: flex; flex-direction: column; }
.coop-flex-wrap     { display: flex; flex-wrap: wrap; }
.coop-grid          { display: grid; }
.coop-inline        { display: inline-flex; align-items: center; }
.coop-items-center  { align-items: center; }
.coop-justify-between { justify-content: space-between; }
.coop-justify-center  { justify-content: center; }

/* Gap */
.coop-gap-xs { gap: 4px; } .coop-gap-sm { gap: 8px; }
.coop-gap-md { gap: 16px; } .coop-gap-lg { gap: 24px; }

/* Margin */
.coop-mt-sm { margin-top: 8px; }  .coop-mt-md { margin-top: 16px; }  .coop-mt-lg { margin-top: 24px; }
.coop-mb-sm { margin-bottom: 8px; }.coop-mb-md { margin-bottom: 16px; }.coop-mb-lg { margin-bottom: 24px; }

/* Text */
.coop-text-primary   { color: var(--primary-color, #1a5f2a); }
.coop-text-secondary { color: var(--text-secondary, #4a5a4f); }
.coop-text-muted     { color: var(--text-muted, #6b7280); }
.coop-text-danger    { color: var(--color-danger, #dc3545); }
.coop-text-sm        { font-size: .85rem; }
.coop-text-xs        { font-size: .75rem; }
.coop-font-bold      { font-weight: 700; }
.coop-font-medium    { font-weight: 500; }
.text-primary-dark   { color: var(--primary-dark, #144a21); }
.text-nepali         { font-family: var(--font-nepali, 'Noto Sans Devanagari', 'Mukta', sans-serif); }

/* Background */
.coop-bg-soft  { background: var(--bg-soft, #f5faf6); }
.coop-bg-muted { background: var(--bg-muted, #e8f5e9); }
.coop-bg-card  { background: var(--bg-card, #fff); }

/* Borders */
.coop-rounded    { border-radius: var(--radius-md, 10px); }
.coop-rounded-lg { border-radius: var(--radius-lg, 16px); }
.coop-bordered   { border: 1px solid var(--border-color, #e5e7eb); }
.coop-w-full     { width: 100%; }

/* Section spacing */
.section-py    { padding-top: var(--space-2xl, 64px); padding-bottom: var(--space-2xl, 64px); }
.section-py-sm { padding-top: var(--space-xl, 40px);  padding-bottom: var(--space-xl, 40px);  }
.section-spacing { margin-bottom: 2rem; }

/* Code / ID chips */
.coop-code {
    font-family: 'Courier New', ui-monospace, monospace;
    background: var(--bg-soft, #f5faf6);
    padding: 4px 10px; border-radius: 6px;
    font-size: .85rem; color: var(--text-primary, #1a2e1f);
    letter-spacing: .5px;
}
.coop-id-badge {
    font-family: 'Courier New', monospace;
    font-size: .85rem; letter-spacing: 2px;
    color: var(--primary-color, #1a5f2a); font-weight: 600;
}

/* Empty state */
.empty-state { text-align: center; padding: 3rem 1rem; color: #aaa; }
.empty-state i { font-size: 3rem; opacity: .35; display: block; margin-bottom: .75rem; }
.empty-state p { font-size: .88rem; margin-bottom: 1rem; }

/* Loading overlay */
.loading-overlay {
    position: fixed; inset: 0; background: rgba(255,255,255,.85);
    display: flex; align-items: center; justify-content: center;
    z-index: 9999; flex-direction: column; gap: 12px;
}
.loading-overlay .spinner-border { color: var(--primary-color, #1a5f2a); width: 2.5rem; height: 2.5rem; }

/* Custom buttons */
.btn-coop {
    display: inline-flex; align-items: center; justify-content: center; gap: 8px;
    padding: 10px 22px; border-radius: var(--radius-md, 10px);
    font-family: inherit; font-weight: 600; font-size: .95rem;
    border: none; cursor: pointer; text-decoration: none;
    background: var(--primary-color, #1a5f2a); color: var(--text-on-primary, #fff);
    transition: all .25s ease; box-shadow: var(--shadow-sm, 0 1px 4px rgba(0,0,0,.08));
}
.btn-coop:hover {
    background: var(--primary-dark, #144a21);
    box-shadow: var(--shadow-primary, 0 4px 20px rgba(26,95,42,.16));
    transform: translateY(-1px); color: var(--text-on-primary, #fff);
}
.btn-coop.btn-outline {
    background: transparent; color: var(--primary-color, #1a5f2a);
    border: 1.5px solid var(--primary-color, #1a5f2a); box-shadow: none;
}
.btn-coop.btn-outline:hover { background: var(--primary-color, #1a5f2a); color: #fff; }

/* Divider */
.divider-icon {
    display: flex; align-items: center; gap: .75rem;
    color: #ccc; font-size: .8rem; margin: 1.2rem 0;
}
.divider-icon::before, .divider-icon::after { content: ''; flex: 1; height: 1px; background: #e5e7eb; }

/* Floating widget stacking */
@media (max-width: 480px) {
    .whatsapp-float        { bottom: 20px  !important; right: 10px !important; z-index: 9990; }
    .chatbot-widget        { bottom: 84px  !important; right: 10px !important; z-index: 9989; }
    .useful-links-widget   { bottom: 20px  !important; left:  10px !important; z-index: 9988; }
    .satisfaction-widget   { bottom: 148px !important; right: 10px !important; z-index: 9986; }
}


/* ════════════════════════════════════════════════════════════════
   §16  MOBILE-FIRST RESPONSIVE
   ════════════════════════════════════════════════════════════════ */

/* § 16a — Admin mobile */
@media (max-width: 991px) {
    .sidebar {
        width: min(86vw, 320px); max-width: 320px;
        z-index: 1200; box-shadow: 0 18px 42px rgba(15,23,42,.14);
    }
    .sidebar.active { transform: translateX(0) !important; }
    .sidebar-overlay {
        position: fixed; inset: 0; background: rgba(15,23,42,.5);
        z-index: 1100; display: block; opacity: 0; visibility: hidden;
        transition: opacity .25s, visibility .25s;
    }
    .sidebar-overlay.active { opacity: 1; visibility: visible; }
    .main-content { margin-left: 0 !important; width: 100%; }
    .admin-header {
        padding: 10px 12px; min-height: 60px; height: auto;
        gap: 10px; z-index: 1100;
    }
    .page-content { padding: 14px 14px 88px; }
    .header-left { gap: 10px; min-width: 0; flex: 1 1 auto; }
    .page-title { font-size: 1rem; max-width: 54vw; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
    .sidebar-backdrop {
        position: fixed; inset: 0; background: rgba(0,0,0,.45);
        z-index: 1040; opacity: 0; pointer-events: none; transition: opacity .2s;
    }
    .sidebar-backdrop.show { opacity: 1; pointer-events: auto; }
}

/* § 16b — Member mobile */
@media (max-width: 991px) {
    .mem-topbar { padding: 10px 12px; gap: 10px; }
    .mem-topbar-brand { flex: 1 1 auto; min-width: 0; }
    .mem-topbar-right { gap: 8px; }
    .mem-topbar-name  { display: none; }
    .mem-topbar-btn {
        width: 40px; height: 40px; border-radius: 12px;
        padding: 0; display: inline-flex; align-items: center; justify-content: center; font-size: 0;
    }
    .mem-topbar-btn i { font-size: 1rem; margin: 0; }
    .bell-dropdown { width: min(92vw, 360px); max-width: 92vw; right: 0; left: auto; }
    .mem-container { padding: 14px 12px 88px; }

    /* Bottom nav (mobile app feel) */
    .mem-nav {
        display: flex !important; position: fixed;
        left: 0; right: 0; bottom: 0; z-index: 1000;
        margin: 0; border-radius: 16px 16px 0 0;
        box-shadow: 0 -4px 20px rgba(15,23,42,.14);
        padding: 5px 4px calc(5px + env(safe-area-inset-bottom));
        overflow-x: auto; overflow-y: hidden;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
        flex-wrap: nowrap; gap: 1px;
    }
    .mem-nav::-webkit-scrollbar { display: none; }
    .mem-nav-item { flex: 0 0 auto; min-width: 48px; padding: 5px 10px; font-size: .6rem; }
    .mem-nav-item i { font-size: .9rem; }
    .mp-bottom-nav { display: none !important; }
    .mem-stats { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

/* § 16c — All portals (small screens) */
@media (max-width: 767px) {
    /* iOS input zoom prevention */
    input[type="text"], input[type="email"], input[type="password"],
    input[type="tel"], input[type="number"], input[type="search"],
    input[type="url"], input[type="date"], input[type="datetime-local"],
    input[type="time"], select, textarea,
    .form-control, .form-select { font-size: 16px !important; }

    /* Universal table horizontal scroll */
    main table:not(.no-mobile-scroll),
    .container table:not(.no-mobile-scroll),
    .card-body > table:not(.no-mobile-scroll) {
        display: block; max-width: 100%;
        overflow-x: auto; -webkit-overflow-scrolling: touch; white-space: nowrap;
    }
    /* Image overflow safety */
    main img:not([width]), article img:not([width]),
    .content img:not([width]), .card img:not([width]),
    .news-content img, .page-content img {
        max-width: 100% !important; height: auto !important;
    }
    /* Tap targets WCAG 2.1 */
    .btn:not(.btn-sm):not(.btn-link),
    .nav-link, .dropdown-item, .pagination .page-link {
        min-height: 44px; display: inline-flex;
        align-items: center; justify-content: center;
    }
    /* Page banner */
    .page-banner { padding: 18px 0 22px; }
    .page-banner h1 { font-size: 1.25rem; }
    .section-header h2 { font-size: 1.35rem; }
    .form-card { padding: 1.1rem; }

    /* v9 table scroll wrapper */
    .v9-table-scroll { width: 100%; overflow-x: auto; -webkit-overflow-scrolling: touch; }
    .v9-table-scroll > table { min-width: 560px; }

    h1 { font-size: 1.35rem; }
    h2 { font-size: 1.15rem; }
    .hero-title-modern, .slider-content h1 { font-size: 2rem; }
}

@media (max-width: 575px) {
    /* Admin */
    .admin-topbar-brand .brand-text,
    .header-date-pill, .admin-name { display: none; }
    .page-title { max-width: 58vw; }
    .sidebar-brand-logo { height: 44px; }

    /* Modal full-height */
    .modal-dialog { margin: 8px !important; max-width: calc(100vw - 16px) !important; }
    .modal-content { max-height: calc(100vh - 16px); }
    .modal-body { max-height: calc(100vh - 140px); overflow-y: auto; -webkit-overflow-scrolling: touch; }
    .modal-footer { flex-wrap: wrap; gap: 6px; }
    .modal-footer .btn { flex: 1 1 auto; min-width: 0; }

    .page-banner { padding: 14px 0 18px; }
    .section-py { padding-top: 2rem; padding-bottom: 2rem; }
    .hero-title-modern, .slider-content h1 { font-size: 1.8rem; }

    /* Long text break */
    .text-truncate-mobile, .member-id, .card-number,
    code, .badge, .breadcrumb-item { word-break: break-word; overflow-wrap: anywhere; }

    /* Bootstrap rows */
    .container, .container-fluid { padding-left: 12px !important; padding-right: 12px !important; }
}

@media (max-width: 480px) {
    /* Card grids — single column */
    .row-cols-2 > [class*="col-"] { flex: 0 0 100%; max-width: 100%; }
    /* ID Card */
    .member-id-card, .id-card-front, .id-card-back {
        max-width: 100% !important; margin-left: auto !important;
        margin-right: auto !important; transform: none !important;
    }
    .id-card-actions { flex-direction: column; gap: 8px; }
    .id-card-actions .btn { width: 100%; }
    /* Datepicker */
    .datepicker, .nepali-datepicker, .ui-datepicker {
        max-width: calc(100vw - 16px) !important;
        left: 8px !important; right: 8px !important;
    }
    /* Toast */
    .toast-container, .alert-floating {
        left: 8px !important; right: 8px !important;
        max-width: calc(100vw - 16px) !important;
    }
}

@media (max-width: 360px) {
    .container, .container-fluid, .container-sm { padding-left: 10px !important; padding-right: 10px !important; }
    .row { margin-left: -8px; margin-right: -8px; }
    .row > [class*="col-"] { padding-left: 8px; padding-right: 8px; }
}


/* ════════════════════════════════════════════════════════════════
   §18  STF-* SHARED COMPONENT CLASSES  (HRM / Staff forms)
   ────────────────────────────────────────────────────────────────
   Defined here (shared) so any admin page — whether it includes
   admin-modern.css or not — gets these classes. admin-modern.css
   still contains its own copy for legacy load-order safety, but
   these take precedence when coop-core.css loads first.
   ════════════════════════════════════════════════════════════════ */

/* ── Page head row ─────────────────────────────────────────────── */
.stf-page-head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 10px;
    margin-bottom: 24px;
}

/* ── Headings ───────────────────────────────────────────────────── */
.stf-title {
    margin: 0;
    color: var(--primary-color, #1a5f2a);
}
.stf-subtitle {
    color: var(--text-muted, #6b7280);
    margin: 6px 0 0;
    font-size: .88rem;
}
.stf-section-title {
    color: var(--primary-color, #1a5f2a);
    margin-top: 0;
}

/* ── Table helpers ─────────────────────────────────────────────── */
.stf-card-table-wrap {
    padding: 0;
    overflow: hidden;
}
.stf-table {
    font-family: var(--font-primary, 'Mukta', 'Noto Sans Devanagari', sans-serif);
    font-size: .875rem;
}
.stf-table-no-margin { margin: 0; }
.stf-soft-head       { background: var(--bg-soft, #f5faf6); }
.stf-align-right     { text-align: right; }

/* ── Status dots ───────────────────────────────────────────────── */
.stf-status-dot      { font-weight: 600; }
.stf-status-active   { color: var(--color-success, #28a745); }
.stf-status-inactive { color: var(--color-danger,  #dc3545); }

/* ── Misc utilities ────────────────────────────────────────────── */
.stf-inline-form { display: inline; }
.stf-self-note   { color: var(--text-muted, #6b7280); font-size: .82rem; }
.stf-muted-note  { color: var(--text-muted, #6b7280); font-size: .82rem; }
.stf-mt24        { margin-top: 24px; }
.stf-grid-gap    { display: grid; gap: 12px; }

/* ── Modal backdrop ────────────────────────────────────────────── */
.stf-modal-backdrop {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, .52);
    z-index: 9999;
    align-items: center;
    justify-content: center;
    padding: 16px;
    overflow-y: auto;
}
/* JS opens the modal by setting display:flex */
.stf-modal-backdrop[style*="flex"],
.stf-modal-backdrop.open {
    display: flex !important;
}

/* ── Modal card sizes ──────────────────────────────────────────── */
.stf-modal-card {
    width: 92%;
    max-width: 520px;
    background: var(--bg-card, #fff);
    border-radius: var(--radius-md, 10px);
    padding: 24px;
    box-shadow: 0 12px 40px rgba(0, 0, 0, .16);
    position: relative;
}
.stf-modal-card-lg { max-width: 880px; }
.stf-modal-card-sm { max-width: 420px; }

/* ── Action rows (buttons at bottom of form) ───────────────────── */
.stf-actions-row {
    display: flex;
    gap: 10px;
    justify-content: flex-end;
    flex-wrap: wrap;
}
.stf-actions-row-lg { margin-top: 18px; }
.stf-actions-row-sm { margin-top: 14px; }

/* ── Responsive: full-width modals on very small screens ───────── */
@media (max-width: 480px) {
    .stf-modal-card,
    .stf-modal-card-lg,
    .stf-modal-card-sm {
        width: 100%;
        max-width: 100%;
        border-radius: var(--radius-sm, 6px);
        padding: 16px;
    }
    .stf-actions-row { flex-direction: column-reverse; }
    .stf-actions-row .btn-coop,
    .stf-actions-row button { width: 100%; justify-content: center; }
}

/* ════════════════════════════════════════════════════════════════
   §17  PRINT
   ════════════════════════════════════════════════════════════════ */
@media print {
    .no-print,
    .coop-no-print,
    .page-banner,
    header, footer,
    .whatsapp-float,
    .scroll-to-top,
    nav,
    .mem-topbar,
    .mem-nav,
    .mp-bottom-nav,
    .admin-sidebar,
    .sidebar,
    .alert-dismissible .btn-close { display: none !important; }
    body { font-size: 12pt; color: #000; background: #fff; }
    .card { box-shadow: none; border: 1px solid #ccc; }
    a { color: inherit; text-decoration: none; }
    .mem-submit-btn { display: none !important; }
}

/* ========== coop-clean.css ========== */
/**
 * ════════════════════════════════════════════════════════════
 * COOP CLEAN — Design Discipline Override v6.5
 * Dev Bandana Cooperative
 * ════════════════════════════════════════════════════════════
 *
 * नियम (Design Principles):
 *  1. No gradients — flat solid colors only
 *  2. No hover-lift (translateY) — subtle bg-change only
 *  3. Soft shadows — max 0 2px 8px rgba(0,0,0,0.07)
 *  4. No decorative animations — functional only
 *  5. Primary color = highlight accent only
 *  6. White + light grey bg — clean & corporate
 *
 * Load order: LAST — after all portal CSS.
 * ════════════════════════════════════════════════════════════
 */

/* ─── SHADOW SCALE (soft, professional) ────────────────────
   Override heavy shadow tokens at :root level               */
:root {
    --shadow-sm  : 0 1px 3px rgba(0,0,0,.06);
    --shadow-md  : 0 2px 8px rgba(0,0,0,.07);
    --shadow-lg  : 0 4px 14px rgba(0,0,0,.08);
    --shadow-primary: 0 2px 8px rgba(var(--primary-rgb, 26,95,42), .12);
    /* Slow down transitions — feels calmer */
    --transition-fast: background .15s, border-color .15s, color .15s;
    --transition-base: background .2s, border-color .2s, color .2s, box-shadow .2s;
}

/* ─── 1. REMOVE ALL HOVER-LIFT TRANSFORMS ─────────────────
   translateY / scale on hover는 디스코텍 느낌 → 제거       */
.card:hover,
.card-coop:hover,
.card-clickable:hover,
.stat-card:hover,
.ds-card:hover,
.ds-tab.active,
.btn-coop:hover,
.btn:hover,
.btn:active,
.btn:focus,
.dash-btn-primary:hover,
.dash-btn-outline-primary:hover,
.dash-btn-outline-warn:hover,
.mem-stat-card:hover,
.mem-quick-link:hover,
.service-card:hover,
.pub-service-card:hover,
.coop-card:hover,
.notice-card:hover,
.team-card:hover,
.gallery-card:hover,
[class*="-card"]:hover {
    transform: none !important;
}

/* Keep sidebar slide transform (functional) */
.sidebar { transform: none; }
@media (max-width: 991.98px) {
    .sidebar { transform: translate3d(-110%, 0, 0) !important; }
    .sidebar.open, .sidebar.sidebar-open { transform: translate3d(0, 0, 0) !important; }
}

/* ─── 2. STRIP ALL GRADIENTS ───────────────────────────────
   Sorted: functional areas → decorative               */

/* ·· 2a. Buttons — flat solid primary ···················· */
.btn-primary,
.dash-btn-primary,
.btn-coop,
.adm-btn-primary {
    background: var(--primary-color) !important;
    border-color: var(--primary-color) !important;
    box-shadow: none !important;
}
.btn-primary:hover,
.dash-btn-primary:hover,
.btn-coop:hover,
.adm-btn-primary:hover {
    background: var(--primary-dark) !important;
    border-color: var(--primary-dark) !important;
    box-shadow: none !important;
}
.btn-danger,
.adm-btn-danger {
    background: var(--color-danger, #dc3545) !important;
    border-color: var(--color-danger, #dc3545) !important;
    box-shadow: none !important;
}
.btn-success,
.adm-btn-success {
    background: var(--color-success, #28a745) !important;
    border-color: var(--color-success, #28a745) !important;
    box-shadow: none !important;
}

/* ·· 2b. Modal header — flat, not gradient ··············· */
.modal-header,
.modal-header[class*="gradient"],
.modal-content .modal-header {
    background: var(--primary-color) !important;
    background-image: none !important;
}

/* ·· 2c. Page banner — flat solid, no shimmer ············ */
.page-banner {
    background: var(--primary-color) !important;
    background-image: none !important;
}
.page-banner::before {
    display: none !important;  /* SVG pattern overlay */
}
.page-banner::after {
    display: none !important;  /* Gold shimmer bar */
}
/* Subtle bottom border instead of gold line */
.page-banner {
    border-bottom: 3px solid color-mix(in srgb, var(--primary-color) 60%, white);
}

/* ·· 2d. Sidebar — flat dark, no gradient ················ */
.sidebar,
.admin-sidebar,
nav.sidebar {
    background: #1e2d24 !important;
    background-image: none !important;
}

/* ·· 2e. Dashboard title gradient-text → flat ············ */
.dash-title-main {
    background: none !important;
    -webkit-background-clip: unset !important;
    -webkit-text-fill-color: var(--primary-dark, #144a21) !important;
    background-clip: unset !important;
    color: var(--primary-dark, #144a21) !important;
}

/* ·· 2f. Dashboard tab bar — flat ························ */
.ds-tabs {
    background: #f5f5f5 !important;
    background-image: none !important;
    box-shadow: 0 1px 3px rgba(0,0,0,.06) !important;
}
.ds-tab {
    background: transparent !important;
    background-image: none !important;
}
.ds-tab.active {
    background: #ffffff !important;
    background-image: none !important;
    color: var(--primary-color) !important;
    box-shadow: 0 1px 4px rgba(0,0,0,.08) !important;
    border-bottom: 2px solid var(--primary-color) !important;
}
/* Remove shimmer ::before pseudo-element on tabs & ds-cards */
.ds-tab::before,
.ds-card::before {
    display: none !important;
}

/* ·· 2g. Dashboard stat cards — flat, no gradient ········ */
.ds-card {
    background: #ffffff !important;
    background-image: none !important;
    box-shadow: 0 1px 4px rgba(0,0,0,.06) !important;
    border: 1px solid #eaecf0 !important;
    transition: box-shadow .2s, border-color .2s !important;
}
.ds-card:hover {
    background: #fff !important;
    box-shadow: 0 2px 8px rgba(0,0,0,.08) !important;
    border-color: color-mix(in srgb, var(--primary-color) 30%, #eaecf0) !important;
}
/* Dashboard icon — flat soft bg */
.ds-icon {
    background: color-mix(in srgb, var(--primary-color) 10%, white) !important;
    background-image: none !important;
    color: var(--primary-color) !important;
    box-shadow: none !important;
}
.ds-icon.warn {
    background: #fff8e6 !important;
    color: #a16207 !important;
}
.ds-icon.danger {
    background: #fef2f2 !important;
    color: #dc2626 !important;
}
.ds-icon.info {
    background: #eff6ff !important;
    color: #1d4ed8 !important;
}
.ds-icon.alt,
.ds-icon.dash-icon-purple {
    background: #f5f3ff !important;
    color: #6d28d9 !important;
}

/* ·· 2h. Dashboard buttons — flat ························ */
.dash-btn-primary {
    background: var(--primary-color) !important;
    background-image: none !important;
    border-color: var(--primary-color) !important;
    box-shadow: none !important;
    color: #fff !important;
}
.dash-btn-primary:hover {
    background: var(--primary-dark) !important;
    box-shadow: none !important;
}
.dash-btn-outline-primary:hover,
.dash-btn-outline-warn:hover {
    background: var(--primary-color) !important;
    background-image: none !important;
    box-shadow: none !important;
}

/* ·· 2i. Stat card component — no gradient, soft bg ······ */
.stat-card {
    transition: border-color .2s, box-shadow .2s !important;
}
.stat-card:hover {
    box-shadow: 0 2px 8px rgba(0,0,0,.08) !important;
    border-color: color-mix(in srgb, var(--primary-color) 25%, #e5e7eb) !important;
}

/* ·· 2j. Card headers — plain white/grey, no gradient ···· */
.card-header,
.form-card-title,
.svc-form-header-grad,
.appfeat-form-header,
.slb-card-head,
.cred-top-bar,
.hg-card-head {
    background: var(--primary-color) !important;
    background-image: none !important;
}
/* Admin panel card-header already set to light — keep light */
.main-content .card-header,
.admin-shell .card-header,
.admin-page .card-header {
    background: #f8faf9 !important;
    background-image: none !important;
    color: #1f2937 !important;
}

/* ·· 2k. Admin topbar — light bar (sidebar मात्र brand green) ···· */
.admin-topbar,
.admin-header,
.adm-topbar {
    background: var(--bg-card, #fff) !important;
    background-image: none !important;
    color: var(--text-primary, #0f172a) !important;
    border-bottom: 1px solid var(--border-color, #e5e7eb) !important;
}

/* ·· 2l. KYC/member stat cards gradients — flat ·········· */
.kyc-stat-box,
.kyc-risk-summary,
.mem-stat-icon,
.mem-quick-link .link-icon,
.hg-sidebar-stat,
.arv-stat-box {
    background-image: none !important;
}

/* ·· 2m. Auth pages — plain white card, no gradient ······ */
.auth-card,
.credential-card,
.cred-page-card,
.login-card {
    background: #ffffff !important;
    background-image: none !important;
    box-shadow: 0 2px 12px rgba(0,0,0,.07) !important;
}

/* ·· 2n. Member portal stat cards — flat ················· */
.ds-stats-grid .stat-card,
.mem-stat,
.mem-stat-card {
    background-image: none !important;
}

/* ·· 2o. Various inline gradient backgrounds ············· */
[class*="form-header"],
[class*="-header-grad"],
[class*="header-gradient"],
[class*="-card-head"] {
    background-image: none !important;
}
/* For dark-bg form headers keep solid primary */
.svc-form-header-grad,
.appfeat-form-header,
.slb-card-head {
    background: var(--primary-color) !important;
}

/* ─── 3. SOFTEN ALL SHADOWS ────────────────────────────────
   No heavy depth — clean "paper" elevation               */
.card,
.card-coop,
.stat-card,
.ds-card,
.modal-content,
.dropdown-menu,
.form-card,
[class*="-card"]:not(.badge) {
    box-shadow: 0 1px 4px rgba(0,0,0,.06) !important;
}
.card:hover,
.card-coop:hover,
.stat-card:hover {
    box-shadow: 0 2px 8px rgba(0,0,0,.08) !important;
}
.modal-content {
    box-shadow: 0 8px 32px rgba(0,0,0,.12) !important;
}
/* Buttons: no shadow */
.btn,
.btn-coop,
[class*="btn-"]:not(.btn-link) {
    box-shadow: none !important;
}
.btn:hover,
.btn:focus,
.btn:active {
    box-shadow: none !important;
}
/* Form focus — subtle ring only */
.form-control:focus,
.form-select:focus,
textarea.form-control:focus {
    box-shadow: 0 0 0 2px rgba(var(--primary-rgb, 26,95,42), .10) !important;
    border-color: var(--primary-color) !important;
}

/* ─── 4. REMOVE DECORATIVE ANIMATIONS ─────────────────────
   Alerts, cards, hover shimmer — all removed             */

/* Stop alert slide-in animation */
.alert {
    animation: none !important;
}

/* Stop any pulse/glow/flash on badges */
.badge, .badge-approved, .badge-pending, .badge-rejected, .badge-review {
    animation: none !important;
}

/* Stat card pulse animation removed */
@keyframes statPulse { from {} to {} }
@keyframes fadeSlideIn { from {} to {} }

/* ─── 5. CLEAN BORDERS ─────────────────────────────────────
   1px solid, soft grey — no heavy outlines               */
.card,
.form-card,
.card-coop {
    border: 1px solid var(--border-color, #e5e7eb) !important;
}
.card:hover {
    border-color: color-mix(in srgb, var(--primary-color) 20%, #e5e7eb) !important;
}

/* Table — remove strong colored header, keep subtle */
.table thead th {
    background: #f9fafb !important;
    color: #374151 !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
    font-size: .82rem !important;
    font-weight: 600 !important;
    border-bottom: 2px solid #e5e7eb !important;
}
.table td {
    border-color: #f3f4f6 !important;
}
.table-striped > tbody > tr:nth-of-type(odd) > * {
    background-color: #fafafa !important;
}

/* ─── 6. PAGE BANNER — clean, flat ───────────────────────
   White text on solid primary. No texture, no gold.      */
.page-banner h1 {
    text-shadow: none !important;
    font-weight: 700;
    letter-spacing: -.01em;
}
.page-banner p {
    opacity: .9;
}

/* ─── 7. FORM CONTROLS — clean professional ───────────────
   No icon-gradient bg, flat borders                      */
.input-group-text {
    background: #f9fafb !important;
    border-color: var(--border-color, #e5e7eb) !important;
}
.form-control,
.form-select {
    border-color: #d1d5db !important;
    background: #ffffff !important;
}
.form-control:hover,
.form-select:hover {
    border-color: #9ca3af !important;
}

/* ─── 8. SIDEBAR NAV — clean hover, no gradient ──────────
   Hover = subtle primary-tint bg only                    */
.sidebar-nav a:hover,
.admin-nav a:hover,
.sidebar-menu a:hover,
.admin-sidebar a:hover {
    background: color-mix(in srgb, var(--primary-color) 12%, transparent) !important;
    background-image: none !important;
}
.sidebar-nav a.active,
.admin-nav a.active,
.sidebar-menu a.active {
    background: var(--primary-color) !important;
    background-image: none !important;
    color: #fff !important;
}

/* ─── 9. MEMBER PORTAL CLEAN ──────────────────────────────
   Member bottom nav, stat cards, quick links             */
.mp-bottom-nav,
.mem-bottom-nav {
    background: #ffffff !important;
    background-image: none !important;
    border-top: 1px solid #e5e7eb !important;
    box-shadow: 0 -1px 6px rgba(0,0,0,.06) !important;
}
.mem-topbar,
.member-topbar {
    background: var(--primary-color) !important;
    background-image: none !important;
}

/* ─── 10. ADMIN-MODERN GRADIENT CARD OVERRIDES ────────────
   Specific classes with hardcoded gradients               */
.dash-icon-purple { background: #f5f3ff !important; color: #6d28d9 !important; }

/* Auth login card gradients */
.auth-split-left,
.cred-hero-side {
    background: color-mix(in srgb, var(--primary-color) 8%, white) !important;
    background-image: none !important;
}

/* KYC risk review stat boxes */
.arv-stat-box,
.krv-stat-box {
    background: #f9fafb !important;
    background-image: none !important;
    border: 1px solid #e5e7eb !important;
}

/* Member quick-link icon */
.link-icon,
.appfeat-icon-wrap {
    background: color-mix(in srgb, var(--primary-color) 10%, white) !important;
    background-image: none !important;
    box-shadow: none !important;
}

/* ─── 11. TRANSITION CALM-DOWN ────────────────────────────
   All transitions to max 0.2s, no cubic-bezier dramatics */
*,
*::before,
*::after {
    transition-duration: 0.18s !important;
}
/* Sidebar slide — keep smooth (0.28s) */
.sidebar {
    transition-duration: 0.28s !important;
}
/* Exceptions: never animate font-size or layout properties */
.sidebar-backdrop {
    transition: opacity .2s !important;
}

/* ========== unified-portal.css ========== */
/**
 * ═══════════════════════════════════════════════════════════════
 * 🌐 UNIFIED PORTAL CSS — आकाश सहकारी
 * ═══════════════════════════════════════════════════════════════
 * फाइल: assets/css/unified-portal.css
 *
 * यो एउटै CSS फाइलले Public Website, Admin, Member र Verify
 * Portal — सबैको shared base styles handle गर्छ।
 *
 * Load order (सबै portal को <head> मा यही क्रममा):
 *   1. Bootstrap 5 (CDN)
 *   2. Font Awesome (CDN)
 *   3. assets/css/unified-portal.css  ← यो फाइल
 *   4. assets/css/global-theme.php    ← DB colors inject
 *   5. Portal-specific CSS (admin.css / member.css / etc.)
 *
 * ⚠️ यो फाइलमा कुनै पनि color hardcode नगर्नुस्।
 *    सधैं CSS variables (--primary-color, etc.) प्रयोग गर्नुस्।
 * ═══════════════════════════════════════════════════════════════
 * Version: 2.0 | Unified across all portals
 * ═══════════════════════════════════════════════════════════════
 */

/* ════════════════════════════════════════════════════════════
   1. FONT IMPORTS
   ════════════════════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Mukta:wght@300;400;500;600;700&family=Noto+Sans+Devanagari:wght@300;400;500;600;700&family=Inter:wght@300;400;500;600;700&display=swap');


/* ════════════════════════════════════════════════════════════
   2. BASE RESET & BODY
   ════════════════════════════════════════════════════════════ */
*, *::before, *::after {
    box-sizing: border-box;
}

html {
    font-size: 16px;
    scroll-behavior: smooth;
    -webkit-text-size-adjust: 100%;
}

body {
    font-family: var(--font-primary, 'Mukta', 'Noto Sans Devanagari', 'Inter', sans-serif);
    font-size: var(--font-size-base, 0.9375rem);
    line-height: 1.7;
    color: var(--text-primary, #1a2e1f);
    background-color: var(--bg-page, #f8faf9);
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
    min-height: 100vh;
}

/* Headings */
h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-primary);
    font-weight: 700;
    line-height: 1.3;
    color: var(--text-primary);
    margin-bottom: 0.5em;
}
h1 { font-size: clamp(1.6rem, 4vw, 2.4rem); }
h2 { font-size: clamp(1.35rem, 3vw, 1.9rem); }
h3 { font-size: clamp(1.15rem, 2.5vw, 1.5rem); }
h4 { font-size: clamp(1.05rem, 2vw, 1.25rem); }
h5 { font-size: 1.05rem; }
h6 { font-size: 0.95rem; }

a {
    color: var(--primary-color);
    text-decoration: none;
    transition: color var(--transition-fast, 0.15s ease);
}
a:hover { color: var(--primary-dark); }

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

input, select, textarea, button {
    font-family: inherit;
}

::selection {
    background: var(--primary-color);
    color: var(--text-on-primary, #fff);
}


/* ════════════════════════════════════════════════════════════
   3. LAYOUT UTILITIES
   ════════════════════════════════════════════════════════════ */
.container-coop {
    max-width: var(--container-max, 1280px);
    margin: 0 auto;
    padding: 0 var(--container-pad, 20px);
    width: 100%;
}

.page-wrapper {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}

.page-content {
    flex: 1;
    padding: var(--space-lg, 24px) 0;
}

/* Grid helpers */
.coop-grid {
    display: grid;
    gap: var(--space-md, 16px);
}
.coop-grid-2 { grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); }
.coop-grid-3 { grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); }
.coop-grid-4 { grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); }


/* ════════════════════════════════════════════════════════════
   4. CARDS — सबै portal मा एकरूप
   ════════════════════════════════════════════════════════════ */
.card {
    background: var(--bg-card, #fff);
    border: 1px solid var(--border-soft, #f0f0f0);
    border-radius: var(--radius-lg, 16px);
    box-shadow: var(--shadow-sm, 0 1px 4px rgba(0,0,0,.08));
    transition: box-shadow var(--transition-base, 0.25s ease),
                transform var(--transition-base, 0.25s ease);
    overflow: hidden;
}
.card:hover { box-shadow: var(--shadow-md, 0 4px 16px rgba(0,0,0,.10)); }

.card-header {
    background: var(--bg-soft, #f5faf6);
    border-bottom: 1px solid var(--border-soft, #f0f0f0);
    padding: 0.9rem 1.25rem;
    font-weight: 600;
    font-size: var(--font-size-base);
    border-radius: var(--radius-lg) var(--radius-lg) 0 0 !important;
}

.card-body { padding: 1.25rem; }

.card-footer {
    background: var(--bg-soft, #f5faf6);
    border-top: 1px solid var(--border-soft, #f0f0f0);
    padding: 0.75rem 1.25rem;
    border-radius: 0 0 var(--radius-lg) var(--radius-lg) !important;
}

/* Stat Card — dashboard numbers */
.stat-card {
    background: var(--bg-card, #fff);
    border-radius: var(--radius-lg);
    padding: var(--space-lg, 24px);
    border: 1px solid var(--border-soft);
    box-shadow: var(--shadow-sm);
    display: flex;
    align-items: flex-start;
    gap: var(--space-md);
    transition: box-shadow var(--transition-base), transform var(--transition-base);
}
.stat-card:hover { box-shadow: var(--shadow-md); transform: translateY(-2px); }

.stat-card-icon {
    width: 52px; height: 52px;
    border-radius: var(--radius-md);
    background: var(--bg-muted, #e8f5e9);
    display: flex; align-items: center; justify-content: center;
    color: var(--primary-color);
    font-size: 1.3rem;
    flex-shrink: 0;
}
.stat-card-value {
    font-size: var(--font-size-2xl, 1.5rem);
    font-weight: 700;
    color: var(--text-primary);
    line-height: 1.2;
}
.stat-card-label {
    font-size: var(--font-size-sm, 0.8125rem);
    color: var(--text-muted, #6b7280);
    margin-top: 2px;
}

/* Clickable card */
a.card, .card-link {
    display: block; color: inherit; text-decoration: none;
}
a.card:hover { color: inherit; }


/* ════════════════════════════════════════════════════════════
   5. BUTTONS — सबै panel मा एकरूप
   ════════════════════════════════════════════════════════════ */
.btn {
    font-family: var(--font-primary);
    font-weight: 500;
    border-radius: var(--radius-md, 10px);
    padding: 0.45rem 1.1rem;
    font-size: var(--font-size-sm, 0.8125rem);
    transition: all var(--transition-base, 0.25s ease);
    letter-spacing: 0.01em;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    cursor: pointer;
    border: 1.5px solid transparent;
    line-height: 1.5;
}
.btn-sm  { padding: 0.28rem 0.75rem; font-size: var(--font-size-xs, 0.75rem); }
.btn-lg  { padding: 0.65rem 1.6rem; font-size: var(--font-size-md, 1rem); }

/* Primary */
.btn-primary {
    background: var(--primary-color) !important;
    border-color: var(--primary-color) !important;
    color: var(--text-on-primary, #fff) !important;
}
.btn-primary:hover, .btn-primary:focus {
    background: var(--primary-dark) !important;
    border-color: var(--primary-dark) !important;
    color: var(--text-on-primary, #fff) !important;
    box-shadow: 0 4px 12px rgba(var(--primary-rgb, 26,95,42), 0.3) !important;
    transform: translateY(-1px);
}
.btn-primary:active { transform: translateY(0); }

/* Outline primary */
.btn-outline-primary {
    background: transparent !important;
    color: var(--primary-color) !important;
    border-color: var(--primary-color) !important;
}
.btn-outline-primary:hover {
    background: var(--primary-color) !important;
    color: var(--text-on-primary, #fff) !important;
}

/* Danger */
.btn-danger  { background: var(--color-danger, #dc2626) !important; border-color: var(--color-danger) !important; color: #fff !important; }
.btn-danger:hover { background: #b91c1c !important; border-color: #b91c1c !important; color: #fff !important; }
.btn-outline-danger { color: var(--color-danger) !important; border-color: var(--color-danger) !important; background: transparent !important; }
.btn-outline-danger:hover { background: var(--color-danger) !important; color: #fff !important; }

/* Warning */
.btn-warning { background: var(--color-warning, #d97706) !important; border-color: var(--color-warning) !important; color: #fff !important; }
.btn-warning:hover { background: #b45309 !important; border-color: #b45309 !important; color: #fff !important; }

/* Success */
.btn-success { background: var(--color-success, #16a34a) !important; border-color: var(--color-success) !important; color: #fff !important; }
.btn-success:hover { background: #15803d !important; border-color: #15803d !important; color: #fff !important; }

/* Info */
.btn-info { background: var(--color-info, #0891b2) !important; border-color: var(--color-info) !important; color: #fff !important; }
.btn-info:hover { background: #0e7490 !important; border-color: #0e7490 !important; color: #fff !important; }

/* Secondary */
.btn-secondary { background: #6b7280 !important; border-color: #6b7280 !important; color: #fff !important; }
.btn-secondary:hover { background: #4b5563 !important; border-color: #4b5563 !important; color: #fff !important; }

/* Ghost / Muted */
.btn-ghost {
    background: transparent; color: var(--text-secondary);
    border-color: var(--border-color);
}
.btn-ghost:hover { background: var(--bg-soft); color: var(--text-primary); }


/* ════════════════════════════════════════════════════════════
   6. FORMS — सबै portal मा एकरूप
   ════════════════════════════════════════════════════════════ */
.form-label {
    font-weight: 500;
    font-size: var(--font-size-sm, 0.8125rem);
    color: var(--text-secondary, #4a5a4f);
    margin-bottom: 0.35rem;
}
.form-label .text-danger { font-size: 0.7em; margin-left: 2px; }

.form-control, .form-select {
    font-family: var(--font-primary);
    font-size: var(--font-size-base, 0.9375rem);
    border: 1.5px solid var(--border-color, #e5e7eb);
    border-radius: var(--radius-md, 10px);
    padding: 10px 14px;
    min-height: 44px;
    color: var(--text-primary, #1a2e1f);
    background-color: var(--bg-card, #fff);
    transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
    line-height: 1.5;
    width: 100%;
}
.form-control-sm, .form-select-sm {
    min-height: 36px;
    padding: 0.32rem 0.75rem;
    font-size: var(--font-size-sm);
}
.form-control:focus, .form-select:focus {
    outline: none;
    border-color: var(--primary-color);
    box-shadow: var(--shadow-focus, 0 0 0 3px rgba(26,95,42,0.18));
    background-color: #fff;
}
.form-control::placeholder { color: var(--text-light, #9ca3af); font-size: var(--font-size-sm); }
.form-control.is-invalid, .form-select.is-invalid { border-color: var(--color-danger) !important; }
.form-control.is-valid,   .form-select.is-valid   { border-color: var(--color-success) !important; }

textarea.form-control { min-height: 100px; resize: vertical; }

.input-group-text {
    background: var(--bg-soft, #f5faf6);
    border: 1.5px solid var(--border-color, #e5e7eb);
    color: var(--text-muted);
    font-size: var(--font-size-sm);
    min-height: 44px;
    padding: 10px 14px;
    border-radius: var(--radius-md);
}

/* Checkbox / Radio */
.form-check { padding-left: 1.85em !important; min-height: 1.6rem !important; margin-bottom: 0.35rem !important; }
.form-check .form-check-input { margin-left: -1.85em !important; margin-top: 0.2em !important; flex-shrink: 0; }
.form-check-label { cursor: pointer; line-height: 1.45; padding-left: 4px; }
.form-check-inline { display: inline-flex !important; align-items: center !important; margin-right: 1.1rem !important; padding-left: 1.85em !important; }
.form-switch { padding-left: 2.8em !important; }
.form-switch .form-check-input { margin-left: -2.8em !important; width: 2.2em !important; height: 1.15em !important; }

/* Form section card — सबै portal मा एउटै */
.form-section {
    background: var(--bg-card);
    border: 1px solid var(--border-soft);
    border-radius: var(--radius-lg);
    padding: 1.5rem;
    margin-bottom: 1.5rem;
    box-shadow: var(--shadow-sm);
}
.form-section-title {
    font-size: var(--font-size-lg, 1.125rem);
    font-weight: 600;
    color: var(--primary-color);
    padding-bottom: 0.6rem;
    border-bottom: 2px solid var(--bg-muted, #e8f5e9);
    margin-bottom: 1.2rem;
    display: flex;
    align-items: center;
    gap: 8px;
}
.form-section-title i { color: var(--primary-color); }


/* ════════════════════════════════════════════════════════════
   7. TABLES — सबै panel मा एकरूप
   ════════════════════════════════════════════════════════════ */
.table {
    font-size: var(--font-size-sm, 0.8125rem);
    color: var(--text-primary);
    margin-bottom: 0;
}
.table th {
    background: var(--bg-soft, #f5faf6);
    font-weight: 600;
    font-size: var(--font-size-xs, 0.75rem);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--text-secondary, #4a5a4f);
    border-bottom: 2px solid var(--border-color, #e5e7eb);
    padding: 0.75rem 1rem;
    white-space: nowrap;
    vertical-align: middle;
}
.table td {
    padding: 0.7rem 1rem;
    vertical-align: middle;
    border-color: var(--border-soft, #f0f0f0);
}
.table-striped > tbody > tr:nth-of-type(odd) > * {
    background-color: rgba(var(--primary-rgb, 26,95,42), 0.025);
}
.table-hover > tbody > tr:hover > * {
    background-color: rgba(var(--primary-rgb, 26,95,42), 0.05);
    transition: background var(--transition-fast);
}

/* Responsive table wrapper */
.table-responsive { border-radius: var(--radius-lg); overflow: hidden; }
.table-card {
    background: var(--bg-card);
    border-radius: var(--radius-lg);
    border: 1px solid var(--border-soft);
    box-shadow: var(--shadow-sm);
    overflow: hidden;
}
.table-card .table { margin-bottom: 0; }


/* ════════════════════════════════════════════════════════════
   8. BADGES & STATUS CHIPS — सबै panel मा एकरूप
   ════════════════════════════════════════════════════════════ */
.badge {
    font-family: var(--font-primary);
    font-weight: 600;
    border-radius: var(--radius-full, 9999px);
    padding: 3px 10px;
    font-size: 0.72em;
    letter-spacing: 0.02em;
    display: inline-flex;
    align-items: center;
    gap: 4px;
}

/* Soft pill badges (preferred over filled) */
.badge-soft-primary { background: var(--bg-muted); color: var(--primary-color); border: 1px solid rgba(var(--primary-rgb),0.2); }
.badge-soft-success { background: var(--color-success-bg); color: var(--color-success); border: 1px solid var(--color-success-border); }
.badge-soft-warning { background: var(--color-warning-bg); color: var(--color-warning); border: 1px solid var(--color-warning-border); }
.badge-soft-danger  { background: var(--color-danger-bg);  color: var(--color-danger);  border: 1px solid var(--color-danger-border); }
.badge-soft-info    { background: var(--color-info-bg);    color: var(--color-info);    border: 1px solid var(--color-info-border); }
.badge-soft-muted   { background: #f1f5f9; color: #475569; border: 1px solid #cbd5e1; }

/* Workflow/Request status — सबैतिर एकनासो — .badge base extend गर्छ */
.status-pending,
.status-approved,
.status-rejected,
.status-review,
.status-active,
.status-inactive {
    display: inline-flex;
    align-items: center;
    border-radius: var(--radius-full);
    padding: 3px 10px;
    font-size: 0.72em;
    font-weight: 600;
    border-width: 1px;
    border-style: solid;
    line-height: 1.4;
}
.status-pending  { background: var(--color-warning-bg); color: var(--color-warning); border-color: var(--color-warning-border); }
.status-approved { background: var(--color-success-bg); color: var(--color-success); border-color: var(--color-success-border); }
.status-rejected { background: var(--color-danger-bg);  color: var(--color-danger);  border-color: var(--color-danger-border); }
.status-review   { background: var(--color-info-bg);    color: var(--color-info);    border-color: var(--color-info-border); }
.status-active   { background: var(--color-success-bg); color: var(--color-success); border-color: var(--color-success-border); }
.status-inactive { background: #f1f5f9; color: #64748b; border-color: #cbd5e1; }

/* Active/Inactive dot indicator */
.status-dot { display: inline-block; width: 8px; height: 8px; border-radius: 50%; }
.status-dot.active   { background: var(--color-success); }
.status-dot.inactive { background: #94a3b8; }
.status-dot.pending  { background: var(--color-warning); }


/* ════════════════════════════════════════════════════════════
   9. ALERTS — सबै panel मा एकरूप
   ════════════════════════════════════════════════════════════ */
.alert {
    border-radius: var(--radius-md, 10px);
    border-width: 1px;
    font-size: var(--font-size-sm);
    padding: 0.85rem 1rem;
    display: flex;
    align-items: flex-start;
    gap: 10px;
}
.alert-success { background: var(--color-success-bg) !important; color: var(--color-success) !important; border-color: var(--color-success-border) !important; }
.alert-warning { background: var(--color-warning-bg) !important; color: var(--color-warning) !important; border-color: var(--color-warning-border) !important; }
.alert-danger, .alert-error { background: var(--color-danger-bg) !important; color: var(--color-danger) !important; border-color: var(--color-danger-border) !important; }
.alert-info, .alert-primary { background: var(--color-info-bg) !important; color: var(--color-info) !important; border-color: var(--color-info-border) !important; }

/* coop-alert — panel-uniform.php को coopAlert() ले generate गर्ने */
.coop-alert {
    border-radius: var(--radius-md);
    padding: 12px 16px;
    display: flex;
    align-items: center;
    gap: 10px;
    margin: 12px 0;
    box-shadow: var(--shadow-sm);
    font-family: var(--font-primary);
    font-size: var(--font-size-sm);
    position: relative;
}
.coop-alert-close {
    background: none; border: none; cursor: pointer;
    font-size: 1.1rem; line-height: 1; padding: 0 4px;
    opacity: 0.7; transition: opacity var(--transition-fast);
    margin-left: auto;
}
.coop-alert-close:hover { opacity: 1; }


/* ════════════════════════════════════════════════════════════
   10. MODALS — सबै panel मा एकरूप
   ════════════════════════════════════════════════════════════ */
.modal-content {
    border: none;
    border-radius: var(--radius-xl, 24px);
    box-shadow: var(--shadow-xl);
    overflow: hidden;
}
.modal-header {
    background: var(--bg-soft);
    border-bottom: 1px solid var(--border-soft);
    padding: 1.1rem 1.5rem;
    border-radius: var(--radius-xl) var(--radius-xl) 0 0;
}
.modal-header .modal-title {
    font-weight: 700;
    font-size: var(--font-size-lg);
    color: var(--primary-color);
}
.modal-body { padding: 1.5rem; }
.modal-footer {
    background: var(--bg-soft);
    border-top: 1px solid var(--border-soft);
    padding: 1rem 1.5rem;
    border-radius: 0 0 var(--radius-xl) var(--radius-xl);
}
.modal-backdrop.show { opacity: 0.5; }


/* ════════════════════════════════════════════════════════════
   11. PAGE BANNER — सबै public pages मा एकरूप
   ════════════════════════════════════════════════════════════ */
.page-banner {
    background: linear-gradient(135deg, var(--primary-dark) 0%, var(--primary-color) 100%);
    padding: 24px 0 28px;
    position: relative;
    overflow: hidden;
    text-align: center;
}
.page-banner::before {
    content: '';
    position: absolute; inset: 0;
    background: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none'%3E%3Cg fill='%23ffffff' fill-opacity='0.04'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
    pointer-events: none;
}
.page-banner::after {
    content: '';
    position: absolute; bottom: 0; left: 0; right: 0; height: 3px;
    background: linear-gradient(to right, transparent 0%, #c8860a 15%, #f5c518 40%, #ffd700 50%, #f5c518 60%, #c8860a 85%, transparent 100%);
}
.page-banner .container { position: relative; z-index: 1; }
.page-banner h1 {
    color: #fff;
    font-size: clamp(1.25rem, 3vw, 1.75rem);
    margin-bottom: 6px;
    text-shadow: 0 1px 6px rgba(0,0,0,0.2);
}
.page-banner p { color: rgba(255,255,255,0.8); margin-bottom: 0; }
.page-banner .breadcrumb { margin-bottom: 0; background: transparent; padding: 0; justify-content: center; }
.page-banner .breadcrumb-item a { color: rgba(255,255,255,0.8); }
.page-banner .breadcrumb-item a:hover { color: #fff; }
.page-banner .breadcrumb-item.active { color: rgba(255,255,255,0.95); }
.page-banner .breadcrumb-item + .breadcrumb-item::before { color: rgba(255,255,255,0.45); }


/* ════════════════════════════════════════════════════════════
   12. SECTION HEADER — सबै pages मा एकरूप
   ════════════════════════════════════════════════════════════ */
.section-header {
    margin-bottom: 2rem;
    text-align: center;
}
.section-header h2, .section-header h3 {
    font-weight: 700;
    color: var(--primary-dark);
    margin-bottom: 0.5rem;
}
.section-header p {
    color: var(--text-muted);
    font-size: var(--font-size-base);
    margin-bottom: 0;
}
.section-divider {
    width: 60px; height: 3px;
    background: linear-gradient(to right, var(--primary-color), var(--secondary-color));
    margin: 0.5rem auto 1rem;
    border-radius: var(--radius-full);
}


/* ════════════════════════════════════════════════════════════
   13. MOBILE-FIRST RESPONSIVE — सबै portal एकरूप
   ════════════════════════════════════════════════════════════ */

/* Mobile sidebar overlay */
.sidebar-overlay {
    display: none;
    position: fixed; inset: 0;
    background: rgba(0,0,0,0.5);
    z-index: var(--z-overlay, 300);
    backdrop-filter: blur(2px);
    -webkit-backdrop-filter: blur(2px);
}
.sidebar-overlay.active { display: block; }

/* Mobile bottom nav — App-like experience */
.mobile-bottom-nav {
    display: none;
    position: fixed;
    bottom: 0; left: 0; right: 0;
    background: var(--bg-card, #fff);
    border-top: 1px solid var(--border-soft);
    box-shadow: 0 -4px 20px rgba(0,0,0,0.08);
    z-index: var(--z-sticky, 200);
    padding: 6px 0 max(6px, env(safe-area-inset-bottom));
    height: 62px;
}
.mobile-bottom-nav .nav-items {
    display: flex;
    align-items: center;
    justify-content: space-around;
    height: 100%;
}
.mobile-bottom-nav .nav-item-btn {
    display: flex; flex-direction: column; align-items: center;
    gap: 2px; cursor: pointer; padding: 4px 10px;
    color: var(--text-muted); text-decoration: none;
    font-size: 0.62rem; font-weight: 500;
    transition: color var(--transition-fast);
    min-width: 52px;
    border: none; background: none; border-radius: var(--radius-md);
}
.mobile-bottom-nav .nav-item-btn i { font-size: 1.2rem; }
.mobile-bottom-nav .nav-item-btn.active, .mobile-bottom-nav .nav-item-btn:hover { color: var(--primary-color); }

@media (max-width: 768px) {
    .mobile-bottom-nav { display: flex; }
    body.has-bottom-nav { padding-bottom: 70px; }

    .hide-mobile { display: none !important; }
    .show-mobile { display: block !important; }

    .coop-grid-3, .coop-grid-4 { grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); }

    .table-responsive { font-size: var(--font-size-xs); }
    .table th, .table td { padding: 0.5rem 0.75rem; }

    .card-body { padding: 1rem; }
    .form-section { padding: 1rem; }

    .modal-dialog { margin: 0.5rem; }
    .modal-content { border-radius: var(--radius-lg); }
}

@media (max-width: 480px) {
    .btn-group-mobile-stack { flex-direction: column !important; width: 100%; }
    .btn-group-mobile-stack .btn { width: 100%; justify-content: center; }
    h1 { font-size: 1.5rem; }
    h2 { font-size: 1.25rem; }
}


/* ════════════════════════════════════════════════════════════
   14. UTILITY CLASSES
   ════════════════════════════════════════════════════════════ */
/* Text */
.text-primary-coop { color: var(--primary-color) !important; }
.text-muted-coop   { color: var(--text-muted) !important; }
.text-nepali       { font-family: var(--font-nepali) !important; }
.text-english      { font-family: var(--font-english) !important; }

/* Background */
.bg-primary-coop   { background: var(--primary-color) !important; color: var(--text-on-primary) !important; }
.bg-soft-coop      { background: var(--bg-soft) !important; }
.bg-muted-coop     { background: var(--bg-muted) !important; }

/* Borders */
.border-primary-coop { border-color: var(--primary-color) !important; }
.border-left-primary { border-left: 4px solid var(--primary-color) !important; }

/* Spacing shortcuts */
.gap-xs { gap: var(--space-xs); }
.gap-sm { gap: var(--space-sm); }
.gap-md { gap: var(--space-md); }
.gap-lg { gap: var(--space-lg); }

/* Shadows */
.shadow-coop-sm { box-shadow: var(--shadow-sm) !important; }
.shadow-coop-md { box-shadow: var(--shadow-md) !important; }
.shadow-coop-lg { box-shadow: var(--shadow-lg) !important; }

/* Radius */
.rounded-coop    { border-radius: var(--radius-md) !important; }
.rounded-coop-lg { border-radius: var(--radius-lg) !important; }

/* Visibility — mobile responsive (defined in section 13 media query above) */
/* hide-mobile: mobile ma hidden, desktop ma visible — @media block ma override huncha */
/* show-mobile: desktop ma hidden, mobile ma visible — @media block ma override huncha */

/* Flex helpers */
.flex-center  { display: flex; align-items: center; justify-content: center; }
.flex-between { display: flex; align-items: center; justify-content: space-between; }
.flex-start   { display: flex; align-items: center; justify-content: flex-start; gap: var(--space-sm); }

/* Divider */
.divider-coop {
    border: none;
    border-top: 1px solid var(--border-soft);
    margin: var(--space-md) 0;
}

/* Empty state */
.empty-state {
    text-align: center;
    padding: var(--space-2xl) var(--space-lg);
    color: var(--text-muted);
}
.empty-state-icon { font-size: 3rem; color: var(--text-light); margin-bottom: var(--space-md); }
.empty-state-title { font-weight: 600; color: var(--text-secondary); margin-bottom: var(--space-sm); }
.empty-state-desc  { font-size: var(--font-size-sm); }

/* Loading spinner */
.coop-spinner {
    width: 2rem; height: 2rem;
    border: 3px solid var(--bg-muted);
    border-top-color: var(--primary-color);
    border-radius: 50%;
    animation: coop-spin 0.7s linear infinite;
    display: inline-block;
}
@keyframes coop-spin { to { transform: rotate(360deg); } }

/* Tooltip */
.coop-tooltip {
    position: relative;
    display: inline-block;
}
.coop-tooltip:hover::after {
    content: attr(data-tip);
    position: absolute;
    bottom: calc(100% + 6px);
    left: 50%; transform: translateX(-50%);
    background: #1a2e1f;
    color: #fff;
    font-size: var(--font-size-xs);
    padding: 5px 10px;
    border-radius: var(--radius-sm);
    white-space: nowrap;
    z-index: var(--z-tooltip, 600);
    pointer-events: none;
}

/* Nepali prose content */
.coop-prose {
    font-family: var(--font-nepali);
    line-height: 1.9;
    color: var(--text-primary);
    font-size: var(--font-size-base);
}
.coop-prose p { margin-bottom: 1em; }
.coop-prose h1, .coop-prose h2, .coop-prose h3 { color: var(--primary-color); }

/* Print utilities */
@media print {
    .no-print, .mobile-bottom-nav, .sidebar-overlay { display: none !important; }
    .page-banner { background: var(--primary-color) !important; -webkit-print-color-adjust: exact; }
    .card { box-shadow: none !important; border: 1px solid #ccc !important; }
}

/* Merged shared components and UI fixes — centralized global portal layer */

/* Source: assets/css/components.css */
/**
 * ═══════════════════════════════════════════════════════════════
 * 🧩 COMPONENTS CSS — आकाश सहकारी
 * ═══════════════════════════════════════════════════════════════
 * फाइल: assets/css/components.css
 *
 * यो फाइलमा सबै reusable UI components छन् जुन Public,
 * Admin, Member र Verify — सबै portal ले share गर्छन्।
 *
 * Load order:
 *   1. unified-portal.css
 *   2. global-theme.php
 *   3. components.css  ← यो फाइल
 *   4. Portal-specific overrides
 *
 * ⚠️ हरेक component यहाँ एकपटक मात्र define गर्नुस्।
 * ═══════════════════════════════════════════════════════════════
 */

/* ════════════════════════════════════════════════════════════
   1. FLASH MESSAGE — panel-uniform.php coopFlash() ले यही use गर्छ
   ════════════════════════════════════════════════════════════ */
.flash-message {
    position: fixed;
    top: 16px;
    right: 16px;
    z-index: var(--z-toast, 500);
    max-width: 420px;
    min-width: 300px;
    animation: slideInRight 0.3s ease forwards;
}
@keyframes slideInRight {
    from { opacity: 0; transform: translateX(40px); }
    to   { opacity: 1; transform: translateX(0); }
}

.flash-message .coop-alert {
    border-radius: var(--radius-md);
    padding: 14px 18px;
    box-shadow: var(--shadow-lg);
}

/* Static flash (inline, not floating) */
.flash-inline {
    border-radius: var(--radius-md);
    padding: 12px 16px;
    margin-bottom: 1rem;
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: var(--font-size-sm);
    font-weight: 500;
}
.flash-inline.success { background: var(--color-success-bg); color: var(--color-success); border: 1px solid var(--color-success-border); }
.flash-inline.error,
.flash-inline.danger  { background: var(--color-danger-bg); color: var(--color-danger); border: 1px solid var(--color-danger-border); }
.flash-inline.warning { background: var(--color-warning-bg); color: var(--color-warning); border: 1px solid var(--color-warning-border); }
.flash-inline.info    { background: var(--color-info-bg); color: var(--color-info); border: 1px solid var(--color-info-border); }


/* ════════════════════════════════════════════════════════════
   2. BREADCRUMB — सबै portal मा एकरूप
   ════════════════════════════════════════════════════════════ */
.coop-breadcrumb {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 4px;
    list-style: none;
    margin: 0; padding: 0;
    font-size: var(--font-size-xs, 0.75rem);
    color: var(--text-muted);
}
.coop-breadcrumb li { display: flex; align-items: center; gap: 4px; }
.coop-breadcrumb li:not(:last-child)::after { content: '/'; color: var(--text-light); margin-left: 4px; }
.coop-breadcrumb a { color: var(--text-muted); text-decoration: none; transition: color var(--transition-fast); }
.coop-breadcrumb a:hover { color: var(--primary-color); }
.coop-breadcrumb li.active { color: var(--text-primary); font-weight: 500; }
.coop-breadcrumb i { font-size: 0.7em; }

/* Page banner style breadcrumb */
.page-banner .coop-breadcrumb a, .page-banner .coop-breadcrumb { color: rgba(255,255,255,0.75); }
.page-banner .coop-breadcrumb li.active { color: #fff; }
.page-banner .coop-breadcrumb li::after { color: rgba(255,255,255,0.4) !important; }


/* ════════════════════════════════════════════════════════════
   3. DATA TABLE WRAPPER — admin र member मा एकरूप
   ════════════════════════════════════════════════════════════ */
.data-table-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: var(--space-sm);
    padding: 1rem 1.25rem;
    background: var(--bg-card);
    border-bottom: 1px solid var(--border-soft);
}
.data-table-header h5 {
    font-weight: 700;
    color: var(--primary-color);
    margin: 0;
    font-size: var(--font-size-base);
}
.data-table-search {
    display: flex;
    align-items: center;
    gap: 8px;
}
.data-table-search .form-control {
    min-width: 200px;
    height: 36px;
    min-height: 36px;
    padding: 6px 12px;
    font-size: var(--font-size-sm);
}
.data-table-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: var(--space-sm);
    padding: 0.75rem 1.25rem;
    background: var(--bg-soft);
    border-top: 1px solid var(--border-soft);
    font-size: var(--font-size-xs);
    color: var(--text-muted);
}

/* Empty state row in table */
.table-empty-row td {
    text-align: center;
    padding: 2.5rem 1rem !important;
    color: var(--text-muted);
    font-size: var(--font-size-sm);
}
.table-empty-row i { display: block; font-size: 2rem; color: var(--text-light); margin-bottom: 8px; }


/* ════════════════════════════════════════════════════════════
   4. ACTION BUTTONS — admin table rows मा एकरूप
   ════════════════════════════════════════════════════════════ */
.action-btns {
    display: flex;
    align-items: center;
    gap: 4px;
    flex-wrap: wrap;
}
.btn-action {
    width: 30px; height: 30px;
    border-radius: var(--radius-sm);
    border: none; cursor: pointer;
    display: inline-flex; align-items: center; justify-content: center;
    font-size: 0.78rem;
    transition: all var(--transition-fast);
    text-decoration: none;
    padding: 0;
}
.btn-action.edit    { background: var(--color-info-bg); color: var(--color-info); }
.btn-action.view    { background: var(--bg-muted); color: var(--primary-color); }
.btn-action.delete  { background: var(--color-danger-bg); color: var(--color-danger); }
.btn-action.toggle  { background: var(--color-warning-bg); color: var(--color-warning); }
.btn-action.approve { background: var(--color-success-bg); color: var(--color-success); }
.btn-action:hover   { filter: brightness(0.9); transform: scale(1.08); }


/* ════════════════════════════════════════════════════════════
   5. SIDEBAR — Admin र Member दुवैमा एकरूप structure
   ════════════════════════════════════════════════════════════ */
.coop-sidebar {
    width: 260px;
    background: var(--bg-card);
    border-right: 1px solid var(--border-soft);
    height: 100vh;
    position: fixed;
    top: 0; left: 0;
    overflow-y: auto;
    z-index: var(--z-sticky, 200);
    display: flex;
    flex-direction: column;
    transition: transform var(--transition-base);
    scrollbar-width: thin;
    scrollbar-color: var(--border-color) transparent;
}
.coop-sidebar::-webkit-scrollbar { width: 4px; }
.coop-sidebar::-webkit-scrollbar-thumb { background: var(--border-color); border-radius: 2px; }

.coop-sidebar-brand {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 16px 20px;
    border-bottom: 1px solid var(--border-soft);
    position: sticky; top: 0;
    background: var(--bg-card);
    z-index: 1;
}
.coop-sidebar-brand img { height: 36px; width: auto; object-fit: contain; }
.coop-sidebar-brand-text { font-weight: 700; font-size: var(--font-size-sm); color: var(--primary-color); line-height: 1.3; }

.coop-sidebar-nav { padding: 12px 10px; flex: 1; }
.coop-sidebar-section { margin-bottom: 4px; }
.coop-sidebar-section-title {
    font-size: 0.65rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--text-muted);
    padding: 8px 12px 4px;
}
.coop-sidebar-link {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 9px 12px;
    border-radius: var(--radius-md);
    color: var(--text-secondary);
    font-size: var(--font-size-sm);
    font-weight: 500;
    text-decoration: none;
    transition: all var(--transition-fast);
    margin-bottom: 1px;
    position: relative;
}
.coop-sidebar-link i { width: 20px; text-align: center; font-size: 0.9rem; color: var(--text-muted); flex-shrink: 0; }
.coop-sidebar-link:hover {
    background: var(--bg-muted);
    color: var(--primary-color);
}
.coop-sidebar-link:hover i { color: var(--primary-color); }
.coop-sidebar-link.active {
    background: var(--primary-color);
    color: var(--text-on-primary, #fff);
}
.coop-sidebar-link.active i { color: var(--text-on-primary, #fff); }

/* Badge on sidebar link */
.coop-sidebar-badge {
    margin-left: auto;
    background: var(--color-danger);
    color: #fff;
    font-size: 0.65rem;
    font-weight: 700;
    padding: 2px 6px;
    border-radius: var(--radius-full);
    min-width: 18px;
    text-align: center;
}

/* Sidebar collapsed state (mobile) */
@media (max-width: 992px) {
    .coop-sidebar { transform: translateX(-100%); }
    .coop-sidebar.open { transform: translateX(0); box-shadow: var(--shadow-xl); }
    .coop-main-content { margin-left: 0 !important; }
}


/* ════════════════════════════════════════════════════════════
   6. TOPBAR / HEADER — Admin र Member मा एकरूप
   ════════════════════════════════════════════════════════════ */
.coop-topbar {
    height: 58px;
    background: var(--bg-card);
    border-bottom: 1px solid var(--border-soft);
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 var(--space-lg);
    position: sticky; top: 0;
    z-index: var(--z-sticky, 200);
    box-shadow: var(--shadow-xs);
}
.coop-topbar-left { display: flex; align-items: center; gap: var(--space-md); }
.coop-topbar-right { display: flex; align-items: center; gap: var(--space-sm); }

.topbar-toggle-btn {
    background: none; border: none; cursor: pointer;
    width: 36px; height: 36px;
    border-radius: var(--radius-md);
    display: flex; align-items: center; justify-content: center;
    color: var(--text-secondary);
    font-size: 1.1rem;
    transition: all var(--transition-fast);
}
.topbar-toggle-btn:hover { background: var(--bg-soft); color: var(--primary-color); }

.topbar-page-title {
    font-weight: 700;
    font-size: var(--font-size-base);
    color: var(--text-primary);
}

/* User avatar in topbar */
.topbar-avatar {
    width: 36px; height: 36px;
    border-radius: 50%;
    background: var(--primary-color);
    color: var(--text-on-primary, #fff);
    display: flex; align-items: center; justify-content: center;
    font-weight: 700; font-size: 0.9rem;
    cursor: pointer;
    text-transform: uppercase;
    border: 2px solid transparent;
    transition: border-color var(--transition-fast);
}
.topbar-avatar:hover { border-color: var(--primary-light); }
.topbar-avatar img { width: 100%; height: 100%; object-fit: cover; border-radius: 50%; }

/* Notification bell */
.topbar-bell {
    position: relative;
    width: 36px; height: 36px;
    border-radius: var(--radius-md);
    border: none; background: none;
    cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    color: var(--text-secondary);
    font-size: 1rem;
    transition: all var(--transition-fast);
}
.topbar-bell:hover { background: var(--bg-soft); color: var(--primary-color); }
.topbar-bell-count {
    position: absolute;
    top: 2px; right: 2px;
    background: var(--color-danger);
    color: #fff;
    font-size: 0.6rem; font-weight: 700;
    width: 16px; height: 16px;
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    border: 1.5px solid var(--bg-card);
}


/* ════════════════════════════════════════════════════════════
   7. AUTH PAGES — Login/Register — सबै portal एकरूप
   ════════════════════════════════════════════════════════════ */
.auth-page {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, var(--primary-dark) 0%, var(--primary-color) 100%);
    padding: var(--space-lg);
    position: relative;
    overflow: hidden;
}
.auth-page::before {
    content: '';
    position: absolute; inset: 0;
    background: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none'%3E%3Cg fill='%23ffffff' fill-opacity='0.05'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
    pointer-events: none;
}

.auth-card {
    background: var(--bg-card);
    border-radius: var(--radius-xl);
    box-shadow: var(--shadow-xl);
    padding: 2.5rem 2rem;
    width: 100%;
    max-width: 420px;
    position: relative;
    z-index: 1;
}
.auth-logo {
    text-align: center;
    margin-bottom: 1.5rem;
}
.auth-logo img { height: 64px; width: auto; object-fit: contain; }
.auth-title {
    text-align: center;
    font-size: var(--font-size-xl);
    font-weight: 700;
    color: var(--primary-color);
    margin-bottom: 4px;
}
.auth-subtitle {
    text-align: center;
    font-size: var(--font-size-sm);
    color: var(--text-muted);
    margin-bottom: 1.5rem;
}
.auth-divider {
    text-align: center;
    color: var(--text-muted);
    font-size: var(--font-size-xs);
    position: relative;
    margin: 1rem 0;
}
.auth-divider::before, .auth-divider::after {
    content: '';
    position: absolute;
    top: 50%; width: calc(50% - 30px);
    height: 1px; background: var(--border-color);
}
.auth-divider::before { left: 0; }
.auth-divider::after { right: 0; }
.auth-footer {
    text-align: center;
    margin-top: 1.25rem;
    font-size: var(--font-size-sm);
    color: var(--text-muted);
}

/* Password toggle */
.password-field { position: relative; }
.password-field .form-control { padding-right: 44px; }
.password-toggle {
    position: absolute; right: 12px; top: 50%; transform: translateY(-50%);
    background: none; border: none; cursor: pointer;
    color: var(--text-muted); font-size: 0.9rem;
    padding: 4px;
    transition: color var(--transition-fast);
}
.password-toggle:hover { color: var(--primary-color); }


/* ════════════════════════════════════════════════════════════
   8. PORTAL-SPECIFIC HEADER OVERRIDES
   ════════════════════════════════════════════════════════════ */

/* Admin sidebar active indicator */
.admin-sidebar-wrapper .coop-sidebar-link.active::before {
    content: '';
    position: absolute;
    left: 0; top: 50%; transform: translateY(-50%);
    width: 3px; height: 60%;
    background: var(--text-on-primary, #fff);
    border-radius: 0 2px 2px 0;
}

/* Member portal card accent */
.mem-portal-card {
    border-left: 4px solid var(--primary-color);
}

/* Verify portal minimal layout */
.verify-page {
    min-height: 100vh;
    background: var(--bg-page);
    display: flex;
    flex-direction: column;
}
.verify-result-card {
    border-radius: var(--radius-xl);
    overflow: hidden;
    box-shadow: var(--shadow-lg);
}
.verify-result-success { border-top: 4px solid var(--color-success); }
.verify-result-error   { border-top: 4px solid var(--color-danger); }


/* ════════════════════════════════════════════════════════════
   9. ID CARD COMPONENT — Member portal print view
   ════════════════════════════════════════════════════════════ */
.id-card {
    width: 85.6mm; height: 53.98mm; /* Standard credit card size */
    border-radius: 8px;
    overflow: hidden;
    box-shadow: var(--shadow-lg);
    background: var(--primary-color);
    position: relative;
    font-family: var(--font-primary);
}
.id-card-header {
    background: var(--primary-dark);
    padding: 8px 12px;
    display: flex; align-items: center; gap: 8px;
}
.id-card-header img { height: 28px; }
.id-card-body { padding: 10px 12px; display: flex; gap: 10px; align-items: flex-start; }
.id-card-photo {
    width: 52px; height: 60px;
    border-radius: 4px;
    object-fit: cover;
    border: 2px solid rgba(255,255,255,0.5);
    flex-shrink: 0;
}
.id-card-info { color: var(--text-on-primary, #fff); flex: 1; }
.id-card-name { font-weight: 700; font-size: 0.7rem; margin-bottom: 2px; }
.id-card-meta { font-size: 0.58rem; opacity: 0.85; line-height: 1.6; }
.id-card-footer {
    position: absolute; bottom: 0; left: 0; right: 0;
    background: rgba(0,0,0,0.25);
    padding: 4px 12px;
    display: flex; justify-content: space-between; align-items: center;
}
.id-card-footer span { font-size: 0.55rem; color: rgba(255,255,255,0.8); }

@media print {
    .id-card { box-shadow: none; border: 1px solid #ccc; }
}


/* ════════════════════════════════════════════════════════════
   10. PRINT STYLES — सबै portal shared
   ════════════════════════════════════════════════════════════ */
@media print {
    .coop-sidebar, .coop-topbar, .mobile-bottom-nav,
    .no-print, .action-btns, .btn-action,
    .sidebar-overlay { display: none !important; }

    body { background: #fff !important; color: #000; font-size: 12px; }
    .card { box-shadow: none !important; border: 1px solid #ddd !important; }
    .table th { background: #f0f0f0 !important; -webkit-print-color-adjust: exact; }
    a[href]:after { content: none !important; }

    .print-header { display: block !important; }
    .print-footer { display: block !important; }
}
.print-header, .print-footer { display: none; }

/* Source: assets/css/ui-fixes.css */
/*!
 * ═══════════════════════════════════════════════════════════════
 * UI FIXES v2.0 — Deep Audit Comprehensive Fix
 * dev-bandana v6.5 — All 4 portals (Public, Admin, Member, Verify)
 * ═══════════════════════════════════════════════════════════════
 * FIXES:
 *   1.  Font size — Devanagari readability
 *   2.  table-responsive-stack — desktop normal / mobile card-stack
 *   3.  Application tracker — type pills + type-pill-icon
 *   4.  Career page (cr-*) — missing layout classes
 *   5.  Icon alignment — FA icons inline with text
 *   6.  Auth login — input field box-sizing overflow fix (CRITICAL)
 *   7.  Notice page — section title / badge CSS
 *   8.  Welfare sidebar tabs
 *   9.  Icon+text inline — @supports :has() for browser safety
 *   10. Interest rates — font/section alignment
 *   11. Mobile responsive — all portals
 *   12. Admin tables — mobile card label polish
 *   13. Dropdown/nav-link safe flex (no Bootstrap breakage)
 *   14. Verify page — vp-card/vp-field layout
 *   15. Global utilities — skeleton, truncate, print, focus
 */

/* ═══════════════════════════════════════════════════════════════
   FIX 1: FONT SIZE — Devanagari Script Readability
   ─────────────────────────────────────────────────────────────── */
html { font-size: 15.5px; }

body {
    font-size: 1rem;
    line-height: 1.72;
    font-family: 'Mukta','Noto Sans Devanagari',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
    color: var(--text-color, #1e293b);
    padding: 0;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    overflow-x: hidden;
}
h1,h2,h3,h4,h5,h6,.card-title {
    font-family: 'Mukta','Noto Sans Devanagari','Poppins',sans-serif;
    font-weight: 700;
    line-height: 1.35;
}

/* ═══════════════════════════════════════════════════════════════
   FIX 2: TABLE-RESPONSIVE-STACK
   Desktop: normal table. Mobile (<=768px): card-stack.
   ─────────────────────────────────────────────────────────────── */
@media (min-width: 769px) {
    .table-responsive-stack thead { display: table-header-group; }
    .table-responsive-stack tbody { display: table-row-group; }
    .table-responsive-stack tr    { display: table-row; }
    .table-responsive-stack td,
    .table-responsive-stack th    { display: table-cell; }
    .table-responsive-stack td::before { display: none !important; }
}

@media (max-width: 768px) {
    .table-responsive-stack              { width: 100%; border-collapse: separate; border-spacing: 0; }
    .table-responsive-stack thead        { display: none; }
    .table-responsive-stack tbody,
    .table-responsive-stack tr           { display: block; }
    .table-responsive-stack tr           {
        border: 1px solid var(--border-color, #e5e7eb);
        border-radius: 10px;
        margin-bottom: 0.75rem;
        padding: 0.25rem 0;
        background: #fff;
        box-shadow: 0 1px 6px rgba(0,0,0,.06);
        overflow: hidden;
    }
    .table-responsive-stack td {
        display: flex;
        align-items: flex-start;
        gap: 0.5rem;
        padding: 0.45rem 0.85rem;
        border: none;
        border-bottom: 1px solid #f3f4f6;
        font-size: 0.88rem;
        min-width: 0;
        word-break: break-word;
    }
    .table-responsive-stack td:last-child { border-bottom: none; }
    /* Empty data-label (checkbox) — hide row on mobile */
    .table-responsive-stack td[data-label=""] { display: none !important; }
    /* Label as pseudo-element */
    .table-responsive-stack td[data-label]:not([data-label=""])::before {
        content: attr(data-label);
        font-weight: 700;
        font-size: 0.72rem;
        color: var(--text-muted, #6b7280);
        min-width: 85px;
        flex-shrink: 0;
        padding-top: 3px;
        text-transform: uppercase;
        letter-spacing: 0.04em;
        white-space: nowrap;
    }
    /* Actions cell — wrap buttons */
    .table-responsive-stack td[data-label="कार्य"],
    .table-responsive-stack td[data-label="कार्यहरू"] {
        flex-wrap: wrap;
        gap: 0.4rem;
    }
}

/* ═══════════════════════════════════════════════════════════════
   FIX 3: APPLICATION TRACKER — Type Pills + Icon
   ─────────────────────────────────────────────────────────────── */
.tracker-hero-section {
    background: linear-gradient(135deg, var(--primary-color,#1a5f2a) 0%, var(--primary-dark,#145021) 100%);
    padding: 3rem 0 2rem; position: relative; overflow: hidden; color: #fff;
}
.tracker-hero-title {
    font-size: clamp(1.5rem,3vw,2rem); font-weight: 800; color: #fff; margin-bottom: .5rem;
}
.tracker-hero-sub { color: rgba(255,255,255,.85); font-size: 1rem; }
.tracker-hero-icon-wrap {
    position: relative; display: inline-flex; align-items: center; justify-content: center; width: 80px; height: 80px;
}
.tracker-hero-icon-ring {
    width: 64px; height: 64px; border-radius: 50%;
    background: rgba(255,255,255,.2);
    display: flex; align-items: center; justify-content: center;
    font-size: 1.8rem; color: #fff;
}
.tracker-types-strip { margin-bottom: 1.5rem; }
.tracker-types-label {
    font-size: .82rem; font-weight: 600; color: var(--text-muted,#6b7280);
    text-transform: uppercase; letter-spacing: .06em; margin-bottom: .6rem;
}
.tracker-type-pills { display: flex; flex-wrap: wrap; gap: .5rem; align-items: center; }

/* type-pill-icon — was completely missing, caused broken icon circles */
.type-pill-icon {
    display: inline-flex; align-items: center; justify-content: center;
    width: 22px; height: 22px; border-radius: 50%;
    background: currentColor; opacity: 0.9;
    font-size: .68rem; flex-shrink: 0;
}
.type-pill-icon i,
.type-pill-icon .fas,
.type-pill-icon .far { color: #fff !important; vertical-align: middle; }

.type-pill {
    display: inline-flex; align-items: center; gap: .45rem;
    padding: .35rem .85rem; border-radius: 999px;
    background: rgba(26,95,42,.08);
    border: 1.5px solid var(--pill-color, var(--primary-color,#1a5f2a));
    color: var(--pill-color, var(--primary-color,#1a5f2a));
    font-size: .82rem; font-weight: 600;
    cursor: default; transition: background .18s, transform .15s;
    white-space: nowrap; text-decoration: none;
}
.type-pill:hover {
    background: var(--pill-color, var(--primary-color,#1a5f2a));
    color: #fff; transform: translateY(-1px);
}
.type-pill:hover .type-pill-icon { opacity: 0.5; }
@media (max-width: 576px) {
    .tracker-type-pills { gap: .3rem; }
    .type-pill { font-size: .74rem; padding: .28rem .6rem; }
    .type-pill-icon { width: 18px; height: 18px; font-size: .6rem; }
}
.tracker-card {
    border-radius: 14px; border: 1.5px solid var(--border-color,#e5e7eb);
    background: #fff; box-shadow: 0 4px 18px rgba(0,0,0,.07); overflow: hidden;
}
.tracker-status-badge {
    display: inline-flex; align-items: center; gap: .4rem;
    padding: .4rem 1rem; border-radius: 999px; font-size: .82rem; font-weight: 700;
}

/* ═══════════════════════════════════════════════════════════════
   FIX 4: CAREER PAGE (cr-*) — All missing layout classes
   ─────────────────────────────────────────────────────────────── */
.cr-hero { background: linear-gradient(135deg,var(--primary-color,#1a5f2a),var(--primary-dark,#145021)); padding:3.5rem 0 2.5rem; color:#fff; position:relative; overflow:hidden; }
.cr-hero-eyebrow { font-size:.78rem; font-weight:700; text-transform:uppercase; letter-spacing:.1em; opacity:.8; margin-bottom:.5rem; }
.cr-hero-title { font-size:clamp(1.6rem,4vw,2.5rem); font-weight:800; margin-bottom:.6rem; }
.cr-hero-sub { font-size:1.05rem; opacity:.88; max-width:520px; }
.cr-hero-stats { display:flex; gap:1.5rem; margin-top:1.5rem; flex-wrap:wrap; }
.cr-stat { text-align:center; }
.cr-stat-num { font-size:1.8rem; font-weight:800; line-height:1; }
.cr-stat-label { font-size:.75rem; opacity:.8; margin-top:.2rem; }
.cr-filter-bar { background:#fff; border-bottom:1px solid var(--border-color,#e5e7eb); padding:.75rem 0; position:sticky; top:0; z-index:100; }
.cr-filter-btn { display:inline-flex; align-items:center; gap:.4rem; padding:.4rem .9rem; border-radius:999px; border:1.5px solid var(--border-color,#e5e7eb); background:#f8fafc; color:var(--text-secondary,#475569); font-size:.82rem; font-weight:600; cursor:pointer; transition:all .15s; white-space:nowrap; }
.cr-filter-btn:hover,.cr-filter-btn.active { background:var(--primary-color,#1a5f2a); color:#fff; border-color:var(--primary-color,#1a5f2a); }
.cr-card { background:#fff; border-radius:14px; border:1.5px solid var(--border-color,#e5e7eb); overflow:hidden; transition:all .2s; height:100%; display:flex; flex-direction:column; }
.cr-card:hover { box-shadow:0 8px 28px rgba(0,0,0,.1); transform:translateY(-2px); border-color:var(--primary-color,#1a5f2a); }
.cr-card-header { padding:1.2rem 1.2rem .8rem; border-bottom:1px solid #f3f4f6; }
.cr-card-body { padding:.8rem 1.2rem; flex:1; }
.cr-card-footer { padding:.8rem 1.2rem; border-top:1px solid #f3f4f6; background:#fafbfc; }
.cr-type-badge { display:inline-flex; align-items:center; gap:.3rem; padding:.25rem .65rem; border-radius:999px; font-size:.72rem; font-weight:700; text-transform:uppercase; letter-spacing:.05em; }
.cr-type-badge.fulltime  { background:#dcfce7; color:#166534; }
.cr-type-badge.parttime  { background:#dbeafe; color:#1e40af; }
.cr-type-badge.contract  { background:#fef9c3; color:#854d0e; }
.cr-type-badge.volunteer { background:#f3e8ff; color:#6b21a8; }
.cr-meta-list { list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:.4rem; }
.cr-meta-item { display:flex; align-items:flex-start; gap:.5rem; font-size:.85rem; color:var(--text-secondary,#475569); }
.cr-meta-item i { color:var(--primary-color,#1a5f2a); margin-top:.2rem; flex-shrink:0; width:14px; text-align:center; }
.cr-detail-grid { display:grid; grid-template-columns:1fr 300px; gap:1.5rem; align-items:start; }
@media (max-width:992px) { .cr-detail-grid { grid-template-columns:1fr; } }
.cr-sidebar { background:#fff; border-radius:14px; border:1.5px solid var(--border-color,#e5e7eb); overflow:hidden; position:sticky; top:80px; }
.cr-sidebar-header { padding:1rem 1.2rem; background:linear-gradient(135deg,var(--primary-color,#1a5f2a),var(--primary-dark,#145021)); color:#fff; }
.cr-sidebar-body { padding:1rem 1.2rem; }
.cr-apply-btn { display:flex; align-items:center; justify-content:center; gap:.5rem; width:100%; padding:.8rem; border-radius:10px; background:var(--primary-color,#1a5f2a); color:#fff; font-weight:700; font-size:.95rem; border:none; cursor:pointer; transition:all .2s; text-decoration:none; }
.cr-apply-btn:hover { background:var(--primary-dark,#145021); color:#fff; transform:translateY(-1px); }
.cr-benefit-list { list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:.5rem; }
.cr-benefit-item { display:flex; align-items:flex-start; gap:.5rem; font-size:.85rem; color:var(--text-secondary,#475569); }
.cr-benefit-item i { color:var(--primary-color,#1a5f2a); margin-top:.2rem; flex-shrink:0; width:14px; text-align:center; }
.cr-divider { height:1px; background:var(--border-color,#e5e7eb); margin:1rem 0; }
.cr-section-label { font-size:.72rem; font-weight:700; text-transform:uppercase; letter-spacing:.06em; color:var(--text-muted,#9ca3af); margin-bottom:.6rem; }
.cr-empty { text-align:center; padding:3rem 1rem; }
.cr-empty-icon { font-size:3rem; color:var(--border-color,#e5e7eb); margin-bottom:1rem; }

/* ═══════════════════════════════════════════════════════════════
   FIX 5: ICON ALIGNMENT — Font Awesome vertical-align
   ─────────────────────────────────────────────────────────────── */
.fas,.far,.fab,.fal,.fad,.fa-solid,.fa-regular,.fa-brands {
    vertical-align: middle;
    line-height: inherit;
}
.btn .fas,.btn .far,.btn .fab,
.btn-sm .fas,.btn-sm .far,
.badge .fas,.badge .far,
.alert .fas,.alert .far { vertical-align: middle; margin-right: .15rem; }

/* Card/section header icon+title row */
.stg-section-title,.card-header h5,.card-header h4,.card-header h6 {
    display: flex; align-items: center; gap: .5rem;
    flex-wrap: wrap; margin: 0;
}

/* ═══════════════════════════════════════════════════════════════
   FIX 6: AUTH LOGIN — Input field overflow fix (CRITICAL BUG)
   admin/index.php, member/login.php, verify.php — inputs overflow
   ─────────────────────────────────────────────────────────────── */
.auth-portal-page *,
.auth-portal-page *::before,
.auth-portal-page *::after { box-sizing: border-box; }

.auth-portal-page input,
.auth-portal-page select,
.auth-portal-page textarea {
    width: 100%; max-width: 100%;
    box-sizing: border-box; min-width: 0;
}
.auth-portal-page .field,
.auth-portal-page .vp-field { width: 100%; max-width: 100%; }

.auth-portal-page .pw-wrap { position: relative; width: 100%; }
.auth-portal-page .pw-wrap input { padding-right: 44px; width: 100%; }
.auth-portal-page .pw-toggle {
    position: absolute; right: 12px; top: 50%; transform: translateY(-50%);
    background: none; border: none; cursor: pointer;
    color: var(--text-muted,#9ca3af); font-size: .9rem; padding: 4px;
}

.auth-portal-page .input-icon { position: relative; width: 100%; display: block; }
.auth-portal-page .input-icon > i:first-child {
    position: absolute; left: 12px; top: 50%; transform: translateY(-50%);
    color: var(--text-muted,#9ca3af); font-size: .9rem; pointer-events: none; z-index: 1;
}
.auth-portal-page .input-icon input { padding-left: 38px; width: 100%; }

.auth-portal-page .submit-btn {
    width: 100%; max-width: 100%;
    display: flex; align-items: center; justify-content: center; gap: .5rem;
}
.auth-portal-page .auth-card,
.auth-portal-page .sr-inner { overflow: hidden; }

@media (max-width: 480px) {
    body.auth-portal-page { padding: 10px 8px 20px; }
    .auth-portal-page .auth-card,
    .auth-portal-page .sr-inner { border-radius: 12px; margin: 0; }
    .auth-portal-page .split-layout { flex-direction: column !important; }
    .auth-portal-page .split-left { display: none; }
    .auth-portal-page .split-right { width: 100% !important; padding: 1.5rem 1rem !important; }
}

/* ═══════════════════════════════════════════════════════════════
   FIX 7: NOTICE PAGE badges & table classes
   ─────────────────────────────────────────────────────────────── */
.ntc-popup-badge { background:#fff8e1; color:#b45309; border:1px solid #fde68a; border-radius:999px; padding:.25rem .65rem; font-size:.75rem; font-weight:700; display:inline-flex; align-items:center; gap:.25rem; }
.ntc-no-badge    { background:#f3f4f6; color:#6b7280; border:1px solid #e5e7eb; border-radius:999px; padding:.25rem .65rem; font-size:.75rem; display:inline-flex; align-items:center; }
.ntc-status-on   { background:#dcfce7; color:#166534; border:1px solid #bbf7d0; border-radius:999px; padding:.25rem .65rem; font-size:.75rem; font-weight:700; display:inline-flex; align-items:center; gap:.25rem; }
.ntc-status-off  { background:#fee2e2; color:#991b1b; border:1px solid #fecaca; border-radius:999px; padding:.25rem .65rem; font-size:.75rem; font-weight:700; display:inline-flex; align-items:center; gap:.25rem; }
.ntc-muted { color:var(--text-muted,#6b7280); font-size:.85rem; }
.ntc-date-icon,.ntc-file-icon { color:var(--text-muted,#9ca3af); }
.ntc-btn-edit   { background:var(--primary-xlight,#e8f5e9); color:var(--primary-color,#1a5f2a); border:1px solid var(--primary-light,#a5d6a7); border-radius:8px; }
.ntc-btn-delete { background:#fee2e2; color:#991b1b; border:1px solid #fecaca; border-radius:8px; }

/* ═══════════════════════════════════════════════════════════════
   FIX 8: WELFARE SIDEBAR TABS
   ─────────────────────────────────────────────────────────────── */
.welfare-sidebar { border-radius:14px; border:1.5px solid var(--border-color,#e5e7eb); overflow:hidden; }
.welfare-nav-btn { display:flex; align-items:center; gap:.75rem; width:100%; padding:.8rem 1rem; border:none; background:transparent; font-size:.88rem; font-weight:600; color:var(--text-secondary,#475569); text-align:left; cursor:pointer; border-bottom:1px solid var(--border-color,#e5e7eb); transition:all .15s; }
.welfare-nav-btn:last-child { border-bottom:none; }
.welfare-nav-btn:hover,.welfare-nav-btn.active { background:var(--primary-xlight,#f0fdf4); color:var(--primary-color,#1a5f2a); border-left:3px solid var(--primary-color,#1a5f2a); padding-left:calc(1rem - 3px); }
.welfare-nav-btn i { width:18px; text-align:center; flex-shrink:0; }

/* ═══════════════════════════════════════════════════════════════
   FIX 9: ICON+TEXT INLINE — @supports :has() safe approach
   Scoped to avoid Bootstrap nav/dropdown breakage.
   ─────────────────────────────────────────────────────────────── */

/* Only apply :has() where browser supports it */
@supports selector(:has(*)) {
    a:has(> i.fas),
    a:has(> i.far),
    a:has(> i.fab),
    button:has(> i.fas),
    button:has(> i.far) {
        display: inline-flex;
        align-items: center;
        gap: 0.4rem;
    }
}

/* Header/topbar nav ONLY — scoped; NOT .nav-link globally (breaks Bootstrap dropdowns) */
.topbar-nav .nav-link,
.header-nav .nav-link,
.main-nav .nav-link,
.navbar-main .nav-link,
.top-bar .nav-link {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
}

/* Admin sidebar only */
.admin-nav-link,
.sidebar-link,
.side-nav-link,
.admin-sidebar .nav-link {
    display: flex; align-items: center; gap: .6rem;
    text-decoration: none; white-space: nowrap;
}

/* Dropdown items — standard block preserved, just add icon spacing */
.dropdown-menu .dropdown-item { display: flex; align-items: center; gap: .5rem; }
.dropdown-menu .dropdown-item > i { width: 18px; text-align: center; flex-shrink: 0; }

/* Breadcrumb */
.breadcrumb { align-items: center; }
.breadcrumb-item { display: flex; align-items: center; }

/* Career sidebar list icons */
.cr-benefit-item i,.cr-meta-item i,.cr-actions i {
    flex-shrink: 0; width: 16px; text-align: center;
}

/* ═══════════════════════════════════════════════════════════════
   FIX 10: INTEREST RATES PAGE — Section alignment
   ─────────────────────────────────────────────────────────────── */
.rates-card-modern {
    background:#fff; border-radius:14px;
    border:1.5px solid var(--border-color,#e5e7eb);
    overflow:hidden; box-shadow:0 3px 14px rgba(0,0,0,.07); height:100%;
}
.rates-header-modern { padding:1.25rem 1.5rem; color:#fff; font-size:1rem; display:flex; align-items:center; gap:.5rem; }
.rates-card-modern.saving-rates .rates-header-modern {
    background:linear-gradient(135deg,var(--primary-color,#1a5f2a),var(--primary-dark,#145021));
}
.rates-card-modern:not(.saving-rates) .rates-header-modern {
    background:linear-gradient(135deg,var(--secondary-color,#c0392b),var(--secondary-dark,#922b21));
}
.section-header .section-subtitle,
.section-header > p { font-size:.95rem; color:var(--text-muted,#6b7280); line-height:1.7; max-width:540px; margin:.5rem auto 0; }
.section-divider { width:48px; height:3px; background:linear-gradient(90deg,var(--primary-color,#1a5f2a),var(--secondary-color,#c0392b)); border-radius:3px; margin:.85rem auto; }
.section-badge { display:inline-flex; align-items:center; gap:.35rem; font-size:.78rem; font-weight:700; color:var(--primary-color,#1a5f2a); background:rgba(26,95,42,.08); border:1px solid rgba(26,95,42,.2); border-radius:999px; padding:.3rem .85rem; text-transform:uppercase; letter-spacing:.05em; }

/* ═══════════════════════════════════════════════════════════════
   FIX 11: MOBILE RESPONSIVE — All portals
   ─────────────────────────────────────────────────────────────── */
@media (max-width: 576px) {
    body { overflow-x: hidden; }
    .container,.container-fluid { padding-left:12px; padding-right:12px; }
    .card { overflow: hidden; }

    /* Stacked action buttons */
    .adm-action-icons { flex-wrap: wrap; gap: 4px; }
    .admin-form-actions { flex-wrap: wrap; gap: 8px; }

    /* Input groups no overflow */
    .input-group { flex-wrap: nowrap; min-width: 0; }
    .input-group > * { min-width: 0; }
    .input-group input { min-width: 0; flex: 1; }

    /* Hide decorative backgrounds on mobile */
    .page-banner-bg,.hero-bg-circle { display: none; }

    /* Tables scroll */
    .table-overflow-x { overflow-x: auto; -webkit-overflow-scrolling: touch; }
}

/* ═══════════════════════════════════════════════════════════════
   FIX 12: ADMIN TABLE — Mobile card polish
   ─────────────────────────────────────────────────────────────── */
@media (max-width: 768px) {
    .admin-empty-state { text-align:center; padding:2rem; color:var(--text-muted,#9ca3af); }
    .admin-empty-state i { font-size:2.5rem; margin-bottom:.75rem; display:block; }

    .adm-icon-btn { display:inline-flex; align-items:center; justify-content:center; width:32px; height:32px; border-radius:8px; }

    .badge-status { display:inline-flex; align-items:center; gap:.3rem; padding:.3rem .7rem; border-radius:999px; font-size:.75rem; font-weight:700; }

    .kyc-list-avatar { width:32px; height:32px; border-radius:8px; object-fit:cover; }
    .av-letter,.av-kyc { width:32px; height:32px; border-radius:8px; display:flex; align-items:center; justify-content:center; font-weight:700; color:#fff; background:var(--primary-color,#1a5f2a); font-size:.9rem; flex-shrink:0; }

    .track-badge { font-size:.72rem; font-family:monospace; background:#f3f4f6; padding:.2rem .5rem; border-radius:6px; }

    /* KYC action buttons row wraps */
    .adm-action-icons,.qaction-form { display:inline-flex; flex-wrap:wrap; gap:4px; }
}

/* ═══════════════════════════════════════════════════════════════
   FIX 13: VERIFY PAGE — vp-card full layout
   ─────────────────────────────────────────────────────────────── */
.vp-outer {
    min-height:100dvh; display:flex; flex-direction:column;
    align-items:center; justify-content:center;
    padding:1.5rem 1rem; background:var(--bg-base,#f8fafc);
}
.vp-card {
    width:100%; max-width:480px; background:#fff;
    border-radius:20px; border:1px solid var(--border-color,#e5e7eb);
    box-shadow:0 20px 44px rgba(15,23,42,.07);
    padding:2rem; box-sizing:border-box; overflow:hidden;
}
.vp-icon {
    width:56px; height:56px; border-radius:16px;
    background:linear-gradient(135deg,var(--primary-color,#1a5f2a),var(--primary-dark,#145021));
    display:flex; align-items:center; justify-content:center;
    font-size:1.5rem; color:#fff; margin:0 auto 1rem;
}
.vp-field { margin-bottom:.85rem; }
.vp-field label { font-size:.82rem; font-weight:600; color:var(--text-secondary,#475569); display:block; margin-bottom:.35rem; }
.vp-field input { width:100%; box-sizing:border-box; }
.vp-submit {
    width:100%; padding:.75rem;
    background:var(--primary-color,#1a5f2a); color:#fff;
    border:none; border-radius:10px; font-size:.95rem; font-weight:700;
    cursor:pointer; display:flex; align-items:center; justify-content:center; gap:.5rem;
    transition:background .2s;
}
.vp-submit:hover { background:var(--primary-dark,#145021); }
.vp-sub { max-width:36rem; margin-left:auto; margin-right:auto; padding:0 4px; line-height:1.65; }

/* ═══════════════════════════════════════════════════════════════
   FIX 14: MEMBER PORTAL MOBILE
   ─────────────────────────────────────────────────────────────── */
@media (max-width: 768px) {
    .mem-dashboard-grid { grid-template-columns:1fr 1fr !important; }
    .mem-stat-card { padding:.85rem; }
    .mem-stat-val { font-size:1.3rem; }
    .mem-sidebar { position:static !important; }
    .mem-sidebar-inner { border-radius:12px; margin-bottom:1rem; }
}
.notif-badge {
    position:absolute; top:-4px; right:-4px;
    background:var(--secondary-color,#c0392b); color:#fff;
    font-size:.65rem; font-weight:800; border-radius:999px;
    padding:2px 5px; min-width:16px; text-align:center; border:2px solid #fff;
}

/* ═══════════════════════════════════════════════════════════════
   FIX 15: GLOBAL UTILITIES — All portals
   ─────────────────────────────────────────────────────────────── */
/* Skeleton loader */
.skeleton { background:linear-gradient(90deg,#f0f0f0 25%,#e8e8e8 50%,#f0f0f0 75%); background-size:200% 100%; animation:skeleton-shimmer 1.4s infinite; border-radius:4px; }
@keyframes skeleton-shimmer { to { background-position:-200% 0; } }

/* Text clamp */
.text-truncate-2 { display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.text-truncate-3 { display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden; }

/* Sticky table header */
.table-sticky-head thead th {
    position:sticky; top:0; z-index:2;
    background:var(--bg-card,#fff); box-shadow:0 1px 0 var(--border-color,#e5e7eb);
}

/* Print */
@media print {
    .no-print { display:none !important; }
    .print-only { display:block !important; }
    body { font-size:12px; }
    .card { box-shadow:none; border:1px solid #ddd; }
}

/* Focus visible accessibility */
:focus-visible { outline:2px solid var(--primary-color,#1a5f2a); outline-offset:2px; }
button:focus-visible, a:focus-visible { border-radius:4px; }

/* ═══════════════════════════════════════════════════════════════
   SHARED: Admin + Member page header hero bars
   ─────────────────────────────────────────────────────────────── */
.page-hero {
    background:linear-gradient(135deg,var(--primary-color,#1a5f2a),var(--primary-dark,#145021));
    padding:2rem 0; color:#fff;
}
/* ── Verify page logo — strict size limit ── */
.vp-page-logo { text-align: center; }
.vp-page-logo img,
body.auth-portal-page .vp-page-logo img,
body[class*="auth"] .vp-page-logo img {
    max-height: 70px !important;
    max-width: 200px !important;
    width: auto !important;
    height: auto !important;
    object-fit: contain !important;
    border-radius: 8px;
    display: block;
    margin: 0 auto .5rem;
}

