/* 21 Ocean Builders — main stylesheet */
/* ─────────────────────────────────────────────────────────────
   21 OCEAN BUILDERS · Editorial Construction Site
   Aesthetic: refined editorial · architectural · warm navy + cream
   ───────────────────────────────────────────────────────────── */

*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}

:root{
  --navy:#0E1B35;
  --navy-deep:#050D1F;
  --navy-mid:#1B2A4A;
  --cream:#F5EFE3;
  --cream-soft:#FAF6ED;
  --paper:#ECE4D0;
  --ink:#14161C;
  --ink-soft:#2A2D38;
  --muted:#7A7163;
  --gold:#C9A557;
  --gold-soft:#D4B872;
  --gold-deep:#A0823E;
  --accent-red:#A8342B;
  --border:#D8CEB8;
  --serif:"Fraunces",Georgia,serif;
  --sans:"Inter",-apple-system,sans-serif;
  --mono:"JetBrains Mono",ui-monospace,monospace;
}

html{scroll-behavior:smooth;scroll-padding-top:80px}
body{
  font-family:var(--sans);
  background:var(--cream);
  color:var(--ink);
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

/* Grain / paper texture overlay */
body::before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:999;
  opacity:0.35;
  mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.08 0 0 0 0 0.07 0 0 0 0 0.05 0 0 0 0.25 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
}

a{color:inherit;text-decoration:none;transition:color 0.2s}
img{max-width:100%;display:block}

/* ── NAV ───────────────────────────────────────────────── */
.nav-wrap{
  position:fixed;top:0;left:0;right:0;z-index:100;
  background:rgba(245,239,227,0.82);
  backdrop-filter:blur(14px) saturate(140%);
  -webkit-backdrop-filter:blur(14px) saturate(140%);
  border-bottom:1px solid rgba(216,206,184,0.5);
  transition:all 0.3s;
}
.nav-inner{
  max-width:1400px;margin:0 auto;
  padding:14px 40px;
  display:flex;align-items:center;justify-content:space-between;
  gap:24px;
}
.brand{
  display:flex;align-items:center;gap:12px;
  cursor:pointer;
}
.brand-logo{
  width:42px;height:42px;
  border-radius:8px;
  background:var(--navy);
  display:grid;place-items:center;
  overflow:hidden;
  flex-shrink:0;
}
.brand-logo img{width:100%;height:100%;object-fit:cover}
.brand-name{
  font-family:var(--serif);
  font-size:17px;font-weight:600;
  letter-spacing:0.01em;
  color:var(--navy);
  line-height:1;
}
.brand-tag{
  font-family:var(--mono);
  font-size:9px;
  letter-spacing:0.16em;
  text-transform:uppercase;
  color:var(--muted);
  margin-top:3px;
}

.nav-links{
  display:flex;align-items:center;gap:4px;
}
.nav-link{
  font-family:var(--sans);
  font-size:13px;font-weight:500;
  letter-spacing:0.01em;
  color:var(--ink-soft);
  padding:9px 16px;
  border-radius:8px;
  transition:all 0.2s;
  cursor:pointer;
  position:relative;
  border:none;background:none;
}
.nav-link:hover{color:var(--navy);background:rgba(14,27,53,0.05)}
.nav-link.active{color:var(--navy)}
.nav-link.active::after{
  content:"";position:absolute;
  bottom:3px;left:50%;transform:translateX(-50%);
  width:4px;height:4px;border-radius:50%;
  background:var(--gold);
}

.nav-cta{
  font-family:var(--sans);
  font-size:12px;font-weight:600;
  letter-spacing:0.04em;
  background:var(--navy);color:var(--cream);
  padding:10px 18px;border-radius:999px;
  border:none;cursor:pointer;
  transition:all 0.2s;
}
.nav-cta:hover{background:var(--navy-deep);transform:translateY(-1px)}

.menu-btn{
  display:none;
  background:none;border:none;
  width:44px;height:44px;
  cursor:pointer;
  align-items:center;justify-content:center;
  flex-direction:column;gap:5px;
}
.menu-btn span{
  display:block;width:22px;height:1.5px;
  background:var(--navy);
  transition:all 0.25s;
}
.menu-btn.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.menu-btn.open span:nth-child(2){opacity:0}
.menu-btn.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* Mobile-only tap-to-call icon, sits between nav-cta and menu-btn */
.nav-phone-mobile{
  display:none;
  width:44px;height:44px;
  align-items:center;justify-content:center;
  color:var(--navy);
  text-decoration:none;
  border-radius:8px;
  transition:background 0.2s;
}
.nav-phone-mobile:hover{background:rgba(14,27,53,0.06)}

/* Floating WhatsApp button — mobile-only, brand green
   Stacks ABOVE the lang-toggle (which sits at bottom:24px right:24px) */
