:root{
	--blue:#1D74E8; --blue-strong:#155CC2; --blue-tint:#EAF3FE; --blue-tint2:#F1F7FE;
	--ink:#0F2742; --slate:#3D5066; --muted:#5E7286;
	--orange:#FF8A3C; --orange-deep:#D86A18; --peach:#FFF2E8;
	--teal:#13B59E; --teal-deep:#0A7A6B; --teal-tint:#E4F7F3;
	--paper:#F4F8FD; --white:#FFFFFF; --border:#E5ECF5;
	--sh-sm:0 6px 18px -10px rgba(21,92,194,.22);
	--sh:0 16px 40px -18px rgba(21,92,194,.30);
	--r:16px; --r-lg:22px;
	--maxw:1140px;
  }
  *{box-sizing:border-box;margin:0;padding:0}
  html{scroll-behavior:smooth}
  body{font-family:"Inter",system-ui,sans-serif;background:var(--white);color:var(--ink);
	-webkit-font-smoothing:antialiased;line-height:1.6}
  a{text-decoration:none;color:inherit}
  h1,h2,h3,.dh{font-family:"Plus Jakarta Sans",sans-serif;letter-spacing:-.02em;line-height:1.08}
  .wrap{max-width:var(--maxw);margin:0 auto;padding:0 20px}
  .eyebrow{font-weight:600;font-size:.72rem;letter-spacing:.15em;text-transform:uppercase;color:var(--blue)}
  
  /* buttons */
  .btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;font-family:"Plus Jakarta Sans";
	font-weight:700;font-size:.95rem;border-radius:999px;padding:.85rem 1.5rem;border:1.5px solid transparent;cursor:pointer;
	transition:transform .15s ease, box-shadow .15s ease, background .15s}
  .btn svg{width:18px;height:18px}
  .btn-primary{background:var(--orange);color:#3a1c05;box-shadow:0 12px 24px -12px rgba(255,138,60,.85)}
  .btn-primary:hover{transform:translateY(-2px)}
  .btn-blue{background:var(--blue);color:#fff;box-shadow:0 12px 24px -14px rgba(29,116,232,.9)}
  .btn-blue:hover{transform:translateY(-2px)}
  .btn-ghost{background:#fff;color:var(--blue);border-color:#cfe0f8}
  .btn-ghost:hover{border-color:var(--blue)}
  
  /* header */
  header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.85);backdrop-filter:blur(12px);border-bottom:1px solid var(--border)}
  .nav{display:flex;align-items:center;justify-content:space-between;height:68px}
  .brand{display:flex;align-items:center;gap:11px;font-family:"Plus Jakarta Sans";font-weight:800;font-size:1.18rem}
  .brand .mark{width:38px;height:38px;border-radius:12px;background:var(--blue);display:grid;place-items:center;color:#fff;position:relative;flex:none;font-weight:800}
  .brand .mark .spark{position:absolute;right:-3px;top:-3px;width:11px;height:11px;border-radius:50%;background:var(--orange);border:2px solid #fff}
  .navlinks{display:none;gap:1.8rem;font-weight:500;font-size:.95rem}
  .navlinks a{color:var(--slate)}
  .navlinks a:hover{color:var(--blue)}
  .navlinks a.is-active,.has-drop.is-active .drop-trigger{color:var(--blue)}
  .has-drop{position:relative}
  .drop-trigger{display:inline-flex;align-items:center;gap:.3rem}
  .drop-trigger .chev{width:15px;height:15px;transition:transform .2s}
  .has-drop:hover .chev,.has-drop:focus-within .chev{transform:rotate(180deg)}
  .has-drop .dropdown{position:absolute;top:100%;left:-12px;padding-top:10px;min-width:214px;opacity:0;visibility:hidden;transform:translateY(6px);transition:opacity .18s ease,transform .18s ease,visibility .18s;z-index:60}
  .has-drop:hover .dropdown,.has-drop:focus-within .dropdown{opacity:1;visibility:visible;transform:translateY(0)}
  .dropdown .menu{background:#fff;border:1px solid var(--border);border-radius:14px;box-shadow:var(--sh);padding:8px;display:flex;flex-direction:column}
  .dropdown .menu a{padding:10px 12px;border-radius:9px;font-size:.92rem;font-weight:500;color:var(--slate)}
  .dropdown .menu a:hover{background:var(--blue-tint);color:var(--blue-strong)}
  .dropdown .menu a.all{color:var(--ink);font-weight:600}
  .dropdown .menu .dd-sep{height:1px;background:var(--border);margin:6px 8px}
  .nav-cta{display:flex;align-items:center;gap:.7rem}
  .nav-phone{display:none;align-items:center;gap:.4rem;font-weight:600;font-size:.9rem;color:var(--ink)}
  .nav-phone svg{width:16px;height:16px;color:var(--blue)}
  .nav-quote{display:none;padding:.6rem 1.4rem}
  .phone-mini{width:42px;height:42px;border-radius:11px;border:1px solid var(--border);background:#fff;display:grid;place-items:center;color:var(--blue)}
  .phone-mini svg{width:18px;height:18px}
  .menu-btn{width:42px;height:42px;border-radius:11px;border:1px solid var(--border);background:#fff;display:grid;place-items:center;cursor:pointer}
  .menu-btn .bars{position:relative;width:18px;height:12px;display:block}
  .menu-btn .bars span{position:absolute;left:0;width:100%;height:2px;border-radius:2px;background:var(--ink);transition:transform .25s ease,opacity .18s,top .25s}
  .menu-btn .bars span:nth-child(1){top:0}
  .menu-btn .bars span:nth-child(2){top:5px}
  .menu-btn .bars span:nth-child(3){top:10px}
  .menu-btn[aria-expanded="true"] .bars span:nth-child(1){top:5px;transform:rotate(45deg)}
  .menu-btn[aria-expanded="true"] .bars span:nth-child(2){opacity:0}
  .menu-btn[aria-expanded="true"] .bars span:nth-child(3){top:5px;transform:rotate(-45deg)}
  .drawer-backdrop{position:fixed;inset:0;z-index:70;background:rgba(15,39,66,.5);backdrop-filter:blur(3px);opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s}
  .drawer-backdrop.open{opacity:1;visibility:visible}
  .drawer{position:fixed;top:0;right:0;z-index:80;height:100dvh;width:min(86vw,340px);background:#fff;border-left:1px solid var(--border);box-shadow:-30px 0 60px -28px rgba(15,39,66,.4);transform:translateX(100%);visibility:hidden;transition:transform .32s cubic-bezier(.4,0,.2,1),visibility .32s;display:flex;flex-direction:column;padding:16px 20px 24px;overflow-y:auto}
  .drawer.open{transform:translateX(0);visibility:visible}
  .drawer-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
  .drawer-close{width:40px;height:40px;border-radius:11px;border:1px solid var(--border);background:#fff;display:grid;place-items:center;cursor:pointer;color:var(--ink)}
  .drawer-close svg{width:18px;height:18px}
  .drawer-links{display:flex;flex-direction:column}
  .drawer-links > a{font-family:"Plus Jakarta Sans";font-weight:600;font-size:1.1rem;padding:15px 4px;border-bottom:1px solid var(--border);color:var(--ink);transition:color .15s,padding-left .15s}
  .drawer-links > a:hover{color:var(--blue);padding-left:8px}
  .drawer-group{border-bottom:1px solid var(--border)}
  .drawer-parent-row{display:flex;align-items:center}
  .drawer-parent-row a{flex:1;font-family:"Plus Jakarta Sans";font-weight:600;font-size:1.1rem;padding:15px 4px;color:var(--ink)}
  .drawer-toggle{width:44px;height:44px;display:grid;place-items:center;background:transparent;border:none;cursor:pointer;color:var(--slate)}
  .drawer-toggle svg{width:18px;height:18px;transition:transform .22s}
  .drawer-toggle[aria-expanded="true"] svg{transform:rotate(180deg)}
  .drawer-sub{max-height:0;overflow:hidden;transition:max-height .28s ease;display:flex;flex-direction:column}
  .drawer-sub.open{max-height:340px}
  .drawer-sub a{padding:11px 4px 11px 16px;font-size:1rem;color:var(--slate);border-top:1px solid var(--border)}
  .drawer-sub a:hover{color:var(--blue)}
  .drawer-sub a.all{font-weight:600;color:var(--ink)}
  .drawer-foot{margin-top:auto;padding-top:20px;display:flex;flex-direction:column;gap:10px}
  .drawer-foot .btn{width:100%}
  body.menu-open{overflow:hidden}
  
  /* hero */
  .hero{background:linear-gradient(180deg,var(--blue-tint2),#fff 78%);padding:40px 0 56px;overflow:hidden}
  .hero-grid{display:grid;gap:34px}
  .hero h1{font-size:clamp(2.3rem,8vw,3.5rem);font-weight:800;margin:14px 0 16px}
  .hero h1 span{color:var(--blue)}
  .hero .lede{font-size:1.1rem;color:var(--slate);max-width:30ch}
  .hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin:22px 0 16px}
  .quote-bar{display:flex;gap:6px;background:#fff;border:1px solid var(--border);border-radius:999px;padding:6px 6px 6px 18px;align-items:center;box-shadow:var(--sh-sm);max-width:440px}
  .quote-bar input{flex:1;border:none;background:transparent;font-family:"Inter";font-size:.92rem;color:var(--ink);outline:none;min-width:0}
  .quote-bar input::placeholder{color:#90a2b5}
  .quote-bar .go{background:var(--orange);color:#3a1c05;font-family:"Plus Jakarta Sans";font-weight:700;border:none;border-radius:999px;padding:.6rem 1rem;font-size:.82rem;cursor:pointer;white-space:nowrap}
  .hero-trust{display:flex;flex-wrap:wrap;gap:8px 18px;margin-top:20px;font-size:.84rem;color:var(--muted)}
  .hero-trust span{display:inline-flex;align-items:center;gap:.4rem}
  .hero-trust svg{width:16px;height:16px;color:var(--teal)}
  .hero-visual{position:relative}
  .hero-visual svg{width:100%;height:auto;display:block;border-radius:var(--r-lg)}
  .chip-float{position:absolute;background:#fff;border:1px solid var(--border);border-radius:14px;box-shadow:var(--sh-sm);padding:9px 13px;display:flex;align-items:center;gap:9px;font-size:.8rem;font-weight:600}
  .chip-float .d{width:26px;height:26px;border-radius:8px;display:grid;place-items:center;color:#fff;font-size:.8rem;flex:none}
  .chip-1{top:14px;left:8px}
  .chip-2{bottom:18px;right:6px}
  
  /* trust stats */
  .stats{border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--white)}
  .stats-grid{display:grid;grid-template-columns:repeat(2,1fr)}
  .stat{padding:24px 16px;text-align:center;border-right:1px solid var(--border);border-bottom:1px solid var(--border)}
  .stat:nth-child(2n){border-right:none}
  .stat .n{font-family:"Plus Jakarta Sans";font-weight:800;font-size:1.7rem;color:var(--ink)}
  .stat .n em{color:var(--orange);font-style:normal}
  .stat .l{font-size:.8rem;color:var(--muted);margin-top:2px}
  
  /* sections */
  .section{padding:64px 0}
  .section.paper{background:var(--paper)}
  .section.tint{background:var(--blue-tint2)}
  .sec-head{max-width:620px;margin-bottom:34px}
  .sec-head h2{font-size:clamp(1.8rem,5vw,2.5rem);font-weight:800;margin:10px 0 10px}
  .sec-head p{color:var(--slate);font-size:1.04rem}
  
  /* services */
  .cards{display:grid;grid-template-columns:1fr;gap:16px}
  .card{background:#fff;border:1px solid var(--border);border-radius:var(--r-lg);padding:26px;box-shadow:var(--sh-sm);
	transition:transform .18s ease, box-shadow .18s ease}
  .card:hover{transform:translateY(-4px);box-shadow:var(--sh)}
  .card .ic{width:54px;height:54px;border-radius:15px;display:grid;place-items:center;margin-bottom:16px}
  .card .ic svg{width:28px;height:28px}
  .ic.b{background:var(--blue-tint);color:var(--blue)}
  .ic.o{background:var(--peach);color:var(--orange-deep)}
  .ic.t{background:var(--teal-tint);color:var(--teal-deep)}
  .card h3{font-size:1.2rem;font-weight:700;margin-bottom:6px}
  .card p{font-size:.92rem;color:var(--slate)}
  
  /* how it works */
  .steps{display:grid;grid-template-columns:1fr;gap:18px;counter-reset:step}
  .step{background:#fff;border:1px solid var(--border);border-radius:var(--r-lg);padding:26px;position:relative}
  .step .num{width:40px;height:40px;border-radius:12px;background:var(--blue);color:#fff;font-family:"Plus Jakarta Sans";font-weight:800;display:grid;place-items:center;margin-bottom:14px}
  .step:nth-child(2) .num{background:var(--orange);color:#3a1c05}
  .step:nth-child(3) .num{background:var(--teal)}
  .step h3{font-size:1.12rem;font-weight:700;margin-bottom:5px}
  .step p{font-size:.92rem;color:var(--slate)}
  
  /* why us */
  .split{display:grid;grid-template-columns:1fr;gap:34px;align-items:center}
  .why-visual svg{width:100%;height:auto;display:block}
  .why h2{font-size:clamp(1.8rem,5vw,2.4rem);font-weight:800;margin:10px 0 12px}
  .why>p{color:var(--slate);font-size:1.04rem;margin-bottom:18px}
  .feat{display:flex;gap:14px;padding:14px 0;border-top:1px solid var(--border)}
  .feat:last-child{border-bottom:1px solid var(--border)}
  .feat .fi{width:40px;height:40px;border-radius:11px;flex:none;display:grid;place-items:center;background:var(--blue-tint);color:var(--blue)}
  .feat .fi svg{width:20px;height:20px}
  .feat h4{font-family:"Plus Jakarta Sans";font-weight:700;font-size:1rem;margin-bottom:2px}
  .feat p{font-size:.9rem;color:var(--slate)}
  
  /* reviews */
  .rev-grid{display:grid;grid-template-columns:1fr;gap:16px}
  .rev{background:#fff;border:1px solid var(--border);border-radius:var(--r-lg);padding:24px;box-shadow:var(--sh-sm)}
  .stars{color:var(--orange);font-size:1rem;letter-spacing:2px;margin-bottom:10px}
  .rev p{font-size:.98rem;color:var(--ink);margin-bottom:16px}
  .who{display:flex;align-items:center;gap:11px}
  .who .av{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;font-family:"Plus Jakarta Sans";font-weight:700;font-size:.9rem}
  .av.b{background:var(--blue-tint);color:var(--blue-strong)}
  .av.o{background:var(--peach);color:var(--orange-deep)}
  .av.t{background:var(--teal-tint);color:var(--teal-deep)}
  .who b{font-family:"Plus Jakarta Sans";font-size:.92rem;display:block}
  .who small{color:var(--muted);font-size:.8rem}
  .rev-top{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px}
  .rev-top .stars{margin-bottom:0}
  .rev-tag{font-family:"Inter",sans-serif;font-size:.7rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--blue-strong);background:var(--blue-tint);border:1px solid var(--border);border-radius:999px;padding:3px 10px;white-space:nowrap}
  
  /* areas */
  .areas{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px}
  .boro{background:#fff;border:1px solid var(--border);border-radius:999px;padding:.6rem 1.2rem;font-family:"Plus Jakarta Sans";font-weight:600;font-size:.92rem;display:flex;align-items:center;gap:.5rem}
  .boro span{width:7px;height:7px;border-radius:50%;background:var(--blue)}
  
  /* cta band */
  /*.cta{background:var(--blue);color:#fff;border-radius:0;padding:56px 0}*/
  .cta{background:url('/img/hero-img01.webp') center/cover, var(--orange);background-blend-mode: multiply;border-radius:0;padding:56px 0;}
  .cta-inner{display:grid;gap:22px;align-items:center}
  .cta h2{font-size:clamp(1.7rem,5vw,2.4rem);font-weight:800;color:#fff}
  .cta p{color:#d4e6fc;font-size:1.05rem;margin-top:8px}
  .cta .row{display:flex;flex-wrap:wrap;gap:12px}
  .cta .btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.5)}
  .cta .btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.1)}
  
  /* footer */
  footer{background:var(--paper);color:var(--slate);padding:54px 0 28px;border-top:1px solid var(--border)}
  .foot-grid{display:grid;grid-template-columns:1fr 1fr;gap:30px;margin-bottom:36px}
  .foot-brand{grid-column:1 / -1}
  .foot-brand .brand{color:var(--ink)}
  .foot-brand p{font-size:.9rem;color:var(--muted);margin-top:12px;max-width:30ch}
  .foot-col h5{font-family:"Plus Jakarta Sans";font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:12px}
  .foot-col a,.foot-col p{display:block;font-size:.9rem;color:var(--slate);margin-bottom:8px}
  .foot-col a:hover{color:var(--blue)}
  .foot-bottom{border-top:1px solid var(--border);padding-top:20px;display:flex;flex-wrap:wrap;gap:8px;justify-content:space-between;font-size:.8rem;color:var(--muted)}
  
  /* page hero (internal pages) */
  .page-hero{background:linear-gradient(180deg,var(--blue-tint2),#fff);padding:48px 0 40px;border-bottom:1px solid var(--border)}
  .page-hero h1{font-size:clamp(2rem,6vw,3rem);font-weight:800;margin:10px 0 12px}
  .page-hero p{color:var(--slate);font-size:1.08rem;max-width:52ch}
  
  /* service rows (hub) */
  .svc-rows{display:flex;flex-direction:column;gap:18px}
  .svc-row{display:grid;grid-template-columns:1fr;gap:18px;background:#fff;border:1px solid var(--border);border-radius:var(--r-lg);padding:26px;box-shadow:var(--sh-sm);transition:transform .18s ease,box-shadow .18s ease}
  .svc-row:hover{transform:translateY(-3px);box-shadow:var(--sh)}
  .svc-row .ic{width:56px;height:56px;border-radius:15px;display:grid;place-items:center;flex:none}
  .svc-row .ic svg{width:28px;height:28px}
  .svc-row h2{font-size:1.4rem;font-weight:700;margin-bottom:6px}
  .svc-row .desc{color:var(--slate);font-size:.98rem;margin-bottom:12px}
  .svc-jobs{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}
  .svc-jobs span{font-size:.78rem;font-weight:500;color:var(--slate);background:var(--paper);border:1px solid var(--border);border-radius:999px;padding:.32rem .7rem}
  .svc-more{display:inline-flex;align-items:center;gap:.4rem;font-family:"Plus Jakarta Sans";font-weight:700;font-size:.92rem;color:var(--blue)}
  .svc-more svg{width:16px;height:16px;transition:transform .15s}
  .svc-row:hover .svc-more svg{transform:translateX(3px)}
  
  /* service detail page */
  .page-hero .ic{width:56px;height:56px;border-radius:15px;display:grid;place-items:center;margin-bottom:16px}
  .page-hero .ic svg{width:28px;height:28px}
  .page-hero .hero-actions{margin-top:24px}
  .feat-list{max-width:760px}
  .list-check{list-style:none;display:grid;grid-template-columns:1fr;gap:12px;max-width:760px}
  .list-check li{display:flex;gap:10px;color:var(--slate)}
  .list-check li svg{width:20px;height:20px;color:var(--blue);flex:none;margin-top:3px}
  .faq{display:grid;gap:12px;max-width:760px}
  .faq details{background:#fff;border:1px solid var(--border);border-radius:var(--r)}
  .faq summary{cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:12px;padding:18px 20px;font-family:"Plus Jakarta Sans";font-weight:600;font-size:1.02rem;color:var(--ink)}
  .faq summary::-webkit-details-marker{display:none}
  .faq summary .fq-ic{width:18px;height:18px;flex:none;color:var(--blue);transition:transform .2s}
  .faq details[open] summary .fq-ic{transform:rotate(180deg)}
  .faq details p{margin:0;padding:0 20px 18px;color:var(--slate);font-size:.96rem}
  .other-svcs{display:flex;flex-wrap:wrap;gap:10px}
  a.boro:hover{border-color:var(--blue);color:var(--blue)}
  
  /* what's-included split (per-service photo, image left) */
  .media-row{display:grid;grid-template-columns:1fr;gap:26px;align-items:stretch}
  .media-row__media{position:relative;overflow:hidden;border-radius:var(--r-lg);min-height:240px;display:grid;place-items:center;
	background:linear-gradient(135deg,var(--blue-tint),#DCEAFB);border:1px solid var(--border)}
  .media-row__media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:2}
  .media-row__media .media-label{position:relative;z-index:1;font-family:"Inter",sans-serif;font-size:.76rem;letter-spacing:.08em;text-transform:uppercase;color:var(--blue-strong);text-align:center;padding:1rem;opacity:.85}
  .media-row__body .sec-head{margin-bottom:22px}
  .media-row__body .feat-list{max-width:none}
  
/* contact */
.contact-grid{display:grid;grid-template-columns:1fr;gap:24px;align-items:start}

/* coloured info panel */
.contact-info{background:var(--blue);color:#fff;padding:32px 28px;border-radius:var(--r-lg);box-shadow:0 16px 38px -26px rgba(15,39,66,.28)}
.contact-info .ci-item{display:flex;gap:13px;align-items:flex-start;margin-bottom:24px}
.contact-info .ci-item:last-child{margin-bottom:0}
.contact-info .ci-ic{flex:none;width:34px;height:34px;border-radius:9px;display:grid;place-items:center;background:rgba(255,255,255,.15)}
.contact-info .ci-ic svg{width:17px;height:17px;color:#fff}
.contact-info h4{font-family:"Plus Jakarta Sans",sans-serif;font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.65);margin-bottom:4px}
.contact-info p,.contact-info a,.contact-info address{display:block;color:#fff;font-size:1rem;font-style:normal;text-decoration:none;line-height:1.5}
.contact-info a:hover{opacity:.82}

/* form panel */
.contact-form{background:var(--white);border:1px solid var(--border);border-radius:var(--r-lg);padding:32px 28px;box-shadow:0 16px 38px -26px rgba(15,39,66,.28)}
.contact-form .field{margin-bottom:18px}
.contact-form label{display:block;font-family:"Plus Jakarta Sans",sans-serif;font-weight:600;font-size:.85rem;color:var(--ink);margin-bottom:7px}
.contact-form input,.contact-form select,.contact-form textarea{width:100%;font-family:"Inter",sans-serif;font-size:.95rem;color:var(--ink);background:var(--white);border:1.5px solid var(--border);border-radius:12px;padding:.7rem .9rem;outline:none;transition:border-color .15s ease,box-shadow .15s ease}
.contact-form input:focus,.contact-form select:focus,.contact-form textarea:focus{border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-tint)}
.contact-form textarea{resize:vertical;min-height:120px}
.contact-form .btn{width:100%;margin-top:4px}
.contact-form .hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}

/* accent hero (thank-you / utility pages) */
.page-hero.is-accent{background:var(--blue);border-bottom:none}
.page-hero.is-accent .eyebrow{color:rgba(255,255,255,.7)}
.page-hero.is-accent h1{color:#fff}
.page-hero.is-accent p{color:rgba(255,255,255,.88)}
.page-hero.is-accent .btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.5)}
.page-hero.is-accent .btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.12)}

/* scroll reveal — progressive enhancement, fires once, respects reduced motion */
@media (prefers-reduced-motion: no-preference){
  .js .reveal{opacity:0;transform:translateY(30px);transition:opacity .8s ease-out,transform .8s ease-out}
  .js .reveal.is-visible{opacity:1;transform:none}
}

/* responsive */
@media (min-width:560px){
  .stats-grid{grid-template-columns:repeat(4,1fr)}
  .stat{border-bottom:none}
  .stat:nth-child(2n){border-right:1px solid var(--border)}
  .stat:last-child{border-right:none}
  .cards{grid-template-columns:repeat(2,1fr)}
  .rev-grid{grid-template-columns:repeat(2,1fr)}
  .list-check{grid-template-columns:repeat(2,1fr)}
}
@media (min-width:880px){
  .navlinks{display:flex}
	.nav-phone{display:flex}
	.menu-btn{display:none}
	.nav-quote{display:inline-flex}
	.phone-mini{display:none}
	.drawer,.drawer-backdrop{display:none}
	.hero{padding:64px 0 80px}
	.hero-grid{grid-template-columns:1.05fr .95fr;align-items:center}
	.section{padding:90px 0}
	.cards{grid-template-columns:repeat(4,1fr)}
	.steps{grid-template-columns:repeat(3,1fr)}
	.rev-grid{grid-template-columns:repeat(3,1fr)}
	.split{grid-template-columns:.9fr 1.1fr;gap:54px}
	.why-visual{order:2}
	.why{order:1}
	.cta-inner{grid-template-columns:1.4fr 1fr}
	.cta .row{justify-content:flex-end}
	.foot-grid{grid-template-columns:2fr 1fr 1fr 1.3fr}
	.foot-brand{grid-column:auto}
	.page-hero{padding:64px 0 52px}
	.svc-row{grid-template-columns:auto 1fr;align-items:start;gap:26px;padding:32px 34px}
	.media-row{grid-template-columns:.92fr 1.08fr;gap:48px}
	.media-row--reverse{grid-template-columns:1.08fr .92fr}
	.media-row--reverse .media-row__media{order:2}
	.media-row--reverse .media-row__body{order:1}
	.contact-grid{grid-template-columns:.85fr 1.15fr;gap:54px;align-items:start}
  }
  