.elementor-1172 .elementor-element.elementor-element-5ec1121{--display:flex;--overlay-opacity:0.5;}.elementor-1172 .elementor-element.elementor-element-5ec1121:not(.elementor-motion-effects-element-type-background), .elementor-1172 .elementor-element.elementor-element-5ec1121 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#0E668C;}.elementor-1172 .elementor-element.elementor-element-5ec1121::before, .elementor-1172 .elementor-element.elementor-element-5ec1121 > .elementor-background-video-container::before, .elementor-1172 .elementor-element.elementor-element-5ec1121 > .e-con-inner > .elementor-background-video-container::before, .elementor-1172 .elementor-element.elementor-element-5ec1121 > .elementor-background-slideshow::before, .elementor-1172 .elementor-element.elementor-element-5ec1121 > .e-con-inner > .elementor-background-slideshow::before, .elementor-1172 .elementor-element.elementor-element-5ec1121 > .elementor-motion-effects-container > .elementor-motion-effects-layer::before{background-color:#053BF2;--background-overlay:'';}.elementor-1172 .elementor-element.elementor-element-1f2eaba{--display:flex;}.elementor-1172 .elementor-element.elementor-element-1f2eaba:not(.elementor-motion-effects-element-type-background), .elementor-1172 .elementor-element.elementor-element-1f2eaba > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#0C5784;}.elementor-1172 .elementor-element.elementor-element-0874fa6{--display:flex;}.elementor-1172 .elementor-element.elementor-element-0874fa6:not(.elementor-motion-effects-element-type-background), .elementor-1172 .elementor-element.elementor-element-0874fa6 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#0C5784;}.elementor-1172 .elementor-element.elementor-element-073f1f5{--display:flex;}.elementor-1172 .elementor-element.elementor-element-2950de7{--display:flex;}/* Start custom CSS for html, class: .elementor-element-3e3624e *//* --- MODERN DESKTOP REFINEMENT --- */
@media (min-width: 993px) {
  .nav-container {
    padding: 0 24px;
    height: 80px; /* Konsistensi tinggi navbar */
  }

  .nav-links {
    display: flex !important;
    gap: 4px;
    align-items: center;
    height: 100%;
  }

  .nav-links > li {
    position: relative;
    height: 100%;
    display: flex;
    align-items: center;
    min-width: auto; /* Reset dari style sebelumnya */
  }

  /* Styling link utama */
  .nav-links > li > a {
    padding: 10px 18px;
    font-size: 0.9rem;
    letter-spacing: 0.5px;
    text-transform: uppercase;
    transition: all 0.3s var(--ease);
  }

  .nav-links > li > a:hover {
    background: rgba(255, 255, 255, 0.05);
    color: var(--gold);
    transform: translateY(0); /* Matikan lompatan ke atas agar lebih elegan */
  }

  /* MODERNIZE SUBMENU (Hover Mode) */
  .submenu {
    position: absolute;
    top: 90%; /* Sedikit di bawah menu utama */
    left: 0;
    width: 480px; /* Ukuran box yang lebih proporsional */
    background: linear-gradient(160deg, rgba(7, 18, 74, 0.98), rgba(4, 10, 43, 1));
    backdrop-filter: blur(12px);
    border: 1px solid rgba(255, 255, 255, 0.08);
    padding: 24px;
    border-radius: 16px;
    box-shadow: 0 20px 50px rgba(0,0,0,0.5);
    
    /* Efek Animasi Sembunyi */
    display: block; /* Harus block untuk transisi */
    opacity: 0;
    visibility: hidden;
    transform: translateY(15px);
    transition: all 0.35s cubic-bezier(0.23, 1, 0.32, 1);
    pointer-events: none;
  }

  /* Tampilkan saat LI di-hover */
  .nav-links > li:hover .submenu {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
    pointer-events: auto;
  }

  /* Merapikan grid di dalam submenu */
  .submenu-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
  }

  .submenu .group h4 {
    color: var(--gold);
    border-bottom: 1px solid rgba(255,255,255,0.1);
    padding-bottom: 8px;
    margin-bottom: 12px;
    font-size: 0.85rem;
  }

  .submenu a {
    display: block;
    padding: 6px 0;
    font-size: 0.88rem;
    font-weight: 500;
    transition: color 0.2s ease;
  }

  .submenu a:hover {
    background: transparent;
    color: #fff;
    transform: translateX(5px); /* Geser sedikit ke kanan saat hover */
  }

  /* Cegah menu terakhir keluar layar */
  .nav-links > li:last-child .submenu {
    left: auto;
    right: 0;
  }
}