.whatsapp-fab{
  position:fixed;
  right:24px;bottom:76px;
  width:54px;height:54px;
  display:none;
  align-items:center;justify-content:center;
  background:#25D366;
  color:#fff;
  border-radius:50%;
  box-shadow:0 8px 22px -6px rgba(0,0,0,0.32);
  z-index:200;
  transition:transform 0.18s, box-shadow 0.18s;
}
.whatsapp-fab:hover,.whatsapp-fab:focus{
  transform:scale(1.06);
  box-shadow:0 12px 28px -6px rgba(0,0,0,0.4);
  outline:none;
}
.whatsapp-fab:focus-visible{outline:2px solid #fff;outline-offset:3px}

/* ── PAGE ROUTING ──────────────────────────────────────── */
.page{display:none;animation:pageIn 0.6s ease}
.page.active{display:block}
@keyframes pageIn{
  from{opacity:0;transform:translateY(12px)}
  to{opacity:1;transform:translateY(0)}
}

.section{
  max-width:1400px;margin:0 auto;
  padding:0 40px;
}

.eyebrow{
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:0.22em;
  text-transform:uppercase;
  color:var(--gold-deep);
  display:inline-flex;align-items:center;gap:10px;
  margin-bottom:24px;
}
.eyebrow::before{
  content:"";
  display:inline-block;
  width:24px;height:1px;
  background:var(--gold);
}

/* ── HOME HERO ─────────────────────────────────────────── */
.hero{
  position:relative;
  padding-top:160px;padding-bottom:90px;
  overflow:hidden;
}
.hero-grid{
  display:grid;
  grid-template-columns:1.1fr 1fr;
  gap:80px;
  align-items:center;
  position:relative;
}
.hero h1{
  font-family:var(--serif);
  font-weight:400;
  font-size:clamp(48px,7vw,108px);
  line-height:0.95;
  letter-spacing:-0.025em;
  color:var(--navy);
  margin-bottom:36px;
}
.hero h1 em{
  font-style:italic;
  color:var(--gold-deep);
  font-weight:400;
}
.hero h1 .underline{
  text-decoration:underline;
  text-decoration-color:var(--gold);
  text-decoration-thickness:3px;
  text-underline-offset:10px;
}
.hero-sub{
  font-size:17px;line-height:1.65;
  color:var(--ink-soft);
  max-width:480px;
  margin-bottom:40px;
}
.hero-cta-row{
  display:flex;gap:14px;flex-wrap:wrap;
}

.btn-primary{
  font-family:var(--sans);
  font-size:14px;font-weight:600;
  letter-spacing:0.02em;
  background:var(--navy);color:var(--cream);
  padding:16px 30px;
  border-radius:999px;
  border:none;cursor:pointer;
  display:inline-flex;align-items:center;gap:10px;
  transition:all 0.25s;
}
.btn-primary:hover{background:var(--navy-deep);transform:translateY(-2px)}
.btn-primary svg{transition:transform 0.25s}
.btn-primary:hover svg{transform:translateX(3px)}

.btn-ghost{
  font-family:var(--sans);
  font-size:14px;font-weight:500;
  letter-spacing:0.02em;
  background:transparent;color:var(--navy);
  padding:16px 26px;
  border-radius:999px;
  border:1px solid rgba(14,27,53,0.25);
  cursor:pointer;
  display:inline-flex;align-items:center;gap:10px;
  transition:all 0.2s;
}
.btn-ghost:hover{border-color:var(--navy);background:rgba(14,27,53,0.03)}

/* Hero visual card — a single "tombstone" detail piece */
.hero-visual{
  position:relative;
  aspect-ratio:3/4;
  border-radius:8px;
  background:linear-gradient(155deg, var(--navy) 0%, var(--navy-mid) 100%);
  overflow:hidden;
  box-shadow:
    0 40px 80px -30px rgba(14,27,53,0.35),
    0 20px 40px -20px rgba(14,27,53,0.2);
}
.hero-visual::before{
  content:"";
  position:absolute;
  inset:20px;
  border:1px solid rgba(201,165,87,0.25);
  border-radius:4px;
  pointer-events:none;
}
.hero-visual-inner{
  position:absolute;inset:0;
  display:flex;flex-direction:column;
  padding:46px 40px;
  color:var(--cream);
}
.hv-tag{
  font-family:var(--mono);font-size:9px;
  letter-spacing:0.22em;text-transform:uppercase;
  color:var(--gold);
  display:flex;align-items:center;gap:10px;
}
.hv-tag::before{
  content:"";display:block;
  width:16px;height:1px;background:var(--gold);
}
.hv-quote{
  font-family:var(--serif);
  font-size:clamp(32px,4.2vw,46px);
  font-weight:400;
  line-height:1.18;
  letter-spacing:-0.01em;
  margin:auto 0 34px;
  color:var(--cream);
  position:relative;
  padding-top:30px;
}
.hv-quote em{font-style:italic;color:var(--gold-soft);font-weight:400}
.hv-mark{
  position:absolute;top:-20px;left:-6px;
  font-family:var(--serif);
  font-size:120px;
  line-height:0.8;
  color:var(--gold);
  opacity:0.45;
  font-weight:400;
}
.hv-stats{
  display:flex;gap:40px;
  padding-top:24px;
  border-top:1px solid rgba(201,165,87,0.2);
}
.hv-stat-num{
  font-family:var(--serif);
  font-size:32px;font-weight:500;
  color:var(--gold);
  line-height:1;
}
.hv-stat-lbl{
  font-family:var(--mono);font-size:9px;
  letter-spacing:0.18em;text-transform:uppercase;
  color:rgba(245,239,227,0.55);
  margin-top:6px;
}

/* Marquee strip */
.marquee{
  border-block:1px solid var(--border);
  background:var(--cream-soft);
  overflow:hidden;
  padding:22px 0;
  margin-top:40px;
}
.marquee-track{
  display:inline-flex;
  gap:80px;
  white-space:nowrap;
  animation:scroll 22s linear infinite;
  font-family:var(--serif);
  font-size:22px;
  font-style:italic;
  color:var(--muted);
  will-change:transform;
  -webkit-backface-visibility:hidden;
  backface-visibility:hidden;
  padding-right:80px;
}
.marquee-track span{display:inline-flex;align-items:center;gap:80px;flex-shrink:0}
.marquee-track span::after{
  content:"✦";color:var(--gold);font-style:normal;font-size:14px;
}
@keyframes scroll{
  0%{transform:translate3d(0,0,0)}
  100%{transform:translate3d(-50%,0,0)}
}
@media (max-width:720px){
  .marquee-track{
    font-size:18px;
    gap:50px;
    animation-duration:18s;
  }
  .marquee-track span{gap:50px}
}

/* ── FEATURED SERVICES ─────────────────────────────────── */
.services-block{padding:120px 0 80px}
.services-head{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:60px;
  align-items:end;
  margin-bottom:70px;
}
.services-head h2{
  font-family:var(--serif);
  font-size:clamp(38px,5.5vw,72px);
  font-weight:400;
  line-height:1;
  letter-spacing:-0.025em;
  color:var(--navy);
}
.services-head p{
  font-size:17px;line-height:1.65;
  color:var(--ink-soft);
  max-width:440px;
  justify-self:end;
}

.services-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:1px;
  background:var(--border);
  border:1px solid var(--border);
  border-radius:10px;
  overflow:hidden;
}
.service-card{
  background:var(--cream);
  padding:40px 34px;
  display:flex;flex-direction:column;
  min-height:260px;
  transition:background 0.3s;
  cursor:default;
}
.service-card:hover{background:var(--cream-soft)}
.service-num{
  font-family:var(--mono);font-size:11px;
  letter-spacing:0.18em;color:var(--gold-deep);
  margin-bottom:24px;
}
.service-card h3{
  font-family:var(--serif);
  font-size:26px;font-weight:500;
  letter-spacing:-0.015em;
  color:var(--navy);
  margin-bottom:10px;
}
.service-meta{
  font-family:var(--mono);
  font-size:11px;font-weight:500;
  letter-spacing:0.06em;
  color:var(--ink-soft);
  margin-bottom:14px;
}
.service-card p{
  font-size:14.5px;line-height:1.6;
  color:var(--ink-soft);
  margin-bottom:auto;
}

