/* ============================================================
   PONPES DARUL ULUM MEDALI — Light & Friendly Theme
   Bright · Warm · Welcoming · Modern
   Font: Syne (display) + Plus Jakarta Sans (body)
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;1,400&family=Syne:wght@400;500;600;700;800&family=Amiri:wght@400;700&display=swap');

/* ===== TOKENS ===== */
:root {
  --bg:        #ffffff;
  --bg-2:      #f5f7ff;
  --bg-3:      #fff8f0;

  /* Brand colors */
  --green:     #16a34a;
  --green-dk:  #0f7a38;
  --green-lt:  #dcfce7;
  --green-glow:rgba(22,163,74,.18);

  --gold:      #d97706;
  --gold-lt:   #fef3c7;
  --gold-glow: rgba(217,119,6,.2);

  --blue:      #2563eb;
  --blue-lt:   #dbeafe;
  --blue-glow: rgba(37,99,235,.15);

  --red:       #dc2626;
  --red-lt:    #fee2e2;

  /* Blob colors — soft pastel tints */
  --blob-green: rgba(22,163,74,.12);
  --blob-gold:  rgba(217,119,6,.1);
  --blob-blue:  rgba(37,99,235,.1);

  /* UI */
  --border:    rgba(0,0,0,.08);
  --border-md: rgba(0,0,0,.12);
  --shadow-sm: 0 1px 4px rgba(0,0,0,.06), 0 4px 16px rgba(0,0,0,.06);
  --shadow-md: 0 4px 24px rgba(0,0,0,.1), 0 1px 4px rgba(0,0,0,.06);
  --shadow-lg: 0 8px 48px rgba(0,0,0,.13), 0 2px 8px rgba(0,0,0,.06);
  --shadow-xl: 0 20px 60px rgba(0,0,0,.16);

  --text:      #111827;
  --text-2:    #374151;
  --text-3:    #6b7280;
  --white:     #ffffff;

  --font-head: 'Syne', sans-serif;
  --font-body: 'Plus Jakarta Sans', sans-serif;
  --font-arab: 'Amiri', serif;

  --ease:        cubic-bezier(.22,1,.36,1);
  --ease-spring: cubic-bezier(.34,1.56,.64,1);

  --r-sm:   8px;
  --r-md:   14px;
  --r-lg:   20px;
  --r-xl:   28px;
  --r-full: 999px;
}

/* ===== RESET ===== */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }
body {
  font-family:var(--font-body);
  background:var(--bg);
  color:var(--text);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
a { text-decoration:none; color:inherit; }
ul { list-style:none; }
img { max-width:100%; display:block; }
.container { max-width:1200px; margin:0 auto; padding:0 28px; }

/* ===== SOFT AMBIENT (global background blobs) ===== */
.ambient-layer {
  position:fixed; inset:0; z-index:0; pointer-events:none; overflow:hidden;
}
.amb-blob { position:absolute; border-radius:50%; filter:blur(100px); }
.amb-red    { width:700px; height:600px; top:-10%; left:-10%;   background:var(--blob-green); }
.amb-blue   { width:600px; height:500px; bottom:-5%; right:-8%; background:var(--blob-blue); }
.amb-orange { width:400px; height:350px; top:45%;   left:55%;   background:var(--blob-gold); }
.amb-dark   { display:none; }
body>*:not(.ambient-layer) { position:relative; z-index:1; }

/* ===== SCROLL REVEAL ===== */
.reveal,.reveal-left,.reveal-right,.reveal-scale {
  opacity:0; transition:opacity .7s var(--ease), transform .7s var(--ease);
}
.reveal       { transform:translateY(28px); }
.reveal-left  { transform:translateX(-32px); }
.reveal-right { transform:translateX(32px); }
.reveal-scale { transform:scale(.95); }
.reveal.visible,.reveal-left.visible,.reveal-right.visible,.reveal-scale.visible { opacity:1; transform:none; }
.delay-1{transition-delay:.1s} .delay-2{transition-delay:.2s}
.delay-3{transition-delay:.3s} .delay-4{transition-delay:.4s}
.delay-5{transition-delay:.5s}

/* ===== BUTTONS ===== */
.btn {
  display:inline-flex; align-items:center; gap:9px;
  padding:13px 28px; border-radius:var(--r-full);
  font-family:var(--font-body); font-weight:700; font-size:.9rem;
  cursor:pointer; border:2px solid transparent;
  transition:all .28s var(--ease); letter-spacing:.01em; white-space:nowrap;
}
.btn-primary {
  background:linear-gradient(135deg,var(--green) 0%,var(--green-dk) 100%);
  color:#fff;
  box-shadow:0 4px 20px var(--green-glow);
}
.btn-primary:hover {
  transform:translateY(-3px);
  box-shadow:0 8px 36px var(--green-glow);
  filter:brightness(1.08);
}
.btn-outline {
  background:rgba(255,255,255,.8);
  color:var(--green-dk); border-color:var(--green);
  backdrop-filter:blur(10px);
}
.btn-outline:hover {
  background:var(--green); color:#fff;
  transform:translateY(-3px); box-shadow:0 6px 24px var(--green-glow);
}
.btn-ghost { background:transparent; color:var(--green); border-color:var(--green); }
.btn-ghost:hover { background:var(--green-lt); transform:translateY(-2px); }
.btn-full { width:100%; justify-content:center; border-radius:var(--r-md); }

/* ===== NAVBAR ===== */
.navbar {
  position:fixed; top:0; left:0; right:0; z-index:900;
  padding:16px 0; transition:all .4s var(--ease);
}
.navbar.scrolled {
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(24px) saturate(180%);
  padding:10px 0;
  border-bottom:1px solid var(--border);
  box-shadow:var(--shadow-sm);
}
.nav-container {
  max-width:1200px; margin:0 auto; padding:0 28px;
  display:flex; align-items:center; justify-content:space-between;
}
.nav-logo { display:flex; align-items:center; gap:11px; }
.logo-img {
  width:44px; height:44px; border-radius:10px;
  object-fit:cover; flex-shrink:0;
  box-shadow:var(--shadow-sm);
}
.logo-main {
  display:block; font-family:var(--font-head); font-weight:700;
  color:var(--text); font-size:.95rem; letter-spacing:.02em; line-height:1.2;
}
.logo-sub {
  display:block; color:var(--text-3); font-size:.65rem;
  letter-spacing:.09em; text-transform:uppercase; margin-top:1px;
}
.nav-menu { display:flex; align-items:center; gap:2px; }
.nav-link {
  color:var(--text-2); font-size:.83rem; font-weight:600;
  padding:7px 13px; border-radius:var(--r-sm);
  transition:all .2s; letter-spacing:.01em;
}
.nav-link:hover { color:var(--green); background:var(--green-lt); }
.nav-link.active { color:var(--green); background:var(--green-lt); }
.hamburger { display:none; flex-direction:column; gap:5px; cursor:pointer; z-index:1001; }
.hamburger span { display:block; width:24px; height:2px; background:var(--text); border-radius:2px; transition:all .3s; }
.hamburger.open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity:0; transform:scaleX(0); }
.hamburger.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

