/* =========================
   GDMI WEBSITE THEME (Teal PDF) v10 - FIX HEADER for 821x1280 (and all tablet widths)
   FULL FILE: Replace entire assets/css/style.css

   Fix utama:
   - Mulai lebar <= 1024px, header otomatis masuk mode HAMBURGER (bukan menu desktop).
   - Di mode hamburger, teks nama PT + slogan disembunyikan (logo saja) supaya header rapi.
   - Dropdown menu sejajar container padding.
   - Ini memastikan ukuran 821x1280 rapi.

   Requirement:
   - Header HTML harus versi hamburger (nav-toggle + nav-toggle-btn) yang sudah Anda pakai.
   ========================= */

:root{
  /* Teal palette */
  --teal-950:#062c33;
  --teal-900:#0b3c44;
  --teal-850:#0c424b;
  --teal-800:#0e4a52;
  --teal-700:#0f5b63;
  --teal-650:#126a73;
  --teal-600:#13707a;
  --teal-500:#1d8a95;

  /* Primary */
  --primary: var(--teal-650);
  --primary-2: var(--teal-700);

  /* Text */
  --ink:#0c1114;
  --muted:#3d4a52;
  --menu-ink: rgba(11,60,68,.92);

  /* Surfaces */
  --surface: rgba(255,255,255,.82);
  --border: rgba(11,60,68,.18);

  /* Effects */
  --radius:16px;
  --radius-lg:22px;
  --shadow-sm: 0 12px 32px rgba(0,0,0,.10);
  --shadow-md: 0 22px 70px rgba(0,0,0,.18);
  --ring: 0 0 0 4px rgba(29,138,149,.22);

  /* Layout */
  --max: 1120px;
  --header-h: 68px;

  /* Spacing */
  --pad-x: 56px;     /* desktop */
  --pad-x-md: 36px;  /* tablet */
  --pad-x-sm: 28px;  /* mobile/tablet hamburger */
  --pad-x-xs: 22px;  /* small phones */

  /* Typography */
  --font: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, "Noto Sans", "Helvetica Neue", sans-serif;
}

/* Base */
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--font);
  color:var(--ink);
  line-height:1.65;
  background:
    radial-gradient(1100px 520px at 18% -10%, rgba(19,112,122,.22), transparent 55%),
    radial-gradient(900px 420px at 85% -12%, rgba(29,138,149,.18), transparent 55%),
    linear-gradient(180deg, rgba(234,243,244,1) 0%, rgba(226,240,241,1) 45%, rgba(234,243,244,1) 100%);
}

a{color:inherit;text-decoration:none}
.container{max-width:var(--max);margin:0 auto;padding:0 var(--pad-x)}
.small{font-size:.97rem;color:var(--muted)}
.mini{font-size:.88rem;color:var(--muted)}

/* Badge */
.badge{
  display:inline-flex;align-items:center;gap:8px;
  padding:7px 12px;border-radius:999px;
  font-weight:850;font-size:.86rem;color:#fff;
  background:linear-gradient(135deg, rgba(15,91,99,.86), rgba(19,112,122,.72));
  border:1px solid rgba(255,255,255,.22);
  box-shadow:0 10px 30px rgba(0,0,0,.14);
}
.badge::before{
  content:"";
  width:8px;height:8px;border-radius:999px;
  background:#fff;
  box-shadow:0 0 0 3px rgba(255,255,255,.18);
}

/* Header */
header{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.76);
  backdrop-filter:saturate(170%) blur(16px);
  border-bottom:1px solid var(--border);
}
.nav{
  min-height:var(--header-h);
  display:flex;align-items:center;justify-content:space-between;
  gap:14px;padding:12px 0;
}

