
:root{--accent:#00D1B2;--accent2:#7C3AED;--accent3:#F59E0B;--black:#111111;--charcoal:#1a1a1a;--offwhite:#f4f2ef;--panel:#ffffff;--muted:#6b6b6b;--line:#d9d9d9;
  --radius:18px;--shadow:0 10px 30px rgba(0,0,0,.08);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:var(--offwhite);color:#111;line-height:1.55}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.container{max-width:1120px;margin:0 auto;padding:0 18px;}

.topbar{background:linear-gradient(180deg,var(--charcoal),var(--black));color:#fff;border-bottom:1px solid rgba(255,255,255,.08);}
.header{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:16px 0;}
.brand{display:flex;align-items:center;gap:14px;min-width:0;}
.brand img{width:54px;height:54px;border-radius:14px;object-fit:cover;background:#000;}
.brand .t strong{font-size:18px;letter-spacing:.2px;display:block}
.brand .t span{font-size:13px;color:rgba(255,255,255,.75);}

.menu-btn{display:none;align-items:center;gap:10px;border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.08);color:#fff;
  padding:10px 12px;border-radius:999px;font-weight:900;font-size:13px;cursor:pointer;
}
.menu-btn svg{width:18px;height:18px}

.nav{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end;}
.nav a{padding:10px 12px;border-radius:999px;border:1px solid rgba(255,255,255,.14);color:#fff;font-weight:800;font-size:13px}
.nav a:hover{background:rgba(255,255,255,.08)}
.nav a.active{background:#fff;color:#111;border-color:#fff}

@media (max-width: 860px){
  .menu-btn{display:inline-flex;}
  .nav{display:none;flex-direction:column;align-items:stretch;gap:10px;padding:14px 0 6px;justify-content:flex-start;}
  .nav.open{display:flex;}
  .nav a{border-radius:14px;text-align:left;padding:12px 12px;}
  .header{flex-wrap:wrap;align-items:flex-start;}
}

.hero{padding:22px 0 26px;border-top:1px solid rgba(255,255,255,.08);}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:18px;align-items:stretch}
.h1{font-size:40px;line-height:1.12;margin:0 0 10px;}
.lead{margin:0 0 16px;color:rgba(255,255,255,.82);font-size:16px;}
.cta-row{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.btn{display:inline-flex;align-items:center;justify-content:center;padding:12px 16px;border-radius:14px;font-weight:900;border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.08);color:#fff;min-height:46px;
}
.btn.primary{background:#fff;color:#111;border-color:#fff}
.btn:active{transform:translateY(1px)}
.badges{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}
.badge{padding:8px 10px;border-radius:999px;border:1px solid rgba(255,255,255,.16);color:rgba(255,255,255,.85);font-size:12px}

.hero-card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:calc(var(--radius) + 6px);overflow:hidden;}
.hero-card .inner{padding:14px;}
.hero-card h3{margin:0 0 8px;font-size:14px;}
.hero-card p{margin:0;color:rgba(255,255,255,.82);font-size:13px;}
.hero-card .photo{height:240px;background:#0f0f0f;}
.hero-card .photo img{width:100%;height:100%;object-fit:cover;opacity:.92;}

/* Homepage hero portfolio strip (tight & premium) */
.hero-media .inner{display:flex;flex-direction:column;gap:8px;}
.hero-media .inner .btn{align-self:flex-start;}
.hero-strip{
  padding:10px;
  display:flex;
  gap:12px;
  background:rgba(0,0,0,.12);
  border-bottom:1px solid rgba(255,255,255,.10);
}
.hero-strip .shot{
  flex:1;
  min-width:0;
  display:block;
  position:relative;
  overflow:hidden;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.12);
  height:150px;
  background:#0c0c0c;
  box-shadow:0 10px 22px rgba(0,0,0,.35), inset 0 0 0 1px rgba(0,0,0,.25);
}
.hero-strip .shot::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,.02) 0%, rgba(0,0,0,.55) 100%);
  opacity:.9;
  pointer-events:none;
}
.hero-strip .shot img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transform:scale(1.02);
  opacity:.96;
  transition:transform .35s ease, opacity .35s ease;
}
.hero-strip .shot:hover img{transform:scale(1.07);opacity:1;}
.hero-strip .shot .shot-label{
  position:absolute;
  left:12px;
  bottom:12px;
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 10px;
  border-radius:999px;
  font-size:12px;
  font-weight:650;
  letter-spacing:.2px;
  color:rgba(255,255,255,.92);
  background:rgba(0,0,0,.38);
  border:1px solid rgba(255,255,255,.14);
  backdrop-filter:blur(10px);
}
@media (max-width: 860px){
  .hero-media .inner .btn{width:100%;}
  .hero-strip{padding:8px;gap:8px;}
  .hero-strip .shot{height:112px;border-radius:12px;}
}
@media (max-width: 560px){
  .hero-strip{overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;}
  .hero-strip .shot{flex:0 0 78%;scroll-snap-align:start;}
}