/* ── PROCESS / APPROACH ────────────────────────────────── */
.approach{
  background:var(--navy);color:var(--cream);
  padding:120px 0;
  margin-top:60px;
  position:relative;
  overflow:hidden;
}
.approach::before{
  content:"";position:absolute;
  top:-60px;left:-60px;
  width:280px;height:280px;
  background:radial-gradient(circle, rgba(201,165,87,0.12) 0%, transparent 70%);
  pointer-events:none;
}
.approach h2{
  font-family:var(--serif);
  font-size:clamp(38px,5vw,64px);
  font-weight:400;
  line-height:1.05;
  letter-spacing:-0.02em;
  margin-bottom:70px;
  max-width:720px;
}
.approach h2 em{font-style:italic;color:var(--gold-soft)}

.steps{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:30px;
}
.step-card{
  position:relative;
  padding-top:30px;
  border-top:1px solid rgba(201,165,87,0.3);
}
.step-num{
  position:absolute;top:-1px;left:0;
  width:38px;height:2px;
  background:var(--gold);
}
.step-num span{
  font-family:var(--mono);font-size:11px;
  letter-spacing:0.15em;
  color:var(--gold);
  position:absolute;top:-22px;left:0;
}
.step-card h4{
  font-family:var(--serif);
  font-size:22px;font-weight:500;
  letter-spacing:-0.01em;
  margin-bottom:14px;
  color:var(--cream);
}
.step-card p{
  font-size:13.5px;line-height:1.6;
  color:rgba(245,239,227,0.65);
}

/* ── STATS BAND ────────────────────────────────────────── */
.stats-band{
  padding:100px 0;
  background:var(--cream-soft);
  border-block:1px solid var(--border);
}
.stats-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:40px;
  text-align:center;
}
.stat-num{
  font-family:var(--serif);
  font-size:clamp(52px,7vw,96px);
  font-weight:400;
  color:var(--navy);
  line-height:1;
  letter-spacing:-0.03em;
}
.stat-num sup{
  font-size:0.4em;
  color:var(--gold);
  font-style:italic;
  font-weight:300;
  vertical-align:super;
  margin-left:4px;
}
.stat-lbl{
  font-family:var(--mono);font-size:10px;
  letter-spacing:0.2em;text-transform:uppercase;
  color:var(--muted);
  margin-top:14px;
}

/* ── CTA FINAL ─────────────────────────────────────────── */
.final-cta{
  padding:140px 0;
  text-align:center;
  max-width:900px;margin:0 auto;
}
.final-cta h2{
  font-family:var(--serif);
  font-size:clamp(42px,6vw,84px);
  font-weight:400;
  line-height:1.02;
  letter-spacing:-0.025em;
  color:var(--navy);
  margin-bottom:40px;
}
.final-cta h2 em{font-style:italic;color:var(--gold-deep)}

