:root {
    --primary: #c78b07;
    --primary-soft: #edf2fb;
    --primary-accent: #f4b766;
    --dark: #0f172a;
    --text: #1e293b;
    --muted: #6b7280;
    --light: #ffffff;
    --bg-body: #f5f7fb;
    --bg-section: #ffffff;
    --border-radius: 12px;
    --transition: all 0.25s ease;
    --max-width: 1140px;
    --shadow-soft: 0 14px 40px rgba(15, 23, 42, 0.08);
  }

  *{box-sizing:border-box;margin:0;padding:0}
  body{
    font-family:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
    background:var(--bg-body);color:var(--text);line-height:1.6;
  }
  a{color:inherit;text-decoration:none}
  img{max-width:100%;display:block}
  .container{width:100%;max-width:var(--max-width);margin:0 auto;padding:0 16px}

  section {
    padding: 150px 0;      /* jarak atas–bawah */
  }

  @media (max-width: 992px) {
    section {
      padding: 80px 0;
    }
  }

  @media (max-width: 768px) {
    section {
      padding: 70px 0;
    }

    section:first-of-type {
      padding-top: 120px !important;
    }
  }

  @media (max-width: 480px) {
    section {
      padding: 200px 0;
    }
  }


  .btn{
    display:inline-flex;align-items:center;gap:8px;
    padding:10px 22px;border-radius:999px;font-size:.95rem;font-weight:600;
    cursor:pointer;border:none;outline:none;background:var(--primary);
    color:#f9fafb;transition:var(--transition);text-transform:uppercase;
    letter-spacing:.04em;
  }
  .btn:hover{background:#183a60;transform:translateY(-1px);box-shadow:0 10px 28px rgba(15,23,42,.18)}
  .btn-outline{background:transparent;color:var(--primary);border:1px solid rgba(15,23,42,.14)}
  .btn-outline:hover{background:#f9fafb}

  .section-heading{text-align:center;max-width:640px;margin:0 auto 36px}
  .section-kicker{
    font-size:.8rem;letter-spacing:.2em;text-transform:uppercase;
    color:var(--primary);margin-bottom:8px;
  }
  .section-title{font-size:1.9rem;font-weight:700;margin-bottom:10px;color:var(--dark)}
  .section-subtitle{font-size:.95rem;color:var(--muted)}

  /* Topbar */
  .topbar{
    background:#e5edf8;border-bottom:1px solid rgba(15,23,42,.06);
    font-size:.8rem;
  }
  .topbar-inner{
    display:flex;justify-content:space-between;align-items:center;
    gap:16px;padding:6px 0;color:var(--muted);
  }
  .topbar-list{display:flex;flex-wrap:wrap;gap:14px;align-items:center}
  .topbar-item{display:inline-flex;align-items:center;gap:6px}
  .topbar-dot{width:4px;height:4px;background:var(--primary-accent);border-radius:999px}

  /* Header / Nav */
  header{
    position:sticky;top:0;z-index:100;
    background:rgba(245,247,251,.9);
    backdrop-filter:blur(12px);
    border-bottom:1px solid rgba(148,163,184,.25);
  }
  .nav{
    display:flex;align-items:center;justify-content:space-between;
    padding:12px 0;gap:24px;
  }
  .logo{
    display:flex;align-items:center;gap:8px;font-weight:700;
    letter-spacing:.06em;text-transform:uppercase;font-size:.95rem;
    color:var(--primary);
  }
  .logo-mark{
    width:100px;
    height:100px;
    justify-content:center;
    }

    .logo-mark img{
    width:100%;
    height:100%;
    object-fit:contain;   /* logo tidak terpotong */
    }

  .nav-links{display:flex;gap:24px;font-size:.9rem}
  .nav-links a{
    color:var(--muted);position:relative;padding:6px 10px 8px;
    border-radius:999px;display:inline-flex;align-items:center;
    justify-content:center;transition:var(--transition);overflow:hidden;
  }
  .nav-links a::after{
    content:"";position:absolute;left:18%;right:18%;bottom:4px;
    height:2px;border-radius:999px;background:var(--primary);
    transform:scaleX(0);transform-origin:center;transition:transform .25s ease;
  }
  .nav-links a:hover{color:var(--primary);background:rgba(148,163,184,.15)}
  .nav-links a:hover::after,.nav-links a.active::after{transform:scaleX(1)}
  .nav-links a.nav-pressed{transform:scale(.94);background:rgba(148,163,184,.25)}

  .nav-cta{display:flex;align-items:center;gap:12px}
  .nav-phone{font-size:.8rem;text-align:right;color:var(--muted)}
  .nav-phone strong{display:block;font-size:.95rem;color:var(--primary)}

  .nav-toggle{
    display:none;cursor:pointer;width:32px;height:32px;
    border-radius:999px;border:1px solid rgba(148,163,184,.8);
    align-items:center;justify-content:center;background:#fff;
  }
  .nav-toggle span,
  .nav-toggle span::before,
  .nav-toggle span::after{
    display:block;width:16px;height:2px;background:var(--primary);
    border-radius:999px;position:relative;transition:var(--transition);
  }
  .nav-toggle span::before,
  .nav-toggle span::after{content:"";position:absolute;left:0}
  .nav-toggle span::before{top:-5px}
  .nav-toggle span::after{top:5px}
  .nav-toggle.active span{background:transparent}
  .nav-toggle.active span::before{top:0;transform:rotate(45deg)}
  .nav-toggle.active span::after{top:0;transform:rotate(-45deg)}

  /* (opsional) nav versi mobile – kalau HTML-nya pakai .nav-mobile */
  .nav-mobile{display:none;}
  .nav-mobile.open{display:block;}
  .nav-mobile-links{
    display:flex;flex-direction:column;gap:10px;
    padding:8px 0 4px;border-top:1px solid rgba(148,163,184,.4);
  }
  .nav-mobile-links a{
    font-size:.9rem;color:var(--muted);padding:6px 2px;
  }
  .nav-mobile-links a:hover{color:var(--primary);}
  .nav-mobile-cta{margin-top:8px;}

  /* ===========================
   HERO SLIDER
=========================== */
.hero-slider {
    position: relative;
    width: 100%;
    height: calc(100vh - 90px); /* SESUAIKAN DENGAN TINGGI NAVBAR */
    overflow: hidden;
}

/* Setiap slide */
.hero-slide {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    background-size: cover;         /* fill container */
    background-position: center;    /* fokus tengah */
    background-repeat: no-repeat;   /* tidak repeat */
    opacity: 0;
    transition: opacity 0.8s ease-in-out;
}

/* Slide aktif */
.hero-slide.active {
    opacity: 1;
}

/* Overlay gelap */
.hero-slide::before {
    content: "";
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,0.35);
}

/* Konten dalam slide */
.hero-content {
    position: relative;
    z-index: 10;
    color: #fff;
    max-width: 50%;
    padding: 30px;
    padding-top: 20%;
}

.hero-content h1 {
    font-size: 3rem;
    line-height: 2.8rem;
    font-weight: 700;
    margin-bottom: 20px;
}

.hero-content p {
    font-size: 1.2rem;
    opacity: 0.95;
    margin-bottom: 25px;
}

.btn-hero {
    display: inline-block;
    background: #d4a017;
    color: #0f172a;
    padding: 12px 26px;
    border-radius: 8px;
    font-weight: 600;
}

/* tombol navigation */
.hero-nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 20;
    background: rgba(255,255,255,0.7);
    border: none;
    font-size: 25px;
    padding: 10px 20px;
    border-radius: 50%;
    cursor: pointer;
    transition: 0.3s;
}

