@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=Playfair+Display:wght@400;500;600;700&display=swap');
:root{
  --bg-primary:#fafafa;--bg-secondary:#f0f0f0;--bg-card:#fff;--bg-glass:rgba(255,255,255,.7);
  --border:#e5e5e5;--border-hover:#ccc;
  --accent:#1a1a1a;--accent-subtle:rgba(0,0,0,.06);
  --text-primary:#1a1a1a;--text-secondary:#666;--text-muted:#999;
  --shadow-sm:0 1px 3px rgba(0,0,0,.04);--shadow-md:0 4px 20px rgba(0,0,0,.06);--shadow-lg:0 12px 40px rgba(0,0,0,.08);
  --radius:12px;--radius-sm:8px;
  --transition:.3s ease;
  --font-sans:'Inter',system-ui,sans-serif;--font-display:'Playfair Display',Georgia,serif;
  --nav-bg:rgba(250,250,250,.85);--nav-border:rgba(0,0,0,.06);
  --hero-overlay:linear-gradient(to top,rgba(250,250,250,.98) 0%,rgba(250,250,250,.6) 50%,rgba(250,250,250,.3) 100%);
  --page-hero-overlay:linear-gradient(to top,rgba(250,250,250,.95) 0%,rgba(250,250,250,.5) 50%,rgba(250,250,250,.3) 100%);
  --tag-bg:rgba(0,0,0,.04);--tag-border:rgba(0,0,0,.08);--tag-color:#1a1a1a;
  --btn-primary-bg:#1a1a1a;--btn-primary-color:#fff;
  --btn-outline-border:#ccc;--btn-outline-hover:rgba(0,0,0,.03);
  --footer-bg:#fafafa;
}
[data-theme="dark"]{
  --bg-primary:#0f0f0f;--bg-secondary:#1a1a1a;--bg-card:#1e1e1e;--bg-glass:rgba(15,15,15,.8);
  --border:#2a2a2a;--border-hover:#444;
  --accent:#e5e5e5;--accent-subtle:rgba(255,255,255,.06);
  --text-primary:#f0f0f0;--text-secondary:#999;--text-muted:#666;
  --shadow-sm:0 1px 3px rgba(0,0,0,.2);--shadow-md:0 4px 20px rgba(0,0,0,.3);--shadow-lg:0 12px 40px rgba(0,0,0,.4);
  --nav-bg:rgba(15,15,15,.88);--nav-border:rgba(255,255,255,.06);
  --hero-overlay:linear-gradient(to top,rgba(15,15,15,.98) 0%,rgba(15,15,15,.6) 50%,rgba(15,15,15,.3) 100%);
  --page-hero-overlay:linear-gradient(to top,rgba(15,15,15,.95) 0%,rgba(15,15,15,.5) 50%,rgba(15,15,15,.3) 100%);
  --tag-bg:rgba(255,255,255,.06);--tag-border:rgba(255,255,255,.1);--tag-color:#e5e5e5;
  --btn-primary-bg:#f0f0f0;--btn-primary-color:#0f0f0f;
  --btn-outline-border:#444;--btn-outline-hover:rgba(255,255,255,.05);
  --footer-bg:#0f0f0f;
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:80px}
body{font-family:var(--font-sans);background:var(--bg-primary);color:var(--text-primary);line-height:1.7;overflow-x:hidden;-webkit-font-smoothing:antialiased;transition:background .4s ease,color .4s ease}
a{text-decoration:none;color:inherit}img{max-width:100%;display:block}ul{list-style:none}button{cursor:pointer;border:none;background:none;font-family:inherit}
/* NAVBAR */
.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;padding:0 clamp(1.5rem,4vw,4rem);height:68px;display:flex;align-items:center;justify-content:space-between;background:var(--nav-bg);backdrop-filter:blur(24px) saturate(1.4);border-bottom:1px solid var(--nav-border);transition:background .4s ease}
.navbar.scrolled{box-shadow:var(--shadow-md)}
.nav-brand{display:flex;align-items:center;gap:10px}
.nav-brand img{height:32px;width:32px;border-radius:6px}
.nav-brand-text{font-weight:700;font-size:1.05rem;letter-spacing:-.02em}
.nav-brand-text span{font-weight:800}
.nav-links{display:flex;gap:4px;align-items:center}
.nav-links a{padding:7px 14px;border-radius:var(--radius-sm);font-size:.84rem;font-weight:500;color:var(--text-secondary);transition:var(--transition)}
.nav-links a:hover,.nav-links a.active{color:var(--text-primary);background:var(--accent-subtle)}
.nav-right{display:flex;align-items:center;gap:12px}
.nav-cta{padding:8px 20px;border-radius:var(--radius-sm);font-size:.82rem;font-weight:600;background:var(--btn-primary-bg);color:var(--btn-primary-color);transition:var(--transition)}
.nav-cta:hover{opacity:.85;transform:translateY(-1px)}
/* Theme Toggle */
.theme-toggle{width:36px;height:36px;border-radius:50%;display:grid;place-items:center;background:var(--accent-subtle);border:1px solid var(--border);transition:var(--transition);font-size:1rem;cursor:pointer;color:var(--text-primary)}
.theme-toggle:hover{border-color:var(--border-hover);transform:scale(1.05)}
.theme-toggle .icon-sun,.theme-toggle .icon-moon{position:absolute}
.theme-toggle .icon-moon{display:block}
.theme-toggle .icon-sun{display:none}
[data-theme="dark"] .theme-toggle .icon-moon{display:none}
[data-theme="dark"] .theme-toggle .icon-sun{display:block}
/* Mobile menu */
.nav-toggle{display:none;flex-direction:column;gap:5px;padding:4px}
.nav-toggle span{width:20px;height:1.5px;background:var(--text-primary);border-radius:2px;transition:var(--transition)}
/* HERO */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;padding:120px clamp(1.5rem,6vw,6rem) 80px;overflow:hidden}
.hero-bg-img{position:absolute;inset:0;z-index:0;background:url('assets/hero_gallery.jpg') center/cover no-repeat}
.hero-bg-img::after{content:'';position:absolute;inset:0;background:var(--hero-overlay);transition:background .4s ease}
.hero-content{position:relative;z-index:2;max-width:640px}
.hero-badge{display:inline-flex;align-items:center;gap:8px;padding:6px 14px;border-radius:100px;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;background:var(--tag-bg);border:1px solid var(--tag-border);color:var(--tag-color);margin-bottom:28px}
.hero-badge .dot{width:6px;height:6px;border-radius:50%;background:#22c55e;animation:pulse-dot 2s infinite}
@keyframes pulse-dot{0%,100%{opacity:1}50%{opacity:.3}}
.hero h1{font-family:var(--font-display);font-size:clamp(2.4rem,5.5vw,4rem);font-weight:700;line-height:1.15;letter-spacing:-.02em;margin-bottom:20px}
.hero-desc{font-size:clamp(.95rem,1.6vw,1.1rem);color:var(--text-secondary);max-width:480px;margin-bottom:36px;line-height:1.8}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap}
.btn-primary{padding:12px 28px;border-radius:var(--radius-sm);font-size:.9rem;font-weight:600;background:var(--btn-primary-bg);color:var(--btn-primary-color);transition:var(--transition);display:inline-flex;align-items:center;gap:8px}
.btn-primary:hover{opacity:.85;transform:translateY(-1px);box-shadow:var(--shadow-md)}
.btn-outline{padding:12px 28px;border-radius:var(--radius-sm);font-size:.9rem;font-weight:600;border:1px solid var(--btn-outline-border);color:var(--text-primary);transition:var(--transition);display:inline-flex;align-items:center;gap:8px}
.btn-outline:hover{background:var(--btn-outline-hover);border-color:var(--border-hover)}
.hero-stats{display:flex;gap:40px;margin-top:56px;padding-top:28px;border-top:1px solid var(--border)}
.hero-stat-num{font-size:1.8rem;font-weight:800;letter-spacing:-.02em}
.hero-stat-label{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-top:2px}
/* SECTIONS */
section{position:relative;z-index:2}
.section-pad{padding:100px clamp(1.5rem,6vw,6rem)}
.section-header{text-align:center;max-width:600px;margin:0 auto 60px}
.section-label{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.14em;color:var(--text-muted);margin-bottom:12px}
.section-title{font-family:var(--font-display);font-size:clamp(1.8rem,3.5vw,2.4rem);font-weight:700;letter-spacing:-.02em;margin-bottom:14px}
.section-subtitle{color:var(--text-secondary);font-size:.95rem}
/* NOW SHOWING */
.now-showing-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:40px;max-width:1100px;margin:0 auto;align-items:start}
.video-embed{position:relative;padding-bottom:56.25%;height:0;overflow:hidden;border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow-sm)}
.video-embed iframe{position:absolute;top:0;left:0;width:100%;height:100%}
.video-embed-note{margin-top:14px;font-size:.85rem;color:var(--text-secondary)}
.video-embed-note a{color:var(--text-primary);text-decoration:underline;text-underline-offset:2px}
.ig-feed-title{display:flex;align-items:center;gap:10px;font-size:1.05rem;font-weight:600;margin-bottom:8px}
.ig-feed-desc{color:var(--text-secondary);font-size:.88rem;margin-bottom:20px}
.ig-placeholder{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:44px 24px;text-align:center;box-shadow:var(--shadow-sm)}
.ig-placeholder-icon{font-size:2.2rem;margin-bottom:10px}
.ig-placeholder p{color:var(--text-secondary);margin-bottom:14px}.ig-placeholder a{color:var(--text-primary)}
.btn-ig{display:inline-block;padding:9px 22px;border-radius:var(--radius-sm);font-size:.82rem;font-weight:600;background:var(--btn-primary-bg);color:var(--btn-primary-color);transition:var(--transition)}
.btn-ig:hover{opacity:.85}
/* QUICK NAV */
.quick-nav-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;max-width:1100px;margin:0 auto}
.quick-card{display:block;padding:28px 18px;border-radius:var(--radius);background:var(--bg-card);border:1px solid var(--border);text-align:center;transition:var(--transition);box-shadow:var(--shadow-sm)}
.quick-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--border-hover)}
.quick-card-icon{font-size:1.8rem;margin-bottom:12px}
.quick-card h3{font-size:.92rem;font-weight:600;margin-bottom:4px}
.quick-card p{font-size:.78rem;color:var(--text-secondary)}
/* ABOUT */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;max-width:1100px;margin:0 auto}
.about-img-wrapper{border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);box-shadow:var(--shadow-md)}
.about-img-wrapper img{width:100%;height:400px;object-fit:cover}
.about-text h3{font-family:var(--font-display);font-size:1.5rem;font-weight:700;margin-bottom:14px}
.about-text p{color:var(--text-secondary);margin-bottom:18px;font-size:.95rem}
.about-features{display:flex;flex-direction:column;gap:10px;margin-top:20px}
.about-feature{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:var(--radius-sm);background:var(--bg-secondary);transition:var(--transition)}
.about-feature:hover{transform:translateX(4px)}
.about-feature-icon{width:36px;height:36px;border-radius:8px;display:grid;place-items:center;background:var(--bg-card);border:1px solid var(--border);font-size:1rem;flex-shrink:0}
.about-feature-text{font-size:.88rem;font-weight:500}
/* MISSION */
.mission-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;max-width:1100px;margin:0 auto}
.mission-card{padding:32px 24px;border-radius:var(--radius);background:var(--bg-card);border:1px solid var(--border);transition:var(--transition);text-align:center;box-shadow:var(--shadow-sm)}
.mission-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.mission-icon{font-size:1.8rem;margin-bottom:14px}
.mission-card h4{font-size:1.05rem;font-weight:600;margin-bottom:8px}
.mission-card p{color:var(--text-secondary);font-size:.88rem}
/* COMMITTEE */
.committee-photo{position:relative;border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);max-width:760px;margin:0 auto 36px;aspect-ratio:16/9;box-shadow:var(--shadow-md)}
.committee-photo img{width:100%;height:100%;object-fit:cover}
.committee-photo-label{position:absolute;bottom:0;left:0;right:0;padding:10px;background:linear-gradient(to top,rgba(0,0,0,.6),transparent);font-size:.82rem;color:#fff;text-align:center}
.committee-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;max-width:1000px;margin:0 auto}
.committee-card{padding:28px 20px;border-radius:var(--radius);background:var(--bg-card);border:1px solid var(--border);text-align:center;transition:var(--transition);box-shadow:var(--shadow-sm)}
.committee-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.committee-icon{font-size:1.8rem;margin-bottom:10px}
.committee-card h4{font-size:1rem;font-weight:600;margin-bottom:3px}
.committee-en{font-size:.75rem;color:var(--text-muted);margin-bottom:8px}
.committee-card p:last-child{color:var(--text-secondary);font-size:.85rem}
/* PROGRAMS */
.program-tabs{display:flex;justify-content:center;gap:6px;margin-bottom:36px;flex-wrap:wrap}
.program-tab{padding:9px 22px;border-radius:100px;font-size:.85rem;font-weight:600;color:var(--text-secondary);border:1px solid var(--border);transition:var(--transition);background:transparent}
.program-tab:hover{border-color:var(--border-hover);color:var(--text-primary)}
.program-tab.active{background:var(--btn-primary-bg);color:var(--btn-primary-color);border-color:transparent}
.program-panel{display:none;max-width:860px;margin:0 auto}.program-panel.active{display:block}
.program-info{text-align:center;margin-bottom:28px}
.program-info h3{font-family:var(--font-display);font-size:1.2rem;font-weight:700;margin-bottom:6px}
.program-info p{color:var(--text-secondary);font-size:.9rem}
.playlist-grid{display:grid;gap:20px}
.playlist-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;padding:16px;box-shadow:var(--shadow-sm)}
.playlist-label{margin-top:10px;font-size:.82rem;color:var(--text-muted);text-align:center}
.programs-cta{text-align:center;margin-top:44px}
/* BTS GALLERY */
.bts-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;max-width:1100px;margin:0 auto;grid-auto-rows:240px}
.bts-item{position:relative;border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);cursor:pointer;box-shadow:var(--shadow-sm)}
.bts-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.bts-item:hover img{transform:scale(1.04)}
.bts-tall{grid-row:span 2}.bts-wide{grid-column:span 2}
.bts-overlay{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:18px;background:linear-gradient(to top,rgba(0,0,0,.7),transparent 60%);opacity:0;transition:var(--transition)}
.bts-item:hover .bts-overlay{opacity:1}
.bts-overlay h4{font-size:.95rem;font-weight:600;color:#fff;margin-bottom:2px}
.bts-overlay p{font-size:.78rem;color:rgba(255,255,255,.7)}
/* SERVICES */
.service-type-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;max-width:960px;margin:0 auto 28px}
.service-type-card{text-align:center;padding:24px 14px;border-radius:var(--radius);background:var(--bg-card);border:1px solid var(--border);transition:var(--transition);box-shadow:var(--shadow-sm)}
.service-type-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.service-type-icon{font-size:1.6rem;margin-bottom:10px}
.service-type-card h4{font-size:.9rem;font-weight:600;margin-bottom:4px}
.service-type-card p{font-size:.78rem;color:var(--text-secondary)}
.service-notice{display:flex;align-items:flex-start;gap:10px;max-width:660px;margin:0 auto;padding:14px 18px;border-radius:var(--radius-sm);background:rgba(251,191,36,.06);border:1px solid rgba(251,191,36,.15)}
.notice-icon{font-size:1.1rem;flex-shrink:0;margin-top:1px}
.service-notice p{font-size:.88rem;color:var(--text-secondary)}.service-notice strong{color:var(--text-primary)}
.form-embed-wrapper{max-width:760px;margin:44px auto 0}
.form-embed-header{text-align:center;margin-bottom:20px}
.form-embed-header h3{font-family:var(--font-display);font-size:1.2rem;font-weight:700;margin-bottom:6px}
.form-embed-header p{color:var(--text-secondary);font-size:.88rem}
.google-form-embed{border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);background:var(--bg-card);box-shadow:var(--shadow-sm)}
.google-form-embed iframe{width:100%;height:600px;border:none}
/* JOIN */
.recruit-status{text-align:center;margin-bottom:44px}
.recruit-badge{display:inline-flex;align-items:center;gap:8px;padding:10px 24px;border-radius:100px;font-size:.9rem;font-weight:600;border:1px solid rgba(34,197,94,.25);background:rgba(34,197,94,.05);color:#16a34a}
.recruit-badge.closed{border-color:rgba(239,68,68,.25);background:rgba(239,68,68,.05);color:#dc2626}
.recruit-dot{width:7px;height:7px;border-radius:50%;background:currentColor;animation:pulse-dot 2s infinite}
.why-join-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;max-width:1060px;margin:0 auto 44px}
.why-card{padding:28px 18px;border-radius:var(--radius);background:var(--bg-card);border:1px solid var(--border);text-align:center;transition:var(--transition);box-shadow:var(--shadow-sm)}
.why-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.why-icon{font-size:1.8rem;margin-bottom:12px}
.why-card h4{font-size:.95rem;font-weight:600;margin-bottom:6px}
.why-card p{color:var(--text-secondary);font-size:.82rem}
/* CONTACT */
.contact-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;max-width:1060px;margin:0 auto}
.contact-card{padding:24px 14px;border-radius:var(--radius);background:var(--bg-card);border:1px solid var(--border);text-align:center;transition:var(--transition);box-shadow:var(--shadow-sm)}
.contact-card:hover{border-color:var(--border-hover);transform:translateY(-2px);box-shadow:var(--shadow-md)}
.contact-card-icon{font-size:1.4rem;margin-bottom:8px}
.contact-card h4{font-size:.85rem;font-weight:600;margin-bottom:6px}
.contact-card a,.contact-card p{font-size:.8rem;color:var(--text-secondary);word-break:break-all}
.contact-card a:hover{color:var(--text-primary)}
/* PAGE HERO */
.page-hero{position:relative;min-height:320px;display:flex;align-items:flex-end;padding:100px clamp(1.5rem,6vw,6rem) 44px;overflow:hidden}
.page-hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;z-index:0}
.page-hero-bg::after{content:'';position:absolute;inset:0;background:var(--page-hero-overlay);transition:background .4s ease}
.page-hero-content{position:relative;z-index:2;max-width:640px}
.page-hero-content h1{font-family:var(--font-display);font-size:clamp(1.8rem,4.5vw,2.8rem);font-weight:700;letter-spacing:-.02em;margin:6px 0 10px}
.page-hero-content p{color:var(--text-secondary);font-size:1rem}
/* AUTH */
.auth-page,.dashboard-page{min-height:100vh;background:var(--bg-primary)}
.auth-page{display:flex;align-items:center;padding:120px clamp(1.5rem,6vw,6rem) 64px}
.auth-shell{width:100%;max-width:1120px;margin:0 auto;display:grid;grid-template-columns:1fr minmax(340px,440px);gap:48px;align-items:center}
.auth-copy h1,.dashboard-hero h1{font-family:var(--font-display);font-size:clamp(2rem,4.2vw,3.4rem);line-height:1.12;letter-spacing:-.02em;margin-bottom:16px}
.auth-copy p,.dashboard-hero p{color:var(--text-secondary);max-width:520px}
.auth-role-list{display:grid;gap:12px;margin-top:32px}
.auth-role-list div{padding:16px 18px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-card);box-shadow:var(--shadow-sm)}
.auth-role-list strong{display:block;margin-bottom:2px}
.auth-role-list span{font-size:.85rem;color:var(--text-secondary)}
.auth-panel{padding:28px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-card);box-shadow:var(--shadow-lg)}
.auth-tabs{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:18px;padding:4px;border-radius:var(--radius-sm);background:var(--bg-secondary)}
.auth-tab{padding:10px 12px;border-radius:var(--radius-sm);font-weight:700;color:var(--text-secondary);transition:var(--transition)}
.auth-tab.active{background:var(--bg-card);color:var(--text-primary);box-shadow:var(--shadow-sm)}
.auth-message{min-height:24px;margin-bottom:12px;font-size:.86rem;color:var(--text-secondary)}
.auth-message[data-type="error"]{color:#dc2626}
.auth-form{display:grid;gap:14px}
.auth-form[hidden],.role-panel[hidden]{display:none}
.auth-form label{display:grid;gap:6px;font-size:.82rem;font-weight:700;color:var(--text-primary)}
.auth-form input,.auth-form select{width:100%;padding:12px 13px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-primary);color:var(--text-primary);font:inherit;transition:var(--transition)}
.auth-form input:focus,.auth-form select:focus{outline:none;border-color:var(--border-hover);box-shadow:0 0 0 3px var(--accent-subtle)}
.auth-submit{justify-content:center;margin-top:4px}
.auth-demo{margin-top:22px;padding-top:18px;border-top:1px solid var(--border)}
.auth-demo-title{font-size:.78rem;font-weight:800;color:var(--text-muted);letter-spacing:.1em;text-transform:uppercase;margin-bottom:10px}
.auth-demo button{padding:8px 12px;margin:0 6px 8px 0;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-secondary);color:var(--text-primary);font-size:.82rem;font-weight:700;transition:var(--transition)}
.auth-demo button:hover{border-color:var(--border-hover);transform:translateY(-1px)}
.auth-note{margin-top:8px;font-size:.78rem;color:var(--text-muted)}
.dashboard-hero{display:flex;justify-content:space-between;gap:32px;align-items:flex-end;padding:124px clamp(1.5rem,6vw,6rem) 52px;border-bottom:1px solid var(--border);background:var(--bg-secondary)}
.dashboard-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.role-badge{display:inline-flex;align-items:center;justify-content:center;min-height:38px;padding:8px 16px;border-radius:100px;background:var(--btn-primary-bg);color:var(--btn-primary-color);font-size:.82rem;font-weight:800}
.role-badge[data-role="super-admin"]{background:#7c3aed;color:#fff}
.role-badge[data-role="admin"]{background:#0f766e;color:#fff}
.role-badge[data-role="user"]{background:var(--btn-primary-bg);color:var(--btn-primary-color)}
.dashboard-content{padding-top:64px}
.dashboard-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;max-width:1100px;margin:0 auto 44px}
.dashboard-content>.dashboard-grid:first-child{grid-template-columns:repeat(2,minmax(0,1fr))}
.dashboard-card{padding:24px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-card);box-shadow:var(--shadow-sm)}
.dashboard-card h2,.dashboard-card h3{font-size:1.05rem;margin-bottom:8px}
.dashboard-card p{color:var(--text-secondary);font-size:.9rem}
.dashboard-kicker{font-size:.72rem!important;font-weight:800;text-transform:uppercase;letter-spacing:.12em;color:var(--text-muted)!important;margin-bottom:8px}
.section-header.compact{margin-bottom:28px}
/* FOOTER */
.footer{position:relative;z-index:2;padding:56px clamp(1.5rem,6vw,6rem) 24px;border-top:1px solid var(--border);background:var(--footer-bg);transition:background .4s ease}
.footer-inner{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:36px;max-width:1100px;margin:0 auto}
.footer-brand{display:flex;align-items:center;gap:9px}
.footer-brand img{height:28px;width:28px;border-radius:6px}
.footer-brand span{font-weight:600;font-size:.9rem}
.footer-nav{display:flex;gap:56px}
.footer-nav-col{display:flex;flex-direction:column;gap:7px}
.footer-nav-col h5{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:var(--text-muted);margin-bottom:3px}
.footer-nav-col a{font-size:.82rem;color:var(--text-secondary);transition:var(--transition)}
.footer-nav-col a:hover{color:var(--text-primary)}
.footer-bottom{max-width:1100px;margin:36px auto 0;padding-top:18px;border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}
.footer-copy,.footer-school{font-size:.75rem;color:var(--text-muted)}
/* REVEAL */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
/* RESPONSIVE */
@media(max-width:1024px){.now-showing-grid{grid-template-columns:1fr}.why-join-grid,.contact-cards,.service-type-grid{grid-template-columns:repeat(2,1fr)}.committee-grid,.mission-grid{grid-template-columns:1fr}.bts-gallery{grid-template-columns:repeat(2,1fr)}.bts-wide{grid-column:span 1}.footer-nav{gap:28px}.quick-nav-grid{grid-template-columns:repeat(3,1fr)}.auth-shell{grid-template-columns:1fr}.dashboard-grid{grid-template-columns:1fr 1fr}}
@media(max-width:900px){.about-grid{grid-template-columns:1fr;gap:28px}.hero-stats{gap:20px}}
@media(max-width:768px){.nav-links,.nav-cta{display:none}.nav-toggle{display:flex}.nav-links.open{display:flex;flex-direction:column;position:absolute;top:68px;left:0;right:0;background:var(--bg-card);backdrop-filter:blur(24px);padding:14px 20px;border-bottom:1px solid var(--nav-border);box-shadow:var(--shadow-lg)}.hero{min-height:auto;padding-top:130px;padding-bottom:56px}.hero-stats{flex-wrap:wrap;gap:16px}.bts-gallery{grid-template-columns:1fr;grid-auto-rows:200px}.bts-tall{grid-row:span 1}.why-join-grid,.contact-cards,.service-type-grid{grid-template-columns:1fr}.footer-inner{flex-direction:column}.footer-nav{flex-wrap:wrap;gap:20px}.footer-bottom{flex-direction:column;text-align:center;gap:3px}.program-tabs{flex-direction:column;align-items:stretch}.quick-nav-grid{grid-template-columns:repeat(2,1fr)}.page-hero{min-height:240px;padding-top:110px}.auth-page{padding-top:108px}.auth-panel{padding:22px}.dashboard-hero{align-items:flex-start;flex-direction:column;padding-top:110px}.dashboard-grid,.dashboard-content>.dashboard-grid:first-child{grid-template-columns:1fr}}
