/*
Theme Name: Sri Dhammarama Manawa Sathkaraka Padanama
Theme URI: http://dhammaramapadanama.org
Author: Antigravity
Author URI: http://google.com
Description: A premium, modern Buddhist organization theme with Sinhala font support and Glassmorphism design.
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: dhammarama
*/

/* ===== CSS VARIABLES ===== */
:root {
    --bg-dark: #0D0D1A;
    --bg-section: #111125;
    --bg-card: rgba(255,255,255,0.04);
    --gold: #D4A843;
    --gold-light: #F0D48A;
    --gold-dark: #A67C2E;
    --saffron: #E8962E;
    --maroon: #5B0E2D;
    --cream: #FFF8E7;
    --text: #E8E4DC;
    --text-muted: #9B9689;
    --border: rgba(212,168,67,0.15);
    --glow: rgba(212,168,67,0.3);
    --radius: 16px;
    --radius-sm: 10px;
    --transition: 0.4s cubic-bezier(0.25,0.46,0.45,0.94);
    --font-sinhala: 'Noto Serif Sinhala', serif;
    --font-heading: 'Playfair Display', serif;
    --font-body: 'Inter', sans-serif;
}

.text-center { text-align: center; }
.mt-60 { margin-top: 60px; }

/* ===== RESET ===== */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior: smooth; scroll-padding-top: 80px; }
body { font-family: var(--font-body); background: var(--bg-dark); color: var(--text); line-height: 1.7; overflow-x: hidden; }
a { text-decoration: none; color: var(--gold); transition: var(--transition); }
a:hover { color: var(--gold-light); }
img { max-width: 100%; display: block; }
ul { list-style: none; }
h1,h2,h3 { font-family: var(--font-sinhala); font-weight: 700; line-height: 1.3; }
h4 { font-family: var(--font-heading); color: var(--gold); font-weight: 400; font-size: 0.9rem; margin-bottom: 0.5rem; }
small { font-size: 0.75em; color: var(--text-muted); display: block; }
.container { max-width: 1200px; margin: 0 auto; padding: 0 24px; }

/* ===== CANVAS ===== */
#lotus-particles { position: fixed; top:0; left:0; width:100%; height:100%; pointer-events:none; z-index:0; }