/* ── SERVICES PAGE ─────────────────────────────────────── */
.page-header{
  padding-top:160px;padding-bottom:80px;
  border-bottom:1px solid var(--border);
}
.page-title{
  font-family:var(--serif);
  font-size:clamp(56px,9vw,140px);
  font-weight:300;
  line-height:0.9;
  letter-spacing:-0.035em;
  color:var(--navy);
  margin-bottom:30px;
}
.page-title em{font-style:italic;color:var(--gold-deep);font-weight:400}
.page-lede{
  font-family:var(--serif);
  font-size:clamp(20px,2.4vw,28px);
  font-weight:400;
  font-style:italic;
  color:var(--ink-soft);
  max-width:780px;
  line-height:1.45;
}

.services-list{padding:100px 0}
.service-row{
  display:grid;
  grid-template-columns:100px 1fr 1fr;
  gap:40px;
  padding:50px 0;
  border-top:1px solid var(--border);
  align-items:start;
}
.service-row:last-child{border-bottom:1px solid var(--border)}
.sr-num{
  font-family:var(--mono);font-size:11px;
  letter-spacing:0.2em;color:var(--gold-deep);
  padding-top:8px;
}
.sr-title{
  font-family:var(--serif);
  font-size:clamp(28px,3.5vw,44px);
  font-weight:400;
  line-height:1;
  letter-spacing:-0.02em;
  color:var(--navy);
}
.sr-title em{font-style:italic;color:var(--gold-deep)}
.sr-body{
  font-size:15px;line-height:1.65;
  color:var(--ink-soft);
}
.sr-body p{margin-bottom:16px}
.sr-list{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:8px 24px;
  margin-top:20px;
}
.sr-list li{
  list-style:none;
  font-family:var(--mono);
  font-size:11.5px;
  letter-spacing:0.04em;
  color:var(--ink-soft);
  padding-left:16px;position:relative;
  line-height:1.5;
}
.sr-list li::before{
  content:"";position:absolute;
  left:0;top:8px;
  width:6px;height:1px;
  background:var(--gold);
}

.services-misc{
  margin-top:30px;
  padding:50px 0 20px;
  border-top:1px solid var(--border);
}
.services-misc .eyebrow{margin-bottom:18px}
.svc-misc-list{
  font-family:var(--mono);
  font-size:11.5px;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:var(--ink-soft);
  line-height:1.9;
  margin-bottom:22px;
}
.svc-misc-note{
  font-family:var(--serif);
  font-size:18px;
  line-height:1.55;
  color:var(--navy);
  font-style:italic;
  max-width:620px;
  margin:0;
}

/* ── PORTFOLIO ─────────────────────────────────────────── */
.portfolio-grid{
  padding:80px 0 120px;
  display:grid;
  grid-template-columns:repeat(12,1fr);
  gap:30px;
}
.project-card{
  position:relative;
  background:var(--navy);
  color:var(--cream);
  border-radius:10px;
  overflow:hidden;
  cursor:pointer;
  transition:transform 0.35s cubic-bezier(.2,.8,.2,1);
  aspect-ratio:4/5;
  display:flex;flex-direction:column;
  padding:32px;
}
.project-card.large{grid-column:span 7;aspect-ratio:5/4}
.project-card.small{grid-column:span 5}
.project-card.wide{grid-column:span 6;aspect-ratio:7/5}
.project-card.medium{grid-column:span 6;aspect-ratio:7/5}
.project-card:hover{transform:translateY(-5px)}
.project-card::after{
  content:"";position:absolute;
  inset:0;
  background:linear-gradient(135deg, transparent 60%, rgba(201,165,87,0.07) 100%);
  pointer-events:none;
}

.pc-tag{
  font-family:var(--mono);font-size:10px;
  letter-spacing:0.2em;text-transform:uppercase;
  color:var(--gold);
  display:inline-flex;align-items:center;gap:10px;
}
.pc-tag::before{
  content:"";display:block;width:20px;height:1px;background:var(--gold);
}
.pc-title{
  font-family:var(--serif);
  font-size:clamp(32px,4vw,52px);
  font-weight:400;
  line-height:0.95;
  letter-spacing:-0.02em;
  margin:auto 0 16px;
  color:var(--cream);
}
.pc-title em{font-style:italic;color:var(--gold-soft)}
.pc-meta{
  display:flex;justify-content:space-between;
  padding-top:18px;
  border-top:1px solid rgba(201,165,87,0.25);
  font-family:var(--mono);font-size:10.5px;
  letter-spacing:0.1em;
  color:rgba(245,239,227,0.65);
}
.pc-meta strong{color:var(--gold);font-weight:500}

