:root{
  --bg:#14171a;
  --surface:#1c2024;
  --surface-2:#20252b;
  --accent:#c8703f;
  --accent-light:#e08a52;
  --gold:#d4a24c;
  --text:#f2ede4;
  --text-muted:#a9aeb4;
  --line:rgba(242,237,228,.12);
  --font-display:'Fraunces',serif;
  --font-body:'Manrope',sans-serif;
  --font-mono:'IBM Plex Mono',monospace;
}
*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  background:var(--bg);
  color:var(--text);
  font-family:var(--font-body);
  overflow-x:hidden;
}
h1,h2,h3,.font-display{font-family:var(--font-display);}
.mono{font-family:var(--font-mono);}
a{text-decoration:none;}
.text-accent{color:var(--accent-light)!important;}
.eyebrow{
  font-family:var(--font-mono);
  letter-spacing:.18em;
  text-transform:uppercase;
  font-size:.75rem;
  color:var(--gold);
}
.section-pad{padding:6.5rem 0;}
@media(max-width:768px){.section-pad{padding:4rem 0;}}
.bg-surface{background:var(--surface);}
.bg-surface-2{background:var(--surface-2);}

/* ---------- Topbar ---------- */
.topbar{
  background:#0e1012;
  color:var(--text-muted);
  font-size:.82rem;
  padding:.45rem 0;
  border-bottom:1px solid var(--line);
}
.topbar a{color:var(--text-muted);transition:.2s;}
.topbar a:hover{color:var(--accent-light);}

/* ---------- Navbar ---------- */
.navbar-custom{
  background:rgba(20,23,26,.75);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);
  transition:padding .3s ease,background .3s ease;
  padding:1.1rem 0;
}
.navbar-custom.scrolled{padding:.55rem 0;background:rgba(20,23,26,.95);}
.navbar-custom .nav-link{
  color:var(--text)!important;
  font-weight:600;
  font-size:.92rem;
  margin:0 .6rem;
  position:relative;
}
.navbar-custom .nav-link::after{
  content:"";position:absolute;left:0;bottom:-4px;width:0;height:2px;background:var(--accent);
  transition:width .25s ease;
}
.navbar-custom .nav-link:hover::after{width:100%;}
.logo-mark{display:flex;align-items:center;gap:.6rem;}
.logo-word{font-family:var(--font-display);font-weight:700;font-size:1.4rem;letter-spacing:.01em;color:var(--text);}
.logo-word span{color:var(--accent-light);}
.btn-call{
  background:var(--accent);
  color:#14171a!important;
  font-weight:700;
  border-radius:2px;
  padding:.6rem 1.3rem;
  font-size:.92rem;
  border:1px solid var(--accent);
  transition:.25s;
  white-space:nowrap;
}
.btn-call:hover{background:transparent;color:var(--accent-light)!important;}
.btn-outline-line{
  border:1px solid var(--line);
  color:var(--text);
  border-radius:2px;
  padding:.6rem 1.3rem;
  font-weight:600;
  transition:.25s;
}
.btn-outline-line:hover{border-color:var(--accent);color:var(--accent-light);}