.brand{
  display:flex;align-items:center;gap:12px;
  min-width:0;flex:1 1 auto;
}
.brand img{height:40px;width:auto;display:block;flex:0 0 auto}
.brand > div{min-width:0}
.brand .title{
  font-weight:950;letter-spacing:.2px;font-size:1rem;line-height:1.15;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  max-width:540px;
}
.brand .sub{
  margin-top:2px;
  font-size:.86rem;
  color:rgba(11,60,68,.72);
  line-height:1.2;
  max-width:540px;
}

/* Hamburger toggle */
.nav-toggle{display:none}  /* Hidden by default */
.nav-toggle-btn{
  display:none;  /* Hidden by default */
  align-items:center;justify-content:center;
  width:44px;height:44px;border-radius:12px;
  background:rgba(255,255,255,.02);
  border:1px solid rgba(11,60,68,.08);
  box-shadow:0 1px 0 rgba(0,0,0,.03);
  cursor:pointer;
}
.nav-toggle-btn:focus{outline:none;box-shadow:var(--shadow-sm), var(--ring)}
.nav-toggle-btn span{
  width:20px;height:2px;
  background:rgba(11,60,68,.88);
  position:relative;display:block;border-radius:999px;
}
.nav-toggle-btn span::before,
.nav-toggle-btn span::after{
  content:"";position:absolute;left:0;
  width:20px;height:2px;border-radius:999px;
  background:rgba(11,60,68,.88);
}
.nav-toggle-btn span::before{top:-6px}
.nav-toggle-btn span::after{top:6px}

/* Desktop menu */
.menu{
  display:flex;
  gap:8px;
  align-items:center;
  justify-content:flex-end;
  flex:0 0 auto;
  white-space:nowrap;
}
.menu a{
  padding:9px 12px;
  border-radius:12px;
  color:var(--menu-ink);
  font-weight:780;
  font-size:.95rem;
  border:1px solid transparent;
  transition:all .18s ease;
}
.menu a:hover{
  background:rgba(19,112,122,.10);
  border-color:rgba(19,112,122,.18);
  color:rgba(11,60,68,.95);
}
.menu a.active{
  background:rgba(19,112,122,.12);
  border-color:rgba(19,112,122,.22);
  color:rgba(11,60,68,.95);
}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:11px 14px;border-radius:14px;
  font-weight:850;
  border:1px solid rgba(11,60,68,.18);
  background:var(--surface);
  transition:transform .15s ease, box-shadow .18s ease, background .18s ease, border-color .18s ease, color .18s ease;
  box-shadow:0 1px 0 rgba(0,0,0,.03);
}
.btn:hover{box-shadow:var(--shadow-sm);transform:translateY(-1px)}
.btn:focus{outline:none;box-shadow:var(--shadow-sm), var(--ring)}

.btn-primary{
  background:linear-gradient(135deg, rgba(15,91,99,.92), rgba(19,112,122,.82));
  border-color:rgba(255,255,255,.22);
  color:#fff;
}
.btn-primary:hover{
  background:linear-gradient(135deg, rgba(11,60,68,.98), rgba(15,91,99,.92));
  border-color:rgba(255,255,255,.26);
  color:#fff;
  box-shadow:var(--shadow-md);
}

