/* At Your Door Mobile RV Repair — self-contained styles */
:root{
  --orange:#d9622b; --orange-lt:#f07b3c;
  --slate:#2a323c; --slate-dk:#1e242c;
  --tan:#d8c3a0; --tan-lt:#e8d9bd;
  --cream:#f7f3ec; --ink:#23272d; --muted:#5c6470;
  --white:#ffffff;
  --shadow:0 14px 40px rgba(30,36,44,.16);
  --radius:16px;
  --maxw:1180px;
  --disp:'Oswald', system-ui, sans-serif;
  --body:'Barlow', system-ui, sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--body);color:var(--ink);background:var(--cream);line-height:1.6;-webkit-font-smoothing:antialiased}
img,svg{max-width:100%;display:block}
a{color:inherit}
h1,h2,h3{font-family:var(--disp);line-height:1.08;margin:0 0 .4em;font-weight:700;letter-spacing:.5px;text-transform:uppercase}
h1{font-size:clamp(2.1rem,5.4vw,4rem)}
h2{font-size:clamp(1.6rem,3.4vw,2.6rem)}
h3{font-size:1.15rem;letter-spacing:.6px}
p{margin:0 0 1rem}
.container{width:min(var(--maxw),92%);margin-inline:auto}
.eyebrow{font-family:var(--disp);text-transform:uppercase;letter-spacing:3px;font-size:.8rem;font-weight:600;color:var(--orange-lt);margin:0 0 .6rem}
.eyebrow--dark{color:var(--orange)}

