/* =========================================================
   JASA Detailing — Premium Automotive Landing
   Paleta: Negro · Morado · Plateado
   Mobile-first, compacto, app-like
   ========================================================= */

:root{
  --black:#08070c;
  --bg:#0a0a0f;
  --bg-2:#0e0c16;
  --panel:#141019;
  --line:rgba(168,85,247,.18);

  --violet:#a855f7;
  --violet-2:#7c3aed;
  --violet-hi:#c98bff;
  --glow:#b026ff;

  --silver-1:#ffffff;
  --silver-2:#d7d8e2;
  --silver-3:#9a9bab;

  --text:#e9e8f0;
  --muted:#a7a6b8;

  --grad-violet:linear-gradient(135deg,#c98bff 0%,#a855f7 45%,#7c3aed 100%);
  --grad-chrome:linear-gradient(180deg,#ffffff 0%,#d7d8e2 38%,#8d8e9e 64%,#f1f1f6 100%);
  --grad-panel:linear-gradient(160deg,rgba(168,85,247,.12),rgba(20,16,25,.4));

  --shadow:0 18px 40px -18px rgba(0,0,0,.8);
  --shadow-violet:0 14px 38px -12px rgba(176,38,255,.55);

  --r:18px;
  --r-sm:13px;
  --maxw:1160px;
  --pad:clamp(1rem,4.5vw,2rem);

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

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}

body{
  font-family:"Inter",system-ui,-apple-system,"Segoe UI",sans-serif;
  background:var(--bg);
  color:var(--text);
  line-height:1.55;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  /* deep ambient glows */
  background-image:
    radial-gradient(58% 32% at 88% 4%, rgba(124,58,237,.20), transparent 70%),
    radial-gradient(46% 26% at 6% 22%, rgba(176,38,255,.12), transparent 72%);
  background-attachment:fixed;
}

img,video,svg,iframe{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:0;background:none;color:inherit}

h1,h2,h3,h4{font-family:"Sora",sans-serif;line-height:1.1;letter-spacing:-.02em;font-weight:700}

.container{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:var(--pad)}

::selection{background:rgba(176,38,255,.35);color:#fff}

:focus-visible{outline:2px solid var(--violet-hi);outline-offset:3px;border-radius:6px}

/* gradient text */
.grad{
  background:var(--grad-violet);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
}

/* =================== BUTTONS =================== */
.btn{
  --b:0;
  display:inline-flex;align-items:center;justify-content:center;gap:.55em;
  font-family:"Sora",sans-serif;font-weight:600;font-size:.95rem;
  padding:.85rem 1.35rem;border-radius:999px;
  position:relative;isolation:isolate;
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .25s;
  white-space:nowrap;
}
.btn .ico{width:1.15em;height:1.15em;fill:currentColor}
.btn:active{transform:scale(.96)}

.btn--wa{
  color:#fff;
  background:linear-gradient(135deg,#a855f7,#7c3aed);
  box-shadow:var(--shadow-violet);
}
.btn--wa::after{
  content:"";position:absolute;inset:0;border-radius:inherit;z-index:-1;
  background:linear-gradient(135deg,#c98bff,#7c3aed);
  opacity:0;transition:opacity .3s;
}
.btn--wa:hover{transform:translateY(-2px)}
.btn--wa:hover::after{opacity:1}

.btn--ghost{
  color:var(--text);
  background:rgba(255,255,255,.04);
  border:1px solid rgba(215,216,226,.28);
  backdrop-filter:blur(8px);
}
.btn--ghost:hover{border-color:var(--violet-hi);color:#fff;transform:translateY(-2px);box-shadow:0 0 0 1px rgba(201,139,255,.4),0 10px 26px -14px rgba(176,38,255,.6)}

.btn--sm{padding:.6rem .95rem;font-size:.85rem}
.btn--lg{padding:1.05rem 1.9rem;font-size:1.05rem}

/* =================== LOADER =================== */
.loader{
  position:fixed;inset:0;z-index:9999;
  display:grid;place-items:center;
  background:radial-gradient(circle at 50% 40%,#16101f,#070509 70%);
  transition:opacity .6s var(--ease),visibility .6s;
  overflow:hidden;
}
.loader.hide{opacity:0;visibility:hidden;pointer-events:none}
.loader__inner{display:flex;flex-direction:column;align-items:center;gap:1.25rem;z-index:2;padding:1.5rem}
.loader__logo{
  width:min(64vw,260px);height:auto;border-radius:14px;
  filter:drop-shadow(0 0 28px rgba(176,38,255,.55));
  animation:logoPulse 2.2s var(--ease) infinite;
}
@keyframes logoPulse{0%,100%{transform:scale(1);filter:drop-shadow(0 0 18px rgba(176,38,255,.35))}50%{transform:scale(1.04);filter:drop-shadow(0 0 34px rgba(176,38,255,.7))}}
.loader__bar{width:min(60vw,230px);height:4px;border-radius:99px;background:rgba(255,255,255,.1);overflow:hidden}
.loader__fill{display:block;height:100%;width:0;border-radius:99px;background:var(--grad-violet);box-shadow:0 0 14px var(--glow);transition:width .25s linear}
.loader__txt{font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--silver-3)}
.loader__sheen{
  position:absolute;top:0;left:-40%;width:40%;height:100%;
  background:linear-gradient(105deg,transparent,rgba(201,139,255,.14),transparent);
  animation:sheen 2.4s linear infinite;
}
@keyframes sheen{0%{left:-40%}100%{left:120%}}

/* =================== HEADER =================== */
.header{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  transition:background .35s,backdrop-filter .35s,border-color .35s,padding .35s;
  border-bottom:1px solid transparent;
}
.header.scrolled{
  background:rgba(10,9,15,.72);
  backdrop-filter:blur(14px) saturate(1.2);
  border-bottom-color:var(--line);
}
.header__inner{
  max-width:var(--maxw);margin-inline:auto;
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
  padding:.55rem var(--pad);
}
.header__brand img{
  width:auto;height:46px;border-radius:8px;
  opacity:0;transform:translateY(-6px);
  transition:opacity .4s,transform .4s;
}
.header.scrolled .header__brand img{opacity:1;transform:none}
.header__nav{display:none;gap:1.6rem;font-size:.9rem;font-weight:500}
.header__nav a{color:var(--muted);position:relative;transition:color .25s}
.header__nav a::after{content:"";position:absolute;left:0;right:100%;bottom:-5px;height:2px;background:var(--grad-violet);transition:right .3s var(--ease)}
.header__nav a:hover{color:#fff}
.header__nav a:hover::after{right:0}
.header__cta{flex-shrink:0}

/* =================== HERO =================== */
.hero{
  position:relative;
  min-height:100svh;
  display:flex;flex-direction:column;justify-content:center;align-items:center;
  text-align:center;
  padding:5.5rem var(--pad) 4.5rem;
  overflow:hidden;
}
.hero__bg{position:absolute;inset:0;z-index:0}
.hero__bg img{
  width:100%;height:100%;object-fit:cover;object-position:50% 38%;
  transform:scale(1.2);
  filter:blur(3.5px) brightness(.88) saturate(1.06);
  animation:kenburns 18s ease-in-out infinite alternate;
}
@keyframes kenburns{0%{transform:scale(1.2) translateY(0)}100%{transform:scale(1.3) translateY(-2%)}}
.hero__bg::after{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(180deg,rgba(8,7,12,.68) 0%,rgba(8,7,12,.44) 35%,rgba(8,7,12,.8) 72%,#0a0a0f 100%),
    radial-gradient(120% 80% at 50% 32%,transparent 26%,rgba(8,7,12,.6) 100%);
}
.hero__glow{
  position:absolute;z-index:1;inset:0;pointer-events:none;
  background:
    radial-gradient(40% 30% at 78% 18%,rgba(176,38,255,.45),transparent 70%),
    radial-gradient(36% 26% at 16% 82%,rgba(124,58,237,.32),transparent 70%);
  mix-blend-mode:screen;
}
.hero__beams{position:absolute;inset:0;z-index:1;overflow:hidden;pointer-events:none}
.hero__beams span{
  position:absolute;top:-30%;width:1px;height:160%;
  background:linear-gradient(transparent,rgba(201,139,255,.5),transparent);
  filter:blur(.5px);opacity:.5;
  animation:beam 7s linear infinite;
}
.hero__beams span:nth-child(1){left:22%;animation-delay:0s}
.hero__beams span:nth-child(2){left:54%;animation-delay:2.4s;height:120%}
.hero__beams span:nth-child(3){left:80%;animation-delay:4.2s}
@keyframes beam{0%{transform:translateY(-20%) rotate(8deg);opacity:0}30%{opacity:.55}100%{transform:translateY(20%) rotate(8deg);opacity:0}}

.hero__content{position:relative;z-index:3;display:flex;flex-direction:column;align-items:center;max-width:720px;animation:heroIn 1s var(--ease) both}
@keyframes heroIn{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:none}}
.hero__logo{
  width:min(62vw,260px);height:auto;border-radius:14px;margin-bottom:1rem;
  filter:drop-shadow(0 6px 26px rgba(176,38,255,.45));
}
.hero__badge{
  display:inline-block;font-family:"Sora",sans-serif;font-weight:600;
  font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--violet-hi);
  padding:.4rem .85rem;border-radius:999px;margin-bottom:.9rem;
  background:rgba(176,38,255,.1);border:1px solid var(--line);
  backdrop-filter:blur(6px);
}
.hero__title{
  font-size:clamp(1.9rem,8.4vw,4rem);font-weight:800;
  text-shadow:0 4px 30px rgba(0,0,0,.6);
  margin-bottom:.7rem;
}
.hero__sub{
  font-size:clamp(.95rem,3.6vw,1.15rem);color:var(--silver-2);
  max-width:34ch;margin:0 auto 1.5rem;
}
.hero__actions{display:flex;flex-wrap:wrap;gap:.7rem;justify-content:center;margin-bottom:1.3rem}
.hero__socials{display:flex;gap:.7rem}
.hero__socials a{
  width:42px;height:42px;border-radius:50%;
  display:grid;place-items:center;
  background:rgba(255,255,255,.06);border:1px solid rgba(215,216,226,.22);
  backdrop-filter:blur(6px);transition:transform .25s,border-color .25s,background .25s;
}
.hero__socials .ico{width:19px;height:19px;fill:var(--silver-2);transition:fill .25s}
.hero__socials a:hover{transform:translateY(-3px) scale(1.06);border-color:var(--violet-hi);background:rgba(176,38,255,.16)}
.hero__socials a:hover .ico{fill:#fff}

.hero__scroll{position:absolute;bottom:1.4rem;left:50%;transform:translateX(-50%);z-index:3;width:26px;height:42px;border:2px solid rgba(215,216,226,.4);border-radius:14px;display:grid;justify-items:center;padding-top:7px}
.hero__scroll span{width:4px;height:8px;border-radius:2px;background:var(--violet-hi);animation:scrolldot 1.6s var(--ease) infinite}
@keyframes scrolldot{0%{opacity:0;transform:translateY(-3px)}40%{opacity:1}80%{opacity:0;transform:translateY(10px)}}

/* marquee */
.marquee{position:absolute;bottom:0;left:0;right:0;z-index:3;overflow:hidden;padding:.6rem 0;border-top:1px solid var(--line);background:linear-gradient(180deg,transparent,rgba(8,7,12,.6))}
.marquee__track{display:flex;align-items:center;gap:1.1rem;width:max-content;animation:marquee 22s linear infinite}
.marquee__track span{font-family:"Sora",sans-serif;font-weight:600;font-size:.8rem;letter-spacing:.04em;color:var(--silver-2);text-transform:uppercase;white-space:nowrap}
.marquee__track i{color:var(--violet);font-style:normal;font-size:.6rem}
@keyframes marquee{to{transform:translateX(-50%)}}

/* =================== SECTION HEADINGS =================== */
.sec-head{text-align:center;max-width:560px;margin:0 auto clamp(1.4rem,4vw,2.2rem)}
.sec-head h2,.about h2,.contact h2,.cta h2{font-size:clamp(1.5rem,6vw,2.5rem);font-weight:800}
.sec-head p{color:var(--muted);font-size:.92rem;margin-top:.45rem}
.eyebrow{display:inline-block;font-family:"Sora",sans-serif;font-weight:600;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--violet);margin-bottom:.5rem}

section{position:relative}
.about,.services,.works,.process,.why,.contact{padding-block:clamp(2.6rem,7vw,4.8rem)}

/* subtle divider glow between sections */
.services::before,.process::before,.contact::before{
  content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:min(80%,640px);height:1px;
  background:linear-gradient(90deg,transparent,var(--violet),transparent);
  opacity:.5;
}

/* =================== ABOUT =================== */
.about{background:linear-gradient(180deg,#0a0a0f,#0c0a13)}
.about__grid{display:grid;grid-template-columns:1fr;gap:1.4rem;align-items:center}
.about__media{position:relative;border-radius:var(--r);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow);aspect-ratio:16/12}
.about__media img{width:100%;height:100%;object-fit:cover}
.about__media::after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,transparent 55%,rgba(176,38,255,.22))}
.about__media-tag{position:absolute;left:.8rem;bottom:.8rem;font-family:"Sora";font-weight:600;font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;padding:.35rem .7rem;border-radius:99px;background:rgba(8,7,12,.6);border:1px solid var(--line);backdrop-filter:blur(6px)}
.about__text p{color:var(--silver-2);font-size:.98rem;margin-top:.3rem}
.about__text strong{color:#fff}
.about__mini{display:grid;grid-template-columns:repeat(3,1fr);gap:.6rem;margin-top:1.3rem}
.mini{background:var(--grad-panel);border:1px solid var(--line);border-radius:var(--r-sm);padding:.8rem .6rem;text-align:center}
.mini b{display:block;font-family:"Sora";font-size:1.02rem;background:var(--grad-chrome);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.mini span{font-size:.72rem;color:var(--muted);line-height:1.25;display:block;margin-top:.15rem}

/* =================== SERVICES =================== */
.services{background:
  radial-gradient(60% 40% at 50% 0%,rgba(124,58,237,.10),transparent 70%),
  linear-gradient(180deg,#0c0a13,#0a0a0f)}
.svc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.8rem}
.svc{
  position:relative;text-align:left;
  background:linear-gradient(165deg,rgba(255,255,255,.05),rgba(20,16,25,.5));
  border:1px solid var(--line);border-radius:var(--r);
  padding:1.05rem .95rem;overflow:hidden;
  transition:transform .3s var(--ease),border-color .3s,box-shadow .3s;
  display:flex;flex-direction:column;gap:.55rem;
}
.svc::before{content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;background:var(--grad-violet);-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 .3s}
.svc::after{content:"";position:absolute;top:-50%;left:-60%;width:60%;height:200%;background:linear-gradient(105deg,transparent,rgba(255,255,255,.13),transparent);transform:skewX(-18deg);transition:left .6s var(--ease)}
.svc:hover,.svc:focus-visible{transform:translateY(-4px);box-shadow:var(--shadow-violet);border-color:transparent}
.svc:hover::before,.svc.open::before{opacity:1}
.svc:hover::after{left:130%}
.svc__ico{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;background:rgba(176,38,255,.14);border:1px solid var(--line)}
.svc__ico svg{width:24px;height:24px;fill:var(--violet-hi)}
.svc__name{font-family:"Sora";font-weight:600;font-size:.98rem;color:#fff;line-height:1.2}
.svc__more{font-size:.82rem;color:var(--muted);max-height:0;opacity:0;overflow:hidden;transition:max-height .4s var(--ease),opacity .3s,margin .3s}
.svc.open .svc__more{max-height:120px;opacity:1}
.svc::after{pointer-events:none}
.svc-foot{text-align:center;margin-top:1.4rem}

/* =================== WORKS / GALLERY =================== */
.works{background:linear-gradient(180deg,#0a0a0f,#0d0a14)}
.filters{display:flex;gap:.5rem;overflow-x:auto;padding-bottom:.5rem;margin-bottom:1.2rem;scrollbar-width:none;justify-content:flex-start}
.filters::-webkit-scrollbar{display:none}
.chip{
  flex:0 0 auto;font-family:"Sora";font-weight:500;font-size:.82rem;
  padding:.5rem .95rem;border-radius:999px;color:var(--muted);
  background:rgba(255,255,255,.04);border:1px solid var(--line);
  transition:all .25s;
}
.chip.is-active{color:#fff;background:var(--grad-violet);border-color:transparent;box-shadow:0 8px 20px -10px var(--glow)}

.rail{
  display:flex;gap:.85rem;overflow-x:auto;scroll-snap-type:x mandatory;
  padding:.4rem var(--pad) 1rem;
  scrollbar-width:none;-webkit-overflow-scrolling:touch;
}
.rail::-webkit-scrollbar{display:none}

.vcard{flex:0 0 auto;width:min(68vw,250px);scroll-snap-align:center;transition:opacity .35s,transform .35s}
.vcard.hide{display:none}
.vcard__media{
  position:relative;aspect-ratio:9/16;border-radius:var(--r);overflow:hidden;
  border:1px solid var(--line);background:#0d0a14;box-shadow:var(--shadow);
}
.vcard__media video{width:100%;height:100%;object-fit:cover}
.vcard__media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 60%,rgba(8,7,12,.75));pointer-events:none}
.vplay{
  position:absolute;inset:0;z-index:2;display:grid;place-items:center;
  background:radial-gradient(circle at 50% 45%,rgba(176,38,255,.25),transparent 60%);
  transition:opacity .3s;
}
.vplay svg{width:30px;height:30px;fill:#fff}
.vplay::before{content:"";position:absolute;width:62px;height:62px;border-radius:50%;background:rgba(124,58,237,.55);backdrop-filter:blur(4px);border:1.5px solid rgba(255,255,255,.6);box-shadow:0 0 30px rgba(176,38,255,.6);animation:pulse 2.4s ease-out infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(176,38,255,.5)}70%{box-shadow:0 0 0 16px rgba(176,38,255,0)}100%{box-shadow:0 0 0 0 rgba(176,38,255,0)}}
.vplay svg{position:relative;z-index:1}
.vcard.playing .vplay{opacity:0;pointer-events:none}
.vsound{
  position:absolute;left:50%;bottom:.7rem;transform:translateX(-50%);
  z-index:3;display:inline-flex;align-items:center;gap:.38rem;
  padding:.4rem .72rem;border-radius:999px;white-space:nowrap;
  background:rgba(8,7,12,.66);border:1px solid var(--line);backdrop-filter:blur(8px);
  opacity:0;pointer-events:none;transition:opacity .3s,background .3s,border-color .3s;
}
.vcard.playing .vsound{opacity:1}
.vsound svg{width:17px;height:17px;fill:var(--violet-hi);flex-shrink:0}
.vsound b{font-family:"Sora";font-weight:600;font-size:.72rem;color:var(--silver-2)}
.vsound__on{display:none}
.vcard.is-unmuted .vsound{background:rgba(124,58,237,.62);border-color:rgba(201,139,255,.55);padding:.4rem .5rem}
.vcard.is-unmuted .vsound svg{fill:#fff}
.vcard.is-unmuted .vsound__off{display:none}
.vcard.is-unmuted .vsound__on{display:inline}
.vcard.is-unmuted .vsound b{display:none}
.vcard__badge{position:absolute;top:.6rem;left:.6rem;z-index:3;font-family:"Sora";font-weight:600;font-size:.68rem;letter-spacing:.04em;padding:.3rem .6rem;border-radius:99px;background:rgba(8,7,12,.7);border:1px solid var(--line);color:var(--violet-hi);backdrop-filter:blur(6px)}
.vcard__cap{margin-top:.6rem;font-size:.85rem;color:var(--silver-2);font-weight:500;padding-inline:.2rem}
.rail__hint{text-align:center;font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:var(--silver-3);margin-top:.2rem}

/* =================== PROCESS =================== */
.process{background:radial-gradient(50% 50% at 50% 0,rgba(176,38,255,.08),transparent 70%),linear-gradient(180deg,#0d0a14,#0a0a0f)}
.rail--steps{padding-top:.6rem}
.step{
  flex:0 0 auto;width:min(64vw,230px);scroll-snap-align:center;
  background:linear-gradient(165deg,rgba(255,255,255,.05),rgba(20,16,25,.55));
  border:1px solid var(--line);border-radius:var(--r);padding:1.3rem 1.1rem 1.2rem;
  position:relative;overflow:hidden;
}
.step__n{font-family:"Sora";font-weight:800;font-size:2.6rem;line-height:1;background:var(--grad-violet);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;opacity:.95}
.step h3{font-size:1.05rem;margin:.5rem 0 .35rem}
.step p{font-size:.84rem;color:var(--muted)}
.step::before{content:"";position:absolute;right:-20px;top:-20px;width:90px;height:90px;border-radius:50%;background:radial-gradient(circle,rgba(176,38,255,.22),transparent 70%)}

/* =================== WHY =================== */
.why{background:linear-gradient(180deg,#0a0a0f,#0c0a13)}
.why-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.7rem}
.feat{
  display:flex;flex-direction:column;align-items:flex-start;gap:.6rem;
  background:var(--grad-panel);border:1px solid var(--line);border-radius:var(--r-sm);
  padding:1rem .9rem;transition:transform .3s var(--ease),border-color .3s,background .3s;
}
.feat svg{width:28px;height:28px;fill:var(--violet-hi);filter:drop-shadow(0 0 8px rgba(176,38,255,.5))}
.feat b{font-family:"Sora";font-weight:600;font-size:.9rem;color:#fff;line-height:1.25}
.feat:hover{transform:translateY(-4px);border-color:var(--violet-hi);background:linear-gradient(160deg,rgba(176,38,255,.18),rgba(20,16,25,.5))}

/* =================== CONTACT =================== */
.contact{background:linear-gradient(180deg,#0c0a13,#0a0a0f)}
.contact__grid{display:grid;grid-template-columns:1fr;gap:1.4rem}
.contact__list{list-style:none;display:flex;flex-direction:column;gap:.75rem;margin:1.1rem 0 1.3rem}
.contact__list li{display:flex;align-items:center;gap:.7rem;font-size:.95rem;color:var(--silver-2)}
.contact__list svg{width:22px;height:22px;fill:var(--violet-hi);flex-shrink:0}
.contact__btns{display:flex;flex-direction:column;gap:.7rem;align-items:stretch}
.contact__btns .btn{width:100%}
.contact__social{display:flex;gap:.7rem;justify-content:center;margin-top:.2rem}
.contact__social a{width:46px;height:46px;border-radius:50%;display:grid;place-items:center;background:rgba(255,255,255,.05);border:1px solid var(--line);transition:transform .25s,border-color .25s,background .25s}
.contact__social .ico{width:20px;height:20px;fill:var(--silver-2);transition:fill .25s}
.contact__social a:hover{transform:translateY(-3px);border-color:var(--violet-hi);background:rgba(176,38,255,.16)}
.contact__social a:hover .ico{fill:#fff}
.contact__map{
  position:relative;display:block;overflow:hidden;
  border-radius:var(--r);border:1px solid var(--line);box-shadow:var(--shadow);
  min-height:260px;
  background:radial-gradient(120% 90% at 70% 20%,#1a1330,#0b0912 70%);
  transition:transform .35s var(--ease),border-color .35s,box-shadow .35s;
}
.contact__map:hover{transform:translateY(-3px);border-color:var(--violet-hi);box-shadow:var(--shadow-violet)}
.map-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(168,85,247,.14) 1px,transparent 1px),linear-gradient(90deg,rgba(168,85,247,.14) 1px,transparent 1px);background-size:34px 34px;mask-image:radial-gradient(120% 100% at 50% 40%,#000 35%,transparent 80%)}
.map-roads{position:absolute;inset:0;opacity:.55;background:
  linear-gradient(60deg,transparent 47%,rgba(201,139,255,.45) 48%,rgba(201,139,255,.45) 49%,transparent 50%),
  linear-gradient(-25deg,transparent 64%,rgba(215,216,226,.35) 65%,rgba(215,216,226,.35) 66%,transparent 67%),
  linear-gradient(110deg,transparent 28%,rgba(168,85,247,.3) 29%,rgba(168,85,247,.3) 30%,transparent 31%)}
.map-pin{position:absolute;top:42%;left:50%;transform:translate(-50%,-50%);width:46px;height:46px;display:grid;place-items:center;border-radius:50%;background:radial-gradient(circle,rgba(176,38,255,.5),transparent 70%)}
.map-pin svg{width:34px;height:34px;fill:var(--violet-hi);filter:drop-shadow(0 4px 10px rgba(176,38,255,.8));animation:pinBob 2.6s var(--ease) infinite}
.map-pin::after{content:"";position:absolute;width:14px;height:14px;border-radius:50%;border:2px solid var(--violet-hi);animation:pulse 2.6s ease-out infinite}
@keyframes pinBob{0%,100%{transform:translateY(0)}50%{transform:translateY(-5px)}}
.map-foot{position:absolute;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:space-between;gap:.6rem;padding:.85rem 1rem;background:linear-gradient(180deg,transparent,rgba(8,7,12,.9));backdrop-filter:blur(2px)}
.map-foot__addr{font-size:.82rem;color:var(--silver-2);font-weight:500}
.map-foot__cta{display:inline-flex;align-items:center;gap:.35rem;font-family:"Sora";font-weight:600;font-size:.78rem;color:var(--violet-hi);white-space:nowrap}
.map-foot__cta svg{width:14px;height:14px;fill:currentColor}

/* =================== CTA =================== */
.cta{position:relative;overflow:hidden;padding-block:clamp(3rem,9vw,5.5rem);text-align:center}
.cta__bg{position:absolute;inset:0;z-index:0}
.cta__bg img{width:100%;height:100%;object-fit:cover;object-position:50% 35%}
.cta__bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,7,12,.78),rgba(10,8,18,.85)),radial-gradient(60% 50% at 50% 50%,rgba(176,38,255,.3),transparent 70%)}
.cta__content{position:relative;z-index:2;max-width:620px}
.cta__content p{color:var(--silver-2);margin:.6rem 0 1.4rem;font-size:1rem}

/* =================== FOOTER =================== */
.footer{background:#070509;border-top:1px solid var(--line);padding-top:2.4rem}
.footer__grid{display:grid;grid-template-columns:1fr;gap:1.6rem;padding-bottom:1.8rem}
.footer__brand img{width:140px;height:auto;border-radius:10px;margin-bottom:.7rem}
.footer__brand p{color:var(--muted);font-size:.85rem;max-width:34ch}
.footer__col h4{font-family:"Sora";font-size:.95rem;color:#fff;margin-bottom:.6rem}
.footer__col p,.footer__col a{color:var(--muted);font-size:.88rem;line-height:1.8}
.footer__col a:hover{color:var(--violet-hi)}
.footer__social{display:flex;flex-direction:column;gap:.2rem}
.footer__bar{border-top:1px solid rgba(255,255,255,.06);padding:1rem var(--pad);text-align:center}
.footer__bar p{color:var(--silver-3);font-size:.76rem}

/* =================== FAB =================== */
.fab{
  position:fixed;right:1rem;bottom:1rem;z-index:900;
  width:56px;height:56px;border-radius:50%;
  display:grid;place-items:center;
  background:linear-gradient(135deg,#25d366,#128c4b);
  box-shadow:0 12px 30px -8px rgba(37,211,102,.6);
  opacity:0;transform:translateY(20px) scale(.8);
  transition:opacity .4s var(--ease),transform .4s var(--ease);
}
.fab.show{opacity:1;transform:none}
.fab svg{width:28px;height:28px;fill:#fff}
.fab::after{content:"";position:absolute;inset:0;border-radius:50%;border:2px solid rgba(37,211,102,.6);animation:pulse 2.6s ease-out infinite}
.fab:hover{transform:scale(1.08)}

/* =================== REVEAL ANIMATIONS =================== */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal:nth-child(2){transition-delay:.06s}
.reveal:nth-child(3){transition-delay:.12s}
.reveal:nth-child(4){transition-delay:.18s}
.reveal:nth-child(5){transition-delay:.24s}
.reveal:nth-child(6){transition-delay:.3s}

/* =================== RESPONSIVE =================== */
@media (min-width:680px){
  .svc-grid{grid-template-columns:repeat(3,1fr)}
  .why-grid{grid-template-columns:repeat(3,1fr)}
  .about__grid{grid-template-columns:1.05fr .95fr}
  .about__media{aspect-ratio:4/5}
  .contact__grid{grid-template-columns:1fr 1fr;align-items:stretch}
  .contact__btns{flex-direction:row;flex-wrap:wrap}
  .contact__btns .btn{width:auto;flex:1 1 auto}
  .contact__social{margin-left:auto}
  .footer__grid{grid-template-columns:1.6fr 1fr 1fr}
  .vcard{width:240px}
}

@media (min-width:920px){
  .header__nav{display:flex}
  .hero__logo{width:300px}
  .vcard{width:260px}
  .rail{padding-inline:max(var(--pad),calc((100vw - var(--maxw))/2 + var(--pad)))}
}

@media (hover:hover){
  .vcard__media{cursor:pointer}
}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
  .hero__bg img{transform:scale(1.2)}
  .reveal{opacity:1;transform:none}
}
