:root{
  --black:#04080f;
  --dark:#070d18;
  --card:#0c1525;
  --yellow:#1a6fd4;
  --yellow2:#1560bf;
  --white:#e8f0fe;
  --muted:#6b84a8;
  --border:#152040;
  --radius:14px;
  --blue:#1a6fd4;
  --blue2:#1560bf;
  --blue-glow:rgba(26,111,212,.35);
  --blue-soft:rgba(26,111,212,.12);
}
*{box-sizing:border-box;margin:0;padding:0;scroll-behavior:smooth;}
body{font-family:'DM Sans',sans-serif;background:var(--black);color:var(--white);overflow-x:hidden;}

/* ─── SCROLLBAR ─── */
::-webkit-scrollbar{width:4px;}
::-webkit-scrollbar-track{background:var(--black);}
::-webkit-scrollbar-thumb{background:var(--yellow);border-radius:4px;}

nav{position:fixed;top:0;left:0;right:0;z-index:999;display:flex;align-items:center;justify-content:space-between;padding:14px 60px;transition:background .3s,backdrop-filter .3s;}
nav.scrolled{background:rgba(4,8,15,.9);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);}
.nav-logo{display:flex;align-items:center;text-decoration:none;}
.nav-logo img{
  height:44px;          /* tinggi standar logo navbar web = 40–48px */
  width:auto;
  max-width:160px;      /* batas lebar */
  object-fit:contain;
  display:block;
}
/* Fallback teks jika gambar belum diisi */
.nav-logo .logo-fallback{
  font-family:'Bebas Neue',sans-serif;
  font-size:26px;letter-spacing:3px;
  color:#fff;
  display:flex;align-items:center;gap:2px;
}
.nav-logo .logo-fallback span{color:var(--blue);}
.nav-links{display:flex;gap:32px;list-style:none;}
.nav-links a{font-size:13px;font-weight:500;color:var(--muted);text-decoration:none;letter-spacing:.5px;text-transform:uppercase;transition:color .2s;}
.nav-links a:hover{color:var(--white);}
.nav-cta{background:var(--blue);color:#fff;padding:10px 24px;border-radius:30px;font-size:13px;font-weight:600;text-decoration:none;transition:transform .2s,box-shadow .2s;}
.nav-cta:hover{transform:translateY(-2px);box-shadow:0 6px 24px var(--blue-glow);}
.nav-burger{display:none;flex-direction:column;gap:5px;cursor:pointer;}
.nav-burger span{width:24px;height:2px;background:var(--white);border-radius:2px;transition:.3s;}

/* ─── HERO ─── */
#hero{min-height:100vh;display:grid;grid-template-columns:1fr 1fr;align-items:center;padding:120px 60px 80px;gap:60px;position:relative;overflow:hidden;}
#hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 60% 80% at 70% 50%,rgba(26,111,212,.1),transparent 70%);pointer-events:none;}
.hero-tag{display:inline-flex;align-items:center;gap:8px;background:rgba(245,196,0,.1);border:1px solid rgba(245,196,0,.25);padding:6px 14px;border-radius:20px;font-size:12px;font-weight:500;color:var(--yellow);letter-spacing:1px;text-transform:uppercase;margin-bottom:24px;}
.hero-tag::before{content:'';width:6px;height:6px;background:var(--yellow);border-radius:50%;}
.hero-title{font-family:'Bebas Neue',sans-serif;font-size:clamp(52px,7vw,96px);line-height:.95;letter-spacing:1px;margin-bottom:24px;}
.hero-title em{font-family:'DM Sans',sans-serif;font-style:italic;font-weight:300;color:var(--yellow);}
.hero-desc{font-size:15px;color:var(--muted);line-height:1.8;max-width:440px;margin-bottom:40px;}
.hero-btns{display:flex;gap:16px;align-items:center;flex-wrap:wrap;}
.btn-primary{display:inline-flex;align-items:center;gap:10px;background:var(--blue);color:#fff;padding:14px 28px;border-radius:30px;font-size:14px;font-weight:700;text-decoration:none;transition:all .2s;}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 28px var(--blue-glow);}
.btn-primary .arrow{width:28px;height:28px;background:rgba(255,255,255,.2);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;}
.btn-ghost{font-size:14px;font-weight:500;color:var(--muted);text-decoration:none;display:flex;align-items:center;gap:6px;transition:color .2s;}
.btn-ghost:hover{color:var(--white);}
.hero-stats{display:flex;gap:32px;margin-top:48px;}
.stat{display:flex;flex-direction:column;gap:4px;}
.stat-num{font-family:'Bebas Neue',sans-serif;font-size:36px;color:var(--yellow);letter-spacing:1px;}
.stat-label{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;}

.hero-right{position:relative;}
.hero-img-wrap{position:relative;border-radius:20px;overflow:hidden;aspect-ratio:4/5;}
.hero-img-wrap img{width:100%;height:100%;object-fit:cover;}
.hero-img-wrap .overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(10,10,10,.6),transparent 50%);}
.hero-badge{position:absolute;bottom:28px;left:28px;right:28px;background:rgba(4,8,15,.75);backdrop-filter:blur(12px);border:1px solid rgba(26,111,212,.3);border-radius:12px;padding:16px 20px;display:flex;align-items:center;justify-content:space-between;}
.hero-badge-text{font-size:14px;font-weight:600;}
.hero-badge-text span{display:block;font-size:12px;color:var(--muted);font-weight:400;margin-top:2px;}
.hero-badge-icon{width:44px;height:44px;background:var(--blue);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:22px;}