/* Buttons */
.btn{display:inline-block;background:var(--orange);color:#fff;font-family:var(--disp);font-weight:600;letter-spacing:1px;text-transform:uppercase;text-decoration:none;padding:.8rem 1.5rem;border-radius:10px;border:2px solid var(--orange);cursor:pointer;transition:transform .15s ease,background .2s ease,box-shadow .2s ease;font-size:.92rem}
.btn:hover{background:var(--orange-lt);border-color:var(--orange-lt);transform:translateY(-2px);box-shadow:0 10px 24px rgba(217,98,43,.35)}
.btn--lg{padding:1rem 1.9rem;font-size:1rem}
.btn--sm{padding:.55rem 1.05rem;font-size:.82rem}
.btn--ghost{background:transparent;color:var(--cream);border-color:rgba(255,255,255,.55)}
.btn--ghost:hover{background:rgba(255,255,255,.12);border-color:#fff;color:#fff}
.section--tan .btn--ghost,.section:not(.section--dark) .btn--ghost{color:var(--slate);border-color:var(--slate)}

/* Header */
.site-header{position:sticky;top:0;z-index:50;background:rgba(247,243,236,.92);backdrop-filter:blur(10px);border-bottom:1px solid rgba(42,50,60,.1);transition:box-shadow .25s ease}
.site-header.scrolled{box-shadow:0 6px 24px rgba(30,36,44,.12)}
.nav{display:flex;align-items:center;justify-content:space-between;padding:.7rem 0;gap:1rem}
.brand{display:flex;align-items:center;gap:.6rem;text-decoration:none;color:var(--slate)}
.brand__mark{flex:none}
.brand__text{font-family:var(--disp);font-weight:700;font-size:1.15rem;line-height:1;text-transform:uppercase;letter-spacing:1px;display:flex;flex-direction:column}
.brand__text small{font-size:.62rem;letter-spacing:2px;color:var(--orange);font-weight:600;margin-top:2px}
.brand__text--light{color:var(--cream)}
.brand__text--light small{color:var(--orange-lt)}
.nav__links{display:flex;align-items:center;gap:1.4rem}
.nav__links a{text-decoration:none;font-weight:600;font-size:.95rem;color:var(--slate);transition:color .2s}
.nav__links a:hover{color:var(--orange)}
.nav__links .nav__portal{color:var(--orange);border:1.5px solid var(--orange);padding:.42rem .85rem;border-radius:8px}
.nav__links .nav__portal:hover{background:var(--orange);color:#fff}
.nav__links .btn{color:#fff}
.nav__toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.nav__toggle span{width:26px;height:3px;background:var(--slate);border-radius:3px;transition:.25s}
.nav__mobile{display:none;flex-direction:column;background:var(--cream);border-bottom:1px solid rgba(42,50,60,.1)}
.nav__mobile a{padding:.85rem 4%;text-decoration:none;color:var(--slate);font-weight:600;border-top:1px solid rgba(42,50,60,.08)}
.nav__mobile.open{display:flex}

/* Hero */
.hero{position:relative;color:var(--cream);overflow:hidden;isolation:isolate}
.hero__bg{position:absolute;inset:0;z-index:-1}
.hero__bg svg{width:100%;height:100%}
.hero__inner{padding:5.5rem 0 5rem;max-width:760px}
.hero h1 span{color:var(--orange-lt)}
.hero__sub{font-size:1.18rem;color:#e7e2d6;max-width:600px}
.hero__cta{display:flex;flex-wrap:wrap;gap:.9rem;margin:1.6rem 0 1.2rem}
.hero__trust{font-size:.92rem;color:var(--tan-lt);letter-spacing:.3px;margin:0}

/* Trust bar */
.trustbar{background:var(--slate-dk);color:var(--cream)}
.trustbar__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;padding:1.4rem 0;text-align:center}
.trustbar__grid div{display:flex;flex-direction:column}
.trustbar__grid strong{font-family:var(--disp);color:var(--orange-lt);font-size:1.25rem;letter-spacing:1px}
.trustbar__grid span{font-size:.82rem;color:var(--tan)}

/* Sections */
.section{padding:4.5rem 0}
.section--dark{background:var(--slate);color:var(--cream)}
.section--tan{background:var(--tan-lt)}
.section__head{max-width:680px;margin:0 auto 2.6rem;text-align:center}
.section__lead{color:var(--muted);font-size:1.05rem}
.section--dark .section__lead{color:var(--tan-lt)}

/* Grid + cards */
.grid{display:grid;gap:1.3rem}
.grid--3{grid-template-columns:repeat(3,1fr)}
.card{background:#fff;border:1px solid rgba(42,50,60,.08);border-radius:var(--radius);padding:1.6rem;box-shadow:0 6px 18px rgba(30,36,44,.06);transition:transform .2s ease,box-shadow .2s ease,border-color .2s}
.card:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:rgba(217,98,43,.35)}
.card__icon{display:inline-flex;align-items:center;justify-content:center;width:50px;height:50px;border-radius:12px;background:linear-gradient(135deg,var(--orange),var(--orange-lt));margin-bottom:.9rem}
.card__icon svg{width:26px;height:26px;fill:none;stroke:#fff;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.card p{color:var(--muted);margin:0;font-size:.96rem}
.card--accent{background:var(--slate);color:var(--cream)}
.card--accent p{color:var(--tan-lt)}
.card--accent .card__icon{background:rgba(247,243,236,.14)}

/* Why */
.why{display:grid;grid-template-columns:1.05fr .95fr;gap:2.6rem;align-items:center}
.why__copy p{color:var(--tan-lt)}
.check{list-style:none;padding:0;margin:0 0 1.6rem;display:grid;gap:.6rem}
.check li{position:relative;padding-left:2rem;color:var(--cream);font-weight:500}
.check li::before{content:"";position:absolute;left:0;top:3px;width:1.2rem;height:1.2rem;border-radius:50%;background:var(--orange);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 12l5 5 9-11'/%3E%3C/svg%3E");background-size:70%;background-position:center;background-repeat:no-repeat}
.why__art svg{border-radius:var(--radius);box-shadow:var(--shadow);background:var(--slate-dk)}
.why__tools{transform-origin:center;animation:wiggle 3.5s ease-in-out infinite}
@keyframes wiggle{0%,100%{transform:rotate(0)}50%{transform:rotate(-8deg)}}

/* Steps */
.steps{list-style:none;padding:0;margin:0 0 2.4rem;display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;counter-reset:s}
.step{background:#fff;border-radius:var(--radius);padding:1.5rem;border:1px solid rgba(42,50,60,.08);box-shadow:0 6px 18px rgba(30,36,44,.06)}
.step__num{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:50%;background:var(--slate);color:var(--orange-lt);font-family:var(--disp);font-weight:700;font-size:1.2rem;margin-bottom:.8rem}
.step p{color:var(--muted);margin:0;font-size:.94rem}
.showcase__panel{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.showcase__panel svg{width:100%;height:auto}

/* Quotes */
.quote{background:#fff;border-radius:var(--radius);padding:1.7rem;box-shadow:0 6px 18px rgba(30,36,44,.07);border-left:4px solid var(--orange);margin:0}
.quote blockquote{margin:0 0 1rem;font-size:1.02rem;color:var(--ink);font-style:italic}
.quote figcaption{font-family:var(--disp);font-weight:600;letter-spacing:1px;color:var(--slate);text-transform:uppercase;font-size:.85rem}

/* CTA band */
.ctaband{background:linear-gradient(120deg,var(--orange),var(--orange-lt));color:#fff;padding:3.4rem 0;text-align:center}
.ctaband h2{color:#fff}
.ctaband p{color:rgba(255,255,255,.92);font-size:1.1rem}
.ctaband .ctaband__inner{max-width:640px;margin-inline:auto}
.ctaband .hero__cta{justify-content:center}
.ctaband .btn{background:#fff;color:var(--orange);border-color:#fff}
.ctaband .btn:hover{background:var(--slate);color:#fff;border-color:var(--slate);box-shadow:0 10px 24px rgba(30,36,44,.3)}
.ctaband .btn--ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.7)}
.ctaband .btn--ghost:hover{background:rgba(255,255,255,.15);color:#fff}

/* FAQ */
.faq{max-width:780px;margin-inline:auto}
.faq__list{display:grid;gap:.8rem}
.faq__item{background:#fff;border:1px solid rgba(42,50,60,.1);border-radius:12px;padding:.3rem 1.2rem;box-shadow:0 4px 14px rgba(30,36,44,.05)}
.faq__item summary{cursor:pointer;font-family:var(--disp);font-weight:600;letter-spacing:.5px;padding:.9rem 0;list-style:none;position:relative;padding-right:2rem;text-transform:uppercase;font-size:1rem}
.faq__item summary::-webkit-details-marker{display:none}
.faq__item summary::after{content:"+";position:absolute;right:0;top:.7rem;font-size:1.5rem;color:var(--orange);transition:transform .2s}
.faq__item[open] summary::after{transform:rotate(45deg)}
.faq__item p{color:var(--muted);margin:0 0 1rem}

/* Contact */
.contact{display:grid;grid-template-columns:1fr 1fr;gap:2.6rem;align-items:start}
.contact__copy p{color:var(--tan-lt)}
.contact__list{list-style:none;padding:0;margin:1.2rem 0;display:grid;gap:.65rem}
.contact__list a{color:var(--orange-lt);text-decoration:none;font-weight:600}
.contact__list a:hover{text-decoration:underline}
.contact__note{font-size:.85rem;color:var(--tan);font-style:italic}
.contact__form{background:#fff;border-radius:var(--radius);padding:1.8rem;box-shadow:var(--shadow);display:grid;gap:.9rem}
.contact__form label{display:flex;flex-direction:column;font-weight:600;color:var(--slate);font-size:.9rem;gap:.35rem}
.contact__form input,.contact__form textarea{font-family:var(--body);font-size:1rem;padding:.7rem .85rem;border:1.5px solid rgba(42,50,60,.2);border-radius:9px;background:var(--cream)}
.contact__form input:focus,.contact__form textarea:focus{outline:none;border-color:var(--orange)}
.contact__formnote{font-size:.8rem;color:var(--muted);margin:0;font-style:italic}

/* Footer */
.footer{background:var(--slate-dk);color:var(--tan-lt);padding:3rem 0 1.4rem}
.footer__inner{display:flex;flex-wrap:wrap;justify-content:space-between;gap:2rem;padding-bottom:2rem;border-bottom:1px solid rgba(247,243,236,.12)}
.footer__brand{max-width:340px}
.footer__brand p{color:var(--tan);font-size:.95rem;margin-top:.6rem}
.footer__links{display:flex;flex-wrap:wrap;gap:1.2rem;align-content:start}
.footer__links a{text-decoration:none;color:var(--tan-lt);font-weight:500}
.footer__links a:hover{color:var(--orange-lt)}
.footer__bottom{display:flex;flex-wrap:wrap;justify-content:space-between;gap:.6rem;padding-top:1.4rem;font-size:.85rem;color:var(--tan)}
.footer__bottom a{color:var(--orange-lt);text-decoration:none}
.footer__bottom a:hover{text-decoration:underline}

/* Mobile bar */
.mobilebar{display:none;position:fixed;bottom:0;left:0;right:0;z-index:60;background:var(--slate);padding:.6rem;gap:.6rem;box-shadow:0 -6px 20px rgba(30,36,44,.3)}
.mobilebar__btn{flex:1;text-align:center;text-decoration:none;font-family:var(--disp);font-weight:600;letter-spacing:1px;text-transform:uppercase;padding:.85rem;border-radius:10px;font-size:.95rem}
.mobilebar__btn--call{background:#fff;color:var(--slate)}
.mobilebar__btn--quote{background:var(--orange);color:#fff}

/* Reveal */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* Intro animation */
.intro{position:fixed;inset:0;z-index:1000;background:linear-gradient(160deg,#2a323c,#1e242c);display:flex;align-items:center;justify-content:center;flex-direction:column;transition:opacity .5s ease,visibility .5s}
.intro.hide{opacity:0;visibility:hidden;pointer-events:none}
.intro__skip{position:absolute;top:1.2rem;right:1.2rem;background:rgba(247,243,236,.15);color:var(--cream);border:1px solid rgba(247,243,236,.3);border-radius:8px;padding:.5rem 1.1rem;font-family:var(--disp);letter-spacing:1px;text-transform:uppercase;cursor:pointer;font-size:.8rem}
.intro__skip:hover{background:rgba(247,243,236,.28)}
.intro__stage{width:min(520px,86vw);text-align:center}
.intro__scene{width:100%;overflow:visible}
.intro__rv{transform:translateX(-420px);animation:rvDrive 1.5s cubic-bezier(.22,.7,.3,1) forwards}
@keyframes rvDrive{0%{transform:translateX(-420px)}100%{transform:translateX(110px)}}
.intro__awning-cloth{transform:scaleY(0);transform-origin:top;animation:awning .6s ease forwards 1.4s}
@keyframes awning{to{transform:scaleY(1);d:path("M60 96 L180 96 L172 124 L68 124 Z")}}
.intro__awning-cloth{animation:awningGrow .6s ease forwards 1.4s}
@keyframes awningGrow{0%{transform:scaleY(0)}100%{transform:scaleY(1)}}
.intro__road{animation:dash 1.5s linear infinite}
@keyframes dash{to{stroke-dashoffset:-52}}
.intro__word{margin-top:1.4rem;opacity:0;transform:translateY(14px);animation:wordIn .6s ease forwards 1.7s}
.intro__word span{display:block;font-family:var(--disp);font-weight:700;font-size:clamp(1.8rem,6vw,2.8rem);color:var(--cream);letter-spacing:2px;text-transform:uppercase}
.intro__word small{display:block;font-family:var(--disp);letter-spacing:5px;color:var(--orange-lt);font-size:.85rem;text-transform:uppercase;margin-top:4px}
@keyframes wordIn{to{opacity:1;transform:none}}

/* Responsive */
@media (max-width:900px){
  .grid--3{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:repeat(2,1fr)}
  .why,.contact{grid-template-columns:1fr}
  .why__art{order:-1}
}
@media (max-width:680px){
  .nav__links{display:none}
  .nav__toggle{display:flex}
  .grid--3{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr}
  .trustbar__grid{grid-template-columns:repeat(2,1fr);gap:1rem}
  .mobilebar{display:flex}
  main{padding-bottom:0}
  body{padding-bottom:72px}
  .hero__inner{padding:3.5rem 0 3rem}
}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
  .intro{display:none!important}
}
