/*
Theme Name: JR Motores
Theme URI: https://jrmotores.online
Author: JR Motores
Description: Tema customizado da JR Motores — oficina mecânica em Campinas/SP. Design industrial dark com acentos em vermelho. Inclui Home, Serviços, Sobre, Galeria e Contato.
Version: 1.0.0
License: GPL v2 or later
Text Domain: jrmotores
*/

/* ============ RESET ============ */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{margin:0;font-family:'Barlow','Inter',system-ui,sans-serif;background:#1f1f1f;color:#f5f5f5;line-height:1.55;font-size:16px;-webkit-font-smoothing:antialiased}
img,video,iframe{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
ul{margin:0;padding:0;list-style:none}
h1,h2,h3,h4{font-family:'Bebas Neue','Oswald',system-ui,sans-serif;margin:0;letter-spacing:.06em;line-height:1.05;font-weight:400}
p{margin:0}

/* ============ TOKENS ============ */
:root{
  --bg:#1f1f1f;
  --card:#2a2a2a;
  --card-2:#333;
  --fg:#f5f5f5;
  --muted:#a8a8a8;
  --border:#3a3a3a;
  --primary:#dc2626;
  --primary-hover:#b91c1c;
  --primary-soft:rgba(220,38,38,.12);
  --maxw:1200px;
}

/* ============ UTIL ============ */
.container{max-width:var(--maxw);margin:0 auto;padding:0 1rem}
@media(min-width:640px){.container{padding:0 1.5rem}}
.eyebrow{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.3em;color:var(--primary);margin:0 0 .5rem}
.muted{color:var(--muted)}
.primary{color:var(--primary)}
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.85rem 1.6rem;font-size:.82rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;border-radius:2px;transition:transform .2s,background .2s,border-color .2s,color .2s}
.btn-primary{background:var(--primary);color:#fff}
.btn-primary:hover{background:var(--primary-hover);transform:translateY(-2px)}
.btn-outline{border:1px solid var(--border);background:rgba(31,31,31,.6);backdrop-filter:blur(6px);color:var(--fg)}
.btn-outline:hover{border-color:var(--primary);color:var(--primary)}
.btn-whatsapp{background:#25d366;color:#fff}
.btn-whatsapp:hover{background:#1ebe5a}

/* ============ HEADER ============ */
.site-header{position:sticky;top:0;z-index:40;border-bottom:1px solid var(--border);background:rgba(31,31,31,.92);backdrop-filter:blur(10px)}
.site-header .container{display:flex;align-items:center;justify-content:space-between;height:4rem}
.brand{display:flex;align-items:center;gap:.75rem}
.brand img{width:44px;height:44px;object-fit:contain}
.brand-name{font-family:'Bebas Neue',sans-serif;font-size:1.5rem;letter-spacing:.1em}
.brand-name span{color:var(--primary)}
.nav-main{display:none;align-items:center;gap:.25rem}
.nav-main a{padding:.5rem 1rem;font-size:.85rem;font-weight:500;text-transform:uppercase;letter-spacing:.05em;transition:color .2s}
.nav-main a:hover,.nav-main a.active,.nav-main .current-menu-item>a{color:var(--primary)}
.nav-cta{display:none;align-items:center;gap:.5rem}
.menu-toggle{display:flex;width:44px;height:44px;align-items:center;justify-content:center;border:1px solid var(--border)}
@media(min-width:900px){.nav-main,.nav-cta{display:flex}.menu-toggle{display:none}}
.nav-mobile{display:none;border-top:1px solid var(--border);background:var(--card)}
.nav-mobile.open{display:block}
.nav-mobile a{display:block;padding:1rem 1.5rem;border-bottom:1px solid var(--border);text-transform:uppercase;letter-spacing:.05em;font-size:.9rem}
.nav-mobile a:hover{color:var(--primary)}

/* ============ HERO ============ */
.hero{position:relative;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:-1}
.hero-bg img{width:100%;height:100%;object-fit:cover;opacity:.4}
.hero-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,var(--bg) 0%,rgba(31,31,31,.7) 50%,rgba(31,31,31,.4))}
.hero-inner{padding:6rem 0 9rem}
.hero h1{font-size:clamp(2.75rem,7vw,5.5rem);text-transform:uppercase;max-width:55rem}
.hero p.lead{margin-top:1.5rem;max-width:34rem;font-size:1.1rem;color:var(--muted)}
.hero p.lead strong{color:var(--fg)}
.hero-ctas{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:2rem}
.hero-stats{margin-top:3.5rem;display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;border-left:2px solid var(--primary);padding-left:1.5rem;max-width:40rem}
.hero-stats .num{font-family:'Bebas Neue',sans-serif;font-size:2.25rem;color:var(--primary)}
.hero-stats .lab{font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted)}

/* ============ PAGE HERO ============ */
.page-hero{position:relative;overflow:hidden;border-bottom:1px solid var(--border);background:var(--card)}
.page-hero::before{content:"";position:absolute;inset:0 auto 0 0;width:4px;background:var(--primary)}
.page-hero .container{padding-top:4rem;padding-bottom:5rem}
.page-hero h1{font-size:clamp(2.5rem,5vw,3.75rem);text-transform:uppercase}
.page-hero p{margin-top:1rem;max-width:40rem;color:var(--muted)}

/* ============ BRANDS BAR ============ */
.brands-bar{border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--card)}
.brands-bar .container{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:.75rem 2.5rem;padding:1.5rem 1rem;font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}

