/* ===========================
   MASJID AL BAROKAH — style.css
   =========================== */
:root{
  --G:#145A32;--G2:#1A7A44;--G3:#1E8449;--G4:#27AE60;--G5:#D5F5E3;
  --Au:#B7950B;--Au2:#D4AC0D;--Au3:#F4D03F;
  --W:#fff;--bg:#F0FDF4;
  --t1:#0D1F12;--t2:#2C4A32;--t3:#617365;
  --b1:#F9FAFB;--b2:#F0F4F1;--b3:#D5E8D8;
  --sh:0 4px 20px rgba(20,90,50,.10);
  --sh2:0 12px 40px rgba(20,90,50,.18);
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:'Nunito',sans-serif;color:var(--t1);background:var(--bg);}

/* ===== SCREENS ===== */
.screen{display:none;}
.screen.active{display:block;}
#s-home.active{display:block;}
#s-login.active{display:flex;}
#s-admin.active,#s-pengurus.active{display:flex;}

/* ===== TOP BAR ===== */
.topbar-pub{
  background:var(--G);color:rgba(255,255,255,.78);
  padding:7px 48px;display:flex;justify-content:space-between;
  align-items:center;font-size:12px;font-weight:600;
}
.jadwal-strip{display:flex;gap:20px;}
.jadwal-strip span b{color:var(--Au3);}