.hero-nav:hover {
    background: #fff;
}

.hero-nav.prev {
    left: 25px;
}

.hero-nav.next {
    right: 25px;
}

/* RESPONSIVE */
@media (max-width: 768px) {
    .hero-content {
        position: relative;
        z-index: 10;
        color: #fff;
        max-width: 100%;
        padding: 30px;
        padding-top: 50%;
    }

    .hero-content h1 {
        font-size: 2rem;
        font-weight: 700;
        margin-bottom: 20px;
        line-height: 1. 8rem;
    }

    .hero-content p {
        font-size: 1.2rem;
        opacity: 0.95;
        margin-bottom: 25px;
    }
}


  /* About */
  .about-grid{
    display:grid;
    grid-template-columns:minmax(0,1.1fr) minmax(0,1fr);
    gap:40px;align-items:center;
  }
  .about-tagline{font-size:.9rem;color:var(--primary);margin-bottom:6px}
  .about-title{font-size:1.8rem;font-weight:700;margin-bottom:10px;color:var(--dark)}
  .about-text{color:var(--muted);font-size:.95rem;margin-bottom:18px}
  .about-list{
    display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
    gap:14px;margin-bottom:18px;
  }
  .about-item{display:flex;gap:10px;align-items:flex-start}
  .about-icon{
    width:24px;height:24px;border-radius:999px;
    border:1px solid rgba(148,163,184,.8);
    display:flex;align-items:center;justify-content:center;
    font-size:.9rem;color:var(--primary);flex-shrink:0;background:#f9fafb;margin-top:2px;
  }
  .about-meta{
    display:flex;gap:24px;flex-wrap:wrap;font-size:.85rem;
    color:var(--muted);margin-top:8px;
  }
  .about-meta strong{display:block;font-size:1.3rem;color:var(--primary)}
  .about-media{
    border-radius:18px;padding:18px;background:#fff;
    border:1px solid rgba(148,163,184,.35);min-height:260px;
    position:relative;overflow:hidden;box-shadow:var(--shadow-soft);
  }
  .about-media-top{
    display:flex;justify-content:space-between;align-items:center;
    font-size:.8rem;margin-bottom:10px;
  }
  .about-chip{
    padding:4px 10px;border-radius:999px;
    border:1px solid rgba(148,163,184,.7);
    background:#f3f4ff;color:var(--primary);
    display:inline-flex;align-items:center;gap:6px;
  }
  .about-chip span{font-size:1rem}
  .about-badges{display:flex;gap:8px;font-size:.7rem;color:var(--muted)}
  .about-graph{
    margin-top:8px;border-radius:14px;background:#f3f4ff;
    padding:14px;font-size:.8rem;
  }
  .about-graph-row{
    display:flex;justify-content:space-between;margin-bottom:8px;color:var(--dark);
  }
  .about-graph-bar{
    width:100%;height:6px;border-radius:999px;background:#e5e7eb;
    overflow:hidden;margin-top:4px;position:relative;
  }
  .about-graph-bar span{
    position:absolute;inset:0;border-radius:inherit;
    background:linear-gradient(90deg,#1f4b7b,#60a5fa);
  }

  .section--alt{background:var(--bg-section)}

  .mission-list {
    list-style: none;
    margin: 0;
    padding: 0;
  }

  .mission-item {
    display: flex;
    align-items: flex-start;
    gap: 14px;
    margin-bottom: 14px;
  }

  .mission-icon {
    width: 38px;
    height: 38px;
    border-radius: 50%;
    background: #f1f5f9;
    border: 1px solid rgba(0,0,0,0.12);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
  }

  .mission-item strong {
    font-size: 1.05rem;
    color: #0f172a;
  }

  /* REMOVE OLD inner structure */
.about-media--full {
  padding: 0;
  background: none;
  border: none;
  box-shadow: var(--shadow-soft);
  border-radius: 18px;
  overflow: hidden;
  position: relative;
  min-height: 340px; /* boleh diubah */
}

/* the image */
.about-media--full img {
  width: 100%;
  height: 100%;
  object-fit: cover;       /* gambar memenuhi area */
  object-position: center; /* fokus tengah */
  display: block;
}

/* responsiveness */
@media (max-width: 768px) {
  .about-media--full {
    min-height: 260px;
  }
}

@media (max-width: 480px) {
  .about-media--full {
    min-height: 200px;
  }
}


  /* Services */
  .services-grid{
    display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px;
  }
  .service-card{
    border-radius:18px;padding:22px 20px;background:#fff;
    border:1px solid rgba(148,163,184,.35);transition:var(--transition);
    position:relative;overflow:hidden;box-shadow:0 10px 28px rgba(15,23,42,.04);
  }
  .service-card::after{
    content:"";position:absolute;inset:-40%;
    background:radial-gradient(circle at top,rgba(148,163,184,.18),transparent 60%);
    opacity:0;transition:var(--transition);pointer-events:none;
  }
  .service-card:hover{
    transform:translateY(-4px);border-color:rgba(31,75,123,.9);
    box-shadow:0 18px 40px rgba(15,23,42,.12);
  }
  .service-card:hover::after{opacity:1}
  .service-icon{
    width:44px;height:44px;border-radius:16px;background:#f3f4ff;
    display:flex;align-items:center;justify-content:center;
    font-size:1.4rem;margin-bottom:10px;
  }
  .service-title{font-size:1rem;font-weight:600;margin-bottom:6px;color:var(--dark)}
  .service-text{font-size:.9rem;color:var(--muted);margin-bottom:10px}
  .service-link{font-size:.8rem;color:var(--primary)}

  /* Projects / Stats */
  .projects-header{
    display:flex;align-items:center;justify-content:space-between;
    gap:24px;margin-bottom:24px;flex-wrap:wrap;
  }
  .projects-header-text{max-width:480px}
  .projects-header-text p{font-size:.95rem;color:var(--muted)}
  .projects-grid{
    display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
    gap:18px;margin-bottom:28px;
  }
  .project-card{
    border-radius:18px;overflow:hidden;background:#fff;
    border:1px solid rgba(148,163,184,.35);box-shadow:0 10px 28px rgba(15,23,42,.04);
  }
  .project-body{padding:14px 16px 16px;font-size:.9rem}
  .project-label{
    font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;
    color:var(--primary);margin-bottom:4px;
  }
  .project-title{font-size:1rem;font-weight:600;margin-bottom:4px;color:var(--dark)}
  .project-meta{font-size:.8rem;color:var(--muted)}
  .stats-strip{
    display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));
    gap:16px;padding:18px;border-radius:18px;background:#fff;
    border:1px solid rgba(148,163,184,.35);box-shadow:var(--shadow-soft);
  }
  .stat-item strong{font-size:1.6rem;color:var(--primary);display:block}
  .stat-item span{font-size:.8rem;color:var(--muted)}

  /* ====================
   PROJECTS CAROUSEL
   ==================== */