/* ============ SECTIONS ============ */
.section{padding:5rem 0}
.section-head{display:flex;align-items:end;justify-content:space-between;gap:1.5rem;margin-bottom:3rem}
.section-head h2{font-size:clamp(2rem,4vw,3rem);text-transform:uppercase}
.link-arrow{font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--primary)}
.link-arrow:hover{text-decoration:underline}

/* ============ CARD GRID ============ */
.card-grid{display:grid;gap:1rem;grid-template-columns:1fr}
@media(min-width:640px){.card-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.card-grid.cols-3{grid-template-columns:repeat(3,1fr)}.card-grid.cols-4{grid-template-columns:repeat(4,1fr)}}
.s-card{position:relative;overflow:hidden;border:1px solid var(--border);background:var(--card);padding:1.5rem;transition:border-color .2s}
.s-card:hover{border-color:var(--primary)}
.s-card::before{content:"";position:absolute;top:0;right:0;height:4px;width:3rem;background:var(--primary);transition:width .3s}
.s-card:hover::before{width:100%}
.s-card .icon{width:36px;height:36px;color:var(--primary);stroke-width:1.8}
.s-card h3{margin-top:1rem;font-size:1.4rem;text-transform:uppercase}
.s-card p{margin-top:.5rem;font-size:.88rem;color:var(--muted)}

/* ============ WHY US ============ */
.why{border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--card)}
.why .container{display:grid;gap:3rem;padding:5rem 1rem}
@media(min-width:1024px){.why .container{grid-template-columns:1fr 1fr}}
.why .img-stack{position:relative}
.why .img-stack .main{aspect-ratio:4/5;width:100%;object-fit:cover}
.why .img-stack .sub{position:absolute;bottom:-1rem;right:-1rem;width:12rem;aspect-ratio:1/1;object-fit:cover;border:4px solid var(--bg);display:none}
@media(min-width:640px){.why .img-stack .sub{display:block}}
.why ul.values{margin-top:2rem;display:flex;flex-direction:column;gap:1rem}
.why ul.values li{display:flex;gap:1rem}
.why ul.values .badge{width:40px;height:40px;flex-shrink:0;background:var(--primary-soft);color:var(--primary);display:flex;align-items:center;justify-content:center;border-radius:2px}
.why ul.values .t{font-weight:600}
.why ul.values .d{font-size:.88rem;color:var(--muted)}