/* Floating cards */
.float-card{position:absolute;background:rgba(22,22,22,.9);backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:12px;padding:12px 16px;animation:float 4s ease-in-out infinite;}
.float-card:nth-child(1){top:20px;right:-20px;animation-delay:0s;}
.float-card:nth-child(2){top:40%;right:-30px;animation-delay:2s;}
@keyframes float{0%,100%{transform:translateY(0);}50%{transform:translateY(-10px);}}
.float-card .fc-label{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;}
.float-card .fc-val{font-size:15px;font-weight:700;color:var(--yellow);}

/* ─── MARQUEE ─── */
.marquee-wrap{border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:16px 0;overflow:hidden;white-space:nowrap;background:var(--dark);}
.marquee-inner{display:inline-flex;gap:48px;animation:marquee 20s linear infinite;}
.marquee-item{font-family:'Bebas Neue',sans-serif;font-size:22px;letter-spacing:2px;color:var(--muted);display:flex;align-items:center;gap:20px;}
.marquee-item .dot{width:8px;height:8px;background:var(--yellow);border-radius:50%;flex-shrink:0;}
@keyframes marquee{from{transform:translateX(0);}to{transform:translateX(-50%);}}

/* ─── SECTION BASE ─── */
section{padding:100px 60px;}
.section-tag{display:inline-flex;align-items:center;gap:8px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:2px;color:var(--yellow);margin-bottom:16px;}
.section-tag::before{content:'';width:20px;height:2px;background:var(--yellow);}
.section-title{font-family:'Bebas Neue',sans-serif;font-size:clamp(36px,5vw,64px);line-height:1;margin-bottom:16px;}
.section-title em{color:var(--yellow);font-style:italic;font-family:'DM Sans',sans-serif;font-weight:300;}
.section-sub{font-size:15px;color:var(--muted);line-height:1.8;max-width:520px;}