.projects-carousel{
  display:flex;
  align-items:center;
  gap:14px;
  margin-bottom:28px; /* sama seperti sebelumnya */
}

.projects-viewport{
  flex:1;
  overflow-x:hidden;    /* ini yang bikin bisa discroll */
  overflow-y:hidden;
  scroll-behavior:smooth;
}

.projects-strip{
  display:flex;
  gap:18px;
}


/* buat card supaya cocok untuk carousel */
.project-card{
  flex:0 0 320px; /* lebar card di desktop */
  border-radius:18px;
  overflow:hidden;
  background:#fff;
  border:1px solid rgba(148,163,184,.35);
  box-shadow:0 10px 28px rgba(15,23,42,.04);
  display:flex;
  flex-direction:column;
}

/* kalau sudah punya style project-image, boleh skip bagian ini */
/* gambar header */
.project-image{
  width:100%;
  height:260px;           /* atur tinggi foto di sini */
  overflow:hidden;
}

.project-image img{
  width:100%;
  height:100%;
  object-fit:cover;       /* isi penuh, crop rapi */
  object-position:center;
  display:block;
}

/* mode overlay: teks di atas gambar + gradient gelap */
.project-card--overlay{
  position:relative;
  padding-bottom:0; /* body-nya kita taruh absolute, jadi padding bawah nggak perlu */
  overflow:hidden;
}