/* Photo background on card */
.project-card .pc-photo{
  position:absolute;
  inset:0;
  background-size:cover;
  background-position:center;
  z-index:0;
  transition:transform 0.5s cubic-bezier(.2,.8,.2,1);
}
.project-card.has-photo::after{
  content:"";position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(14,27,53,0.25) 0%, rgba(14,27,53,0.55) 50%, rgba(14,27,53,0.92) 100%);
  pointer-events:none;
  z-index:1;
}
.project-card.has-photo:hover .pc-photo{transform:scale(1.04)}
.project-card.has-photo .pc-tag,
.project-card.has-photo .pc-title,
.project-card.has-photo .pc-meta{
  position:relative;z-index:2;
}
.pc-count{
  display:inline-block;
  margin-left:10px;
  padding:2px 8px;
  border:1px solid rgba(201,165,87,0.4);
  border-radius:999px;
  color:var(--gold);
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:0.08em;
}

/* ── LIGHTBOX ───────────────────────────────────────────── */
.lightbox{
  display:none;
  position:fixed;inset:0;
  background:rgba(14,27,53,0.97);
  z-index:9999;
  align-items:center;justify-content:center;
  padding:40px 20px;
}
.lightbox.open{display:flex}
.lb-body{
  max-width:1200px;width:100%;max-height:100%;
  display:flex;flex-direction:column;align-items:center;
  gap:16px;
}
.lb-head{
  display:flex;justify-content:space-between;align-items:center;
  width:100%;
  padding:0 8px;
}
.lb-proj{
  font-family:var(--serif);
  font-size:20px;font-weight:500;
  color:var(--cream);
}
.lb-proj em{color:var(--gold-soft);font-style:italic}
.lb-count{
  font-family:var(--mono);
  font-size:11px;letter-spacing:0.14em;
  color:rgba(245,239,227,0.5);
}
.lb-body img{
  max-width:100%;max-height:75vh;
  object-fit:contain;
  border-radius:6px;
  box-shadow:0 30px 60px -20px rgba(0,0,0,0.5);
}
.lb-caption{
  font-family:var(--serif);
  font-size:15px;font-style:italic;
  color:rgba(245,239,227,0.7);
  text-align:center;
  min-height:1.5em;
}
.lb-close{
  position:absolute;top:20px;right:20px;
  background:rgba(245,239,227,0.1);
  border:1px solid rgba(245,239,227,0.2);
  color:var(--cream);
  width:42px;height:42px;
  border-radius:50%;
  font-size:18px;
  cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:all 0.2s;
}
.lb-close:hover{background:rgba(245,239,227,0.2)}
.lb-nav{
  position:absolute;top:50%;
  transform:translateY(-50%);
  background:rgba(245,239,227,0.08);
  border:1px solid rgba(245,239,227,0.15);
  color:var(--cream);
  width:52px;height:52px;
  border-radius:50%;
  font-size:28px;
  cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:all 0.2s;
  font-family:serif;
}
.lb-nav:hover{background:rgba(245,239,227,0.16)}
.lb-prev{left:20px}
.lb-next{right:20px}
@media (max-width:720px){
  .lb-nav{width:42px;height:42px;font-size:22px}
  .lb-prev{left:8px}
  .lb-next{right:8px}
  .lb-proj{font-size:16px}
}

/* ── CONTACT ──────────────────────────────────────────── */
.contact-wrap{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:80px;
  padding:80px 0 120px;
  align-items:start;
}
.contact-info h3{
  font-family:var(--serif);
  font-size:clamp(30px,3.5vw,42px);
  font-weight:400;
  line-height:1.1;
  letter-spacing:-0.02em;
  color:var(--navy);
  margin-bottom:40px;
}
.contact-info h3 em{font-style:italic;color:var(--gold-deep)}

.ci-block{
  margin-bottom:30px;
  padding:24px;
  background:var(--cream-soft);
  border:1px solid var(--border);
  border-radius:10px;
}
.ci-lbl{
  font-family:var(--mono);font-size:10px;
  letter-spacing:0.2em;text-transform:uppercase;
  color:var(--gold-deep);
  margin-bottom:10px;
}
.ci-val{
  font-family:var(--serif);
  font-size:22px;font-weight:500;
  color:var(--navy);
  line-height:1.3;
}
.ci-val a{border-bottom:1px solid var(--gold);transition:color 0.2s}
.ci-val a:hover{color:var(--gold-deep)}

.contact-form{
  background:var(--navy);
  border-radius:14px;
  padding:42px 38px;
  color:var(--cream);
}
.contact-form h4{
  font-family:var(--serif);
  font-size:26px;font-weight:400;
  margin-bottom:8px;color:var(--cream);
}
.contact-form .cf-intro{
  font-size:13.5px;
  color:rgba(245,239,227,0.65);
  margin-bottom:28px;
  line-height:1.5;
}
.cf-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px 16px;
}
.cf-field{display:flex;flex-direction:column}
.cf-field.full{grid-column:span 2}
.cf-field label{
  font-family:var(--mono);font-size:9.5px;
  letter-spacing:0.18em;text-transform:uppercase;
  color:var(--gold);
  margin-bottom:8px;
}
.cf-field label .cf-opt{
  font-weight:400;
  letter-spacing:0.08em;
  color:rgba(245,239,227,0.45);
  margin-left:4px;
}
.cf-field input,.cf-field select,.cf-field textarea{
  background:rgba(245,239,227,0.06);
  border:1px solid rgba(201,165,87,0.18);
  border-radius:7px;
  color:var(--cream);
  font-family:var(--sans);
  font-size:14px;
  padding:12px 14px;
  outline:none;
  transition:all 0.2s;
  width:100%;
}
.cf-field input:focus,.cf-field select:focus,.cf-field textarea:focus{
  border-color:var(--gold);
  background:rgba(245,239,227,0.1);
}
.cf-field textarea{min-height:110px;resize:vertical;font-family:var(--sans);line-height:1.5}
.cf-field select{cursor:pointer}
.cf-field select option{background:var(--navy);color:var(--cream)}

