/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:1000;background:rgba(11,36,68,0.97);backdrop-filter:blur(14px);height:70px;padding:0 5%;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid rgba(201,146,42,0.22)}
.nav-brand{display:flex;align-items:center;gap:13px;text-decoration:none}
.nav-logo-wrap{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--gold),var(--gold2));display:flex;align-items:center;justify-content:center;border:2px solid rgba(245,217,138,0.35);overflow:hidden;flex-shrink:0}
.nav-logo-wrap img{width:100%;height:100%;object-fit:contain;border-radius:50%}
.nav-logo-fallback{font-family:'Cormorant Garamond',serif;font-size:19px;font-weight:700;color:var(--navy);display:none}
.nav-txt strong{display:block;font-family:'Cormorant Garamond',serif;font-size:17px;font-weight:700;color:var(--gold3);letter-spacing:.02em;line-height:1.15}
.nav-txt small{font-size:10.5px;color:rgba(255,255,255,0.48);font-weight:400;letter-spacing:.04em}
.nav-links{display:flex;align-items:center;gap:3px;list-style:none}
.nav-links a{color:rgba(255,255,255,.72);text-decoration:none;font-size:13.5px;font-weight:400;padding:8px 13px;border-radius:7px;transition:all .2s}
.nav-links a:hover,.nav-links a.active{color:#fff;background:rgba(201,146,42,0.15)}
.nav-links a.active{color:var(--gold3)}
.nav-cta{background:var(--gold)!important;color:var(--navy)!important;font-weight:700!important;padding:9px 20px!important;border-radius:8px!important}
.nav-cta:hover{background:var(--gold2)!important}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:6px}
.hamburger span{width:24px;height:2px;background:#fff;border-radius:2px;transition:all .3s}
.mob-menu{display:none;position:fixed;top:70px;left:0;right:0;z-index:999;background:rgba(11,36,68,0.98);backdrop-filter:blur(14px);flex-direction:column;padding:16px 5% 24px;border-bottom:1px solid rgba(201,146,42,0.2)}
.mob-menu.open{display:flex}
.mob-menu a{color:rgba(255,255,255,.8);text-decoration:none;font-size:15px;padding:13px 0;border-bottom:1px solid rgba(255,255,255,.07)}
.mob-menu .mob-cta{margin-top:12px;background:var(--gold);color:var(--navy);text-align:center;border-radius:8px;font-weight:700;padding:13px;border:none}

/* HERO */
.hero{min-height:100vh;background:var(--navy);position:relative;overflow:hidden;display:flex;align-items:center;padding:100px 5% 140px}
.hero-glow{position:absolute;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(201,146,42,0.09) 0%,transparent 70%);top:50%;right:12%;transform:translateY(-50%);pointer-events:none}
.hero-ring{position:absolute;width:680px;height:680px;border-radius:50%;border:1px solid rgba(201,146,42,0.10);top:50%;right:3%;transform:translateY(-50%);pointer-events:none}
.hero-ring::before{content:'';position:absolute;inset:60px;border-radius:50%;border:1px solid rgba(201,146,42,0.08)}
.hero-ring::after{content:'';position:absolute;inset:120px;border-radius:50%;border:1px solid rgba(201,146,42,0.06)}
.hero-content{position:relative;z-index:2;max-width:640px}
.hero-tag{display:inline-flex;align-items:center;gap:8px;background:rgba(201,146,42,0.12);border:1px solid rgba(201,146,42,0.28);border-radius:100px;padding:7px 18px;margin-bottom:28px;color:var(--gold3);font-size:12px;font-weight:600;letter-spacing:.09em;text-transform:uppercase}
.hero-tag::before{content:'✦';font-size:9px}
.hero h1{font-family:'Cormorant Garamond',serif;font-size:clamp(46px,6vw,78px);line-height:1.07;color:#fff;margin-bottom:10px}
.hero h1 em{color:var(--gold3);font-style:italic}
.hero-tagline{font-size:18px;font-weight:300;color:rgba(255,255,255,.65);margin-bottom:18px;letter-spacing:.03em}
.hero-visi{font-size:14.5px;color:rgba(255,255,255,.48);line-height:1.8;margin-bottom:40px;max-width:500px;border-left:2px solid var(--gold);padding-left:16px;font-style:italic}
.hero-btns{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:52px}
.btn-gold{display:inline-flex;align-items:center;gap:8px;background:var(--gold);color:var(--navy);font-weight:700;font-size:14.5px;padding:13px 28px;border-radius:8px;text-decoration:none;transition:all .25s;letter-spacing:.01em}
.btn-gold:hover{background:var(--gold2);transform:translateY(-2px)}
.btn-ghost{display:inline-flex;align-items:center;gap:8px;border:1px solid rgba(255,255,255,.28);color:#fff;font-weight:400;font-size:14.5px;padding:13px 28px;border-radius:8px;text-decoration:none;transition:all .25s}
.btn-ghost:hover{background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.5)}
.btn-gold-outline{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--gold2);color:var(--gold2);font-weight:500;font-size:14.5px;padding:13px 28px;border-radius:8px;text-decoration:none;transition:all .25s}
.btn-gold-outline:hover{background:rgba(201,146,42,.1)}
.hero-stats{display:flex;gap:32px;flex-wrap:wrap;padding-top:28px;border-top:1px solid rgba(255,255,255,.08)}
.hstat-n{font-family:'Cormorant Garamond',serif;font-size:34px;font-weight:700;color:var(--gold3);line-height:1}
.hstat-l{font-size:12px;color:rgba(255,255,255,.45);margin-top:4px;letter-spacing:.04em}

