/* ═══════════════════════════════════════════════════════════════
   GINEEN SERVICES — Premium one-page experience
   Palette: navy #0b2545 · orange #f26b1f · cream #fff8f0 · ink #06122a
   ═══════════════════════════════════════════════════════════════ */

:root{
  --navy-900:#06122a;
  --navy-800:#0b2545;
  --navy-700:#13325f;
  --navy-600:#1c4583;
  --navy-100:#dfe8f5;

  --orange-700:#c5500f;
  --orange-600:#f26b1f;
  --orange-500:#ff8a3d;
  --orange-100:#ffe8d6;

  --cream:#fff8f0;
  --bg:#ffffff;
  --line:rgba(11,37,69,.08);
  --muted:#5b6b85;
  --text:#0b2545;

  --shadow-sm: 0 6px 20px -10px rgba(11,37,69,.25);
  --shadow:    0 30px 60px -30px rgba(11,37,69,.35);
  --shadow-lg: 0 50px 120px -40px rgba(11,37,69,.45);

  --rad: 22px;
  --rad-sm: 14px;

  --container: 1240px;
  --gutter: clamp(20px, 4vw, 56px);

  --ease: cubic-bezier(.22,.61,.36,1);
  --ease-out: cubic-bezier(.16,1,.3,1);
}

