/* ============================================================
   FILIPE ELECTRIC CAR — v3 (refinado, arredondado, suave)
   Rail lateral + hero assimétrico. Preto & laranja. Outfit/Inter.
   ============================================================ */

:root{
  --orange:#FA7A1E;
  --orange-2:#FF9244;
  --bg:#0B0B0D;
  --bg-2:#111114;
  --panel:#16161B;
  --panel-2:#1D1D23;
  --line:rgba(255,255,255,.08);
  --line-2:rgba(255,255,255,.14);
  --text:#F4F4F6;
  --muted:#9A9AA4;
  --rail:104px;
  --r-lg:26px;
  --r-md:18px;
  --r-sm:14px;
  --ease:cubic-bezier(.16,1,.3,1);
  --shadow:0 24px 60px -20px rgba(0,0,0,.7);
}

*{margin:0;padding:0;box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{font-family:'Inter',system-ui,sans-serif;background:var(--bg);color:var(--text);line-height:1.65;overflow-x:hidden;-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
h1,h2,h3{font-family:'Outfit',sans-serif;font-weight:700;line-height:1.05;letter-spacing:-.02em}
.hl{color:var(--orange)}

/* eyebrow tag */
.tag{display:inline-flex;align-items:center;gap:9px;font-size:.78rem;font-weight:600;letter-spacing:.04em;color:var(--muted);margin-bottom:20px}
.tag i{width:24px;height:2px;border-radius:2px;background:var(--orange);display:inline-block}

@media (hover:hover) and (pointer:fine){*{cursor:none !important}}

/* ---------- LOADER ---------- */
.loader{position:fixed;inset:0;z-index:9999;background:var(--bg);display:grid;place-items:center;transition:opacity .6s var(--ease),visibility .6s}
.loader.done{opacity:0;visibility:hidden}
.loader__inner{display:flex;flex-direction:column;align-items:center;gap:24px}
.loader__logo{height:46px;opacity:.95;animation:floaty 1.6s var(--ease) infinite}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}
.loader__track{width:min(58vw,220px);height:3px;background:rgba(255,255,255,.1);border-radius:3px;overflow:hidden}
.loader__track i{display:block;height:100%;width:0;background:var(--orange);border-radius:3px;box-shadow:0 0 14px var(--orange)}

/* ---------- CURSOR ---------- */
.cursor{position:fixed;top:0;left:0;width:10px;height:10px;border-radius:50%;background:var(--orange);pointer-events:none;z-index:9990;transform:translate(-50%,-50%);transition:width .28s var(--ease),height .28s var(--ease),background .28s,opacity .28s}
.cursor.is-link{width:48px;height:48px;background:rgba(250,122,30,.22);border:1.5px solid var(--orange)}
.cursor.is-hide{opacity:0}
.cursor.is-drag{width:74px;height:74px;background:var(--orange)}
.cursor.is-drag::after{content:'arraste';position:absolute;inset:0;display:grid;place-items:center;font-family:'Outfit';font-size:.62rem;font-weight:700;color:#0B0B0D;letter-spacing:.05em}
@media (hover:none),(pointer:coarse){.cursor{display:none}}

/* ---------- RAIL ---------- */
.rail{position:fixed;left:0;top:0;bottom:0;width:var(--rail);z-index:800;display:flex;flex-direction:column;align-items:center;justify-content:space-between;padding:30px 0;background:linear-gradient(180deg,var(--bg-2),var(--bg))}
.rail::after{content:'';position:absolute;right:0;top:24px;bottom:24px;width:1px;background:linear-gradient(180deg,transparent,var(--line-2),transparent)}
.rail__mark svg{width:28px;height:36px;fill:var(--orange);filter:drop-shadow(0 0 12px rgba(250,122,30,.5));transition:transform .4s var(--ease)}
.rail__mark:hover svg{transform:scale(1.12) rotate(-4deg)}
.rail__nav{display:flex;flex-direction:column;gap:40px;align-items:center}
.rail__nav a{writing-mode:vertical-rl;transform:rotate(180deg);font-family:'Outfit';font-weight:600;font-size:.82rem;letter-spacing:.06em;color:var(--muted);position:relative;transition:color .3s}
.rail__nav a::before{content:'';position:absolute;left:-14px;top:50%;transform:translateY(-50%) scale(.4);width:6px;height:6px;border-radius:50%;background:var(--orange);opacity:0;transition:.3s var(--ease)}
.rail__nav a:hover,.rail__nav a.active{color:var(--text)}
.rail__nav a:hover::before,.rail__nav a.active::before{opacity:1;transform:translateY(-50%) scale(1)}
.rail__social{display:flex;flex-direction:column;gap:18px}
.rail__social a svg{width:20px;height:20px;fill:none;stroke:var(--muted);stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round;transition:stroke .3s,transform .3s var(--ease)}
.rail__social a[aria-label="WhatsApp"] svg{fill:var(--muted);stroke:none}
.rail__social a:hover svg{stroke:var(--orange);fill:var(--orange);transform:translateY(-3px)}
.rail__social a[aria-label="Instagram"]:hover svg{fill:none;stroke:var(--orange)}

/* ---------- TOPBAR (mobile) ---------- */
.topbar{display:none;position:fixed;top:0;left:0;right:0;z-index:820;align-items:center;justify-content:flex-end;padding:14px 18px;background:rgba(11,11,13,.8);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
body.menu-open .topbar{background:transparent;backdrop-filter:none;border-color:transparent;pointer-events:none}
body.menu-open .topbar__burger{opacity:0;pointer-events:none}
.topbar__burger{display:flex;flex-direction:column;gap:5px;background:none;border:0;padding:6px;z-index:830}
.topbar__burger span{width:24px;height:2px;border-radius:2px;background:var(--text);transition:.3s var(--ease)}
body.menu-open .topbar__burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
body.menu-open .topbar__burger span:nth-child(2){opacity:0}
body.menu-open .topbar__burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ---------- SHELL ---------- */
.shell{margin-left:var(--rail);padding:0 clamp(20px,4vw,76px)}

/* ---------- HERO ---------- */
.hero{position:relative;min-height:100svh;display:grid;grid-template-columns:1.1fr .9fr;grid-template-rows:1fr auto;gap:46px clamp(34px,5vw,86px);align-items:center;padding:120px 0 36px}
.hero__glow{position:absolute;z-index:0;width:70vw;height:70vw;max-width:760px;max-height:760px;left:-12%;top:-6%;background:radial-gradient(circle,rgba(250,122,30,.20),transparent 62%);filter:blur(20px);pointer-events:none}
.hero__left{position:relative;z-index:2}
.hero__logo{height:48px;margin-bottom:30px;opacity:.96}
.hero__title{font-size:clamp(2.5rem,5.6vw,5rem);font-weight:800;margin-bottom:26px;max-width:16ch}
.hero__lead{color:var(--muted);max-width:48ch;font-size:1.08rem;margin-bottom:36px}
.hero__cta{display:flex;gap:14px;flex-wrap:wrap}
.hero__right{position:relative;z-index:2}
.hero__panel{position:relative;border-radius:var(--r-lg);overflow:hidden;aspect-ratio:5/6;box-shadow:var(--shadow);border:1px solid var(--line)}
.hero__panel img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease)}
.hero__panel:hover img{transform:scale(1.05)}
.hero__panel::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(11,11,13,.6))}
.hero__panel figcaption{position:absolute;left:16px;bottom:16px;z-index:2;display:inline-flex;align-items:center;gap:9px;padding:9px 15px;border-radius:100px;background:rgba(11,11,13,.7);backdrop-filter:blur(8px);border:1px solid var(--line-2);font-size:.82rem;font-weight:500}
.hero__panel .pulse{width:8px;height:8px;border-radius:50%;background:#43d17f;box-shadow:0 0 8px #43d17f;animation:pulse 1.5s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.35}}
.hero__stats{grid-column:1 / -1;display:grid;grid-template-columns:repeat(4,1fr);gap:14px;position:relative;z-index:2}
.hstat{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-md);padding:24px 22px;transition:transform .4s var(--ease),border-color .4s,background .4s}
.hstat:hover{transform:translateY(-5px);border-color:rgba(250,122,30,.4);background:var(--panel-2)}
.hstat__n{font-family:'Outfit';font-weight:800;font-size:clamp(1.9rem,3.4vw,2.8rem);color:var(--orange);display:block;line-height:1}
.hstat__l{display:block;margin-top:9px;font-size:.82rem;color:var(--muted)}

