/* ─── BUTTONS ──────────────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:8px;padding:13px 28px;border-radius:var(--radius-full);font-size:0.9rem;font-weight:600;cursor:pointer;transition:var(--transition);border:2px solid transparent;white-space:nowrap;line-height:1;}
.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary);}
.btn-primary:hover{background:var(--primary-dark);border-color:var(--primary-dark);transform:translateY(-2px);box-shadow:var(--shadow-md);}
.btn-accent{background:var(--accent);color:#fff;border-color:var(--accent);}
.btn-accent:hover{background:var(--accent-dark);border-color:var(--accent-dark);transform:translateY(-2px);box-shadow:0 8px 24px rgba(232,160,32,0.35);}
.btn-outline{background:transparent;color:var(--primary);border-color:var(--primary);}
.btn-outline:hover{background:var(--primary);color:#fff;transform:translateY(-2px);}
.btn-outline-white{background:transparent;color:#fff;border-color:rgba(255,255,255,0.6);}
.btn-outline-white:hover{background:rgba(255,255,255,0.15);border-color:#fff;}
.btn-danger{background:var(--danger);color:#fff;border-color:var(--danger);}
.btn-danger:hover{background:#c0392b;transform:translateY(-2px);}
.btn-sm{padding:8px 18px;font-size:0.82rem;}
.btn-xs{padding:5px 12px;font-size:0.75rem;}

/* ─── NAVBAR ──────────────────────────────────────────────────────── */
.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;padding:20px 0;transition:var(--transition);}
.navbar.scrolled{background:rgba(255,255,255,0.96);backdrop-filter:blur(12px);box-shadow:var(--shadow-sm);padding:12px 0;}
.navbar-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;}
.navbar-brand{display:flex;align-items:center;gap:10px;flex-shrink:0;}
.brand-logo-box{width:40px;height:40px;background:var(--accent);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:0.95rem;color:#fff;font-family:var(--font-heading);flex-shrink:0;}
.brand-text{display:flex;flex-direction:column;line-height:1.1;}
.brand-name{font-family:var(--font-heading);font-size:1rem;font-weight:700;color:#fff;transition:var(--transition);}
.brand-sub{font-size:0.62rem;font-weight:500;color:rgba(255,255,255,0.65);text-transform:uppercase;letter-spacing:0.06em;transition:var(--transition);}
.navbar.scrolled .brand-name{color:var(--primary);}
.navbar.scrolled .brand-sub{color:var(--text-muted);}
.navbar-links{display:flex;align-items:center;gap:2px;}
.navbar-links a{font-size:0.88rem;font-weight:500;color:rgba(255,255,255,0.85);padding:8px 14px;border-radius:var(--radius-sm);transition:var(--transition);}
.navbar-links a:hover{color:#fff;background:rgba(255,255,255,0.12);}
.navbar.scrolled .navbar-links a{color:var(--text-secondary);}
.navbar.scrolled .navbar-links a:hover{color:var(--primary);background:var(--primary-light);}
.navbar-cta .btn{padding:9px 22px;font-size:0.85rem;}
.navbar.scrolled .btn-outline-white{color:var(--primary);border-color:var(--primary);}
.navbar.scrolled .btn-outline-white:hover{background:var(--primary);color:#fff;}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px;background:none;border:none;}
.hamburger span{display:block;width:24px;height:2px;background:#fff;border-radius:2px;transition:var(--transition);}
.navbar.scrolled .hamburger span{background:var(--primary);}
.mobile-nav{display:none;position:fixed;inset:0;background:var(--primary);z-index:999;flex-direction:column;align-items:center;justify-content:center;gap:10px;}
.mobile-nav.open{display:flex;}
.mobile-nav a{color:rgba(255,255,255,0.85);font-size:1.2rem;font-weight:500;padding:14px 40px;border-radius:var(--radius-md);transition:var(--transition);width:280px;text-align:center;}
.mobile-nav a:hover,.mobile-nav a.active{background:rgba(255,255,255,0.1);color:#fff;}
.mobile-nav-close{position:absolute;top:24px;right:24px;background:none;border:none;color:#fff;font-size:1.8rem;cursor:pointer;line-height:1;}

/* ─── HERO CAROUSEL ───────────────────────────────────────────────── */
.hero-carousel{position:relative;width:100%;height:100vh;min-height:600px;overflow:hidden;}
.hero-slides{position:relative;width:100%;height:100%;}
.hero-slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity 1s ease;pointer-events:none;}
.hero-slide.active{opacity:1;pointer-events:auto;}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(26,60,94,0.88) 0%,rgba(18,43,69,0.68) 100%);}
.hero-content{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:80px 40px 120px;color:#fff;gap:20px;z-index:2;}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(232,160,32,0.15);border:1px solid rgba(232,160,32,0.45);color:var(--accent);padding:7px 22px;border-radius:var(--radius-full);font-size:0.78rem;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;}
.hero-badge::before{content:'';width:6px;height:6px;background:var(--accent);border-radius:50%;flex-shrink:0;}
.hero-content h1{color:#fff;font-size:clamp(2.2rem,5.5vw,4rem);line-height:1.12;text-shadow:0 2px 20px rgba(0,0,0,0.25);max-width:820px;}
.hero-content p{color:rgba(255,255,255,0.82);font-size:clamp(1rem,1.8vw,1.18rem);max-width:520px;line-height:1.7;}
.hero-btns{display:flex;gap:14px;flex-wrap:wrap;justify-content:center;margin-top:6px;}
.hero-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:10;background:rgba(255,255,255,0.12);border:1px solid rgba(255,255,255,0.25);color:#fff;width:50px;height:50px;border-radius:50%;font-size:1.1rem;cursor:pointer;transition:var(--transition);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;}
.hero-arrow:hover{background:var(--accent);border-color:var(--accent);}
.hero-arrow-prev{left:28px;}
.hero-arrow-next{right:28px;}
.hero-dots{position:absolute;bottom:88px;left:50%;transform:translateX(-50%);display:flex;gap:10px;z-index:10;}
.hero-dot{width:8px;height:8px;border-radius:50%;border:2px solid rgba(255,255,255,0.5);background:transparent;cursor:pointer;transition:var(--transition);padding:0;}
.hero-dot.active{background:var(--accent);border-color:var(--accent);width:24px;border-radius:4px;}
.hero-scroll{position:absolute;bottom:32px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;color:rgba(255,255,255,0.45);font-size:0.72rem;letter-spacing:0.12em;text-transform:uppercase;z-index:10;}
.hero-scroll-line{width:1px;height:32px;background:rgba(255,255,255,0.3);animation:scrollLine 2s ease-in-out infinite;}
@keyframes scrollLine{0%,100%{transform:scaleY(1);opacity:.4;}50%{transform:scaleY(.4);opacity:.15;}}
@keyframes bounce{0%,100%{transform:translateX(-50%) translateY(0);}50%{transform:translateX(-50%) translateY(6px);}}

/* ─── STATS SECTION ───────────────────────────────────────────────── */
.stats-section{background:var(--primary);}
.stats-inner{display:grid;grid-template-columns:repeat(4,1fr);max-width:1200px;margin:0 auto;}
.stat-card{padding:52px 32px;text-align:center;border-right:1px solid rgba(255,255,255,0.08);transition:var(--transition);}
.stat-card:last-child{border-right:none;}
.stat-card:hover{background:rgba(255,255,255,0.04);}
.stat-num{display:block;font-family:var(--font-heading);font-size:clamp(2.4rem,4vw,3.4rem);font-weight:700;color:var(--accent);line-height:1;margin-bottom:10px;}
.stat-label{display:block;font-size:0.82rem;font-weight:500;color:rgba(255,255,255,0.65);text-transform:uppercase;letter-spacing:0.08em;}

/* ─── LINK ARROW ──────────────────────────────────────────────────── */
.link-arrow{display:inline-flex;align-items:center;gap:8px;color:var(--primary);font-weight:600;font-size:0.92rem;transition:var(--transition);}
.link-arrow:hover{color:var(--accent);gap:14px;}

/* ─── CARDS ───────────────────────────────────────────────────────── */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:var(--transition);}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow-hover);border-color:transparent;}
.card-hover{transition:var(--transition);}
.card-hover:hover{transform:translateY(-6px);box-shadow:var(--shadow-hover);}

/* Event Cards */
.event-card{background:var(--surface);border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border);transition:var(--transition);}
.event-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-hover);border-color:transparent;}
.event-card-img{width:100%;aspect-ratio:16/9;object-fit:cover;background:var(--primary-light);}
.event-card-body{padding:24px;}
.event-date-badge{display:inline-flex;align-items:center;gap:6px;background:var(--accent-light);color:var(--accent-dark);font-size:0.78rem;font-weight:600;padding:5px 12px;border-radius:var(--radius-full);margin-bottom:12px;}
.event-venue{display:flex;align-items:center;gap:6px;font-size:0.82rem;color:var(--text-muted);margin-bottom:14px;}
.event-desc{font-size:0.88rem;line-height:1.6;color:var(--text-secondary);margin-bottom:18px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}