.project-card--overlay .project-image{
  border-radius:18px;     /* supaya sudut ikut bulat */
}

/* body jadi overlay di bawah foto */
.project-card--overlay .project-body{
  position:absolute;
  left:0;
  right:0;
  bottom:0;
  padding:18px 20px 20px;
  background:linear-gradient(
    to top,
    rgba(15,23,42,0.92),
    rgba(15,23,42,0.55),
    rgba(15,23,42,0)
  );
  color:#f9fafb;
}

/* warna teks di atas gambar */
.project-card--overlay .project-title{
  color:#f9fafb;
}
.project-card--overlay .project-meta{
  color:#e5e7eb;
}
.project-card--overlay .project-label{
  color:var(--primary-accent);
}

/* supaya tinggi card konsisten di layout carousel */
.project-card--overlay{
  min-height:260px; /* sama atau sedikit lebih kecil dari tinggi gambar */
}


.project-body{
  padding:14px 16px 16px;
  font-size:.9rem;
}

/* arrows (mirip team-arrow) */
.projects-arrow{
  width:32px;
  height:32px;
  border-radius:999px;
  border:1px solid rgba(148,163,184,.7);
  background:#fff;
  color:var(--primary);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  font-size:1.1rem;
  transition:var(--transition);
  flex-shrink:0;
}
.projects-arrow:hover{
  background:#e5edf8;
}