/* ---------- BUTTONS ---------- */
.btn{display:inline-flex;align-items:center;gap:10px;padding:15px 28px;font-family:'Outfit';font-weight:600;font-size:.97rem;border-radius:100px;transition:transform .35s var(--ease),background .35s,color .35s,border-color .35s,box-shadow .35s;will-change:transform}
.btn__arrow{font-style:normal;transition:transform .35s var(--ease)}
.btn--solid{background:var(--orange);color:#0B0B0D}
.btn--solid:hover{background:var(--orange-2);box-shadow:0 14px 36px -8px rgba(250,122,30,.6)}
.btn--solid:hover .btn__arrow{transform:translateX(5px)}
.btn--line{background:transparent;color:var(--text);border:1px solid var(--line-2)}
.btn--line:hover{border-color:var(--orange);color:var(--orange)}

/* ---------- TICKER ---------- */
.ticker{overflow:hidden;margin:0 calc(clamp(20px,4vw,76px) * -1);padding:20px 0;background:var(--bg-2);border-block:1px solid var(--line)}
.ticker__row{display:flex;align-items:center;gap:26px;width:max-content;animation:ticker 40s linear infinite;white-space:nowrap}
.ticker__row span{font-family:'Outfit';font-weight:600;font-size:clamp(1.1rem,2.4vw,1.7rem);color:rgba(255,255,255,.34)}
.ticker__row i{color:var(--orange);font-style:normal;font-size:1rem}
@keyframes ticker{to{transform:translateX(-50%)}}

/* ---------- BLOCK HEAD ---------- */
.block-head{padding:clamp(74px,10vw,134px) 0 clamp(36px,5vw,58px)}
.block-head h2{font-size:clamp(2rem,4.4vw,3.4rem)}
.block-head--row{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap}
.estr__hint{color:var(--muted);font-size:.92rem;font-weight:500}

/* ---------- SERVIÇOS — ÍNDICE ---------- */
.svc{position:relative;padding-bottom:clamp(40px,6vw,80px)}
.svc-list{list-style:none}
.svc-row{position:relative;display:grid;grid-template-columns:64px 1.05fr 1.45fr 40px;align-items:center;gap:22px;padding:30px 26px;border-radius:var(--r-md);transition:background .4s var(--ease),transform .4s var(--ease)}
.svc-row::after{content:'';position:absolute;left:26px;right:26px;bottom:0;height:1px;background:var(--line)}
.svc-row:last-child::after{display:none}
.svc-row__num{font-family:'Outfit';font-weight:600;color:var(--muted);font-size:.95rem;transition:color .4s}
.svc-row__title{font-size:clamp(1.35rem,2.6vw,2rem);font-weight:600;transition:transform .4s var(--ease),color .4s}
.svc-row__desc{color:var(--muted);font-size:.96rem;transition:color .4s}
.svc-row__go{justify-self:end;font-size:1.3rem;color:var(--muted);transition:transform .4s var(--ease),color .4s}
.svc-row:hover{background:linear-gradient(90deg,rgba(250,122,30,.10),rgba(250,122,30,.02));transform:translateX(6px)}
.svc-row:hover .svc-row__title{color:var(--orange)}
.svc-row:hover .svc-row__num{color:var(--orange)}
.svc-row:hover .svc-row__go{transform:translate(4px,-4px);color:var(--orange)}
.svc-preview{position:fixed;top:0;left:0;width:300px;height:210px;border-radius:var(--r-md);overflow:hidden;pointer-events:none;z-index:700;opacity:0;transform:translate(-50%,-50%) scale(.85);transition:opacity .35s var(--ease),transform .35s var(--ease);box-shadow:var(--shadow);border:1px solid var(--line-2)}
.svc-preview.show{opacity:1;transform:translate(-50%,-50%) scale(1)}
.svc-preview img{width:100%;height:100%;object-fit:cover}

/* ---------- A OFICINA ---------- */
.oficina{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(36px,6vw,90px);padding:clamp(74px,10vw,134px) 0;align-items:start}
.oficina__statement{position:sticky;top:64px}
.oficina__big{font-family:'Outfit';font-weight:800;font-size:clamp(3.6rem,8vw,7rem);line-height:.9;margin:6px 0 22px}
.oficina__cap{color:var(--muted);max-width:32ch}
.oficina__body h2{font-size:clamp(1.8rem,3.4vw,2.7rem);margin-bottom:22px;max-width:20ch}
.oficina__body>p{color:var(--muted);max-width:54ch;margin-bottom:34px}
.oficina__points{list-style:none;display:grid;gap:12px;margin-bottom:38px}
.oficina__points li{display:flex;align-items:center;gap:18px;padding:20px 24px;border-radius:var(--r-md);background:var(--panel);border:1px solid var(--line);font-size:1.04rem;transition:transform .4s var(--ease),border-color .4s}
.oficina__points li:hover{transform:translateX(6px);border-color:rgba(250,122,30,.35)}
.oficina__points .num{font-family:'Outfit';font-weight:700;color:var(--orange);font-size:.92rem}

/* ---------- ESTRUTURA ---------- */
.estr__track{display:flex;gap:22px;overflow-x:auto;scroll-snap-type:x mandatory;padding-bottom:34px;margin:0 calc(clamp(20px,4vw,76px) * -1);padding-inline:clamp(20px,4vw,76px);scrollbar-width:none;cursor:grab}
.estr__track::-webkit-scrollbar{display:none}
.estr__track.dragging{cursor:grabbing;scroll-snap-type:none}
.estr__card{flex:0 0 clamp(280px,42vw,520px);scroll-snap-align:start;position:relative;border-radius:var(--r-lg);overflow:hidden;aspect-ratio:16/11;box-shadow:var(--shadow)}
.estr__card img{width:100%;height:100%;object-fit:cover;pointer-events:none;transition:transform .8s var(--ease)}
.estr__card:hover img{transform:scale(1.06)}
.estr__card figcaption{position:absolute;left:0;right:0;bottom:0;padding:38px 24px 22px;background:linear-gradient(transparent,rgba(11,11,13,.92));display:flex;flex-direction:column;gap:5px}
.estr__card .cap{display:inline-block;align-self:flex-start;padding:4px 12px;border-radius:100px;background:rgba(250,122,30,.16);color:var(--orange);font-size:.72rem;font-weight:600;letter-spacing:.04em}
.estr__card figcaption strong{font-family:'Outfit';font-weight:600;font-size:1.1rem}

/* ---------- CONTATO ---------- */
.contato{display:grid;grid-template-columns:1fr 1fr;gap:clamp(20px,2.5vw,32px);padding:clamp(74px,10vw,134px) 0 clamp(60px,8vw,100px)}
.contato__card{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(30px,4vw,50px)}
.contato__card h2{font-size:clamp(1.9rem,4vw,2.9rem);margin-bottom:32px}
.contato__data{display:grid;grid-template-columns:1fr 1fr;gap:26px;margin-bottom:36px}
.contato__data dt{font-size:.74rem;font-weight:600;letter-spacing:.04em;color:var(--orange);margin-bottom:7px}
.contato__data dd{font-size:1rem;line-height:1.5}
.contato__data a:hover{color:var(--orange)}
.contato__map{position:relative;display:block;border-radius:var(--r-lg);overflow:hidden;min-height:360px;box-shadow:var(--shadow)}
.contato__map img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;filter:grayscale(.3) brightness(.85) contrast(1.04);transition:transform .8s var(--ease),filter .5s}
.contato__map:hover img{transform:scale(1.05);filter:grayscale(0) brightness(.95)}
.contato__map::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(11,11,13,.05),rgba(11,11,13,.45))}
.contato__pin{position:absolute;left:50%;top:50%;transform:translate(-50%,-100%);z-index:2;animation:pinBounce 2s var(--ease) infinite}
.contato__pin svg{width:42px;height:42px;fill:var(--orange);stroke:#0B0B0D;stroke-width:1;filter:drop-shadow(0 6px 10px rgba(0,0,0,.5))}
@keyframes pinBounce{0%,100%{transform:translate(-50%,-100%)}50%{transform:translate(-50%,-114%)}}
.contato__maptag{position:absolute;left:18px;bottom:18px;z-index:3;padding:10px 16px;border-radius:100px;background:rgba(11,11,13,.78);backdrop-filter:blur(8px);border:1px solid var(--line-2);font-family:'Outfit';font-weight:600;font-size:.82rem;transition:background .3s,color .3s,border-color .3s}
.contato__map:hover .contato__maptag{background:var(--orange);color:#0B0B0D;border-color:var(--orange)}

/* ---------- FOOTER ---------- */
.foot{padding:clamp(50px,7vw,90px) 0 36px;border-top:1px solid var(--line)}
.foot__top{display:flex;align-items:center;justify-content:space-between;gap:28px;flex-wrap:wrap;padding-bottom:36px}
.foot__logo{height:52px}
.foot__nav{display:flex;gap:28px;flex-wrap:wrap}
.foot__nav a{color:var(--muted);font-weight:500;font-size:.95rem;transition:color .3s}
.foot__nav a:hover{color:var(--orange)}
.foot__row{display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;padding-top:26px;border-top:1px solid var(--line);font-size:.82rem;color:var(--muted)}
.foot__credit{opacity:.7;transition:opacity .3s}
.foot__credit:hover{opacity:1}
.foot__credit a{color:var(--muted);transition:color .3s}
.foot__credit a:hover{color:var(--orange)}

/* ---------- FLOATING WHATSAPP ---------- */
.wa-float{display:none;position:fixed;right:16px;bottom:16px;z-index:760;width:56px;height:56px;border-radius:50%;background:#25D366;place-items:center;box-shadow:0 12px 30px rgba(0,0,0,.45)}
.wa-float svg{width:28px;height:28px;fill:#fff}

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

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1080px){
  .hero{grid-template-columns:1fr;grid-template-rows:auto auto auto;min-height:auto;padding:128px 0 34px;gap:38px}
  .hero__right{max-width:440px}
  .hero__panel{aspect-ratio:16/12}
  .oficina{grid-template-columns:1fr;gap:34px}
  .oficina__statement{position:static}
}

@media (max-width:860px){
  :root{--rail:0px}
  .rail{display:none}
  .topbar{display:flex}
  .wa-float{display:grid}
  .shell{margin-left:0;padding:0 20px}
  .rail__nav,.rail__social{display:none}
  .hero{padding:100px 0 30px}
  .hero__stats{grid-template-columns:1fr 1fr}
  .ticker,.estr__track{margin-inline:-20px}
  .estr__track{padding-inline:20px}
  .svc-row{grid-template-columns:46px 1fr;gap:6px 16px;padding:24px 18px;row-gap:8px}
  .svc-row__num{grid-row:1;grid-column:1}
  .svc-row__title{grid-row:1;grid-column:2}
  .svc-row__desc{grid-row:2;grid-column:2}
  .svc-row__go{display:none}
  .svc-row:hover{transform:none}
  .svc-row::after{left:18px;right:18px}
  .contato{grid-template-columns:1fr}
  .contato__data{grid-template-columns:1fr 1fr}
  .foot__top{justify-content:flex-start;gap:20px}
  .foot__row{flex-direction:column;gap:8px}
}

/* mobile slide-in menu */
.mobile-menu{position:fixed;inset:0;z-index:805;background:var(--bg-2);transform:translateX(100%);transition:transform .5s var(--ease);display:flex;flex-direction:column;justify-content:center;gap:6px;padding:40px}
.mobile-menu.open{transform:translateX(0)}
.mobile-menu a{font-family:'Outfit';font-weight:700;font-size:2rem;padding:16px 0;border-bottom:1px solid var(--line);color:var(--text);display:flex;align-items:center;gap:16px}
.mobile-menu a .num{font-size:.9rem;color:var(--orange);font-weight:600}
.mobile-menu__close{position:absolute;top:16px;right:18px;width:46px;height:46px;border:0;border-radius:50%;background:var(--panel);color:var(--text);font-size:2rem;line-height:1;cursor:pointer;display:grid;place-items:center;transition:background .3s,color .3s}
.mobile-menu__close:hover{background:var(--orange);color:#0B0B0D}
@media (min-width:861px){.mobile-menu{display:none}}

@media (max-width:430px){
  .contato__data{grid-template-columns:1fr}
  .hero__title{font-size:2.3rem}
}

/* ---------- REDUCED MOTION ---------- */
@media (prefers-reduced-motion:reduce){
  *{animation:none !important;transition:none !important}
  .js .reveal{opacity:1;transform:none}
}