.cf-submit{
  margin-top:22px;
  width:100%;
  background:var(--gold);color:var(--navy);
  font-family:var(--sans);font-size:14px;font-weight:700;
  letter-spacing:0.03em;
  padding:15px 24px;
  border-radius:8px;
  border:none;cursor:pointer;
  transition:all 0.2s;
}
.cf-submit:hover{background:var(--gold-soft);transform:translateY(-1px)}

/* ── FOOTER ───────────────────────────────────────────── */
.footer{
  background:var(--navy-deep);color:var(--cream);
  padding:80px 0 30px;
  position:relative;
}
.footer-grid{
  display:grid;
  grid-template-columns:2fr 1fr 1fr 1fr;
  gap:50px;
  padding-bottom:50px;
  border-bottom:1px solid rgba(201,165,87,0.2);
}
.f-brand{max-width:360px}
.f-logo{
  display:flex;align-items:center;gap:14px;
  margin-bottom:20px;
}
.f-logo-icon{
  width:50px;height:50px;
  border-radius:10px;
  background:var(--navy);
  overflow:hidden;
}
.f-logo-icon img{width:100%;height:100%;object-fit:cover}
.f-brand-name{
  font-family:var(--serif);
  font-size:22px;font-weight:500;
  color:var(--cream);
}
.f-brand-tag{
  font-family:var(--mono);font-size:9px;
  letter-spacing:0.18em;text-transform:uppercase;
  color:var(--gold);
  margin-top:4px;
}
.f-lead{
  font-family:var(--serif);
  font-size:16px;font-weight:400;font-style:italic;
  color:rgba(245,239,227,0.7);
  line-height:1.5;
}

.f-col h5{
  font-family:var(--mono);font-size:10px;
  letter-spacing:0.2em;text-transform:uppercase;
  color:var(--gold);
  margin-bottom:18px;
}
.f-col ul{list-style:none}
.f-col li{margin-bottom:10px}
.f-col a{
  font-size:13.5px;
  color:rgba(245,239,227,0.75);
  transition:color 0.2s;
  cursor:pointer;
}
.f-col a:hover{color:var(--gold)}
.f-col address{
  font-style:normal;
  font-size:13.5px;line-height:1.7;
  color:rgba(245,239,227,0.75);
}

.f-bottom{
  padding-top:30px;
  display:flex;justify-content:space-between;align-items:center;
  font-family:var(--mono);font-size:10.5px;
  color:rgba(245,239,227,0.4);
  letter-spacing:0.08em;
}
.f-bottom a:hover{color:var(--gold)}

/* ── REVIEWS ──────────────────────────────────────────── */
.reviews-hero{padding-top:160px;padding-bottom:60px;border-bottom:1px solid var(--border)}
.reviews-summary{
  display:grid;
  grid-template-columns:auto 1fr;
  gap:50px;
  align-items:center;
  padding:50px 0 30px;
}
.rating-big{
  font-family:var(--serif);
  font-size:clamp(72px,10vw,140px);
  font-weight:400;
  line-height:0.9;
  letter-spacing:-0.03em;
  color:var(--navy);
}
.rating-big sup{
  font-size:0.28em;color:var(--muted);font-weight:400;
  vertical-align:super;margin-left:6px;
}
.rating-side .stars{
  color:var(--gold);
  font-size:22px;
  letter-spacing:2px;
  margin-bottom:8px;
}
.rating-side p{
  font-family:var(--serif);
  font-size:18px;font-style:italic;
  color:var(--ink-soft);max-width:540px;
  line-height:1.5;
}

.reviews-section{padding:60px 0 100px}
.reviews-cta-card{
  background:var(--navy);color:var(--cream);
  border-radius:14px;
  padding:46px 42px;
  margin-bottom:70px;
  display:grid;
  grid-template-columns:1fr auto;
  gap:40px;
  align-items:center;
}
.reviews-cta-card h3{
  font-family:var(--serif);
  font-size:clamp(24px,3vw,34px);
  font-weight:400;
  line-height:1.2;
  color:var(--cream);
  margin-bottom:10px;
}
.reviews-cta-card h3 em{font-style:italic;color:var(--gold-soft)}
.reviews-cta-card p{
  font-size:14px;
  color:rgba(245,239,227,0.7);
  max-width:520px;
  line-height:1.55;
}