/* Blog Cards */
.blog-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:var(--transition);}
.blog-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-hover);border-color:transparent;}
.blog-card-img{width:100%;aspect-ratio:16/9;object-fit:cover;background:var(--primary-light);}
.blog-card-body{padding:24px;}
.blog-tag{display:inline-block;background:var(--primary-light);color:var(--primary);font-size:0.72rem;font-weight:600;padding:4px 12px;border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:0.06em;margin-bottom:10px;}
.blog-meta{font-size:0.78rem;color:var(--text-muted);margin-top:14px;}

/* Committee Cards */
.committee-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px 20px;text-align:center;transition:var(--transition);}
.committee-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-hover);border-color:var(--accent);}
.committee-photo{width:96px;height:96px;border-radius:50%;object-fit:cover;margin:0 auto 16px;border:3px solid var(--border);}
.committee-card.featured .committee-photo{width:120px;height:120px;border-color:var(--accent);}
.role-badge{display:inline-block;background:var(--primary-light);color:var(--primary);font-size:0.72rem;font-weight:600;padding:4px 14px;border-radius:var(--radius-full);margin-top:8px;text-transform:capitalize;}

/* ─── FORMS ───────────────────────────────────────────────────────── */
.form-group{margin-bottom:20px;}
.form-label{display:block;font-size:0.85rem;font-weight:600;color:var(--text-primary);margin-bottom:7px;}
.form-control{width:100%;padding:11px 16px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:0.92rem;color:var(--text-primary);background:var(--surface);transition:var(--transition);outline:none;}
.form-control:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(26,60,94,0.08);}
.form-control::placeholder{color:var(--text-muted);}
textarea.form-control{resize:vertical;min-height:100px;}
select.form-control{cursor:pointer;}
.form-hint{font-size:0.78rem;color:var(--text-muted);margin-top:5px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.error-text{color:var(--danger);font-size:0.83rem;margin-top:6px;}

/* ─── TABLES ──────────────────────────────────────────────────────── */
.table-wrap{overflow-x:auto;border-radius:var(--radius-md);border:1px solid var(--border);}
table{width:100%;border-collapse:collapse;font-size:0.88rem;}
thead{background:var(--surface-2);}
th{padding:12px 16px;text-align:left;font-weight:600;font-size:0.78rem;text-transform:uppercase;letter-spacing:0.06em;color:var(--text-secondary);border-bottom:1px solid var(--border);}
td{padding:13px 16px;border-bottom:1px solid var(--border);color:var(--text-primary);vertical-align:middle;}
tr:last-child td{border-bottom:none;}
tr:hover td{background:var(--surface-2);}
.status-badge{display:inline-block;padding:4px 12px;border-radius:var(--radius-full);font-size:0.75rem;font-weight:600;}
.status-paid{background:var(--success-bg);color:#1A7A4A;}
.status-pending{background:var(--warning-bg);color:#B8760A;}
.status-overdue{background:var(--danger-bg);color:#B71C1C;}
.status-upcoming{background:var(--primary-light);color:var(--primary);}
.status-archived{background:var(--surface-2);color:var(--text-muted);}
.status-published{background:var(--success-bg);color:#1A7A4A;}
.status-draft{background:var(--warning-bg);color:#B8760A;}

/* ─── MODALS ──────────────────────────────────────────────────────── */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(18,43,69,0.7);z-index:2000;align-items:center;justify-content:center;padding:24px;}
.modal-overlay.open{display:flex;}
.modal{background:var(--surface);border-radius:var(--radius-lg);padding:36px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;position:relative;box-shadow:var(--shadow-lg);}
.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;}
.modal-close{background:none;border:none;font-size:1.4rem;color:var(--text-muted);cursor:pointer;line-height:1;padding:4px;}
.modal-close:hover{color:var(--danger);}

/* ─── AUTH PAGES ──────────────────────────────────────────────────── */
.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);padding:24px;}
.auth-card{background:var(--surface);border-radius:var(--radius-lg);padding:48px 40px;width:100%;max-width:420px;box-shadow:var(--shadow-lg);text-align:center;}
.auth-card .brand-logo-box{width:56px;height:56px;font-size:1.2rem;margin:0 auto 20px;}
.auth-card h2{margin-bottom:8px;}
.auth-card>p{margin-bottom:28px;font-size:0.9rem;}
.auth-card form{text-align:left;}
.auth-card .btn{margin-top:8px;}

/* ─── ADMIN LAYOUT ────────────────────────────────────────────────── */
.admin-layout{display:flex;min-height:100vh;}
.admin-sidebar{width:240px;background:var(--primary);flex-shrink:0;display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow-y:auto;}
.sidebar-brand{padding:24px 20px;border-bottom:1px solid rgba(255,255,255,0.08);}
.sidebar-brand .brand-logo-box{background:var(--accent);}
.sidebar-brand .brand-name,.sidebar-brand .brand-sub{color:#fff;}
.sidebar-brand .brand-sub{color:rgba(255,255,255,0.5);}
.sidebar-nav{padding:16px 0;flex:1;}
.sidebar-link{display:flex;align-items:center;gap:12px;padding:12px 20px;color:rgba(255,255,255,0.7);font-size:0.9rem;font-weight:500;transition:var(--transition);}
.sidebar-link:hover,.sidebar-link.active{background:rgba(255,255,255,0.1);color:#fff;}
.sidebar-link .icon{font-size:1.1rem;width:20px;text-align:center;}
.sidebar-logout{padding:16px 0;border-top:1px solid rgba(255,255,255,0.08);}
.admin-main{flex:1;overflow-x:hidden;}
.admin-topbar{background:var(--surface);border-bottom:1px solid var(--border);padding:16px 32px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100;}
.admin-topbar h1{font-size:1.3rem;font-family:var(--font-body);font-weight:600;}
.admin-content{padding:32px;}
.admin-menu-toggle{display:none;background:none;border:none;font-size:1.4rem;cursor:pointer;color:var(--primary);}

/* Mobile Sidebar Styles */
@media(max-width:768px){
  .admin-layout{flex-direction:row;}
  .admin-sidebar{width:240px;height:100vh;position:fixed;top:0;left:0;z-index:1000;flex-direction:column;transform:translateX(-100%);transition:transform 0.3s ease;}
  .admin-sidebar.open{transform:translateX(0);}
  .admin-sidebar.collapsed{transform:translateX(-100%);}
  .admin-menu-toggle{display:block;}
  .admin-main{margin-left:0;width:100%;}
  .admin-content{padding:20px 16px;}
}

/* Summary Cards */
.summary-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:32px;}
.summary-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:24px;text-align:center;}
.summary-num{font-family:var(--font-heading);font-size:1.8rem;font-weight:700;color:var(--primary);display:block;margin-bottom:6px;}
.summary-label{font-size:0.78rem;text-transform:uppercase;letter-spacing:0.06em;color:var(--text-muted);font-weight:600;}

/* Quick Link Cards */
.quick-links{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;}
.quick-link-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:20px;text-align:center;transition:var(--transition);cursor:pointer;}
.quick-link-card:hover{border-color:var(--primary);box-shadow:var(--shadow-md);transform:translateY(-3px);}
.quick-link-icon{font-size:1.8rem;margin-bottom:10px;}
.quick-link-card span{font-size:0.82rem;font-weight:600;color:var(--text-secondary);}

/* Section header within admin */
.admin-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;}
.admin-section-header h2{font-size:1.3rem;font-family:var(--font-body);font-weight:600;}