/* SECTIONS */
section{padding:88px 5%}
.sec-lbl{display:inline-block;font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--teal);margin-bottom:10px}
.sec-ttl{font-family:'Cormorant Garamond',serif;font-size:clamp(34px,4.2vw,52px);line-height:1.12;color:var(--navy);margin-bottom:18px}
.sec-ttl em{color:var(--gold);font-style:italic}
.sec-dsc{font-size:15.5px;color:var(--muted);line-height:1.78;max-width:560px}
.sec-hd{margin-bottom:56px}
.sec-hd.center{text-align:center}
.sec-hd.center .sec-dsc{margin:0 auto}

/* VISI MISI */
.vismis{background:#fff}
.vm-grid{display:grid;grid-template-columns:1fr 1fr;gap:28px;margin-bottom:40px}
.vm-card{border-radius:16px;padding:36px;position:relative;overflow:hidden}
.vm-card.visi{background:var(--navy);border:1px solid rgba(201,146,42,0.2)}
.vm-card.misi{background:var(--gold-pale);border:1px solid var(--border)}
.vm-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--gold),transparent)}
.vm-icon{font-size:36px;margin-bottom:16px}
.vm-title{font-family:'Cormorant Garamond',serif;font-size:26px;font-weight:700;margin-bottom:14px}
.vm-card.visi .vm-title{color:var(--gold3)}
.vm-card.misi .vm-title{color:var(--navy)}
.vm-card.visi p{font-size:14.5px;color:rgba(255,255,255,.7);line-height:1.8;font-style:italic}
.misi-list{display:flex;flex-direction:column;gap:12px}
.misi-item{display:flex;gap:12px;align-items:flex-start;font-size:14px;color:var(--text);line-height:1.65}
.misi-dot{width:20px;height:20px;border-radius:50%;background:var(--gold);flex-shrink:0;margin-top:2px;display:flex;align-items:center;justify-content:center;font-size:9px;color:var(--navy);font-weight:700}

/* PROGRAM */
.program{background:var(--navy)}
.program .sec-lbl{color:var(--gold3)}
.program .sec-ttl{color:#fff}
.program .sec-dsc{color:rgba(255,255,255,.55)}
.prog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.prog-card{background:rgba(255,255,255,.04);border:1px solid rgba(201,146,42,.18);border-radius:14px;padding:30px 26px;transition:all .3s;position:relative;overflow:hidden}
.prog-card::after{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--gold),var(--gold2),transparent);opacity:0;transition:opacity .3s}
.prog-card:hover{background:rgba(255,255,255,.07);transform:translateY(-4px)}
.prog-card:hover::after{opacity:1}
.prog-num{font-family:'Cormorant Garamond',serif;font-size:44px;color:rgba(201,146,42,.15);font-weight:700;line-height:1;margin-bottom:14px}
.prog-icon{font-size:28px;margin-bottom:12px}
.prog-title{font-size:16px;font-weight:600;color:#fff;margin-bottom:9px}
.prog-desc{font-size:13.5px;color:rgba(255,255,255,.52);line-height:1.7}
.prog-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:14px}
.ptag{font-size:11px;background:rgba(201,146,42,.13);color:var(--gold3);border-radius:100px;padding:4px 10px;border:1px solid rgba(201,146,42,.2)}