@media (max-width: 860px){
  .hero-grid{grid-template-columns:1fr;}
  .h1{font-size:32px;}
  .hero-card .photo{height:210px;}
}

.main{padding:18px 0 44px}
.section{background:var(--panel);border:1px solid var(--line);border-radius:calc(var(--radius) + 6px);box-shadow:var(--shadow);padding:22px;margin:16px 0}
.section h2{margin:0 0 12px;font-size:24px}
.section .sub{margin:0 0 16px;color:var(--muted)}

.grid{display:grid;grid-template-columns:repeat(12,1fr);gap:14px}
.col-6{grid-column:span 6} .col-4{grid-column:span 4} .col-8{grid-column:span 8} .col-12{grid-column:span 12}
@media (max-width: 860px){.col-6,.col-4,.col-8{grid-column:span 12}}

.service{border:1px solid var(--line);border-radius:var(--radius);padding:16px;background:linear-gradient(180deg,#fff,#fbfbfb)}
.service h3{margin:0 0 8px;font-size:16px} .service p{margin:0;color:var(--muted);font-size:14px}

.pricing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px}
.price-box{border:1px solid var(--line);border-radius:var(--radius);padding:16px;background:#fff}
.price-box h3{margin:0 0 8px;font-size:16px}
.price-box .price{font-size:22px;font-weight:950;margin:0 0 6px}
.price-box .note{margin:0;color:var(--muted);font-size:13px}

.hr-title{display:flex;align-items:center;gap:12px;margin:18px 0 12px}
.hr-title .pill{background:var(--black);color:#fff;padding:8px 12px;border-radius:999px;font-weight:950;font-size:12px;letter-spacing:.9px}
.hr-title .line{flex:1;height:1px;background:var(--line)}

.form{display:grid;gap:12px;max-width:680px}
.field label{display:block;font-weight:950;font-size:13px;margin-bottom:6px}
.field input,.field textarea,.field select{width:100%;border:1px solid var(--line);border-radius:14px;padding:12px;font-size:15px;background:#fff}
.field textarea{min-height:120px;resize:vertical}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media (max-width: 640px){.form .row{grid-template-columns:1fr}}

.footer{background:var(--black);color:rgba(255,255,255,.85);padding:26px 0;margin-top:20px}
.footer a{color:#fff;text-decoration:underline} .small{font-size:12px;color:rgba(255,255,255,.7)}

.whatsapp-fab{position:fixed;right:14px;bottom:14px;z-index:999;display:flex;align-items:center;gap:10px;background:#1f1f1f;color:#fff;border:1px solid rgba(255,255,255,.18);
  padding:12px 14px;border-radius:999px;box-shadow:0 18px 40px rgba(0,0,0,.18);}
.whatsapp-fab:hover{background:#2a2a2a} .whatsapp-fab svg{width:18px;height:18px}

.reviews{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px}
.review{border:1px solid var(--line);border-radius:var(--radius);padding:16px;background:#fff}
.stars{letter-spacing:2px;font-size:14px;margin-bottom:8px} .review p{margin:0 0 10px;color:var(--muted)} .review strong{display:block;font-size:13px}

.map-wrap iframe{width:100%;height:340px;border:0;border-radius:var(--radius)}
@media (max-width: 640px){.map-wrap iframe{height:300px;}}

.slider{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:#fff}
.ba{position:relative;width:100%;aspect-ratio:16/9;min-height:240px;background:#f0f0f0}
.ba img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover} .ba .after{clip-path:inset(0 0 0 50%)}
.ba .handle{position:absolute;top:0;bottom:0;left:50%;width:2px;background:#fff;box-shadow:0 0 0 1px rgba(0,0,0,.15)}
.ba .knob{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#fff;border:1px solid rgba(0,0,0,.15);border-radius:999px;padding:8px 10px;font-weight:950;font-size:12px}
.ba input{position:absolute;inset:0;width:100%;height:100%;opacity:0;cursor:ew-resize}

.home-logo{display:flex;gap:14px;align-items:center;margin:10px 0 4px;}
.home-logo img{width:84px;height:84px;border-radius:18px;object-fit:cover;border:1px solid rgba(255,255,255,.18);}
.home-logo .meta{font-weight:950;letter-spacing:.2px}


/* --- Modern + quirky extras --- */
.badge{border-color: rgba(255,255,255,.22)!important;}
.badge:nth-child(1){background: rgba(0,209,178,.16);}
.badge:nth-child(2){background: rgba(124,58,237,.16);}
.badge:nth-child(3){background: rgba(245,158,11,.16);}

.section h2{position:relative;padding-bottom:10px;}
.section h2::after{
  content:"";
  position:absolute;left:0;bottom:0;width:84px;height:4px;border-radius:999px;
  background: linear-gradient(90deg, var(--accent), var(--accent2), var(--accent3));
}

.service, .price-box, .review{
  transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease;
}
.service:hover, .price-box:hover, .review:hover{
  transform: translateY(-2px);
  box-shadow: 0 14px 30px rgba(0,0,0,.10);
  border-color: rgba(0,209,178,.55);
}

.btn.primary{position:relative;border:2px solid transparent;}
.btn.primary::after{
  content:"";
  position:absolute;inset:-2px;border-radius:16px;
  background: linear-gradient(90deg, var(--accent), var(--accent2), var(--accent3));
  z-index:-1;
}

.hero-card{box-shadow: 0 20px 60px rgba(0,0,0,.16);}
.hero-card .inner{background: linear-gradient(180deg, rgba(0,209,178,.10), rgba(124,58,237,.08));}

.topbar{position:relative;overflow:hidden;}
.topbar::before{
  content:"";position:absolute;width:420px;height:420px;border-radius:999px;right:-180px;top:-220px;
  background: radial-gradient(circle at 30% 30%, rgba(0,209,178,.45), rgba(124,58,237,0));
  pointer-events:none;
}
.topbar::after{
  content:"";position:absolute;width:520px;height:520px;border-radius:999px;left:-260px;bottom:-320px;
  background: radial-gradient(circle at 60% 40%, rgba(245,158,11,.35), rgba(0,209,178,0));
  pointer-events:none;
}




/* --- Mobile polish: neater + more professional --- */
@media (max-width: 640px){
  body{line-height:1.5;}
  .container{padding:0 14px;}
  .header{padding:12px 0; gap:10px;}
  .brand img{width:44px;height:44px;border-radius:12px;}
  .brand .t strong{font-size:16px;}
  .brand .t span{font-size:12px;}

  .menu-btn{padding:9px 11px;font-size:12px;}
  .nav a{padding:11px 12px;font-size:13px;}

  .hero{padding:16px 0 18px;}
  .h1{font-size:28px;line-height:1.12;margin-bottom:8px;}
  .lead{font-size:14px;margin-bottom:10px;}
  .badges{gap:8px;margin-top:10px;}
  .badge{font-size:11px;padding:7px 9px;}

  .main{padding:12px 0 34px;}
  .section{
    padding:16px;
    margin:12px 0;
    border-radius:20px;
  }
  .section h2{font-size:20px;margin-bottom:10px;}
  .section .sub{font-size:13px;margin-bottom:12px;}

  .grid{gap:12px;}
  .pricing-grid{gap:12px;}
  .service,.price-box,.review{padding:14px;border-radius:18px;}
  .service h3,.price-box h3{font-size:15px;}
  .price-box .note,.service p,.review p{font-size:13px;}

  .btn{min-height:44px;width:100%;}
  /* keep hero quote buttons tidy */
  .hero .btn{width:100%;}
  .hero [style*="display:flex"]{gap:10px!important;}

  .map-wrap iframe{height:280px;}
  .whatsapp-fab{right:12px;bottom:12px;padding:10px 12px;}
  .whatsapp-fab span{display:none;} /* icon-only on small screens */
}

/* Slightly larger phones / small tablets */
@media (min-width: 641px) and (max-width: 860px){
  .container{padding:0 16px;}
  .hero{padding:18px 0 20px;}
  .h1{font-size:32px;}
  .section{padding:18px;margin:14px 0;}
}


/* Premium motion */
.reveal{opacity:0;transform:translateY(10px);transition:opacity .6s ease, transform .6s ease;}
.reveal.in-view{opacity:1;transform:none;}

/* Lightbox */
.lightbox{position:fixed;inset:0;display:none;align-items:center;justify-content:center;z-index:9999;padding:18px;}
.lightbox.open{display:flex;}
.lightbox .lb-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.72);backdrop-filter:blur(10px);}
.lightbox .lb-panel{position:relative;width:min(980px, 96vw);border-radius:18px;overflow:hidden;border:1px solid rgba(255,255,255,.14);box-shadow:0 30px 90px rgba(0,0,0,.55);background:#0b0b0b;}
.lightbox .lb-media{position:relative;aspect-ratio:16/10;background:#0b0b0b;}
.lightbox .lb-media img{width:100%;height:100%;object-fit:cover;display:block;}
.lightbox .lb-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;background:linear-gradient(180deg, rgba(10,10,10,.65), rgba(10,10,10,.92));}
.lightbox .lb-title{font-weight:650;font-size:14px;color:rgba(255,255,255,.9);}
.lightbox .lb-actions{display:flex;gap:10px;align-items:center;}
.lightbox .lb-btn{appearance:none;border:1px solid rgba(255,255,255,.16);background:rgba(255,255,255,.06);color:rgba(255,255,255,.92);padding:9px 12px;border-radius:999px;cursor:pointer;transition:transform .15s ease, background .2s ease;}
.lightbox .lb-btn:hover{background:rgba(255,255,255,.10);}
.lightbox .lb-btn:active{transform:scale(.98);}
.lightbox .lb-nav{position:absolute;inset:0;display:flex;align-items:center;justify-content:space-between;pointer-events:none;padding:0 10px;}
.lightbox .lb-nav button{pointer-events:auto;}

/* --- Scrolling reliability (mobile-first) --- */
html{
  -webkit-text-size-adjust:100%;
  text-size-adjust:100%;
}
body{
  overflow-y:auto;
  overflow-x:hidden;
  position:relative;
}

/* Ensure the header is never sticky/fixed on any device */
.topbar{
  position:relative !important;
  top:auto !important;
}
/* Prevent overscroll "rubber band" from feeling janky around fixed UI */
@supports (overscroll-behavior: contain){
  html{overscroll-behavior-y:auto;}
  .lightbox{overscroll-behavior:contain;}
}

@media (max-width: 768px){
  .hero-strip{gap:10px;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;}
  .hero-strip .shot{flex:0 0 82%;scroll-snap-align:start;height:190px;}
  .hero-strip::-webkit-scrollbar{height:8px;}
  .hero-strip::-webkit-scrollbar-thumb{background:rgba(255,255,255,.14);border-radius:99px;}
}