/* Header CTA hover (text = menu color) */
header .menu a.btn.btn-primary{color:#fff !important}
header .menu a.btn.btn-primary:hover{
  background:rgba(255,255,255,.82) !important;
  border-color:rgba(19,112,122,.28) !important;
  color:rgba(11,60,68,.95) !important;
  box-shadow:var(--shadow-sm);
}

/* Enhanced button visibility on hero */
.hero.hero-image .btn:not(.btn-primary){
  background:rgba(255,255,255,.92);
  border-color:rgba(255,255,255,.4);
  color:var(--ink);
  box-shadow:0 2px 8px rgba(0,0,0,.15), 0 1px 3px rgba(0,0,0,.1);
}
.hero.hero-image .btn:not(.btn-primary):hover{
  background:rgba(255,255,255,.98);
  border-color:rgba(255,255,255,.6);
  box-shadow:0 4px 12px rgba(0,0,0,.2), 0 2px 4px rgba(0,0,0,.12);
}

/* Content */
.hero{padding:58px 0 36px}
.hero-grid{display:grid;grid-template-columns:1.25fr .75fr;gap:22px;align-items:stretch}
h1{font-size:2.4rem;line-height:1.16;margin:12px 0 12px;letter-spacing:-.4px}
h2{font-size:1.65rem;margin:0 0 10px;letter-spacing:-.2px}
h3{font-size:1.12rem;margin:0 0 8px}
p{margin:0 0 10px}
.hr{height:1px;background:linear-gradient(90deg, transparent, rgba(11,60,68,.18), transparent);margin:18px 0}

.card{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:18px;
  box-shadow:0 2px 0 rgba(0,0,0,.02);
}

.grid-3{display:grid;grid-template-columns:repeat(3, minmax(0,1fr));gap:14px}
.grid-2{display:grid;grid-template-columns:repeat(2, minmax(0,1fr));gap:14px}
.section{padding:34px 0}
.section.soft{
  /* background:
    radial-gradient(900px 340px at 15% 0%, rgba(19,112,122,.18), transparent 55%),
    radial-gradient(800px 320px at 85% 0%, rgba(29,138,149,.14), transparent 55%),
    rgba(255,255,255,.35); */
  border-top:1px solid rgba(11,60,68,.10);
  border-bottom:1px solid rgba(11,60,68,.10);
}
.page-title{padding:26px 0 10px}

.footer{
  padding:30px 0;
  border-top:1px solid rgba(11,60,68,.12);
  background:linear-gradient(180deg, rgba(255,255,255,.65), rgba(255,255,255,.90));
}
.footer-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:18px}

