:root{
  --yellow:#FFC400;
  --yellow-d:#e6af00;
  --yellow-soft:rgba(255,196,0,.12);
  --ink:#111315;
  --ink-2:#1b1e21;
  --carbon:#0a0b0d;
  --white:#fff;
  --grey-900:#1a1d20;
  --grey-700:#3a3f45;
  --grey-500:#6b7177;
  --grey-300:#a7adb3;
  --grey-100:#f6f7f8;
  --grey-50:#fafbfb;
  --line:#e9ebed;
  --radius-sm:14px;
  --radius:18px;
  --radius-lg:24px;
  --shadow-sm:0 2px 10px -2px rgba(15,18,20,.06);
  --shadow:0 22px 55px -16px rgba(15,18,20,.18);
  --shadow-lg:0 40px 80px -20px rgba(15,18,20,.35);
  --t:0.35s;
  --t-slow:0.55s;
  --max:1200px;
  --ease:cubic-bezier(.22,.61,.36,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
  color:var(--ink);background:var(--white);line-height:1.65;font-size:16px;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden;
}
img,svg,iframe{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:"Sora","Inter",sans-serif;line-height:1.12;letter-spacing:-.025em;font-weight:700}
.container{width:100%;max-width:var(--max);margin:0 auto;padding:0 24px}

/* BUTTONS */
.btn{
  position:relative;display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-weight:600;font-size:1rem;letter-spacing:-.01em;padding:15px 28px;border-radius:14px;
  cursor:pointer;border:1.5px solid transparent;white-space:nowrap;overflow:hidden;
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .25s var(--ease),border-color .25s var(--ease);
}
.btn svg{transition:transform .25s var(--ease)}
.btn:active{transform:scale(.98)}
.btn--wa{background:#25D366;color:#fff;box-shadow:0 10px 30px -6px rgba(37,211,102,.55),inset 0 1px 0 rgba(255,255,255,.25);font-weight:700}
.btn--wa::after{content:"";position:absolute;top:0;left:-120%;width:60%;height:100%;background:linear-gradient(110deg,transparent,rgba(255,255,255,.35),transparent);transform:skewX(-18deg);transition:left .7s var(--ease)}
.btn--wa:hover{background:#22c45e;transform:translateY(-3px) scale(1.02);box-shadow:0 20px 44px -8px rgba(37,211,102,.65),inset 0 1px 0 rgba(255,255,255,.25)}
.btn--wa:hover::after{left:130%}
.btn--wa:hover svg{transform:scale(1.08)}
.btn--outline{background:rgba(255,255,255,.04);color:#fff;border-color:rgba(255,255,255,.22);backdrop-filter:blur(8px)}
.btn--outline:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.45);transform:translateY(-3px)}
.btn--ghost{background:var(--yellow);color:var(--ink);padding:11px 20px;font-size:.92rem;font-weight:700;border-radius:11px;box-shadow:0 6px 18px -6px rgba(255,196,0,.6)}
.btn--ghost:hover{background:var(--yellow-d);transform:translateY(-2px) scale(1.03);box-shadow:0 12px 28px -6px rgba(255,196,0,.75)}
.btn--ghost svg{color:var(--ink)}
.btn--lg{padding:21px 46px;font-size:1.18rem;border-radius:16px}

/* NAV */
.nav{position:sticky;top:0;z-index:50;background:rgba(12,13,15,.55);backdrop-filter:blur(18px) saturate(160%);-webkit-backdrop-filter:blur(18px) saturate(160%);border-bottom:1px solid rgba(255,255,255,.07);transition:background .35s var(--ease),box-shadow .35s var(--ease),border-color .35s}
.nav.scrolled{background:rgba(10,11,13,.82);box-shadow:0 10px 40px -16px rgba(0,0,0,.6)}
.nav__inner{display:flex;align-items:center;justify-content:space-between;height:60px}
.brand{display:flex;align-items:center;gap:11px;color:#fff}
.brand__mark{display:grid;place-items:center;width:38px;height:38px;background:var(--yellow);color:var(--ink);font-family:"Sora",sans-serif;font-weight:800;border-radius:10px;font-size:1rem;letter-spacing:-.04em;box-shadow:0 4px 14px -4px rgba(255,196,0,.6)}
.brand__logo{width:42px;height:42px;object-fit:contain;display:block}
.brand__name{font-family:"Sora",sans-serif;font-weight:600;font-size:1.12rem;letter-spacing:-.02em}
.brand__name strong{font-weight:800}
.nav__links{display:flex;gap:8px}
.nav__links a{position:relative;color:#c3c8cc;font-weight:500;font-size:.94rem;padding:8px 14px;border-radius:9px;transition:color .2s var(--ease),background .2s var(--ease)}
.nav__links a::after{content:"";position:absolute;left:14px;right:14px;bottom:4px;height:1.5px;background:var(--yellow);transform:scaleX(0);transform-origin:left;transition:transform .3s var(--ease)}
.nav__links a:hover{color:#fff}
.nav__links a:hover::after{transform:scaleX(1)}
.nav__call{margin-left:6px}

/* HERO */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;color:#fff;padding:140px 0 120px;overflow:hidden}
.hero__bg{position:absolute;inset:0;z-index:-3;will-change:transform;
  background:
    linear-gradient(105deg,rgba(8,9,11,.94) 0%,rgba(8,9,11,.8) 38%,rgba(8,9,11,.5) 65%,rgba(8,9,11,.35) 100%),
    linear-gradient(to top,rgba(8,9,11,.85) 0%,transparent 40%),
    url("hero.webp") center 40%/cover no-repeat;
}
.hero__glow{position:absolute;z-index:-2;top:28%;left:6%;width:560px;height:560px;max-width:80vw;
  background:radial-gradient(circle,rgba(255,196,0,.22) 0%,rgba(255,196,0,.06) 35%,transparent 70%);
  filter:blur(20px);pointer-events:none}
.hero::after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:130px;background:linear-gradient(to top,var(--carbon),transparent);z-index:-1}
.hero__inner{position:relative;width:100%}
.hero__content{max-width:720px}
.pill{display:inline-flex;align-items:center;gap:9px;background:rgba(255,196,0,.1);color:var(--yellow);border:1px solid rgba(255,196,0,.32);padding:9px 18px;border-radius:50px;font-size:.8rem;font-weight:600;letter-spacing:.02em;margin-bottom:28px;backdrop-filter:blur(6px)}
.pill__dot{width:7px;height:7px;border-radius:50%;background:var(--yellow);box-shadow:0 0 0 0 rgba(255,196,0,.6);animation:dot 2s infinite}
@keyframes dot{0%{box-shadow:0 0 0 0 rgba(255,196,0,.55)}70%{box-shadow:0 0 0 8px rgba(255,196,0,0)}100%{box-shadow:0 0 0 0 rgba(255,196,0,0)}}
.hero__title{font-family:"Sora",sans-serif;font-size:clamp(2.4rem,6vw,4.6rem);font-weight:800;line-height:1.04;letter-spacing:-.035em;margin-bottom:24px;text-shadow:0 2px 40px rgba(0,0,0,.4)}
.hero__title span{color:var(--yellow)}
.hero__sub{font-size:clamp(1.08rem,2vw,1.35rem);line-height:1.6;color:#cdd2d6;max-width:580px;margin-bottom:40px;font-weight:400}
.hero__cta{display:flex;flex-wrap:wrap;gap:16px;margin-bottom:0}

/* BENEFITS (hero glass cards) */
.benefits{list-style:none;display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:64px;max-width:760px}
.benefit{display:flex;align-items:center;gap:14px;padding:18px 20px;border-radius:16px;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  box-shadow:0 8px 30px -12px rgba(0,0,0,.5),inset 0 1px 0 rgba(255,255,255,.08);
  transition:transform .3s var(--ease),background .3s var(--ease),border-color .3s var(--ease)}
.benefit:hover{transform:translateY(-4px);background:rgba(255,255,255,.1);border-color:rgba(255,196,0,.4)}
.benefit__icon{flex:none;display:grid;place-items:center;width:46px;height:46px;border-radius:12px;background:rgba(255,196,0,.14);color:var(--yellow);border:1px solid rgba(255,196,0,.25)}
.benefit strong{display:block;font-family:"Sora",sans-serif;font-size:1rem;font-weight:700;color:#fff;letter-spacing:-.01em}
.benefit span{font-size:.83rem;color:#aeb3b8}

/* SECTION HEAD */
.section-head{text-align:center;max-width:660px;margin:0 auto 64px}
.eyebrow{display:inline-block;color:var(--yellow-d);font-weight:700;font-size:.78rem;text-transform:uppercase;letter-spacing:.18em;margin-bottom:16px}
.section-head h2{font-size:clamp(1.9rem,4vw,2.9rem);letter-spacing:-.03em;margin-bottom:16px}
.section-head p{color:var(--grey-500);font-size:1.08rem;line-height:1.7}

/* SERVICES */
.services{position:relative;padding:130px 0;overflow:hidden;
  background:
    radial-gradient(circle at 50% -10%,rgba(255,196,0,.1),transparent 45%),
    linear-gradient(180deg,var(--carbon) 0%,#0d0f12 100%);
  color:#fff}
.services::before{content:"";position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.035) 1px,transparent 1px);background-size:30px 30px;opacity:.5;pointer-events:none}
.services .container{position:relative}
.services .eyebrow{color:var(--yellow)}
.services .section-head h2{color:#fff}
.services .section-head p{color:#b6bbc0}
.grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.card{position:relative;border-radius:var(--radius);padding:38px 30px;overflow:hidden;
  background:rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.09);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.05);
  backdrop-filter:blur(12px) saturate(140%);-webkit-backdrop-filter:blur(12px) saturate(140%);
  transition:transform var(--t) var(--ease),box-shadow var(--t) var(--ease),border-color var(--t) var(--ease),background var(--t) var(--ease)}
.card::before{content:"";position:absolute;inset:0;border-radius:var(--radius);padding:1px;background:linear-gradient(140deg,rgba(255,196,0,.55),transparent 45%);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity .4s var(--ease)}
.card::after{content:"";position:absolute;top:-50%;right:-30%;width:200px;height:200px;background:radial-gradient(circle,rgba(255,196,0,.18),transparent 70%);filter:blur(12px);opacity:0;transition:opacity .4s var(--ease);pointer-events:none}
.card:hover{transform:translateY(-6px);background:rgba(255,255,255,.07);border-color:rgba(255,196,0,.35);box-shadow:0 30px 65px -24px rgba(0,0,0,.7)}
.card:hover::before{opacity:1}
.card:hover::after{opacity:1}
.card__icon{position:relative;display:grid;place-items:center;width:60px;height:60px;border-radius:16px;background:rgba(255,196,0,.12);color:var(--yellow);border:1px solid rgba(255,196,0,.25);margin-bottom:24px;transition:background .4s var(--ease),color .4s var(--ease),transform .4s var(--ease)}
.card:hover .card__icon{background:var(--yellow);color:var(--ink);transform:scale(1.06) rotate(-3deg)}
.card h3{position:relative;font-size:1.22rem;margin-bottom:11px;letter-spacing:-.02em;color:#fff}
.card p{position:relative;color:#aeb3b8;font-size:.96rem;line-height:1.65}
@media(max-width:980px){.grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.grid{grid-template-columns:1fr;gap:16px}}

/* WHY — El compromiso de Grúas Muñoz */
.why{position:relative;padding:130px 0;overflow:hidden;
  background:
    radial-gradient(circle at 50% -5%, rgba(255,196,0,.07), transparent 55%),
    radial-gradient(circle at 90% 90%, rgba(15,18,20,.04), transparent 50%),
    var(--white)}
.why .section-head{margin-bottom:72px}
.why__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:28px;position:relative}
.why-card{position:relative;padding:44px 40px;border-radius:var(--radius);background:var(--white);
  border:1px solid var(--line);
  box-shadow:var(--shadow-sm);
  transition:transform var(--t) var(--ease),
             box-shadow var(--t) var(--ease),
             border-color var(--t) var(--ease),
             opacity .8s var(--ease)}
.why-card::before{content:"";position:absolute;inset:0;border-radius:var(--radius);padding:1px;
  background:linear-gradient(135deg,rgba(255,196,0,.6),transparent 55%);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  opacity:0;transition:opacity .4s cubic-bezier(.22,.61,.36,1);pointer-events:none}
.why-card:hover{transform:translateY(-6px);
  box-shadow:0 28px 60px -20px rgba(15,18,20,.18),0 10px 24px -12px rgba(255,196,0,.16)}
.why-card:hover::before{opacity:1}
.why-card__icon{position:relative;display:grid;place-items:center;width:64px;height:64px;
  border-radius:18px;background:var(--ink);color:var(--yellow);margin-bottom:26px;
  box-shadow:0 14px 28px -14px rgba(17,19,21,.55);
  transition:transform .4s cubic-bezier(.22,.61,.36,1)}
.why-card__icon::after{content:"";position:absolute;inset:-14px;border-radius:30px;
  background:radial-gradient(circle, rgba(255,196,0,.4), transparent 65%);
  filter:blur(10px);opacity:0;transition:opacity .4s cubic-bezier(.22,.61,.36,1);z-index:-1}
.why-card:hover .why-card__icon{transform:scale(1.08)}
.why-card:hover .why-card__icon::after{opacity:1}
.why-card h3{font-size:1.32rem;letter-spacing:-.02em;margin-bottom:12px;color:var(--ink);font-weight:700}
.why-card p{color:var(--grey-500);font-size:1rem;line-height:1.7}

/* Reveal: stagger left-to-right by 100ms */
.why-card.reveal{transform:translate3d(-24px,18px,0)}
.why-card.reveal.in{transform:translate3d(0,0,0)}
.why-card:nth-child(1).reveal{transition-delay:0ms}
.why-card:nth-child(2).reveal{transition-delay:100ms}
.why-card:nth-child(3).reveal{transition-delay:200ms}
.why-card:nth-child(4).reveal{transition-delay:300ms}

@media(max-width:760px){
  .why{padding:90px 0}
  .why .section-head{margin-bottom:50px}
  .why__grid{grid-template-columns:1fr;gap:18px}
  .why-card{padding:34px 28px}
  .why-card.reveal{transform:translate3d(0,24px,0)}
}

/* STATS */
.stats{position:relative;padding:64px 0;overflow:hidden;
  background:
    radial-gradient(circle at 20% 30%,rgba(255,196,0,.1),transparent 40%),
    radial-gradient(circle at 80% 70%,rgba(255,196,0,.06),transparent 45%),
    linear-gradient(180deg,var(--carbon) 0%,#0d0f12 100%);
  color:#fff;border-top:1px solid rgba(255,255,255,.05);border-bottom:1px solid rgba(255,255,255,.05)}
.stats::before{content:"";position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.035) 1px,transparent 1px);background-size:30px 30px;opacity:.5;pointer-events:none}
.stats__grid{position:relative;display:grid;grid-template-columns:repeat(4,1fr);gap:0}
.stat{position:relative;text-align:center;padding:14px 24px}
.stat + .stat::before{content:"";position:absolute;left:0;top:18%;bottom:18%;width:1px;background:linear-gradient(to bottom,transparent,rgba(255,255,255,.14),transparent)}
.stat__num{display:block;font-family:"Sora",sans-serif;font-weight:800;font-size:clamp(2.3rem,4.6vw,3.2rem);line-height:1;color:var(--yellow);letter-spacing:-.04em;text-shadow:0 0 30px rgba(255,196,0,.2);margin-bottom:10px}
.stat__num--text{letter-spacing:-.03em;font-size:clamp(1.9rem,4vw,2.7rem)}
.stat__label{display:block;color:#b6bbc0;font-size:.92rem;font-weight:500;letter-spacing:.02em}
@media(max-width:760px){
  .stats{padding:50px 0}
  .stats__grid{grid-template-columns:repeat(2,1fr);gap:0}
  .stat{padding:18px 12px}
  .stat:nth-child(2)::before{content:""}
  .stat:nth-child(3)::before{display:none}
  .stat:nth-child(3),.stat:nth-child(4){border-top:1px solid rgba(255,255,255,.08);margin-top:8px;padding-top:24px}
}

/* SHOWCASE (servicios reales + opiniones) */
.showcase{padding:110px 0 80px;background:linear-gradient(180deg,var(--grey-100) 0%,var(--grey-50) 100%)}
.sc-gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.sc-item{position:relative;border-radius:var(--radius);overflow:hidden;aspect-ratio:16/10;box-shadow:var(--shadow-sm);border:1px solid var(--line);transition:transform var(--t) var(--ease),box-shadow var(--t) var(--ease)}
.sc-item:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.sc-item img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease)}
.sc-item:hover img{transform:scale(1.05)}
.sc-item::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(8,9,11,.45),transparent 45%);opacity:.7;transition:opacity var(--t) var(--ease)}
.sc-item:hover::after{opacity:1}
.sc-item figcaption{position:absolute;left:16px;bottom:16px;z-index:1;display:inline-flex;align-items:center;
  background:rgba(12,13,15,.62);color:#fff;font-size:.78rem;font-weight:600;letter-spacing:.02em;
  padding:8px 14px;border-radius:50px;border:1px solid rgba(255,255,255,.18);backdrop-filter:blur(8px)}

/* TESTIMONIALS CAROUSEL */
.tcarousel{position:relative;margin-top:64px}
.testimonials{display:flex;gap:18px;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;
  scroll-padding-left:4px;padding:6px 4px 18px;scrollbar-width:none}
.testimonials::-webkit-scrollbar{display:none}
.tcard{flex:0 0 calc((100% - 18px*3) / 4);scroll-snap-align:start;
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:28px 26px;
  box-shadow:var(--shadow-sm);
  transition:transform var(--t) var(--ease),box-shadow var(--t) var(--ease),border-color var(--t) var(--ease)}
.tcard:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent}
.tcarousel__btn{position:absolute;top:50%;transform:translateY(-50%);z-index:2;width:46px;height:46px;
  border-radius:50%;background:#fff;border:1px solid var(--line);color:var(--ink);
  display:grid;place-items:center;cursor:pointer;box-shadow:var(--shadow-sm);
  transition:transform var(--t) var(--ease),background var(--t) var(--ease),box-shadow var(--t) var(--ease),opacity var(--t) var(--ease)}
.tcarousel__btn:hover{background:var(--ink);color:var(--yellow);box-shadow:var(--shadow);transform:translateY(-50%) scale(1.05)}
.tcarousel__btn:disabled{opacity:.35;cursor:not-allowed;pointer-events:none}
.tcarousel__btn--prev{left:-22px}
.tcarousel__btn--next{right:-22px}
.tcarousel__dots{display:flex;justify-content:center;gap:8px;margin-top:18px}
.tcarousel__dot{width:8px;height:8px;border-radius:50%;background:var(--line);cursor:pointer;border:none;padding:0;
  transition:background var(--t) var(--ease),transform var(--t) var(--ease),width var(--t) var(--ease)}
.tcarousel__dot[aria-current="true"]{background:var(--ink);width:22px;border-radius:6px}
@media(max-width:1024px){.tcard{flex:0 0 calc((100% - 18px*2) / 3)}}
@media(max-width:760px){.tcard{flex:0 0 calc((100% - 18px) / 2)}.tcarousel__btn{display:none}}
@media(max-width:520px){
  .tcard{flex:0 0 86%;padding:24px 22px}
  .testimonials{gap:14px;scroll-padding-left:18px;padding:6px 18px 18px;margin:0 -18px}
}
.tcard__head{display:flex;align-items:center;gap:13px;margin-bottom:16px}
.avatar{flex:none;display:grid;place-items:center;width:46px;height:46px;border-radius:50%;background:linear-gradient(145deg,var(--ink),var(--grey-700));color:var(--yellow);font-family:"Sora",sans-serif;font-weight:700;font-size:1.1rem}
.tcard__head strong{display:block;font-family:"Sora",sans-serif;font-size:.98rem;letter-spacing:-.01em}
.stars{color:var(--yellow);font-size:.92rem;letter-spacing:2px}
.tcard p{color:var(--grey-700);font-size:.96rem;line-height:1.65}

.trust{list-style:none;display:flex;flex-wrap:wrap;justify-content:center;gap:14px 14px;margin-top:48px;padding-top:40px;border-top:1px solid var(--line)}
.trust li{display:inline-flex;align-items:center;gap:9px;background:#fff;border:1px solid var(--line);
  padding:12px 20px;border-radius:50px;font-weight:600;font-size:.92rem;color:var(--ink);box-shadow:var(--shadow-sm);
  transition:transform .3s var(--ease),border-color .3s var(--ease)}
.trust li:hover{transform:translateY(-3px);border-color:var(--yellow)}
.trust svg{color:var(--yellow-d)}
@media(max-width:860px){
  .testimonials{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:600px){
  .sc-gallery{grid-template-columns:1fr;gap:14px}
  .testimonials{grid-template-columns:1fr;gap:14px;margin-top:44px}
  .trust{margin-top:44px;padding-top:36px}
  .trust li{font-size:.86rem;padding:10px 16px}
}

/* COVERAGE */
.coverage{padding:80px 0 110px;background:linear-gradient(180deg,var(--grey-50),var(--grey-100))}
.coverage__inner{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.coverage__text h2{font-size:clamp(1.9rem,4vw,2.9rem);letter-spacing:-.03em;margin-bottom:18px}
.coverage__text>p{color:var(--grey-500);font-size:1.08rem;line-height:1.7;margin-bottom:30px}
.coverage__list{list-style:none;display:flex;flex-direction:column;gap:14px;margin-bottom:34px}
.coverage__list li{display:flex;flex-direction:column;padding:16px 20px;background:#fff;border-radius:14px;border:1px solid var(--line);border-left:4px solid var(--yellow);box-shadow:var(--shadow-sm);transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.coverage__list li:hover{transform:translateX(6px);box-shadow:var(--shadow)}
.coverage__list strong{font-family:"Sora",sans-serif;font-size:1.05rem;letter-spacing:-.01em}
.coverage__list span{color:var(--grey-500);font-size:.9rem}
.coverage__map{height:480px;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg);border:1px solid var(--line)}
.coverage__map iframe{width:100%;height:100%}

/* FAQ */
.faq{padding:120px 0;background:var(--white)}
.faq__list{max-width:820px;margin:0 auto;display:flex;flex-direction:column;gap:14px}
.faq__item{background:var(--grey-50);border:1px solid var(--line);border-radius:var(--radius-sm);padding:0 26px;transition:border-color var(--t) var(--ease),background var(--t) var(--ease),box-shadow var(--t) var(--ease),transform var(--t) var(--ease)}
.faq__item:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.faq__item[open]{background:#fff;border-color:var(--yellow);box-shadow:var(--shadow-sm)}
.faq__item summary{position:relative;list-style:none;cursor:pointer;padding:22px 40px 22px 0;font-family:"Sora",sans-serif;font-weight:600;font-size:1.05rem;letter-spacing:-.01em;color:var(--ink)}
.faq__item summary::-webkit-details-marker{display:none}
.faq__item summary::after{content:"";position:absolute;right:4px;top:50%;width:11px;height:11px;border-right:2px solid var(--ink);border-bottom:2px solid var(--ink);transform:translateY(-70%) rotate(45deg);transition:transform .3s var(--ease)}
.faq__item[open] summary::after{transform:translateY(-30%) rotate(-135deg);border-color:var(--yellow-d)}
.faq__item p{padding:0 0 22px;color:var(--grey-500);font-size:.98rem;line-height:1.7}
@media(max-width:600px){
  .faq{padding:68px 0}
  .faq__item{padding:0 20px}
  .faq__item summary{font-size:.98rem;padding:18px 36px 18px 0}
}

/* CTA */
.cta{position:relative;padding:130px 0;background:
  radial-gradient(circle at 78% 18%,rgba(255,196,0,.18),transparent 45%),
  radial-gradient(circle at 15% 90%,rgba(255,196,0,.08),transparent 40%),
  linear-gradient(160deg,var(--ink),var(--carbon));
  color:#fff;text-align:center;overflow:hidden}
.cta::before{content:"";position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.04) 1px,transparent 1px);background-size:26px 26px;opacity:.6}
.cta__inner{position:relative;max-width:720px;margin:0 auto}
.cta h2{font-size:clamp(2.1rem,5vw,3.3rem);letter-spacing:-.035em;margin-bottom:18px}
.cta p{color:#c9cdd0;font-size:1.18rem;line-height:1.6;margin-bottom:38px}
.cta__phone{display:block;margin-top:24px;color:#9aa0a5;font-size:.98rem}
.cta__phone a{color:var(--yellow);font-weight:700}

/* FOOTER */
.footer{position:relative;background:
  radial-gradient(circle at 15% 0%,rgba(255,196,0,.06),transparent 45%),
  radial-gradient(circle at 100% 100%,rgba(255,255,255,.03),transparent 50%),
  linear-gradient(180deg,#0a0b0d 0%,#050608 100%);
  color:#c3c8cc;overflow:hidden;
  border-top:1px solid rgba(255,196,0,.45)}
.footer::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(255,196,0,.85) 50%,transparent);
  box-shadow:0 0 18px rgba(255,196,0,.35)}
.footer__inner{display:grid;grid-template-columns:1.5fr 1fr 1.1fr;gap:64px;padding:88px 0 56px}
.footer__about p{font-size:.96rem;line-height:1.75;color:#a7adb3;margin-top:22px;max-width:380px}
.footer__logo{height:auto;max-width:230px;width:100%;display:block}
.footer__col h4{color:#fff;margin-bottom:22px;text-transform:uppercase;letter-spacing:.18em;font-size:.78rem;font-family:"Sora",sans-serif;font-weight:700;position:relative;padding-bottom:14px}
.footer__col h4::after{content:"";position:absolute;left:0;bottom:0;width:32px;height:2px;background:var(--yellow);border-radius:2px}
.footer__col a{transition:color .25s var(--ease),transform .25s var(--ease)}
.footer__col a:hover{color:var(--yellow)}
.footer__list{list-style:none;display:flex;flex-direction:column;gap:11px}
.footer__list a{display:inline-flex;align-items:center;gap:10px;font-size:.95rem;color:#b6bbc0;position:relative;padding-left:14px}
.footer__list a::before{content:"";position:absolute;left:0;top:50%;width:6px;height:6px;border-radius:50%;background:var(--yellow);opacity:.7;transform:translateY(-50%);transition:opacity .25s var(--ease),transform .25s var(--ease)}
.footer__list a:hover{transform:translateX(3px)}
.footer__list a:hover::before{opacity:1;transform:translateY(-50%) scale(1.25)}
.footer__info{list-style:none;display:flex;flex-direction:column;gap:13px;margin-bottom:26px}
.footer__info li{display:inline-flex;align-items:center;gap:11px;font-size:.95rem;color:#b6bbc0}
.footer__info a{display:inline-flex;align-items:center;gap:11px;color:#b6bbc0}
.footer__ico{flex:none;color:var(--yellow);opacity:.85;transition:opacity .25s var(--ease),transform .25s var(--ease)}
.footer__info li:hover .footer__ico,.footer__info a:hover .footer__ico{opacity:1;transform:scale(1.06)}
.footer__cta{background:rgba(37,211,102,.12);color:#fff;border:1px solid rgba(37,211,102,.45);
  padding:11px 20px;font-size:.92rem;border-radius:12px;font-weight:600;
  box-shadow:0 6px 18px -8px rgba(37,211,102,.4)}
.footer__cta:hover{background:#25D366;border-color:#25D366;transform:translateY(-2px);
  box-shadow:0 14px 30px -10px rgba(37,211,102,.6)}
.footer__bottom{border-top:1px solid rgba(255,255,255,.06);padding:26px 0 30px;
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;
  font-size:.85rem;color:#7e848a}
.footer__tagline{font-style:italic;color:#6b7177}
@media(max-width:860px){
  .footer__inner{grid-template-columns:1fr;gap:48px;padding:64px 0 40px}
  .footer__bottom{justify-content:center;text-align:center;flex-direction:column;gap:6px}
}

/* WHATSAPP FLOAT */
.wa-float{position:fixed;right:22px;bottom:22px;z-index:60;display:inline-flex;align-items:center;gap:0;
  height:62px;padding:0;border-radius:50px;background:#25D366;color:#fff;overflow:hidden;
  box-shadow:0 16px 38px -8px rgba(37,211,102,.55);
  transition:transform var(--t) var(--ease),box-shadow var(--t) var(--ease);
  animation:wa-breath 4.2s ease-in-out infinite}
.wa-float__icon{flex:none;display:grid;place-items:center;width:62px;height:62px}
.wa-float__label{font-weight:700;font-size:1rem;letter-spacing:-.01em;white-space:nowrap;max-width:0;opacity:0;
  padding-right:0;transition:max-width .45s var(--ease),opacity .35s var(--ease),padding-right .45s var(--ease)}
.wa-float:hover{transform:translateY(-2px);box-shadow:0 24px 50px -10px rgba(37,211,102,.7);animation-play-state:paused}
.wa-float:hover .wa-float__label{max-width:240px;opacity:1;padding-right:24px}
@keyframes wa-breath{
  0%,100%{box-shadow:0 16px 38px -8px rgba(37,211,102,.55),0 0 0 0 rgba(37,211,102,.18)}
  50%{box-shadow:0 18px 40px -8px rgba(37,211,102,.6),0 0 0 10px rgba(37,211,102,0)}
}
@media(max-width:600px){
  .wa-float{right:16px;bottom:16px;height:58px}
  .wa-float__icon{width:58px;height:58px}
  .wa-float__label{display:none}
}

/* REVEAL */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* RESPONSIVE */
@media(max-width:980px){
  .benefits{max-width:none}
}
@media(max-width:860px){
  .nav__links{display:none}
  .hero{padding:120px 0 90px}
  .coverage__inner{grid-template-columns:1fr;gap:40px}
  .coverage__map{height:340px}
  .footer__inner{grid-template-columns:1fr;gap:30px;text-align:left}
  .services,.gallery,.coverage{padding:84px 0}
  .cta{padding:90px 0}
}
@media(max-width:600px){
  .container{padding:0 18px}
  body{font-size:15.5px}
  .hero{padding:96px 0 64px;min-height:auto}
  .hero__title{font-size:clamp(2rem,9vw,2.8rem);line-height:1.08}
  .hero__sub{font-size:1rem;margin-bottom:26px}
  .hero__cta{gap:12px}
  .hero__cta .btn{width:100%;padding:14px 22px;font-size:.98rem}
  .pill{font-size:.74rem;padding:7px 14px;margin-bottom:20px}
  .benefits{grid-template-columns:1fr;gap:10px;margin-top:38px}
  .benefit{padding:14px 16px;gap:12px}
  .benefit__icon{width:42px;height:42px}
  .benefit strong{font-size:.96rem}
  .benefit span{font-size:.8rem}
  .section-head{margin-bottom:40px}
  .section-head h2{font-size:clamp(1.65rem,6.8vw,2.1rem)}
  .section-head p{font-size:.98rem}
  .eyebrow{font-size:.72rem;letter-spacing:.16em;margin-bottom:12px}
  .services,.coverage,.faq,.showcase,.why{padding:72px 0}
  .cta{padding:70px 0}
  .card{padding:26px 22px}
  .card h3{font-size:1.15rem}
  .btn--lg{padding:18px 28px;font-size:1.06rem;width:100%}
  .stats{padding:42px 0}
  .stat{padding:14px 10px}
  .stat__num{font-size:2.2rem;margin-bottom:6px}
  .stat__num--text{font-size:1.7rem}
  .stat__label{font-size:.82rem}
  .stat:nth-child(3),.stat:nth-child(4){padding-top:20px;margin-top:6px}
  .sc-item{aspect-ratio:5/4}
  .sc-item figcaption{font-size:.74rem;padding:7px 12px;left:12px;bottom:12px}
  .coverage__map{height:280px;border-radius:var(--radius)}
  .coverage__list li{padding:14px 16px}
  .coverage__list strong{font-size:1rem}
  .coverage__list span{font-size:.85rem}
  .cta h2{font-size:clamp(1.75rem,7vw,2.3rem)}
  .cta p{font-size:1.02rem;margin-bottom:28px}
  .faq__item summary{font-size:.95rem;padding:18px 32px 18px 0}
  .faq__item p{font-size:.92rem}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
  .hero__bg{transform:none!important}
}