/* ===== HERO ===== */
.hero {
  position:relative; min-height:100vh;
  display:flex; align-items:center; justify-content:center;
  overflow:hidden;
  background:linear-gradient(160deg, #e8f5ee 0%, #f0f7ff 40%, #fff8ee 100%);
}
.hero-bg {
  position:absolute; inset:0;
  background:
    radial-gradient(ellipse 900px 700px at 0%   20%, rgba(22,163,74,.14)  0%,transparent 65%),
    radial-gradient(ellipse 700px 600px at 100% 80%, rgba(37,99,235,.1)   0%,transparent 65%),
    radial-gradient(ellipse 600px 500px at 80%  5%,  rgba(217,119,6,.12)  0%,transparent 65%),
    radial-gradient(ellipse 500px 400px at 10%  90%, rgba(37,99,235,.08)  0%,transparent 65%);
}
.hero-pattern {
  position:absolute; inset:0; opacity:.045; z-index:1;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='100' height='100' viewBox='0 0 100 100'%3E%3Cg fill='none' stroke='%2316a34a' stroke-width='0.6'%3E%3Cpolygon points='50,6 61,28 85,28 66,42 73,65 50,52 27,65 34,42 15,28 39,28'/%3E%3Ccircle cx='50' cy='50' r='6'/%3E%3C/g%3E%3C/svg%3E");
  background-size:100px 100px;
}
.hero-orb { position:absolute; border-radius:50%; filter:blur(90px); pointer-events:none; z-index:1; }
.hero-orb-1 { width:700px; height:600px; top:-150px; left:-100px; background:rgba(22,163,74,.18); }
.hero-orb-2 { width:600px; height:500px; bottom:-100px; right:-80px; background:rgba(37,99,235,.14); }

.hero-content {
  position:relative; z-index:3; text-align:center;
  padding:130px 28px 80px; max-width:920px;
}
.hero-badge {
  display:inline-flex; align-items:center; gap:8px;
  background:rgba(22,163,74,.1); border:1px solid rgba(22,163,74,.3);
  color:var(--green-dk); padding:7px 20px; border-radius:var(--r-full);
  font-size:.73rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase;
  margin-bottom:24px; animation:fadeDown .9s var(--ease) both;
}
.hero-badge::before,.hero-badge::after { content:'✦'; font-size:.5rem; color:var(--green); }
.hero-eyebrow {
  font-family:var(--font-body); font-style:italic; font-weight:400;
  color:var(--text-3); font-size:1.05rem; margin-bottom:10px;
  animation:fadeUp 1s var(--ease) .1s both;
}
.hero-title {
  font-family:var(--font-head);
  font-size:clamp(2.6rem,6vw,5rem);
  font-weight:800; color:var(--text);
  line-height:1.06; letter-spacing:-.03em; margin-bottom:8px;
  animation:fadeUp 1s var(--ease) .2s both;
}
.hero-title .highlight {
  background:linear-gradient(135deg,var(--green) 0%,var(--blue) 60%,var(--gold) 100%);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
  display:block;
}
.hero-arabic {
  font-family:var(--font-arab); font-size:clamp(1.3rem,2.5vw,2rem);
  color:rgba(217,119,6,.55); direction:rtl; margin:12px 0 22px;
  animation:fadeUp 1s var(--ease) .3s both;
}
.hero-desc {
  color:var(--text-2); font-size:1.05rem; line-height:1.9;
  max-width:580px; margin:0 auto 40px;
  animation:fadeUp 1s var(--ease) .4s both;
}
.hero-cta {
  display:flex; gap:14px; justify-content:center; flex-wrap:wrap;
  margin-bottom:56px; animation:fadeUp 1s var(--ease) .5s both;
}
/* Stat cards */
.hero-stats {
  display:inline-grid; grid-template-columns:repeat(3,1fr);
  background:rgba(255,255,255,.7);
  border:1px solid var(--border);
  backdrop-filter:blur(20px);
  border-radius:var(--r-lg); overflow:hidden;
  box-shadow:var(--shadow-md);
  animation:fadeUp 1s var(--ease) .6s both;
}
.stat-item { padding:22px 34px; text-align:center; position:relative; transition:background .25s; }
.stat-item:hover { background:rgba(22,163,74,.06); }
.stat-item+.stat-item::before {
  content:''; position:absolute; left:0; top:20%; bottom:20%;
  width:1px; background:var(--border);
}
.stat-num {
  display:block; font-family:var(--font-head); font-size:2.4rem; font-weight:800;
  background:linear-gradient(135deg,var(--green),var(--blue));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
  line-height:1;
}
.stat-label {
  display:block; color:var(--text-3); font-size:.72rem;
  letter-spacing:.07em; text-transform:uppercase; margin-top:5px; font-weight:600;
}
.stat-divider { display:none; }
.hero-scroll { position:absolute; bottom:30px; left:50%; transform:translateX(-50%); z-index:3; }
.scroll-arrow {
  width:42px; height:42px; border-radius:50%;
  border:2px solid rgba(22,163,74,.35);
  display:flex; align-items:center; justify-content:center;
  color:var(--green); background:rgba(255,255,255,.7); backdrop-filter:blur(8px);
  animation:scrollBounce 2.5s ease-in-out infinite; transition:all .3s;
}
.scroll-arrow:hover { background:var(--green); color:#fff; border-color:var(--green); }

@keyframes scrollBounce { 0%,100%{transform:translateY(0)} 50%{transform:translateY(10px)} }
@keyframes fadeUp   { from{opacity:0;transform:translateY(28px)} to{opacity:1;transform:none} }
@keyframes fadeDown { from{opacity:0;transform:translateY(-16px)} to{opacity:1;transform:none} }
@keyframes pulse    { 0%,100%{box-shadow:0 0 0 0 rgba(22,163,74,.4)} 60%{box-shadow:0 0 0 10px rgba(22,163,74,0)} }

/* ===== PENGUMUMAN ===== */
.pengumuman-bar {
  background:var(--green);
  border:none; padding:10px 0; overflow:hidden;
}
.pengumuman-inner { display:flex; align-items:stretch; }
.pengumuman-label {
  background:var(--green-dk);
  color:#fff; padding:0 22px; font-size:.72rem; font-weight:800;
  letter-spacing:.1em; text-transform:uppercase; white-space:nowrap;
  display:flex; align-items:center; gap:7px; flex-shrink:0;
  font-family:var(--font-head);
}
.ticker-wrap { overflow:hidden; flex:1; display:flex; align-items:center; padding:4px 0; }
.ticker {
  display:inline-block; white-space:nowrap;
  color:rgba(255,255,255,.92); font-size:.84rem; font-weight:600;
  padding-left:100%; animation:ticker 35s linear infinite;
}
@keyframes ticker { from{transform:translateX(0)} to{transform:translateX(-100%)} }

/* ===== SECTION BASE ===== */
.section { padding:96px 0; }
.section-header { text-align:center; margin-bottom:60px; }
.section-tag {
  display:inline-block;
  background:var(--green-lt); border:1px solid rgba(22,163,74,.25);
  color:var(--green-dk); padding:5px 18px; border-radius:var(--r-full);
  font-size:.72rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase;
  margin-bottom:14px;
}
.section-title {
  font-family:var(--font-head); font-size:clamp(1.9rem,3.5vw,3rem);
  font-weight:800; color:var(--text); line-height:1.1;
  letter-spacing:-.03em; margin-bottom:14px;
}
.section-divider {
  width:48px; height:3px; margin:0 auto 16px; border-radius:2px;
  background:linear-gradient(90deg,var(--green),var(--blue));
}
.section-desc { color:var(--text-3); font-size:1rem; max-width:540px; margin:0 auto; line-height:1.85; }

/* Section backgrounds */
.profil      { background:var(--bg); }
.program     { background:var(--bg-2); }
.persyaratan { background:var(--bg-3); }
.jadwal      { background:var(--bg); }
.biaya       { background:var(--bg-2); }
.kontak      { background:var(--bg-3); }

/* ===== PROFIL ===== */
.profil { position:relative; overflow:hidden; }
.profil-grid { display:grid; grid-template-columns:1fr 1.35fr; gap:72px; align-items:center; margin-bottom:72px; }

.profil-image { position:relative; }
.image-card {
  border-radius:var(--r-xl); overflow:hidden; position:relative;
  height:480px; background:#e8f5ee;
  border:1px solid var(--border-md);
  box-shadow:var(--shadow-xl);
}
.kiai-photo {
  width:100%; height:100%; object-fit:cover; object-position:center top;
  position:absolute; inset:0; transition:transform .6s var(--ease);
}
.image-card:hover .kiai-photo { transform:scale(1.04); }
.kiai-label {
  position:absolute; bottom:0; left:0; right:0; z-index:2;
  background:linear-gradient(to top, rgba(15,122,56,.95) 0%, rgba(15,122,56,.7) 55%, transparent 100%);
  padding:52px 28px 28px;
}
.kiai-title {
  display:block; font-size:.7rem; font-weight:700;
  letter-spacing:.12em; text-transform:uppercase; color:rgba(255,255,255,.8); margin-bottom:5px;
}
.kiai-name {
  display:block; font-family:var(--font-head); font-size:1.2rem;
  font-weight:700; color:#fff; letter-spacing:.01em;
}

.profil-content h3 {
  font-family:var(--font-head); font-size:1.8rem; font-weight:800;
  color:var(--text); margin-bottom:18px; line-height:1.2; letter-spacing:-.02em;
}
.profil-content p { color:var(--text-2); line-height:1.9; margin-bottom:16px; font-size:.96rem; }
.profil-visi { display:flex; flex-direction:column; gap:12px; margin-top:28px; }
.visi-item {
  display:flex; gap:16px; align-items:flex-start;
  background:#fff; padding:18px 20px; border-radius:var(--r-md);
  border:1px solid var(--border); border-left:3px solid var(--green);
  box-shadow:var(--shadow-sm); transition:all .3s var(--ease);
}
.visi-item:hover { box-shadow:var(--shadow-md); transform:translateX(5px); }
.visi-icon {
  width:38px; height:38px; border-radius:var(--r-sm); flex-shrink:0;
  background:var(--green-lt); display:flex; align-items:center; justify-content:center; color:var(--green-dk);
}
.visi-item strong { display:block; font-weight:700; color:var(--text); margin-bottom:4px; font-size:.8rem; letter-spacing:.05em; text-transform:uppercase; }
.visi-item p { margin:0; font-size:.87rem; color:var(--text-3); }

.keunggulan-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; }
.keunggulan-card {
  background:#fff; border-radius:var(--r-lg); padding:30px 22px; text-align:center;
  border:1px solid var(--border); box-shadow:var(--shadow-sm);
  transition:all .35s var(--ease); position:relative; overflow:hidden;
}
.keunggulan-card:hover { transform:translateY(-8px); box-shadow:var(--shadow-lg); border-color:rgba(22,163,74,.2); }
.keung-icon {
  width:60px; height:60px; border-radius:16px; margin:0 auto 16px;
  background:linear-gradient(135deg,var(--green),var(--green-dk));
  display:flex; align-items:center; justify-content:center;
  color:#fff; font-size:1.4rem;
  box-shadow:0 4px 16px var(--green-glow);
  transition:all .35s var(--ease-spring);
}
.keunggulan-card:hover .keung-icon { transform:scale(1.12) rotate(-5deg); }
.keunggulan-card h4 { font-family:var(--font-head); font-weight:700; margin-bottom:8px; color:var(--text); font-size:.95rem; }
.keunggulan-card p { color:var(--text-3); font-size:.83rem; line-height:1.7; }

/* ===== PROGRAM ===== */
.program { position:relative; overflow:hidden; }
.program .section-tag { background:var(--blue-lt); border-color:rgba(37,99,235,.2); color:var(--blue); }
.program-grid-duo { display:grid; grid-template-columns:repeat(2,1fr); gap:20px; max-width:920px; margin:0 auto; }
.program-card {
  background:#fff; border:1px solid var(--border); border-radius:var(--r-xl);
  padding:40px 36px; position:relative; overflow:hidden;
  box-shadow:var(--shadow-sm); transition:all .35s var(--ease);
}
.program-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:4px;
  background:linear-gradient(90deg,var(--green),var(--blue));
  border-radius:var(--r-xl) var(--r-xl) 0 0;
}
.program-card:hover { transform:translateY(-8px); box-shadow:var(--shadow-xl); border-color:rgba(22,163,74,.2); }
.program-card.featured { background:linear-gradient(160deg,#f0fdf4 0%,#fff 100%); border-color:rgba(22,163,74,.25); }
.program-card.featured::before { background:linear-gradient(90deg,var(--gold),var(--green)); }
.program-badge {
  display:inline-flex; align-items:center; gap:5px;
  background:linear-gradient(135deg,var(--green),var(--green-dk));
  color:#fff; padding:4px 14px; border-radius:var(--r-full);
  font-size:.68rem; font-weight:800; letter-spacing:.1em; text-transform:uppercase; margin-bottom:20px;
}
.program-icon { font-size:2.2rem; color:var(--blue); margin-bottom:14px; }
.program-card.featured .program-icon { color:var(--green); }
.program-card h3 { font-family:var(--font-head); font-size:1.55rem; font-weight:800; color:var(--text); margin-bottom:4px; letter-spacing:-.02em; }
.program-subtitle { font-size:.74rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--blue); margin-bottom:18px; }
.program-card.featured .program-subtitle { color:var(--green-dk); }
.program-desc { font-size:.9rem; line-height:1.85; color:var(--text-3); margin-bottom:24px; }
.program-list { display:flex; flex-direction:column; gap:10px; margin-bottom:32px; }
.program-list li { display:flex; align-items:center; gap:10px; font-size:.87rem; color:var(--text-2); }
.program-list i { color:var(--green); font-size:.75rem; flex-shrink:0; }

/* ===== PERSYARATAN ===== */
.persyaratan { position:relative; overflow:hidden; }
.syarat-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-bottom:48px; }
.syarat-grid-1 { grid-template-columns:1fr; max-width:660px; margin:0 auto 48px; }
.syarat-center { text-align:center; }
.syarat-card {
  background:#fff; border:1px solid var(--border); border-radius:var(--r-lg);
  padding:32px 28px; box-shadow:var(--shadow-sm); transition:all .3s var(--ease);
}
.syarat-card:hover { box-shadow:var(--shadow-lg); transform:translateY(-4px); border-color:rgba(22,163,74,.2); }
.syarat-header { display:flex; align-items:center; gap:14px; margin-bottom:22px; padding-bottom:16px; border-bottom:1px solid var(--border); }
.syarat-num { font-family:var(--font-head); font-size:2.2rem; font-weight:800; color:var(--green); opacity:.25; line-height:1; }
.syarat-header h3 { font-family:var(--font-head); font-size:.92rem; font-weight:700; color:var(--text); }
.syarat-list { display:flex; flex-direction:column; gap:13px; }
.syarat-list-inline { display:grid; grid-template-columns:1fr 1fr; gap:13px; }
.syarat-list li { display:flex; align-items:flex-start; gap:12px; }
.syarat-list i { color:var(--green); margin-top:3px; font-size:.85rem; flex-shrink:0; }
.syarat-list span { font-size:.87rem; color:var(--text-2); line-height:1.6; }