/* Tabs */
.tabs{display:flex;gap:4px;background:var(--surface-2);padding:4px;border-radius:var(--radius-sm);margin-bottom:28px;width:fit-content;}
.tab-btn{padding:8px 20px;border-radius:calc(var(--radius-sm) - 2px);font-size:0.88rem;font-weight:600;border:none;background:transparent;color:var(--text-secondary);transition:var(--transition);cursor:pointer;}
.tab-btn.active{background:var(--surface);color:var(--primary);box-shadow:var(--shadow-sm);}
.tab-panel{display:none;}
.tab-panel.active{display:block;}

/* Filter row */
.filter-row{display:flex;align-items:center;gap:12px;margin-bottom:20px;flex-wrap:wrap;}
.search-input{flex:1;min-width:220px;padding:10px 16px;border:1.5px solid var(--border);border-radius:var(--radius-full);font-size:0.88rem;outline:none;transition:var(--transition);}
.search-input:focus{border-color:var(--primary);}

/* ─── DIRECTOR PORTAL ─────────────────────────────────────────────── */
.attendance-topbar{display:flex;gap:12px;margin-bottom:24px;flex-wrap:wrap;}
.attendance-pill{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-full);padding:10px 20px;font-size:0.9rem;font-weight:600;color:var(--text-primary);}
.attendance-pill.present{background:var(--success-bg);border-color:var(--success);color:#1A7A4A;}
.member-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
.member-grid-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:16px;transition:var(--transition);}
.member-grid-card.marked{opacity:0;transform:scale(0.95);pointer-events:none;}
.grid-card-header{font-weight:700;font-size:0.95rem;color:var(--primary);margin-bottom:12px;padding-bottom:10px;border-bottom:1px solid var(--border);}
.member-checkbox-row{display:flex;align-items:center;gap:10px;padding:6px 0;font-size:0.88rem;color:var(--text-primary);cursor:pointer;}
.member-checkbox-row input[type=checkbox]{width:16px;height:16px;accent-color:var(--primary);}
.mark-present-btn{width:100%;margin-top:12px;padding:9px;background:var(--primary);color:#fff;border:none;border-radius:var(--radius-sm);font-weight:600;font-size:0.85rem;cursor:pointer;transition:var(--transition);}
.mark-present-btn:hover{background:var(--primary-dark);}
.present-card{background:var(--success-bg);border-color:var(--success);}
.present-card .grid-card-header{color:#1A7A4A;}

/* Scan bar */
.scan-bar{text-align:center;padding:20px 0;border-bottom:1px solid var(--border);margin-bottom:24px;}
.scan-bar p{font-size:0.85rem;color:var(--text-muted);margin-top:8px;}
.qr-scanner-container{background:var(--surface);border:2px solid var(--accent);border-radius:var(--radius-lg);padding:24px;margin-bottom:32px;max-width:500px;margin-left:auto;margin-right:auto;}
.scanner-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;font-weight:600;color:var(--primary);}
.scan-status{text-align:center;margin-top:14px;font-weight:600;min-height:24px;font-size:0.9rem;}
.scan-status.success{color:var(--success);}
.scan-status.error{color:var(--danger);}

/* ─── MEMBER PORTAL ───────────────────────────────────────────────── */
.member-layout{min-height:100vh;background:var(--bg);}
.member-topbar{background:var(--primary);padding:16px 0;position:sticky;top:0;z-index:100;}
.member-topbar-inner{display:flex;align-items:center;justify-content:space-between;}
.member-topbar .brand-name,.member-topbar .brand-sub{color:#fff;}
.member-topbar .brand-sub{color:rgba(255,255,255,0.55);}
.member-nav{display:flex;gap:4px;}
.member-nav a{color:rgba(255,255,255,0.75);font-size:0.85rem;padding:7px 14px;border-radius:var(--radius-sm);transition:var(--transition);font-weight:500;}
.member-nav a:hover,.member-nav a.active{background:rgba(255,255,255,0.12);color:#fff;}
.member-content{max-width:1100px;margin:0 auto;padding:40px 24px;}
.welcome-banner{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);border-radius:var(--radius-lg);padding:36px;color:#fff;margin-bottom:32px;}
.welcome-banner h2{color:#fff;font-size:clamp(1.4rem,3vw,2rem);margin-bottom:8px;}
.welcome-banner p{color:rgba(255,255,255,0.75);margin:0;}

/* QR Card */
.qr-section{text-align:center;padding:32px 0;}
.qr-card{display:inline-flex;flex-direction:column;align-items:center;background:var(--surface);border:2px solid var(--border);border-radius:var(--radius-lg);padding:24px;gap:16px;box-shadow:var(--shadow-md);max-width:300px;margin:20px auto;}
.qr-card-header{display:flex;align-items:center;gap:10px;width:100%;padding-bottom:14px;border-bottom:1px solid var(--border);}
.qr-club-name{font-weight:600;font-size:0.75rem;color:var(--primary);display:block;line-height:1.3;}
.qr-card-label{font-size:0.65rem;color:var(--accent);text-transform:uppercase;letter-spacing:0.05em;}
.qr-card-footer{display:flex;flex-direction:column;align-items:center;gap:4px;padding-top:14px;border-top:1px solid var(--border);width:100%;}
.qr-member-name{font-weight:600;font-size:1rem;color:var(--primary);}
.qr-membership-no{font-size:0.8rem;color:var(--text-muted);font-family:monospace;}
.qr-hint{font-size:0.82rem;color:var(--text-muted);margin-top:8px;}

/* Photo Upload Grid */
.photo-upload-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:20px;}
.photo-slot{display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center;}
.photo-preview-box{width:120px;height:120px;border-radius:var(--radius-md);overflow:hidden;position:relative;border:2px dashed var(--border);cursor:pointer;background:var(--surface-2);}
.photo-preview-box img{width:100%;height:100%;object-fit:cover;}
.photo-overlay{position:absolute;inset:0;background:rgba(26,60,94,0.6);display:flex;align-items:center;justify-content:center;opacity:0;transition:var(--transition);color:#fff;font-size:0.72rem;font-weight:600;}
.photo-preview-box:hover .photo-overlay{opacity:1;}
.photo-slot-label{font-size:0.8rem;font-weight:600;color:var(--text-primary);}
.upload-status{font-size:0.75rem;min-height:18px;}
.upload-status.uploading{color:var(--accent);}
.upload-status.done{color:var(--success);}
.upload-status.error{color:var(--danger);}

/* ─── GALLERY ─────────────────────────────────────────────────────── */
.gallery-section-dark{background:var(--primary-dark);}
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:220px;gap:14px;}
.gallery-item{border-radius:var(--radius-md);overflow:hidden;background:rgba(255,255,255,0.06);cursor:pointer;position:relative;}
.gallery-item:first-child{grid-column:span 2;grid-row:span 2;}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform 0.5s ease;}
.gallery-item:hover img{transform:scale(1.06);}
.gallery-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(26,60,94,0.8) 0%,transparent 55%);opacity:0;transition:var(--transition);display:flex;align-items:flex-end;padding:18px;}
.gallery-item:hover .gallery-overlay{opacity:1;}
.gallery-overlay span{color:#fff;font-size:0.82rem;font-weight:600;}

/* ─── MEDIA PAGE ──────────────────────────────────────────────────── */
.video-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:var(--transition);cursor:pointer;}
.video-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-hover);}
.video-thumb{width:100%;aspect-ratio:16/9;object-fit:cover;position:relative;}
.video-play-btn{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(26,60,94,0.4);transition:var(--transition);}
.video-card:hover .video-play-btn{background:rgba(26,60,94,0.6);}
.play-circle{width:56px;height:56px;background:rgba(255,255,255,0.95);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.2rem;}
.video-card-body{padding:16px;}
.press-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;display:flex;gap:16px;transition:var(--transition);}
.press-card:hover{box-shadow:var(--shadow-md);}
.press-thumb{width:80px;height:80px;border-radius:var(--radius-sm);object-fit:cover;background:var(--surface-2);flex-shrink:0;}
.press-source{display:inline-block;background:var(--primary-light);color:var(--primary);font-size:0.72rem;font-weight:600;padding:3px 10px;border-radius:var(--radius-full);margin-bottom:8px;}

