/* Sekolah Olahraga Garuda — demo sekolah olahraga
   Palet: utama #b91c1c (merah garuda), aksen #facc15 (kuning), tema terang */

:root{
  --merah:#b91c1c;
  --merah-tua:#7f1212;
  --merah-muda:#fef2f2;
  --kuning:#facc15;
  --kuning-tua:#eab308;
  --tinta:#1c1917;
  --abu:#57534e;
  --garis:#e7e2df;
  --bg:#fffdfa;
  --kartu:#ffffff;
  --radius:16px;
  --shadow:0 8px 28px rgba(124,18,18,.10);
  --shadow-sm:0 3px 12px rgba(124,18,18,.07);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:-apple-system,"Segoe UI",Roboto,Arial,sans-serif;
  color:var(--tinta);
  background:var(--bg);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%}
a{color:inherit;text-decoration:none}

/* ---------- demo bar ---------- */
.demobar{
  background:var(--tinta);
  color:#fff;
  font-size:.82rem;
  text-align:center;
  padding:7px 14px;
  letter-spacing:.2px;
}
.demobar a{color:var(--kuning);font-weight:600}
.demobar a:hover{text-decoration:underline}

/* ---------- header ---------- */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(255,253,250,.92);
  backdrop-filter:blur(8px);
  border-bottom:1px solid var(--garis);
}
.nav{
  max-width:1140px;margin:0 auto;padding:.7rem 1.1rem;
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
}
.brand{display:flex;align-items:center;gap:.6rem;font-weight:800;font-size:1.08rem}
.brand .logo{
  width:40px;height:40px;flex:0 0 40px;
  display:grid;place-items:center;
  background:linear-gradient(135deg,var(--merah),var(--merah-tua));
  border-radius:12px;box-shadow:var(--shadow-sm);
}
.brand .logo svg{width:24px;height:24px;fill:var(--kuning)}
.brand b{color:var(--merah);line-height:1.1}
.brand small{display:block;font-size:.66rem;font-weight:600;color:var(--abu);letter-spacing:1.5px;text-transform:uppercase}