/* Penyesuaian Logo-Mark */
.logo-mark {
  width: 50px;
  height: 50px;
  overflow: hidden; /* Agar gambar tidak keluar dari border radius */
  border: 1px solid rgba(255,255,255,0.1);
}
/* --- MODERN & ELONGATED DESKTOP STYLE --- */
@media (min-width: 993px) {
  /* Memastikan container membagi ruang dengan adil */
  .nav-container {
    padding: 0 40px;
    max-width: 1400px; /* Lebih lebar untuk menampung teks panjang */
    display: flex;
    justify-content: space-between; 
    align-items: center;
  }

  .nav-left {
    display: flex;
    align-items: center;
    gap: 40px; /* Jarak antara teks brand dan menu pertama */
    flex: 1; 
  }

  /* Efek Tulisan Memanjang */
  .logo-text {
    font-size: 1.1rem;
    letter-spacing: 0.25em; /* Ini yang membuatnya terlihat memanjang/modern */
    text-transform: uppercase;
    white-space: nowrap; /* Memaksa satu baris */
    font-weight: 800;
    color: var(--muted);
  }

  /* Menu Items Refinement */
  .nav-links {
    display: flex !important;
    gap: 12px;
    margin: 0;
    padding: 0;
    list-style: none;
  }

  .nav-links > li {
    position: relative;
    padding: 25px 0; /* Memberikan area hover yang luas */
  }

  .nav-links > li > a {
    font-size: 0.85rem;
    font-weight: 600;
    letter-spacing: 1px;
    padding: 8px 16px;
    border-radius: 8px;
    transition: all 0.1s var(--ease);
  }

  .nav-links > li > a:hover {
    background: rgba(255, 255, 255, 0.05);
    color: var(--gold);
    transform: none; /* Menghilangkan lompatan agar lebih clean */
  }

  /* Submenu Positioning (Dropdown) */
  .submenu {
    position: absolute;
    top: 100%; /* Pas di bawah navbar */
    left: 0;
    width: 450px;
    background: rgba(7, 18, 74, 0.98);
    backdrop-filter: blur(15px);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 12px;
    padding: 20px;
    box-shadow: 0 20px 40px rgba(0,0,0,0.4);
    
    /* Animasi */
    display: block;
    opacity: 0;
    visibility: hidden;
    transform: translateY(10px);
    transition: all 0.1s ease;
    pointer-events: none;
  }

  .nav-links > li:hover .submenu {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
    pointer-events: auto;
  }

  /* Merapikan Submenu Grid */
  .submenu-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
  }

  /* Terakhir (Kontak) agar tidak keluar layar */
  .nav-links > li:last-child .submenu {
    left: auto;
    right: 0;
  }
}

