@import url("../fonts/gf.css");
/* Mansfield Web Dev - warm South DFW local web studio. Light theme, navy + warm orange.
   Mobile-first: every multi-column grid stacks by default and only gains columns at
   min-width:821px (never set grid-template-columns inline). */

:root{
  --bg:#ffffff; --soft:#f3f7fc; --cream:#fbf5ec; --panel:#ffffff;
  --navy:#16314f; --navy-deep:#102640; --foot:#112338;
  --ink:#16314f; --text:#46566b; --muted:#6c7d93; --faint:#8a98ab;
  --orange:#ee8a1e; --orange-d:#d6760b; --orange-soft:#fdf0df;
  --blue:#3f6fa3; --blue-d:#2f5882; --blue-soft:#e9f1fa;
  --line:#e6ecf3; --line2:#d6deea;
  --display:"Poppins",system-ui,-apple-system,sans-serif;
  --body:"Inter",system-ui,-apple-system,sans-serif;
  --wrap:1180px; --radius:14px;
  --shadow:0 18px 44px -28px rgba(18,40,72,.40);
  --shadow-sm:0 8px 22px -16px rgba(18,40,72,.32);
}
@supports(color:color(display-p3 1 1 1)){@media(color-gamut:p3){:root{
  --orange:color(display-p3 .886 .55 .14);--orange-d:color(display-p3 .80 .46 .07);
  --blue:color(display-p3 .27 .44 .63);--navy:color(display-p3 .10 .19 .31)}}}