/* ─── SERVICES ─── */
#services{background:var(--dark);}
.services-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:56px;flex-wrap:wrap;gap:24px;}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
.service-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:32px;transition:all .3s;cursor:default;position:relative;overflow:hidden;}
.service-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--yellow);transform:scaleX(0);transform-origin:left;transition:transform .3s;}
.service-card:hover{border-color:rgba(245,196,0,.3);transform:translateY(-4px);}
.service-card:hover::after{transform:scaleX(1);}
.service-icon{width:52px;height:52px;background:rgba(245,196,0,.1);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:24px;margin-bottom:20px;}
.service-name{font-family:'Bebas Neue',sans-serif;font-size:24px;letter-spacing:.5px;margin-bottom:10px;}
.service-desc{font-size:13px;color:var(--muted);line-height:1.7;}
.service-arrow{margin-top:20px;color:var(--yellow);font-size:20px;display:block;transition:transform .2s;}
.service-card:hover .service-arrow{transform:translateX(6px);}

/* ─── PORTFOLIO ─── */
#portfolio{background:var(--black);}
.portfolio-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:40px;flex-wrap:wrap;gap:24px;}
.filter-tabs{display:flex;gap:8px;flex-wrap:wrap;}
.ftab{padding:8px 18px;border-radius:20px;border:1px solid var(--border);background:none;color:var(--muted);font-size:13px;font-weight:500;cursor:pointer;font-family:'DM Sans',sans-serif;transition:all .2s;}
.ftab.active,.ftab:hover{background:var(--blue);color:#fff;border-color:var(--blue);}

/* Grid uniform — semua kotak sama persis */
.portfolio-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:16px;
}
.porto-item{
  border-radius:var(--radius);overflow:hidden;
  position:relative;cursor:zoom-in;
  aspect-ratio:1/1; /* kotak sempurna */
  background:var(--card);
}
/* pastikan tidak ada tall/wide lagi */
.porto-item.tall,.porto-item.wide{
  grid-row:unset!important;grid-column:unset!important;
  aspect-ratio:1/1!important;
}
.porto-img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease;}
.porto-item:hover .porto-img{transform:scale(1.07);}
.porto-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(4,8,15,.9) 0%,rgba(4,8,15,.3) 55%,transparent 100%);
  opacity:0;transition:opacity .3s;
}
.porto-item:hover .porto-overlay{opacity:1;}
.porto-info{
  position:absolute;bottom:0;left:0;right:0;
  padding:18px 20px;
  transform:translateY(12px);opacity:0;transition:all .3s;
}
.porto-item:hover .porto-info{transform:translateY(0);opacity:1;}
.porto-cat{font-size:10px;color:var(--blue);text-transform:uppercase;letter-spacing:1.5px;font-weight:700;margin-bottom:3px;}
.porto-name{font-family:'Bebas Neue',sans-serif;font-size:18px;letter-spacing:.5px;color:#fff;line-height:1.2;}

/* Zoom icon — ikon mata */
.porto-zoom{
  position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%) scale(0);
  width:52px;height:52px;border-radius:50%;
  background:rgba(255,255,255,.15);backdrop-filter:blur(8px);
  border:2px solid rgba(255,255,255,.4);
  display:flex;align-items:center;justify-content:center;
  font-size:22px;
  transition:transform .3s cubic-bezier(.175,.885,.32,1.275), opacity .3s;
  opacity:0;color:#fff;
  pointer-events:none;
}
.porto-item:hover .porto-zoom{
  opacity:1;
  transform:translate(-50%,-50%) scale(1);
}