/* Ukuran Kotak Logo */
.logo-mark {
  width: 48px;
  height: 48px;
  background: none; /* Hilangkan gradient jika menggunakan logo gambar */
  flex-shrink: 0;
}
@media (min-width: 993px) {
  .nav-container {
    padding: 0 40px;
    max-width: 1400px;
  }

  /* Label Menu Hilang */
  .hamburger-label {
    display: none;
  }

  /* Logo & Teks Memanjang */
  .logo-text {
    font-size: 1.1rem;
    letter-spacing: 0.25em; /* Efek memanjang modern */
    text-transform: uppercase;
    white-space: nowrap;
    font-weight: 800;
  }

  /* Penyesuaian jarak menu agar seimbang */
  .nav-links {
    display: flex !important;
    gap: 15px;
  }

  /* Submenu tetap berfungsi sebagai dropdown */
  .submenu {
    position: absolute;
    top: 100%;
    opacity: 0;
    visibility: hidden;
    transform: translateY(10px);
    transition: all 0.1s var(--ease);
    pointer-events: none;
    /* ... rest of your submenu styling ... */
  }

  .nav-links > li:hover .submenu {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
    pointer-events: auto;
  }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-99222c3 *//* =========================
   Theme variables
   ========================= */
:root{
  --blue-900: #07124a;
  --blue-800: #0b1b5a;
  --blue-700: #12306f;
  --gold: #ffd700;
  --muted-white: rgba(255,255,255,0.92);
  --muted-2: rgba(255,255,255,0.72);
  --glass: rgba(255,255,255,0.04);
  --radius: 14px;
  --max-width: 1200px;
  --ease: cubic-bezier(.2,.9,.2,1);
  --card-bg: linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0.01));
}

/* =========================
   Base reset
   ========================= */
*{box-sizing:border-box}
html,body{height:100%;margin:0;font-family:Inter, "Poppins", system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial;color:var(--muted-white);-webkit-font-smoothing:antialiased}
a{color:inherit}
img{display:block;max-width:100%;height:auto}

/* =========================
   Layout container
   ========================= */
.lp-container{max-width:var(--max-width);margin:36px auto;padding:28px}

/* =========================
   HERO
   ========================= */
.hero{
  display:grid;
  grid-template-columns: 1fr 520px;
  gap:32px;
  align-items:center;
  background:var(--card-bg);
  padding:28px;border-radius:var(--radius);
  border:1px solid rgba(255,255,255,0.03);
  box-shadow: 0 18px 50px rgba(2,6,23,0.45);
}
.kicker{display:inline-block;padding:6px 12px;border-radius:999px;background:rgba(255,215,80,0.08);color:var(--gold);font-weight:700;margin-bottom:12px}
.hero-title{font-family:'Playfair Display', serif;font-size:2.2rem;color:var(--gold);margin:0 0 12px}
.hero-lead{color:var(--muted-2);margin-bottom:18px;font-weight:600}
.hero-ctas{display:flex;gap:12px;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:10px;padding:12px 18px;border-radius:12px;font-weight:800;cursor:pointer;text-decoration:none;transition:transform 220ms var(--ease),box-shadow 220ms var(--ease)}
.btn.primary{background:linear-gradient(90deg,var(--gold), #ffd86b);color:var(--blue-900);box-shadow:0 12px 30px rgba(255,200,60,0.12)}
.btn.ghost{background:transparent;border:1px solid rgba(255,255,255,0.06);color:var(--muted-white)}
.btn:hover{transform:translateY(-4px)}
.trust-list{list-style:none;padding:12px 0 0;margin:0;color:var(--muted-2);font-weight:700}
.trust-list li{margin:6px 0}

/* HERO IMAGE */
.hero-right{position:relative;border-radius:12px;overflow:hidden;min-height:320px;display:flex;align-items:center;justify-content:center}
.hero-image{width:100%;height:100%;object-fit:cover;border-radius:10px}
.hero-caption{font-size:0.85rem;color:var(--muted-2);margin-top:8px;text-align:center}

/* =========================
   ABOUT
   ========================= */
.section{margin-top:40px}
.about{display:grid;grid-template-columns:1fr 420px;gap:28px;align-items:center}
.about-card{background:var(--card-bg);padding:20px;border-radius:12px;border:1px solid rgba(255,255,255,0.03);box-shadow:0 12px 30px rgba(2,6,23,0.35)}
.about-card h2{color:var(--gold);margin-bottom:8px}
.about-grid{display:flex;gap:12px;flex-wrap:wrap;margin-top:12px}
.about-item{min-width:160px;background:rgba(255,255,255,0.02);padding:12px;border-radius:10px;font-weight:700;color:var(--muted-white)}
.about-image{border-radius:12px;box-shadow:0 12px 30px rgba(2,6,23,0.35)}

/* =========================
   SERVICES
   ========================= */
.section-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}
.section-head .muted{color:var(--muted-2);font-weight:700}
.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px}
.service-card{background:var(--card-bg);padding:16px;border-radius:12px;border:1px solid rgba(255,255,255,0.03);transition:transform 220ms var(--ease),box-shadow 220ms var(--ease)}
.service-card:hover{transform:translateY(-8px);box-shadow:0 18px 40px rgba(2,6,23,0.45)}
.service-media{height:160px;overflow:hidden;border-radius:10px;margin-bottom:12px}
.service-card h3{color:var(--gold);margin:0 0 8px}
.service-card p{color:var(--muted-2);font-weight:600}

