/*
Theme Name: Rick's Automotive (GeneratePress Child)
Template: generatepress
Description: Lightweight GeneratePress child theme for Rick's Automotive (ricksauto.ca), Woodstock ON.
Version: 1.0
Text Domain: ricks-automotive-child
*/

@import url('https://fonts.googleapis.com/css2?family=Barlow+Condensed:wght@500;600;700&family=Inter:wght@400;500;600;700&display=swap');

:root{
  --navy:#0e2439; --navy-2:#16324b; --ink:#12202e; --accent:#e2582b;
  --accent-dark:#c2461f; --gold:#f2a51c; --paper:#f6f4ef; --line:#e3ddd2;
  --muted:#6b7683; --white:#ffffff;
}

/* Reset a few GeneratePress defaults so our design controls the page */
body{font-family:'Inter',system-ui,sans-serif;color:var(--ink);background:#fff;line-height:1.7}
h1,h2,h3,.display{font-family:'Barlow Condensed',sans-serif;text-transform:uppercase;letter-spacing:.01em;line-height:1.04;font-weight:700}
a{color:inherit;text-decoration:none}
#content, .site-content, .inside-article{padding:0 !important;max-width:none !important}
.site-content .wrap{max-width:1180px;margin:0 auto;padding:0 24px}
.wrap{max-width:1180px;margin:0 auto;padding:0 24px}

.btn{display:inline-flex;align-items:center;gap:9px;font-weight:600;font-size:15px;padding:14px 26px;border-radius:8px;transition:.2s;cursor:pointer;border:2px solid transparent}
.btn-accent{background:var(--accent);color:#fff}.btn-accent:hover{background:var(--accent-dark);color:#fff}
.btn-ghost{border-color:rgba(255,255,255,.5);color:#fff}.btn-ghost:hover{background:rgba(255,255,255,.12);border-color:#fff}
.btn-dark{background:var(--navy);color:#fff}.btn-dark:hover{background:var(--navy-2);color:#fff}
.btn-block{display:flex;width:100%;justify-content:center}
.eyebrow{font-family:'Barlow Condensed',sans-serif;text-transform:uppercase;letter-spacing:.16em;font-weight:600;color:var(--accent);font-size:15px}
.ico{width:22px;height:22px;flex:none;stroke:currentColor;stroke-width:2;fill:none;stroke-linecap:round;stroke-linejoin:round}

/* top bar + header */
.topbar{background:var(--ink);color:#cfd8e0;font-size:13.5px}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;height:42px;flex-wrap:wrap;gap:6px}
.topbar a:hover{color:#fff}.topbar .tb-r{display:flex;gap:22px;align-items:center}.topbar .tb-i{display:flex;gap:7px;align-items:center}
.site-header,header.site-header{position:sticky;top:0;z-index:50;background:#fff;border-bottom:1px solid var(--line);box-shadow:0 2px 14px rgba(0,0,0,.04)}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;height:86px}
.logo{display:flex;align-items:center;gap:12px}
.logo img,.logo .custom-logo-link img{display:block;height:68px;width:auto;max-width:260px;object-fit:contain}
.logo .custom-logo-link{display:flex;align-items:center}
.logo-txt b{font-family:'Barlow Condensed';font-size:27px;font-weight:700;text-transform:uppercase;letter-spacing:.02em;display:block;line-height:.92;color:var(--navy)}
.logo-txt span{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);font-weight:600}
nav.main{display:flex;gap:30px;align-items:center}
nav.main ul{list-style:none;display:flex;gap:30px;align-items:center;margin:0;padding:0}
nav.main a{font-weight:600;font-size:15px;color:var(--ink);position:relative;padding:6px 0}
nav.main a:hover,nav.main .current-menu-item>a{color:var(--accent)}
nav.main a:hover::after,nav.main .current-menu-item>a::after{content:"";position:absolute;left:0;bottom:0;height:2px;width:100%;background:var(--accent)}
.nav-cta{display:flex;align-items:center;gap:14px}
.menu-toggle{display:none}
@media(max-width:900px){
  nav.main{display:none}
  .menu-toggle{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border:1px solid var(--line);border-radius:8px;background:#fff;cursor:pointer}
  nav.main.mobile-open{display:block;position:absolute;top:86px;left:0;right:0;background:#fff;border-bottom:1px solid var(--line);padding:10px 24px 20px}
  nav.main.mobile-open ul{flex-direction:column;align-items:flex-start;gap:4px}
  nav.main.mobile-open li{width:100%;padding:8px 0;border-bottom:1px solid var(--line)}
}

/* hero (home) */
.hero{position:relative;background:linear-gradient(135deg,#0b1e30 0%,#123454 55%,#0e2439 100%);color:#fff;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;background-image:linear-gradient(115deg,transparent 60%,rgba(226,88,43,.22) 61%,rgba(226,88,43,.22) 66%,transparent 67%);opacity:.7}
.hero .wrap{position:relative;display:grid;grid-template-columns:1.15fr .85fr;gap:40px;align-items:center;padding:72px 24px 80px}
.hero h1{font-size:64px;margin:16px 0 18px}
.hero h1 em{color:var(--gold);font-style:normal}
.hero p.lead{font-size:19px;color:#d5dee6;max-width:540px;margin-bottom:30px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-photo{aspect-ratio:4/3;border-radius:14px;overflow:hidden}
.hero-photo img{width:100%;height:100%;object-fit:cover;display:block}
@media(max-width:880px){.hero .wrap{grid-template-columns:1fr}.hero h1{font-size:46px}.hero-photo{display:none}}

/* trust bar */
.trust{background:var(--navy);color:#fff}
.trust .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;padding:0}
.trust .t{display:flex;align-items:center;justify-content:center;gap:11px;padding:20px 12px;border-right:1px solid rgba(255,255,255,.1);font-weight:600;font-size:15px}
.trust .t:last-child{border-right:none}
.trust .t svg{width:24px;height:24px;stroke:var(--gold);stroke-width:1.8;fill:none;flex:none}
@media(max-width:760px){.trust .wrap{grid-template-columns:1fr 1fr}.trust .t{border-right:none;border-bottom:1px solid rgba(255,255,255,.1)}}

section{padding:78px 0}
.sec-head{text-align:center;max-width:660px;margin:0 auto 50px}
.sec-head h2{font-size:44px;margin:10px 0 14px;color:var(--navy)}
.sec-head p{color:var(--muted);font-size:17px}

.intro{background:var(--paper)}
.intro .wrap{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.intro h2{font-size:42px;color:var(--navy);margin-bottom:18px}
.intro p{margin-bottom:16px;font-size:16.5px;color:#3b4753}
.intro-photo{aspect-ratio:2/1;border-radius:14px;overflow:hidden}
.intro-photo img{width:100%;height:100%;object-fit:cover;display:block}
@media(max-width:820px){.intro .wrap{grid-template-columns:1fr}}

.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.svc{border:1px solid var(--line);border-radius:14px;padding:30px 26px;transition:.2s;background:#fff;position:relative;display:block}
.svc:hover{border-color:var(--accent);transform:translateY(-4px);box-shadow:0 14px 30px rgba(14,36,57,.08)}
.svc-ic{width:56px;height:56px;border-radius:12px;background:#fdeee7;display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.svc-ic svg{width:28px;height:28px;stroke:var(--accent);stroke-width:1.8;fill:none;stroke-linecap:round;stroke-linejoin:round}
.svc h3{font-size:23px;color:var(--navy);margin-bottom:8px}
.svc p{font-size:15px;color:var(--muted);margin-bottom:14px}
.svc .more{font-weight:600;color:var(--accent);font-size:14.5px;display:inline-flex;align-items:center;gap:6px}
@media(max-width:820px){.svc-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.svc-grid{grid-template-columns:1fr}}
.svc-more{text-align:center;margin-top:42px}

.why{background:var(--navy);color:#fff}
.why .sec-head h2{color:#fff}
.why .sec-head p{color:#aebccb}
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:26px}
.why-c{text-align:center}
.why-ic{width:64px;height:64px;margin:0 auto 16px;border-radius:50%;background:rgba(242,165,28,.14);display:flex;align-items:center;justify-content:center}
.why-ic svg{width:30px;height:30px;stroke:var(--gold);stroke-width:1.7;fill:none;stroke-linecap:round;stroke-linejoin:round}
.why-c h3{font-size:20px;margin-bottom:9px}
.why-c p{color:#aebccb;font-size:14.5px}
@media(max-width:820px){.why-grid{grid-template-columns:1fr 1fr}}

.makes{background:var(--paper);text-align:center}
.makes-strip{display:flex;flex-wrap:wrap;justify-content:center;gap:12px;max-width:900px;margin:0 auto}
.make{background:#fff;border:1px solid var(--line);border-radius:40px;padding:9px 20px;font-weight:600;font-size:15px;color:var(--navy)}
.makes .btn{margin-top:34px}

.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.rev{border:1px solid var(--line);border-radius:14px;padding:28px 26px;background:#fff}
.stars{display:flex;gap:3px;margin-bottom:14px}
.stars svg{width:20px;height:20px;fill:var(--gold);stroke:none}
.rev p{font-size:15.5px;color:#3b4753;margin-bottom:16px;font-style:italic}
.rev b{font-weight:600;color:var(--navy);font-style:normal}
@media(max-width:820px){.rev-grid{grid-template-columns:1fr}}

.parts{text-align:center;padding:54px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.parts .eyebrow{display:block;margin-bottom:22px}
.parts-strip{display:flex;flex-wrap:wrap;justify-content:center;gap:16px 40px;align-items:center}
.part{font-family:'Barlow Condensed';font-weight:700;font-size:26px;text-transform:uppercase;color:#9aa4ae;letter-spacing:.02em}

.locate{background:linear-gradient(135deg,#0b1e30,#123454);color:#fff}
.locate .wrap{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center}
.locate h2{font-size:42px;margin-bottom:20px}
.locate .li{display:flex;gap:14px;align-items:flex-start;margin-bottom:16px;font-size:16px;color:#d5dee6}
.locate .li svg{width:24px;height:24px;stroke:var(--gold);stroke-width:1.7;fill:none;flex:none;margin-top:2px}
.locate .li b{color:#fff;font-weight:600;display:block}
.locate .btn{margin-top:12px}
.map{aspect-ratio:5/4;border-radius:14px;overflow:hidden}
.map iframe{width:100%;height:100%;border:0;border-radius:14px}
@media(max-width:820px){.locate .wrap{grid-template-columns:1fr}}

/* inner page hero */
.phero{background:linear-gradient(135deg,#0b1e30 0%,#123454 60%,#0e2439 100%);color:#fff;padding:52px 0 56px;position:relative;overflow:hidden}
.phero::before{content:"";position:absolute;inset:0;background-image:linear-gradient(115deg,transparent 62%,rgba(226,88,43,.2) 63%,rgba(226,88,43,.2) 68%,transparent 69%);opacity:.6}
.phero .wrap{position:relative}
.crumb{font-size:13.5px;color:#9fb1c2;margin-bottom:8px}.crumb a:hover{color:#fff}.crumb span{color:var(--gold)}

.layout{display:grid;grid-template-columns:1fr 340px;gap:52px;padding:60px 0}
@media(max-width:920px){.layout{grid-template-columns:1fr;gap:40px}}
.body h1{font-size:38px;color:var(--navy);margin-bottom:16px}
.body h2{font-size:32px;color:var(--navy);margin:34px 0 14px}
.body h2:first-child{margin-top:0}
.body p{margin-bottom:16px;font-size:16.5px;color:#3b4753}
.body strong{color:var(--ink);font-weight:600}
.body ul{margin:0 0 18px 2px;padding-left:20px}
.body li{font-size:16.5px;color:#3b4753;margin-bottom:8px}

.highlight{background:#fdeee7;border-left:4px solid var(--accent);border-radius:0 12px 12px 0;padding:24px 28px;margin:26px 0}
.highlight h3{font-size:22px;color:var(--accent-dark);margin-bottom:8px}
.highlight p{margin-bottom:0;font-size:15.5px;color:#5c3a2e}

.signs{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:22px 0 6px}
.sign{display:flex;gap:12px;align-items:flex-start;background:var(--paper);border-radius:10px;padding:16px 18px}
.sign svg{width:22px;height:22px;stroke:var(--accent);stroke-width:2;fill:none;flex:none;margin-top:2px}
.sign b{font-weight:600;color:var(--navy);font-size:15px}
@media(max-width:520px){.signs{grid-template-columns:1fr}}

.steps{margin:20px 0}
.step{display:flex;gap:18px;align-items:flex-start;padding:16px 0;border-bottom:1px solid var(--line)}
.step .n{flex:none;width:40px;height:40px;border-radius:50%;background:var(--navy);color:var(--gold);font-family:'Barlow Condensed';font-weight:700;font-size:22px;display:flex;align-items:center;justify-content:center}
.step b{font-weight:600;color:var(--navy);font-size:17px;display:block;margin-bottom:2px}
.step p{margin:0;font-size:15px;color:var(--muted)}

/* sidebar */
aside .card{border:1px solid var(--line);border-radius:14px;padding:24px;margin-bottom:22px}
aside .card.dark{background:var(--navy);color:#fff;border-color:var(--navy)}
aside h3{font-family:'Barlow Condensed';text-transform:uppercase;font-size:20px;color:var(--navy);margin-bottom:16px;letter-spacing:.03em}
aside .card.dark h3{color:#fff}
.svc-list a{display:flex;align-items:center;justify-content:space-between;padding:11px 0;border-bottom:1px solid var(--line);font-weight:500;font-size:15px;color:var(--ink);transition:.15s}
.svc-list a:last-child{border-bottom:none}
.svc-list a:hover{color:var(--accent);padding-left:6px}
.svc-list a.on{color:var(--accent);font-weight:600}
.card.dark p{color:#aebccb;font-size:14.5px;margin-bottom:16px}
.card.dark .num{font-family:'Barlow Condensed';font-size:30px;color:#fff;font-weight:700;display:block;margin-bottom:4px}
.card.dark .hours{font-size:13.5px;color:#9fb1c2;margin-top:14px}

/* related + cta */
.related{background:var(--paper);padding:56px 0}
.related .sec-head{text-align:center;margin-bottom:34px}
.related h2{font-size:34px;color:var(--navy)}
.rel-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.rel{background:#fff;border:1px solid var(--line);border-radius:12px;padding:24px;transition:.2s;display:block}
.rel:hover{border-color:var(--accent);transform:translateY(-3px)}
.rel b{font-family:'Barlow Condensed';text-transform:uppercase;font-size:20px;color:var(--navy);display:block;margin-bottom:5px}
.rel p{font-size:14px;color:var(--muted)}
@media(max-width:720px){.rel-grid{grid-template-columns:1fr}}
.cta{background:linear-gradient(135deg,#0b1e30,#123454);color:#fff;text-align:center;padding:60px 24px}
.cta h2{font-size:38px;margin-bottom:12px}
.cta p{color:#d5dee6;font-size:17px;margin-bottom:26px}
.cta .btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* hub grid (Services / Car Care) */
.hub-hero{background:linear-gradient(135deg,#0b1e30 0%,#123454 60%,#0e2439 100%);color:#fff;padding:56px 0;text-align:center}
.hub-hero h1{font-size:52px;margin:12px 0 14px}
.hub-hero p{font-size:18px;color:#d5dee6;max-width:640px;margin:0 auto}
.hub-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;padding:60px 0}
@media(max-width:820px){.hub-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.hub-grid{grid-template-columns:1fr}}

/* contact page */
.contact-grid{display:grid;grid-template-columns:360px 1fr;gap:40px;padding:56px 0}
@media(max-width:820px){.contact-grid{grid-template-columns:1fr;gap:32px}}
.info-row{display:flex;gap:14px;align-items:flex-start;margin-bottom:18px}
.info-row svg{width:24px;height:24px;stroke:var(--accent);stroke-width:1.7;fill:none;flex:none;margin-top:2px}
.info-row b{display:block;color:var(--navy);font-weight:600;font-size:15px}
.info-row span,.info-row a{color:var(--muted);font-size:15px}
.info-row a:hover{color:var(--accent)}
.field{margin-bottom:16px}
.field label{display:block;font-size:14px;font-weight:600;color:var(--navy);margin-bottom:6px}
.field input,.field select,.field textarea{width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:8px;font-family:inherit;font-size:15px;color:var(--ink);background:#fff}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--accent)}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:520px){.field-row{grid-template-columns:1fr}}
.map-full{width:100%;height:420px;border:0;display:block}

/* WS Form (Contact page appointment form) — brand-match via WS Form's
   documented CSS hooks (wsf-label / wsf-field / wsf-button / wsf-help),
   so this applies automatically without touching the form in WS Form's
   own builder. See https://wsform.com/knowledgebase/styling-forms-with-css/ */
.wsf-form{font-family:'Inter',system-ui,sans-serif}
.wsf-form .wsf-field-wrapper .wsf-label{display:block;font-family:inherit;font-size:14px;font-weight:600;color:var(--navy);margin-bottom:6px;text-transform:none;letter-spacing:normal}
.wsf-form .wsf-field-wrapper .wsf-field{width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:8px;font-family:inherit;font-size:15px;color:var(--ink);background:#fff;box-shadow:none}
.wsf-form .wsf-field-wrapper .wsf-field:focus{outline:none;border-color:var(--accent)}
.wsf-form .wsf-field-wrapper .wsf-field::placeholder{color:var(--muted);opacity:1}
.wsf-form .wsf-field-wrapper .wsf-help{color:var(--muted);font-size:13px}
.wsf-form .wsf-field-wrapper .wsf-button{display:inline-flex;align-items:center;gap:9px;font-family:'Inter',system-ui,sans-serif;font-weight:600;font-size:15px;padding:14px 26px;border-radius:8px;border:2px solid transparent;background:var(--accent);color:#fff;cursor:pointer;transition:.2s}
.wsf-form .wsf-field-wrapper .wsf-button:hover{background:var(--accent-dark);color:#fff}

/* footer */
.site-footer,footer.site-footer{background:var(--ink);color:#9aa8b5;font-size:14.5px;padding:52px 0 26px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;padding-bottom:36px;border-bottom:1px solid rgba(255,255,255,.1)}
.site-footer h4{font-family:'Barlow Condensed';text-transform:uppercase;letter-spacing:.08em;color:#fff;font-size:18px;margin-bottom:16px}
.site-footer a:hover{color:#fff}.site-footer ul{list-style:none;margin:0;padding:0}.site-footer li{margin-bottom:9px}
.foot-logo b{font-family:'Barlow Condensed';font-size:26px;color:#fff;text-transform:uppercase;display:block;line-height:1}
.foot-bot{padding-top:22px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px;font-size:13px;color:#6f7d8a}
@media(max-width:720px){.foot-grid{grid-template-columns:1fr 1fr}}