.menu{list-style:none;display:flex;align-items:center;gap:.3rem}
.menu a{
  display:block;padding:.5rem .8rem;border-radius:9px;
  font-weight:600;font-size:.93rem;color:var(--abu);transition:.18s;
}
.menu a:hover{color:var(--merah);background:var(--merah-muda)}
.menu a.active{color:#fff;background:var(--merah)}
.menu .btn-nav{background:var(--kuning);color:var(--tinta)!important}
.menu .btn-nav:hover{background:var(--kuning-tua)}

#nav{display:none}
.burger{display:none;cursor:pointer;flex-direction:column;gap:5px;padding:6px}
.burger span{width:24px;height:3px;background:var(--merah);border-radius:3px;transition:.2s}

/* ---------- buttons ---------- */
.btn{
  display:inline-block;padding:.8rem 1.5rem;border-radius:11px;
  font-weight:700;font-size:.95rem;cursor:pointer;border:0;transition:.18s;
}
.btn-primary{background:var(--merah);color:#fff;box-shadow:var(--shadow-sm)}
.btn-primary:hover{background:var(--merah-tua);transform:translateY(-2px)}
.btn-accent{background:var(--kuning);color:var(--tinta)}
.btn-accent:hover{background:var(--kuning-tua);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--merah);border:2px solid var(--merah)}
.btn-ghost:hover{background:var(--merah);color:#fff}

/* ---------- layout ---------- */
.wrap{max-width:1140px;margin:0 auto;padding:0 1.1rem}
section{padding:3.4rem 0}
.section-head{text-align:center;max-width:720px;margin:0 auto 2.2rem}
.eyebrow{
  display:inline-block;font-size:.74rem;font-weight:800;letter-spacing:2px;
  text-transform:uppercase;color:var(--merah);
  background:var(--merah-muda);padding:.35rem .85rem;border-radius:30px;margin-bottom:.8rem;
}
h1,h2,h3{line-height:1.18;font-weight:800;letter-spacing:-.4px}
h2{font-size:1.9rem;margin-bottom:.5rem}
h3{font-size:1.18rem}
.lead{color:var(--abu);font-size:1.02rem}

/* ---------- hero ---------- */
.hero{
  position:relative;overflow:hidden;
  background:
    radial-gradient(1100px 460px at 88% -10%,rgba(250,204,21,.20),transparent 60%),
    linear-gradient(160deg,#fff7f6 0%,var(--bg) 55%);
  border-bottom:1px solid var(--garis);
}
.hero .wrap{
  display:grid;grid-template-columns:1.1fr .9fr;gap:2.4rem;align-items:center;
  padding-top:3.4rem;padding-bottom:3.6rem;
}
.hero h1{font-size:2.7rem;margin-bottom:1rem}
.hero h1 .hl{color:var(--merah)}
.hero p{font-size:1.1rem;color:var(--abu);max-width:34ch;margin-bottom:1.6rem}
.hero-cta{display:flex;gap:.8rem;flex-wrap:wrap}
.hero-stats{display:flex;gap:1.8rem;margin-top:2rem;flex-wrap:wrap}
.hero-stats b{display:block;font-size:1.7rem;color:var(--merah);line-height:1}
.hero-stats span{font-size:.82rem;color:var(--abu)}

/* hero visual — pure CSS field */
.hero-art{
  position:relative;aspect-ratio:1/1;border-radius:24px;
  background:linear-gradient(150deg,var(--merah),var(--merah-tua));
  box-shadow:var(--shadow);display:grid;place-items:center;overflow:hidden;
}
.hero-art::before{
  content:"";position:absolute;inset:0;
  background:
    repeating-linear-gradient(0deg,transparent 0 38px,rgba(255,255,255,.06) 38px 76px);
}
.hero-art .ring{
  width:62%;height:62%;border-radius:50%;
  border:7px solid var(--kuning);
  display:grid;place-items:center;position:relative;z-index:1;
  box-shadow:0 0 0 14px rgba(250,204,21,.12);
}
.hero-art .ring svg{width:46%;height:46%;fill:#fff}
.hero-badge{
  position:absolute;bottom:14px;left:14px;z-index:2;
  background:var(--kuning);color:var(--tinta);font-weight:800;
  font-size:.8rem;padding:.45rem .8rem;border-radius:10px;
}

/* ---------- cabang/program cards ---------- */
.grid{display:grid;gap:1.2rem}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}

.card{
  background:var(--kartu);border:1px solid var(--garis);border-radius:var(--radius);
  padding:1.5rem;box-shadow:var(--shadow-sm);transition:.2s;
}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:#f0d9d9}
.card .ic{
  width:52px;height:52px;border-radius:13px;display:grid;place-items:center;
  background:var(--merah-muda);margin-bottom:1rem;
}
.card .ic svg{width:28px;height:28px;fill:var(--merah)}
.card h3{margin-bottom:.4rem}
.card p{color:var(--abu);font-size:.93rem}
.card .tag{display:inline-block;margin-top:.8rem;font-size:.78rem;font-weight:700;color:var(--kuning-tua)}

/* ---------- highlight band ---------- */
.band{
  background:linear-gradient(135deg,var(--merah),var(--merah-tua));
  color:#fff;border-radius:22px;padding:2.6rem;margin:0 auto;
  display:grid;grid-template-columns:1fr auto;gap:1.6rem;align-items:center;
}
.band h2{color:#fff}
.band p{color:rgba(255,255,255,.88)}
.band .btn-accent{white-space:nowrap}

/* ---------- feature list ---------- */
.feat{display:flex;gap:.8rem;align-items:flex-start}
.feat .dot{
  flex:0 0 28px;width:28px;height:28px;border-radius:50%;
  background:var(--kuning);display:grid;place-items:center;margin-top:2px;
}
.feat .dot svg{width:15px;height:15px;fill:var(--tinta)}
.feat h3{font-size:1.02rem;margin-bottom:.15rem}
.feat p{color:var(--abu);font-size:.9rem}

/* ---------- page header ---------- */
.page-head{
  background:
    radial-gradient(700px 280px at 100% 0,rgba(250,204,21,.18),transparent 60%),
    linear-gradient(160deg,#fff7f6,var(--bg));
  border-bottom:1px solid var(--garis);
  padding:2.8rem 0;text-align:center;
}
.page-head h1{font-size:2.2rem;margin-bottom:.4rem}
.page-head p{color:var(--abu);max-width:60ch;margin:0 auto}
.crumb{font-size:.8rem;color:var(--abu);margin-bottom:.6rem}
.crumb a{color:var(--merah);font-weight:600}

/* ---------- profil ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:2.2rem;align-items:center}
.visual-box{
  aspect-ratio:4/3;border-radius:18px;overflow:hidden;position:relative;
  background:linear-gradient(150deg,var(--merah),var(--merah-tua));box-shadow:var(--shadow);
}
.visual-box::after{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 30% 30%,rgba(250,204,21,.35),transparent 55%);
}
.visual-box .mono{
  position:absolute;inset:0;display:grid;place-items:center;z-index:1;
  font-weight:900;font-size:3rem;color:rgba(255,255,255,.18);letter-spacing:2px;
}
.values{list-style:none;display:grid;gap:1rem}
.values li{display:flex;gap:.8rem;align-items:flex-start}
.values .n{
  flex:0 0 34px;width:34px;height:34px;border-radius:10px;font-weight:800;
  background:var(--merah);color:#fff;display:grid;place-items:center;
}

.stat-band{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;text-align:center}
.stat-band .s{background:var(--kartu);border:1px solid var(--garis);border-radius:14px;padding:1.4rem .6rem}
.stat-band b{display:block;font-size:2rem;color:var(--merah);line-height:1}
.stat-band span{font-size:.82rem;color:var(--abu)}

/* coach grid */
.coach{text-align:center}
.coach .av{
  width:84px;height:84px;border-radius:50%;margin:0 auto .8rem;
  background:linear-gradient(135deg,var(--merah),var(--merah-tua));
  display:grid;place-items:center;color:var(--kuning);font-weight:800;font-size:1.6rem;
}
.coach h3{font-size:1rem}
.coach span{font-size:.82rem;color:var(--abu)}

/* ---------- akademik / timeline ---------- */
.timeline{position:relative;margin-left:1rem;padding-left:1.8rem;border-left:3px solid var(--merah-muda)}
.tl-item{position:relative;margin-bottom:1.6rem}
.tl-item::before{
  content:"";position:absolute;left:-2.32rem;top:4px;width:16px;height:16px;border-radius:50%;
  background:var(--kuning);border:3px solid #fff;box-shadow:0 0 0 2px var(--merah);
}
.tl-item h3{font-size:1.05rem}
.tl-item p{color:var(--abu);font-size:.92rem}

table{width:100%;border-collapse:collapse;background:var(--kartu);border-radius:14px;overflow:hidden;box-shadow:var(--shadow-sm)}
th,td{padding:.85rem 1rem;text-align:left;border-bottom:1px solid var(--garis);font-size:.92rem}
th{background:var(--merah);color:#fff;font-weight:700;font-size:.85rem;letter-spacing:.3px}
tr:last-child td{border-bottom:0}
tbody tr:nth-child(even){background:var(--merah-muda)}

/* ---------- PPDB ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1.1rem;counter-reset:s}
.step{background:var(--kartu);border:1px solid var(--garis);border-radius:14px;padding:1.4rem;position:relative}
.step::before{
  counter-increment:s;content:counter(s);
  position:absolute;top:-14px;left:1.2rem;width:34px;height:34px;border-radius:10px;
  background:var(--kuning);color:var(--tinta);font-weight:800;display:grid;place-items:center;
}
.step h3{margin:.6rem 0 .3rem;font-size:1.02rem}
.step p{color:var(--abu);font-size:.88rem}

.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.price{background:var(--kartu);border:1px solid var(--garis);border-radius:18px;padding:1.8rem;text-align:center}
.price.feat-price{border:2px solid var(--merah);box-shadow:var(--shadow);position:relative}
.price.feat-price .pop{
  position:absolute;top:-13px;left:50%;transform:translateX(-50%);
  background:var(--kuning);color:var(--tinta);font-size:.72rem;font-weight:800;padding:.3rem .8rem;border-radius:20px;
}
.price h3{font-size:1.1rem}
.price .amt{font-size:2rem;font-weight:800;color:var(--merah);margin:.5rem 0}
.price .amt small{font-size:.85rem;color:var(--abu);font-weight:600}
.price ul{list-style:none;text-align:left;margin:1rem 0;display:grid;gap:.5rem}
.price ul li{font-size:.9rem;color:var(--abu);padding-left:1.5rem;position:relative}
.price ul li::before{content:"✓";position:absolute;left:0;color:var(--merah);font-weight:800}

/* ---------- forms ---------- */
.form-card{background:var(--kartu);border:1px solid var(--garis);border-radius:18px;padding:1.8rem;box-shadow:var(--shadow-sm)}
.demo-note{background:var(--kuning);color:var(--tinta);font-size:.82rem;font-weight:700;padding:.55rem .9rem;border-radius:9px;margin-bottom:1.2rem;display:inline-block}
.field{margin-bottom:1rem}
.field label{display:block;font-size:.85rem;font-weight:700;margin-bottom:.35rem}
.field input,.field select,.field textarea{
  width:100%;padding:.7rem .85rem;border:1.5px solid var(--garis);border-radius:10px;
  font:inherit;font-size:.93rem;background:#fffdfa;color:var(--tinta);
}
.field input:focus,.field select:focus,.field textarea:focus{outline:0;border-color:var(--merah)}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:1rem}

/* ---------- galeri ---------- */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.gitem{
  aspect-ratio:4/3;border-radius:14px;overflow:hidden;position:relative;
  display:grid;place-items:center;color:#fff;box-shadow:var(--shadow-sm);
}
.gitem span{position:relative;z-index:1;font-weight:800;font-size:.95rem;text-shadow:0 1px 4px rgba(0,0,0,.3)}
.gitem svg{position:absolute;width:38%;height:38%;fill:rgba(255,255,255,.22);bottom:8px;right:8px}
.g1{background:linear-gradient(140deg,#b91c1c,#7f1212)}
.g2{background:linear-gradient(140deg,#0e7490,#155e75)}
.g3{background:linear-gradient(140deg,#15803d,#166534)}
.g4{background:linear-gradient(140deg,#c2410c,#9a3412)}
.g5{background:linear-gradient(140deg,#6d28d9,#5b21b6)}
.g6{background:linear-gradient(140deg,#0369a1,#075985)}
.g7{background:linear-gradient(140deg,#b91c1c,#facc15)}
.g8{background:linear-gradient(140deg,#1f2937,#111827)}
.g9{background:linear-gradient(140deg,#a16207,#854d0e)}

.medals{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.medal{background:var(--kartu);border:1px solid var(--garis);border-radius:14px;padding:1.3rem;display:flex;gap:.9rem;align-items:center}
.medal .m{
  flex:0 0 46px;width:46px;height:46px;border-radius:50%;display:grid;place-items:center;
  background:var(--kuning);color:var(--tinta);font-weight:900;
}
.medal h3{font-size:.98rem;margin-bottom:.1rem}
.medal span{font-size:.82rem;color:var(--abu)}

/* ---------- kontak ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:2rem;align-items:start}
.info-list{list-style:none;display:grid;gap:1.1rem}
.info-list li{display:flex;gap:.9rem;align-items:flex-start}
.info-list .ic{
  flex:0 0 42px;width:42px;height:42px;border-radius:11px;display:grid;place-items:center;
  background:var(--merah-muda);
}
.info-list .ic svg{width:22px;height:22px;fill:var(--merah)}
.info-list b{display:block;font-size:.95rem}
.info-list span{font-size:.9rem;color:var(--abu)}
.map-box{
  aspect-ratio:16/10;border-radius:16px;margin-top:1.4rem;position:relative;overflow:hidden;
  background:linear-gradient(135deg,#fef2f2,#fff);border:1px solid var(--garis);
  display:grid;place-items:center;color:var(--abu);font-size:.9rem;
}
.map-box::before{
  content:"";position:absolute;inset:0;
  background:
    repeating-linear-gradient(0deg,transparent 0 28px,rgba(185,28,28,.06) 28px 30px),
    repeating-linear-gradient(90deg,transparent 0 28px,rgba(185,28,28,.06) 28px 30px);
}
.map-pin{position:relative;z-index:1;text-align:center}
.map-pin svg{width:34px;height:34px;fill:var(--merah)}

.faq{display:grid;gap:.8rem}
.faq details{background:var(--kartu);border:1px solid var(--garis);border-radius:12px;padding:.4rem 1.1rem}
.faq summary{cursor:pointer;font-weight:700;padding:.7rem 0;font-size:.95rem;list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq summary::before{content:"+";color:var(--merah);font-weight:800;margin-right:.6rem}
.faq details[open] summary::before{content:"–"}
.faq p{color:var(--abu);font-size:.91rem;padding-bottom:.8rem}

/* ---------- footer ---------- */
.site-footer{background:var(--tinta);color:#d6d3d1;padding:3rem 0 1.5rem;margin-top:2rem}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2rem}
.site-footer .brand b{color:#fff}
.site-footer .brand small{color:var(--kuning)}
.site-footer p{font-size:.9rem;color:#a8a29e;margin-top:.8rem}
.foot-col h4{font-size:.95rem;color:#fff;margin-bottom:.9rem}
.foot-col ul{list-style:none;display:grid;gap:.5rem}
.foot-col a,.foot-col li{font-size:.9rem;color:#a8a29e}
.foot-col a:hover{color:var(--kuning)}
.foot-bottom{border-top:1px solid #44403c;margin-top:2rem;padding-top:1.2rem;text-align:center;font-size:.82rem;color:#78716c}
.foot-bottom b{color:var(--kuning)}

/* ---------- responsive ---------- */
@media(max-width:820px){
  .burger{display:flex}
  .menu{
    position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:stretch;
    gap:.2rem;background:var(--bg);border-bottom:1px solid var(--garis);
    padding:.6rem 1rem 1rem;box-shadow:var(--shadow-sm);
    max-height:0;overflow:hidden;opacity:0;transition:.25s;
  }
  #nav:checked ~ .menu{max-height:480px;opacity:1;padding-top:.6rem}
  #nav:checked ~ .burger span:nth-child(1){transform:translateY(8px) rotate(45deg)}
  #nav:checked ~ .burger span:nth-child(2){opacity:0}
  #nav:checked ~ .burger span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}
  .nav{position:relative;flex-wrap:wrap}
  .hero .wrap{grid-template-columns:1fr;text-align:center}
  .hero p{margin-left:auto;margin-right:auto}
  .hero-cta,.hero-stats{justify-content:center}
  .hero-art{max-width:340px;margin:0 auto}
  .grid-3,.grid-4{grid-template-columns:1fr 1fr}
  .split,.contact-grid{grid-template-columns:1fr}
  .band{grid-template-columns:1fr;text-align:center}
  .steps,.price-grid,.gallery,.medals,.stat-band{grid-template-columns:1fr 1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:520px){
  h2{font-size:1.55rem}
  .hero h1{font-size:2.1rem}
  .grid-3,.grid-4,.grid-2,.steps,.price-grid,.gallery,.medals,.stat-band,.row2,.foot-grid{grid-template-columns:1fr}
  section{padding:2.6rem 0}
}