*{box-sizing:border-box;margin:0}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);font-family:var(--body);font-size:17px;line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
.wrap{max-width:var(--wrap);margin-inline:auto;padding-inline:24px}
a{color:inherit;text-decoration:none;transition:color .18s ease}
img{max-width:100%;display:block}
h1,h2,h3,h4{font-family:var(--display);color:var(--navy);line-height:1.12;letter-spacing:-.01em;font-weight:700}
.skip{position:absolute;left:-999px}.skip:focus{left:16px;top:16px;background:var(--orange);color:#fff;padding:8px 14px;border-radius:8px;z-index:99}

/* eyebrow / labels */
.eyebrow{font-family:var(--display);font-weight:600;font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--orange-d);margin-bottom:14px}
.eyebrow--blue{color:var(--blue-d)}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;font-family:var(--display);font-weight:600;font-size:.95rem;padding:13px 24px;border-radius:10px;border:1.5px solid transparent;line-height:1;cursor:pointer;transition:background .18s,border-color .18s,color .18s,transform .18s,box-shadow .18s}
.btn--solid{background:var(--orange);color:#fff;box-shadow:0 10px 22px -12px rgba(214,118,11,.7)}
.btn--solid:hover{background:var(--orange-d);transform:translateY(-2px)}
.btn--navy{background:var(--navy);color:#fff}
.btn--navy:hover{background:var(--navy-deep);transform:translateY(-2px)}
.btn--ghost{background:#fff;color:var(--navy);border-color:var(--line2)}
.btn--ghost:hover{border-color:var(--blue);color:var(--blue-d);transform:translateY(-2px)}
.btn--lg{padding:16px 30px;font-size:1.02rem}
.btn--full{width:100%}
.btn i{font-size:.92em}

/* ===== NAV ===== */
.nav{position:sticky;top:0;z-index:40;background:rgba(255,255,255,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav__row{max-width:1300px;margin-inline:auto;padding:0 24px;height:74px;display:flex;align-items:center;justify-content:space-between;gap:20px}
.brand{display:flex;align-items:center;gap:11px}
.brand__mark{height:38px;width:auto;display:block}
.brand__wm{display:flex;flex-direction:column;line-height:1.02}
.brand__wm .wm1{font-family:var(--display);color:var(--navy);font-weight:800;font-size:1.04rem;letter-spacing:.01em}
.brand__wm .wm2{font-family:var(--display);color:var(--orange-d);font-weight:600;font-size:.62rem;letter-spacing:.22em;text-transform:uppercase}
.nav__links{display:flex;align-items:center;gap:28px;font-family:var(--display);font-weight:500;font-size:.95rem;color:var(--navy)}
.nav__links a:not(.btn){color:var(--navy)}
.nav__links a:not(.btn):hover{color:var(--orange-d)}
.nav__toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.nav__toggle span{width:24px;height:2px;background:var(--navy);display:block;border-radius:2px}

/* ===== HERO (free-form blended, light) ===== */
.hero{position:relative;overflow:hidden;background:
  radial-gradient(120% 90% at 88% 4%,var(--blue-soft) 0,transparent 52%),
  linear-gradient(180deg,#ffffff 0,#f6f9fd 100%)}
.hero__grid{display:grid;gap:30px;align-items:center;padding-block:46px 56px}
.hero__copy{max-width:600px}
.hero h1{font-size:clamp(2.15rem,5vw,3.5rem);font-weight:800;color:var(--navy);letter-spacing:-.02em}
.hero h1 em{font-style:normal;color:var(--orange)}
.hero__lede{color:var(--text);font-size:clamp(1.04rem,1.4vw,1.18rem);margin-top:20px;max-width:50ch}
.hero__cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:28px}
.hero__trust{display:flex;flex-wrap:wrap;gap:10px 18px;margin-top:26px;font-family:var(--display);font-weight:500;font-size:.84rem;color:var(--muted)}
.hero__trust span{display:inline-flex;align-items:center;gap:7px}
.hero__trust i{color:var(--orange-d)}
.hero__art{position:relative}
.hero__shot{width:100%;border-radius:18px;box-shadow:var(--shadow);border:1px solid var(--line);background:#fff}
.hero__tagnote{position:absolute;right:6%;bottom:-14px;font-family:"Poppins",cursive;font-style:italic;font-weight:600;color:var(--orange-d);font-size:.95rem;transform:rotate(-4deg);background:#fff;padding:6px 12px;border-radius:10px;box-shadow:var(--shadow-sm);border:1px solid var(--orange-soft)}

/* ===== TRUST STRIP ===== */
.trust{background:var(--navy);color:#fff}
.trust__grid{display:grid;gap:22px;padding-block:26px}
.trust__item{display:flex;align-items:flex-start;gap:13px}
.trust__ico{flex:none;width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.08);color:var(--orange);font-size:1.05rem}
.trust__item b{display:block;font-family:var(--display);font-weight:600;font-size:.86rem;letter-spacing:.04em;text-transform:uppercase;color:#fff}
.trust__item span{font-size:.88rem;color:#bcc9da}

/* ===== SECTION SHELL ===== */
.sec{padding:74px 0}
.sec--soft{background:var(--soft)}
.sec--cream{background:var(--cream)}
.sec__head{max-width:640px;margin:0 auto 44px;text-align:center}
.sec__head h2{font-size:clamp(1.7rem,3.2vw,2.4rem);font-weight:700}
.sec__head h2 em{font-style:normal;color:var(--orange)}
.sec__head p{margin-top:14px;color:var(--text)}
.h2{font-size:clamp(1.7rem,3.2vw,2.4rem);font-weight:700;color:var(--navy)}
.h2 em{font-style:normal;color:var(--orange)}

/* ===== SERVICES (how we help) ===== */
.svcgrid{display:grid;gap:18px}
.svccard{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:28px 26px;transition:transform .2s,border-color .2s,box-shadow .2s}
.svccard:hover{transform:translateY(-4px);border-color:var(--line2);box-shadow:var(--shadow-sm)}
.svccard__ico{width:50px;height:50px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:var(--orange-soft);color:var(--orange-d);font-size:1.25rem;margin-bottom:18px}
.svccard h3{font-size:1.16rem;font-weight:600;margin-bottom:8px}
.svccard p{font-size:.95rem;color:var(--text)}
.svccard__more{display:inline-flex;align-items:center;gap:6px;margin-top:14px;font-family:var(--display);font-weight:600;font-size:.86rem;color:var(--blue-d)}
.svccard__more i{transition:transform .18s}
.svccard:hover .svccard__more i{transform:translateX(4px)}
.cardlink{position:absolute;inset:0;z-index:3;border-radius:inherit}
.cardlink:focus-visible{outline:2px solid var(--blue);outline-offset:3px}

/* ===== SIGNATURE: Local Trust Stack interactive ===== */
.stack{display:grid;gap:36px;align-items:center}
.stack__intro .eyebrow{margin-bottom:14px}
.stack__intro h2{font-size:clamp(1.6rem,3vw,2.25rem);font-weight:700}
.stack__intro p{margin-top:14px;color:var(--text)}
.stack__intro .stack__cta{margin-top:24px;display:flex;gap:14px;flex-wrap:wrap}
.stack__tool{background:#fff;border:1px solid var(--line2);border-radius:18px;box-shadow:var(--shadow);overflow:hidden}
.stack__bar{padding:18px 24px;border-bottom:1px solid var(--line);background:var(--navy);color:#fff;display:flex;align-items:center;justify-content:space-between;gap:12px}
.stack__bar b{font-family:var(--display);font-weight:600;font-size:.92rem}
.stack__bar span{font-family:var(--display);font-size:.78rem;color:#bcc9da}
.stack__rows{list-style:none;padding:8px 0;margin:0}
.stack__row{display:flex;align-items:center;gap:14px;width:100%;text-align:left;background:none;border:0;border-bottom:1px solid var(--line);padding:15px 24px;cursor:pointer;font:inherit;color:var(--navy);transition:background .15s}
.stack__row:last-child{border-bottom:0}
.stack__row:hover{background:var(--soft)}
.stack__check{flex:none;width:26px;height:26px;border-radius:8px;border:2px solid var(--line2);display:flex;align-items:center;justify-content:center;color:#fff;font-size:.8rem;transition:background .18s,border-color .18s}
.stack__row[aria-pressed="true"] .stack__check{background:var(--orange);border-color:var(--orange)}
.stack__row[aria-pressed="true"] .stack__check i{opacity:1}
.stack__check i{opacity:0;transition:opacity .15s}
.stack__txt b{display:block;font-family:var(--display);font-weight:600;font-size:1rem}
.stack__txt span{font-size:.85rem;color:var(--muted)}
.stack__meter{padding:20px 24px;background:var(--soft);border-top:1px solid var(--line)}
.stack__track{height:9px;border-radius:6px;background:var(--line2);overflow:hidden}
.stack__fill{height:100%;width:0;background:linear-gradient(90deg,var(--orange),var(--orange-d));border-radius:6px;transition:width .4s cubic-bezier(.2,.7,.3,1)}
.stack__verdict{margin-top:12px;font-family:var(--display);font-weight:600;font-size:.96rem;color:var(--navy)}
.stack__verdict span{color:var(--orange-d)}

/* ===== WHY CHOOSE ===== */
.why{display:grid;gap:38px;align-items:center}
.why__art{position:relative}
.why__photo{width:100%;border-radius:18px;box-shadow:var(--shadow);border:1px solid var(--line)}
.why__note{position:absolute;left:6%;bottom:-16px;font-family:"Poppins";font-style:italic;font-weight:600;color:#fff;background:var(--orange);font-size:.88rem;padding:9px 15px;border-radius:11px;box-shadow:var(--shadow-sm);transform:rotate(-3deg)}
.why h2{font-size:clamp(1.6rem,3vw,2.25rem);font-weight:700}
.why__list{list-style:none;padding:0;margin:24px 0 0;display:grid;gap:15px}
.why__list li{display:flex;gap:13px;align-items:flex-start;color:var(--text)}
.why__list i{flex:none;color:var(--orange-d);margin-top:4px}
.why__list b{color:var(--navy);font-weight:600;font-family:var(--display)}

/* ===== GROWTH PATH (Presence/Trust/Leads/Updates) ===== */
.path{display:grid;gap:18px;counter-reset:step}
.path__step{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px 24px}
.path__n{font-family:var(--display);font-weight:800;font-size:1rem;color:#fff;background:var(--navy);width:36px;height:36px;border-radius:9px;display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.path__step:nth-child(2) .path__n{background:var(--blue-d)}
.path__step:nth-child(3) .path__n{background:var(--orange-d)}
.path__step:nth-child(4) .path__n{background:var(--navy-deep)}
.path__step h3{font-size:1.1rem;font-weight:600;margin-bottom:7px}
.path__step p{font-size:.93rem;color:var(--text)}

/* ===== WORK GRID ===== */
.work__head{display:flex;justify-content:space-between;align-items:baseline;gap:16px;margin-bottom:30px;flex-wrap:wrap}
.work__more{font-family:var(--display);font-weight:600;font-size:.92rem;color:var(--blue-d);display:inline-flex;align-items:center;gap:7px}
.work__more i{transition:transform .18s}.work__more:hover i{transform:translateX(4px)}
.workgrid{display:grid;gap:20px}
.wcard{position:relative;display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:transform .2s,border-color .2s,box-shadow .2s}
.wcard:hover{transform:translateY(-4px);border-color:var(--line2);box-shadow:var(--shadow-sm)}
.wcard__shot{overflow:hidden;border-bottom:1px solid var(--line);background:var(--soft)}
.wcard__shot img{width:100%;aspect-ratio:16/10;object-fit:cover;object-position:top center}
.wcard figcaption{padding:16px 18px}
.wcard__tag{font-family:var(--display);font-weight:600;font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:var(--orange-d);display:block;margin-bottom:6px}
.wcard figcaption b{display:block;color:var(--navy);font-family:var(--display);font-weight:600;font-size:1.02rem;line-height:1.25}
.wcard figcaption p{font-size:.86rem;color:var(--muted);margin-top:5px}

/* ===== PROCESS TIMELINE ===== */
.steps{list-style:none;padding:0;margin:0;display:grid;gap:26px;position:relative}
.step{position:relative;display:flex;gap:18px;align-items:flex-start}
.step__n{flex:none;width:46px;height:46px;border-radius:50%;background:#fff;border:2px solid var(--orange);color:var(--orange-d);font-family:var(--display);font-weight:700;display:flex;align-items:center;justify-content:center;font-size:1.05rem}
.step h3{font-size:1.1rem;font-weight:600;margin-bottom:5px}
.step p{font-size:.93rem;color:var(--text)}

/* ===== CTA / CONTACT ===== */
.contact{display:grid;gap:38px;align-items:start}
.contact__pitch h2{font-size:clamp(1.7rem,3vw,2.3rem);font-weight:700}
.contact__pitch p{margin-top:14px;color:var(--text)}
.contact__lines{list-style:none;padding:0;margin:26px 0 0;display:grid;gap:16px}
.contact__lines li{display:flex;gap:14px;align-items:center}
.contact__lines i{flex:none;width:42px;height:42px;border-radius:10px;background:var(--orange-soft);color:var(--orange-d);display:flex;align-items:center;justify-content:center;font-size:1.05rem}
.contact__lines b{display:block;font-family:var(--display);font-weight:600;color:var(--navy);font-size:.78rem;letter-spacing:.06em;text-transform:uppercase}
.contact__lines a,.contact__lines span{color:var(--text)}
.form{display:grid;gap:15px;background:#fff;border:1px solid var(--line2);border-radius:18px;padding:30px;box-shadow:var(--shadow-sm)}
.form__row{display:grid;gap:15px}
.form label{display:grid;gap:7px;font-family:var(--display);font-size:.78rem;font-weight:600;letter-spacing:.03em;color:var(--navy)}
.form input,.form textarea,.form select{background:#fafcfe;border:1.5px solid var(--line2);border-radius:9px;padding:13px 14px;color:var(--navy);font:inherit;font-size:.96rem;font-family:var(--body);font-weight:400}
.form input:focus,.form textarea:focus,.form select:focus{outline:none;border-color:var(--orange);background:#fff;box-shadow:0 0 0 3px var(--orange-soft)}
.form__note{font-size:.86rem;margin-top:2px;font-family:var(--display);font-weight:500}
.form__note[data-state=ok]{color:#1c8a55}.form__note[data-state=err]{color:#c63c3c}
.hp{position:absolute!important;left:-9999px!important;width:1px;height:1px;overflow:hidden}
.form__fine{font-size:.78rem;color:var(--faint);margin-top:2px}

/* ===== FOOTER ===== */
.foot{background:var(--foot);color:#c7d2e0;padding:54px 0 30px}
.foot__top{display:grid;gap:30px;padding-bottom:34px;border-bottom:1px solid rgba(255,255,255,.1)}
.foot__brand{max-width:320px}
.foot__brand .brand__wm .wm1{color:#fff}.foot__brand .brand__wm .wm2{color:var(--orange)}
.foot__brand p{margin-top:14px;font-size:.9rem;color:#9fb0c4}
.foot__social{display:flex;gap:12px;margin-top:18px}
.foot__social a{width:38px;height:38px;border-radius:9px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.07);color:#c7d2e0;transition:background .18s,color .18s}
.foot__social a:hover{background:var(--orange);color:#fff}
.foot__col h4{font-family:var(--display);font-weight:600;color:#fff;font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;margin-bottom:14px}
.foot__col ul{list-style:none;padding:0;margin:0;display:grid;gap:9px}
.foot__col a{font-size:.92rem;color:#aebdce}.foot__col a:hover{color:#fff}
.foot__bottom{display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;align-items:center;padding-top:22px;font-size:.85rem;color:#8b9bb0}
.foot__attr a{color:var(--orange);font-weight:500}
.foot__attr a:hover{color:#fff}

/* ===== SUBPAGES ===== */
.phead{background:radial-gradient(120% 90% at 90% 0,var(--blue-soft) 0,transparent 55%),linear-gradient(180deg,#fff,#f6f9fd)}
.phead__in{padding-block:54px 40px}
.crumbs{font-family:var(--display);font-size:.8rem;font-weight:500;color:var(--muted);margin-bottom:18px}
.crumbs a{color:var(--blue-d)}.crumbs a:hover{color:var(--orange-d)}.crumbs span{color:var(--faint);margin:0 8px}
.phead h1{font-size:clamp(2rem,4.2vw,3rem);font-weight:800;max-width:20ch}
.phead .lede{margin-top:18px;color:var(--text);max-width:62ch;font-size:1.08rem}
.prose{max-width:72ch}
.prose h2{font-size:1.45rem;font-weight:700;margin:38px 0 12px}
.prose h3{font-size:1.12rem;font-weight:600;margin:26px 0 8px}
.prose p,.prose li{color:var(--text);margin-bottom:13px}
.prose ul{padding-left:22px;margin-bottom:14px}
.prose strong{color:var(--navy);font-weight:600}
.prose a{color:var(--blue-d);font-weight:500;text-decoration:underline;text-decoration-color:var(--line2)}
.prose a:hover{color:var(--orange-d)}

/* service detail layout */
.spv{display:grid;gap:40px;align-items:start;padding-bottom:10px}
.spv__main h2{font-size:1.45rem;font-weight:700;margin:34px 0 12px;color:var(--navy)}
.spv__main h2:first-child{margin-top:0}
.spv__main p{color:var(--text);margin-bottom:14px;max-width:64ch}
.spv__main strong{color:var(--navy);font-weight:600}
.spv__aside{background:var(--soft);border:1px solid var(--line2);border-radius:16px;padding:26px}
.spv__aside h3{font-family:var(--display);font-size:.74rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--orange-d);margin-bottom:16px}
.spv__aside ul{list-style:none;padding:0;display:grid;gap:11px;margin:0}
.spv__aside li{display:flex;gap:11px;color:var(--navy);font-size:.94rem;align-items:flex-start}
.spv__aside li i{color:var(--orange-d);margin-top:4px;font-size:.82rem}
.spv__aside .btn{margin-top:22px}
.spv__aside .aside-note{color:var(--muted);font-size:.84rem;margin-top:14px;line-height:1.5}
.deliver{display:grid;gap:0;border:1px solid var(--line);border-radius:14px;overflow:hidden;margin:6px 0}
.deliver div{padding:22px 22px;border-bottom:1px solid var(--line)}
.deliver h4{color:var(--navy);font-size:1rem;font-weight:600;margin-bottom:7px;display:flex;align-items:center;gap:10px}
.deliver h4 i{color:var(--orange-d);font-size:.92rem}
.deliver p{color:var(--text);font-size:.9rem;margin:0}
.signs{list-style:none;padding:0;margin:6px 0;display:grid;gap:10px}
.signs li{color:var(--text);padding-left:26px;position:relative}
.signs li::before{content:"\2192";position:absolute;left:0;color:var(--orange-d);font-weight:700}

/* FAQ */
.faq{border-top:1px solid var(--line);margin-top:8px}
.faq details{border-bottom:1px solid var(--line)}
.faq summary{cursor:pointer;list-style:none;padding:20px 38px 20px 2px;position:relative;color:var(--navy);font-family:var(--display);font-weight:600;font-size:1.05rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";position:absolute;right:8px;top:17px;color:var(--orange-d);font-weight:400;font-size:1.4rem;transition:transform .2s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{color:var(--text);padding:0 2px 22px;max-width:72ch;margin:0}

/* related */
.rel{display:grid;gap:16px;margin-top:8px}
.rel a{display:block;padding:22px;border:1px solid var(--line);border-radius:12px;background:#fff;transition:border-color .2s,transform .2s,box-shadow .2s}
.rel a:hover{border-color:var(--line2);transform:translateY(-3px);box-shadow:var(--shadow-sm)}
.rel .n{font-family:var(--display);color:var(--orange-d);font-size:.8rem;font-weight:700}
.rel b{display:block;color:var(--navy);font-family:var(--display);font-weight:600;font-size:1.1rem;margin:8px 0 6px}
.rel span.d{color:var(--muted);font-size:.88rem}

/* about values */
.values{display:grid;gap:0;border:1px solid var(--line);border-radius:14px;overflow:hidden;margin-top:6px;background:#fff}
.values div{padding:28px 26px;border-bottom:1px solid var(--line)}
.values h3{color:var(--navy);font-size:1.06rem;font-weight:600;margin-bottom:8px;display:flex;align-items:center;gap:10px}
.values h3 i{color:var(--orange-d)}
.values p{color:var(--text);font-size:.94rem}
.about__photo{width:100%;border-radius:16px;border:1px solid var(--line);box-shadow:var(--shadow-sm)}
.statbar{display:grid;gap:16px;margin:8px 0}
.statbar div{background:var(--soft);border:1px solid var(--line);border-radius:12px;padding:22px;text-align:center}
.statbar b{display:block;font-family:var(--display);font-weight:800;font-size:1.8rem;color:var(--navy)}
.statbar span{font-size:.86rem;color:var(--muted)}

/* reveal */
.js [data-reveal]{opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease}
.js [data-reveal].in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.js [data-reveal]{opacity:1!important;transform:none!important;transition:none!important}}
.uline{background:linear-gradient(currentColor,currentColor) no-repeat 0 100%/0 1px;transition:background-size .25s ease,color .18s ease}
.uline:hover{background-size:100% 1px}

/* ===== DESKTOP GRID COLUMNS (mobile-first: stacked by default) ===== */
@media(min-width:721px){
  .trust__grid{grid-template-columns:repeat(2,1fr);column-gap:30px}
  .svcgrid{grid-template-columns:repeat(2,1fr)}
  .path{grid-template-columns:repeat(2,1fr)}
  .workgrid{grid-template-columns:repeat(2,1fr)}
  .form__row{grid-template-columns:1fr 1fr}
  .statbar{grid-template-columns:repeat(3,1fr)}
}
@media(min-width:821px){
  .nav__row{padding:0 30px}.wrap{padding-inline:30px}
  .hero__grid{grid-template-columns:1.05fr .95fr;gap:50px;padding:64px 0 74px}
  .trust__grid{grid-template-columns:repeat(4,1fr)}
  .svcgrid{grid-template-columns:repeat(3,1fr)}
  .stack{grid-template-columns:.9fr 1.1fr;gap:54px}
  .why{grid-template-columns:1fr 1.05fr;gap:54px}
  .why--rev .why__art{order:2}
  .path{grid-template-columns:repeat(4,1fr)}
  .workgrid{grid-template-columns:repeat(3,1fr)}
  .steps{grid-template-columns:repeat(5,1fr);gap:24px}
  .steps::before{content:"";position:absolute;top:23px;left:8%;right:8%;height:2px;background:linear-gradient(90deg,transparent,var(--line2) 10%,var(--line2) 90%,transparent)}
  .step{flex-direction:column;text-align:center}
  .step__n{position:relative;z-index:1}
  .contact{grid-template-columns:.9fr 1.1fr;gap:54px}
  .spv{grid-template-columns:1.3fr .7fr;gap:50px}
  .spv__aside{position:sticky;top:96px}
  .deliver{grid-template-columns:1fr 1fr}.deliver div:nth-child(odd){border-right:1px solid var(--line)}
  .rel{grid-template-columns:repeat(3,1fr)}
  .values{grid-template-columns:repeat(3,1fr)}
  .values div{border-bottom:0;border-right:1px solid var(--line)}.values div:last-child{border-right:0}
  .foot__top{grid-template-columns:1.4fr 1fr 1fr 1fr}
  .workgrid--4{grid-template-columns:repeat(4,1fr)}
}
@media(min-width:1000px){.workgrid--gallery{grid-template-columns:repeat(3,1fr)}}

/* ===== MOBILE NAV ===== */
@media(max-width:820px){
  .nav__toggle{display:flex}
  .nav__links{position:absolute;top:74px;left:0;right:0;background:#fff;border-bottom:1px solid var(--line);flex-direction:column;align-items:stretch;gap:0;padding:8px 24px 18px;display:none;box-shadow:var(--shadow-sm)}
  .nav__links.is-open{display:flex}
  .nav__links a:not(.btn){padding:13px 0;border-bottom:1px solid var(--line)}
  .nav__links .btn{margin-top:12px}
  .hero__tagnote{position:static;display:inline-block;margin-top:16px;transform:none}
  .why__note{position:static;display:inline-block;margin-top:14px;transform:none}
  .sec{padding:54px 0}
}

/* ===== Before/After redesign slider (signature interactive) ===== */
.redo{display:grid;gap:34px;align-items:center}
.redo__copy .eyebrow{margin-bottom:14px}
.redo__copy h2{font-size:clamp(1.6rem,3vw,2.25rem);font-weight:700}
.redo__copy p{margin-top:14px;color:var(--text)}
.redo__pts{list-style:none;padding:0;margin:22px 0 0;display:grid;gap:12px}
.redo__pts li{display:flex;gap:12px;align-items:flex-start;color:var(--text)}
.redo__pts i{flex:none;color:var(--orange-d);margin-top:4px}
.redo__pts b{color:var(--navy);font-family:var(--display);font-weight:600}
.redo__cta{margin-top:24px}
.ba{position:relative;width:100%;aspect-ratio:16/10;border-radius:16px;overflow:hidden;border:1px solid var(--line2);box-shadow:var(--shadow);user-select:none;touch-action:pan-y;background:var(--soft)}
.ba__layer{position:absolute;inset:0}
.ba__layer img{width:100%;height:100%;object-fit:cover;display:block;pointer-events:none}
.ba__after{clip-path:inset(0 calc(100% - var(--pos,55%)) 0 0)}
.ba__tag{position:absolute;top:14px;font-family:var(--display);font-weight:600;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:#fff;background:rgba(16,38,64,.82);padding:6px 12px;border-radius:7px;backdrop-filter:blur(4px)}
.ba__tag--b{left:14px}
.ba__tag--a{right:14px;background:rgba(214,118,11,.92)}
.ba__line{position:absolute;top:0;bottom:0;left:var(--pos,55%);width:3px;background:#fff;transform:translateX(-1.5px);box-shadow:0 0 0 1px rgba(16,38,64,.12)}
.ba__grip{position:absolute;top:50%;left:var(--pos,55%);transform:translate(-50%,-50%);width:46px;height:46px;border-radius:50%;background:#fff;border:2px solid var(--orange);display:flex;align-items:center;justify-content:center;gap:3px;color:var(--orange-d);cursor:ew-resize;box-shadow:var(--shadow-sm);font-size:.8rem}
.ba__grip:focus-visible{outline:3px solid var(--blue);outline-offset:3px}
.ba__hint{text-align:center;color:var(--muted);font-size:.82rem;margin-top:12px;font-family:var(--display)}
@media(min-width:821px){.redo{grid-template-columns:.85fr 1.15fr;gap:50px}.redo--rev .redo__art{order:2}}
