/* ================= GOOGLE FONTS ================= */
@import url('https://fonts.googleapis.com/css2?family=Merriweather:ital,wght@0,300;0,400;0,700;0,900;1,400&family=Roboto:wght@300;400;500;700;900&display=swap');

/* ================= VARIABLES ================= */
:root {
    --brand-navy:       #00377B;
    --brand-orange:     #FF6C00;
    --brand-blue-light: #61B9F0;
    --brand-pale-blue:  #F2F8FD;
    --brand-soft-blue:  #E4F3FD;
    --primary-gradient:   linear-gradient(135deg,#00377B 0%,#0055B3 100%);
    --secondary-gradient: linear-gradient(135deg,#FF6C00 0%,#FF9240 100%);
    --accent-gradient:    linear-gradient(135deg,#FF6C00 0%,#FF9240 100%);
    --subhead-gradient:   linear-gradient(135deg,#61B9F0 0%,#00377B 100%);
    --tags-gradient:      linear-gradient(135deg,#f59e0b 0%,#ef4444 100%);
    --bg-primary:    #ffffff;
    --bg-secondary:  #F0F4F8;
    --bg-tertiary:   #F2F8FD;
    --text-primary:  #0D1B2A;
    --text-secondary:#2E4A6B;
    --text-tertiary: #7B9BBF;
    --border-color:  #D3E4F2;
    --shadow-sm: 0 2px 8px  rgba(0,55,123,.06);
    --shadow-md: 0 8px 24px rgba(0,55,123,.10);
    --shadow-lg: 0 16px 48px rgba(0,55,123,.14);
    --shadow-xl: 0 24px 64px rgba(0,55,123,.18);
    --blur-amount: 20px;
    --header-h: 72px;
    --font-title: "Merriweather",serif;
    --font-body:  "Roboto",sans-serif;
}

[data-theme="dark"] {
    --bg-primary:    #0D1B2A;
    --bg-secondary:  #0a1628;
    --bg-tertiary:   #1A3554;
    --text-primary:  #F2F8FD;
    --text-secondary:#A8C8E8;
    --text-tertiary: #61B9F0;
    --border-color:  rgba(97,185,240,.12);
    --shadow-sm: 0 2px 8px  rgba(0,0,0,.35);
    --shadow-md: 0 8px 24px rgba(0,0,0,.45);
    --shadow-lg: 0 16px 48px rgba(0,0,0,.55);
    --shadow-xl: 0 24px 64px rgba(0,0,0,.65);
}

*,*::before,*::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body { background:var(--bg-secondary); font-family:var(--font-body); color:var(--text-primary); line-height:1.6; overflow-x:hidden; }
h1,h2,h3,h4,h5,h6 { font-family:var(--font-title); }
a { text-decoration:none; }

/* ── FILTER OVERLAY ── */
.filter-overlay { position:fixed; inset:0; z-index:998; background:rgba(0,20,50,.55); backdrop-filter:blur(6px); opacity:0; pointer-events:none; transition:opacity .35s; }
.filter-overlay.show { opacity:1; pointer-events:all; }

/* ── FILTER PANELS ── */
.filter-panel { position:fixed; top:var(--header-h); left:0; right:0; z-index:999; max-height:calc(85vh - var(--header-h)); overflow-y:auto; background:var(--bg-primary); border-bottom:2px solid var(--border-color); box-shadow:var(--shadow-xl); padding:24px 44px 32px; transform:translateY(-110%); transition:transform .42s cubic-bezier(.34,1.1,.64,1); }
.filter-panel.open { transform:translateY(0); }
[data-theme="dark"] .filter-panel { background:var(--bg-secondary); }
.panel-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:18px; }
.panel-title-group { display:flex; align-items:center; gap:14px; }
.panel-icon-circle { width:46px; height:46px; border-radius:13px; display:flex; align-items:center; justify-content:center; font-size:1.25rem; flex-shrink:0; }
.panel-icon-circle.campus { background:var(--primary-gradient); color:#fff; }
.panel-icon-circle.dept   { background:var(--subhead-gradient); color:#fff; }
.panel-icon-circle.tags   { background:var(--tags-gradient);    color:#fff; }
.panel-title { font-family:var(--font-title); font-size:1.15rem; font-weight:700; color:var(--brand-navy); margin:0 0 2px; }
[data-theme="dark"] .panel-title { color:var(--text-primary); }
.panel-subtitle { font-size:.8rem; color:var(--text-tertiary); }
.panel-close-btn { width:40px; height:40px; border-radius:50%; border:2px solid var(--border-color); background:var(--bg-secondary); cursor:pointer; display:flex; align-items:center; justify-content:center; font-size:.95rem; color:var(--text-secondary); transition:all .25s; }
.panel-close-btn:hover { background:var(--primary-gradient); border-color:transparent; color:#fff; transform:scale(1.08) rotate(90deg); }
.panel-divider { display:flex; align-items:center; gap:12px; margin:4px 0 16px; }
.panel-divider span { font-size:.68rem; font-weight:700; letter-spacing:2px; text-transform:uppercase; color:var(--text-tertiary); white-space:nowrap; }
.panel-divider::before,.panel-divider::after { content:''; flex:1; height:1px; background:var(--border-color); }

/* ── CAMPUS GRID ── */
.campus-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(200px,1fr)); gap:12px; }
.campus-card { border-radius:14px; padding:20px 18px; cursor:pointer; border:2px solid var(--border-color); background:var(--bg-tertiary); transition:all .28s; display:flex; flex-direction:column; align-items:flex-start; gap:10px; color:inherit; text-decoration:none; }
.campus-card:hover,.campus-card.active { border-color:var(--brand-navy); background:var(--tags-gradient); transform:translateY(-3px); box-shadow:var(--shadow-lg); }
.campus-card:hover .campus-card-name,.campus-card.active .campus-card-name { color:#fff; }
.campus-card:hover .campus-card-sub,.campus-card.active .campus-card-sub { color:rgba(255,255,255,.8); }
.campus-card-icon { width:42px; height:42px; border-radius:11px; background:var(--primary-gradient); display:flex; align-items:center; justify-content:center; font-size:1.1rem; color:#fff; }
.campus-card-name { font-family:var(--font-title); font-weight:700; font-size:.9rem; color:var(--brand-navy); }
[data-theme="dark"] .campus-card-name { color:var(--text-secondary); }
.campus-card-sub { font-size:.75rem; color:var(--text-tertiary); }

/* ── DEPT GRID ── */
.dept-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(180px,1fr)); gap:10px; }
.dept-card { border-radius:13px; padding:14px 16px; cursor:pointer; border:2px solid var(--border-color); background:var(--bg-tertiary); transition:all .28s; display:flex; align-items:center; gap:12px; color:inherit; text-decoration:none; }
.dept-card:hover,.dept-card.active { border-color:var(--brand-blue-light); background:var(--tags-gradient); transform:translateX(5px); }
.dept-card:hover .dept-card-name,.dept-card.active .dept-card-name { color:#fff; }
.dept-card:hover .dept-card-count,.dept-card.active .dept-card-count { color:rgba(255,255,255,.8); }
.dept-card-icon { width:38px; height:38px; border-radius:9px; display:flex; align-items:center; justify-content:center; font-size:1rem; color:#fff; flex-shrink:0; }
.dept-card-name { font-family:var(--font-title); font-weight:700; font-size:.84rem; color:var(--brand-navy); }
[data-theme="dark"] .dept-card-name { color:var(--text-secondary); }
.dept-card-count { font-size:.72rem; color:var(--text-tertiary); margin-top:2px; }

/* ── TAGS GRID ── */
.tags-grid { display:flex; flex-wrap:wrap; gap:10px; padding:4px 0; }
.tag-chip { display:inline-flex; align-items:center; gap:6px; padding:.55rem 1.1rem; background:var(--bg-tertiary); border:2px solid var(--border-color); border-radius:50px; color:var(--text-secondary); font-size:.85rem; font-weight:600; cursor:pointer; transition:all .25s; text-decoration:none; }
.tag-chip i { font-size:.8rem; color:var(--brand-orange); transition:color .25s; }
.tag-chip:hover,.tag-chip.active { background:var(--tags-gradient); border-color:transparent; color:#fff; transform:translateY(-2px); box-shadow:var(--shadow-md); }
.tag-chip:hover i,.tag-chip.active i { color:#fff; }

/* ══════════════════════════════════════
   HEADER
══════════════════════════════════════ */
.light-header { position:sticky; top:0; z-index:1000; background:rgba(255,255,255,.92); backdrop-filter:blur(var(--blur-amount)); border-bottom:1px solid var(--border-color); box-shadow:var(--shadow-sm); }
[data-theme="dark"] .light-header { background:rgba(10,22,40,.92); }
.header-inner { max-width:1400px; margin:0 auto; padding:1rem 2rem; display:flex; justify-content:space-between; align-items:center; gap:1rem; }
.logo-theme-wrapper { display:flex; align-items:center; gap:.75rem; flex-shrink:0; }
.portal-logo img { height:44px; transition:transform .3s; }
.portal-logo img:hover { transform:scale(1.05) rotate(-2deg); }
.theme-toggle-btn { background:var(--bg-primary); border:2px solid var(--border-color); border-radius:12px; width:44px; height:44px; display:flex; align-items:center; justify-content:center; cursor:pointer; transition:all .3s; }
.theme-toggle-btn:hover { background:var(--primary-gradient); border-color:transparent; }
.theme-toggle-btn:hover .theme-icon { color:#fff; transform:rotate(30deg); }
.theme-icon { font-size:20px; color:var(--text-primary); transition:all .3s; }
.top-menu { display:flex; gap:.4rem; flex:1; justify-content:center; }
.menu-link { position:relative; padding:.7rem 1.2rem; color:var(--text-secondary)!important; font-family:var(--font-body); font-weight:500; font-size:14px; border-radius:10px; transition:all .3s; letter-spacing:.02em; text-decoration:none; }
.menu-link span { position:relative; z-index:2; }
.menu-link::before { content:''; position:absolute; inset:0; background:var(--primary-gradient); border-radius:10px; opacity:0; transition:opacity .3s; }
.menu-link:hover,.menu-link.active,.menu-link.panel-active { color:#fff!important; }
.menu-link:hover::before,.menu-link.active::before,.menu-link.panel-active::before { opacity:1; }
.auth-buttons { display:flex; gap:1rem; align-items:center; flex-shrink:0; }
.profile-dropdown-container { position:relative; }
.profile-dropdown-trigger { display:flex; align-items:center; gap:.6rem; background:var(--bg-primary); border:2px solid var(--border-color); border-radius:50px; padding:.45rem .9rem .45rem .45rem; cursor:pointer; transition:all .3s; }
.profile-dropdown-trigger:hover { background:var(--brand-soft-blue); }
.profile-dropdown-trigger .user-avatar { width:38px; height:38px; border-radius:50%; background:var(--primary-gradient); display:flex; align-items:center; justify-content:center; font-weight:700; font-size:15px; color:#fff; }
.dropdown-arrow { color:var(--text-secondary); font-size:14px; transition:transform .3s; }
.profile-dropdown-trigger:hover .dropdown-arrow { transform:rotate(180deg); }
.profile-dropdown-menu { position:absolute; top:calc(100% + 10px); right:0; width:300px; background:var(--bg-primary); border:2px solid var(--border-color); border-radius:20px; box-shadow:var(--shadow-xl); opacity:0; visibility:hidden; transform:translateY(-10px); transition:all .3s; z-index:1001; overflow:hidden; }
.profile-dropdown-menu.show { opacity:1; visibility:visible; transform:translateY(0); }
.dropdown-header { display:flex; align-items:center; gap:1rem; padding:1.25rem; background:var(--brand-soft-blue); border-bottom:1px solid var(--border-color); }
[data-theme="dark"] .dropdown-header { background:#112236; }
.user-avatar-large { width:50px; height:50px; border-radius:50%; background:var(--primary-gradient); display:flex; align-items:center; justify-content:center; font-weight:700; font-size:20px; color:#fff; flex-shrink:0; }
.user-info { flex:1; min-width:0; }
.user-name { font-family:var(--font-title); font-size:1rem; font-weight:700; color:var(--brand-navy); margin:0 0 .2rem; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
[data-theme="dark"] .user-name { color:#F2F8FD; }
.user-email { font-size:.82rem; color:var(--text-secondary); margin:0; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.dropdown-divider { height:1px; background:var(--border-color); }
.dropdown-items { padding:.6rem; }
.dropdown-item { display:flex; align-items:center; gap:.75rem; padding:.75rem .9rem; color:var(--text-primary); border-radius:10px; transition:all .3s; font-size:.9rem; text-decoration:none; }
.dropdown-item i { font-size:18px; color:var(--brand-blue-light); width:22px; text-align:center; }
.dropdown-item:hover { background:var(--brand-pale-blue); color:var(--brand-navy); }
.dropdown-settings { padding:.6rem; }
.dropdown-setting-item { display:flex; align-items:center; justify-content:space-between; padding:.75rem .9rem; border-radius:10px; margin-bottom:.4rem; background:var(--bg-tertiary); }
.setting-label { display:flex; align-items:center; gap:.75rem; font-weight:500; font-size:.9rem; color:var(--text-primary); }
.setting-label i { font-size:18px; color:var(--brand-blue-light); width:22px; text-align:center; }
.setting-select { background:var(--bg-primary); border:2px solid var(--border-color); border-radius:8px; padding:.4rem .6rem; color:var(--text-primary); font-size:.82rem; cursor:pointer; }
.logout-item i { color:#ef4444!important; }
.logout-item:hover { background:rgba(239,68,68,.08)!important; }
.btn-auth { padding:.65rem 1.3rem; border-radius:12px; font-family:var(--font-body); font-size:14px; font-weight:700; transition:all .3s; display:inline-flex; align-items:center; gap:.5rem; border:none; }
.btn-signin-header { background:var(--primary-gradient); color:#fff; }
.btn-signin-header:hover { transform:translateY(-2px); color:#fff; }
.mobile-menu-toggle { display:none; background:var(--bg-primary); border:2px solid var(--border-color); border-radius:12px; color:var(--text-primary); font-size:22px; padding:.45rem .7rem; cursor:pointer; }

/* ══════════════════════════════════════
   MOBILE MENU  ✅ SCROLL FIX
══════════════════════════════════════ */

/* Lock page scroll while menu is open */
body.menu-open { overflow: hidden; }

.mobile-dropdown {
    display: none;
    background: var(--bg-primary);
    border-top: 1px solid var(--border-color);
    padding: 1.25rem;
    /* ✅ Scroll lives here, not on the body */
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior: contain;
}

.mobile-dropdown.open {
    display: block;
    /* ✅ Cap height so it never pushes past the screen */
    max-height: calc(100dvh - var(--header-h));
}

.mobile-menu-section { display:flex; flex-direction:column; gap:.75rem; }
.mobile-user-info { display:flex; align-items:center; gap:.75rem; padding:1rem 1.1rem; background:var(--brand-pale-blue); border-radius:12px; border:2px solid var(--border-color); }
.mobile-user-info .user-avatar { width:36px; height:36px; border-radius:50%; background:var(--primary-gradient); display:flex; align-items:center; justify-content:center; font-weight:700; font-size:14px; color:#fff; flex-shrink:0; }
.mobile-username { font-family:var(--font-title); font-weight:700; color:var(--brand-navy); font-size:1rem; display:block; }
[data-theme="dark"] .mobile-username { color:var(--brand-orange); }
.mobile-menu-link { color:var(--text-primary)!important; font-weight:500; padding:1rem 1.1rem; border-radius:12px; background:var(--bg-secondary); border:2px solid var(--border-color); display:flex; align-items:center; font-size:.9rem; text-decoration:none; transition:all .3s; }
.mobile-menu-link:hover { background:var(--primary-gradient); border-color:transparent; color:#fff!important; }
.mobile-filter-toggle { cursor:pointer; user-select:none; }
.mobile-filter-toggle .bi-chevron-down { transition:transform .3s; flex-shrink:0; }
.mobile-accordion { display:none; flex-direction:column; background:var(--bg-tertiary); border:1px solid var(--border-color); border-radius:12px; margin-top:-4px; overflow:hidden; }
.mobile-accordion.open { display:flex; }
.mobile-filter-item { display:flex; align-items:center; gap:10px; padding:11px 16px; font-size:.86rem; font-weight:500; color:var(--text-primary); border-bottom:1px solid var(--border-color); transition:background .2s,padding-left .2s; text-decoration:none; }
.mobile-filter-item:last-child { border-bottom:none; }
.mobile-filter-item:hover,.mobile-filter-item.mobile-filter-active { background:var(--brand-soft-blue); color:var(--brand-navy); padding-left:22px; }
[data-theme="dark"] .mobile-filter-item:hover { background:var(--bg-secondary); color:var(--text-primary); }
.mobile-category-row { display:flex; flex-wrap:wrap; gap:.5rem; padding:.5rem 0; }
.mobile-pill { display:inline-flex; align-items:center; padding:.5rem 1rem; background:var(--bg-secondary); border:2px solid var(--border-color); border-radius:50px; color:var(--text-secondary); font-size:.82rem; font-weight:500; transition:all .25s; text-decoration:none; }
.mobile-pill:hover,.mobile-pill.active { background:var(--primary-gradient); border-color:transparent; color:#fff!important; }
.mobile-signout,.mobile-signin { padding:1rem 1.1rem!important; border-radius:12px; font-weight:700; display:flex; align-items:center; gap:.6rem; transition:all .3s; font-size:.9rem; text-decoration:none; }
.mobile-signout { color:#ef4444!important; background:rgba(239,68,68,.08)!important; border:2px solid rgba(239,68,68,.25)!important; }
.mobile-signin { background:var(--primary-gradient)!important; color:#fff!important; border:none!important; }

/* ══════════════════════════════════════
   SIDEBAR MENU DROPDOWN (mobile)
══════════════════════════════════════ */
.side-menu-dropdown { display:none; background:var(--bg-primary); border-bottom:1px solid var(--border-color); }
.side-menu-toggle { width:100%; background:var(--brand-pale-blue); color:var(--brand-navy); border:none; padding:1rem 2rem; text-align:left; font-family:var(--font-body); font-size:16px; font-weight:600; cursor:pointer; display:flex; justify-content:space-between; align-items:center; transition:all .3s; }
.side-menu-toggle:hover { background:var(--brand-soft-blue); }
.side-menu-toggle .bi-chevron-down { transition:transform .3s; }
.side-menu-content { max-height:0; overflow:hidden; transition:max-height .35s ease; }
.side-menu-content.active { max-height:300px; }
.side-menu-item { display:flex; align-items:center; gap:1rem; padding:1rem 2rem; color:var(--text-primary); text-decoration:none; font-family:var(--font-body); font-size:15px; font-weight:500; transition:all .3s; border-bottom:1px solid var(--border-color); }
.side-menu-item:last-child { border-bottom:none; }
.side-menu-item:hover { background:var(--brand-pale-blue); color:var(--brand-navy); }
.side-menu-item.active { background:var(--primary-gradient); color:#fff; }
.side-menu-item.active i { color:#fff; }
[data-theme="dark"] .side-menu-item { color:var(--text-primary); }
[data-theme="dark"] .side-menu-item:hover { background:var(--bg-tertiary); }

/* ══════════════════════════════════════
   CLUB HEADER
══════════════════════════════════════ */
.club-header-full { width:100%; background:linear-gradient(135deg,#001e4d 0%,#00377B 35%,#0055B3 70%,#0070d4 100%); position:relative; overflow:hidden; padding:3rem 0 2.5rem; }
.club-header-full::before { content:''; position:absolute; top:0; left:0; right:0; height:4px; background:linear-gradient(90deg,#FF6C00 0%,#FF9240 50%,#FF6C00 100%); z-index:3; }
.ch-blob-1 { position:absolute; width:480px; height:480px; background:radial-gradient(circle,rgba(97,185,240,.10) 0%,transparent 65%); border-radius:50%; top:-180px; right:-80px; pointer-events:none; }
.ch-blob-2 { position:absolute; width:320px; height:320px; background:radial-gradient(circle,rgba(255,108,0,.08) 0%,transparent 65%); border-radius:50%; bottom:-120px; left:8%; pointer-events:none; }
.ch-blob-3 { position:absolute; width:200px; height:200px; background:radial-gradient(circle,rgba(255,255,255,.05) 0%,transparent 65%); border-radius:50%; top:30%; left:40%; pointer-events:none; }
.ch-grid { position:absolute; inset:0; background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px); background-size:44px 44px; pointer-events:none; }
.club-header-inner { max-width:1400px; margin:0 auto; padding:0 2.5rem; display:flex; gap:2.5rem; align-items:flex-start; position:relative; z-index:1; }
.club-header-full .club-logo-wrapper { position:relative; flex-shrink:0; margin-top:.25rem; }
.club-header-full .logo-glow { position:absolute; inset:-12px; background:rgba(97,185,240,.18); border-radius:26px; filter:blur(20px); z-index:0; }
.club-header-full .club-logo { width:150px; height:150px; border-radius:20px; object-fit:cover; border:3px solid rgba(255,255,255,.35); box-shadow:0 12px 40px rgba(0,0,0,.30),0 0 0 1px rgba(255,255,255,.10); position:relative; z-index:1; background:rgba(255,255,255,.08); }
.club-header-full .club-info-wrapper { flex:1; display:flex; flex-direction:column; gap:1rem; padding-top:.1rem; }
.ch-title-row { display:flex; align-items:flex-start; justify-content:space-between; gap:1rem; }
.club-header-full .club-title { font-family:var(--font-title); font-size:2.4rem; font-weight:900; color:#ffffff; margin:0; line-height:1.15; letter-spacing:-.025em; text-shadow:0 2px 16px rgba(0,0,0,.22); }
.ch-edit-btn { flex-shrink:0; display:inline-flex; align-items:center; gap:.4rem; padding:.45rem 1rem; background:rgba(255,255,255,.12); border:1.5px solid rgba(255,255,255,.25); border-radius:8px; color:#fff; font-size:.8rem; font-weight:600; font-family:var(--font-body); backdrop-filter:blur(8px); transition:all .3s; cursor:pointer; text-decoration:none; white-space:nowrap; margin-top:.3rem; }
.ch-edit-btn:hover { background:rgba(255,255,255,.22); color:#fff; transform:translateY(-1px); }
.club-header-full .club-tagline { font-size:.97rem; color:rgba(255,255,255,.72); margin:0; font-style:italic; line-height:1.5; }
.club-header-full .club-meta-row { display:flex; gap:1.75rem; align-items:center; flex-wrap:wrap; padding:.85rem 0; border-top:1px solid rgba(255,255,255,.14); border-bottom:1px solid rgba(255,255,255,.14); }
.club-header-full .meta-item { display:flex; align-items:center; gap:.55rem; font-size:.88rem; color:rgba(255,255,255,.82); }
.club-header-full .meta-item i { font-size:.95rem; color:#FF9240; }
.club-header-full .stats-badges-row { display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:.85rem; }
.club-header-full .info-badges,.club-header-full .action-badges { display:flex; gap:.65rem; flex-wrap:wrap; align-items:center; }
.club-header-full .info-badge { display:inline-flex; align-items:center; gap:.45rem; padding:.45rem 1rem; background:rgba(255,255,255,.12); border:1.5px solid rgba(255,255,255,.22); border-radius:8px; font-size:.83rem; font-weight:600; color:#ffffff; backdrop-filter:blur(8px); transition:all .3s; white-space:nowrap; }
.club-header-full .info-badge:hover { background:rgba(255,255,255,.20); transform:translateY(-1px); }
.club-header-full .info-badge i { font-size:.88rem; color:#61B9F0; }
.club-header-full .stat-badge { display:inline-flex; align-items:center; gap:.45rem; padding:.45rem 1rem; background:rgba(255,255,255,.10); border:1.5px solid rgba(255,255,255,.18); border-radius:8px; font-size:.9rem; font-weight:700; color:#ffffff; backdrop-filter:blur(8px); cursor:default; transition:all .3s; white-space:nowrap; }
.club-header-full .stat-badge i { font-size:.88rem; color:rgba(255,255,255,.75); }
.club-header-full .like-form { display:inline-block; }
.club-header-full .like-badge { cursor:pointer; border-color:hsl(0,88%,48%); color:red; }
.club-header-full .like-badge i { color:red; }
.club-header-full .like-badge:hover { background:rgba(239,68,68,.28); transform:translateY(-2px) scale(1.04); }
.club-header-full .social-links-row { display:flex; gap:.6rem; flex-wrap:wrap; }
.club-header-full .social-btn { width:38px; height:38px; display:flex; align-items:center; justify-content:center; border-radius:9px; background:rgba(255,255,255,.12); border:1.5px solid rgba(255,255,255,.22); color:#fff; text-decoration:none; transition:all .3s; backdrop-filter:blur(8px); }
.club-header-full .social-btn:hover { background:var(--secondary-gradient); border-color:transparent; transform:translateY(-3px) scale(1.08); box-shadow:0 6px 18px rgba(255,108,0,.38); }
.club-header-full .social-btn i { font-size:16px; color:#fff; }

/* ══════════════════════════════════════
   LAYOUT WRAPPER
══════════════════════════════════════ */
.layout-wrapper { max-width:1400px; margin:0 auto; display:flex; gap:1.75rem; padding:2rem 2.5rem; position:relative; z-index:1; }

/* ── MINI SIDEBAR ── */
.mini-sidebar { width:64px; background:var(--bg-primary); border-radius:18px; flex-shrink:0; height:fit-content; position:sticky; top:90px; box-shadow:var(--shadow-lg); display:flex; flex-direction:column; border:2px solid var(--border-color); overflow:visible; }
.sidebar-item { height:64px; display:flex; align-items:center; justify-content:center; color:var(--brand-blue-light); font-size:22px; text-decoration:none; transition:all .3s; border-bottom:1px solid var(--border-color); position:relative; overflow:hidden; }
.sidebar-item:first-child { border-radius:16px 16px 0 0; }
.sidebar-item:last-child  { border-bottom:none; border-radius:0 0 16px 16px; }
.sidebar-item:first-child:last-child { border-radius:16px; }
.sidebar-item::before { content:''; position:absolute; inset:0; background:var(--primary-gradient); opacity:0; transition:opacity .3s; }
.sidebar-item i { position:relative; z-index:1; transition:all .3s; }
.sidebar-item:hover,.sidebar-item.active { color:#fff; }
.sidebar-item:hover::before,.sidebar-item.active::before { opacity:1; }
.mini-sidebar-tooltip.bs-tooltip-end .tooltip-arrow::before,.mini-sidebar-tooltip.bs-tooltip-auto[data-popper-placement^=right] .tooltip-arrow::before { border-right-color:#ffffff!important; }
.mini-sidebar-tooltip .tooltip-inner { background-color:#ffffff!important; color:#00377B!important; font-family:"Roboto",sans-serif!important; font-weight:700!important; font-size:.85rem!important; padding:.5rem 1.1rem!important; border-radius:10px!important; min-width:90px!important; box-shadow:0 8px 24px rgba(0,55,123,.20)!important; border:1.5px solid #D3E4F2!important; }
.mini-sidebar-tooltip.tooltip { --bs-tooltip-bg:#ffffff; --bs-tooltip-color:#00377B; --bs-tooltip-opacity:1; }

/* ══════════════════════════════════════
   MAIN CONTENT
══════════════════════════════════════ */
.main-content { flex:1; min-width:0; }
.profile-page { color:var(--text-primary); }
.content-section { background:var(--bg-primary); border:1.5px solid var(--border-color); border-radius:20px; padding:2rem 2.25rem; margin-bottom:1.5rem; box-shadow:var(--shadow-sm); position:relative; overflow:hidden; transition:box-shadow .3s,transform .3s; }
.content-section:hover { box-shadow:var(--shadow-md); transform:translateY(-1px); }
.content-section::before { content:''; position:absolute; left:0; top:0; bottom:0; width:4px; background:var(--primary-gradient); border-radius:20px 0 0 20px; }
[data-theme="dark"] .content-section { background:#0e2038; border-color:rgba(97,185,240,.10); }
.section-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:1.5rem; padding-bottom:.9rem; border-bottom:1.5px solid var(--border-color); }
.section-title { font-family:var(--font-title); font-size:1.45rem; font-weight:800; color:var(--brand-navy); margin:0; display:flex; align-items:center; gap:.65rem; }
[data-theme="dark"] .section-title { color:var(--text-primary); }
.section-title i { font-size:1.2rem; color:var(--brand-orange); }
.section-content { margin-bottom:1.25rem; }
.description-text { font-size:.97rem; line-height:1.82; color:var(--text-secondary); margin-bottom:0; }
[data-theme="dark"] .description-text { color:var(--text-secondary); }
.modern-btn { display:inline-flex; align-items:center; gap:.6rem; padding:.75rem 1.5rem; background:var(--primary-gradient); color:#fff; font-family:var(--font-body); font-size:.88rem; font-weight:700; border-radius:10px; text-decoration:none; transition:all .3s; border:none; box-shadow:0 4px 16px rgba(0,55,123,.22); cursor:pointer; }
.modern-btn:hover { transform:translateY(-2px); box-shadow:0 8px 24px rgba(0,55,123,.30); color:#fff; }
.modern-btn i { font-size:.95rem; transition:transform .3s; }
.modern-btn:hover i { transform:translateX(3px); }
.modern-btn.secondary { background:transparent; color:var(--brand-navy); border:1.5px solid var(--border-color); box-shadow:none; }
.modern-btn.secondary:hover { background:var(--brand-pale-blue); color:var(--brand-navy); border-color:var(--brand-blue-light); transform:translateY(-2px); }
.modern-btn.secondary:hover i { transform:translateX(-3px); }
.modern-btn.sm { padding:.5rem 1rem; font-size:.80rem; border-radius:8px; }

/* ── PEOPLE GRID ── */
.people-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(155px,1fr)); gap:1.1rem; margin-bottom:1.5rem; }
.person-card { background:var(--bg-primary); border:1.5px solid var(--border-color); border-radius:16px; overflow:hidden; transition:all .32s; cursor:pointer; box-shadow:var(--shadow-sm); }
.person-card:hover { transform:translateY(-6px) scale(1.02); box-shadow:0 16px 40px rgba(0,55,123,.16); border-color:var(--brand-blue-light); }
.person-image-wrapper { position:relative; width:100%; aspect-ratio:1; overflow:hidden; background:linear-gradient(135deg,#E4F3FD,#F2F8FD); }
.person-image { width:100%; height:100%; object-fit:cover; transition:transform .5s; }
.person-card:hover .person-image { transform:scale(1.08); }
.person-overlay { position:absolute; inset:0; background:var(--primary-gradient); opacity:0; transition:opacity .3s; }
.person-card:hover .person-overlay { opacity:.12; }
.person-hover-overlay { position:absolute; inset:0; display:flex; align-items:flex-end; padding:.6rem; background:linear-gradient(to top,rgba(0,40,100,.75) 0%,transparent 55%); opacity:0; transition:opacity .3s; }
.person-card:hover .person-hover-overlay { opacity:1; }
.person-hover-name { color:#fff; font-family:var(--font-title); font-size:.72rem; font-weight:700; line-height:1.3; }
.person-info { padding:.7rem .8rem; text-align:center; background:var(--bg-primary); border-top:1px solid var(--border-color); }
[data-theme="dark"] .person-info { background:var(--bg-secondary); }
.person-name { font-family:var(--font-title); font-size:.78rem; font-weight:700; color:var(--brand-navy); margin:0 0 .25rem; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
[data-theme="dark"] .person-name { color:var(--text-primary); }
.person-position { font-size:.7rem; color:var(--brand-blue-light); margin:0; font-weight:600; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.empty-state { text-align:center; padding:3rem; color:var(--text-secondary); grid-column:1/-1; }
.empty-state i { font-size:3.5rem; color:var(--brand-blue-light); opacity:.3; margin-bottom:1rem; display:block; }
.empty-state p { font-size:1rem; margin:0; color:var(--brand-navy); font-weight:600; }

/* ── MOBILE SEARCH ── */
.mobile-search-form { width:100%; }
.mobile-search-row { display:flex; gap:8px; }
.mobile-search-input { flex:1; padding:.8rem 1rem; background:var(--bg-primary); border:2px solid var(--border-color); border-radius:12px; color:var(--text-primary); font-family:var(--font-body); font-size:.9rem; outline:none; transition:border-color .25s; }
.mobile-search-input::placeholder { color:var(--text-tertiary); }
.mobile-search-input:focus { border-color:#61B9F0; }
.mobile-search-btn { background:var(--primary-gradient); border:none; border-radius:12px; color:#fff; padding:.8rem 1.1rem; cursor:pointer; font-size:1rem; transition:transform .2s,box-shadow .2s; flex-shrink:0; }
.mobile-search-btn:hover { transform:translateY(-2px); box-shadow:0 4px 12px rgba(0,55,123,.35); }

/* ══════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════ */
@media(max-width:1100px){
    .club-header-full .club-title { font-size:2rem; }
    .club-header-full .club-logo { width:130px; height:130px; }
}
@media(max-width:992px){
    .club-header-inner { flex-direction:column; align-items:center; text-align:center; }
    .club-header-full .club-info-wrapper { align-items:center; }
    .club-header-full .club-title { font-size:1.85rem; }
    .club-header-full .club-meta-row { justify-content:center; }
    .club-header-full .stats-badges-row { flex-direction:column; align-items:center; }
    .ch-title-row { flex-direction:column; align-items:center; }
    .people-grid { grid-template-columns:repeat(auto-fill,minmax(140px,1fr)); }
    .filter-panel { padding:20px 20px 26px; }
    .campus-grid { grid-template-columns:1fr 1fr; }
    .dept-grid   { grid-template-columns:1fr 1fr; }
}
@media(max-width:768px){
    :root { --header-h:64px; }
    .header-inner { padding:.8rem 1.25rem; }
    .top-menu,.auth-buttons { display:none; }
    .mobile-menu-toggle { display:flex; }
    .mini-sidebar { display:none; }
    .side-menu-dropdown { display:block; }
    .layout-wrapper { padding:1.5rem 1rem; gap:0; }
    .club-header-full { padding:2rem 0; }
    .club-header-inner { padding:0 1.25rem; gap:1.25rem; }
    .club-header-full .club-title { font-size:1.55rem; }
    .club-header-full .club-logo { width:90px; height:90px; border-radius:14px; }
    .content-section { padding:1.4rem 1.25rem; }
    .section-title { font-size:1.2rem; }
    .people-grid { grid-template-columns:repeat(2,1fr); gap:.7rem; }
    .filter-panel { top:64px; max-height:calc(85vh - 64px); padding:16px 16px 22px; }
    .campus-grid,.dept-grid { grid-template-columns:1fr; }
}
@media(max-width:480px){
    .club-header-full .club-title { font-size:1.35rem; }
    .club-header-full .club-logo { width:76px; height:76px; border-radius:12px; }
    .people-grid { grid-template-columns:repeat(2,1fr); gap:.55rem; }
    .modern-btn { padding:.65rem 1.1rem; font-size:.82rem; }
}

@media(max-width:768px){
    .mini-sidebar { display:none !important; }
    .layout-wrapper { flex-direction:column; padding:1rem; gap:0; }
} 
            /* ── Coming-Soon Card ── */
            
            .coming-soon-section {
                background: linear-gradient(135deg,
                    color-mix(in srgb, var(--accent) 6%, var(--surface-2)) 0%,
                    var(--surface-2) 100%);
                border: 1.5px dashed color-mix(in srgb, var(--accent) 35%, transparent);
                border-radius: 1.25rem;
                padding: 0;
                overflow: hidden;
            }
            .coming-soon-inner {
                display: flex;
                flex-direction: column;
                align-items: center;
                text-align: center;
                padding: 3rem 2rem 2.5rem;
                gap: .9rem;
            }
            .coming-soon-icon-ring {
                width: 72px;
                height: 72px;
                border-radius: 50%;
                background: linear-gradient(135deg,
                    color-mix(in srgb, var(--accent) 20%, transparent),
                    color-mix(in srgb, var(--accent) 8%, transparent));
                border: 2px solid color-mix(in srgb, var(--accent) 30%, transparent);
                display: flex;
                align-items: center;
                justify-content: center;
                font-size: 1.75rem;
                color: var(--accent);
                animation: pulse-ring 2.4s ease-in-out infinite;
            }
            @keyframes pulse-ring {
                0%, 100% { box-shadow: 0 0 0 0 color-mix(in srgb, var(--accent) 25%, transparent); }
                50%       { box-shadow: 0 0 0 12px color-mix(in srgb, var(--accent) 0%, transparent); }
            }
            .coming-soon-title {
                font-size: 1.15rem;
                font-weight: 700;
                color: var(--text-primary);
                margin: 0;
                letter-spacing: -.01em;
            }
            .coming-soon-sub {
                font-size: .875rem;
                color: var(--text-tertiary);
                max-width: 340px;
                line-height: 1.65;
                margin: 0;
            }
            .coming-soon-dots {
                display: flex;
                gap: .45rem;
                margin-top: .4rem;
            }
            .coming-soon-dots span {
                width: 7px;
                height: 7px;
                border-radius: 50%;
                background: var(--accent);
                opacity: .35;
                animation: dot-bounce 1.4s ease-in-out infinite;
            }
            .coming-soon-dots span:nth-child(2) { animation-delay: .2s; }
            .coming-soon-dots span:nth-child(3) { animation-delay: .4s; }
            @keyframes dot-bounce {
                0%, 80%, 100% { transform: translateY(0);  opacity: .35; }
                40%            { transform: translateY(-6px); opacity: 1;   }
            }