/* Hero image */
.hero.hero-image{
  position:relative;
  padding:74px 0 44px;
  border-bottom:1px solid rgba(11,60,68,.14);
  background:
    radial-gradient(900px 380px at 20% 0%, rgba(29,138,149,.28), transparent 60%),
    url("../img/hero.jpg");
  background-size:cover;
  background-position:center;
}
.hero.hero-image::before{
  content:"";position:absolute;inset:0;z-index:0;
  background:linear-gradient(180deg, rgba(11,60,68,.72) 0%, rgba(11,60,68,.52) 45%, rgba(11,60,68,.36) 100%);
  pointer-events:none;
}
.hero.hero-image::after{
  content:"";position:absolute;inset:0;z-index:0;
  background:linear-gradient(90deg, rgba(11,60,68,.52), rgba(11,60,68,.26) 55%, rgba(11,60,68,.08) 100%);
  pointer-events:none;
}
.hero.hero-image .container{position:relative;z-index:1}
.hero.hero-image .hero-content h1,
.hero.hero-image .hero-content p,
.hero.hero-image .hero-content .badge{color:#fff}
.hero.hero-image .hero-content h1{
  text-shadow:0 2px 8px rgba(0,0,0,.4), 0 1px 3px rgba(0,0,0,.3);
}
.hero.hero-image .hero-content p{
  text-shadow:0 1px 4px rgba(0,0,0,.3);
}
.hero.hero-image .hero-content .badge{
  text-shadow:0 1px 3px rgba(0,0,0,.2);
}

/* KPI Pills */
.kpi{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:8px;
}
.pill{
  display:inline-flex;
  align-items:center;
  padding:8px 14px;
  border-radius:20px;
  font-size:.88rem;
  font-weight:750;
  background:rgba(255,255,255,.18);
  border:1px solid rgba(255,255,255,.3);
  color:#fff;
  backdrop-filter:blur(8px);
  box-shadow:0 2px 8px rgba(0,0,0,.1);
  transition:all .18s ease;
}
.pill:hover{
  background:rgba(255,255,255,.28);
  border-color:rgba(255,255,255,.5);
  transform:translateY(-1px);
  box-shadow:0 4px 12px rgba(0,0,0,.15);
}

/* Project List */
.project-list{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px 24px;
  margin-top:20px;
}
.project-item{
  padding:12px 16px;
  background:linear-gradient(135deg, rgba(11,60,68,.92), rgba(15,91,99,.85));
  border:1px solid rgba(255,255,255,.15);
  border-radius:12px;
  color:#fff;
  font-size:.92rem;
  font-weight:600;
  line-height:1.4;
  transition:all .18s ease;
  box-shadow:0 2px 8px rgba(0,0,0,.12);
}
.project-item:hover{
  background:linear-gradient(135deg, rgba(15,91,99,.95), rgba(19,112,122,.88));
  border-color:rgba(255,255,255,.25);
  transform:translateY(-1px);
  box-shadow:0 4px 16px rgba(0,0,0,.18);
}

/* =========================
   RESPONSIVE
   ========================= */

/* Tablet */
@media (max-width: 980px){
  .container{padding:0 var(--pad-x-md)}
  h1{font-size:2.05rem}
  .hero-grid{grid-template-columns:1fr}
  .grid-3{grid-template-columns:1fr}
  .grid-2{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .hero.hero-image{padding:68px 0 38px}
  .kpi{justify-content:center}
  .project-list{grid-template-columns:1fr;gap:10px}
}

/* FIX: Hamburger for ALL widths <= 1024px (so 821px always clean) */
@media (max-width: 1024px){
  .container{padding:0 var(--pad-x-sm)}

  /* Hide PT name + slogan for clean header */
  .brand > div{display:flex;}
  .brand img{height:42px;}

  /* Show hamburger button */
  .nav-toggle-btn{
    display:flex;
    position:absolute;
    right:var(--pad-x-sm);
    top:50%;
    transform:translateY(-50%);
    z-index:1000;
  }

  /* Give brand room so text doesn't overlap hamburger button */
  .brand{padding-right:56px;}

  /* Allow title to wrap on mobile */
  .brand .title{
    white-space:normal;
    font-size:.88rem;
    line-height:1.2;
  }
  .brand .sub{display:none;}

  /* Make nav position:relative so absolute children are scoped */
  header .nav{
    position:relative;
    display:flex;
    align-items:center;
    justify-content:flex-start;
  }

  /* Convert menu to dropdown - hidden by default */
  .menu{
    position:absolute;
    left:0;right:0;
    top:calc(var(--header-h) + 10px);
    margin:0 var(--pad-x-sm);
    padding:12px;
    border-radius:16px;
    background:rgba(255,255,255,.96);
    border:1px solid rgba(11,60,68,.18);
    box-shadow:var(--shadow-sm);
    display:none;
    flex-direction:column;
    align-items:stretch;
    gap:6px;
    white-space:normal;
    z-index:999;
  }

  /* Show dropdown when checkbox is checked */
  .nav-toggle:checked ~ .menu{display:flex;}
}

/* Small phones */
@media (max-width: 420px){
  .container{padding:0 var(--pad-x-xs)}
  .menu{margin:0 var(--pad-x-xs)}
}

.brands{
  display:grid;
  grid-template-columns:repeat(5, minmax(0, 1fr));
  gap:14px;
  margin-top:14px;
}

.brand-card{
  background:rgba(255,255,255,.78);
  border:1px solid rgba(11,60,68,.16);
  border-radius:16px;
  padding:14px;
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:92px;
  box-shadow:0 1px 0 rgba(0,0,0,.03);
}

.brand-card img{
  max-width:100%;
  max-height:54px;
  object-fit:contain;
  filter:saturate(1.05);
}

@media (max-width: 980px){
  .brands{grid-template-columns:repeat(3, minmax(0, 1fr));}
}

@media (max-width: 600px){
  .brands{grid-template-columns:repeat(2, minmax(0, 1fr));}
  .brand-card{min-height:86px}
  .brand-card img{max-height:48px}
}
/* =========================
   FORM STYLES
   ========================= */

.cta-bar{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:16px;
}

.form{
  display:flex;
  flex-direction:column;
  gap:14px;
  margin-top:8px;
}

.form .row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
}

.form label{
  display:block;
  font-size:.85rem;
  font-weight:700;
  color:var(--muted);
  margin-bottom:5px;
  letter-spacing:.2px;
}

.form input,
.form select,
.form textarea{
  width:100%;
  padding:10px 13px;
  border-radius:10px;
  border:1px solid rgba(11,60,68,.20);
  background:rgba(255,255,255,.88);
  font-family:var(--font);
  font-size:.93rem;
  color:var(--ink);
  outline:none;
  transition:border-color .18s ease, box-shadow .18s ease;
  box-sizing:border-box;
}

.form input:focus,
.form select:focus,
.form textarea:focus{
  border-color:rgba(19,112,122,.55);
  box-shadow:0 0 0 3px rgba(29,138,149,.14);
  background:#fff;
}

.form input::placeholder,
.form textarea::placeholder{
  color:rgba(61,74,82,.45);
  font-size:.88rem;
}

.form select{
  appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%230b3c44' fill-opacity='.5' d='M1 1l5 5 5-5'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:right 12px center;
  padding-right:34px;
  cursor:pointer;
}

.form textarea{
  resize:vertical;
  min-height:90px;
  line-height:1.55;
}

.form > div > label,
.form > label{
  margin-bottom:5px;
}

/* Required star */
.form .required::after{
  content:" *";
  color:rgba(19,112,122,.8);
}

/* Section divider inside form */
.form .form-section{
  border-top:1px solid rgba(11,60,68,.10);
  padding-top:14px;
  margin-top:2px;
}

.form .form-section-title{
  font-size:.8rem;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.8px;
  color:rgba(19,112,122,.85);
  margin-bottom:12px;
}

@media (max-width: 640px){
  .form .row{grid-template-columns:1fr;}
  .cta-bar{flex-direction:column;}
  .cta-bar .btn{width:100%;justify-content:center;}
}

/* =========================
   WHATSAPP BUTTON
   ========================= */

/* WhatsApp SVG icon */
.wa-icon {
  display:inline-block;
  width:16px !important;
  height:16px !important;
  min-width:16px;
  min-height:16px;
  max-width:16px;
  max-height:16px;
  flex-shrink:0;
  vertical-align:middle;
  margin-right:6px;
  position:relative;
  top:-1px;
  overflow:hidden;
}

.btn-wa {
  background: var(--surface);
  border-color: rgba(37,211,102,.40);
  color: #128c50 !important;
  font-weight: 850;
  font-size:.95rem;
  padding:11px 14px;
  line-height:1;
}
.btn-wa:hover {
  background: rgba(37,211,102,.08);
  border-color: rgba(37,211,102,.60);
  color: #0e7040 !important;
  box-shadow: 0 8px 24px rgba(37,211,102,.18);
  transform: translateY(-1px);
}
.btn-wa:focus {
  outline: none;
  box-shadow: 0 0 0 4px rgba(37,211,102,.22);
}

/* =========================
   REDESIGN v11 — Style Update
   ========================= */

/* Section title centered */
.section-title{
  text-align:center;
  margin-bottom:28px;
}
.section-title h2{
  font-size:1.9rem;
  margin-bottom:8px;
  letter-spacing:-.3px;
}
.section-title p{
  color:var(--muted);
  font-size:.97rem;
  max-width:560px;
  margin:0 auto;
}

/* Contact icon list */
.contact-icon-list{
  display:flex;
  flex-direction:column;
  gap:14px;
  margin-top:4px;
}
.contact-icon-item{
  display:flex;
  align-items:flex-start;
  gap:12px;
}
.contact-icon-item .ci-icon{
  width:36px;height:36px;
  border-radius:10px;
  background:rgba(19,112,122,.10);
  border:1px solid rgba(19,112,122,.18);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
  margin-top:1px;
}
.contact-icon-item .ci-icon svg{
  width:16px;height:16px;
}
.contact-icon-item .ci-body{
  flex:1;
}
.contact-icon-item .ci-label{
  font-size:.78rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.6px;
  color:rgba(19,112,122,.85);
  margin-bottom:2px;
}
.contact-icon-item .ci-value{
  font-size:.93rem;
  color:var(--ink);
  line-height:1.45;
}
.contact-icon-item .ci-value a{
  color:var(--ink);
}
.contact-icon-item .ci-value a:hover{
  color:var(--primary);
  text-decoration:underline;
}

/* Accordion FAQ */
.accordion{
  display:flex;
  flex-direction:column;
  gap:0;
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  overflow:hidden;
  background:#fff;
}
.accordion details{
  border-bottom:1px solid var(--border);
}
.accordion details:last-child{
  border-bottom:none;
}
.accordion summary{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:16px 20px;
  font-weight:700;
  font-size:1rem;
  cursor:pointer;
  list-style:none;
  color:var(--ink);
  gap:12px;
  transition:background .15s ease;
  user-select:none;
}
.accordion summary::-webkit-details-marker{display:none}
.accordion summary:hover{
  background:rgba(19,112,122,.05);
}
.accordion details[open] summary{
  background:rgba(19,112,122,.07);
  color:var(--primary);
}
.accordion .acc-chevron{
  width:20px;height:20px;
  flex-shrink:0;
  border-radius:6px;
  background:rgba(19,112,122,.10);
  display:flex;align-items:center;justify-content:center;
  transition:transform .2s ease, background .15s ease;
}
.accordion details[open] .acc-chevron{
  transform:rotate(180deg);
  background:rgba(19,112,122,.18);
}
.accordion .acc-body{
  padding:0 20px 18px 20px;
  color:var(--muted);
  font-size:.95rem;
  line-height:1.65;
  border-top:1px solid rgba(19,112,122,.10);
  margin-top:-1px;
}

/* CTA contact bar (FAQ bottom) */
.cta-contact-bar{
  background:linear-gradient(135deg, rgba(19,112,122,.06), rgba(29,138,149,.04));
  border:1px solid rgba(19,112,122,.15);
  border-radius:var(--radius-lg);
  padding:22px 26px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  flex-wrap:wrap;
  gap:16px;
  margin-top:24px;
}
.cta-contact-bar .cta-info{
  display:flex;
  flex-direction:column;
  gap:6px;
}
.cta-contact-bar .cta-info-row{
  display:flex;
  align-items:center;
  gap:8px;
  font-size:.9rem;
  color:var(--muted);
}
.cta-contact-bar .cta-info-row svg{
  width:15px;height:15px;
  flex-shrink:0;
  color:var(--primary);
}
.cta-contact-bar .cta-info-title{
  font-weight:700;
  font-size:1rem;
  color:var(--ink);
  margin-bottom:4px;
}

/* Status pages (sukses / gagal) */
.status-page-wrap{
  min-height:80vh;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:40px 20px;
}
.status-card{
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:48px 40px;
  max-width:520px;
  width:100%;
  text-align:center;
  box-shadow:var(--shadow-sm);
}
.status-card .status-icon{
  width:64px;height:64px;
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 20px;
}
.status-card.status-sukses .status-icon{
  background:rgba(37,211,102,.12);
  border:2px solid rgba(37,211,102,.3);
}
.status-card.status-gagal .status-icon{
  background:rgba(239,68,68,.10);
  border:2px solid rgba(239,68,68,.25);
}
.status-card h1{
  font-size:1.65rem;
  margin:0 0 10px;
}
.status-card p{
  color:var(--muted);
  margin:0 0 24px;
  font-size:.97rem;
  line-height:1.6;
}
.status-card .status-contact{
  background:rgba(19,112,122,.05);
  border:1px solid rgba(19,112,122,.12);
  border-radius:12px;
  padding:14px 18px;
  margin-bottom:24px;
  font-size:.9rem;
  color:var(--muted);
  text-align:left;
}
.status-card .status-contact p{margin:0 0 4px;}
.status-card .status-contact p:last-child{margin:0;}

/* Stats row */
.stats-row{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
  margin-top:14px;
}
.stat-card{
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:20px 16px;
  text-align:center;
  box-shadow:0 1px 0 rgba(0,0,0,.03);
}
.stat-card .stat-num{
  font-size:1.6rem;
  font-weight:900;
  color:var(--primary);
  line-height:1.1;
  margin-bottom:4px;
  letter-spacing:-.5px;
}
.stat-card .stat-label{
  font-size:.82rem;
  color:var(--muted);
  line-height:1.3;
}

/* Page inner hero (for non-index pages) */
.page-hero{
  padding:36px 0 24px;
  border-bottom:1px solid var(--border);
  margin-bottom:8px;
}
.page-hero .badge{margin-bottom:10px;display:inline-flex;}
.page-hero h1{
  font-size:2.2rem;
  margin:8px 0 10px;
  letter-spacing:-.4px;
}
.page-hero p{
  color:var(--muted);
  max-width:620px;
  font-size:.97rem;
}

@media(max-width:640px){
  .stats-row{grid-template-columns:1fr 1fr;}
  .cta-contact-bar{flex-direction:column;align-items:flex-start;}
  .status-card{padding:36px 24px;}
  .page-hero h1{font-size:1.7rem;}
  .accordion summary{font-size:.93rem;padding:14px 16px;}
  .accordion .acc-body{padding:0 16px 16px;}
}

/* =========================
   SCROLL ANIMATIONS
   ========================= */

.anim-ready {
  opacity: 0;
  transition: opacity .55s cubic-bezier(.22,1,.36,1),
              transform .55s cubic-bezier(.22,1,.36,1);
  will-change: transform, opacity;
}
.anim-from-left  { transform: translateX(-72px); }
.anim-from-right { transform: translateX(72px); }
.anim-from-bottom{ transform: translateY(48px); }

.anim-visible {
  opacity: 1 !important;
  transform: translate(0,0) !important;
}

/* Stagger delays for grid children */
.anim-delay-1 { transition-delay: .08s; }
.anim-delay-2 { transition-delay: .18s; }
.anim-delay-3 { transition-delay: .28s; }
.anim-delay-4 { transition-delay: .38s; }
.anim-delay-5 { transition-delay: .48s; }
.anim-delay-6 { transition-delay: .58s; }

/* Respect reduced-motion preference */
@media (prefers-reduced-motion: reduce) {
  .anim-ready {
    opacity: 1;
    transform: none;
    transition: none;
  }
}

/* =========================
   TENTANG HERO IMAGE
   ========================= */
.tentang-hero {
  position: relative;
  width: 100%;
  height: 380px;
  overflow: hidden;
  border-bottom: 1px solid rgba(11,60,68,.18);
}
.tentang-hero img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  display: block;
}
.tentang-hero::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    180deg,
    rgba(11,60,68,.18) 0%,
    rgba(11,60,68,.42) 60%,
    rgba(11,60,68,.72) 100%
  );
}
.tentang-hero-caption {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 1;
  padding: 28px var(--pad-x);
  max-width: var(--max);
  margin: 0 auto;
}
.tentang-hero-caption .badge { margin-bottom: 10px; display:inline-flex; }
.tentang-hero-caption h1 {
  color: #fff;
  font-size: 2rem;
  margin: 6px 0 6px;
  letter-spacing: -.3px;
  text-shadow: 0 2px 8px rgba(0,0,0,.35);
}
.tentang-hero-caption p {
  color: rgba(255,255,255,.88);
  font-size: .95rem;
  max-width: 580px;
  text-shadow: 0 1px 4px rgba(0,0,0,.25);
  margin: 0;
}

@media (max-width: 768px) {
  .tentang-hero { height: 260px; }
  .tentang-hero-caption h1 { font-size: 1.6rem; }
}