/* ===== NAVBAR ===== */
.navbar { position: fixed; top:0; left:0; right:0; z-index:1000; padding:12px 0; transition: var(--transition); background: transparent; }
.navbar.scrolled { background: rgba(13,13,26,0.95); backdrop-filter: blur(20px); box-shadow: 0 2px 30px rgba(0,0,0,0.5); border-bottom: 1px solid var(--border); }
.nav-container { max-width:1200px; margin:0 auto; padding:0 24px; display:flex; align-items:center; justify-content:space-between; }
.nav-logo { display:flex; align-items:center; gap:12px; }
.lotus-icon { font-size: 2rem; color: var(--gold); filter: drop-shadow(0 0 8px var(--glow)); animation: spin 20s linear infinite; }
@keyframes spin { from{transform:rotate(0deg)}to{transform:rotate(360deg)} }
.logo-text { display:flex; flex-direction:column; }
.logo-sinhala { font-family: var(--font-sinhala); font-size:1rem; font-weight:700; color: var(--gold); }
.logo-english { font-size:0.65rem; color: var(--text-muted); letter-spacing:2px; text-transform:uppercase; }
.nav-menu { display:flex; gap:4px; align-items:center; }
.nav-link { padding:8px 14px; border-radius:var(--radius-sm); color:var(--text); font-size:0.85rem; font-family:var(--font-sinhala); display:flex; flex-direction:column; align-items:center; transition:var(--transition); }
.nav-link:hover, .nav-link.active { color: var(--gold); background: rgba(212,168,67,0.08); }
.nav-link small { font-size:0.6rem; font-family:var(--font-body); color:var(--text-muted); }
.nav-cta { background: linear-gradient(135deg, var(--gold-dark), var(--gold)); color:#1A1A2E !important; font-weight:600; border-radius:30px; padding:8px 20px; }
.nav-cta:hover { transform:translateY(-2px); box-shadow: 0 4px 20px var(--glow); }
.nav-cta small { color: rgba(26,26,46,0.7); }

/* Hamburger */
.hamburger { display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:8px; z-index:1001; }
.hamburger span { width:28px; height:2px; background:var(--gold); transition:var(--transition); border-radius:2px; }
.hamburger.active span:nth-child(1) { transform:rotate(45deg) translate(5px,5px); }
.hamburger.active span:nth-child(2) { opacity:0; }
.hamburger.active span:nth-child(3) { transform:rotate(-45deg) translate(5px,-5px); }

/* ===== HERO ===== */
.hero { min-height:100vh; display:flex; align-items:center; justify-content:center; position:relative; overflow:hidden; background: linear-gradient(135deg, #0D0D1A 0%, #1A0A2E 30%, #2D0A1A 60%, #0D0D1A 100%); }
.hero::before { content:''; position:absolute; top:50%; left:50%; width:800px; height:800px; transform:translate(-50%,-50%); background:radial-gradient(circle, rgba(212,168,67,0.08) 0%, transparent 70%); border-radius:50%; animation: pulse 6s ease-in-out infinite; }
@keyframes pulse { 0%,100%{transform:translate(-50%,-50%) scale(1);opacity:0.5} 50%{transform:translate(-50%,-50%) scale(1.2);opacity:1} }
.hero-overlay { position:absolute; inset:0; background: url('https://images.unsplash.com/photo-1609609830354-8f615e56873e?w=1600&q=80') center/cover no-repeat; opacity:0.15; }
.hero-content { text-align:center; z-index:1; padding:40px 24px; max-width:900px; }
.hero-badge { display:inline-block; padding:8px 24px; border:1px solid var(--gold); border-radius:50px; color:var(--gold); font-family:var(--font-sinhala); font-size:1rem; letter-spacing:4px; margin-bottom:24px; backdrop-filter:blur(10px); background:rgba(212,168,67,0.05); }
.hero-title { margin-bottom:24px; }
.hero-sinhala { display:block; font-size:clamp(2rem,5vw,3.5rem); color:var(--cream); text-shadow: 0 0 40px rgba(212,168,67,0.3); margin-bottom:8px; }
.hero-english { display:block; font-family:var(--font-heading); font-size:clamp(1rem,2.5vw,1.6rem); color:var(--gold); font-weight:400; letter-spacing:3px; }
.hero-subtitle { font-family:var(--font-sinhala); font-size:1.1rem; color:var(--text-muted); margin-bottom:8px; max-width:700px; margin-left:auto; margin-right:auto; }
.hero-subtitle-en { font-size:0.9rem; color:var(--text-muted); margin-bottom:40px; opacity:0.7; }
.hero-buttons { display:flex; gap:16px; justify-content:center; flex-wrap:wrap; }

/* Buttons */
.btn { display:inline-flex; align-items:center; gap:8px; padding:14px 32px; border-radius:50px; font-family:var(--font-sinhala); font-size:0.95rem; font-weight:600; cursor:pointer; transition:var(--transition); border:none; }
.btn-primary { background:linear-gradient(135deg, var(--gold-dark), var(--gold)); color:#1A1A2E; box-shadow: 0 4px 20px rgba(212,168,67,0.3); }
.btn-primary:hover { transform:translateY(-3px); box-shadow: 0 8px 30px rgba(212,168,67,0.5); color:#1A1A2E; }
.btn-outline { border:1px solid var(--gold); color:var(--gold); background:transparent; }
.btn-outline:hover { background:rgba(212,168,67,0.1); transform:translateY(-3px); }
.btn-full { width:100%; justify-content:center; }

/* Scroll Indicator */
.scroll-indicator { position:absolute; bottom:30px; left:50%; transform:translateX(-50%); }
.scroll-arrow { width:24px; height:40px; border:2px solid var(--gold); border-radius:12px; position:relative; }
.scroll-arrow::after { content:''; position:absolute; top:6px; left:50%; transform:translateX(-50%); width:4px; height:8px; background:var(--gold); border-radius:2px; animation: scrollAnim 2s infinite; }
@keyframes scrollAnim { 0%{opacity:1;top:6px} 100%{opacity:0;top:24px} }

/* ===== SECTIONS ===== */
.section { padding:100px 0; position:relative; z-index:1; }
.section:nth-child(even) { background: var(--bg-section); }
.section-header { text-align:center; margin-bottom:60px; }
.section-badge { display:inline-block; padding:6px 20px; border:1px solid var(--border); border-radius:50px; color:var(--gold); font-size:0.85rem; font-family:var(--font-sinhala); margin-bottom:16px; background:rgba(212,168,67,0.03); }
.section-title { font-size:clamp(1.8rem,4vw,2.5rem); color:var(--cream); margin-bottom:8px; }
.section-subtitle { font-family:var(--font-heading); color:var(--gold); font-size:1rem; }

/* ===== ABOUT ===== */
.about-grid { display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:start; margin-bottom:60px; }
.about-image { position:relative; border-radius:var(--radius); overflow:hidden; }
.about-image img { width:100%; height:400px; object-fit:cover; }
.about-image-overlay { position:absolute; bottom:0; left:0; right:0; padding:20px; background:linear-gradient(transparent, rgba(0,0,0,0.8)); display:flex; flex-direction:column; }
.about-year { font-size:3rem; font-weight:900; color:var(--gold); font-family:var(--font-heading); }
.about-card { background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius); padding:24px; margin-bottom:16px; transition:var(--transition); backdrop-filter:blur(10px); }
.about-card:hover { border-color: var(--gold); transform:translateX(8px); box-shadow: 0 0 30px rgba(212,168,67,0.1); }
.about-card-icon { width:48px; height:48px; border-radius:12px; background:linear-gradient(135deg, var(--gold-dark), var(--gold)); display:flex; align-items:center; justify-content:center; color:#1A1A2E; font-size:1.2rem; margin-bottom:12px; }
.about-card h3 { font-size:1.1rem; color:var(--cream); margin-bottom:4px; }

/* Stats */
.stats-row { display:grid; grid-template-columns:repeat(4,1fr); gap:24px; padding:40px; border:1px solid var(--border); border-radius:var(--radius); background:var(--bg-card); backdrop-filter:blur(10px); }
.stat-item { text-align:center; }
.stat-number { font-size:2.5rem; font-weight:900; font-family:var(--font-heading); color:var(--gold); }
.stat-suffix { font-size:1.5rem; color:var(--gold); font-family:var(--font-heading); }
.stat-label { display:block; font-family:var(--font-sinhala); font-size:0.85rem; color:var(--text-muted); margin-top:4px; }

/* ===== TEACHINGS ===== */
.teachings-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-bottom:48px; }
.teaching-card { background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius); padding:32px; text-align:center; transition:var(--transition); }
.teaching-card:hover { border-color:var(--gold); transform:translateY(-8px); box-shadow: 0 20px 40px rgba(0,0,0,0.3); }
.teaching-card.featured { border-color:var(--gold); background:rgba(212,168,67,0.05); position:relative; }
.teaching-card.featured::before { content:''; position:absolute; top:-1px; left:20%; right:20%; height:3px; background:linear-gradient(90deg, transparent, var(--gold), transparent); }
.teaching-icon { font-size:3rem; margin-bottom:16px; }
.teaching-card h3 { font-size:1.2rem; color:var(--cream); }
.teaching-points { text-align:left; margin-top:16px; }
.teaching-points li { padding:6px 0; border-bottom:1px solid rgba(255,255,255,0.05); font-size:0.85rem; font-family:var(--font-sinhala); color:var(--text-muted); }
.teaching-points li:last-child { border:none; }

/* Pali Quote */
.pali-quote { text-align:center; padding:48px; border:1px solid var(--border); border-radius:var(--radius); background:linear-gradient(135deg, rgba(91,14,45,0.1), rgba(212,168,67,0.05)); }
.pali-quote blockquote { font-family:var(--font-sinhala); font-size:1.3rem; color:var(--gold-light); line-height:2; margin-bottom:16px; }
.quote-translation { font-style:italic; color:var(--text-muted); margin-bottom:8px; }
.pali-quote cite { color:var(--gold); font-size:0.9rem; }

/* ===== EVENTS ===== */
.events-grid { display:grid; gap:20px; }
.event-card { display:flex; gap:24px; background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius); padding:24px; transition:var(--transition); }
.event-card:hover { border-color:var(--gold); transform:translateX(8px); box-shadow: 0 10px 30px rgba(0,0,0,0.3); }
.event-date { min-width:100px; text-align:center; padding:16px; background:linear-gradient(135deg, var(--maroon), rgba(91,14,45,0.6)); border-radius:var(--radius-sm); display:flex; flex-direction:column; justify-content:center; }
.event-day { font-size:2.5rem; font-weight:900; color:var(--gold); font-family:var(--font-heading); line-height:1; }
.event-month { font-family:var(--font-sinhala); color:var(--cream); font-size:0.9rem; }
.event-year { font-size:0.75rem; color:var(--text-muted); }
.event-tag { display:inline-block; padding:4px 12px; border-radius:20px; font-size:0.75rem; background:rgba(212,168,67,0.1); color:var(--gold); border:1px solid var(--border); margin-bottom:8px; font-family:var(--font-sinhala); }
.event-tag.special { background:rgba(232,150,46,0.15); color:var(--saffron); border-color:rgba(232,150,46,0.3); }
.event-info h3 { font-size:1.1rem; color:var(--cream); }
.event-info p { font-size:0.9rem; color:var(--text-muted); margin-top:4px; }
.event-info i { color:var(--gold); margin-right:8px; width:16px; }

/* ===== GALLERY ===== */
.gallery-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.gallery-item { position:relative; border-radius:var(--radius); overflow:hidden; cursor:pointer; aspect-ratio:4/3; }
.gallery-item img { width:100%; height:100%; object-fit:cover; transition:var(--transition); }
.gallery-item:hover img { transform:scale(1.1); }
.gallery-overlay { position:absolute; inset:0; background:rgba(13,13,26,0.7); display:flex; flex-direction:column; align-items:center; justify-content:center; opacity:0; transition:var(--transition); }
.gallery-item:hover .gallery-overlay { opacity:1; }
.gallery-overlay i { font-size:2rem; color:var(--gold); margin-bottom:8px; }
.gallery-overlay span { font-family:var(--font-sinhala); font-size:0.9rem; color:var(--cream); }

/* Lightbox */
.lightbox { position:fixed; inset:0; background:rgba(0,0,0,0.95); z-index:2000; display:none; align-items:center; justify-content:center; flex-direction:column; }
.lightbox.active { display:flex; }
.lightbox-close { position:absolute; top:20px; right:20px; background:none; border:none; color:var(--gold); font-size:2.5rem; cursor:pointer; z-index:2001; }
.lightbox-prev, .lightbox-next { position:absolute; top:50%; transform:translateY(-50%); background:rgba(212,168,67,0.1); border:1px solid var(--border); color:var(--gold); width:50px; height:50px; border-radius:50%; cursor:pointer; font-size:1.2rem; display:flex; align-items:center; justify-content:center; transition:var(--transition); }
.lightbox-prev { left:20px; }
.lightbox-next { right:20px; }
.lightbox-prev:hover, .lightbox-next:hover { background:rgba(212,168,67,0.2); }
#lightbox-img { max-width:80%; max-height:75vh; border-radius:var(--radius); }
.lightbox-caption { font-family:var(--font-sinhala); color:var(--cream); margin-top:16px; font-size:1.1rem; }

/* ===== MONKS ===== */
.monks-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:32px; }
.monk-card { text-align:center; background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius); padding:40px 24px; transition:var(--transition); }
.monk-card:hover { border-color:var(--gold); transform:translateY(-8px); box-shadow: 0 20px 40px rgba(0,0,0,0.3); }
.monk-image { width:160px; height:160px; margin:0 auto 20px; position:relative; border-radius:50%; overflow:hidden; }
.monk-image img { width:100%; height:100%; object-fit:cover; }
.monk-glow { position:absolute; inset:-4px; border-radius:50%; border:2px solid var(--gold); opacity:0; transition:var(--transition); }
.monk-card:hover .monk-glow { opacity:1; animation: glowPulse 2s infinite; }
@keyframes glowPulse { 0%,100%{box-shadow:0 0 10px var(--glow)} 50%{box-shadow:0 0 25px var(--glow)} }
.monk-card h3 { font-size:1.15rem; color:var(--cream); margin-bottom:4px; }
.monk-role { display:inline-block; padding:4px 16px; border-radius:20px; font-size:0.75rem; background:rgba(212,168,67,0.08); color:var(--gold); border:1px solid var(--border); margin:8px 0 12px; font-family:var(--font-sinhala); }
.monk-card p { font-size:0.9rem; color:var(--text-muted); }