.reviews-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:24px;
  margin-bottom:40px;
}
.review-card{
  background:var(--cream-soft);
  border:1px solid var(--border);
  border-radius:12px;
  padding:30px 28px;
  display:flex;flex-direction:column;
  transition:transform 0.25s,box-shadow 0.25s;
}
.review-card:hover{
  transform:translateY(-3px);
  box-shadow:0 18px 38px -20px rgba(14,27,53,0.18);
}
.rc-stars{
  color:var(--gold);font-size:16px;
  letter-spacing:1.5px;margin-bottom:16px;
}
.rc-quote{
  font-family:var(--serif);
  font-size:17px;
  line-height:1.55;
  color:var(--ink);
  font-weight:400;
  margin-bottom:24px;
  flex:1;
}
.rc-meta{
  border-top:1px solid var(--border);
  padding-top:16px;
  display:flex;justify-content:space-between;
  align-items:flex-end;
}
.rc-name{
  font-family:var(--sans);
  font-size:13.5px;font-weight:600;
  color:var(--navy);
}
.rc-project{
  font-family:var(--mono);font-size:10px;
  letter-spacing:0.1em;color:var(--muted);
  margin-top:3px;
}
.rc-date{
  font-family:var(--mono);font-size:10px;
  letter-spacing:0.1em;color:var(--muted);
}
.rc-source{
  display:inline-block;
  margin-top:14px;
  font-family:var(--mono);
  font-size:9.5px;
  letter-spacing:0.16em;
  text-transform:uppercase;
  color:var(--muted);
  text-decoration:none;
  border-top:1px solid var(--border);
  padding-top:14px;
  width:100%;
  transition:color 0.2s;
}
.rc-source:hover{color:var(--gold-deep)}
.rc-source span{margin-left:4px;font-family:var(--sans);font-size:11px}

.reviews-empty{
  grid-column:1/-1;
  padding:80px 40px;
  text-align:center;
  background:var(--cream-soft);
  border:1px dashed var(--border);
  border-radius:12px;
}
.reviews-empty h4{
  font-family:var(--serif);
  font-size:28px;font-weight:400;
  color:var(--navy);
  margin-bottom:12px;
}
.reviews-empty p{
  font-size:15px;color:var(--ink-soft);
  max-width:440px;margin:0 auto;
}

/* Review submission modal */
.modal-backdrop{
  position:fixed;inset:0;
  background:rgba(14,27,53,0.72);
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
  display:none;
  align-items:flex-start;justify-content:center;
  padding:60px 20px 20px;
  z-index:200;overflow-y:auto;
}
.modal-backdrop.open,
.modal-backdrop.show{display:flex}
.review-modal{
  background:var(--cream);
  border-radius:16px;
  max-width:560px;width:100%;
  padding:42px 38px;
  position:relative;
  animation:mIn 0.3s cubic-bezier(.2,.8,.2,1);
}
@keyframes mIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.modal-close{
  position:absolute;top:18px;right:18px;
  width:36px;height:36px;
  background:none;border:none;cursor:pointer;
  font-size:22px;color:var(--muted);
  border-radius:8px;
  transition:all 0.2s;
}
.modal-close:hover{background:rgba(14,27,53,0.06);color:var(--navy)}
.review-modal h3{
  font-family:var(--serif);
  font-size:30px;font-weight:400;
  line-height:1.1;
  color:var(--navy);
  margin-bottom:10px;
}
.review-modal h3 em{font-style:italic;color:var(--gold-deep)}
.review-modal .m-intro{
  font-size:14px;color:var(--ink-soft);
  margin-bottom:24px;
  line-height:1.55;
}
.rm-stars-select{
  display:flex;gap:6px;margin-bottom:20px;
}
.rm-stars-select button{
  background:none;border:none;cursor:pointer;
  font-size:30px;color:var(--border);
  padding:0;
  transition:color 0.15s,transform 0.15s;
}
.rm-stars-select button:hover{transform:scale(1.15)}
.rm-stars-select button.on{color:var(--gold)}
.rm-field{margin-bottom:16px}
.rm-field label{
  display:block;
  font-family:var(--mono);font-size:10px;
  letter-spacing:0.18em;text-transform:uppercase;
  color:var(--gold-deep);
  margin-bottom:8px;
}
.rm-field input,.rm-field textarea{
  width:100%;
  background:var(--cream-soft);
  border:1px solid var(--border);
  border-radius:8px;
  padding:12px 14px;
  font-family:var(--sans);
  font-size:14px;
  color:var(--ink);
  outline:none;
  transition:border-color 0.2s;
}
.rm-field input:focus,.rm-field textarea:focus{border-color:var(--gold)}
.rm-field textarea{resize:vertical;min-height:120px;line-height:1.55}
.rm-submit{
  width:100%;
  background:var(--navy);color:var(--cream);
  border:none;border-radius:8px;
  padding:16px 22px;
  font-family:var(--sans);font-size:14px;font-weight:600;
  letter-spacing:0.02em;
  cursor:pointer;
  transition:all 0.2s;
  margin-top:12px;
}
.rm-submit:hover{background:var(--navy-deep)}
.rm-submit:disabled{opacity:0.55;cursor:wait}
.rm-note{
  font-family:var(--mono);font-size:10px;
  letter-spacing:0.12em;
  color:var(--muted);
  text-align:center;
  margin-top:14px;
  line-height:1.5;
}
.rm-thanks{
  display:none;
  text-align:center;
  padding:40px 10px;
}
.rm-thanks.show{display:block}
.rm-thanks-icon{
  font-family:var(--serif);
  font-size:64px;color:var(--gold);
  line-height:1;margin-bottom:16px;
}
.rm-thanks h4{
  font-family:var(--serif);
  font-size:28px;font-weight:400;
  color:var(--navy);
  margin-bottom:10px;
}
.rm-thanks h4 em{font-style:italic;color:var(--gold-deep)}
.rm-thanks p{
  font-size:14px;color:var(--ink-soft);
  max-width:380px;margin:0 auto;
  line-height:1.55;
}