/* ─── FOOTER ──────────────────────────────────────────────────────── */
footer{background:var(--primary-dark);color:rgba(255,255,255,0.75);}
.footer-top{display:grid;grid-template-columns:2fr 1fr 1fr;gap:60px;padding:72px 0 56px;}
.footer-brand-logo{display:flex;align-items:center;gap:12px;margin-bottom:18px;}
.footer-brand p{font-size:0.88rem;line-height:1.75;color:rgba(255,255,255,0.52);max-width:300px;margin-bottom:22px;}
.social-links{display:flex;gap:10px;}
.social-link{width:38px;height:38px;border-radius:var(--radius-sm);background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.12);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,0.65);transition:var(--transition);}
.social-link:hover{background:var(--accent);border-color:var(--accent);color:#fff;}
.footer-col h4{font-size:0.75rem;font-weight:600;color:rgba(255,255,255,0.38);text-transform:uppercase;letter-spacing:0.1em;margin-bottom:18px;}
.footer-col a,.footer-col p{display:block;font-size:0.88rem;color:rgba(255,255,255,0.58);margin-bottom:10px;line-height:1.5;transition:var(--transition);}
.footer-col a:hover{color:var(--accent);padding-left:4px;}
.footer-bottom{border-top:1px solid rgba(255,255,255,0.08);padding:20px 0;display:flex;align-items:center;justify-content:space-between;}
.footer-bottom p{font-size:0.8rem;color:rgba(255,255,255,0.32);}
.footer-bottom a{color:rgba(255,255,255,0.4);font-size:0.8rem;transition:var(--transition);}
.footer-bottom a:hover{color:var(--accent);}

/* ─── BLOG POST PAGE ──────────────────────────────────────────────── */
.blog-post-cover{width:100%;max-height:480px;object-fit:cover;border-radius:var(--radius-lg);margin-bottom:32px;}
.blog-post-meta{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:24px;font-size:0.85rem;color:var(--text-muted);}
.blog-post-content{font-size:1.05rem;line-height:1.85;}
.blog-post-content h2,.blog-post-content h3{margin:28px 0 14px;}
.blog-post-content p{margin-bottom:18px;}
.blog-post-content ul,.blog-post-content ol{padding-left:24px;margin-bottom:18px;}
.blog-post-content img{border-radius:var(--radius-md);margin:20px 0;}

/* ─── ABOUT PAGE ──────────────────────────────────────────────────── */
.about-hero{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);padding:120px 0 80px;text-align:center;color:#fff;}
.about-hero h1{color:#fff;margin-bottom:16px;}
.about-hero p{color:rgba(255,255,255,0.75);max-width:560px;margin:0 auto;}
.mvv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.mvv-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:32px 28px;text-align:center;transition:var(--transition);}
.mvv-card:hover{box-shadow:var(--shadow-md);border-color:var(--accent);}
.mvv-icon{font-size:2.5rem;margin-bottom:16px;}
.mvv-card h3{margin-bottom:12px;}

/* Expenses */
.expense-total-row td{font-weight:700;color:var(--primary);background:var(--primary-light)!important;}