/* ============ REVIEWS ============ */
.reviews{border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--card)}
.reviews .container{max-width:880px;padding:5rem 1rem}
.reviews .head{text-align:center;margin-bottom:2.5rem}
.reviews .head h2{font-size:clamp(2rem,4vw,3rem);text-transform:uppercase}
.reviews .stars{display:flex;gap:.25rem;color:var(--primary);justify-content:center;margin-top:.75rem}
.review-card{position:relative;border:1px solid var(--border);background:var(--bg);padding:2rem;min-height:220px;transition:opacity .3s,transform .3s}
@media(min-width:640px){.review-card{padding:3rem}}
.review-card .stars{justify-content:flex-start;margin:0 0 1rem}
.review-card .text{font-family:'Bebas Neue',sans-serif;font-size:1.25rem;line-height:1.4;letter-spacing:.02em}
@media(min-width:640px){.review-card .text{font-size:1.45rem}}
.review-meta{margin-top:1.5rem;display:flex;align-items:center;gap:.75rem;border-top:1px solid var(--border);padding-top:1.25rem}
.review-meta .avatar{width:44px;height:44px;border-radius:50%;background:var(--primary-soft);color:var(--primary);display:flex;align-items:center;justify-content:center;font-weight:700;text-transform:uppercase;font-size:.85rem}
.review-meta .name{font-weight:600;font-size:.9rem}
.review-meta .when{font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}
.review-dots{display:flex;justify-content:center;gap:.5rem;margin-top:1.5rem}
.review-dots button{height:6px;width:8px;background:var(--border);transition:width .2s,background .2s}
.review-dots button.active{width:32px;background:var(--primary)}
.review-link{text-align:center;margin-top:2rem}
.review-link a{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--primary)}
.review-link a:hover{text-decoration:underline}

/* ============ CTA ============ */
.cta{padding:5rem 0}
.cta-box{position:relative;overflow:hidden;border:1px solid var(--border);background:var(--card);padding:2.5rem}
@media(min-width:640px){.cta-box{padding:4rem}}
.cta-box::before{content:"";position:absolute;top:0;bottom:0;left:0;width:6px;background:var(--primary)}
.cta-box{display:grid;gap:2rem;align-items:center}
@media(min-width:1024px){.cta-box{grid-template-columns:1fr auto}}
.cta-box h2{font-size:clamp(1.7rem,4vw,3rem);text-transform:uppercase}
.cta-info{margin-top:1rem;display:grid;gap:.75rem;font-size:.88rem;color:var(--muted)}
@media(min-width:640px){.cta-info{grid-template-columns:repeat(3,1fr)}}
.cta-info span{display:inline-flex;align-items:center;gap:.5rem}
.cta-info svg{color:var(--primary);width:16px;height:16px}

/* ============ CONTACT ============ */
.contact-grid{display:grid;gap:2.5rem}
@media(min-width:1024px){.contact-grid{grid-template-columns:1fr 1fr}}
.info-card{border:1px solid var(--border);background:var(--card);padding:1.5rem}
.info-card .ic{width:32px;height:32px;color:var(--primary)}
.info-card h3{margin-top:.75rem;font-size:1.05rem;text-transform:uppercase;letter-spacing:.08em}
.info-card p,.info-card a{margin-top:.5rem;font-size:.88rem;color:var(--muted)}
.info-card a:hover{color:var(--primary)}
.info-grid{display:grid;gap:1rem}
@media(min-width:640px){.info-grid{grid-template-columns:1fr 1fr}}
.social-row{display:flex;gap:.75rem;flex-wrap:wrap}
.social-row a{display:inline-flex;align-items:center;gap:.5rem;padding:.6rem 1rem;font-size:.85rem;border-radius:2px}
.map-wrap{overflow:hidden;border:1px solid var(--border)}
.map-wrap iframe{width:100%;aspect-ratio:4/3;border:0}
.form-card{border:1px solid var(--border);background:var(--card);padding:1.5rem}
@media(min-width:640px){.form-card{padding:2rem}}
.form-card h2{font-size:1.8rem;text-transform:uppercase}
.form-card p.note{margin-top:.25rem;font-size:.88rem;color:var(--muted)}
form.contact-form{margin-top:1.5rem;display:flex;flex-direction:column;gap:1rem}
.field label{display:block;font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:.4rem}
.field input,.field textarea{width:100%;padding:.7rem .85rem;background:var(--bg);border:1px solid var(--border);color:var(--fg);font-family:inherit;font-size:.95rem;border-radius:2px}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--primary)}
.field textarea{min-height:130px;resize:vertical}