/* =========================
   GALLERY
   ========================= */
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.gallery-item{border-radius:10px;overflow:hidden;box-shadow:0 12px 30px rgba(2,6,23,0.35)}
.gallery-item img{width:100%;height:180px;object-fit:cover;transition:transform 260ms var(--ease)}
.gallery-item:hover img{transform:scale(1.05)}

/* =========================
   PROCESS
   ========================= */
.process{display:flex;gap:18px;flex-wrap:wrap;margin-top:18px}
.process-list{list-style:none;padding:0;margin:12px 0 0;display:flex;flex-direction:column;gap:12px}
.process-list li{background:rgba(255,255,255,0.02);padding:12px;border-radius:10px;border:1px solid rgba(255,255,255,0.03);font-weight:700;color:var(--muted-white)}
.process-list li span{display:block;color:var(--muted-2);font-weight:600;margin-top:6px}

/* =========================
   TESTIMONIALS
   ========================= */
.testi-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:12px}
.testi{background:var(--card-bg);padding:16px;border-radius:12px;border:1px solid rgba(255,255,255,0.03);font-style:italic;color:var(--muted-2)}
.testi cite{display:block;margin-top:12px;font-weight:800;color:var(--muted-white)}

/* =========================
   CONTACT CTA
   ========================= */
.contact-card{background:linear-gradient(90deg,var(--blue-700),var(--blue-800));padding:20px;border-radius:12px;border:1px solid rgba(255,255,255,0.03);display:flex;flex-direction:column;gap:12px}
.contact-actions{display:flex;gap:12px;flex-wrap:wrap}
.contact-meta{display:flex;gap:12px;flex-wrap:wrap;color:var(--muted-2);font-weight:700}

/* =========================
   Small note
   ========================= */
.small-note{font-size:0.9rem;color:var(--muted-2);margin-top:18px;text-align:center}

/* =========================
   Responsive
   ========================= */
@media (max-width:1100px){
  .hero{grid-template-columns:1fr 420px}
  .about{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:820px){
  .hero{grid-template-columns:1fr}
  .hero-right{order:-1}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .gallery-item img{height:160px}
  .process{flex-direction:column}
  .testi-grid{grid-template-columns:1fr}
}
@media (max-width:420px){
  .gallery-grid{grid-template-columns:1fr}
  .hero-title{font-size:1.6rem}
  .btn{padding:10px 14px}
  .hero-right{min-height:220px}
}

/* Accessibility focus */
a:focus, button:focus { outline: 3px solid rgba(255,215,0,0.12); outline-offset: 4px; border-radius:8px; }
.hero h1 {
    color: var(--gold); /* Menggunakan variabel emas yang sudah dibuat */
    /* Atau pakai kode warna manual */
    /* color: #FFD700; */
}/* End custom CSS */