/* ---------- Hero ---------- */
.hero{
  position:relative;
  min-height:92vh;
  display:flex;
  align-items:center;
  padding-top:6rem;
  background:
    radial-gradient(ellipse at 80% 20%, rgba(200,112,63,.18), transparent 55%),
    linear-gradient(160deg,#14171a 0%,#181c20 60%,#14171a 100%);
  overflow:hidden;
}
.hero::before{
  content:"";position:absolute;inset:0;
  background-image:
    linear-gradient(var(--line) 1px, transparent 1px),
    linear-gradient(90deg, var(--line) 1px, transparent 1px);
  background-size:64px 64px;
  opacity:.35;
  mask-image:linear-gradient(180deg,transparent,#000 15%,#000 70%,transparent);
  -webkit-mask-image:linear-gradient(180deg,transparent,#000 15%,#000 70%,transparent);
}
.hero-badge{
  display:inline-flex;align-items:center;gap:.5rem;
  border:1px solid var(--line);border-radius:100px;
  padding:.4rem .95rem;font-size:.8rem;color:var(--text-muted);
  background:rgba(255,255,255,.02);
}
.hero-badge .dot{width:8px;height:8px;border-radius:50%;background:var(--gold);animation:pulse 1.8s infinite;}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(212,162,76,.55);}70%{box-shadow:0 0 0 9px rgba(212,162,76,0);}100%{box-shadow:0 0 0 0 rgba(212,162,76,0);}}
.hero h1{
  font-size:clamp(2.4rem,5.4vw,4.4rem);
  font-weight:700;
  line-height:1.05;
  letter-spacing:-.01em;
}
.hero p.lead-text{color:var(--text-muted);font-size:1.15rem;max-width:34rem;}
.hero-phone-cta{
  display:inline-flex;align-items:center;gap:1rem;
  background:var(--accent);
  padding:1.1rem 1.7rem;
  border-radius:3px;
  color:#14171a;
  font-weight:700;
}
.hero-phone-cta .num{font-family:var(--font-mono);font-size:1.5rem;letter-spacing:.02em;}
.hero-phone-cta small{display:block;font-weight:600;font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;opacity:.75;}
.hero-phone-cta:hover{background:var(--accent-light);color:#14171a;}
.hero-stats{border-top:1px solid var(--line);margin-top:3.2rem;padding-top:1.6rem;}
.hero-stats .num{font-family:var(--font-mono);font-size:1.9rem;color:var(--accent-light);font-weight:600;}
.hero-stats .lbl{font-size:.78rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;}
.hero-visual{
  position:relative;border:1px solid var(--line);border-radius:4px;overflow:hidden;
  aspect-ratio:4/5;
}
.hero-visual img{width:100%;height:100%;object-fit:cover;filter:saturate(1.05) contrast(1.05);}
.hero-visual .tag{
  position:absolute;bottom:1.1rem;left:1.1rem;background:rgba(20,23,26,.82);
  backdrop-filter:blur(6px);border:1px solid var(--line);padding:.7rem 1rem;border-radius:3px;font-size:.82rem;
}

/* ---------- Marquee ribbon (signature element) ---------- */
.ribbon{
  background:var(--accent);
  color:#14171a;
  overflow:hidden;
  white-space:nowrap;
  padding:.75rem 0;
  transform:rotate(-1.1deg);
  margin:-1.4rem 0;
  position:relative;z-index:2;
  border-top:2px solid #14171a;border-bottom:2px solid #14171a;
}
.ribbon-track{display:inline-block;animation:scrollLeft 26s linear infinite;font-family:var(--font-mono);font-weight:600;font-size:.95rem;letter-spacing:.05em;}
.ribbon-track span{margin:0 1.4rem;}
@keyframes scrollLeft{0%{transform:translateX(0);}100%{transform:translateX(-50%);}}

/* ---------- Stats ---------- */
.stat-box{border-left:1px solid var(--line);padding-left:1.4rem;}
.stat-box .num{font-family:var(--font-mono);font-size:2.6rem;font-weight:600;color:var(--accent-light);}
.stat-box .lbl{color:var(--text-muted);font-size:.88rem;}

/* ---------- Services ---------- */
.svc-card{
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:4px;
  padding:2.1rem 1.8rem;
  height:100%;
  transition:.3s ease;
  position:relative;
}
.svc-card:hover{transform:translateY(-6px);border-color:var(--accent);box-shadow:0 20px 40px -20px rgba(0,0,0,.6);}
.svc-icon{
  width:52px;height:52px;border-radius:3px;
  background:rgba(200,112,63,.12);
  display:flex;align-items:center;justify-content:center;
  color:var(--accent-light);font-size:1.4rem;margin-bottom:1.3rem;
}
.svc-card h3{font-size:1.2rem;margin-bottom:.6rem;}
.svc-card p{color:var(--text-muted);font-size:.92rem;margin-bottom:0;}
.svc-card .learn{color:var(--accent-light);font-size:.85rem;font-weight:600;margin-top:1rem;display:inline-block;}

/* ---------- Process ---------- */
.step{position:relative;padding-top:1rem;}
.step .idx{
  font-family:var(--font-mono);font-size:2.6rem;color:transparent;
  -webkit-text-stroke:1px var(--line);
  font-weight:600;line-height:1;
}
.step h3{margin-top:.6rem;font-size:1.15rem;}
.step p{color:var(--text-muted);font-size:.9rem;}

/* ---------- Gallery ---------- */
.gal-item{position:relative;overflow:hidden;border-radius:4px;border:1px solid var(--line);}
.gal-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease;display:block;}
.gal-item:hover img{transform:scale(1.08);}
.gal-item .cap{
  position:absolute;left:0;bottom:0;right:0;
  background:linear-gradient(0deg,rgba(14,16,18,.92),transparent);
  padding:1rem;font-size:.85rem;font-weight:600;
}

/* ---------- Why us ---------- */
.check-list li{
  display:flex;gap:.8rem;padding:.7rem 0;border-bottom:1px dashed var(--line);
}
.check-list li:last-child{border-bottom:none;}
.check-list i{color:var(--accent-light);font-size:1.1rem;margin-top:.15rem;}

/* ---------- Testimonials ---------- */
.testi-card{
  background:var(--surface);border:1px solid var(--line);border-radius:4px;
  padding:2.3rem;max-width:44rem;margin:0 auto;text-align:center;
}
.testi-card p{font-family:var(--font-display);font-size:1.35rem;font-weight:500;line-height:1.5;}
.testi-name{color:var(--accent-light);font-weight:700;margin-top:1.2rem;}
.testi-role{color:var(--text-muted);font-size:.85rem;}
.carousel-indicators [data-bs-target]{background:var(--accent-light);width:8px;height:8px;border-radius:50%;}

/* ---------- Final CTA ---------- */
.final-cta{
  background:
    radial-gradient(ellipse at 30% 30%, rgba(200,112,63,.25), transparent 60%),
    var(--surface-2);
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  text-align:center;
}
.final-cta .big-phone{
  font-family:var(--font-mono);font-size:clamp(2.2rem,6vw,4rem);font-weight:600;color:var(--accent-light);
}
.final-cta .big-phone:hover{color:var(--gold);}

/* ---------- Footer ---------- */
footer{background:#0e1012;border-top:1px solid var(--line);padding:3.5rem 0 1.5rem;}
footer h5{font-family:var(--font-display);font-size:1.1rem;margin-bottom:1rem;}
footer a{color:var(--text-muted);}
footer a:hover{color:var(--accent-light);}
.footer-line{border-top:1px solid var(--line);margin-top:2.5rem;padding-top:1.5rem;font-size:.82rem;color:var(--text-muted);}

/* ---------- Floating call button ---------- */
.floating-call{
  position:fixed;right:1.4rem;bottom:1.4rem;z-index:1200;
  background:var(--accent);color:#14171a;
  width:60px;height:60px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;font-size:1.5rem;
  box-shadow:0 10px 30px -8px rgba(0,0,0,.6);
  animation:floatPulse 2.2s infinite;
}
@keyframes floatPulse{0%{box-shadow:0 0 0 0 rgba(200,112,63,.5);}70%{box-shadow:0 0 0 16px rgba(200,112,63,0);}100%{box-shadow:0 0 0 0 rgba(200,112,63,0);}}

/* ---------- Mobile fixed call bar ---------- */
.mobile-call-bar{
  position:fixed;left:0;right:0;bottom:0;z-index:1100;
  background:var(--accent);color:#14171a;
  display:none;align-items:center;justify-content:center;gap:.6rem;
  padding:.9rem;font-weight:700;font-family:var(--font-mono);
}
@media(max-width:767px){.mobile-call-bar{display:flex;} body{padding-bottom:56px;} .floating-call{display:none;}}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease;}
.reveal.in{opacity:1;transform:translateY(0);}

@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none;}
  .ribbon-track,.hero-badge .dot,.floating-call{animation:none;}
}