/* ===== NAVBAR ===== */
.navbar{
  background:#fff;border-bottom:2px solid var(--G5);
  padding:0 48px;display:flex;align-items:center;
  justify-content:space-between;position:sticky;top:0;z-index:300;
  box-shadow:0 2px 12px rgba(20,90,50,.07);
}
.brand{display:flex;align-items:center;gap:13px;padding:14px 0;cursor:pointer;}
.brand-ico{width:50px;height:50px;background:linear-gradient(135deg,var(--G),var(--G3));border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:24px;box-shadow:0 4px 12px rgba(20,90,50,.25);}
.brand-name{font-family:'Playfair Display',serif;font-size:15px;color:var(--G);display:block;font-weight:700;}
.brand-sub{font-size:10px;color:var(--t3);letter-spacing:2px;text-transform:uppercase;}
.nav-menu{display:flex;align-items:center;gap:2px;height:100%;}
.nd{position:relative;}
.nl{display:flex;align-items:center;gap:5px;padding:18px 14px;font-size:13px;font-weight:700;color:var(--t2);cursor:pointer;border:none;background:none;font-family:'Nunito',sans-serif;border-bottom:3px solid transparent;transition:all .2s;white-space:nowrap;text-decoration:none;}
.nl:hover,.nl.active{color:var(--G3);border-bottom-color:var(--G3);}
.arr{font-size:9px;transition:transform .2s;}
.nd:hover .arr{transform:rotate(180deg);}
.dropdown{position:absolute;top:calc(100% + 2px);left:0;background:#fff;border-radius:14px;box-shadow:0 16px 48px rgba(0,0,0,.13);border:1px solid var(--b3);min-width:215px;opacity:0;pointer-events:none;transform:translateY(-8px);transition:all .2s;z-index:999;overflow:hidden;}
.nd:hover .dropdown{opacity:1;pointer-events:all;transform:translateY(0);}
.dd-head{padding:10px 18px;background:var(--G5);border-bottom:1px solid var(--b3);}
.dd-head span{font-size:10px;font-weight:800;color:var(--G);letter-spacing:2px;text-transform:uppercase;}
.dd-link{display:flex;align-items:center;gap:10px;padding:11px 18px;font-size:13px;font-weight:700;color:var(--t2);cursor:pointer;transition:all .15s;border:none;background:none;width:100%;text-align:left;font-family:'Nunito',sans-serif;}
.dd-link:hover{background:var(--G5);color:var(--G);}
.dd-ico{font-size:16px;width:22px;text-align:center;}
.dd-sep{height:1px;background:var(--b3);margin:3px 0;}
.btn-login-nav{background:linear-gradient(135deg,var(--G3),var(--G4));color:#fff;padding:11px 26px;border-radius:50px;font-size:13px;font-weight:800;border:none;cursor:pointer;font-family:'Nunito',sans-serif;box-shadow:0 4px 14px rgba(30,132,73,.28);transition:all .25s;margin-left:10px;}
.btn-login-nav:hover{transform:translateY(-2px);box-shadow:0 7px 20px rgba(30,132,73,.38);}

/* ===== HERO ===== */
.hero{min-height:88vh;background:linear-gradient(150deg,var(--G) 0%,#1a6b3e 50%,#1f7d49 100%);display:flex;align-items:center;position:relative;overflow:hidden;}
.hero-glow{position:absolute;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(212,172,13,.07),transparent 70%);top:-200px;right:-150px;pointer-events:none;}
.hero-inner{max-width:1180px;margin:0 auto;padding:80px 48px;display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;width:100%;}
.hero-badge{display:inline-flex;align-items:center;gap:7px;background:rgba(212,172,13,.18);border:1px solid rgba(212,172,13,.35);color:var(--Au3);padding:7px 18px;border-radius:50px;font-size:11px;font-weight:800;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:20px;}
.hero-arabic{font-family:'Amiri',serif;font-size:36px;color:var(--Au3);text-shadow:0 0 30px rgba(244,208,63,.2);margin-bottom:10px;direction:rtl;}
.hero-title{font-family:'Playfair Display',serif;font-size:44px;font-weight:700;color:#fff;line-height:1.15;margin-bottom:14px;}
.hero-title span{color:var(--Au3);}
.hero-loc{font-size:13px;color:rgba(255,255,255,.65);font-weight:600;letter-spacing:1px;margin-bottom:22px;}
.hero-desc{font-size:15px;color:rgba(255,255,255,.75);line-height:1.8;margin-bottom:32px;}
.hero-btns{display:flex;gap:13px;flex-wrap:wrap;}
.btn-gold{background:linear-gradient(135deg,var(--Au),var(--Au2));color:var(--G);padding:14px 32px;border-radius:50px;font-size:14px;font-weight:800;border:none;cursor:pointer;font-family:'Nunito',sans-serif;box-shadow:0 5px 20px rgba(183,149,11,.35);transition:all .3s;}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 9px 28px rgba(183,149,11,.45);}
.btn-outline-w{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.4);padding:12px 30px;border-radius:50px;font-size:14px;font-weight:700;cursor:pointer;font-family:'Nunito',sans-serif;transition:all .3s;}
.btn-outline-w:hover{border-color:#fff;background:rgba(255,255,255,.08);}
.hero-stats{display:flex;gap:28px;margin-top:36px;padding-top:28px;border-top:1px solid rgba(255,255,255,.15);}
.hstat{cursor:pointer;}
.hstat-val{font-size:26px;font-weight:800;color:var(--Au3);}
.hstat-lbl{font-size:11px;color:rgba(255,255,255,.55);margin-top:2px;}
.hstat:hover .hstat-val{opacity:.8;}
.hero-card{background:rgba(255,255,255,.07);backdrop-filter:blur(10px);border:1px solid rgba(212,172,13,.22);border-radius:24px;padding:28px;position:relative;overflow:hidden;}
.hero-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--Au),var(--Au3),var(--Au));}
.shalat-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:6px;margin-top:20px;background:rgba(255,255,255,.05);border-radius:12px;padding:14px;}
.st{text-align:center;cursor:pointer;transition:.2s;}
.st:hover .st-val{color:var(--Au3);}
.st-name{font-size:9px;color:var(--Au3);font-weight:800;letter-spacing:1.5px;text-transform:uppercase;}
.st-val{font-size:16px;font-weight:800;color:#fff;margin-top:3px;transition:.2s;}
.hero-wave{position:absolute;bottom:0;left:0;right:0;}

/* ===== PUBLIC SECTIONS ===== */
.pub-section{padding:80px 48px;}
.pub-section.alt{background:var(--bg);}
.pub-section.dark{background:var(--G);color:#fff;}
.s-label{display:inline-block;font-size:11px;font-weight:800;letter-spacing:3px;text-transform:uppercase;color:var(--G3);margin-bottom:10px;}
.dark .s-label{color:var(--Au3);}
.s-title{font-family:'Playfair Display',serif;font-size:34px;font-weight:700;color:var(--G);margin-bottom:12px;line-height:1.2;}
.dark .s-title{color:#fff;}
.s-desc{font-size:15px;color:var(--t3);line-height:1.8;max-width:540px;}
.dark .s-desc{color:rgba(255,255,255,.68);}
.s-head{margin-bottom:48px;}
.s-head.center{text-align:center;}
.s-head.center .s-desc{margin:0 auto;}
.divider{display:flex;align-items:center;gap:12px;margin:12px 0;}
.div-line{flex:1;height:2px;background:linear-gradient(90deg,transparent,var(--Au2),transparent);}
.div-gem{color:var(--Au2);font-size:14px;}
.inner{max-width:1180px;margin:0 auto;}

/* ===== ABOUT CARDS ===== */
.about-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;}
.about-card{background:#fff;border-radius:18px;padding:28px 22px;text-align:center;border:1px solid var(--b3);box-shadow:var(--sh);transition:all .3s;cursor:pointer;}
.about-card:hover{transform:translateY(-7px) scale(1.02);box-shadow:var(--sh2);border-color:var(--G3);}
.about-ico{font-size:38px;margin-bottom:14px;}
.about-card h3{font-size:14px;font-weight:800;color:var(--G);margin-bottom:8px;}
.about-card p{font-size:13px;color:var(--t3);line-height:1.7;}
.about-card .card-lnk{margin-top:14px;font-size:12px;color:var(--G3);font-weight:800;}

/* ===== SEJARAH ===== */
.sejarah-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start;}
.timeline{position:relative;padding-left:26px;}
.timeline::before{content:'';position:absolute;left:0;top:8px;bottom:8px;width:2px;background:linear-gradient(180deg,var(--G3),var(--G4));border-radius:2px;}
.tl{position:relative;margin-bottom:32px;cursor:pointer;transition:.2s;border-radius:12px;padding:4px 6px;margin-left:-6px;}
.tl:hover{background:var(--G5);padding:8px 10px;margin-left:-10px;}
.tl:hover .tl-title{color:var(--G3);}
.tl-dot{position:absolute;left:-31px;top:8px;width:11px;height:11px;border-radius:50%;background:var(--G3);border:3px solid #fff;box-shadow:0 0 0 3px var(--G5);}
.tl-year{font-size:11px;font-weight:800;color:var(--G3);letter-spacing:1px;margin-bottom:5px;}
.tl-title{font-size:15px;font-weight:800;color:var(--t1);margin-bottom:6px;transition:.2s;}
.tl-desc{font-size:13px;color:var(--t3);line-height:1.7;}
.mosque-frame{background:linear-gradient(135deg,var(--G),var(--G2));border-radius:22px;padding:36px;text-align:center;margin-bottom:20px;}
.mosque-emoji{font-size:90px;filter:drop-shadow(0 14px 36px rgba(0,0,0,.3));}
.mosque-frame p{color:rgba(255,255,255,.75);font-size:13px;margin-top:14px;line-height:1.7;}
.mosque-stats{display:flex;gap:20px;justify-content:center;margin-top:18px;}
.ms{text-align:center;cursor:pointer;}
.ms:hover .ms-val{transform:scale(1.08);display:inline-block;}
.ms-val{font-size:22px;font-weight:800;color:var(--Au3);transition:.2s;}
.ms-lbl{font-size:10px;color:rgba(255,255,255,.5);margin-top:2px;}
.quote-box{background:var(--G5);border-left:4px solid var(--G3);border-radius:0 14px 14px 0;padding:22px;margin-top:20px;cursor:pointer;transition:.2s;}
.quote-box:hover{background:#c8f0d9;}
.quote-box p{font-family:'Amiri',serif;font-size:17px;color:var(--G);line-height:1.7;margin-bottom:6px;}
.quote-box cite{font-size:12px;color:var(--t3);font-style:normal;font-weight:700;}
.lokasi-box{background:#fff;border-radius:16px;padding:22px;border:1px solid var(--b3);margin-top:18px;box-shadow:var(--sh);cursor:pointer;transition:.2s;}
.lokasi-box:hover{box-shadow:var(--sh2);border-color:var(--G3);}
.lokasi-box h4{font-size:13px;font-weight:800;color:var(--G);margin-bottom:12px;}
.lokasi-box p{font-size:13px;color:var(--t3);line-height:1.9;}

/* ===== VISI MISI ===== */
.visi-box{background:linear-gradient(135deg,var(--G),var(--G2));border-radius:22px;padding:44px;text-align:center;margin-bottom:28px;position:relative;overflow:hidden;cursor:pointer;}
.visi-box::before{content:'"';position:absolute;top:-30px;left:20px;font-size:180px;color:rgba(255,255,255,.04);font-family:'Playfair Display',serif;line-height:1;}
.visi-arabic{font-family:'Amiri',serif;font-size:26px;color:var(--Au3);margin-bottom:10px;}
.visi-badge{display:inline-block;background:var(--Au2);color:var(--G);padding:5px 18px;border-radius:50px;font-size:10px;font-weight:800;letter-spacing:2px;text-transform:uppercase;margin-bottom:18px;}
.visi-text{font-size:19px;color:#fff;font-weight:700;line-height:1.6;max-width:680px;margin:0 auto;}
.misi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
.misi-card{background:#fff;border-radius:18px;padding:24px 20px;border:1px solid var(--b3);border-top:4px solid var(--G3);transition:all .3s;cursor:pointer;}
.misi-card:hover{transform:translateY(-5px);box-shadow:var(--sh2);border-top-color:var(--Au2);}
.misi-num{width:36px;height:36px;border-radius:10px;background:var(--G5);color:var(--G);font-weight:800;font-size:14px;display:flex;align-items:center;justify-content:center;margin-bottom:14px;}
.misi-card h4{font-size:14px;font-weight:800;color:var(--G);margin-bottom:8px;}
.misi-card p{font-size:13px;color:var(--t3);line-height:1.7;}
.motto-strip{background:var(--G5);border-radius:18px;padding:28px;display:flex;gap:20px;align-items:center;margin-top:28px;cursor:pointer;transition:.2s;}
.motto-strip:hover{background:#c8f0d9;}
.motto-ico{font-size:36px;flex-shrink:0;}
.motto-arabic{font-family:'Amiri',serif;font-size:19px;color:var(--G);line-height:1.5;}
.motto-trans{font-size:13px;color:var(--t3);margin-top:5px;}
.motto-ref{font-size:12px;color:var(--G3);font-weight:700;margin-top:3px;}

/* ===== PROGRAM ===== */
.prog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.prog-card{background:#fff;border-radius:18px;overflow:hidden;border:1px solid var(--b3);box-shadow:var(--sh);transition:all .3s;}
.prog-card:hover{transform:translateY(-4px);box-shadow:var(--sh2);}
.prog-body{padding:24px 20px 18px;}
.prog-emoji{font-size:40px;margin-bottom:12px;}
.prog-badge{display:inline-block;background:var(--G5);color:var(--G3);font-size:10px;font-weight:800;padding:3px 10px;border-radius:50px;margin-bottom:10px;}
.prog-card h3{font-size:15px;font-weight:800;color:var(--G);margin-bottom:5px;}
.prog-sched{font-size:12px;color:var(--Au);font-weight:700;margin-bottom:10px;}
.prog-desc{font-size:13px;color:var(--t3);line-height:1.7;}
.prog-foot{padding:14px 20px;border-top:1px solid var(--b2);background:var(--b1);display:flex;justify-content:space-between;align-items:center;}
.prog-pic{font-size:12px;color:var(--t3);font-weight:600;}

/* ===== JADWAL TABLE ===== */
.jadwal-tbl{width:100%;border-collapse:separate;border-spacing:0 3px;margin-top:28px;}
.jadwal-tbl th{background:var(--G);color:var(--Au3);font-size:11px;letter-spacing:1px;text-transform:uppercase;padding:12px 18px;text-align:left;}
.jadwal-tbl th:first-child{border-radius:10px 0 0 10px;}
.jadwal-tbl th:last-child{border-radius:0 10px 10px 0;}
.jadwal-tbl td{background:#fff;padding:12px 18px;font-size:13px;color:var(--t2);border-top:1px solid var(--b2);border-bottom:1px solid var(--b2);}
.jadwal-tbl tr td:first-child{font-weight:800;color:var(--G);border-left:1px solid var(--b2);border-radius:9px 0 0 9px;}
.jadwal-tbl tr td:last-child{border-right:1px solid var(--b2);border-radius:0 9px 9px 0;}
.jadwal-tbl tr:hover td{background:var(--G5);cursor:pointer;}
.hl{color:var(--G3);font-weight:700;}

/* ===== STRUKTUR ===== */
.struk-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:20px;}
.pcard{background:#fff;border-radius:18px;padding:24px 18px;text-align:center;border:1px solid var(--b3);box-shadow:var(--sh);transition:all .3s;cursor:pointer;}
.pcard:hover{transform:translateY(-5px);box-shadow:var(--sh2);}
.pcard-ava{width:64px;height:64px;border-radius:50%;margin:0 auto 14px;display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:800;color:#fff;background:linear-gradient(135deg,var(--G),var(--G3));box-shadow:0 4px 14px rgba(30,132,73,.25);}
.pcard.ketua .pcard-ava{background:linear-gradient(135deg,var(--Au),var(--Au2));color:var(--G);}
.pcard.ketua{border-color:var(--Au3);border-width:2px;}
.pcard-name{font-size:14px;font-weight:800;color:var(--G);margin-bottom:5px;}
.pcard-job{font-size:11px;color:var(--t3);font-weight:600;}

/* ===== FASILITAS ===== */
.fas-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.fas-card{background:#fff;border-radius:18px;padding:24px 20px;border:1px solid var(--b3);box-shadow:var(--sh);display:flex;gap:16px;align-items:flex-start;transition:all .3s;cursor:pointer;}
.fas-card:hover{transform:translateY(-3px);box-shadow:var(--sh2);border-color:var(--G3);}
.fas-ico{width:48px;height:48px;border-radius:14px;background:var(--G5);display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0;}
.fas-info h4{font-size:14px;font-weight:800;color:var(--G);margin-bottom:6px;}
.fas-info p{font-size:12px;color:var(--t3);line-height:1.6;}

/* ===== DONASI ===== */
.donasi-layout{display:grid;grid-template-columns:1fr 1fr;gap:44px;}
.dprog-card{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);border-radius:18px;padding:22px;margin-bottom:16px;transition:.3s;cursor:pointer;}
.dprog-card:hover{background:rgba(255,255,255,.15);}
.dprog-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:10px;}
.dprog-title{font-size:15px;font-weight:800;color:#fff;}
.dprog-pct{font-size:20px;font-weight:800;color:var(--Au3);}
.dprog-desc{font-size:13px;color:rgba(255,255,255,.65);margin-bottom:14px;line-height:1.6;}
.dprog-bar{height:8px;background:rgba(255,255,255,.15);border-radius:4px;overflow:hidden;margin-bottom:8px;}
.dprog-fill{height:100%;border-radius:4px;background:linear-gradient(90deg,var(--G4),var(--Au3));}
.dprog-amounts{display:flex;justify-content:space-between;font-size:12px;}
.dprog-col{color:var(--G4);font-weight:700;}
.dprog-tgt{color:rgba(255,255,255,.5);}
.donasi-form-card{background:#fff;border-radius:22px;padding:32px;position:sticky;top:80px;}
.df-title{font-family:'Playfair Display',serif;font-size:20px;color:var(--G);margin-bottom:5px;}
.df-sub{font-size:13px;color:var(--t3);margin-bottom:22px;}
.nom-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:7px;margin-bottom:10px;}
.nom-btn{padding:11px 6px;border:2px solid var(--b3);border-radius:10px;text-align:center;font-size:12px;font-weight:700;color:var(--t2);cursor:pointer;transition:.2s;background:#fff;font-family:'Nunito',sans-serif;}
.nom-btn:hover,.nom-btn.active{border-color:var(--G3);background:var(--G5);color:var(--G);}
.pf{margin-bottom:14px;}
.pf label{display:block;font-size:12px;font-weight:800;color:var(--t2);margin-bottom:6px;}
.pf input,.pf select,.pf textarea{width:100%;padding:11px 13px;border:2px solid var(--b3);border-radius:10px;font-size:13px;font-family:'Nunito',sans-serif;color:var(--t1);background:var(--b1);outline:none;transition:.2s;}
.pf input:focus,.pf select:focus,.pf textarea:focus{border-color:var(--G3);background:#fff;box-shadow:0 0 0 3px rgba(30,132,73,.08);}
.rek-info{background:var(--G5);border-radius:12px;padding:14px;font-size:13px;color:var(--G);font-weight:600;margin-bottom:14px;line-height:1.6;}
.rek-info b{font-size:14px;display:block;margin-bottom:2px;}
.btn-donasi{width:100%;padding:14px;background:linear-gradient(135deg,var(--G3),var(--G4));color:#fff;border:none;border-radius:12px;font-size:15px;font-weight:800;cursor:pointer;font-family:'Nunito',sans-serif;box-shadow:0 5px 18px rgba(30,132,73,.28);transition:.3s;}
.btn-donasi:hover{transform:translateY(-2px);box-shadow:0 9px 26px rgba(30,132,73,.38);}
.dstats{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:28px;}
.dst{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);border-radius:14px;padding:18px;text-align:center;}
.dst-val{font-size:24px;font-weight:800;color:var(--Au3);}
.dst-lbl{font-size:12px;color:rgba(255,255,255,.6);margin-top:3px;}

/* ===== GALERI ===== */
.gal-filter{display:flex;gap:8px;margin-bottom:28px;flex-wrap:wrap;justify-content:center;}
.gf-btn{padding:9px 20px;border-radius:50px;font-size:13px;font-weight:700;border:2px solid var(--b3);background:#fff;color:var(--t3);cursor:pointer;transition:.2s;font-family:'Nunito',sans-serif;}
.gf-btn.active,.gf-btn:hover{border-color:var(--G3);background:var(--G5);color:var(--G);}
.gal-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;}
.gi{aspect-ratio:1;border-radius:16px;background:var(--G5);display:flex;align-items:center;justify-content:center;font-size:48px;cursor:pointer;position:relative;overflow:hidden;border:2px solid transparent;transition:.3s;}
.gi:hover{transform:scale(1.04);border-color:var(--G3);box-shadow:var(--sh2);}
.gi.wide{grid-column:span 2;aspect-ratio:2/1;}
.gi-ov{position:absolute;inset:0;background:linear-gradient(transparent 40%,rgba(20,90,50,.92));opacity:0;transition:.3s;display:flex;flex-direction:column;justify-content:flex-end;padding:14px;}
.gi:hover .gi-ov{opacity:1;}
.gi-title{color:#fff;font-size:13px;font-weight:800;margin-bottom:3px;}
.gi-cat{color:var(--Au3);font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;}

/* ===== KONTAK ===== */
.kontak-layout{display:grid;grid-template-columns:1fr 1fr;gap:56px;}
.ki{display:flex;gap:16px;align-items:flex-start;margin-bottom:24px;}
.ki-ico{width:44px;height:44px;border-radius:12px;background:rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0;}
.ki-lbl{font-size:11px;color:rgba(255,255,255,.5);font-weight:700;letter-spacing:.5px;margin-bottom:3px;}
.ki-val{font-size:14px;color:#fff;font-weight:700;line-height:1.5;}
.kontak-form{background:#fff;border-radius:22px;padding:32px;}
.kontak-form h3{font-family:'Playfair Display',serif;font-size:20px;color:var(--G);margin-bottom:5px;}
.kontak-form > p{font-size:13px;color:var(--t3);margin-bottom:22px;}
.btn-kirim{width:100%;padding:14px;background:linear-gradient(135deg,var(--G3),var(--G4));color:#fff;border:none;border-radius:12px;font-size:15px;font-weight:800;cursor:pointer;font-family:'Nunito',sans-serif;transition:.3s;}
.btn-kirim:hover{transform:translateY(-2px);box-shadow:0 8px 22px rgba(30,132,73,.3);}

/* ===== FOOTER ===== */
footer{background:var(--G);color:rgba(255,255,255,.7);padding:56px 48px 32px;}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:44px;margin-bottom:44px;max-width:1180px;margin-left:auto;margin-right:auto;}
.footer-brand{display:flex;align-items:center;gap:12px;margin-bottom:16px;}
.footer-ico{width:44px;height:44px;background:linear-gradient(135deg,var(--Au),var(--Au2));border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px;}
.footer-name{font-family:'Playfair Display',serif;color:#fff;font-size:15px;font-weight:700;}
.footer-desc{font-size:13px;line-height:1.8;}
.fcol h4{color:#fff;font-size:12px;font-weight:800;letter-spacing:1px;text-transform:uppercase;margin-bottom:14px;}
.flinks{list-style:none;}
.flinks li{margin-bottom:8px;}
.flinks a{color:rgba(255,255,255,.6);text-decoration:none;font-size:13px;font-weight:600;cursor:pointer;transition:.2s;}
.flinks a:hover{color:var(--Au3);}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12);padding-top:20px;display:flex;justify-content:space-between;align-items:center;font-size:12px;max-width:1180px;margin:0 auto;}

/* ===== LOGIN SCREEN ===== */
#s-login{align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,var(--G) 0%,#1a7a44 100%);padding:40px 20px;}
.login-box{background:#fff;border-radius:26px;width:100%;max-width:420px;padding:42px 34px;box-shadow:var(--sh2);position:relative;overflow:hidden;}
.login-box::before{content:'';position:absolute;top:0;left:0;right:0;height:5px;background:linear-gradient(90deg,var(--G3),var(--Au),var(--G3));}
.login-logo{text-align:center;margin-bottom:26px;}
.login-ico{width:58px;height:58px;background:linear-gradient(135deg,var(--G3),var(--G4));border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:26px;margin:0 auto 11px;}
.login-logo h2{font-family:'Playfair Display',serif;font-size:19px;color:var(--G);}
.login-logo p{font-size:12px;color:var(--t3);margin-top:3px;}
.acc-tabs{display:flex;background:var(--b1);border-radius:12px;padding:4px;margin-bottom:22px;gap:4px;}
.acc-tab{flex:1;padding:10px;text-align:center;border-radius:10px;font-size:13px;font-weight:800;cursor:pointer;border:none;background:transparent;color:var(--t3);font-family:'Nunito',sans-serif;transition:.2s;}
.acc-tab.active{background:var(--G3);color:#fff;box-shadow:0 2px 8px rgba(30,132,73,.28);}
.err-msg{background:#FEF2F2;color:#DC2626;padding:10px 13px;border-radius:10px;font-size:13px;font-weight:700;margin-bottom:16px;display:none;border:1px solid #FCA5A5;}
.err-msg.show{display:block;}
.fg{margin-bottom:16px;}
.fg label{display:block;font-size:12px;font-weight:800;color:var(--t2);margin-bottom:6px;}
.fg input{width:100%;padding:12px 14px;border:2px solid var(--b3);border-radius:11px;font-size:14px;font-family:'Nunito',sans-serif;color:var(--t1);background:var(--b1);outline:none;transition:.2s;}
.fg input:focus{border-color:var(--G3);background:#fff;}
.cred-box{background:var(--G5);border-radius:12px;padding:14px;margin:16px 0;font-size:12px;border:1px solid var(--b3);}
.cred-box strong{color:var(--G);display:block;margin-bottom:8px;font-size:13px;}
.cred-box div{color:var(--t2);margin-bottom:5px;line-height:1.6;}
.cred-box b{color:var(--G3);}
.demo-hint{font-size:11px;color:var(--t3);margin-top:5px;}
.demo-hint b{color:var(--G3);cursor:pointer;text-decoration:underline;}
.btn-login-full{width:100%;padding:14px;background:linear-gradient(135deg,var(--G3),var(--G4));color:#fff;border:none;border-radius:12px;font-size:15px;font-weight:800;font-family:'Nunito',sans-serif;cursor:pointer;box-shadow:0 5px 18px rgba(30,132,73,.28);transition:.3s;}
.btn-login-full:hover{transform:translateY(-2px);}
.login-back{text-align:center;margin-top:16px;}
.login-back a{color:var(--t3);font-size:13px;cursor:pointer;text-decoration:none;}
.login-back a:hover{color:var(--G3);}

/* ===== DASHBOARD LAYOUT ===== */
#s-admin,#s-pengurus{min-height:100vh;background:var(--bg);flex-direction:row;}
.sidebar{width:256px;min-height:100vh;background:var(--G);position:fixed;top:0;left:0;bottom:0;z-index:100;display:flex;flex-direction:column;overflow-y:auto;}
.sb-head{padding:24px 20px;border-bottom:1px solid rgba(212,172,13,.18);text-align:center;}
.sb-mosque{font-size:34px;margin-bottom:7px;}
.sb-title{font-family:'Playfair Display',serif;color:var(--Au3);font-size:12px;line-height:1.5;}
.sb-user{padding:14px 18px;border-bottom:1px solid rgba(255,255,255,.1);display:flex;align-items:center;gap:11px;}
.sb-ava{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:16px;flex-shrink:0;}
.sb-ava.a{background:linear-gradient(135deg,var(--Au),var(--Au2));color:var(--G);}
.sb-ava.p{background:linear-gradient(135deg,var(--G3),var(--G4));color:#fff;}
.sb-uname{color:#fff;font-weight:700;font-size:13px;}
.sb-urole{color:var(--Au3);font-size:11px;}
.sb-nav{flex:1;padding:12px 8px;}
.sb-group{color:rgba(255,255,255,.32);font-size:10px;letter-spacing:2px;text-transform:uppercase;padding:0 10px;margin:14px 0 5px;font-weight:700;}
.sb-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:11px;cursor:pointer;color:rgba(255,255,255,.62);font-size:13px;font-weight:700;transition:.2s;margin-bottom:2px;text-decoration:none;border:1px solid transparent;}
.sb-item:hover{background:rgba(255,255,255,.08);color:#fff;}
.sb-item.active{background:rgba(212,172,13,.2);color:var(--Au3);border-color:rgba(212,172,13,.28);}
.sb-ico{font-size:16px;width:20px;text-align:center;flex-shrink:0;}
.sb-foot{padding:12px 8px;border-top:1px solid rgba(255,255,255,.1);}
.btn-logout{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;background:rgba(239,68,68,.12);border:1px solid rgba(239,68,68,.22);border-radius:11px;color:#FCA5A5;font-size:13px;font-weight:700;font-family:'Nunito',sans-serif;cursor:pointer;transition:.2s;}
.btn-logout:hover{background:rgba(239,68,68,.22);color:#FEE2E2;}
.main-wrap{margin-left:256px;flex:1;min-height:100vh;display:flex;flex-direction:column;}
.dash-topbar{background:#fff;padding:15px 26px;border-bottom:1px solid var(--b3);display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;z-index:50;box-shadow:0 2px 8px rgba(0,0,0,.05);}
.dash-title{font-family:'Playfair Display',serif;font-size:19px;color:var(--G);}
.dash-date{font-size:12px;color:var(--t3);font-weight:600;}
.dash-content{flex:1;padding:26px;}

/* ===== DASHBOARD WIDGETS ===== */
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:15px;margin-bottom:22px;}
.scard{background:#fff;border-radius:15px;padding:18px;display:flex;align-items:flex-start;gap:13px;box-shadow:var(--sh);border:1px solid var(--b3);transition:.3s;}
.scard:hover{transform:translateY(-2px);box-shadow:var(--sh2);}
.scard-ico{width:46px;height:46px;border-radius:13px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0;}
.scard-lbl{font-size:10px;color:var(--t3);font-weight:800;letter-spacing:.5px;text-transform:uppercase;margin-bottom:4px;}
.scard-val{font-size:24px;font-weight:800;color:var(--t1);line-height:1;}
.scard-chg{font-size:11px;color:var(--G3);font-weight:700;margin-top:2px;}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:18px;}
.dcard{background:#fff;border-radius:15px;padding:20px;box-shadow:var(--sh);border:1px solid var(--b3);}
.dcard-head{font-family:'Playfair Display',serif;font-size:14px;color:var(--G);margin-bottom:14px;padding-bottom:10px;border-bottom:1px solid var(--b2);display:flex;justify-content:space-between;align-items:center;}
.full-dcard{background:#fff;border-radius:15px;padding:20px;box-shadow:var(--sh);border:1px solid var(--b3);margin-bottom:18px;}
.sec-hdr{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;}
.sec-ttl{font-family:'Playfair Display',serif;font-size:16px;color:var(--G);}
.act-list{list-style:none;}
.act-item{display:flex;align-items:flex-start;gap:10px;padding:9px 0;border-bottom:1px solid var(--b2);}
.act-item:last-child{border-bottom:none;}
.act-dot{width:7px;height:7px;border-radius:50%;background:var(--G4);flex-shrink:0;margin-top:5px;}
.act-text{font-size:13px;color:var(--t2);}
.act-time{font-size:11px;color:var(--t3);margin-top:1px;}
.jdl-list{list-style:none;}
.jdl-item{display:flex;justify-content:space-between;align-items:center;padding:9px 0;border-bottom:1px solid var(--b2);}
.jdl-item:last-child{border-bottom:none;}
.jdl-name{font-weight:700;font-size:13px;color:var(--G);}
.jdl-imam{font-size:11px;color:var(--G3);font-weight:600;margin-top:2px;}
.jdl-time{font-size:14px;font-weight:800;}
.dtbl{width:100%;border-collapse:collapse;font-size:13px;}
.dtbl th{text-align:left;padding:10px 13px;background:var(--G5);color:var(--G);font-size:11px;letter-spacing:.5px;text-transform:uppercase;font-weight:800;border-bottom:2px solid var(--b3);}
.dtbl td{padding:10px 13px;border-bottom:1px solid var(--b2);color:var(--t2);}
.dtbl tr:hover td{background:var(--b1);}
.bdg{display:inline-block;padding:3px 10px;border-radius:50px;font-size:11px;font-weight:800;}
.bdg-green{background:#D1FAE5;color:#065F46;}
.bdg-yellow{background:#FEF3C7;color:#92400E;}
.bdg-blue{background:#DBEAFE;color:#1E40AF;}
.bdg-red{background:#FEE2E2;color:#991B1B;}
.ff{margin-bottom:14px;}
.ff label{display:block;font-size:12px;font-weight:800;color:var(--t2);margin-bottom:6px;}
.ff input,.ff select,.ff textarea{width:100%;padding:10px 13px;border:2px solid var(--b3);border-radius:10px;font-size:13px;font-family:'Nunito',sans-serif;color:var(--t1);background:var(--b1);outline:none;transition:.2s;}
.ff input:focus,.ff select:focus,.ff textarea:focus{border-color:var(--G3);background:#fff;box-shadow:0 0 0 3px rgba(30,132,73,.07);}
.ff textarea{height:80px;resize:vertical;}
.btn{padding:9px 20px;border-radius:10px;font-size:13px;font-weight:800;font-family:'Nunito',sans-serif;cursor:pointer;border:none;transition:.2s;}
.btn-g{background:var(--G3);color:#fff;}
.btn-g:hover{background:var(--G2);transform:translateY(-1px);}
.btn-au{background:linear-gradient(135deg,var(--Au),var(--Au2));color:var(--G);}
.btn-au:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(183,149,11,.28);}
.btn-red{background:#FEE2E2;color:#DC2626;}
.btn-sm{padding:6px 13px;font-size:12px;}
.btn-full{width:100%;padding:13px;font-size:14px;}
.prog-bar-wrap{height:8px;background:var(--b2);border-radius:4px;overflow:hidden;margin:7px 0;}
.prog-bar-fill{height:100%;border-radius:4px;background:linear-gradient(90deg,var(--G3),var(--G4));}
.chart-wrap{display:flex;align-items:flex-end;gap:5px;height:130px;padding-bottom:22px;}
.cb-wrap{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;height:100%;justify-content:flex-end;}
.cb{width:100%;border-radius:5px 5px 0 0;min-height:4px;background:linear-gradient(180deg,var(--G4),var(--G3));}
.cb.au{background:linear-gradient(180deg,var(--Au3),var(--Au2));}
.cb-lbl{font-size:10px;color:var(--t3);font-weight:700;}
.cb-val{font-size:10px;color:var(--G3);font-weight:700;}
.pcard2{display:flex;gap:12px;padding:14px;background:#fff;border-radius:14px;border:1px solid var(--b3);margin-bottom:11px;transition:.2s;}
.pcard2:hover{box-shadow:var(--sh);border-color:var(--G5);}
.pdate{width:50px;height:50px;background:var(--G);border-radius:11px;display:flex;flex-direction:column;align-items:center;justify-content:center;flex-shrink:0;color:#fff;}
.pday{font-size:19px;font-weight:800;line-height:1;}
.pmon{font-size:9px;letter-spacing:1px;color:var(--Au3);text-transform:uppercase;}
.pt{font-weight:800;font-size:13px;color:var(--G);margin-bottom:3px;}
.pd{font-size:12px;color:var(--t3);line-height:1.5;}
.gal-dash{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px;}
.gal-d-item{aspect-ratio:1;border-radius:13px;background:var(--G5);display:flex;align-items:center;justify-content:center;font-size:38px;cursor:pointer;position:relative;overflow:hidden;border:1px solid var(--b3);transition:.3s;}
.gal-d-item:hover{transform:scale(1.04);box-shadow:var(--sh2);}
.gal-d-cap{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,rgba(20,90,50,.9));padding:14px 8px 8px;color:#fff;font-size:10px;font-weight:700;opacity:0;transition:.3s;}
.gal-d-item:hover .gal-d-cap{opacity:1;}
.alert-ok{background:#D1FAE5;border:1px solid var(--G4);border-radius:10px;padding:11px 14px;font-size:13px;color:var(--G);font-weight:700;margin-bottom:14px;display:none;}
.alert-ok.show{display:block;}
.form-sub{display:none;background:var(--bg);border-radius:12px;padding:18px;margin-bottom:18px;border:1px solid var(--b3);}

/* ===== TOAST ===== */
#toast{position:fixed;bottom:22px;right:22px;background:var(--G);color:#fff;padding:13px 20px;border-radius:13px;font-size:13px;font-weight:700;box-shadow:var(--sh2);z-index:9999;transform:translateY(80px);opacity:0;transition:.3s;max-width:320px;}
#toast.show{transform:translateY(0);opacity:1;}