/* responsive */
@media (max-width: 1024px){
  .project-card{
    flex:0 0 300px;
  }
}

@media (max-width: 768px){
  .projects-carousel{
    gap:8px;
  }
  .project-card{
    flex:0 0 260px;
  }
}

@media (max-width: 480px){
  .projects-carousel{
    gap:6px;
  }
  .project-card{
    flex:0 0 230px;
  }
  .projects-arrow{
    width:28px;
    height:28px;
    font-size:.95rem;
  }
}


  /* TEAM */
  .team-grid{
    display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:18px;
  }
  .team-card{
    border-radius:18px;background:#fff;
    border:1px solid rgba(148,163,184,.35);padding:18px 18px 16px;
    box-shadow:0 10px 28px rgba(15,23,42,.04);
    text-align:center;transition:var(--transition);position:relative;overflow:hidden;
  }
  .team-card::after{
    content:"";position:absolute;inset:-40%;
    background:radial-gradient(circle at top,rgba(148,163,184,.18),transparent 60%);
    opacity:0;transition:var(--transition);pointer-events:none;
  }
  .team-card:hover{
    transform:translateY(-4px);border-color:rgba(31,75,123,.9);
    box-shadow:0 18px 40px rgba(15,23,42,.12);
  }
  .team-card:hover::after{opacity:1}
  .team-avatar{
    width:64px;height:64px;border-radius:999px;margin:0 auto 10px;
    background:radial-gradient(circle at top,#dbeafe,#1f4b7b);
    display:flex;align-items:center;justify-content:center;
    font-size:1.8rem;color:#e5edf8;
  }
  .team-name{font-weight:600;color:var(--dark);margin-bottom:2px}
  .team-role{
    font-size:.82rem;color:var(--primary);text-transform:uppercase;
    letter-spacing:.13em;margin-bottom:8px;
  }
  .team-text{font-size:.85rem;color:var(--muted);margin-bottom:8px}
  .team-meta{font-size:.78rem;color:var(--muted)}

  /* TEAM CAROUSEL */
.team-carousel-section {
  padding: 150px 0;
}

.team-carousel {
  display: flex;
  gap: 22px;
  overflow-x: hidden;
  scroll-behavior: smooth;
  padding-bottom: 10px;
}

.team-carousel::-webkit-scrollbar {
  height: 8px;
}
.team-carousel::-webkit-scrollbar-thumb {
  background: rgba(148,163,184,.4);
  border-radius: 10px;
}

.team-slide {
  flex: 0 0 260px;
  height: 260px;
  border-radius: 20px;
  background: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(148,163,184,.35);
  box-shadow: 0 10px 25px rgba(0,0,0,0.05);
  overflow: hidden;
}

.team-slide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Controls */
.team-controls {
  text-align: center;
  margin-top: 22px;
}

.team-controls button {
  width: 40px;
  height: 40px;
  font-size: 22px;
  margin: 0 6px;
  border-radius: 50%;
  border: 1px solid rgba(148,163,184,.5);
  background: #fff;
  cursor: pointer;
  transition: .25s;
}

.team-controls button:hover {
  background: #e2e8f0;
}


  /* Testimonials */
  .testimonials-grid{
    display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:18px;
  }
  .testimonial-card{
    border-radius:18px;padding:18px 18px 16px;background:#fff;
    border:1px solid rgba(148,163,184,.35);position:relative;overflow:hidden;
    box-shadow:0 10px 28px rgba(15,23,42,.04);
  }
  .testimonial-quote-mark{
    position:absolute;right:2px;top:-10px;font-size:3.5rem;
    color:rgba(148,163,184,.18);
  }
  .testimonial-text{font-size:.9rem;color:var(--muted);margin-bottom:14px}
  .testimonial-author{display:flex;align-items:center;gap:10px}
  .testimonial-avatar{
    width:36px;height:36px;border-radius:999px;
    background:radial-gradient(circle at top,#dbeafe,#1f4b7b);display:inline-block;
  }
  .testimonial-meta{font-size:.8rem}
  .testimonial-meta strong{display:block;font-size:.9rem;color:var(--dark)}

  /* Blog */
  .blog-grid{
    display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:18px;
  }
  .blog-card{
    border-radius:18px;overflow:hidden;background:#fff;
    border:1px solid rgba(148,163,184,.35);box-shadow:0 10px 28px rgba(15,23,42,.04);
  }
  .blog-body{padding:16px 16px 18px;font-size:.85rem}
  .blog-tag{
    font-size:.75rem;color:var(--primary);letter-spacing:.16em;
    text-transform:uppercase;margin-bottom:4px;
  }
  .blog-title{font-size:.98rem;font-weight:600;margin-bottom:6px;color:var(--dark)}
  .blog-meta{font-size:.8rem;color:var(--muted)}

  /* Contact */
  .contact-grid{
    display:grid;grid-template-columns:minmax(0,1.1fr) minmax(0,1fr);gap:32px;
  }
  .contact-card{
    border-radius:18px;padding:24px 22px;background:#fff;
    border:1px solid rgba(148,163,184,.35);box-shadow:var(--shadow-soft);
  }
  .contact-card p{font-size:.9rem;color:var(--muted);margin-bottom:16px}
  .contact-info-list{list-style:none;margin-bottom:16px;font-size:.9rem}
  .contact-info-list li+li{margin-top:10px}
  .contact-info-label{
    display:block;font-size:.78rem;text-transform:uppercase;
    letter-spacing:.18em;color:var(--primary);
  }
  form{display:grid;gap:10px}
  .form-row{
    display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px;
  }
  .field{display:flex;flex-direction:column;gap:4px;font-size:.85rem}
  .field label{color:var(--muted)}
  .field input,
  .field textarea{
    background:#fff;border:1px solid rgba(148,163,184,.9);
    border-radius:8px;padding:8px 10px;color:var(--text);
    font:inherit;outline:none;transition:var(--transition);
  }
  .field input:focus,
  .field textarea:focus{
    border-color:var(--primary);box-shadow:0 0 0 1px rgba(31,75,123,.2);
  }
  .field textarea{resize:vertical;min-height:110px}

  /* ======================
   CONTACT – MAP & PINS
   ====================== */

.contact-section{
  background:#020617; /* dark navy */
  color:#e5e7eb;
  padding-top:150px;
  padding-bottom:80px;
}

.contact-section .section-heading{
  color:#f9fafb;
}
.contact-section .section-title{
  color:#f9fafb;
}
.contact-section .section-subtitle{
  color:#9ca3af;
}

/* wrapper map full width (tetap dibatasi container) */
.contact-map-wrapper{
  margin-top:24px;
  margin-bottom:40px;
}

.contact-map{
  position:relative;
  width:100%;
  min-height:460px;
  border-radius:20px;
  overflow:hidden;
  background:#0b1120;
  border:1px solid rgba(148,163,184,.2);
}

.contact-map::before{
  content:"";
  position:absolute;
  inset:0;
  top:-500px;
  background:
    linear-gradient(to bottom, rgba(2,6,23,0.4), rgba(2,6,23,0.7)),
    url("images/maps.png") center/contain no-repeat;
  z-index:1;
}


/* pin lokasi */
.contact-pin{
  position:absolute;
  transform:translate(-50%,-100%);
  z-index:2;
  display:flex;
  flex-direction:column;
  gap:6px;
  max-width:220px;
}

/* titik bulat + pin */
.contact-pin-marker{
  width:32px;
  height:32px;
  border-radius:999px;
  background:var(--primary-accent);
  display:flex;
  align-items:center;
  justify-content:center;
  color:#111827;
  font-size:1.1rem;
  box-shadow:0 10px 26px rgba(0,0,0,.55);
  position:relative;
}
.contact-pin-marker::after{
  content:"";
  position:absolute;
  bottom:-9px;
  left:50%;
  width:0;
  height:0;
  transform:translateX(-50%);
  border-left:6px solid transparent;
  border-right:6px solid transparent;
  border-top:9px solid var(--primary-accent);
}

/* kartu info lokasi */
.contact-pin-card{
  margin-left:6px;
  padding:8px 10px;
  border-radius:8px;
  background:rgba(15,23,42,.92);
  border:1px solid rgba(148,163,184,.5);
  box-shadow:0 10px 30px rgba(0,0,0,.6);
  font-size:.78rem;
}
.contact-pin-name{
  font-weight:700;
  text-transform:uppercase;
  font-size:.78rem;
  letter-spacing:.08em;
  color:#f9fafb;
  margin-bottom:2px;
}
.contact-pin-text{
  color:#d1d5db;
  font-size:.78rem;
}

/* contoh koordinat (atur sesuai kebutuhan) */
.contact-pin--hq{   /* misal: Surabaya / HQ */
  top:100%;
  left:52%;
}
.contact-pin--yard1{ /* misal: Jakarta */
  top:65%;
  left:32%;
}
.contact-pin--yard2{ /* misal: Batam */
  top:90%;
  left:37%;
}

/* Kontak form di dark mode */
.contact-section .contact-card{
  background:#020617;
  border-color:rgba(148,163,184,.6);
  box-shadow:0 18px 40px rgba(0,0,0,.65);
}
.contact-section .contact-card p,
.contact-section .contact-info-list,
.contact-section .contact-info-list li,
.contact-section .field label{
  color:#e5e7eb;
}
.contact-section .field input,
.contact-section .field textarea{
  background:#020617;
  border-color:rgba(148,163,184,.8);
  color:#f9fafb;
}
.contact-section .field input::placeholder,
.contact-section .field textarea::placeholder{
  color:#6b7280;
}
.contact-section .field input:focus,
.contact-section .field textarea:focus{
  border-color:var(--primary-accent);
  box-shadow:0 0 0 1px rgba(244,183,102,.35);
}

/* agar teks kecil tidak nempel */
.contact-section .contact-card h4{
  color:#f9fafb;
}

/* responsive */
@media (max-width: 900px){
  .contact-map{
    min-height:260px;
  }
  .contact-pin{
    max-width:180px;
  }
}
@media (max-width: 600px){
  .contact-map{
    min-height:220px;
  }
  .contact-pin{
    font-size:.3rem;
  }
  .contact-map::before{
    content:"";
    position:absolute;
    inset:0;
    top:-150px;
    background:
      linear-gradient(to bottom, rgba(2,6,23,0.4), rgba(2,6,23,0.7)),
      url("images/maps.png") center/contain no-repeat;
    z-index:1;
  }
}


  /* Footer */
  footer{
    border-top:1px solid rgba(148,163,184,.4);
    background:#e5edf8;padding:22px 0;
    font-size:.8rem;color:var(--muted);
  }
  .footer-inner{
    display:flex;align-items:center;justify-content:space-between;
    gap:16px;flex-wrap:wrap;
  }
  .footer-links{display:flex;gap:14px;flex-wrap:wrap}
  .footer-links a{color:var(--muted)}
  .footer-links a:hover{color:var(--primary)}

  /* Scroll reveal */
  .reveal{opacity:0;transform:translateY(30px);
    transition:opacity .6s ease,transform .6s ease;}
  .reveal.visible{opacity:1;transform:translateY(0)}


  /*bahasa*/
  /* Language Dropdown */
.nav-lang{
  position:relative;
}

.lang-current{
  background:transparent;
  border:1px solid rgba(148,163,184,.4);
  color:var(--primary);
  padding:6px 14px;
  border-radius:999px;
  cursor:pointer;
  font-size:.85rem;
  font-weight:600;
  display:flex;
  align-items:center;
  gap:6px;
  transition:var(--transition);
}

.lang-current:hover{
  background:rgba(148,163,184,.12);
}

.lang-arrow{
  font-size:.7rem;
}

.lang-dropdown{
  position:absolute;
  top:110%;
  right:0;
  min-width:120px;
  background:#fff;
  border-radius:12px;
  box-shadow:0 10px 28px rgba(15,23,42,.12);
  border:1px solid rgba(148,163,184,.25);
  display:none;
  flex-direction:column;
  overflow:hidden;
  z-index:999;
}

.lang-dropdown a{
  padding:10px 14px;
  font-size:.85rem;
  color:var(--text);
  transition:var(--transition);
}

.lang-dropdown a:hover{
  background:var(--primary-soft);
  color:var(--primary);
}

/* Mobile Language List */
.nav-lang-mobile {
  display:flex;
  flex-direction:column;
  gap:6px;
  margin-top:8px;
}

.nav-lang-mobile a{
  padding:6px 0;
  font-size:.9rem;
  color:var(--primary);
}


  /* ===========================
     GLOBAL RESPONSIVE
     =========================== */

  /* Tablet landscape / small desktop */
  @media (max-width: 1024px){
    section{padding:72px 0;}
    .nav{gap:16px;}
    .projects-header{gap:16px;}
  }

  /* Tablet landscape (termasuk iPad Air 820px) */
@media (max-width: 900px){
  /* nav pakai burger */
  .nav-links,
  .nav-cta{
    display:none;
  }
  .nav-toggle{
    display:flex;
  }
}

/* Tablet & hp – layout umum */
@media (max-width: 768px){
  .container{padding:0 14px;}
  section{padding:64px 0;}

  /* topbar jadi kolom */
  .topbar-inner{
    flex-direction:column;
    align-items:flex-start;
  }





  /* about, contact, projects header */
  .about-grid{
    grid-template-columns:minmax(0,1fr);
    gap:28px;
  }
  .contact-grid{
    grid-template-columns:minmax(0,1fr);
    gap:24px;
  }
  .projects-header{
    flex-direction:column;
    align-items:flex-start;
  }
  .projects-header-text{
    max-width:none;
  }

  .stats-strip{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }

  /* footer */
  .footer-inner{
    flex-direction:column;
    align-items:flex-start;
  }
}


  /* HP kecil */
  @media (max-width: 480px){
    .container{padding:0 12px;}
    section{padding:56px 0;}
    .hero{padding:56px 0 64px;}
    .hero-title{font-size:2.1rem;}

    .hero-actions{
      flex-direction:column;
      align-items:stretch;
    }
    .hero-actions .btn,
    .hero-actions .btn-outline{
      width:100%;
      justify-content:center;
    }

    .stats-strip{
      grid-template-columns:minmax(0,1fr);
    }

    .section-title{font-size:1.6rem;}
    .projects-header{align-items:flex-start;}

    .hero-content {
        position: relative;
        z-index: 10;
        color: #fff;
        max-width: 100%;
        padding: 30px;
        padding-top: 30%;
    }

    .hero-content h1 {
        font-size: 2rem;
        font-weight: 700;
        margin-bottom: 20px;
        line-height: 1. 8rem;
    }

    .hero-content p {
        font-size: 1.2rem;
        opacity: 0.95;
        margin-bottom: 25px;
    }

    .contact-pin-card{
      margin-left:6px;
      padding:8px 10px;
      border-radius:8px;
      background:rgba(15,23,42,.92);
      border:1px solid rgba(148,163,184,.5);
      box-shadow:0 10px 30px rgba(0,0,0,.6);
      font-size:.78rem;
    }
    .contact-pin-name{
      font-weight:700;
      text-transform:uppercase;
      font-size:.78rem;
      letter-spacing:.08em;
      color:#f9fafb;
      margin-bottom:2px;
    }
    .contact-pin-text{
      color:#d1d5db;
      font-size:.6rem;
    }

    /* contoh koordinat (atur sesuai kebutuhan) */
    .contact-pin--hq{   /* misal: Surabaya / HQ */
      top:100%;
      left:52%;
    }
    .contact-pin--yard1{ /* misal: Jakarta */
      top:65%;
      left:32%;
    }
    .contact-pin--yard2{ /* misal: Batam */
      top:90%;
      left:37%;
    }
  }