/* ── LIGHTBOX ── */
#lightbox{
  position:fixed;inset:0;z-index:9997;
  background:rgba(4,8,15,.96);backdrop-filter:blur(12px);
  display:none;align-items:center;justify-content:center;
  padding:20px;
}
#lightbox.open{display:flex;}
.lb-inner{
  position:relative;max-width:900px;width:100%;
  animation:lbIn .3s cubic-bezier(.175,.885,.32,1.275);
}
@keyframes lbIn{from{opacity:0;transform:scale(.9);}to{opacity:1;transform:scale(1);}}
#lbImg{
  width:100%;max-height:80vh;object-fit:contain;
  border-radius:16px;display:block;
  box-shadow:0 32px 80px rgba(0,0,0,.6);
}
.lb-close{
  position:absolute;top:-16px;right:-16px;
  width:40px;height:40px;border-radius:50%;
  background:var(--blue);color:#fff;border:none;
  font-size:18px;cursor:pointer;display:flex;
  align-items:center;justify-content:center;
  transition:transform .2s,background .2s;
  box-shadow:0 4px 16px rgba(0,0,0,.4);
}
.lb-close:hover{transform:scale(1.1);background:var(--blue2);}
.lb-caption{
  text-align:center;margin-top:16px;
}
.lb-caption-cat{font-size:11px;color:var(--blue);text-transform:uppercase;letter-spacing:1.5px;font-weight:700;margin-bottom:4px;}
.lb-caption-name{font-family:'Bebas Neue',sans-serif;font-size:22px;letter-spacing:.5px;}
.lb-nav{
  position:absolute;top:50%;transform:translateY(-50%);
  width:44px;height:44px;border-radius:50%;
  background:rgba(255,255,255,.1);backdrop-filter:blur(6px);
  border:1px solid rgba(255,255,255,.15);color:#fff;
  font-size:20px;cursor:pointer;display:flex;
  align-items:center;justify-content:center;
  transition:all .2s;
}
.lb-nav:hover{background:var(--blue);border-color:var(--blue);}
.lb-prev{left:-56px;}
.lb-next{right:-56px;}
.lb-counter{
  position:absolute;bottom:-40px;left:50%;transform:translateX(-50%);
  font-size:12px;color:var(--muted);
  font-family:'Bebas Neue',sans-serif;letter-spacing:2px;
}
/* ── VISITOR BADGE ── */
#visitorBadge{
  position:fixed;bottom:100px;left:24px;z-index:999;
  background:rgba(4,8,15,.85);backdrop-filter:blur(10px);
  border:1px solid var(--border);border-radius:30px;
  padding:8px 16px;font-size:12px;color:var(--muted);
  display:flex;align-items:center;gap:8px;
  opacity:0;transform:translateY(10px);
  transition:opacity .4s,transform .4s;
  pointer-events:none;
}
#visitorBadge.show{opacity:1;transform:translateY(0);}
.vb-dot{
  width:8px;height:8px;border-radius:50%;
  background:#10b981;flex-shrink:0;
  animation:vbPulse 1.8s ease-in-out infinite;
}
@keyframes vbPulse{0%,100%{box-shadow:0 0 0 0 rgba(16,185,129,.4);}50%{box-shadow:0 0 0 5px rgba(16,185,129,0);}}
#vbCount{font-weight:700;color:var(--white);}

@media(max-width:768px){
  .lb-prev{left:8px;}
  .lb-next{right:8px;}
  #visitorBadge{left:12px;bottom:90px;font-size:11px;}
}

/* ─── HOW WE WORK ─── */
#process{background:var(--dark);}
.process-wrap{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;}
.process-steps{display:flex;flex-direction:column;gap:0;}
.step{display:flex;gap:24px;padding:28px 0;border-bottom:1px solid var(--border);position:relative;cursor:default;}
.step:last-child{border-bottom:none;}
.step-num{font-family:'Bebas Neue',sans-serif;font-size:48px;color:rgba(245,196,0,.15);line-height:1;transition:color .3s;flex-shrink:0;width:60px;}
.step:hover .step-num{color:var(--yellow);}
.step-content{}
.step-name{font-family:'Bebas Neue',sans-serif;font-size:22px;letter-spacing:.5px;margin-bottom:8px;}
.step-desc{font-size:13px;color:var(--muted);line-height:1.7;}
.step-icon{width:36px;height:36px;background:rgba(245,196,0,.1);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:18px;margin-bottom:10px;}
.process-right{position:relative;}
.process-img{width:100%;border-radius:20px;aspect-ratio:4/5;object-fit:cover;}
.process-card{position:absolute;bottom:32px;right:-24px;background:var(--black);border:1px solid var(--border);border-radius:14px;padding:20px 24px;min-width:200px;}
.process-card-title{font-size:12px;color:var(--muted);margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px;}
.process-card-items{display:flex;flex-direction:column;gap:6px;}
.pci{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:500;}
.pci::before{content:'✓';color:var(--yellow);font-size:12px;font-weight:700;}