/* PENDAFTARAN */
.reg{background:var(--cream)}
.reg-layout{display:grid;grid-template-columns:1fr 1.1fr;gap:64px;align-items:start}
.reg-steps{display:flex;flex-direction:column;gap:0;margin-top:6px}
.rstep{display:flex;gap:18px;align-items:flex-start;padding-bottom:28px;position:relative}
.rstep:not(:last-child)::after{content:'';position:absolute;left:18px;top:42px;bottom:0;width:2px;background:linear-gradient(to bottom,var(--gold),transparent)}
.rstep-c{width:38px;height:38px;border-radius:50%;background:var(--gold);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:var(--navy);flex-shrink:0}
.rstep-b{padding-top:5px}
.rstep-t{font-size:15px;font-weight:600;color:var(--navy);margin-bottom:4px}
.rstep-d{font-size:13.5px;color:var(--muted);line-height:1.6}
.syarat-list{margin-top:6px}
.syarat-item{display:flex;align-items:flex-start;gap:10px;padding:10px 0;border-bottom:1px solid var(--border);font-size:14px;color:var(--text)}
.syarat-item:last-child{border-bottom:none}
.s-ck{color:var(--teal);font-size:15px;flex-shrink:0;margin-top:1px}
.reg-box{background:#fff;border:1px solid var(--border);border-radius:16px;padding:36px;box-shadow:0 4px 40px rgba(11,36,68,.06)}
.form-h{font-family:'Cormorant Garamond',serif;font-size:24px;color:var(--navy);margin-bottom:4px}
.form-s{font-size:13px;color:var(--muted);margin-bottom:24px}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.fg{margin-bottom:15px}
.fg label{display:block;font-size:12.5px;font-weight:600;color:var(--navy);margin-bottom:6px;letter-spacing:.02em}
.fg input,.fg select,.fg textarea{width:100%;padding:10px 13px;border:1px solid rgba(0,0,0,.11);border-radius:8px;font-family:'Plus Jakarta Sans',sans-serif;font-size:14px;color:var(--text);background:#fff;outline:none;transition:border-color .2s}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--gold)}
.fg textarea{resize:vertical;min-height:88px}
.btn-sub{width:100%;padding:13px;background:var(--navy);color:#fff;border:none;border-radius:8px;font-family:'Plus Jakarta Sans',sans-serif;font-size:15px;font-weight:700;cursor:pointer;transition:all .25s;margin-top:4px}
.btn-sub:hover{background:var(--navy2);transform:translateY(-1px)}
.extra-box{margin-top:22px;border-radius:12px;padding:18px 20px;display:flex;align-items:center;gap:14px}
.extra-box.unduh{background:var(--gold-pale);border:1px solid var(--border2)}
.extra-box.twibbon{background:var(--navy);margin-top:12px}
.extra-ico{font-size:26px;flex-shrink:0}
.extra-txt strong{display:block;font-size:14px;font-weight:600;margin-bottom:2px}
.extra-box.unduh .extra-txt strong{color:var(--navy)}
.extra-box.twibbon .extra-txt strong{color:#fff}
.extra-txt span{font-size:12.5px}
.extra-box.unduh .extra-txt span{color:var(--muted)}
.extra-box.twibbon .extra-txt span{color:rgba(255,255,255,.55)}
.extra-btn{margin-left:auto;display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:700;border-radius:7px;padding:9px 16px;text-decoration:none;white-space:nowrap;transition:all .2s;flex-shrink:0}
.extra-box.unduh .extra-btn{background:var(--gold);color:var(--navy)}
.extra-box.unduh .extra-btn:hover{background:var(--gold2)}
.extra-box.twibbon .extra-btn{border:1px solid var(--gold2);color:var(--gold2)}
.extra-box.twibbon .extra-btn:hover{background:rgba(201,146,42,.12)}

/* GALERI */
.gallery{background:#fff}
.gallery-note{display:inline-flex;align-items:center;gap:8px;background:var(--teal-light);border-radius:8px;padding:10px 16px;font-size:13px;color:var(--teal);margin-bottom:28px;font-weight:500}
.g-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:220px 200px;gap:14px;margin-bottom:28px}
.gitem{border-radius:12px;overflow:hidden;position:relative;background:var(--navy);cursor:pointer}
.gitem:first-child{grid-column:span 2;grid-row:span 2}
.gph{width:100%;height:100%;min-height:200px;background:linear-gradient(135deg,var(--navy),var(--navy2));display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px}
.gitem:first-child .gph{min-height:420px}
.gico{font-size:36px;opacity:.65}
.gitem:first-child .gico{font-size:56px}
.glbl{font-size:12px;color:rgba(255,255,255,.5);text-align:center;padding:0 16px;max-width:160px}
.ghov{position:absolute;inset:0;background:linear-gradient(to top,rgba(11,36,68,.88) 0%,transparent 55%);opacity:0;transition:opacity .3s;display:flex;align-items:flex-end;padding:14px 16px}
.gitem:hover .ghov{opacity:1}
.ghov span{font-size:12.5px;color:#fff;font-weight:500}
.gfooter{text-align:center}

/* TESTIMONI */
.testi{background:var(--cream)}
.tgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.tcard{background:#fff;border:1px solid var(--border);border-radius:14px;padding:28px;position:relative}
.tq{font-family:'Cormorant Garamond',serif;font-size:56px;line-height:.4;color:var(--gold);opacity:.3;position:absolute;top:18px;left:22px}
.tstars{display:flex;gap:2px;margin-bottom:8px}
.tstar{color:var(--gold);font-size:13px}
.ttext{font-size:14.5px;color:var(--text);line-height:1.78;margin-top:20px;margin-bottom:20px;font-style:italic}
.tauthor{display:flex;align-items:center;gap:12px}
.tav{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,var(--gold),var(--navy));display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:#fff;font-family:'Cormorant Garamond',serif;flex-shrink:0}
.tname{font-size:14px;font-weight:600;color:var(--navy)}
.trole{font-size:12px;color:var(--muted)}

/* KONTAK */
.contact{background:var(--navy)}
.contact .sec-lbl{color:var(--gold3)}
.contact .sec-ttl{color:#fff}
.cgrid{display:grid;grid-template-columns:1fr 1.25fr;gap:60px;align-items:start}
.c-desc{font-size:15px;color:rgba(255,255,255,.58);line-height:1.78;margin-bottom:38px}
.citems{display:flex;flex-direction:column;gap:18px}
.citem{display:flex;gap:15px;align-items:flex-start}
.cico{width:44px;height:44px;flex-shrink:0;border-radius:10px;background:rgba(201,146,42,.14);border:1px solid rgba(201,146,42,.24);display:flex;align-items:center;justify-content:center;font-size:18px}
.clbl{font-size:12px;color:rgba(255,255,255,.42);text-transform:uppercase;letter-spacing:.06em;margin-bottom:3px}
.cval{font-size:15px;color:#fff}
.cval a{color:var(--gold3);text-decoration:none}
.cval a:hover{text-decoration:underline}
.cform-box{background:rgba(255,255,255,.05);border:1px solid rgba(201,146,42,.2);border-radius:16px;padding:36px}
.cform-box .fg label{color:rgba(255,255,255,.75)}
.cform-box .fg input,.cform-box .fg textarea{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);color:#fff}
.cform-box .fg input::placeholder,.cform-box .fg textarea::placeholder{color:rgba(255,255,255,.32)}
.cform-box .fg input:focus,.cform-box .fg textarea:focus{border-color:var(--gold)}
.btn-csub{width:100%;padding:13px;background:var(--gold);color:var(--navy);border:none;border-radius:8px;font-family:'Plus Jakarta Sans',sans-serif;font-size:15px;font-weight:700;cursor:pointer;transition:all .25s;margin-top:4px}
.btn-csub:hover{background:var(--gold2)}

/* FOOTER */
footer{background:#060E1A;padding:52px 5% 28px;border-top:1px solid rgba(201,146,42,.14)}
.ftop{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.06);margin-bottom:24px}
.fbrand{font-family:'Cormorant Garamond',serif;font-size:20px;color:var(--gold3);margin-bottom:10px}
.fdesc{font-size:13.5px;color:rgba(255,255,255,.4);line-height:1.7;max-width:260px;margin-bottom:20px}
.fsocs{display:flex;gap:10px}
.fsoc{width:34px;height:34px;border-radius:8px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;font-size:14px;color:rgba(255,255,255,.5);text-decoration:none;transition:all .2s}
.fsoc:hover{background:rgba(201,146,42,.2);border-color:var(--gold);color:var(--gold3)}
.fctitle{font-size:11.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.38);margin-bottom:16px}
.flinks{list-style:none;display:flex;flex-direction:column;gap:10px}
.flinks a{font-size:13.5px;color:rgba(255,255,255,.52);text-decoration:none;transition:color .2s}
.flinks a:hover{color:var(--gold3)}
.fbot{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px}
.fcopy{font-size:12px;color:rgba(255,255,255,.28)}

/* REVEAL */
.reveal{opacity:0;transform:translateY(26px);transition:all .65s cubic-bezier(.25,.46,.45,.94)}
.reveal.visible{opacity:1;transform:translateY(0)}

/* MODAL */
.modal-bg{display:none;position:fixed;inset:0;z-index:3000;background:rgba(0,0,0,.72);align-items:center;justify-content:center;padding:20px}
.modal-bg.open{display:flex}
.modal-box{background:#fff;border-radius:18px;padding:40px;max-width:420px;width:100%;text-align:center}
.m-ico{font-size:54px;margin-bottom:16px}
.m-ttl{font-family:'Cormorant Garamond',serif;font-size:26px;color:var(--navy);margin-bottom:8px}
.m-msg{font-size:14.5px;color:var(--muted);line-height:1.65;margin-bottom:24px}
.m-close{background:var(--navy);color:#fff;border:none;padding:12px 30px;border-radius:8px;font-family:'Plus Jakarta Sans',sans-serif;font-size:14px;font-weight:600;cursor:pointer;transition:background .2s}
.m-close:hover{background:var(--navy2)}