.alur-pendaftaran {
  background:linear-gradient(135deg,var(--green-dk) 0%,var(--green) 100%);
  border-radius:var(--r-xl); padding:48px 52px;
  box-shadow:var(--shadow-xl); position:relative; overflow:hidden;
}
.alur-pendaftaran::before {
  content:''; position:absolute; inset:0; opacity:.06;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='80' height='80' viewBox='0 0 80 80'%3E%3Cg fill='none' stroke='%23ffffff' stroke-width='0.6'%3E%3Cpolygon points='40,5 73,22 73,58 40,75 7,58 7,22'/%3E%3C/g%3E%3C/svg%3E") repeat;
  background-size:80px 80px;
}
.alur-pendaftaran h3 {
  color:#fff; font-family:var(--font-head); font-size:1.1rem; font-weight:700;
  margin-bottom:36px; display:flex; align-items:center; gap:10px; flex-wrap:wrap; position:relative;
}
.alur-steps { display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:16px; position:relative; }
.alur-step { display:flex; flex-direction:column; align-items:center; gap:12px; flex:1; min-width:90px; }
.step-circle {
  width:52px; height:52px; border-radius:50%;
  background:rgba(255,255,255,.2); border:2px solid rgba(255,255,255,.5);
  display:flex; align-items:center; justify-content:center;
  font-family:var(--font-head); font-weight:800; color:#fff; font-size:1.1rem;
  transition:transform .3s var(--ease-spring); backdrop-filter:blur(8px);
}
.alur-step:hover .step-circle { transform:scale(1.15); background:rgba(255,255,255,.35); }
.step-label { text-align:center; color:rgba(255,255,255,.9); font-size:.8rem; font-weight:600; line-height:1.45; }
.alur-arrow { color:rgba(255,255,255,.4); font-size:1rem; }
.alur-note {
  color:rgba(255,255,255,.8); font-size:.86rem; margin-top:28px;
  display:flex; align-items:flex-start; gap:9px; justify-content:center;
  padding-top:24px; border-top:1px solid rgba(255,255,255,.2); position:relative;
}
.alur-note i { color:#fde68a; flex-shrink:0; margin-top:2px; }

/* ===== JADWAL ===== */
.jadwal { position:relative; overflow:hidden; }
.jadwal-container { max-width:780px; margin:0 auto; }
.jadwal-timeline { position:relative; padding-left:48px; }
.jadwal-timeline::before {
  content:''; position:absolute; left:22px; top:8px; bottom:8px; width:2px; border-radius:2px;
  background:linear-gradient(to bottom,var(--green),var(--blue),rgba(37,99,235,.15));
}
.timeline-item { position:relative; margin-bottom:22px; }
.timeline-dot {
  position:absolute; left:-36px; top:10px;
  width:14px; height:14px; background:#fff;
  border:2.5px solid var(--border-md); border-radius:50%; transition:all .3s;
}
.timeline-item.active .timeline-dot {
  background:var(--green); border-color:var(--green);
  box-shadow:0 0 0 5px rgba(22,163,74,.15), 0 0 16px rgba(22,163,74,.3);
  animation:pulse 2.5s ease-in-out infinite;
}
.timeline-content {
  background:#fff; border:1px solid var(--border); border-radius:var(--r-md);
  padding:22px 26px; box-shadow:var(--shadow-sm); transition:all .3s var(--ease);
}
.timeline-content:hover { box-shadow:var(--shadow-md); transform:translateX(6px); border-color:rgba(22,163,74,.2); }
.timeline-item.active .timeline-content { border-color:rgba(22,163,74,.3); background:linear-gradient(135deg,#f0fdf4,#fff); }
.timeline-date { font-size:.76rem; color:var(--text-3); display:flex; align-items:center; gap:7px; margin-bottom:8px; font-weight:600; letter-spacing:.04em; }
.timeline-date i { color:var(--green); }
.timeline-content h4 { font-family:var(--font-head); font-weight:700; color:var(--text); margin-bottom:8px; font-size:1rem; }
.timeline-content p { font-size:.87rem; color:var(--text-2); line-height:1.8; margin-bottom:12px; }
.timeline-badge { display:inline-block; padding:3px 13px; border-radius:var(--r-full); font-size:.68rem; font-weight:700; letter-spacing:.06em; }
.timeline-badge.open { background:var(--green-lt); color:var(--green-dk); border:1px solid rgba(22,163,74,.25); }
.timeline-badge.upcoming { background:var(--gold-lt); color:var(--gold); border:1px solid rgba(217,119,6,.2); }

/* ===== BIAYA ===== */
.biaya { position:relative; overflow:hidden; }
.biaya-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-bottom:40px; }
.biaya-grid-2 { grid-template-columns:repeat(2,1fr); max-width:860px; margin-left:auto; margin-right:auto; }
.biaya-card {
  background:#fff; border:1px solid var(--border); border-radius:var(--r-xl);
  overflow:hidden; box-shadow:var(--shadow-sm); transition:all .35s var(--ease); position:relative;
}
.biaya-card:hover { transform:translateY(-8px); box-shadow:var(--shadow-xl); border-color:rgba(22,163,74,.2); }
.biaya-card.featured { border-color:rgba(22,163,74,.3); box-shadow:var(--shadow-md); }
.biaya-badge {
  position:absolute; top:18px; right:18px;
  background:var(--green); color:#fff;
  padding:4px 13px; border-radius:var(--r-full); font-size:.67rem; font-weight:800; letter-spacing:.08em; text-transform:uppercase;
}
.biaya-header { padding:26px 28px 22px; }
.biaya-card:not(.featured) .biaya-header { background:linear-gradient(135deg,var(--blue) 0%,#1d4ed8 100%); }
.biaya-card.featured .biaya-header { background:linear-gradient(135deg,var(--green) 0%,var(--green-dk) 100%); }
.biaya-header h3 { color:#fff; font-family:var(--font-head); font-size:1.2rem; font-weight:800; margin-bottom:6px; }
.biaya-tag { display:inline-block; background:rgba(255,255,255,.2); color:rgba(255,255,255,.9); padding:3px 12px; border-radius:var(--r-full); font-size:.7rem; font-weight:600; letter-spacing:.06em; }
.biaya-body { padding:22px 28px; }
.biaya-item { display:flex; justify-content:space-between; align-items:center; padding:10px 0; font-size:.86rem; border-bottom:1px solid var(--border); }
.biaya-item:last-of-type { border-bottom:none; }
.biaya-val { font-weight:700; color:var(--text); }
.biaya-divider { border:none; border-top:2px dashed var(--border); margin:8px 0; }
.biaya-item.total { font-weight:800; padding-top:14px; }
.biaya-item.total .biaya-val { color:var(--green-dk); font-size:1.08rem; }
.biaya-note { padding:10px 28px 20px; font-size:.76rem; color:var(--text-3); display:flex; align-items:flex-start; gap:7px; border-top:1px solid var(--border); line-height:1.5; }
.biaya-note i { color:var(--green); flex-shrink:0; margin-top:1px; }

.beasiswa-info {
  background:linear-gradient(135deg,var(--green-dk) 0%,var(--green) 100%);
  border-radius:var(--r-xl); padding:38px 44px;
  display:flex; align-items:center; gap:28px; flex-wrap:wrap;
  box-shadow:var(--shadow-xl);
}
.beasiswa-icon { font-size:2.6rem; color:#fde68a; flex-shrink:0; }
.beasiswa-content h3 { color:#fff; font-family:var(--font-head); font-weight:700; margin-bottom:8px; font-size:1.15rem; }
.beasiswa-content p { color:rgba(255,255,255,.85); font-size:.9rem; line-height:1.8; }

/* ===== KONTAK ===== */
.kontak { position:relative; overflow:hidden; }
.kontak-grid { display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:start; }
.kontak-item { display:flex; gap:16px; align-items:flex-start; margin-bottom:26px; }
.kontak-icon {
  width:46px; height:46px; border-radius:12px; flex-shrink:0;
  background:var(--green-lt); border:1px solid rgba(22,163,74,.2);
  display:flex; align-items:center; justify-content:center;
  color:var(--green-dk); font-size:1.05rem; transition:all .3s var(--ease);
}
.kontak-item:hover .kontak-icon { background:var(--green); color:#fff; border-color:transparent; transform:scale(1.08); }
.kontak-detail h4 { font-family:var(--font-head); font-weight:700; margin-bottom:5px; font-size:.87rem; color:var(--text); }
.kontak-detail p,.kontak-detail a { color:var(--text-2); font-size:.9rem; line-height:1.8; }
.kontak-detail a:hover { color:var(--green-dk); }
.sosmed-links h4 { font-family:var(--font-head); font-weight:700; margin-bottom:14px; font-size:.87rem; color:var(--text); }
.sosmed-icons { display:flex; flex-wrap:wrap; gap:10px; }
.sosmed-btn {
  display:inline-flex; align-items:center; gap:8px;
  padding:8px 16px; border-radius:var(--r-sm);
  font-size:.8rem; font-weight:600; transition:all .28s var(--ease);
  border:1px solid transparent;
}
.sosmed-btn.instagram { background:#fce7f3; color:#be185d; border-color:#fbcfe8; }
.sosmed-btn.instagram:hover { background:#ec4899; color:#fff; transform:translateY(-2px); box-shadow:0 4px 16px rgba(236,72,153,.3); }
.sosmed-btn.facebook  { background:var(--blue-lt); color:var(--blue); border-color:#bfdbfe; }
.sosmed-btn.facebook:hover  { background:var(--blue); color:#fff; transform:translateY(-2px); box-shadow:0 4px 16px var(--blue-glow); }
.sosmed-btn.whatsapp  { background:var(--green-lt); color:var(--green-dk); border-color:#bbf7d0; }
.sosmed-btn.whatsapp:hover  { background:#16a34a; color:#fff; transform:translateY(-2px); box-shadow:0 4px 16px var(--green-glow); }
.sosmed-btn.youtube   { background:var(--red-lt); color:var(--red); border-color:#fecaca; }
.sosmed-btn.youtube:hover   { background:var(--red); color:#fff; transform:translateY(-2px); box-shadow:0 4px 16px rgba(220,38,38,.3); }

.kontak-map iframe { border-radius:var(--r-xl); width:100%; height:440px; box-shadow:var(--shadow-lg); display:block; border:1px solid var(--border); }

/* ===== FOOTER ===== */
.footer { background:var(--green-dk); }
.footer-top { padding:68px 0; }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1.6fr; gap:48px; }
.footer-brand .footer-logo { display:flex; align-items:center; gap:13px; margin-bottom:18px; }
.footer-tagline { color:rgba(255,255,255,.6); font-size:.87rem; line-height:1.9; margin-bottom:16px; }
.footer-arabic { font-family:var(--font-arab); font-size:1.4rem; color:rgba(253,230,138,.7); direction:rtl; }
.footer-links h4,.footer-contact h4 {
  font-family:var(--font-head); color:rgba(255,255,255,.9); font-weight:700;
  margin-bottom:18px; font-size:.8rem; letter-spacing:.09em; text-transform:uppercase;
}
.footer-links ul { display:flex; flex-direction:column; gap:11px; }
.footer-links a { color:rgba(255,255,255,.55); font-size:.85rem; transition:all .25s; display:inline-block; }
.footer-links a:hover { color:#fff; padding-left:6px; }
.footer-contact p { color:rgba(255,255,255,.6); font-size:.83rem; display:flex; align-items:flex-start; gap:9px; margin-bottom:11px; line-height:1.65; }
.footer-contact i { color:#fde68a; flex-shrink:0; margin-top:3px; }
.btn-wa {
  display:inline-flex; align-items:center; gap:9px;
  background:linear-gradient(135deg,#25d366,#1da84e);
  color:#fff; padding:11px 20px; border-radius:var(--r-sm);
  font-size:.83rem; font-weight:700; margin-top:12px;
  transition:all .3s var(--ease); box-shadow:0 4px 16px rgba(37,211,102,.3);
}
.btn-wa:hover { transform:translateY(-2px); box-shadow:0 8px 28px rgba(37,211,102,.45); }
.footer-bottom { border-top:1px solid rgba(255,255,255,.1); padding:20px 0; background:rgba(0,0,0,.2); }
.footer-bottom .container { display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:8px; }
.footer-bottom p { color:rgba(255,255,255,.4); font-size:.76rem; }

/* ===== BACK TO TOP ===== */
.back-to-top {
  position:fixed; bottom:28px; right:28px; z-index:899;
  width:46px; height:46px; border-radius:var(--r-md); border:2px solid rgba(22,163,74,.3);
  background:#fff; color:var(--green-dk); cursor:pointer; font-size:.95rem;
  display:flex; align-items:center; justify-content:center;
  box-shadow:var(--shadow-md);
  opacity:0; pointer-events:none;
  transform:translateY(12px) scale(.85);
  transition:all .3s var(--ease-spring);
}
.back-to-top.visible { opacity:1; pointer-events:all; transform:translateY(0) scale(1); }
.back-to-top:hover { background:var(--green); color:#fff; border-color:var(--green); transform:translateY(-4px) scale(1.08); box-shadow:0 8px 28px var(--green-glow); }

/* ===== MOBILE STICKY CTA ===== */
.sticky-cta {
  display:none; position:fixed; bottom:0; left:0; right:0; z-index:800;
  background:rgba(255,255,255,.96); backdrop-filter:blur(20px);
  border-top:2px solid var(--green); padding:14px 24px; gap:12px;
  justify-content:space-between; align-items:center;
  box-shadow:0 -4px 24px rgba(0,0,0,.1);
}
.sticky-cta-text { color:var(--text-2); font-size:.82rem; }
.sticky-cta-text strong { color:var(--green-dk); display:block; font-size:.9rem; }

/* ===== RESPONSIVE ===== */
@media(max-width:1024px){
  .profil-grid{grid-template-columns:1fr;gap:48px}
  .keunggulan-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr;gap:36px}
}
@media(max-width:768px){
  .nav-menu{
    display:none;position:fixed;inset:0;z-index:999;
    background:rgba(255,255,255,.97);backdrop-filter:blur(24px);
    flex-direction:column;justify-content:center;align-items:center;gap:20px;
  }
  .nav-menu.open{display:flex}
  .nav-link{font-size:1.1rem;padding:10px 24px;color:var(--text)}
  .hamburger{display:flex}
  .hamburger span{background:var(--text)}
  .hero-stats{grid-template-columns:1fr;width:100%;max-width:280px;margin:0 auto}
  .stat-item+.stat-item::before{width:60%;height:1px;top:0;left:20%;bottom:auto}
  .program-grid-duo,.syarat-grid,.biaya-grid,.biaya-grid-2,.kontak-grid{grid-template-columns:1fr}
  .syarat-list-inline{grid-template-columns:1fr}
  .alur-steps{flex-direction:column}
  .alur-arrow{transform:rotate(90deg)}
  .alur-pendaftaran{padding:30px 22px}
  .beasiswa-info{flex-direction:column;text-align:center;padding:30px 24px}
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom .container{flex-direction:column;text-align:center}
  .section{padding:68px 0}
  .hero{background:linear-gradient(160deg,#e8f5ee 0%,#f0f7ff 100%)}
  .sticky-cta{display:flex}
  .back-to-top{bottom:80px}
}
@media(max-width:480px){
  .keunggulan-grid{grid-template-columns:1fr}
  .hero-cta{flex-direction:column}
  .hero-cta .btn{justify-content:center}
  .hero-title{font-size:2.1rem}
  .container{padding:0 18px}
}