/* ─── TESTIMONIAL ─── */
#testimonials{background:var(--black);}
.testi-head{text-align:center;margin-bottom:56px;}
.testi-head .section-sub{margin:0 auto;}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
.testi-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:28px;transition:transform .3s;}
.testi-card:hover{transform:translateY(-4px);}
.testi-stars{color:var(--yellow);font-size:14px;letter-spacing:2px;margin-bottom:16px;}
.testi-text{font-size:14px;color:var(--muted);line-height:1.8;margin-bottom:20px;font-style:italic;}
.testi-author{display:flex;align-items:center;gap:12px;}
.testi-avatar{width:44px;height:44px;border-radius:50%;background:var(--yellow);display:flex;align-items:center;justify-content:center;font-weight:700;color:var(--black);font-size:16px;flex-shrink:0;}
.testi-name{font-weight:600;font-size:14px;}
.testi-loc{font-size:12px;color:var(--muted);}

/* ─── BOOKING ─── */
#booking{background:linear-gradient(135deg,var(--dark) 0%,#050c1a 100%);position:relative;overflow:hidden;}
#booking::before{content:'';position:absolute;top:-100px;right:-100px;width:400px;height:400px;background:radial-gradient(circle,rgba(26,111,212,.1),transparent 70%);pointer-events:none;}
.booking-wrap{display:grid;grid-template-columns:1fr 1.2fr;gap:80px;align-items:center;}
.booking-info{}
.booking-info .section-sub{margin-bottom:32px;}
.booking-perks{display:flex;flex-direction:column;gap:14px;}
.perk{display:flex;align-items:center;gap:14px;font-size:14px;font-weight:500;}
.perk-icon{width:40px;height:40px;background:rgba(245,196,0,.1);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;}

.booking-form{background:var(--card);border:1px solid var(--border);border-radius:20px;padding:40px;}
.booking-form h3{font-family:'Bebas Neue',sans-serif;font-size:28px;letter-spacing:.5px;margin-bottom:6px;}
.booking-form p{font-size:13px;color:var(--muted);margin-bottom:28px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px;}
.form-group{display:flex;flex-direction:column;gap:6px;}
.form-group.full{grid-column:1/-1;}
.form-group label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);}
.form-group input,.form-group select,.form-group textarea{background:#1e1e1e;border:1px solid var(--border);border-radius:8px;padding:12px 14px;color:var(--white);font-family:'DM Sans',sans-serif;font-size:14px;outline:none;transition:border-color .2s;resize:none;}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--yellow);}
.form-group select option{background:#1e1e1e;}
.submit-btn{width:100%;background:var(--blue);color:#fff;border:none;border-radius:30px;padding:15px;font-size:15px;font-weight:700;cursor:pointer;font-family:'DM Sans',sans-serif;transition:all .2s;margin-top:8px;display:flex;align-items:center;justify-content:center;gap:8px;}
.submit-btn:hover{transform:translateY(-2px);box-shadow:0 8px 28px var(--blue-glow);}

/* Success state */
.booking-success{display:none;text-align:center;padding:40px 20px;}
.booking-success .success-icon{font-size:56px;margin-bottom:16px;}
.booking-success h3{font-family:'Bebas Neue',sans-serif;font-size:28px;margin-bottom:8px;}
.booking-success p{font-size:14px;color:var(--muted);line-height:1.7;}

/* ─── FOOTER ─── */
footer{background:var(--dark);border-top:1px solid var(--border);padding:60px 60px 32px;}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px;}
.footer-brand{}
.footer-logo{font-family:'Bebas Neue',sans-serif;font-size:32px;color:var(--yellow);letter-spacing:2px;margin-bottom:14px;}
.footer-tagline{font-size:13px;color:var(--muted);line-height:1.8;max-width:260px;margin-bottom:20px;}
.footer-socials{display:flex;gap:12px;}
.social-btn{width:38px;height:38px;border:1px solid var(--border);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:16px;text-decoration:none;transition:all .2s;}
.social-btn:hover{background:var(--yellow);border-color:var(--yellow);transform:translateY(-2px);}
.footer-col h4{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--white);margin-bottom:16px;}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:10px;}
.footer-col ul li a{font-size:13px;color:var(--muted);text-decoration:none;transition:color .2s;}
.footer-col ul li a:hover{color:var(--yellow);}
.footer-bottom{border-top:1px solid var(--border);padding-top:24px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;}
.footer-bottom p{font-size:12px;color:var(--muted);}
.footer-bottom a{color:var(--yellow);text-decoration:none;}