*,*::before,*::after{ box-sizing:border-box }
html{ scroll-behavior:smooth }
html,body{ margin:0 }
body{
  font-family:"Manrope","Plus Jakarta Sans",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  color:var(--text);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{ max-width:100%; display:block }
a{ color:inherit; text-decoration:none }
button{ font:inherit; cursor:pointer; border:0; background:transparent }
input,select,textarea{ font:inherit; color:inherit }

::selection{ background:var(--orange-600); color:#fff }

/* ─── Helpers ─── */
.eyebrow{
  display:inline-flex; align-items:center; gap:10px;
  font-size:.78rem; letter-spacing:.18em; text-transform:uppercase; font-weight:700;
  color:var(--navy-700);
  padding:8px 14px; border-radius:999px;
  background:linear-gradient(135deg, #fff, #fff7ee);
  border:1px solid var(--line);
  box-shadow:var(--shadow-sm);
}
.eyebrow .dot{
  width:8px; height:8px; border-radius:999px;
  background:var(--orange-600);
  box-shadow:0 0 0 4px rgba(242,107,31,.18);
  animation:pulse 2s infinite;
}
.eyebrow--light{
  color:#fff; background:rgba(255,255,255,.08);
  border-color:rgba(255,255,255,.16);
  box-shadow:none; backdrop-filter:blur(8px);
}
.section-head{
  text-align:center; max-width:760px; margin:0 auto clamp(36px,5vw,64px);
}
.section-head h2{
  font-family:"Plus Jakarta Sans",sans-serif;
  font-weight:800;
  font-size:clamp(2rem, 4.4vw, 3.6rem);
  line-height:1.05; letter-spacing:-.02em;
  margin:18px 0 16px;
}
.section-head h2 em{
  font-family:"Playfair Display",serif;
  font-style:italic; font-weight:600;
  color:var(--orange-600);
}
.section-head p{
  color:var(--muted); font-size:1.08rem; line-height:1.65;
  max-width:600px; margin:0 auto;
}
.section-head--light h2{ color:#fff }
.section-head--light p{ color:rgba(255,255,255,.7) }

/* ─── Reveal animation ─── */
.reveal,.reveal-left,.reveal-right,.reveal-stack > *{
  opacity:0; transform:translateY(34px);
  transition:opacity .9s var(--ease-out), transform .9s var(--ease-out);
  transition-delay: calc(var(--i,0) * 80ms);
}
.reveal-left{ transform:translateX(-50px) }
.reveal-right{ transform:translateX(50px) }
.is-visible.reveal,
.is-visible.reveal-left,
.is-visible.reveal-right,
.reveal-stack.is-visible > *{
  opacity:1; transform:none;
}
.reveal-stack > *{ transition-delay: calc(var(--i,0) * 110ms) }
.reveal-stack > *:nth-child(1){ --i:1 }
.reveal-stack > *:nth-child(2){ --i:2 }
.reveal-stack > *:nth-child(3){ --i:3 }
.reveal-stack > *:nth-child(4){ --i:4 }
.reveal-stack > *:nth-child(5){ --i:5 }

@keyframes pulse{
  0%,100%{ box-shadow:0 0 0 4px rgba(242,107,31,.18) }
  50%   { box-shadow:0 0 0 8px rgba(242,107,31,0) }
}
@keyframes floaty{
  0%,100%{ transform:translateY(0) }
  50%   { transform:translateY(-14px) }
}
@keyframes drift{
  0%  { transform:translate3d(0,0,0) }
  50% { transform:translate3d(40px,-20px,0) }
  100%{ transform:translate3d(0,0,0) }
}
@keyframes shimmer{
  0%  { background-position: 200% 0 }
  100%{ background-position:-200% 0 }
}
@keyframes ping{
  0%  { transform:scale(1); opacity:1 }
  100%{ transform:scale(3.4); opacity:0 }
}

/* ═══════════════════════════════════════
   DOCK
   ═══════════════════════════════════════ */
.dock{
  position:fixed; right:18px; bottom:18px; z-index:90;
  display:flex; flex-direction:column; gap:12px;
}
.dock__btn{
  width:54px; height:54px; border-radius:18px;
  display:grid; place-items:center;
  background:#fff; color:var(--navy-800);
  box-shadow:var(--shadow);
  transition:transform .35s var(--ease), background .35s, color .35s;
  position:relative;
}
.dock__btn svg{ width:24px; height:24px }
.dock__btn:hover{ transform:translateY(-3px) }
.dock__btn--wa{ background:#25D366; color:#fff }
.dock__btn--call{ background:linear-gradient(135deg,var(--orange-600),var(--orange-500)); color:#fff }
.dock__btn--top{ opacity:0; pointer-events:none; transition:opacity .35s, transform .35s }
.is-scrolled .dock__btn--top{ opacity:1; pointer-events:auto }

/* ═══════════════════════════════════════
   RIBBON
   ═══════════════════════════════════════ */
.ribbon{
  background:var(--navy-900);
  color:#fff;
  overflow:hidden;
  font-size:.84rem; letter-spacing:.04em;
  border-bottom:1px solid rgba(255,255,255,.06);
}
.ribbon__track{
  display:flex; gap:48px;
  white-space:nowrap;
  padding:11px 0;
  animation: marquee 38s linear infinite;
  width:max-content;
}
.ribbon__track span{ opacity:.88 }
@keyframes marquee{
  0%  { transform:translateX(0) }
  100%{ transform:translateX(-50%) }
}

/* ═══════════════════════════════════════
   NAV
   ═══════════════════════════════════════ */
.nav{
  position:sticky; top:0; z-index:80;
  display:grid; grid-template-columns:auto 1fr auto;
  align-items:center; gap:24px;
  padding: 18px var(--gutter);
  background:rgba(255,255,255,.7);
  backdrop-filter: saturate(160%) blur(18px);
  -webkit-backdrop-filter: saturate(160%) blur(18px);
  border-bottom:1px solid transparent;
  transition: padding .35s var(--ease), background .35s, border-color .35s, box-shadow .35s;
}
.is-scrolled .nav{
  padding-block:12px;
  background:rgba(255,255,255,.88);
  border-bottom-color:var(--line);
  box-shadow:var(--shadow-sm);
}
.nav__brand{ display:flex; align-items:center; gap:12px }
.nav__brand img{ width:48px; height:48px; object-fit:contain }
.nav__brand-text{
  display:flex; flex-direction:column; line-height:1;
  font-family:"Plus Jakarta Sans",sans-serif;
}
.nav__brand-text strong{ font-size:1.18rem; color:var(--navy-800); letter-spacing:-.01em }
.nav__brand-text em{ font-style:normal; font-size:.78rem; letter-spacing:.32em; color:var(--orange-600); font-weight:700; margin-top:3px }

.nav__links{
  display:flex; justify-content:center; gap:34px;
  font-weight:600; font-size:.95rem;
}
.nav__links a{
  position:relative; padding:6px 0;
  color:var(--navy-800); opacity:.85;
  transition:opacity .25s;
}
.nav__links a::after{
  content:""; position:absolute; left:50%; bottom:-2px;
  width:0; height:2px; background:var(--orange-600);
  transition: width .35s var(--ease), left .35s var(--ease);
  border-radius:2px;
}
.nav__links a:hover{ opacity:1 }
.nav__links a:hover::after{ width:100%; left:0 }

.nav__cta{ display:flex; align-items:center; gap:14px; justify-content:flex-end }
.phone-pill{
  display:flex; align-items:center; gap:12px;
  padding:8px 16px 8px 8px;
  border-radius:999px;
  background:linear-gradient(135deg,var(--navy-800),var(--navy-700));
  color:#fff;
  box-shadow:var(--shadow-sm);
  transition: transform .35s var(--ease), box-shadow .35s;
}
.phone-pill:hover{ transform:translateY(-2px); box-shadow:var(--shadow) }
.phone-pill__icon{
  width:38px; height:38px; border-radius:50%;
  background:linear-gradient(135deg,var(--orange-600),var(--orange-500));
  display:grid; place-items:center;
}
.phone-pill__icon svg{ width:18px; height:18px; fill:#fff }
.phone-pill small{ display:block; font-size:.66rem; letter-spacing:.18em; opacity:.75; text-transform:uppercase }
.phone-pill b{ font-size:1rem; letter-spacing:.02em }

.nav__burger{ display:none; flex-direction:column; gap:5px; padding:10px }
.nav__burger span{ width:24px; height:2px; background:var(--navy-800); border-radius:2px; transition:transform .3s, opacity .3s }

/* ═══════════════════════════════════════
   HERO
   ═══════════════════════════════════════ */
.hero{
  position:relative;
  padding: clamp(60px, 8vw, 110px) var(--gutter) clamp(80px, 10vw, 140px);
  overflow:hidden;
  background:
    radial-gradient(ellipse at top right, #fff3e3 0%, transparent 60%),
    linear-gradient(180deg, #fffaf2 0%, #ffffff 70%);
}
.hero__bg{ position:absolute; inset:0; pointer-events:none; overflow:hidden }
.hero__orb{
  position:absolute; border-radius:50%;
  filter: blur(80px);
  opacity:.55;
}
.hero__orb--1{ width:440px; height:440px; background:#ffd9b3; top:-120px; left:-80px; animation:drift 18s ease-in-out infinite }
.hero__orb--2{ width:520px; height:520px; background:#cfe2ff; bottom:-180px; right:-120px; animation:drift 22s ease-in-out infinite reverse }
.hero__orb--3{ width:280px; height:280px; background:#ffe6cf; top:35%; left:40%; animation:drift 14s ease-in-out infinite }
.hero__grid{
  position:absolute; inset:0;
  background-image:
    linear-gradient(to right, rgba(11,37,69,.05) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(11,37,69,.05) 1px, transparent 1px);
  background-size: 56px 56px;
  mask-image: radial-gradient(ellipse at center, #000 35%, transparent 75%);
  opacity:.4;
}

.hero__inner{
  position:relative;
  max-width:var(--container); margin:0 auto;
  display:grid; grid-template-columns: 1.05fr 1fr; gap: clamp(40px, 6vw, 90px);
  align-items:center;
}

.hero__title{
  font-family:"Plus Jakarta Sans",sans-serif;
  font-weight:800;
  font-size: clamp(2.6rem, 6vw, 5.4rem);
  line-height:.96; letter-spacing:-.035em;
  color:var(--navy-900);
  margin:18px 0 22px;
}
.hero__title .line{ display:block; overflow:hidden }
.hero__title .line span,
.hero__title .line em{ display:inline-block }
.hero__title .line--accent em{
  font-family:"Playfair Display",serif;
  font-weight:600; font-style:italic;
  color:var(--orange-600);
  position:relative;
}
.hero__title .ital::after{
  content:""; position:absolute; bottom:.05em; left:0; right:0; height:.18em;
  background: linear-gradient(90deg, transparent, var(--orange-100), transparent);
  z-index:-1; transform:skewY(-2deg);
}
.hero__sub{
  color:var(--muted); font-size:1.12rem; line-height:1.7;
  max-width:540px; margin:0 0 32px;
}
.hero__cta{ display:flex; flex-wrap:wrap; gap:14px; margin-bottom:34px }
.hero__pills{
  list-style:none; padding:0; margin:0;
  display:flex; flex-wrap:wrap; gap:14px 22px;
  color:var(--navy-800); font-weight:600; font-size:.94rem;
}
.hero__pills li{ display:inline-flex; align-items:center; gap:8px }
.hero__pills svg{ width:18px; height:18px; color:var(--orange-600) }

/* Buttons */
.btn{
  display:inline-flex; align-items:center; gap:10px;
  padding: 16px 24px; border-radius:14px;
  font-weight:700; font-size:.98rem; letter-spacing:.01em;
  transition: transform .35s var(--ease), box-shadow .35s, background .35s, color .35s;
  white-space:nowrap;
  position:relative; overflow:hidden;
}
.btn svg{ width:20px; height:20px }
.btn--primary{
  background:linear-gradient(135deg,var(--orange-600),var(--orange-500));
  color:#fff;
  box-shadow: 0 18px 40px -16px rgba(242,107,31,.7);
}
.btn--primary::after{
  content:""; position:absolute; inset:0;
  background: linear-gradient(120deg, transparent 30%, rgba(255,255,255,.45) 50%, transparent 70%);
  background-size:200% 100%;
  animation: shimmer 6s linear infinite;
  pointer-events:none;
}
.btn--primary:hover{ transform:translateY(-3px); box-shadow:0 24px 60px -18px rgba(242,107,31,.85) }
.btn--ghost{
  background:#fff; color:var(--navy-800);
  border:1px solid var(--line);
  box-shadow:var(--shadow-sm);
}
.btn--ghost:hover{ background:var(--navy-800); color:#fff; transform:translateY(-3px) }
.btn--xl{ padding:22px 30px; font-size:1.05rem; border-radius:18px }
.btn--xl small{ display:block; font-size:.62rem; letter-spacing:.2em; opacity:.75; text-transform:uppercase }
.btn--xl b{ font-size:1.15rem }
.btn--full{ width:100%; justify-content:center }

/* Hero visual stack */
.hero__visual{ position:relative; min-height:560px }
.card-stack{ position:relative; width:100%; height:100%; min-height:560px }
.card-stack figure{
  position:absolute; margin:0;
  border-radius:28px; overflow:hidden;
  box-shadow:var(--shadow-lg);
  transition: transform .8s var(--ease);
  background:#fff;
}
.card-stack figure img{ width:100%; height:100%; object-fit:cover }
.card-stack__back{
  width:62%; aspect-ratio:3/4;
  top:8%; right:0;
  transform: rotate(6deg);
  filter: saturate(95%);
}
.card-stack__mid{
  width:52%; aspect-ratio:3/4;
  top:38%; left:0;
  transform: rotate(-7deg);
}
.card-stack__front{
  width:70%; aspect-ratio:4/5;
  top:0; left:14%;
  z-index:2;
  animation: floaty 7s ease-in-out infinite;
}
.card-stack__front figcaption{
  position:absolute; left:18px; bottom:18px; right:18px;
  padding:14px 18px;
  background:rgba(255,255,255,.92);
  backdrop-filter: blur(8px);
  border-radius:16px;
  font-family:"Plus Jakarta Sans",sans-serif;
}
.card-stack__front figcaption strong{ display:block; color:var(--navy-800); font-size:1.05rem; margin-bottom:2px }
.card-stack__front figcaption span{ color:var(--orange-600); font-weight:600; font-size:.86rem }
.card-stack:hover .card-stack__back{ transform: rotate(8deg) translateY(-6px) }
.card-stack:hover .card-stack__mid{ transform: rotate(-9deg) translateY(-6px) }
.card-stack:hover .card-stack__front{ animation-play-state:paused; transform: translateY(-10px) }

.floater{
  position:absolute; z-index:3;
  background:#fff; border-radius:16px;
  padding:12px 16px; box-shadow:var(--shadow);
  display:flex; align-items:center; gap:12px;
  font-family:"Plus Jakarta Sans",sans-serif;
}
.floater svg{ width:28px; height:28px }
.floater--rating{ top:-4%; left:-8%; animation: floaty 8s ease-in-out infinite }
.floater--rating b{ display:block; font-size:1.1rem; color:var(--navy-900); line-height:1 }
.floater--rating span{ font-size:.78rem; color:var(--muted) }
.floater--ticker{
  bottom:-4%; right:-2%;
  color:var(--navy-900); font-weight:700; font-size:.88rem;
  animation: floaty 9s ease-in-out infinite .8s;
}
.floater--ticker .ping{
  width:10px; height:10px; border-radius:50%;
  background:#22c55e; position:relative;
}
.floater--ticker .ping::after{
  content:""; position:absolute; inset:0; border-radius:50%; background:#22c55e;
  animation: ping 1.6s ease-out infinite;
}

.hero__scroll{
  position:absolute; bottom:22px; left:50%; transform:translateX(-50%);
  display:flex; flex-direction:column; align-items:center; gap:10px;
  color:var(--navy-700); font-size:.72rem; letter-spacing:.32em; text-transform:uppercase; font-weight:700;
}
.hero__scroll span{
  width:20px; height:34px; border:2px solid var(--navy-700); border-radius:14px;
  position:relative;
}
.hero__scroll span::after{
  content:""; position:absolute; left:50%; top:8px; transform:translateX(-50%);
  width:3px; height:8px; background:var(--orange-600); border-radius:2px;
  animation: scrollMouse 1.8s ease-in-out infinite;
}
@keyframes scrollMouse{
  0%,100%{ transform:translate(-50%,0); opacity:1 }
  50%   { transform:translate(-50%,10px); opacity:.4 }
}

/* ═══════════════════════════════════════
   STRIP / MARQUEE
   ═══════════════════════════════════════ */
.strip{
  background:var(--navy-800);
  color:#fff;
  padding:22px 0;
  overflow:hidden;
  border-top:1px solid rgba(255,255,255,.06);
  border-bottom:1px solid rgba(255,255,255,.06);
}
.strip__track{
  display:flex; align-items:center; gap:32px;
  white-space:nowrap;
  font-family:"Playfair Display",serif;
  font-style:italic; font-weight:500; font-size:1.6rem;
  animation: marquee 42s linear infinite;
  width:max-content;
}
.strip__track span{ display:inline-block }
.strip__track i{ color:var(--orange-600); font-style:normal; font-size:.6em }

/* ═══════════════════════════════════════
   SERVICES
   ═══════════════════════════════════════ */
.services{
  padding: clamp(80px, 9vw, 130px) var(--gutter);
  max-width:var(--container); margin:0 auto;
}
.services__grid{
  display:grid; gap:20px;
  grid-template-columns: repeat(12, 1fr);
}
.svc{
  grid-column: span 4;
  position:relative;
  padding:32px 28px 28px;
  border-radius:var(--rad);
  background:#fff;
  border:1px solid var(--line);
  box-shadow: 0 8px 28px -18px rgba(11,37,69,.18);
  transition: transform .45s var(--ease), box-shadow .45s, border-color .45s;
  overflow:hidden;
}
.svc::before{
  content:""; position:absolute; inset:auto -40% -40% auto;
  width:60%; aspect-ratio:1; border-radius:50%;
  background: radial-gradient(circle at center, var(--orange-100), transparent 60%);
  opacity:0; transition: opacity .45s;
  pointer-events:none;
}
.svc:hover{
  transform: translateY(-8px);
  box-shadow: 0 30px 60px -25px rgba(11,37,69,.35);
  border-color: var(--orange-100);
}
.svc:hover::before{ opacity:1 }
.svc__icon{
  width:60px; height:60px; border-radius:18px;
  background:linear-gradient(135deg, #fff5e9, #fff);
  border:1px solid var(--line);
  display:grid; place-items:center;
  color:var(--orange-600);
  margin-bottom:24px;
  transition: transform .45s var(--ease), background .45s, color .45s;
}
.svc__icon svg{ width:28px; height:28px }
.svc:hover .svc__icon{
  background:linear-gradient(135deg,var(--orange-600),var(--orange-500));
  color:#fff; transform: rotate(-8deg) scale(1.05);
}
.svc h3{
  font-family:"Plus Jakarta Sans",sans-serif;
  font-size:1.32rem; margin:0 0 8px;
  letter-spacing:-.01em;
}
.svc > p{
  color:var(--muted); line-height:1.6; font-size:.96rem; margin:0 0 18px;
}
.svc__points{
  list-style:none; padding:0; margin:0 0 22px;
  display:grid; gap:6px;
  font-size:.88rem; color:var(--navy-700); font-weight:600;
}
.svc__points li{ display:flex; align-items:center; gap:8px }
.svc__points li::before{
  content:""; width:6px; height:6px; border-radius:50%; background:var(--orange-600);
}
.svc__points--row{ grid-template-columns: 1fr 1fr; gap:6px 22px }
.svc__cta{
  display:inline-flex; align-items:center; gap:8px;
  font-weight:700; color:var(--navy-800);
  border-bottom:2px solid transparent;
  padding-bottom:3px;
  transition: color .3s, border-color .3s, gap .3s;
}
.svc__cta i{ font-style:normal; transition: transform .3s var(--ease) }
.svc__cta:hover{ color:var(--orange-600); border-color:var(--orange-600); gap:14px }
.svc__cta:hover i{ transform:translateX(4px) }

.svc--wide{ grid-column: span 8 }
.svc--dark{
  grid-column: span 4;
  background: linear-gradient(160deg, var(--navy-800) 0%, var(--navy-900) 100%);
  color:#fff; border-color: transparent;
}
.svc--dark h3{ color:#fff }
.svc--dark > p{ color:rgba(255,255,255,.7) }
.svc--dark .svc__icon{ background:rgba(255,255,255,.08); border-color:rgba(255,255,255,.12); color:#fff }
.svc--dark .svc__points{ color:rgba(255,255,255,.85) }
.svc__cta--light{ color:#fff }
.svc__cta--light:hover{ color:var(--orange-500); border-color:var(--orange-500) }

/* ═══════════════════════════════════════
   WHY US
   ═══════════════════════════════════════ */
.why{
  position:relative;
  padding: clamp(80px, 9vw, 130px) var(--gutter);
  background: linear-gradient(160deg, var(--navy-900) 0%, var(--navy-800) 60%, var(--navy-700) 100%);
  color:#fff;
  overflow:hidden;
}
.why::before{
  content:""; position:absolute; inset:0;
  background:
    radial-gradient(circle at 15% 20%, rgba(242,107,31,.25), transparent 35%),
    radial-gradient(circle at 85% 80%, rgba(28,69,131,.7), transparent 40%);
  pointer-events:none;
}
.why::after{
  content:""; position:absolute; inset:0;
  background-image:
    linear-gradient(to right, rgba(255,255,255,.04) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255,255,255,.04) 1px, transparent 1px);
  background-size: 60px 60px;
  mask-image: radial-gradient(ellipse at center, #000 30%, transparent 80%);
  pointer-events:none;
}
.why > *{ position:relative; z-index:1 }
.why__grid{
  max-width:var(--container); margin:0 auto;
  display:grid; gap:20px;
  grid-template-columns: repeat(4, 1fr);
}
.why__card{
  position:relative;
  padding:36px 28px 30px;
  border-radius:var(--rad);
  background: linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.02));
  border:1px solid rgba(255,255,255,.1);
  backdrop-filter: blur(12px);
  overflow:hidden;
}
.why__card::before{
  content:""; position:absolute; top:0; left:0; right:0; height:2px;
  background: linear-gradient(90deg, transparent, var(--orange-600), transparent);
  opacity:.7;
}
.why__num{
  font-family:"Plus Jakarta Sans",sans-serif;
  font-weight:800; font-size:clamp(3rem, 5vw, 4.4rem);
  background:linear-gradient(135deg, #fff, var(--orange-500));
  -webkit-background-clip:text; background-clip:text;
  color:transparent;
  line-height:1; letter-spacing:-.04em;
}
.why__plus{
  display:inline-block;
  font-family:"Plus Jakarta Sans",sans-serif;
  font-weight:800; font-size:1.6rem;
  color:var(--orange-500); vertical-align:top; margin-left:4px;
}
.why__card h3{
  font-family:"Plus Jakarta Sans",sans-serif;
  margin:18px 0 8px; font-size:1.15rem; color:#fff;
}
.why__card p{ color:rgba(255,255,255,.72); font-size:.92rem; line-height:1.6; margin:0 }

.why__pillars{
  max-width:var(--container); margin:60px auto 0;
  display:grid; gap:20px;
  grid-template-columns: repeat(4, 1fr);
}
.pillar{
  position:relative; padding:30px 26px;
  border-radius:var(--rad-sm);
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  transition: background .35s, transform .35s var(--ease);
}
.pillar:hover{ background:rgba(255,255,255,.08); transform:translateY(-4px) }
.pillar__num{
  font-family:"Playfair Display",serif;
  font-style:italic; font-weight:500;
  font-size:1.5rem; color:var(--orange-500);
}
.pillar h4{
  font-family:"Plus Jakarta Sans",sans-serif;
  margin:14px 0 8px; font-size:1.05rem; color:#fff;
}
.pillar p{ font-size:.88rem; color:rgba(255,255,255,.7); line-height:1.55; margin:0 }

/* ═══════════════════════════════════════
   PROCESS
   ═══════════════════════════════════════ */
.process{
  padding: clamp(80px, 9vw, 130px) var(--gutter);
  max-width:var(--container); margin:0 auto;
}
.process__list{
  list-style:none; padding:0; margin:0;
  display:grid; grid-template-columns: repeat(4, 1fr); gap:18px;
  position:relative;
}
.process__list::before{
  content:""; position:absolute; top:34px; left:6%; right:6%; height:2px;
  background: repeating-linear-gradient(90deg, var(--orange-600) 0 8px, transparent 8px 16px);
  z-index:0;
}
.step{
  position:relative; z-index:1;
  padding:34px 24px 28px;
  border-radius:var(--rad);
  background:#fff; border:1px solid var(--line);
  text-align:center;
  transition: transform .45s var(--ease), box-shadow .45s;
}
.step:hover{ transform: translateY(-6px); box-shadow:var(--shadow) }
.step__num{
  display:inline-grid; place-items:center;
  width:64px; height:64px; border-radius:50%;
  background:linear-gradient(135deg,var(--orange-600),var(--orange-500));
  color:#fff; font-family:"Plus Jakarta Sans",sans-serif;
  font-weight:800; font-size:1.25rem;
  box-shadow: 0 10px 30px -10px rgba(242,107,31,.7);
  margin-bottom:18px;
}
.step h3{
  font-family:"Plus Jakarta Sans",sans-serif;
  margin:0 0 8px; font-size:1.18rem;
}
.step p{ color:var(--muted); font-size:.95rem; line-height:1.6; margin:0 }

/* ═══════════════════════════════════════
   FEATURE SPLIT
   ═══════════════════════════════════════ */
.feature{
  padding: clamp(80px, 9vw, 130px) var(--gutter);
  max-width:var(--container); margin:0 auto;
  display:grid; gap:clamp(40px,5vw,80px);
  grid-template-columns: 1fr 1fr;
  align-items:center;
}
.feature__media{ position:relative; min-height:520px }
.feature__frame{
  position:absolute; overflow:hidden;
  border-radius:24px;
  box-shadow:var(--shadow-lg);
}
.feature__frame:first-child{
  inset:0 30% 25% 0;
  border:8px solid #fff;
}
.feature__frame img{ width:100%; height:100%; object-fit:cover }
.feature__frame--small{
  inset:35% 0 0 35%;
  width:auto; aspect-ratio:4/3;
  border:6px solid #fff;
  transform: rotate(4deg);
}
.feature__chip{
  position:absolute; left:16px; top:16px;
  background:rgba(255,255,255,.92); backdrop-filter:blur(8px);
  padding:8px 14px 8px 12px; border-radius:999px;
  font-size:.82rem; font-weight:700; color:var(--navy-800);
  display:flex; align-items:center; gap:8px;
  box-shadow:var(--shadow-sm);
}
.feature__chip .ping{
  width:8px; height:8px; border-radius:50%; background:#22c55e; position:relative;
}
.feature__chip .ping::after{
  content:""; position:absolute; inset:0; border-radius:50%; background:#22c55e;
  animation: ping 1.6s ease-out infinite;
}

.feature__copy h2{
  font-family:"Plus Jakarta Sans",sans-serif;
  font-weight:800; font-size: clamp(1.8rem, 3.4vw, 2.8rem);
  letter-spacing:-.02em; line-height:1.1; margin:16px 0;
}
.feature__copy h2 em{
  font-family:"Playfair Display",serif;
  font-style:italic; font-weight:600; color:var(--orange-600);
}
.feature__copy p{ color:var(--muted); line-height:1.7; font-size:1.05rem }
.feature__list{
  list-style:none; padding:0; margin:24px 0 32px;
  display:grid; gap:10px; font-weight:600;
}
.feature__list li{ display:flex; align-items:center; gap:12px; color:var(--navy-800) }
.feature__list i{
  display:grid; place-items:center;
  width:26px; height:26px; border-radius:50%;
  background:var(--orange-600); color:#fff;
  font-style:normal; font-weight:800; font-size:.9rem;
}

/* ═══════════════════════════════════════
   WORK / GALLERY
   ═══════════════════════════════════════ */
.work{
  padding: clamp(80px, 9vw, 130px) var(--gutter);
  max-width:var(--container); margin:0 auto;
}
.work__grid{
  display:grid; gap:14px;
  grid-template-columns: repeat(4, 1fr);
  grid-auto-rows: 200px;
}
.work__item{
  position:relative; margin:0; overflow:hidden;
  border-radius:18px;
  background:var(--navy-800);
}
.work__item img{
  width:100%; height:100%; object-fit:cover;
  transition: transform 1.2s var(--ease), filter 1.2s var(--ease);
  filter: saturate(96%);
}
.work__item::after{
  content:""; position:absolute; inset:0;
  background: linear-gradient(180deg, transparent 50%, rgba(6,18,42,.85) 100%);
  opacity:.8; transition: opacity .35s;
}
.work__item figcaption{
  position:absolute; left:18px; right:18px; bottom:14px;
  color:#fff; font-weight:700; font-size:.92rem;
  z-index:1;
  transform: translateY(8px); opacity:.85;
  transition: transform .45s var(--ease), opacity .45s;
}
.work__item:hover img{ transform: scale(1.08); filter: saturate(110%) }
.work__item:hover figcaption{ transform: none; opacity:1 }
.work__item:hover::after{ opacity:1 }

.work__item--a{ grid-column: span 2; grid-row: span 2 }
.work__item--b{ grid-column: span 1; grid-row: span 1 }
.work__item--c{ grid-column: span 1; grid-row: span 1 }
.work__item--d{ grid-column: span 1; grid-row: span 1 }
.work__item--e{ grid-column: span 1; grid-row: span 1 }
.work__item--f{ grid-column: span 2; grid-row: span 1 }
.work__item--g{ grid-column: span 1; grid-row: span 1 }
.work__item--h{ grid-column: span 1; grid-row: span 1 }

/* ═══════════════════════════════════════
   REVIEWS
   ═══════════════════════════════════════ */
.reviews{
  padding: clamp(80px, 9vw, 130px) var(--gutter);
  background: linear-gradient(180deg, var(--navy-900) 0%, var(--navy-800) 100%);
  color:#fff; position:relative; overflow:hidden;
}
.reviews::before{
  content:""; position:absolute; top:-20%; left:-10%; width:60%; aspect-ratio:1;
  background: radial-gradient(circle, rgba(242,107,31,.18), transparent 60%);
  filter:blur(40px); pointer-events:none;
}
.reviews__grid{
  position:relative;
  max-width:var(--container); margin:0 auto;
  display:grid; gap:20px;
  grid-template-columns: repeat(2, 1fr);
}
.review{
  margin:0; padding:32px 30px;
  border-radius:var(--rad);
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
  border:1px solid rgba(255,255,255,.1);
  position:relative;
  transition: transform .45s var(--ease), background .45s;
}
.review:hover{ transform: translateY(-6px); background: rgba(255,255,255,.08) }
.review::before{
  content:"\201C"; position:absolute; top:-10px; right:24px;
  font-family:"Playfair Display",serif;
  font-size:6rem; line-height:1; color:var(--orange-600); opacity:.4;
}
.review__stars{
  color:var(--orange-500); font-size:1.1rem; letter-spacing:.15em; margin-bottom:14px;
}
.review blockquote{
  margin:0; font-size:1.05rem; line-height:1.7; font-weight:500;
  color:rgba(255,255,255,.92);
}
.review figcaption{
  margin-top:22px; padding-top:18px;
  border-top:1px solid rgba(255,255,255,.1);
  display:flex; align-items:center; gap:14px;
}
.review__avatar{
  width:48px; height:48px; border-radius:50%;
  display:grid; place-items:center;
  background: var(--c, var(--orange-600));
  color:#fff; font-family:"Plus Jakarta Sans",sans-serif;
  font-weight:800; font-size:1.2rem;
}
.review figcaption b{ display:block; color:#fff; font-size:1rem }
.review figcaption em{ font-style:normal; color:rgba(255,255,255,.55); font-size:.85rem }

/* ═══════════════════════════════════════
   MEGA CTA
   ═══════════════════════════════════════ */
.megacta{
  padding: clamp(80px, 9vw, 130px) var(--gutter);
  background: linear-gradient(135deg, var(--orange-700) 0%, var(--orange-600) 50%, var(--orange-500) 100%);
  color:#fff; text-align:center;
  position:relative; overflow:hidden;
}
.megacta::before{
  content:""; position:absolute; inset:0;
  background-image:
    radial-gradient(circle at 20% 20%, rgba(255,255,255,.18), transparent 30%),
    radial-gradient(circle at 80% 80%, rgba(255,255,255,.12), transparent 40%);
  pointer-events:none;
}
.megacta::after{
  content:""; position:absolute; inset:0;
  background-image:
    linear-gradient(to right, rgba(255,255,255,.08) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255,255,255,.08) 1px, transparent 1px);
  background-size: 80px 80px;
  mask-image: radial-gradient(ellipse at center, #000 25%, transparent 75%);
  pointer-events:none;
}
.megacta__inner{ position:relative; max-width:760px; margin:0 auto; z-index:1 }
.megacta h2{
  font-family:"Plus Jakarta Sans",sans-serif;
  font-weight:800; font-size: clamp(2rem, 4.4vw, 3.4rem);
  letter-spacing:-.02em; line-height:1.1; margin:18px 0;
}
.megacta h2 em{
  font-family:"Playfair Display",serif;
  font-style:italic; font-weight:600; color:#fff;
  background: linear-gradient(180deg, #fff 60%, rgba(255,255,255,.6));
  -webkit-background-clip:text; background-clip:text;
}
.megacta p{ color:rgba(255,255,255,.92); font-size:1.1rem; line-height:1.7; margin-bottom:32px }
.megacta__buttons{ display:flex; flex-wrap:wrap; gap:16px; justify-content:center }
.megacta .btn--primary{
  background:#fff; color:var(--orange-700);
  box-shadow: 0 20px 50px -20px rgba(0,0,0,.5);
}
.megacta .btn--primary::after{ display:none }
.megacta .btn--primary:hover{ background:var(--navy-900); color:#fff }
.megacta .btn--ghost{
  background:rgba(255,255,255,.1); color:#fff; border-color:rgba(255,255,255,.3);
  backdrop-filter:blur(8px);
}
.megacta .btn--ghost:hover{ background:#fff; color:var(--navy-900) }

/* ═══════════════════════════════════════
   CONTACT
   ═══════════════════════════════════════ */
.contact{
  padding: clamp(80px, 9vw, 130px) var(--gutter);
  max-width:var(--container); margin:0 auto;
  display:grid; gap: clamp(40px, 5vw, 80px);
  grid-template-columns: 1fr 1.05fr;
  align-items:start;
}
.contact__copy h2{
  font-family:"Plus Jakarta Sans",sans-serif;
  font-weight:800; font-size: clamp(2rem, 4vw, 3rem);
  letter-spacing:-.02em; line-height:1.1; margin:16px 0;
}
.contact__copy h2 em{
  font-family:"Playfair Display",serif;
  font-style:italic; font-weight:600; color:var(--orange-600);
}
.contact__copy > p{ color:var(--muted); line-height:1.7; font-size:1.05rem; margin-bottom:30px }

.contact__info{ list-style:none; padding:0; margin:0 0 30px; display:grid; gap:16px }
.contact__info li{
  display:flex; gap:14px; align-items:center;
  padding:16px 18px; border-radius:var(--rad-sm);
  background:#fff; border:1px solid var(--line);
  box-shadow:var(--shadow-sm);
  transition: transform .35s var(--ease), box-shadow .35s;
}
.contact__info li:hover{ transform:translateX(4px); box-shadow:var(--shadow) }
.contact__icon{
  width:42px; height:42px; border-radius:12px;
  background:linear-gradient(135deg, var(--orange-100), #fff);
  border:1px solid var(--line);
  color:var(--orange-600);
  display:grid; place-items:center; flex-shrink:0;
}
.contact__icon svg{ width:20px; height:20px }
.contact__info small{
  display:block; font-size:.72rem; letter-spacing:.18em; text-transform:uppercase;
  color:var(--muted); margin-bottom:2px;
}
.contact__info b{ font-size:1.05rem; color:var(--navy-800) }

.fb{
  display:inline-flex; align-items:center; gap:12px;
  padding:14px 22px; border-radius:14px;
  background:#1877F2; color:#fff; font-weight:700;
  transition: transform .35s var(--ease), box-shadow .35s;
}
.fb svg{ width:22px; height:22px }
.fb i{ font-style:normal; margin-left:auto }
.fb:hover{ transform:translateY(-3px); box-shadow: 0 18px 40px -16px rgba(24,119,242,.7) }

/* Form */
.contact__form{
  padding:30px;
  border-radius:var(--rad);
  background:#fff;
  border:1px solid var(--line);
  box-shadow:var(--shadow-lg);
  display:grid; gap:16px;
  grid-template-columns: 1fr 1fr;
}
.field{ display:grid; gap:6px }
.field label{
  font-size:.78rem; letter-spacing:.12em; text-transform:uppercase; font-weight:700;
  color:var(--navy-700);
}
.field input,.field select,.field textarea{
  border:1.5px solid var(--line);
  background:#fafbfc;
  border-radius:12px;
  padding:14px 16px;
  font-size:1rem; color:var(--navy-900);
  transition: border-color .25s, background .25s, box-shadow .25s;
  outline:none;
}
.field input:focus,.field select:focus,.field textarea:focus{
  border-color: var(--orange-600);
  background:#fff;
  box-shadow: 0 0 0 4px rgba(242,107,31,.12);
}
.field--full{ grid-column: 1 / -1 }
.contact__form .btn{ grid-column: 1 / -1; margin-top:6px }
.contact__hint{
  grid-column: 1 / -1;
  color:var(--muted); font-size:.85rem; text-align:center;
}
.contact__hint a{ color:var(--orange-600); font-weight:700 }

/* ═══════════════════════════════════════
   FOOTER
   ═══════════════════════════════════════ */
.footer{
  background: linear-gradient(180deg, var(--navy-900) 0%, #03081a 100%);
  color: rgba(255,255,255,.7);
  padding: 80px var(--gutter) 30px;
}
.footer__main{
  max-width:var(--container); margin:0 auto;
  display:grid; gap:50px;
  grid-template-columns: 1.6fr 1fr 1fr 1fr;
}
.footer__brand img{ width:60px; height:60px; margin-bottom:18px }
.footer__brand h3{
  font-family:"Plus Jakarta Sans",sans-serif;
  color:#fff; font-size:1.5rem; margin:0 0 12px;
}
.footer__brand p{ line-height:1.7; margin-bottom:20px; font-size:.95rem }
.footer__fb{
  display:inline-flex; align-items:center; gap:8px;
  font-weight:700; color:var(--orange-500);
}
.footer__col h4{
  color:#fff; font-family:"Plus Jakarta Sans",sans-serif;
  font-size:1rem; letter-spacing:.04em; margin:0 0 18px;
}
.footer__col ul{ list-style:none; padding:0; margin:0; display:grid; gap:10px; font-size:.94rem }
.footer__col a{ transition: color .25s, padding .25s }
.footer__col a:hover{ color:var(--orange-500); padding-left:4px }
.footer__bar{
  max-width:var(--container); margin: 50px auto 0;
  padding-top:24px;
  border-top:1px solid rgba(255,255,255,.08);
  display:flex; flex-wrap:wrap; gap:14px; justify-content:space-between;
  font-size:.82rem; color:rgba(255,255,255,.5);
}

/* ═══════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════ */
/* ═══════════════════════════════════════════════════════════════
   GENERAL TOUCH / TAP IMPROVEMENTS
   ═══════════════════════════════════════════════════════════════ */
@media (hover: none) and (pointer: coarse){
  /* Disable hover-only transforms that can stick on touch */
  *:hover { transition: none; }

  /* Visible tap feedback on all interactive elements */
  a, button, [role="button"], summary, .svc, .work__item, .review, .pillar, .step{
    -webkit-tap-highlight-color: rgba(242,107,31,.18);
  }
  a:active, button:active, .svc:active, .work__item:active, summary:active{
    transform: scale(.985);
    transition: transform .14s var(--ease);
  }
}

/* ═══════════════════════════════════════════════════════════════
   TABLET / MEDIUM (≤ 1080px)
   ═══════════════════════════════════════════════════════════════ */
@media (max-width: 1080px){
  .nav__links{ display:none }
  .nav__burger{ display:inline-flex }

  .hero__inner{ grid-template-columns:1fr; gap: clamp(40px, 6vw, 60px) }
  .hero__visual{
    width: 100%;        /* needed when hero__inner becomes single-column grid */
    min-height:520px;
    max-width:520px;
    margin:0 auto;
  }
  .floater--rating{ left:-2% }
  .floater--ticker{ right:0 }

  .svc{ grid-column: span 6 }
  .svc--wide,.svc--dark{ grid-column: span 12 }

  .why__grid,.why__pillars{ grid-template-columns: repeat(2, 1fr) }
  .process__list{ grid-template-columns: repeat(2, 1fr) }
  .process__list::before{ display:none }

  .feature{ grid-template-columns: 1fr }
  .feature__media{ min-height:440px }

  .reviews__grid{ grid-template-columns: 1fr }

  .work__grid{ grid-template-columns: repeat(2, 1fr); grid-auto-rows: 180px }
  .work__item--a{ grid-column: span 2; grid-row: span 2 }
  .work__item--f{ grid-column: span 2 }

  .contact{ grid-template-columns: 1fr }

  .footer__main{ grid-template-columns: 1fr 1fr }
}

/* ═══════════════════════════════════════════════════════════════
   MOBILE PHONE (≤ 720px) — COMPREHENSIVE OVERHAUL
   ═══════════════════════════════════════════════════════════════ */
@media (max-width: 720px){

  /* —— Safe-area insets for notched devices —— */
  body{
    padding-bottom: env(safe-area-inset-bottom);
  }

  /* —— Footer respects safe-area on notched devices —— */
  .footer{ padding-bottom: calc(30px + env(safe-area-inset-bottom)); }

  /* —— Floating dock: smaller, hugged to the bottom-right corner on phones,
        respects safe-area-inset for notched devices —— */
  .dock{
    right: 14px;
    bottom: calc(14px + env(safe-area-inset-bottom));
    gap: 10px;
  }
  .dock__btn{
    width: 50px;
    height: 50px;
    border-radius: 16px;
  }
  .dock__btn svg{ width: 22px; height: 22px }

  /* —— Navigation: tighter, safer —— */
  .nav{
    padding: 12px clamp(14px, 4vw, 20px);
    gap: 10px;
  }
  .nav__brand-text strong{ font-size: 1.04rem }
  .nav__brand-text em{ font-size: .68rem; letter-spacing: .28em }
  .nav__brand img{ width: 40px; height: 40px }

  .phone-pill{
    padding: 8px;
    min-width: 44px; min-height: 44px;
    border-radius: 999px;
  }
  .phone-pill small,
  .phone-pill b{ display:none }
  .phone-pill__icon{ width: 32px; height: 32px }

  .nav__burger{
    width: 44px; height: 44px;
    align-items: center;
    border-radius: 12px;
  }

  /* Ribbon — slightly smaller, smoother */
  .ribbon{ font-size: .76rem }
  .ribbon__track{ padding: 9px 0; gap: 36px; animation-duration: 30s }

  /* —— Hero: optimized for mobile (less scrolling, better hierarchy) —— */
  .hero{
    padding: clamp(40px, 8vw, 70px) clamp(16px, 5vw, 24px) clamp(60px, 9vw, 100px);
  }
  .hero__title{
    font-size: clamp(2.3rem, 10vw, 3.3rem);
    line-height: 1;
    letter-spacing: -.03em;
  }
  .hero__sub{
    font-size: 1.02rem;
    line-height: 1.6;
    margin-bottom: 26px;
  }
  .hero__cta{ flex-direction:column; align-items:stretch; gap: 12px }
  .btn{
    justify-content: center;
    min-height: 54px;
    padding: 14px 22px;
    font-size: 1rem;
  }
  .btn--primary,
  .btn--ghost{ width: 100%; }
  .hero__pills{
    gap: 10px 16px;
    font-size: .88rem;
  }
  .hero__visual{
    width: 100%;
    min-height: 420px;
    max-width: 92vw;
    margin: 0 auto;
  }
  /* card-stack inside must use the parent's computed width, not its own min-height block */
  .card-stack{ min-height: 440px }
  .card-stack__front{ width: 72%; left: 12% }
  .card-stack__back{ width: 60% }
  .card-stack__mid{ width: 52% }
  .floater--rating{ top: -2%; left: 0; padding: 10px 14px }
  .floater--rating svg{ width: 22px; height: 22px }
  .floater--rating b{ font-size: 1rem }
  .floater--ticker{ bottom: -2%; right: 0; padding: 10px 14px; font-size: .8rem }

  .hero__scroll{ bottom: 14px }
  .hero__scroll span{ width: 18px; height: 30px }

  /* —— Marquee strips — quieter on mobile —— */
  .strip__track{ font-size: 1.2rem; gap: 22px; animation-duration: 36s }

  /* —— Section spacing: tighter but breathable —— */
  .services,.why,.process,.feature,.work,.reviews,.megacta,.contact{
    padding: clamp(60px, 10vw, 90px) clamp(16px, 5vw, 24px);
  }
  .section-head{ margin-bottom: clamp(28px, 5vw, 44px) }
  .section-head h2{
    font-size: clamp(1.8rem, 7vw, 2.4rem);
    line-height: 1.08;
  }
  .section-head p{
    font-size: 1rem;
    padding-inline: 4px;
  }

  /* —— Service cards: full-width on phone with comfortable tap target —— */
  .svc{
    grid-column: span 12;
    padding: 26px 22px 22px;
    border-radius: 18px;
  }
  .svc__icon{
    width: 52px; height: 52px;
    margin-bottom: 18px;
  }
  .svc h3{ font-size: 1.22rem; line-height: 1.2 }
  .svc > p{ font-size: .96rem }
  .svc__cta{
    min-height: 44px;
    padding: 6px 0;
    align-items: center;
  }

  /* —— Why us / Stats —— */
  .why__grid,.why__pillars{ grid-template-columns: 1fr; gap: 14px }
  .why__card{ padding: 28px 22px 24px }
  .why__num{ font-size: clamp(2.6rem, 11vw, 3.4rem) }
  .pillar{ padding: 24px 20px }
  .why__pillars{ margin-top: 40px }

  /* —— Process —— */
  .process__list{ grid-template-columns: 1fr; gap: 14px }
  .step{ padding: 28px 22px 24px }

  /* —— Feature split (gazebo) —— */
  .feature{ gap: 32px }
  .feature__media{ min-height: 380px }
  .feature__frame:first-child{ inset: 0 26% 24% 0 }
  .feature__frame--small{ inset: 38% 0 0 32% }
  .feature__chip{ left: 12px; top: 12px; font-size: .76rem; padding: 6px 12px 6px 10px }
  .feature__copy h2{ font-size: clamp(1.6rem, 6.5vw, 2.2rem) }
  .feature__copy p{ font-size: 1rem }

  /* —— Gallery / work —— */
  .work__grid{ grid-template-columns: 1fr; grid-auto-rows: 240px; gap: 12px }
  .work__item,.work__item--a,.work__item--f{ grid-column: span 1; grid-row: span 1 }
  .work__item figcaption{ font-size: .9rem }

  /* —— Reviews —— */
  .review{ padding: 26px 22px }
  .review blockquote{ font-size: 1rem; line-height: 1.65 }

  /* —— Mega CTA: tighter heading, stacked buttons —— */
  .megacta h2{ font-size: clamp(1.8rem, 7.5vw, 2.6rem) }
  .megacta p{ font-size: 1rem }
  .megacta__buttons{ flex-direction: column; gap: 12px }
  .megacta__buttons .btn{ width: 100% }
  .btn--xl{ padding: 18px 22px; font-size: 1rem; border-radius: 16px }
  .btn--xl b{ font-size: 1.06rem }

  /* —— Contact form —— */
  .contact__form{ grid-template-columns: 1fr; padding: 22px; gap: 14px }
  .field input,.field select,.field textarea{
    min-height: 52px;
    padding: 14px 16px;
    font-size: 16px; /* prevents iOS zoom on focus */
    border-radius: 12px;
  }
  .field textarea{ min-height: 110px }
  .field label{ font-size: .72rem }
  .contact__info li{ padding: 14px 16px; min-height: 64px }
  .fb{ width: 100%; justify-content: center; min-height: 52px }

  /* —— FAQ details: bigger tap area —— */
  #faq details{ padding: 16px 18px !important }
  #faq summary{ min-height: 44px; padding: 6px 0; font-size: 1rem !important }
  #faq summary::-webkit-details-marker{ display: none }
  #faq details[open] summary span{ transform: rotate(45deg) }
  #faq summary span{ transition: transform .25s var(--ease); font-size: 1.2rem !important }

  /* —— Footer —— */
  .footer{ padding-left: clamp(16px, 5vw, 24px); padding-right: clamp(16px, 5vw, 24px) }
  .footer__main{ grid-template-columns: 1fr; gap: 36px }
  .footer__bar{ justify-content:center; text-align:center; flex-direction: column; gap: 8px }
  .footer__col h4{ margin-bottom: 14px }
  .footer__col a{ min-height: 32px; display: inline-flex; align-items: center }

  /* —— Service area cards —— */
  #service-area{ padding-bottom: clamp(60px, 10vw, 90px) }
  #service-area article{ padding: 20px !important }
}

/* ═══════════════════════════════════════════════════════════════
   VERY SMALL PHONES (≤ 380px) — slight extra refinement
   ═══════════════════════════════════════════════════════════════ */
@media (max-width: 380px){
  .nav__brand-text em{ display: none }
  .ribbon{ font-size: .72rem }
  .hero__title{ font-size: clamp(2rem, 11vw, 2.7rem) }
  .dock__btn{ width: 46px; height: 46px }
}

/* ═══════════════════════════════════════════════════════════════
   LANDSCAPE PHONES — keep hero compact
   ═══════════════════════════════════════════════════════════════ */
@media (max-width: 900px) and (orientation: landscape) and (max-height: 500px){
  .hero{ min-height: auto; padding-top: 50px }
}

/* ═══════════════════════════════════════════════════════════════
   MOBILE MENU — improved animation & smoother open
   (overrides the dynamically-injected styles in main.js with cleaner ones)
   ═══════════════════════════════════════════════════════════════ */
@media (max-width: 1080px){
  .nav__links.is-open{
    /* Stagger entrance of links */
  }
  .nav__links.is-open a{
    animation: navLinkIn .55s var(--ease-out) backwards;
  }
  .nav__links.is-open a:nth-child(1){ animation-delay: .05s }
  .nav__links.is-open a:nth-child(2){ animation-delay: .10s }
  .nav__links.is-open a:nth-child(3){ animation-delay: .15s }
  .nav__links.is-open a:nth-child(4){ animation-delay: .20s }
  .nav__links.is-open a:nth-child(5){ animation-delay: .25s }
  .nav__links.is-open a:nth-child(6){ animation-delay: .30s }
  .nav__links.is-open a:nth-child(7){ animation-delay: .35s }
  .nav__links.is-open a:nth-child(8){ animation-delay: .40s }
}
@keyframes navLinkIn{
  from { opacity: 0; transform: translateY(20px); }
  to   { opacity: 1; transform: translateY(0); }
}

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{ animation:none !important; transition: none !important }
  .reveal,.reveal-left,.reveal-right,.reveal-stack > *{ opacity:1 !important; transform:none !important }
  .nav__links.is-open a{ animation: none !important }
}
