@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=Outfit:wght@400;600;700;800&display=swap');

:root {
  --bg-dark: #f8fafc;
  --bg-card: #ffffff;
  --bg-card2: #f1f5f9;
  --blue: #1e40af;
  --blue-light: #2563eb;
  --blue-glow: rgba(37,99,235,0.06);
  --cyan: #3b82f6;
  --text: #0f172a;
  --text-muted: #64748b;
  --border: #e2e8f0;
  --radius: 12px;
  --shadow: 0 4px 20px rgba(15,23,42,0.04);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',sans-serif;background:var(--bg-dark);color:var(--text);line-height:1.6}

/* SCROLLBAR */
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:var(--bg-dark)}
::-webkit-scrollbar-thumb{background:var(--blue-light);border-radius:3px}

/* NAVBAR */
.navbar{position:fixed;top:0;left:0;width:100%;z-index:1000;padding:14px 40px;display:flex;align-items:center;justify-content:space-between;background:rgba(255,255,255,0.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);transition:.3s}
.nav-brand{display:flex;align-items:center;gap:12px}
.nav-logo{width:42px;height:42px;border-radius:10px;object-fit:contain;background:#f0f7ff;padding:4px;border:1px solid #d0e7ff}
.nav-brand h1{font-family:'Outfit',sans-serif;font-size:18px;font-weight:700;color:var(--blue);letter-spacing:-.3px}
.nav-brand span{font-size:12px;color:var(--text-muted)}
.nav-links{display:flex;gap:8px;align-items:center}
.nav-links a{color:var(--text-muted);text-decoration:none;padding:8px 16px;border-radius:8px;font-size:14px;font-weight:500;transition:.2s}
.nav-links a:hover,.nav-links a.active{color:var(--blue-light);background:var(--blue-glow)}
.nav-toggle{display:none;background:none;border:none;color:var(--text);font-size:24px;cursor:pointer}

/* HERO */
.hero{min-height:92vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:120px 20px 80px;position:relative;overflow:hidden;background:radial-gradient(circle at 50% 100%, #eff6ff 0%, var(--bg-dark) 80%)}
.hero-content{position:relative;z-index:1;max-width:860px;margin:0 auto}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:#eff6ff;border:1px solid #bfdbfe;border-radius:50px;padding:6px 18px;font-size:13px;color:var(--blue-light);margin-bottom:24px;font-weight:500}
.hero h2{font-family:'Outfit',sans-serif;font-size:clamp(2.2rem,5vw,3.6rem);font-weight:800;line-height:1.2;margin-bottom:20px;letter-spacing:-1px;color:var(--blue)}
.hero h2 span{color:var(--blue-light)}
.hero p{font-size:1.1rem;color:var(--text-muted);max-width:600px;margin:0 auto 36px}
.hero-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.btn-primary{background:var(--blue-light);color:#fff;padding:13px 30px;border-radius:10px;text-decoration:none;font-weight:600;font-size:15px;transition:.3s}
.btn-primary:hover{background:var(--blue);transform:translateY(-1px);box-shadow:0 6px 20px rgba(37,99,235,0.15)}
.btn-outline{background:transparent;color:var(--blue-light);padding:13px 30px;border-radius:10px;text-decoration:none;font-weight:600;font-size:15px;border:1.5px solid #bfdbfe;transition:.3s}
.btn-outline:hover{background:#eff6ff;border-color:var(--blue-light)}

/* HEADER LOGOS */
.header-logos{display:flex;align-items:center;justify-content:center;gap:40px;padding:32px 20px;background:#ffffff;border-bottom:1px solid var(--border)}
.logo-box{display:flex;align-items:center;gap:14px}
.logo-img{width:60px;height:60px;border-radius:12px;object-fit:contain;background:#f8fafc;padding:6px;border:1px solid var(--border)}
.logo-label strong{display:block;font-size:15px;font-weight:700;color:var(--text)}
.logo-label span{font-size:12px;color:var(--text-muted)}
.logo-divider{width:1px;height:50px;background:var(--border)}

/* SECTION */
.section{padding:80px 40px;background:var(--bg-card)}
.container{max-width:1200px;margin:0 auto}
.section-header{text-align:center;margin-bottom:56px}
.section-tag{display:inline-block;background:#eff6ff;color:var(--blue-light);border:1px solid #bfdbfe;border-radius:50px;padding:4px 16px;font-size:12px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;margin-bottom:14px}
.section-header h2{font-family:'Outfit',sans-serif;font-size:clamp(1.8rem,3.5vw,2.4rem);font-weight:800;letter-spacing:-.5px;margin-bottom:12px;color:var(--blue)}
.section-header p{color:var(--text-muted);max-width:540px;margin:0 auto;font-size:15px}

/* CARDS GRID */
.grid-3 {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 24px;
  width: 100%;
}
.grid-3 .kendaraan-card, 
.grid-3 .card {
  flex: 1 1 340px;
  max-width: 380px;
  width: 100%;
  box-sizing: border-box;
}

.grid-4{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px}
.grid-2{display:grid;grid-template-columns:repeat(auto-fit,minmax(340px,1fr));gap:28px}

/* CARD */
.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:28px;transition:.3s;position:relative;box-shadow:var(--shadow)}
.card:hover{transform:translateY(-3px);border-color:var(--blue-light);box-shadow:0 10px 30px rgba(15,23,42,0.06)}
.card-icon{width:52px;height:52px;border-radius:12px;background:#eff6ff;border:1px solid #d0e7ff;display:flex;align-items:center;justify-content:center;font-size:20px;color:var(--blue-light);margin-bottom:18px}
.card h3{font-size:17px;font-weight:700;margin-bottom:8px;color:var(--text)}
.card p{font-size:14px;color:var(--text-muted);line-height:1.65}
.card .badge{display:inline-block;font-size:11px;padding:3px 10px;border-radius:50px;margin-top:14px;font-weight:600}
.badge-active{background:#e8f5e9;color:#2e7d32;border:1px solid #a5d6a7}
.badge-repair{background:#fff3e0;color:#ef6c00;border:1px solid #ffe0b2}
.badge-off{background:#ffebee;color:#c62828;border:1px solid #ffcdd2}

/* STAT STRIP */
.stats-strip{background:#ffffff;border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:40px;display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:32px;text-align:center}
.stat-item h3{font-family:'Outfit',sans-serif;font-size:2.4rem;font-weight:800;color:var(--blue);line-height:1}
.stat-item p{font-size:13px;color:var(--text-muted);margin-top:6px}

/* DIVISI / ORG */
.staff-card{
    background:#ffffff;
    border:1px solid var(--border);
    border-radius:20px;
    padding:30px;
    text-align:center;
    transition:.3s;
    box-shadow:0 10px 25px rgba(0,0,0,.05);
}
.staff-card:hover{
    border-color:var(--blue-light);
    transform:translateY(-5px);
    box-shadow:0 20px 40px rgba(37,99,235,.12);
}
.staff-avatar{
    width:180px;
    height:180px;
    border-radius:50%;
    margin:0 auto 20px;
    overflow:hidden;
    border:5px solid #dbeafe;
    background:#fff;
    box-shadow:0 10px 30px rgba(37,99,235,.15);
    display:flex;
    align-items:center;
    justify-content:center;
}
.staff-avatar img{
    width:100%;
    height:100%;
    object-fit:cover;
}
.staff-card strong{
    display:block;
    font-size:20px;
    font-weight:800;
    margin-bottom:8px;
    line-height:1.5;
}
.staff-card span{
    font-size:15px;
    color:var(--text-muted);
}

/* KENDARAAN */
.kendaraan-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:24px;display:flex;align-items:center;gap:20px;transition:.3s;box-shadow:var(--shadow)}
.kendaraan-card:hover{border-color:var(--blue-light);transform:translateY(-2px)}
.kendaraan-icon{width:56px;height:56px;border-radius:14px;background:#eff6ff;display:flex;align-items:center;justify-content:center;font-size:22px;color:var(--blue-light);flex-shrink:0;border:1px solid #bfdbfe}
.kendaraan-info h4{font-size:16px;font-weight:700;margin-bottom:4px;color:var(--text)}
.kendaraan-info p{font-size:13px;color:var(--text-muted)}
.kendaraan-plat{font-family:monospace;font-size:13px;font-weight:700;color:var(--blue);margin-top:6px}

/* FOOTER */
footer{background:#ffffff;border-top:1px solid var(--border);padding:60px 40px 30px}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:48px;margin-bottom:48px}
.footer-brand h3{font-family:'Outfit',sans-serif;font-size:20px;font-weight:800;margin-bottom:10px;color:var(--blue)}
.footer-brand p{font-size:14px;color:var(--text-muted);line-height:1.7;margin-bottom:20px}
.sosmed-row{display:flex;gap:12px;flex-wrap:wrap}
.sosmed-btn{width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:17px;color:#fff;text-decoration:none;transition:.3s}
.sosmed-btn:hover{transform:scale(1.05)}
.footer-col h4{font-size:13px;font-weight:700;color:var(--blue);text-transform:uppercase;letter-spacing:.8px;margin-bottom:18px}
.footer-col ul{list-style:none}
.footer-col ul li{margin-bottom:10px}
.footer-col ul li a{color:var(--text-muted);text-decoration:none;font-size:14px;transition:.2s}
.footer-col ul li a:hover{color:var(--blue-light)}
.maps-wrap{border-radius:12px;overflow:hidden;border:1px solid var(--border)}
.maps-wrap iframe{width:100%;height:220px;border:0;display:block}
.footer-bottom{border-top:1px solid var(--border);padding-top:24px;display:flex;justify-content:space-between;align-items:center;font-size:13px;color:var(--text-muted);flex-wrap:wrap;gap:12px}

/* FORM */
.form-card{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:40px;max-width:640px;margin:0 auto;box-shadow:var(--shadow)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-group{margin-bottom:20px}
.form-group label{display:block;font-size:13px;font-weight:600;color:var(--text-muted);margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}
.form-group input,.form-group select,.form-group textarea{width:100%;background:#f8fafc;border:1.5px solid var(--border);border-radius:8px;padding:12px 16px;color:var(--text);font-family:'Inter',sans-serif;font-size:14px;transition:.3s;outline:none}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--blue-light);box-shadow:0 0 0 3px rgba(37,99,235,0.08);background:#ffffff}
.form-group select option{background:#ffffff}
.form-group textarea{resize:vertical;min-height:100px}
.border-submit,.btn-submit{background:var(--blue-light);color:#fff;border:none;padding:15px 36px;border-radius:8px;font-family:'Inter',sans-serif;font-size:15px;font-weight:700;cursor:pointer;width:100%;transition:.3s;letter-spacing:.3px}
.btn-submit:hover{background:var(--blue);transform:translateY(-1px)}

/* ALERTS */
.alert{padding:14px 20px;border-radius:8px;font-weight:600;margin-bottom:20px;font-size:14px}
.alert-success{background:#e8f5e9;border:1px solid #a5d6a7;color:#2e7d32}
.alert-danger{background:#ffebee;border:1px solid #ffcdd2;color:#c62828}

/* WIFI GRID */
.wifi-group{background:#ffffff;border-radius:var(--radius);padding:24px;border:1px solid var(--border);margin-bottom:24px;box-shadow:var(--shadow)}
.wifi-group-title{font-size:13px;font-weight:700;color:var(--blue);text-transform:uppercase;letter-spacing:.8px;margin-bottom:16px;display:flex;align-items:center;gap:8px}
.wifi-items{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px}
.wifi-item{background:#f8fafc;border:1px solid var(--border);border-radius:10px;padding:16px;display:flex;align-items:center;gap:12px;transition:.3s}
.wifi-item:hover{border-color:var(--blue-light);background:#ffffff}
.wifi-dot{width:10px;height:10px;border-radius:50%;background:#4caf50;flex-shrink:0}
.wifi-dot.repair{background:#ff9800}
.wifi-item strong{font-size:14px;display:block;margin-bottom:2px;color:var(--text)}
.wifi-item span{font-size:12px;color:var(--text-muted)}

/* BACK BTN */
.back-link{display:inline-flex;align-items:center;gap:8px;color:var(--text-muted);text-decoration:none;font-size:14px;font-weight:500;margin-bottom:32px;transition:.2s}
.back-link:hover{color:var(--blue-light)}

/* UTILS & ANIMATIONS */
.logo-divider-nav{width:1px;height:32px;background:#dbeafe;margin:0 4px}
@keyframes fadeInUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.fade-in-up{opacity:0;animation:fadeInUp .5s ease forwards}
.delay-1{animation-delay:.05s}.delay-2{animation-delay:.1s}.delay-3{animation-delay:.15s}.delay-4{animation-delay:.2s}

/* MOMENT SECTION */
.moment-section{padding: 60px 20px;background: #ffffff}
.moment-container{max-width: 900px;margin: 0 auto}
.moment-card-large{background: var(--bg-card);border: 1px solid var(--border);border-radius: 24px;overflow: hidden;margin-bottom: 40px;box-shadow: 0 10px 30px rgba(0,0,0,0.08);transition: 0.4s}
.moment-card-large:hover{transform: translateY(-5px);box-shadow: 0 20px 40px rgba(37,99,235,0.12)}
.moment-card-large img{width: 100%;height: 450px;object-fit: cover;display: block}
.moment-content{padding: 30px}
.moment-content h3{font-size: 24px;font-weight: 800;color: var(--text);margin-bottom: 8px}
.moment-content p{font-size: 15px;color: var(--text-muted)}

/* =========================================================
   🛑 GLOBAL CLEAN MOBILE RESPONSIVE (BREAKPOINT TERPADU)
   ========================================================= */
   
@media (max-width: 768px) {
  body { padding-top: 80px !important; }
  
  /* 1. MENGGESER LOGO MAKSIMAL KE KIRI DENGAN MENOLKAN PADDING KIRI NAVBAR */
  .navbar { 
    padding: 10px 12px 10px 4px !important; /* Padding kiri diubah jadi 4px agar mepet ke kiri */
  }
  .nav-brand { 
    gap: 4px !important; /* Memperrapat jarak horizontal antara kedua logo dan teks */
  }
  
  /* 2. MENYESUAIKAN UKURAN KEDUA LOGO BOX DI FASILITAS (BIAR SAMA DENGAN PROFIL) */
  .nav-brand .logo-box {
    margin: 0 !important;
    padding: 0 !important;
  }
  .nav-brand .logo-box img {
    width: 34px !important;   /* Ukuran pas & serasi dengan profil */
    height: 34px !important;
    border-radius: 8px !important;
    object-fit: contain !important;
    background: #f0f7ff;
    padding: 3px;
    border: 1px solid #d0e7ff;
  }
  
  /* 3. MERAPIKAN TEKS AGAR STRIP BARISNYA KEMBALI SEJAJAR (TIDAK TURUN KE BAWAH) */
  .brand-text h1 {
    font-size: 15px !important;
    line-height: 1.2 !important;
    font-family: 'Outfit', sans-serif;
    font-weight: 700;
    color: var(--blue);
  }
  .brand-text span {
    font-size: 10px !important;
    line-height: 1.2 !important;
    display: inline-block !important;
    white-space: nowrap !important;  /* KUNCI: Memaksa kata 'Gizi' agar tidak patah ke bawah */
    color: var(--text-muted);
  }

  /* Aktifkan tombol menu garis tiga secara konsisten */
  .nav-toggle {
    display: block !important;
    font-size: 24px !important;
    color: var(--blue) !important;
  }

  /* Sembunyikan link navigasi default di HP */
  .nav-links {
    display: none !important;
    position: absolute !important;
    top: 60px !important; /* Disesuaikan dengan tinggi navbar baru yang ramping */
    left: 0 !important;
    width: 100% !important;
    background: #ffffff !important;
    flex-direction: column !important;
    padding: 20px !important;
    box-shadow: 0 10px 20px rgba(0,0,0,0.08) !important;
    border-bottom: 1px solid var(--border) !important;
    gap: 8px !important;
    z-index: 1000 !important;
  }

  /* SUPORT KEDUA JENIS SCRIPT JS (.open DAN .active) */
  .nav-links.active, 
  .nav-links.open {
    display: flex !important;
  }

  .nav-links a {
    width: 100% !important;
    text-align: center !important;
    box-sizing: border-box !important;
  }

  .header-logos{flex-direction:column;gap:20px}
  .logo-divider{width:80px;height:1px}
}