/* ─── MOBILE MENU ─── */
.mobile-menu{position:fixed;inset:0;background:var(--black);z-index:998;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:32px;transform:translateX(100%);transition:transform .3s;}
.mobile-menu.open{transform:translateX(0);}
.mobile-menu a{font-family:'Bebas Neue',sans-serif;font-size:36px;letter-spacing:2px;text-decoration:none;color:var(--white);transition:color .2s;}
.mobile-menu a:hover{color:var(--yellow);}

/* ─── ANIMATIONS ─── */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .6s,transform .6s;}
.reveal.visible{opacity:1;transform:translateY(0);}

/* ─── MAP SECTION ─── */
#map-survey{background:var(--black);border-top:1px solid var(--border);}
.map-header{text-align:center;margin-bottom:48px;}
.map-header .section-sub{margin:0 auto 32px;}

#mapLeaflet{
  height:420px;border-radius:var(--radius);
  border:1px solid var(--border);
  display:none;margin-top:24px;
  overflow:hidden;
  box-shadow:0 8px 40px rgba(0,0,0,.4);
}

.map-open-btn{
  display:flex;align-items:center;gap:10px;
  background:var(--blue);color:#fff;
  padding:14px 32px;border-radius:30px;
  font-size:15px;font-weight:700;cursor:pointer;
  border:none;font-family:'DM Sans',sans-serif;
  margin:0 auto;transition:all .2s;
}
.map-open-btn:hover{transform:translateY(-2px);box-shadow:0 8px 28px var(--blue-glow);}

.location-search{
  position:relative;max-width:600px;margin:24px auto 0;
  display:none;
}
.location-search input{
  width:100%;background:#1e1e1e;
  border:1px solid var(--border);border-radius:10px;
  padding:14px 18px 14px 44px;
  color:var(--white);font-family:'DM Sans',sans-serif;
  font-size:14px;outline:none;transition:border-color .2s;
}
.location-search input:focus{border-color:var(--yellow);}
.location-search::before{
  content:'🔍';position:absolute;left:14px;top:50%;
  transform:translateY(-50%);font-size:16px;z-index:1;
  pointer-events:none;
}
.search-results{
  position:absolute;top:calc(100% + 6px);left:0;right:0;
  background:#1e1e1e;border:1px solid var(--border);
  border-radius:10px;list-style:none;
  max-height:240px;overflow-y:auto;z-index:1000;
  box-shadow:0 8px 32px rgba(0,0,0,.5);
}
.search-results li{
  padding:12px 16px;font-size:13px;cursor:pointer;
  border-bottom:1px solid var(--border);color:var(--muted);
  transition:background .15s,color .15s;
  line-height:1.4;
}
.search-results li:last-child{border-bottom:none;}
.search-results li:hover{background:rgba(245,196,0,.08);color:var(--white);}

