/* ================================================================
   SAPA — Clean Blue & White Design System
   Palette: Pure white + Deep blue + Sky accent + Soft grays
   Fonts: Plus Jakarta Sans (display) + Inter (body)
   ================================================================ */

@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&family=Inter:wght@400;500;600&display=swap');

/* ===== TOKENS ===== */
:root {
  /* Core Palette */
  --blue-900: #0F2044;
  --blue-800: #1A3260;
  --blue-700: #1E4080;
  --blue-600: #1D51A1;
  --blue-500: #2563EB;
  --blue-400: #3B82F6;
  --blue-300: #60A5FA;
  --blue-100: #DBEAFE;
  --blue-50:  #EFF6FF;

  --white:    #FFFFFF;
  --gray-50:  #F8FAFC;
  --gray-100: #F1F5F9;
  --gray-200: #E2E8F0;
  --gray-300: #CBD5E1;
  --gray-400: #94A3B8;
  --gray-500: #64748B;
  --gray-600: #475569;
  --gray-700: #334155;
  --gray-900: #0F172A;

  --green:    #059669;
  --green-lt: #D1FAE5;
  --red:      #DC2626;
  --red-lt:   #FEE2E2;
  --amber:    #D97706;
  --amber-lt: #FEF3C7;

  /* Gradients */
  --g-blue:   linear-gradient(135deg, #1E4080 0%, #2563EB 100%);
  --g-blue-lt:linear-gradient(135deg, #EFF6FF 0%, #DBEAFE 100%);
  --g-sky:    linear-gradient(135deg, #2563EB 0%, #60A5FA 100%);

  /* Shadows */
  --shadow-sm: 0 1px 3px rgba(15,32,68,0.06), 0 1px 2px rgba(15,32,68,0.04);
  --shadow:    0 4px 16px rgba(15,32,68,0.08), 0 2px 4px rgba(15,32,68,0.04);
  --shadow-md: 0 8px 32px rgba(15,32,68,0.10), 0 4px 8px rgba(15,32,68,0.06);
  --shadow-lg: 0 16px 48px rgba(15,32,68,0.12), 0 8px 16px rgba(15,32,68,0.06);
  --shadow-xl: 0 24px 64px rgba(15,32,68,0.14), 0 12px 24px rgba(15,32,68,0.08);
  --shadow-blue:0 8px 32px rgba(37,99,235,0.22);

  /* Geometry */
  --r:   8px;
  --r-md:12px;
  --r-lg:16px;
  --r-xl:24px;
  --r-2xl:32px;

  /* Motion */
  --ease:  cubic-bezier(0.16, 1, 0.3, 1);
  --ease-b:cubic-bezier(0.34, 1.56, 0.64, 1);
  --t:     0.3s var(--ease);
  --tf:    0.18s ease;
}

/* ===== RESET ===== */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; font-size:16px; }
body {
  font-family:'Inter', -apple-system, sans-serif;
  background:var(--white);
  color:var(--gray-700);
  line-height:1.65;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4 {
  font-family:'Plus Jakarta Sans', sans-serif;
  color:var(--gray-900);
  line-height:1.15;
  letter-spacing:-0.02em;
}
a { text-decoration:none; color:inherit; transition:var(--tf); }
img { max-width:100%; height:auto; display:block; }
ul { list-style:none; }
.container { max-width:1180px; margin:0 auto; padding:0 24px; }
::selection { background:var(--blue-100); color:var(--blue-800); }

/* ===== LOADING ===== */
.loading-screen {
  position:fixed; inset:0; background:var(--white); z-index:99999;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  transition:opacity .6s var(--ease), visibility .6s;
}
.loading-screen.hidden { opacity:0; visibility:hidden; pointer-events:none; }
.loading-logo {
  width:64px; height:64px; border-radius:18px; background:var(--g-blue);
  display:flex; align-items:center; justify-content:center;
  margin-bottom:20px; animation:ls-pulse 1.8s ease-in-out infinite;
  box-shadow:var(--shadow-blue);
}
.loading-logo img { width:44px; height:44px; object-fit:contain; filter:brightness(10); }
.loading-name {
  font-family:'Plus Jakarta Sans',sans-serif; font-size:1rem; font-weight:700;
  color:var(--gray-900); margin-bottom:24px; letter-spacing:.02em;
}
.loading-bar { width:140px; height:2px; background:var(--gray-100); border-radius:2px; overflow:hidden; margin-bottom:10px; }
.loading-bar-inner { width:0; height:100%; background:var(--g-sky); border-radius:2px; animation:ls-bar 1.6s var(--ease) forwards; }
.loading-dev { font-size:.68rem; color:var(--gray-300); letter-spacing:.1em; text-transform:uppercase; }
@keyframes ls-pulse { 0%,100%{transform:scale(1)} 50%{transform:scale(1.05)} }
@keyframes ls-bar { to{width:100%} }

/* ===== NAVBAR ===== */
.navbar {
  position:fixed; top:0; left:0; width:100%; z-index:1000;
  transition:background var(--t), box-shadow var(--t);
}
.navbar.scrolled {
  background:rgba(255,255,255,0.97);
  backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px);
  box-shadow:0 1px 0 var(--gray-200), var(--shadow-sm);
}
.navbar .container {
  display:flex; align-items:center; justify-content:space-between; height:68px;
}
.navbar-brand { display:flex; align-items:center; gap:10px; flex-shrink:0; }
.navbar-brand img { height:36px; width:36px; object-fit:contain; border-radius:9px; }
.navbar-brand span {
  font-family:'Plus Jakarta Sans',sans-serif; font-weight:800; font-size:1rem;
  color:var(--white); letter-spacing:-0.01em;
}
.navbar.scrolled .navbar-brand span { color:var(--blue-900); }
.nav-menu { display:flex; align-items:center; gap:2px; }
.nav-menu > a, .nav-menu > .dropdown > a {
  padding:8px 12px; font-size:.83rem; font-weight:500;
  color:rgba(255,255,255,0.8); border-radius:var(--r);
  display:inline-flex; align-items:center; gap:4px; white-space:nowrap;
  transition:color var(--tf), background var(--tf);
}
.navbar.scrolled .nav-menu > a,
.navbar.scrolled .nav-menu > .dropdown > a { color:var(--gray-600); }
.nav-menu > a:hover, .nav-menu > a.active,
.nav-menu > .dropdown > a:hover, .nav-menu > .dropdown > a.active { color:var(--white); background:rgba(255,255,255,0.12); }
.navbar.scrolled .nav-menu > a:hover,
.navbar.scrolled .nav-menu > a.active,
.navbar.scrolled .nav-menu > .dropdown > a:hover,
.navbar.scrolled .nav-menu > .dropdown > a.active { color:var(--blue-600); background:var(--blue-50); }
.nav-menu .dropdown { position:relative; }
.nav-menu .dropdown-menu {
  position:absolute; top:calc(100% + 10px); left:0; min-width:220px;
  background:var(--white); border-radius:var(--r-lg); box-shadow:var(--shadow-xl);
  padding:8px; opacity:0; visibility:hidden; transform:translateY(6px);
  transition:var(--t); border:1px solid var(--gray-100); z-index:200;
}
.nav-menu .dropdown:hover .dropdown-menu { opacity:1; visibility:visible; transform:translateY(0); }
.nav-menu .dropdown-menu a {
  display:block; padding:10px 14px; font-size:.83rem; border-radius:var(--r);
  color:var(--gray-600);
}
.nav-menu .dropdown-menu a:hover { background:var(--blue-50); color:var(--blue-600); }
.nav-cta {
  margin-left:12px !important; background:var(--white) !important; color:var(--blue-700) !important;
  padding:8px 18px !important; border-radius:50px !important;
  font-weight:700 !important; font-size:.81rem !important;
  box-shadow:var(--shadow-sm); transition:var(--t) !important;
}
.navbar.scrolled .nav-cta {
  background:var(--blue-500) !important; color:var(--white) !important;
  box-shadow:var(--shadow-blue) !important;
}
.nav-cta:hover { transform:translateY(-1px) !important; box-shadow:var(--shadow-blue) !important; }
.nav-toggle {
  display:none; flex-direction:column; gap:5px; cursor:pointer;
  padding:8px; border:none; background:none;
}
.nav-toggle span { width:22px; height:2px; background:var(--white); border-radius:2px; display:block; transition:var(--t); }
.navbar.scrolled .nav-toggle span { background:var(--gray-700); }

/* ===== HERO ===== */
.hero {
  min-height:100vh; position:relative; overflow:hidden;
  display:flex; align-items:center; padding:100px 0 80px;
  background:var(--blue-900);
}
.hero-bg {
  position:absolute; inset:0; z-index:0;
  background:linear-gradient(135deg, #0F2044 0%, #1A3260 45%, #1D51A1 100%);
}
.hero-bg::before {
  content:''; position:absolute; inset:0;
  background-image:
    radial-gradient(circle at 70% 30%, rgba(96,165,250,0.12) 0%, transparent 50%),
    radial-gradient(circle at 20% 80%, rgba(37,99,235,0.15) 0%, transparent 45%);
}
/* Subtle grid pattern */
.hero-bg::after {
  content:''; position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,0.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.025) 1px, transparent 1px);
  background-size:60px 60px;
  mask-image:linear-gradient(to bottom, transparent 0%, black 20%, black 80%, transparent 100%);
}
.hero .container { position:relative; z-index:2; }
.hero-grid { display:grid; grid-template-columns:1fr 460px; gap:80px; align-items:center; }

/* Left */
.hero-badge {
  display:inline-flex; align-items:center; gap:8px; margin-bottom:24px;
  background:rgba(255,255,255,0.08); border:1px solid rgba(255,255,255,0.15);
  color:var(--blue-300); padding:7px 16px; border-radius:50px;
  font-size:.75rem; font-weight:600; letter-spacing:.08em; text-transform:uppercase;
}
.hero-badge i { font-size:.8rem; }
.hero h1 {
  font-size:clamp(2.2rem,4.5vw,3.6rem); color:var(--white); font-weight:800;
  line-height:1.08; margin-bottom:22px; letter-spacing:-0.03em;
}
.hero h1 span { color:var(--blue-300); }
.hero-desc {
  font-size:1.05rem; color:rgba(255,255,255,0.6); line-height:1.8;
  margin-bottom:40px; max-width:480px;
}
.hero-ctas { display:flex; gap:12px; flex-wrap:wrap; margin-bottom:48px; }

/* Hotline pill */
.hero-hotline {
  display:inline-flex; align-items:center; gap:0;
  background:rgba(255,255,255,0.06); border:1px solid rgba(255,255,255,0.1);
  border-radius:50px; overflow:hidden; backdrop-filter:blur(10px);
}
.hero-hotline-label {
  padding:10px 16px; font-size:.72rem; font-weight:700; letter-spacing:.08em;
  text-transform:uppercase; color:rgba(255,255,255,0.4); border-right:1px solid rgba(255,255,255,0.1);
}
.hero-hotline-num {
  padding:10px 16px; font-family:'Plus Jakarta Sans',sans-serif;
  font-size:.92rem; font-weight:700; color:var(--white);
}
.hero-hotline-wa {
  padding:10px 18px; background:rgba(74,222,128,0.1); border-left:1px solid rgba(255,255,255,0.08);
  display:flex; align-items:center; gap:5px; font-size:.78rem; font-weight:700;
  color:#4ade80; transition:var(--tf);
}
.hero-hotline-wa:hover { background:rgba(74,222,128,0.18); color:#4ade80; }

/* Right card */
.hero-card {
  background:rgba(255,255,255,0.06); border:1px solid rgba(255,255,255,0.12);
  border-radius:var(--r-2xl); padding:32px; backdrop-filter:blur(16px);
  position:relative; overflow:hidden;
}
.hero-card::before {
  content:''; position:absolute; top:-60px; right:-60px;
  width:200px; height:200px; border-radius:50%;
  background:radial-gradient(circle, rgba(96,165,250,0.15) 0%, transparent 70%);
}
.hero-card-head {
  display:flex; align-items:center; gap:14px; padding-bottom:20px;
  border-bottom:1px solid rgba(255,255,255,0.08); margin-bottom:22px;
}
.hero-card-icon {
  width:52px; height:52px; border-radius:14px; background:var(--g-sky);
  display:flex; align-items:center; justify-content:center;
  font-size:1.4rem; color:var(--white); box-shadow:var(--shadow-blue); flex-shrink:0;
}
.hero-card-head h3 { font-size:.95rem; color:var(--white); margin-bottom:3px; font-weight:700; }
.hero-card-head p { font-size:.75rem; color:rgba(255,255,255,0.35); }
.hero-stats-grid { display:grid; grid-template-columns:1fr 1fr; gap:10px; margin-bottom:18px; }
.hero-stat {
  background:rgba(255,255,255,0.05); border:1px solid rgba(255,255,255,0.08);
  border-radius:var(--r-lg); padding:14px; text-align:center; transition:var(--tf);
}
.hero-stat:hover { background:rgba(255,255,255,0.09); }
.hero-stat .n {
  font-family:'Plus Jakarta Sans',sans-serif; font-size:1.75rem; font-weight:800;
  color:var(--white); line-height:1; margin-bottom:4px; letter-spacing:-0.02em;
}
.hero-stat.accent .n { color:var(--blue-300); }
.hero-stat .l { font-size:.69rem; color:rgba(255,255,255,0.35); font-weight:500; text-transform:uppercase; letter-spacing:.06em; }
.hero-tags { display:flex; gap:7px; flex-wrap:wrap; }
.hero-tag {
  padding:5px 12px; border-radius:50px; font-size:.71rem; font-weight:600;
  background:rgba(255,255,255,0.06); border:1px solid rgba(255,255,255,0.1); color:rgba(255,255,255,0.5);
}
.hero-tag.on { background:rgba(96,165,250,0.12); border-color:rgba(96,165,250,0.25); color:var(--blue-300); }

/* ===== BUTTONS ===== */
.btn {
  display:inline-flex; align-items:center; gap:8px;
  padding:11px 24px; border-radius:50px; font-weight:600;
  font-size:.86rem; border:none; cursor:pointer; transition:var(--t);
  font-family:'Plus Jakarta Sans',sans-serif; white-space:nowrap;
  line-height:1.4; justify-content:center; letter-spacing:-.01em;
}
.btn-primary { background:var(--g-sky); color:var(--white); box-shadow:var(--shadow-blue); }
.btn-primary:hover { transform:translateY(-2px); box-shadow:0 12px 36px rgba(37,99,235,0.3); }
.btn-white { background:var(--white); color:var(--blue-700); box-shadow:var(--shadow); }
.btn-white:hover { background:var(--blue-50); transform:translateY(-1px); }
.btn-outline-w { background:transparent; color:rgba(255,255,255,0.8); border:1.5px solid rgba(255,255,255,0.3); }
.btn-outline-w:hover { background:rgba(255,255,255,0.08); color:var(--white); border-color:rgba(255,255,255,0.6); }
.btn-outline { background:transparent; color:var(--blue-600); border:1.5px solid var(--blue-200); }
.btn-outline:hover { background:var(--blue-600); color:var(--white); border-color:var(--blue-600); }
.btn-ghost { background:var(--gray-100); color:var(--gray-700); }
.btn-ghost:hover { background:var(--gray-200); }
.btn-sm  { padding:7px 16px; font-size:.79rem; }
.btn-lg  { padding:14px 32px; font-size:.94rem; }
.btn-block { width:100%; }
/* Status */
.btn-danger  { background:#EF4444; color:#fff; }
.btn-danger:hover  { background:#DC2626; }
.btn-warning { background:#F59E0B; color:#fff; }
.btn-success { background:#10B981; color:#fff; }
.btn-info    { background:#3B82F6; color:#fff; }
.btn-secondary { background:#94A3B8; color:#fff; }

/* ===== SECTION ===== */
.section { padding:96px 0; }
.section-sm { padding:60px 0; }
.bg-white  { background:var(--white); }
.bg-gray   { background:var(--gray-50); }
.bg-blue-lt{ background:var(--blue-50); }
.bg-blue   { background:var(--blue-900); }

/* Section Header */
.s-eye {
  display:inline-flex; align-items:center; gap:8px; margin-bottom:12px;
  font-size:.7rem; font-weight:700; letter-spacing:.14em; text-transform:uppercase;
  color:var(--blue-500);
}
.s-eye::before { content:''; display:block; width:16px; height:2px; background:var(--blue-400); border-radius:2px; }
.s-title {
  font-size:clamp(1.75rem,3vw,2.5rem); font-weight:800; line-height:1.1;
  letter-spacing:-0.03em; margin-bottom:14px; color:var(--gray-900);
}
.s-title.white { color:var(--white); }
.s-sub { font-size:.97rem; color:var(--gray-500); line-height:1.8; max-width:500px; }
.s-sub.white { color:rgba(255,255,255,0.55); }
.s-hdr { margin-bottom:48px; }
.s-hdr.center { text-align:center; }
.s-hdr.center .s-eye { justify-content:center; }
.s-hdr.center .s-sub { margin:0 auto; }
.s-hdr.split { display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:end; }

/* ===== STATS BAND ===== */
.stats-band { background:var(--white); border-top:1px solid var(--gray-100); border-bottom:1px solid var(--gray-100); }
.stats-row  { display:grid; grid-template-columns:repeat(4,1fr); }
.stat-cell {
  padding:36px 28px; text-align:center; border-right:1px solid var(--gray-100);
  transition:background var(--tf);
}
.stat-cell:last-child { border-right:none; }
.stat-cell:hover { background:var(--blue-50); }
.stat-ico { font-size:1.2rem; color:var(--blue-400); margin-bottom:10px; display:block; }
.stat-num {
  font-family:'Plus Jakarta Sans',sans-serif; font-size:2.6rem; font-weight:800;
  color:var(--blue-700); line-height:1; margin-bottom:5px; letter-spacing:-0.03em;
}
.stat-lbl { font-size:.75rem; color:var(--gray-400); font-weight:600; text-transform:uppercase; letter-spacing:.05em; }

/* ===== SERVICE CARDS ===== */
.svc-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:16px; }
.svc-card {
  background:var(--white); border:1.5px solid var(--gray-100); border-radius:var(--r-xl);
  padding:28px 28px; display:flex; gap:20px; align-items:flex-start;
  transition:var(--t); cursor:default;
}
.svc-card:hover { box-shadow:var(--shadow-lg); transform:translateY(-4px); border-color:var(--blue-100); }
.svc-ico {
  width:50px; height:50px; border-radius:14px; flex-shrink:0;
  display:flex; align-items:center; justify-content:center; font-size:1.3rem;
}
.svc-ico.bl  { background:var(--blue-50);  color:var(--blue-500); }
.svc-ico.sky { background:#F0F9FF; color:#0284C7; }
.svc-ico.grn { background:#F0FDF4; color:var(--green); }
.svc-ico.ind { background:#EEF2FF; color:#6366F1; }
.svc-body h3 { font-size:.98rem; font-weight:700; margin-bottom:7px; color:var(--gray-900); }
.svc-body p  { font-size:.83rem; color:var(--gray-500); line-height:1.75; margin-bottom:12px; }
.svc-link {
  font-size:.78rem; font-weight:700; color:var(--blue-500);
  display:inline-flex; align-items:center; gap:5px; transition:gap var(--tf);
}
.svc-link:hover { gap:9px; }

/* ===== PROGRAM CARDS ===== */
.prog-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.prog-card {
  background:var(--white); border-radius:var(--r-xl); overflow:hidden;
  border:1.5px solid var(--gray-100); transition:var(--t);
}
.prog-card:hover { box-shadow:var(--shadow-lg); transform:translateY(-4px); border-color:var(--blue-100); }
.prog-img { position:relative; height:186px; overflow:hidden; background:var(--blue-50); }
.prog-img img { width:100%; height:100%; object-fit:cover; transition:transform .6s var(--ease); }
.prog-card:hover .prog-img img { transform:scale(1.06); }
.prog-img-ph { width:100%; height:100%; display:flex; align-items:center; justify-content:center; font-size:2.5rem; color:var(--blue-200); }
.prog-body { padding:22px; }
.prog-tag {
  display:inline-block; padding:3px 10px; border-radius:50px; margin-bottom:9px;
  font-size:.68rem; font-weight:700; letter-spacing:.06em; text-transform:uppercase;
  background:var(--blue-50); color:var(--blue-600);
}
.prog-body h3 { font-size:.95rem; font-weight:700; margin-bottom:7px; color:var(--gray-900); line-height:1.4; }
.prog-body p  { font-size:.82rem; color:var(--gray-500); line-height:1.7; margin-bottom:12px; }

/* ===== GALLERY ===== */
.gal-grid {
  display:grid; gap:12px;
  grid-template-columns:repeat(3,1fr);
  grid-template-rows:255px 255px;
}
.gal-item { border-radius:var(--r-xl); overflow:hidden; position:relative; cursor:pointer; }
.gal-item:first-child { grid-row:span 2; }
.gal-item img { width:100%; height:100%; object-fit:cover; transition:transform .6s var(--ease); display:block; }
.gal-item:hover img { transform:scale(1.06); }
.gal-ov {
  position:absolute; inset:0;
  background:linear-gradient(to top, rgba(15,32,68,.82) 0%, rgba(15,32,68,.08) 50%, transparent 100%);
  opacity:1; transition:background .3s; display:flex; align-items:flex-end; padding:18px;
}
.gal-item:hover .gal-ov { background:linear-gradient(to top, rgba(15,32,68,.92) 0%, rgba(15,32,68,.2) 55%, transparent 100%); }
.gal-ov span { color:var(--white); font-size:.84rem; font-weight:600; text-shadow:0 1px 4px rgba(0,0,0,.5); }

/* ===== NEWS ===== */
.news-grid { display:grid; grid-template-columns:1.6fr 1fr 1fr; gap:20px; }
.news-card {
  background:var(--white); border-radius:var(--r-xl); overflow:hidden;
  border:1.5px solid var(--gray-100); transition:var(--t); display:flex; flex-direction:column;
}
.news-card:hover { box-shadow:var(--shadow-lg); transform:translateY(-4px); border-color:var(--blue-100); }
.news-card.feat { grid-row:span 2; }
.news-img-w { overflow:hidden; background:var(--blue-50); }
.news-img-w img { width:100%; height:200px; object-fit:cover; transition:transform .6s var(--ease); display:block; }
.news-card.feat .news-img-w img { height:280px; }
.news-card:hover .news-img-w img { transform:scale(1.04); }
.news-img-ph { width:100%; height:200px; display:flex; align-items:center; justify-content:center; font-size:2rem; color:var(--blue-200); }
.news-bd { padding:22px; flex:1; display:flex; flex-direction:column; }
.news-meta { display:flex; align-items:center; gap:8px; margin-bottom:9px; flex-wrap:wrap; }
.news-tag { font-size:.68rem; font-weight:700; color:var(--blue-600); background:var(--blue-50); padding:3px 9px; border-radius:50px; letter-spacing:.04em; text-transform:uppercase; }
.news-date { font-size:.73rem; color:var(--gray-400); }
.news-bd h3 { font-size:.92rem; font-weight:700; line-height:1.45; margin-bottom:7px; color:var(--gray-900); flex:1; }
.news-card.feat .news-bd h3 { font-size:1.1rem; }
.news-bd p  { font-size:.82rem; color:var(--gray-500); margin-bottom:12px; line-height:1.7; }
.news-lnk  { font-size:.78rem; font-weight:700; color:var(--blue-500); display:inline-flex; align-items:center; gap:5px; margin-top:auto; transition:gap var(--tf); }
.news-lnk:hover { gap:9px; }

/* ===== TEAM ===== */
.team-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(148px,1fr)); gap:14px; }
.team-card {
  background:var(--white); border-radius:var(--r-xl); padding:26px 16px;
  text-align:center; border:1.5px solid var(--gray-100); transition:var(--t);
}
.team-card:hover { box-shadow:var(--shadow-md); transform:translateY(-3px); border-color:var(--blue-100); }
.team-av {
  width:76px; height:76px; border-radius:50%; overflow:hidden;
  margin:0 auto 12px; border:2.5px solid var(--gray-100); transition:var(--t);
}
.team-card:hover .team-av { border-color:var(--blue-300); }
.team-av img { width:100%; height:100%; object-fit:cover; }
.team-card h4 { font-size:.85rem; font-weight:700; margin-bottom:3px; color:var(--gray-900); }
.team-card span { font-size:.73rem; color:var(--blue-500); font-weight:600; }

/* ===== MITRA ===== */
.mitra-row { display:flex; flex-wrap:wrap; gap:12px; justify-content:center; }
.mitra-chip {
  background:var(--white); border:1.5px solid var(--gray-100); border-radius:var(--r-lg);
  padding:16px 22px; display:flex; flex-direction:column; align-items:center; gap:8px;
  min-width:136px; max-width:180px; transition:var(--t);
}
.mitra-chip:hover { box-shadow:var(--shadow-md); transform:translateY(-2px); border-color:var(--blue-100); }
.mitra-chip img { max-height:44px; max-width:110px; object-fit:contain; }
.mitra-chip span { font-size:.74rem; font-weight:600; color:var(--gray-500); text-align:center; }

/* ===== VOLUNTEER ===== */
.vol-wrap { max-width:700px; margin:0 auto; background:var(--white); border-radius:var(--r-2xl); box-shadow:var(--shadow-xl); overflow:hidden; }
.vol-head {
  background:var(--g-blue); padding:30px 40px; display:flex; align-items:center; gap:20px;
  position:relative; overflow:hidden;
}
.vol-head::after {
  content:''; position:absolute; right:-40px; top:-40px; width:180px; height:180px; border-radius:50%;
  background:radial-gradient(circle, rgba(96,165,250,0.2) 0%, transparent 70%);
}
.vol-head-ico { width:52px; height:52px; border-radius:14px; background:rgba(255,255,255,0.15); display:flex; align-items:center; justify-content:center; font-size:1.5rem; color:#fff; flex-shrink:0; position:relative; z-index:1; }
.vol-head-txt { position:relative; z-index:1; }
.vol-head h3 { font-size:1.1rem; color:var(--white); margin-bottom:3px; }
.vol-head p  { font-size:.82rem; color:rgba(255,255,255,0.6); }
.vol-body { padding:32px 40px; }
.vol-closed { text-align:center; padding:60px 36px; background:var(--gray-50); border-radius:var(--r-2xl); max-width:480px; margin:0 auto; }
.vol-closed .vc-ico { width:68px; height:68px; border-radius:18px; background:var(--blue-50); display:flex; align-items:center; justify-content:center; font-size:1.8rem; color:var(--blue-300); margin:0 auto 18px; }
.vol-closed h4 { font-size:1.05rem; font-weight:700; margin-bottom:7px; color:var(--gray-900); }
.vol-closed p  { font-size:.85rem; color:var(--gray-500); }

/* ===== MAP ===== */
.map-sec { background:var(--blue-900); padding:96px 0; }
.map-frame { border-radius:var(--r-2xl); overflow:hidden; border:1px solid rgba(255,255,255,0.08); box-shadow:0 32px 72px rgba(0,0,0,0.4); line-height:0; }
.map-frame #indexMap, .map-frame iframe { width:100%; height:440px; border:none; display:block; }
.map-bar { margin-top:16px; display:grid; grid-template-columns:repeat(3,1fr); gap:12px; }
.map-cell {
  background:rgba(255,255,255,0.05); border:1px solid rgba(255,255,255,0.07);
  border-radius:var(--r-lg); padding:16px 18px; display:flex; align-items:center; gap:12px;
  transition:background var(--tf);
}
.map-cell:hover { background:rgba(255,255,255,0.08); }
.map-cell i { font-size:1.1rem; color:var(--blue-300); width:20px; text-align:center; flex-shrink:0; }
.map-cell span { font-size:.82rem; color:rgba(255,255,255,0.55); line-height:1.5; }

/* ===== PAGE HEADER ===== */
.page-header {
  background:var(--blue-900); padding:130px 0 72px; position:relative; overflow:hidden;
}
.page-header::before {
  content:''; position:absolute; inset:0;
  background:linear-gradient(135deg, #0F2044 0%, #1A3260 45%, #1D51A1 100%);
}
.page-header::after {
  content:''; position:absolute; bottom:0; left:0; width:100%; height:72px;
  background:linear-gradient(to top, var(--white), transparent);
}
.page-header.to-gray::after  { background:linear-gradient(to top, var(--gray-50), transparent); }
.page-header.to-blue-lt::after { background:linear-gradient(to top, var(--blue-50), transparent); }
.ph-inner { text-align:center; position:relative; z-index:1; }
.ph-inner h1 { color:var(--white); font-size:2.6rem; margin-bottom:12px; }
.ph-inner p  { color:rgba(255,255,255,0.55); font-size:.97rem; }
.breadcrumb { display:flex; justify-content:center; gap:6px; margin-top:14px; flex-wrap:wrap; }
.breadcrumb a, .breadcrumb span { font-size:.79rem; color:rgba(255,255,255,0.4); }
.breadcrumb a:hover { color:rgba(255,255,255,0.8); }
.breadcrumb .sep { color:rgba(255,255,255,0.2); }
.breadcrumb .cur { color:var(--blue-300); }

/* ===== FORMS ===== */
.form-group { margin-bottom:17px; }
.form-group label { display:block; margin-bottom:6px; font-weight:600; font-size:.82rem; color:var(--gray-700); }
.form-control {
  width:100%; padding:11px 14px; border:1.5px solid var(--gray-200); border-radius:var(--r-md);
  font-size:.88rem; font-family:'Inter',sans-serif; background:var(--white);
  color:var(--gray-900); outline:none; transition:border-color .2s, box-shadow .2s;
}
.form-control:focus { border-color:var(--blue-400); box-shadow:0 0 0 3px rgba(59,130,246,0.12); }
textarea.form-control { min-height:110px; resize:vertical; }
select.form-control { cursor:pointer; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:14px; }

/* ===== CHATBOX ===== */
.chatbox-float { position:fixed; bottom:24px; right:24px; z-index:999; }
.chatbox-toggle {
  width:52px; height:52px; border-radius:50%; background:var(--g-sky);
  border:none; color:#fff; font-size:1.25rem; cursor:pointer;
  box-shadow:var(--shadow-blue); transition:var(--t);
  display:flex; align-items:center; justify-content:center;
}
.chatbox-toggle:hover { transform:scale(1.08); }
.chatbox-widget {
  position:absolute; bottom:64px; right:0; width:340px; height:470px;
  background:var(--white); border-radius:var(--r-2xl); box-shadow:var(--shadow-xl);
  display:none; flex-direction:column; overflow:hidden; border:1px solid var(--gray-100);
}
.chatbox-widget.active { display:flex; animation:cb-in .3s var(--ease); }
@keyframes cb-in { from{opacity:0;transform:translateY(10px) scale(0.97)} to{opacity:1;transform:none} }
.chatbox-header { background:var(--g-blue); padding:14px 18px; display:flex; align-items:center; justify-content:space-between; flex-shrink:0; }
.chatbox-header h4 { font-size:.88rem; font-weight:700; color:#fff; }
.chatbox-header .chat-expand { color:rgba(255,255,255,0.5); font-size:.9rem; text-decoration:none; }
.chatbox-messages { flex:1; overflow-y:auto; padding:14px; display:flex; flex-direction:column; gap:10px; }
.chat-msg { max-width:85%; padding:10px 13px; border-radius:14px; font-size:.83rem; line-height:1.5; word-wrap:break-word; animation:msg-in .2s var(--ease); }
.chat-msg.bot  { background:var(--gray-50); color:var(--gray-800); align-self:flex-start; border-bottom-left-radius:4px; }
.chat-msg.user { background:var(--g-sky); color:#fff; align-self:flex-end; border-bottom-right-radius:4px; }
.chatbox-input { display:flex; padding:10px; gap:8px; border-top:1px solid var(--gray-100); flex-shrink:0; }
.chatbox-input input { flex:1; padding:8px 13px; border:1.5px solid var(--gray-200); border-radius:50px; font-size:.83rem; outline:none; font-family:'Inter',sans-serif; }
.chatbox-input input:focus { border-color:var(--blue-400); }
.chatbox-input button { width:34px; height:34px; border-radius:50%; background:var(--g-sky); border:none; color:#fff; cursor:pointer; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
@keyframes msg-in { from{opacity:0;transform:translateY(4px)} to{opacity:1;transform:none} }

/* ===== FOOTER ===== */
.footer { background:var(--blue-900); color:rgba(255,255,255,0.5); padding:80px 0 0; }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:48px; margin-bottom:48px; }
.foot-brand { display:flex; align-items:center; gap:10px; margin-bottom:16px; }
.foot-brand img { height:34px; border-radius:8px; filter:brightness(10); }
.foot-brand span { font-family:'Plus Jakarta Sans',sans-serif; font-weight:800; font-size:.98rem; color:var(--white); letter-spacing:-0.01em; }
.footer h4 { font-family:'Plus Jakarta Sans',sans-serif; color:var(--white); font-size:.8rem; font-weight:700; margin-bottom:14px; letter-spacing:.07em; text-transform:uppercase; }
.footer p, .footer li a { font-size:.83rem; color:rgba(255,255,255,0.4); line-height:1.95; }
.footer li a:hover { color:var(--white); }
.foot-contact p { display:flex; align-items:flex-start; gap:10px; margin-bottom:7px; }
.foot-contact i { color:var(--blue-300); margin-top:4px; width:14px; flex-shrink:0; }
.foot-div { height:1px; background:rgba(255,255,255,0.06); margin-bottom:22px; }
.footer-bottom { display:flex; align-items:center; justify-content:space-between; padding-bottom:28px; font-size:.77rem; color:rgba(255,255,255,0.2); }
.foot-social { display:flex; gap:6px; }
.foot-social a {
  width:32px; height:32px; border-radius:8px; background:rgba(255,255,255,0.05);
  display:flex; align-items:center; justify-content:center; font-size:.8rem;
  color:rgba(255,255,255,0.35); border:1px solid rgba(255,255,255,0.07); transition:var(--tf);
}
.foot-social a:hover { background:var(--blue-500); color:#fff; border-color:var(--blue-500); }

/* ===== ALERTS ===== */
.alert { padding:13px 16px; border-radius:var(--r-md); margin-bottom:16px; font-size:.85rem; display:flex; align-items:center; gap:8px; }
.alert-success { background:#F0FDF4; color:#15803D; border:1px solid #BBF7D0; }
.alert-danger  { background:#FEF2F2; color:#991B1B; border:1px solid #FECACA; }
.alert-warning { background:#FFFBEB; color:#92400E; border:1px solid #FDE68A; }
.alert-info    { background:var(--blue-50); color:var(--blue-700); border:1px solid var(--blue-100); }

/* ===== SHARED UI ===== */
.tabs { display:flex; gap:2px; margin-bottom:22px; border-bottom:1.5px solid var(--gray-100); }
.tab-btn { padding:10px 20px; border:none; background:none; font-family:'Inter',sans-serif; font-weight:600; font-size:.82rem; color:var(--gray-400); cursor:pointer; position:relative; transition:color var(--tf); }
.tab-btn.active { color:var(--blue-600); }
.tab-btn.active::after { content:''; position:absolute; bottom:-1.5px; left:0; width:100%; height:2px; background:var(--blue-500); border-radius:2px; }
.tab-content { display:none; }
.tab-content.active { display:block; animation:msg-in .22s var(--ease); }

.modal-overlay { position:fixed; inset:0; background:rgba(15,32,68,0.55); z-index:2000; display:none; align-items:center; justify-content:center; backdrop-filter:blur(6px); }
.modal-overlay.active { display:flex; }
.modal { background:var(--white); border-radius:var(--r-2xl); width:520px; max-width:95%; max-height:90vh; overflow-y:auto; box-shadow:var(--shadow-xl); }
.modal-header { padding:20px 24px; border-bottom:1px solid var(--gray-100); display:flex; justify-content:space-between; align-items:center; }
.modal-header h3 { font-size:.98rem; font-weight:700; color:var(--gray-900); }
.modal-close { background:none; border:none; font-size:1.3rem; cursor:pointer; color:var(--gray-400); line-height:1; }
.modal-body { padding:22px; }
.modal-footer { padding:14px 22px; border-top:1px solid var(--gray-100); display:flex; justify-content:flex-end; gap:10px; }

.table-responsive { overflow-x:auto; }
table { width:100%; border-collapse:collapse; }
table th, table td { padding:11px 16px; text-align:left; border-bottom:1px solid var(--gray-100); font-size:.82rem; vertical-align:middle; }
table th { background:var(--gray-50); font-weight:700; color:var(--gray-700); font-size:.7rem; text-transform:uppercase; letter-spacing:.06em; white-space:nowrap; }
table tr:last-child td { border-bottom:none; }
table tr:hover td { background:var(--blue-50); }

.badge { display:inline-block; padding:3px 9px; border-radius:50px; font-size:.68rem; font-weight:700; }
.badge-success { background:#F0FDF4; color:#15803D; }
.badge-warning { background:#FFFBEB; color:#92400E; }
.badge-danger  { background:#FEF2F2; color:#991B1B; }
.badge-info    { background:var(--blue-50); color:var(--blue-700); }
.badge-blue    { background:var(--blue-100); color:var(--blue-700); }
.badge-purple  { background:#F5F3FF; color:#6D28D9; }

.pagination { display:flex; justify-content:center; gap:6px; margin-top:36px; }
.pagination a, .pagination span { width:36px; height:36px; display:flex; align-items:center; justify-content:center; border-radius:var(--r); font-size:.82rem; font-weight:600; border:1.5px solid var(--gray-200); color:var(--gray-500); transition:var(--tf); }
.pagination a:hover, .pagination span.active { background:var(--blue-500); color:#fff; border-color:var(--blue-500); }

/* Info card (used in pages) */
.info-card {
  background:var(--blue-50); border:1.5px solid var(--blue-100); border-radius:var(--r-xl);
  padding:24px; display:flex; gap:16px; align-items:flex-start; margin-bottom:24px;
}
.info-card i { font-size:1.4rem; color:var(--blue-500); flex-shrink:0; margin-top:2px; }
.info-card strong { font-size:.9rem; color:var(--blue-800); display:block; margin-bottom:4px; }
.info-card p { font-size:.84rem; color:var(--blue-700); line-height:1.65; }

/* Timeline (used in layanan) */
.timeline { display:flex; flex-direction:column; gap:0; }
.timeline-item { padding:16px 16px 16px 44px; position:relative; }
.timeline-item::before { content:''; position:absolute; left:16px; top:0; bottom:0; width:1.5px; background:var(--blue-100); }
.timeline-item::after { content:attr(data-step); position:absolute; left:8px; top:18px; width:18px; height:18px; background:var(--blue-500); color:#fff; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:.65rem; font-weight:800; }
.timeline-item:first-child::before { top:20px; }
.timeline-item:last-child::before { height:20px; }
.timeline-item h4 { font-size:.88rem; font-weight:700; margin-bottom:4px; color:var(--gray-900); }
.timeline-item p  { font-size:.82rem; color:var(--gray-500); line-height:1.65; }

/* Service card (layanan page) */
.service-card {
  background:var(--white); border-radius:var(--r-xl); padding:28px; text-align:center;
  border:1.5px solid var(--gray-100); transition:var(--t);
}
.service-card:hover { box-shadow:var(--shadow-lg); transform:translateY(-4px); border-color:var(--blue-100); }
.service-card .icon {
  width:56px; height:56px; border-radius:16px; background:var(--blue-50);
  display:flex; align-items:center; justify-content:center;
  font-size:1.4rem; color:var(--blue-500); margin:0 auto 16px;
}
.service-card h3 { font-size:.96rem; font-weight:700; margin-bottom:8px; color:var(--gray-900); }
.service-card p  { font-size:.83rem; color:var(--gray-500); line-height:1.7; }

/* Grid helpers */
.grid-2 { display:grid; grid-template-columns:repeat(2,1fr); gap:24px; }
.grid-3 { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }

/* Card (generic) */
.card { background:var(--white); border-radius:var(--r-xl); border:1.5px solid var(--gray-100); overflow:hidden; transition:var(--t); }
.card:hover { box-shadow:var(--shadow-md); transform:translateY(-3px); border-color:var(--blue-100); }
.card-img { width:100%; height:200px; object-fit:cover; display:block; }
.card-body { padding:22px; }
.card-body h3 { font-size:.95rem; font-weight:700; margin-bottom:8px; color:var(--gray-900); line-height:1.4; }
.card-body p  { font-size:.83rem; color:var(--gray-500); line-height:1.7; }
.card-footer { padding:14px 22px; border-top:1px solid var(--gray-100); display:flex; align-items:center; justify-content:space-between; }
.card-meta { font-size:.76rem; color:var(--gray-400); display:flex; align-items:center; gap:8px; flex-wrap:wrap; }
.card-meta i { color:var(--blue-300); }
.section-header { text-align:center; margin-bottom:48px; }
.section-header h2 { font-size:2rem; font-weight:800; margin-bottom:10px; }
.section-header p  { color:var(--gray-500); }
.section-header .badge { margin-bottom:10px; display:inline-block; }

/* ===== RESPONSIVE ===== */
@media(max-width:1100px){
  .nav-menu > a,.nav-menu > .dropdown > a { padding:7px 9px; font-size:.78rem; }
}
@media(max-width:992px){
  .nav-menu {
    position:fixed; top:68px; left:0; width:100%; background:var(--white);
    flex-direction:column; padding:16px; gap:0; box-shadow:var(--shadow-xl);
    max-height:0; overflow:hidden; transition:max-height .4s var(--ease); z-index:999;
    border-top:1px solid var(--gray-100);
  }
  .nav-menu.active { max-height:600px; overflow-y:auto; }
  .nav-menu > a,.nav-menu > .dropdown > a { padding:11px 14px; width:100%; font-size:.88rem; color:var(--gray-700); }
  .nav-menu > a:hover,.nav-menu > a.active,
  .nav-menu > .dropdown > a:hover,.nav-menu > .dropdown > a.active { color:var(--blue-600); background:var(--blue-50); }
  .nav-menu .dropdown-menu { position:static; box-shadow:none; border:none; opacity:1; visibility:visible; transform:none; padding:0 0 0 14px; background:transparent; }
  .nav-cta { margin-left:0!important; margin-top:8px; background:var(--blue-500)!important; color:#fff!important; }
  .nav-toggle { display:flex; }
  .hero-grid { grid-template-columns:1fr; gap:0; }
  .hero h1 { font-size:2.3rem; }
  .hero-card { display:none; }
  .stats-row { grid-template-columns:repeat(2,1fr); }
  .stat-cell { border-bottom:1px solid var(--gray-100); }
  .svc-grid { grid-template-columns:1fr; }
  .prog-grid { grid-template-columns:repeat(2,1fr); }
  .news-grid { grid-template-columns:1fr 1fr; }
  .news-card.feat { grid-column:span 2; }
  .footer-grid { grid-template-columns:repeat(2,1fr); }
  .map-bar { grid-template-columns:1fr; }
  .s-hdr.split { grid-template-columns:1fr; gap:14px; }
  .grid-2 { grid-template-columns:1fr; }
  .grid-3 { grid-template-columns:repeat(2,1fr); }
}
@media(max-width:768px){
  .section { padding:68px 0; }
  .hero { padding:90px 0 60px; }
  .hero h1 { font-size:2rem; }
  .gal-grid { grid-template-columns:1fr 1fr; grid-template-rows:auto; }
  .gal-item:first-child { grid-row:auto; grid-column:span 2; }
  .prog-grid { grid-template-columns:1fr; }
  .news-grid { grid-template-columns:1fr; }
  .news-card.feat { grid-column:auto; }
  .footer-grid { grid-template-columns:1fr; gap:24px; }
  .footer-bottom { flex-direction:column; gap:10px; text-align:center; }
  .form-row { grid-template-columns:1fr; }
  .vol-head { flex-direction:column; text-align:center; padding:24px; }
  .vol-body { padding:24px; }
  .chatbox-widget { width:310px; }
  .team-grid { grid-template-columns:repeat(3,1fr); }
  .grid-3 { grid-template-columns:1fr; }
  .ph-inner h1 { font-size:2rem; }
}
@media(max-width:480px){
  .hero-ctas { flex-direction:column; }
  .hero-ctas .btn { width:100%; }
  .stats-row { grid-template-columns:1fr; }
  .stat-cell { border-right:none; }
  .gal-grid { grid-template-columns:1fr; }
  .gal-item:first-child { grid-column:auto; }
  .team-grid { grid-template-columns:repeat(2,1fr); }
  .chatbox-widget { width:calc(100vw - 48px); right:-10px; }
}