/* ============ GALLERY ============ */
.gallery-grid{display:grid;gap:.75rem;grid-template-columns:repeat(2,1fr);grid-auto-rows:200px}
@media(min-width:768px){.gallery-grid{grid-template-columns:repeat(4,1fr);grid-auto-rows:220px}}
.gallery-grid a{position:relative;overflow:hidden;border:1px solid var(--border);display:block}
.gallery-grid a img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.gallery-grid a:hover img{transform:scale(1.05)}
.gallery-grid .span-2{grid-column:span 2}
.gallery-grid .span-r2{grid-row:span 2}
.video-wrap{margin-top:3rem;border:1px solid var(--border);background:var(--card);overflow:hidden}
.video-wrap video{width:100%;aspect-ratio:16/9;background:#000}

/* ============ SOBRE ============ */
.about-grid{display:grid;gap:3rem}
@media(min-width:1024px){.about-grid{grid-template-columns:1fr 1fr}}
.about-grid .copy p{color:var(--muted);margin-top:1rem}
.about-grid .copy p strong{color:var(--fg)}
.values-list{margin-top:2rem;display:grid;gap:.75rem}
@media(min-width:640px){.values-list{grid-template-columns:1fr 1fr}}
.values-list li{display:flex;align-items:flex-start;gap:.5rem;font-size:.9rem}
.values-list svg{color:var(--primary);width:20px;height:20px;flex-shrink:0;margin-top:2px}
.about-grid .imgs{display:grid;gap:1rem}
.about-grid .imgs img{aspect-ratio:4/3;width:100%;object-fit:cover}

/* ============ FOOTER ============ */
.site-footer{border-top:1px solid var(--border);background:var(--card)}
.site-footer .container{display:grid;gap:2.5rem;padding:3rem 1rem}
@media(min-width:768px){.site-footer .container{grid-template-columns:2fr 1fr 1fr}}
.site-footer h4{font-size:1.1rem;text-transform:uppercase;letter-spacing:.1em;margin-bottom:1rem}
.site-footer ul li{margin-bottom:.5rem;font-size:.9rem;color:var(--muted)}
.site-footer ul li a:hover{color:var(--primary)}
.site-footer .col-1 p{margin-top:.75rem;max-width:30rem;font-size:.9rem;color:var(--muted)}
.site-footer .socials{margin-top:1rem;display:flex;gap:.75rem}
.site-footer .socials a{width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--border);border-radius:2px}
.site-footer .socials a:hover{background:var(--primary);color:#fff;border-color:var(--primary)}
.site-footer .contact-list li{display:flex;gap:.5rem}
.site-footer .contact-list svg{color:var(--primary);width:16px;height:16px;flex-shrink:0;margin-top:3px}
.copyright{border-top:1px solid var(--border);padding:1rem;text-align:center;font-size:.75rem;color:var(--muted)}

/* ============ FLOATING WHATSAPP ============ */
.wa-float{position:fixed;bottom:1.25rem;right:1.25rem;z-index:50;width:56px;height:56px;border-radius:50%;background:#25d366;color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 24px rgba(0,0,0,.4);transition:transform .2s}
.wa-float:hover{transform:scale(1.08)}

/* ============ SUCCESS BANNER ============ */
.alert{padding:1rem 1.25rem;border:1px solid var(--border);background:var(--card);margin-bottom:1.5rem;font-size:.9rem}
.alert.ok{border-left:4px solid #25d366}
.alert.err{border-left:4px solid var(--primary)}