/* Result box */
#surveyResult{max-width:600px;margin:20px auto 0;}
.survey-result-free,.survey-result-paid{
  border-radius:var(--radius);padding:24px 28px;
  animation:fadeUp .4s ease;
}
.survey-result-free{
  background:rgba(16,185,129,.1);
  border:1px solid rgba(16,185,129,.3);
}
.survey-result-paid{
  background:rgba(245,196,0,.07);
  border:1px solid rgba(245,196,0,.25);
}
.survey-result-free h3{color:#10b981;font-family:'Bebas Neue',sans-serif;font-size:24px;margin-bottom:8px;}
.survey-result-paid h3{color:var(--yellow);font-family:'Bebas Neue',sans-serif;font-size:24px;margin-bottom:8px;}
.survey-result-free p,.survey-result-paid p{font-size:14px;color:var(--muted);margin-bottom:4px;line-height:1.6;}
.survey-result-free strong,.survey-result-paid strong{color:var(--white);}
.result-note{font-size:12px;color:var(--muted);margin-top:8px;font-style:italic;}

/* Approval box */
#approvalBox{
  max-width:600px;margin:16px auto 0;
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--radius);padding:24px 28px;
  display:none;animation:fadeUp .4s ease;
}
.approval-label{
  display:flex;align-items:center;gap:10px;
  font-size:14px;color:var(--white);cursor:pointer;
  margin-bottom:16px;user-select:none;
}
.approval-label input{
  width:18px;height:18px;accent-color:var(--yellow);cursor:pointer;flex-shrink:0;
}
.offer-input{
  width:100%;background:#1e1e1e;
  border:1px solid var(--border);border-radius:8px;
  padding:12px 14px;color:var(--white);
  font-family:'DM Sans',sans-serif;font-size:14px;
  outline:none;margin-bottom:14px;
  transition:border-color .2s;
}
.offer-input:focus{border-color:var(--yellow);}
.btn-wa{
  width:100%;background:#25d366;color:#fff;
  padding:13px;border-radius:30px;
  font-size:14px;font-weight:700;cursor:pointer;
  border:none;font-family:'DM Sans',sans-serif;
  display:flex;align-items:center;justify-content:center;gap:8px;
  transition:all .2s;
}
.btn-wa:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px rgba(37,211,102,.35);}
.btn-wa:disabled{opacity:.4;cursor:not-allowed;}

/* Info strip */
.map-info-strip{
  display:flex;justify-content:center;gap:40px;flex-wrap:wrap;
  margin-bottom:32px;
}
.mis-item{display:flex;align-items:center;gap:10px;font-size:14px;}
.mis-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0;}
.mis-dot.green{background:#10b981;}
.mis-dot.yellow{background:var(--yellow);}

@keyframes fadeUp{from{opacity:0;transform:translateY(12px);}to{opacity:1;transform:translateY(0);}}

/* ─── RESPONSIVE ─── */
@media(max-width:1024px){
  #hero{grid-template-columns:1fr;padding:120px 32px 60px;}
  .hero-right{display:none;}
  section{padding:80px 32px;}
  .services-grid{grid-template-columns:1fr 1fr;}
  .portfolio-grid{grid-template-columns:repeat(2,1fr);}
  .porto-item.tall,.porto-item.wide{grid-column:1!important;grid-row:auto!important;}
  .testi-grid{grid-template-columns:1fr 1fr;}
  .booking-wrap{grid-template-columns:1fr;}
  .process-wrap{grid-template-columns:1fr;}
  .process-right{display:none;}
  footer{padding:60px 32px 32px;}
  .footer-grid{grid-template-columns:1fr 1fr;}
}
@media(max-width:768px){
  nav{padding:16px 24px;}
  .nav-links,.nav-cta{display:none;}
  .nav-burger{display:flex;}
  #hero{padding:100px 24px 60px;}
  .hero-title{font-size:52px;}
  .hero-stats{gap:20px;}
  section{padding:60px 24px;}
  .services-grid{grid-template-columns:1fr;}
  .portfolio-grid{grid-template-columns:1fr 1fr;}
  .porto-item.tall,.porto-item.wide{grid-column:1!important;grid-row:auto!important;}
  .testi-grid{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr;}
  .form-row{grid-template-columns:1fr;}
  .booking-form{padding:28px 20px;}
  footer{padding:40px 24px 24px;}
}