/* ===== DONATE ===== */
.donate-text { text-align:center; margin-bottom:48px; }
.donate-quote { font-family:var(--font-sinhala); font-size:1.5rem; color:var(--gold-light); margin-bottom:16px; }
.donate-cards { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-bottom:40px; }
.donate-card { background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius); padding:32px; text-align:center; transition:var(--transition); }
.donate-card:hover { border-color:var(--gold); transform:translateY(-8px); box-shadow: 0 20px 40px rgba(0,0,0,0.3); }
.donate-card-icon { width:64px; height:64px; margin:0 auto 16px; border-radius:50%; background:linear-gradient(135deg, var(--gold-dark), var(--gold)); display:flex; align-items:center; justify-content:center; color:#1A1A2E; font-size:1.5rem; }
.donate-card h3 { color:var(--cream); font-size:1.1rem; }
.donate-amount { display:block; margin-top:12px; padding:8px 16px; border-radius:20px; background:rgba(212,168,67,0.08); color:var(--gold); font-size:0.85rem; font-family:var(--font-sinhala); }
.bank-details { padding:32px; border:1px solid var(--border); border-radius:var(--radius); background:var(--bg-card); }
.bank-details h3 { font-size:1.2rem; color:var(--gold); margin-bottom:20px; text-align:center; }
.bank-info-grid { display:grid; grid-template-columns:repeat(auto-fit, minmax(300px, 1fr)); gap:20px; margin-top:20px; }
.bank-info-item { padding:24px; background:rgba(255,255,255,0.03); border-radius:var(--radius); border:1px solid var(--border); transition: var(--transition); height: 100%; }
.bank-info-item:hover { background: rgba(255,255,255,0.05); border-color: var(--gold); transform: translateY(-5px); }
.bank-header { display: flex; align-items: center; gap: 12px; margin-bottom: 20px; border-bottom: 1px solid var(--border); padding-bottom: 12px; }
.bank-header i { font-size: 1.5rem; color: var(--gold); }
.bank-name { font-family: var(--font-sinhala); font-size: 1.1rem; color: var(--cream); font-weight: 700; }
.bank-branch { font-size: 0.8rem; color: var(--gold); display: block; margin-top: 2px; }
.account-group { margin-bottom: 12px; }
.account-group:last-child { margin-bottom: 0; }
.bank-label { display:block; font-family:var(--font-sinhala); font-size:0.75rem; color:var(--text-muted); margin-bottom:4px; text-transform: uppercase; letter-spacing: 1px; }
.bank-value { font-size:1.1rem; color:var(--cream); font-weight:600; font-family: var(--font-heading); display: block; }
.account-name-label { font-size: 0.85rem; color: var(--saffron); font-family: var(--font-sinhala); margin-bottom: 4px; display: block; }

/* ===== CONTACT ===== */
.contact-grid { display:grid; grid-template-columns:1fr 1fr; gap:48px; }
.contact-item { display:flex; gap:16px; margin-bottom:24px; }
.contact-icon { width:48px; height:48px; min-width:48px; border-radius:12px; background:linear-gradient(135deg, var(--gold-dark), var(--gold)); display:flex; align-items:center; justify-content:center; color:#1A1A2E; font-size:1.1rem; }
.contact-item h4 { font-family:var(--font-sinhala); color:var(--cream); font-size:0.95rem; margin-bottom:4px; }
.contact-item p { font-size:0.9rem; color:var(--text-muted); }
.social-links { display:flex; gap:12px; margin-top:16px; }
.social-link { width:44px; height:44px; border-radius:50%; border:1px solid var(--border); display:flex; align-items:center; justify-content:center; color:var(--gold); transition:var(--transition); }
.social-link:hover { background:var(--gold); color:#1A1A2E; transform:translateY(-3px); }

/* Form */
.contact-form { background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius); padding:32px; backdrop-filter:blur(10px); }
.form-group { margin-bottom:20px; }
.form-group label { display:block; font-family:var(--font-sinhala); font-size:0.9rem; color:var(--cream); margin-bottom:6px; }
.form-group input, .form-group select, .form-group textarea { width:100%; padding:12px 16px; border:1px solid var(--border); border-radius:var(--radius-sm); background:rgba(255,255,255,0.03); color:var(--text); font-family:var(--font-body); font-size:0.9rem; transition:var(--transition); outline:none; }
.form-group input:focus, .form-group select:focus, .form-group textarea:focus { border-color:var(--gold); box-shadow: 0 0 20px rgba(212,168,67,0.1); }
.form-group textarea { resize:vertical; }
.form-group select { cursor:pointer; }

/* ===== FOOTER ===== */
.footer { background: #080812; border-top:1px solid var(--border); padding:60px 0 0; position:relative; z-index:1; }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1.5fr; gap:40px; margin-bottom:40px; }
.footer-logo { display:flex; align-items:center; gap:12px; margin-bottom:16px; }
.footer-about p { font-size:0.9rem; color:var(--text-muted); margin-bottom:16px; }
.footer-links h4 { font-family:var(--font-sinhala); color:var(--cream); font-size:1rem; margin-bottom:16px; }
.footer-links a { display:block; color:var(--text-muted); font-size:0.9rem; padding:4px 0; transition:var(--transition); font-family:var(--font-sinhala); }
.footer-links a:hover { color:var(--gold); padding-left:8px; }
.footer-newsletter h4 { font-family:var(--font-sinhala); color:var(--cream); font-size:1rem; margin-bottom:12px; }
.footer-newsletter p { font-size:0.85rem; color:var(--text-muted); margin-bottom:16px; font-family:var(--font-sinhala); }
.newsletter-form { display:flex; gap:8px; }
.newsletter-form input { flex:1; padding:10px 16px; border:1px solid var(--border); border-radius:var(--radius-sm); background:rgba(255,255,255,0.03); color:var(--text); outline:none; font-size:0.85rem; }
.newsletter-form input:focus { border-color:var(--gold); }
.newsletter-form button { padding:10px 16px; border:none; border-radius:var(--radius-sm); background:linear-gradient(135deg, var(--gold-dark), var(--gold)); color:#1A1A2E; cursor:pointer; transition:var(--transition); }
.newsletter-form button:hover { transform:translateY(-2px); }
.footer-bottom { text-align:center; padding:24px 0; border-top:1px solid var(--border); }
.footer-bottom p { font-size:0.85rem; color:var(--text-muted); font-family:var(--font-sinhala); }
.footer-blessing { color:var(--gold); margin-top:8px; font-style:italic; }

/* ===== REVEAL ANIMATION ===== */
.js .reveal { opacity:0; transform:translateY(30px); transition: opacity 0.8s ease, transform 0.8s ease; }
.reveal.visible { opacity:1; transform:translateY(0); }
/* Fallback if JS is disabled or stuck: reveal elements after 3 seconds anyway */
@keyframes autoReveal { to { opacity: 1; transform: translateY(0); } }
.js .reveal:not(.visible) { animation: autoReveal 0.1s forwards 3s; }

/* ===== RESPONSIVE ===== */
@media(max-width:1024px) {
    .about-grid, .contact-grid { grid-template-columns:1fr; }
    .teachings-grid,.monks-grid,.donate-cards { grid-template-columns:repeat(2,1fr); }
    .stats-row { grid-template-columns:repeat(2,1fr); }
    .footer-grid { grid-template-columns:repeat(2,1fr); }
}
@media(max-width:768px) {
    .hamburger { display:flex; }
    .nav-menu { position:fixed; top:0; right:-100%; width:280px; height:100vh; background:rgba(13,13,26,0.98); backdrop-filter:blur(20px); flex-direction:column; padding:80px 24px 24px; gap:4px; transition:var(--transition); border-left:1px solid var(--border); }
    .nav-menu.active { right:0; }
    .nav-link { justify-content:flex-start; flex-direction:row; gap:8px; }
    .nav-link small { font-size:0.75rem; }
    .teachings-grid,.monks-grid,.donate-cards { grid-template-columns:1fr; }
    .gallery-grid { grid-template-columns:repeat(2,1fr); }
    .event-card { flex-direction:column; }
    .event-date { flex-direction:row; gap:8px; min-width:auto; }
    .bank-info-grid { grid-template-columns:1fr; }
    .footer-grid { grid-template-columns:1fr; }
    .hero-sinhala { font-size:2rem; }
}
@media(max-width:480px) {
    .gallery-grid { grid-template-columns:1fr; }
    .stats-row { grid-template-columns:1fr; }
    .hero-buttons { flex-direction:column; align-items:center; }
}