/* ── RESPONSIVE ───────────────────────────────────────── */
@media (max-width:1024px){
  .section, .nav-inner{padding-left:30px;padding-right:30px}
  .reviews-summary{grid-template-columns:1fr;gap:24px}
  .reviews-cta-card{grid-template-columns:1fr;gap:24px}
  .reviews-grid{grid-template-columns:1fr;gap:18px}
  .hero-grid{grid-template-columns:1fr;gap:60px}
  .services-head{grid-template-columns:1fr;gap:24px}
  .services-head p{justify-self:start}
  .steps{grid-template-columns:repeat(2,1fr);gap:40px 30px}
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:50px 30px}
  .contact-wrap{grid-template-columns:1fr;gap:50px}
  .portfolio-grid{gap:20px}
  .project-card.large,.project-card.small,.project-card.wide,.project-card.medium{grid-column:span 12}
  .service-row{grid-template-columns:60px 1fr;gap:24px}
  .service-row .sr-body{grid-column:2}
  .footer-grid{grid-template-columns:1fr 1fr;gap:40px}
  .f-brand{grid-column:span 2}
}

@media (max-width:720px){
  .section, .nav-inner{padding-left:20px;padding-right:20px}
  .reviews-hero{padding-top:130px;padding-bottom:40px}
  .reviews-cta-card{padding:30px 24px}
  .review-modal{padding:32px 24px}
  .rating-big{font-size:72px}
  .nav-links{
    position:fixed;top:72px;left:0;right:0;
    background:var(--cream);
    flex-direction:column;
    padding:20px;gap:4px;
    border-bottom:1px solid var(--border);
    transform:translateY(-120%);
    opacity:0;pointer-events:none;
    transition:all 0.3s;
  }
  .nav-links.open{transform:translateY(0);opacity:1;pointer-events:auto}
  .nav-link{width:100%;text-align:left;padding:14px 16px}
  .nav-cta{display:none}
  .menu-btn{display:flex}
  .nav-phone-mobile{display:flex}
  .whatsapp-fab{display:flex}

  .hero{padding-top:130px;padding-bottom:60px}
  .services-block{padding:80px 0 40px}
  .services-grid{grid-template-columns:1fr}
  .approach{padding:80px 0}
  .steps{grid-template-columns:1fr;gap:36px}
  .stats-band{padding:70px 0}
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:40px 20px}
  .final-cta{padding:80px 0}
  .services-list{padding:60px 0}
  .service-row{padding:36px 0;grid-template-columns:1fr}
  .service-row .sr-num{padding-top:0}
  .sr-list{grid-template-columns:1fr}
  .portfolio-grid{padding:50px 0 80px;gap:16px}
  .project-card{padding:24px;min-height:360px}
  .contact-form{padding:30px 24px}
  .cf-grid{grid-template-columns:1fr}
  .cf-field.full{grid-column:span 1}
  .footer{padding:60px 0 30px}
  .footer-grid{grid-template-columns:1fr;gap:36px;padding-bottom:36px}
  .f-brand{grid-column:span 1}
  .f-bottom{flex-direction:column;gap:12px;text-align:center}
  .hv-big{font-size:72px}
  .hv-stats{gap:24px}
}

/* Reveal on scroll */
.reveal{opacity:0;transform:translateY(24px);transition:all 0.8s cubic-bezier(.2,.8,.2,1)}
.reveal.in{opacity:1;transform:translateY(0)}

/* ── LANGUAGE TOGGLE (floating, follows scroll) ─────────── */
.lang-toggle{
  position:fixed;
  bottom:24px;right:24px;
  z-index:150;
  display:inline-flex;align-items:center;
  background:var(--navy);
  color:var(--cream);
  border-radius:999px;
  padding:4px;
  box-shadow:
    0 12px 30px -10px rgba(14,27,53,0.45),
    0 4px 12px -4px rgba(14,27,53,0.25);
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:0.14em;
  user-select:none;
  transition:transform 0.35s cubic-bezier(.2,.8,.2,1),
             opacity 0.35s,
             box-shadow 0.3s;
  opacity:0;
  transform:translateY(24px) scale(0.95);
}
.lang-toggle.ready{opacity:1;transform:translateY(0) scale(1)}
.lang-toggle.scrolling{
  box-shadow:
    0 18px 40px -10px rgba(14,27,53,0.55),
    0 6px 16px -4px rgba(14,27,53,0.3);
}
.lang-toggle button{
  background:transparent;
  border:none;
  color:rgba(245,239,227,0.55);
  padding:8px 14px;
  border-radius:999px;
  cursor:pointer;
  font-family:inherit;
  font-size:inherit;
  letter-spacing:inherit;
  font-weight:600;
  transition:all 0.25s;
}
.lang-toggle button:hover{color:var(--cream)}
.lang-toggle button.on{
  background:var(--gold);
  color:var(--navy);
}
@media(max-width:640px){
  .lang-toggle{bottom:16px;right:16px;font-size:10px}
  .lang-toggle button{padding:7px 12px}
}