/* ==============================================================
   DLS INNOVATIONS — HOMEPAGE  (audit build)
   Poppins · DLS Blue · the smile · two-tone heads · soft cards.
   Warm + photography-led. One bold blue moment. Editorial restraint.
   ============================================================== */

:root{
  --blue:#2D6BE4;
  --blue-deep:#1E54C2;
  --ink:#141822;
  --slate:#5C6775;
  --slate-2:#7B8694;
  --white:#FFFFFF;
  --warm:#F6F9FE;
  --soft:#E9F1FF;
  --frame:#E7EBF2;
  --amber:#F4A93B;
  --font:'Poppins',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --w:1180px;
  --e:cubic-bezier(.22,.61,.36,1);
  --e2:cubic-bezier(.16,1,.3,1);
  --card:0 28px 60px -28px rgba(20,24,40,.22), 0 10px 22px -14px rgba(20,24,40,.10);
  --card-sm:0 16px 38px -22px rgba(20,24,40,.15);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--font);color:var(--slate);background:var(--white);line-height:1.72;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;font-size:17px}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
::selection{background:var(--blue);color:#fff}
.wrap{width:100%;max-width:var(--w);margin:0 auto;padding:0 48px}

h1,h2,h3,h4{font-family:var(--font);color:var(--ink);font-weight:700;letter-spacing:-.02em;line-height:1.1}
.blue{color:var(--blue)}

.smile-u{position:relative;display:inline-block}
.smile-u svg{position:absolute;left:4%;right:4%;bottom:-.08em;width:92%;height:.2em}
.smile-u svg path{stroke:var(--blue);stroke-width:3.5;fill:none;stroke-linecap:round}

.eyebrow{display:inline-block;font-weight:700;font-size:.73rem;letter-spacing:.18em;text-transform:uppercase;color:var(--blue)}
.eyebrow.lt{color:#9DC0FF}

.btn{display:inline-flex;align-items:center;gap:10px;font-family:var(--font);font-weight:600;font-size:.95rem;
  padding:16px 30px;border-radius:100px;cursor:pointer;border:1.5px solid transparent;
  transition:background .25s var(--e),color .25s,border-color .25s,transform .25s,box-shadow .25s}
.btn .a{transition:transform .3s var(--e2)}.btn:hover .a{transform:translateX(4px)}
.btn-blue{background:var(--blue);color:#fff;box-shadow:0 10px 22px -12px rgba(45,107,228,.5)}
.btn-blue:hover{background:var(--blue-deep);transform:translateY(-2px);box-shadow:0 16px 28px -14px rgba(45,107,228,.5)}
.btn-out{background:var(--white);color:var(--blue);border-color:var(--frame)}
.btn-out:hover{border-color:var(--blue);transform:translateY(-2px)}
.btn-glass{background:rgba(255,255,255,.14);color:#fff;border-color:rgba(255,255,255,.6);backdrop-filter:blur(6px)}
.btn-glass:hover{background:#fff;color:var(--blue);border-color:#fff;transform:translateY(-2px)}

/* Logo */
.logo{display:inline-flex;flex-direction:column;line-height:1}
.logo .row{display:flex;align-items:baseline;gap:8px}
.logo .d{font-weight:800;font-size:1.36rem;letter-spacing:-.01em;color:var(--ink)}
.logo .i{font-weight:700;font-size:.72rem;letter-spacing:.26em;color:var(--slate)}
.logo .sm{margin-top:3px;width:38px;height:6px}
.logo .sm path{stroke:var(--blue);stroke-width:2.4;fill:none;stroke-linecap:round}
.on-light .d{color:#fff}.on-light .i{color:rgba(255,255,255,.82)}

/* Photography — one cohesive, on-brand daylight treatment */
.photo{position:relative;overflow:hidden;background:#dde6f3;isolation:isolate;border-radius:24px}
.photo .img{position:absolute;inset:0;transition:transform 1.2s var(--e2)}
.photo::before{content:"";position:absolute;inset:0;z-index:3;pointer-events:none;opacity:.2;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 48 48' fill='none' stroke='%23ffffff' stroke-width='1'%3E%3Ccircle cx='24' cy='24' r='13.5'/%3E%3Ccircle cx='24' cy='24' r='5'/%3E%3C/svg%3E") no-repeat center;background-size:38px 38px}
.photo::after{content:"";position:absolute;inset:0;z-index:2;pointer-events:none;
  background:radial-gradient(125% 115% at 50% 12%, transparent 66%, rgba(20,24,34,.08) 100%),
  url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='150' height='150'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.02'/%3E%3C/svg%3E");mix-blend-mode:multiply}
.photo .tag{position:absolute;left:16px;bottom:15px;z-index:4;font-size:.54rem;font-weight:600;letter-spacing:.1em;
  text-transform:uppercase;color:rgba(255,255,255,.82);background:rgba(20,24,34,.22);backdrop-filter:blur(3px);padding:4px 10px;border-radius:6px}
.hz:hover .img{transform:scale(1.045)}
.cta .bg::before,.band .bg::before{display:none}
.cta .bg,.band .bg{border-radius:0}
.s1 .img{background:linear-gradient(150deg,#e9f2fd 0%,#c4d7ef 46%,#e6d6b9 100%)}
.s2 .img{background:linear-gradient(150deg,#eaf3fc 0%,#cbdcf0 46%,#e7d8bd 100%)}
.s3 .img{background:linear-gradient(150deg,#edf3fb 0%,#cfdaee 46%,#e4d4ba 100%)}
.s4 .img{background:linear-gradient(150deg,#e8f1fd 0%,#c2d4ec 46%,#ead9bb 100%)}
.s5 .img{background:linear-gradient(150deg,#ecf4fc 0%,#c8d8ee 46%,#e3d5bb 100%)}
.s6 .img{background:linear-gradient(150deg,#eef3fb 0%,#d0dbef 46%,#e5d6bc 100%)}
.s-hero .img{background:linear-gradient(145deg,#e6f0fd 0%,#bcd2ef 42%,#dcc8a6 100%)}
.s-band .img{background:linear-gradient(135deg,#0f131d 0%,#1b2742 50%,#294169 100%)}

.avatar{border-radius:50%;overflow:hidden;position:relative;flex-shrink:0;background:#cdd9ec}
.avatar i{position:absolute;inset:0;background:linear-gradient(150deg,#cfe0f1,#e7cfa9)}

.rv{opacity:0;transform:translateY(26px);transition:opacity .9s var(--e2),transform .9s var(--e2)}
.rv.in{opacity:1;transform:none}
.rv[data-d="1"]{transition-delay:.09s}.rv[data-d="2"]{transition-delay:.18s}.rv[data-d="3"]{transition-delay:.27s}

/* ==============================================================
   NAV
   ============================================================== */
.topbar{position:fixed;inset:0 0 auto 0;z-index:400;background:rgba(255,255,255,.9);
  backdrop-filter:saturate(180%) blur(16px);border-bottom:1px solid transparent;transition:border-color .35s,box-shadow .35s}
.topbar.solid{border-bottom-color:var(--frame);box-shadow:0 6px 24px -20px rgba(20,24,40,.5)}
.nav{display:flex;align-items:center;justify-content:space-between;height:92px;gap:40px}
.nav-links{display:flex;align-items:center;gap:34px;list-style:none;margin:0 auto}
.nav-links a{font-size:.93rem;font-weight:500;color:var(--slate);transition:color .25s;position:relative;white-space:nowrap}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-7px;height:2px;width:100%;background:var(--blue);
  transform:scaleX(0);transform-origin:left;transition:transform .3s var(--e)}
.nav-links a:hover{color:var(--blue)}.nav-links a:hover::after{transform:scaleX(1)}
.nav-right{display:flex;align-items:center;gap:20px;flex-shrink:0}
.nav-right .find{font-size:.9rem;font-weight:600;color:var(--ink);white-space:nowrap}.nav-right .find:hover{color:var(--blue)}
.nav-right .sep{width:1px;height:22px;background:var(--frame)}
.menu-btn{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px}
.menu-btn span{width:24px;height:2px;background:var(--ink);border-radius:2px}

/* ==============================================================
   HERO — one focal point: commanding type + one clean image
   ============================================================== */
.hero{padding:168px 0 116px;background:radial-gradient(1100px 560px at 90% 6%, var(--soft) 0%, rgba(233,241,255,0) 60%), var(--white)}
.hero-grid{display:grid;grid-template-columns:1.04fr .96fr;gap:88px;align-items:center}
.hero h1{font-size:clamp(2.5rem,4.9vw,4.2rem);font-weight:700;letter-spacing:-.025em;line-height:1.08}
.hero .sub{max-width:500px;margin-top:26px;font-size:1.18rem;color:var(--slate);line-height:1.55}
.hero .cta-row{display:flex;gap:13px;margin-top:34px;flex-wrap:wrap}
.hero .mini{margin-top:28px;display:flex;align-items:center;gap:14px;color:var(--slate-2);font-size:.95rem;font-weight:500}
.hero .mini b{color:var(--ink);font-weight:700}.hero .mini .ln{width:28px;height:2px;background:var(--blue);border-radius:2px}
.hero-photo{aspect-ratio:5/6;border-radius:30px;box-shadow:var(--card)}

/* ==============================================================
   TRUST STRIP
   ============================================================== */
.hero-stats{display:grid;grid-template-columns:repeat(4,1fr);margin-top:clamp(56px,7vh,88px);
  padding-top:42px;border-top:1px solid var(--frame)}
.hero-stats .stat{padding:0 36px;border-left:1px solid var(--frame)}
.hero-stats .stat:first-child{padding-left:0;border-left:none}
.hero-stats .num{font-size:clamp(1.6rem,2.3vw,2.05rem);font-weight:600;color:var(--ink);letter-spacing:-.02em;line-height:1}
.hero-stats .num .u{color:var(--blue)}
.hero-stats .lab{margin-top:11px;font-size:.74rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--slate-2);line-height:1.4;max-width:13ch}

/* ==============================================================
   SECTION SCAFFOLD
   ============================================================== */
.section{padding:clamp(92px,12vh,140px) 0}
.warmbg{background:var(--warm)}
.sec-head{max-width:760px}
.sec-head.center{margin:0 auto;text-align:center}
.sec-head h2{font-size:clamp(1.95rem,3.5vw,2.95rem);margin-top:18px;line-height:1.12}
.sec-head p{font-size:1.18rem;color:var(--slate);margin-top:26px;max-width:600px}
.sec-head.center p{margin-left:auto;margin-right:auto}

/* TRUSTED PARTNERSHIPS — interactive audience experience */
.partners-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:92px;align-items:stretch}
.partners-copy h2{font-size:clamp(1.9rem,3.3vw,2.8rem);margin-top:18px}
.partners-copy .lead{font-size:1.16rem;color:var(--slate);margin-top:22px;max-width:520px}
.aud-list{margin-top:38px;list-style:none;border-top:1px solid var(--frame)}
.aud-row{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:23px 4px 23px 0;
  border-bottom:1px solid var(--frame);cursor:pointer;transition:padding .35s var(--e)}
.aud-row .at{display:flex;flex-direction:column;gap:3px}
.aud-row .an{font-size:1.24rem;font-weight:700;color:var(--ink);letter-spacing:-.01em;transition:color .25s}
.aud-row .ad{font-size:.88rem;color:var(--slate-2);font-weight:500}
.aud-row .arw{color:var(--blue);font-size:1.15rem;opacity:0;transform:translateX(-8px);transition:opacity .3s,transform .3s}
.aud-row:hover,.aud-row.active{padding-left:14px}
.aud-row:hover .an,.aud-row.active .an{color:var(--blue)}
.aud-row:hover .arw,.aud-row.active .arw{opacity:1;transform:none}
.partners-media{position:relative;display:flex;align-self:stretch}
.partners-media .ph{flex:1;min-height:500px;border-radius:28px;box-shadow:var(--card)}
.partners-media .sw{position:absolute;inset:0;opacity:0;transition:opacity .6s var(--e2)}
.partners-media .sw.on{opacity:1}
.partners-media .g1{background:linear-gradient(150deg,#e9f2fd 0%,#c4d7ef 46%,#e6d6b9 100%)}
.partners-media .g2{background:linear-gradient(150deg,#eaf3fc 0%,#cbdcf0 46%,#e7d8bd 100%)}
.partners-media .g3{background:linear-gradient(150deg,#edf3fb 0%,#cfdaee 46%,#e4d4ba 100%)}
.partners-media .g4{background:linear-gradient(150deg,#e8f1fd 0%,#c2d4ec 46%,#ead9bb 100%)}
.partners-media .g5{background:linear-gradient(150deg,#ecf4fc 0%,#c8d8ee 46%,#e3d5bb 100%)}
.partners-media .g6{background:linear-gradient(150deg,#eef3fb 0%,#d0dbef 46%,#e5d6bc 100%)}

/* WHY DLS — alternating image/text rows */
.zig{display:flex;flex-direction:column;gap:clamp(90px,11vh,140px);margin-top:90px}
.zrow{display:grid;grid-template-columns:1fr 1fr;gap:92px;align-items:center}
.zrow .zmedia{aspect-ratio:5/4;border-radius:28px;box-shadow:var(--card-sm)}
.zrow:nth-child(even) .zmedia{order:2}
.zrow .zn{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:50%;
  background:var(--soft);color:var(--blue);font-weight:800;font-size:1rem;margin-bottom:20px}
.zrow h3{font-size:clamp(1.5rem,2.3vw,1.95rem);margin-bottom:14px}
.zrow .zlead{font-size:1.12rem;color:var(--slate);line-height:1.6;margin-bottom:22px}
.zlist{list-style:none;display:flex;flex-direction:column;gap:12px}
.zlist li{display:flex;gap:14px;align-items:flex-start;font-size:1rem;color:var(--ink);font-weight:500}
.zlist .ck{flex-shrink:0;width:7px;height:7px;border-radius:50%;background:var(--blue);margin-top:10px}

/* SCALE PANEL — the bold blue moment (proposal anchor + shows scale) */
.scale-wrap{padding:clamp(72px,9vh,110px) 0}
.scale-panel{background:linear-gradient(150deg,#2D6BE4 0%,#1E54C2 100%);border-radius:32px;
  padding:clamp(54px,6.5vw,90px);display:grid;grid-template-columns:auto 1fr;gap:74px;align-items:center;color:#fff;
  box-shadow:0 34px 70px -34px rgba(45,107,228,.55)}
.scale-panel .big{font-weight:700;font-size:clamp(3rem,6.4vw,4.7rem);color:#fff;letter-spacing:-.03em;line-height:.86}
.scale-panel .biglabel{font-size:.72rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.82);margin-top:16px}
.scale-panel .ptext{font-size:clamp(1.16rem,1.7vw,1.42rem);color:#fff;font-weight:600;line-height:1.42;letter-spacing:-.01em}
.scale-panel .psub{font-size:1.06rem;color:rgba(255,255,255,.8);margin-top:14px;line-height:1.55}
.scale-panel .cred-line{margin-top:26px;padding-top:22px;border-top:1px solid rgba(255,255,255,.28);
  font-size:.86rem;font-weight:500;color:rgba(255,255,255,.86);letter-spacing:.01em}

/* PICTURE DAY — full-bleed band + steps */
/* PICTURE DAY — light connected timeline */
.timeline{display:grid;grid-template-columns:repeat(4,1fr);gap:34px;margin-top:64px}
.tstep{position:relative;padding-top:66px}
.tstep .tn{position:absolute;top:0;left:0;width:48px;height:48px;border-radius:50%;
  background:var(--blue);color:#fff;display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:1.02rem;z-index:2;box-shadow:0 10px 20px -10px rgba(45,107,228,.6)}
.tstep::before{content:"";position:absolute;top:24px;left:48px;right:-34px;height:2px;background:var(--frame);z-index:0}
.tstep:last-child::before{display:none}
.tstep h3{font-size:1.3rem;font-weight:700;margin-bottom:9px}
.tstep p{font-size:.96rem;color:var(--slate);line-height:1.55}

/* SERVICES — photo cards, one image per topic */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:64px}
.svc{background:#fff;border:1px solid var(--frame);border-radius:22px;overflow:hidden;box-shadow:var(--card-sm);
  transition:transform .32s var(--e),box-shadow .32s var(--e)}
.svc:hover{transform:translateY(-6px);box-shadow:var(--card)}
.svc .ph{aspect-ratio:16/11}
.svc .body{padding:24px 26px 28px}
.svc .n{font-weight:700;color:var(--blue);font-size:.78rem;letter-spacing:.08em}
.svc h3{font-size:1.22rem;font-weight:700;margin:8px 0 9px}
.svc p{font-size:.95rem;color:var(--slate);line-height:1.55}

/* YEARBOOK — split with image */
.yb-points{margin-top:34px;display:grid;grid-template-columns:1fr 1fr;gap:16px 30px}
.yb-point{padding-top:16px;border-top:2px solid var(--blue)}
.yb-point h4{font-size:1.06rem;margin-bottom:6px;font-weight:700}
.yb-point p{font-size:.9rem;color:var(--slate);line-height:1.5}

/* PARENT — split */
.split{display:grid;grid-template-columns:1fr 1fr;gap:96px;align-items:center}
.split.flip .sp-media{order:2}
.split .sp-media{aspect-ratio:5/6;border-radius:28px;box-shadow:var(--card-sm)}
.split h2{font-size:clamp(1.85rem,3.2vw,2.65rem);margin-top:18px}
.split .lead{font-size:1.16rem;color:var(--slate);margin-top:22px}
.p-list{margin-top:32px;list-style:none}
.p-list li{display:grid;grid-template-columns:auto 1fr;gap:18px;padding:20px 0;border-top:1px solid var(--frame)}
.p-list li:first-child{border-top:none}
.p-list .ck{flex-shrink:0;width:8px;height:8px;border-radius:50%;background:var(--blue);margin-top:11px}
.p-list h4{font-size:1.12rem;margin-bottom:3px;font-weight:700}
.p-list p{font-size:.94rem;color:var(--slate);line-height:1.5}
.tech-note{margin-top:30px;display:inline-flex;align-items:center;gap:11px;background:var(--soft);border-radius:100px;
  padding:13px 22px;font-size:.86rem;color:var(--slate);font-weight:500}
.tech-note .dot{width:7px;height:7px;border-radius:50%;background:var(--blue);flex-shrink:0}
.tech-note b{color:var(--ink);font-weight:700}

/* TESTIMONIALS — featured quote + two supporting (human beat) */
.testi-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:34px;margin-top:76px;align-items:stretch}
.tfeature{background:linear-gradient(150deg,#2D6BE4 0%,#1E54C2 100%);color:#fff;border-radius:28px;padding:clamp(40px,4vw,56px);
  box-shadow:0 28px 60px -28px rgba(45,107,228,.5);display:flex;flex-direction:column;justify-content:center}
.tfeature .who span{color:rgba(255,255,255,.78)}
.tfeature .stars{color:var(--amber);letter-spacing:4px;font-size:.95rem;margin-bottom:22px}
.tfeature blockquote{font-size:clamp(1.28rem,2vw,1.62rem);font-weight:600;color:#fff;line-height:1.4;letter-spacing:-.01em}
.tfeature .who{margin-top:30px;display:flex;align-items:center;gap:14px}
.tfeature .who .avatar{width:50px;height:50px}
.tfeature .who b{color:#fff;font-weight:700;display:block;font-size:.98rem}
.tfeature .who span{color:rgba(255,255,255,.66);font-size:.86rem}
.tside{display:flex;flex-direction:column;gap:30px}
.tc{background:var(--white);border:1px solid var(--frame);border-radius:22px;padding:38px 34px;box-shadow:var(--card-sm);flex:1;display:flex;flex-direction:column;justify-content:center}
.tc .stars{color:var(--amber);letter-spacing:3px;font-size:.8rem;margin-bottom:14px}
.tc blockquote{font-size:1.02rem;color:var(--ink);line-height:1.55;font-weight:500}
.tc .who{margin-top:20px;display:flex;align-items:center;gap:12px}
.tc .who .avatar{width:42px;height:42px}
.tc .who b{color:var(--ink);font-weight:700;display:block;font-size:.9rem}
.tc .who span{font-size:.82rem;color:var(--slate)}
.tnote{text-align:center;margin-top:36px;font-size:.8rem;color:var(--slate-2)}

/* CTA */
.cta{background:linear-gradient(180deg,#fff 0%,var(--soft) 100%);text-align:center}
.cta-inner{padding:clamp(104px,14vh,168px) 0}
.cta h2{font-size:clamp(2.1rem,4vw,3.4rem);color:var(--ink);max-width:760px;margin:16px auto 0;letter-spacing:-.02em}
.cta h2 .blue{color:var(--blue)}
.cta p{font-size:1.18rem;color:var(--slate);max-width:540px;margin:22px auto 0}
.cta .cta-row{display:flex;gap:13px;justify-content:center;flex-wrap:wrap;margin-top:38px}

/* FOOTER */
footer.site{background:var(--warm);color:var(--slate);padding:100px 0 40px;border-top:1px solid var(--frame)}
.foot-grid{display:grid;grid-template-columns:1.8fr 1fr 1.05fr 1.05fr;gap:60px;padding-bottom:64px;border-bottom:1px solid var(--frame)}
.foot-brand .logo{margin-bottom:26px}
.foot-brand .logo .d{font-size:1.5rem}
.foot-brand .logo .i{font-size:.78rem}
.foot-brand .logo .sm{width:42px;height:7px;margin-top:4px}
.foot-tag{font-size:1rem;color:var(--slate);max-width:340px;line-height:1.7}
.foot-contact{margin-top:26px;display:flex;flex-direction:column;gap:8px;font-size:.93rem}
.foot-contact span{color:var(--slate)}
.foot-contact a{color:var(--ink);font-weight:600;width:fit-content;transition:color .25s}
.foot-contact a:hover{color:var(--blue)}
.foot-col h5{font-weight:700;color:var(--ink);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;margin-bottom:22px}
.foot-col ul{list-style:none;display:flex;flex-direction:column;gap:14px}
.foot-col a{font-size:.94rem;color:var(--slate);transition:color .25s}
.foot-col a:hover{color:var(--blue)}
.foot-bottom{display:flex;align-items:center;justify-content:space-between;padding-top:30px;flex-wrap:wrap;gap:14px;
  font-size:.72rem;font-weight:600;letter-spacing:.09em;text-transform:uppercase;color:var(--slate-2)}
.foot-bottom .socials{display:flex;gap:10px}
.foot-bottom .socials a{width:36px;height:36px;border:1px solid var(--frame);border-radius:9px;display:flex;
  align-items:center;justify-content:center;color:var(--ink);font-size:.74rem;font-weight:700;transition:background .25s,border-color .25s,color .25s}
.foot-bottom .socials a:hover{background:var(--blue);border-color:var(--blue);color:#fff}

/* RESPONSIVE */
@media (max-width:1000px){
  .hero-grid,.zrow,.split,.partners-grid,.scale-panel{grid-template-columns:1fr;gap:48px}
  .partners-media{order:-1;max-width:480px;margin:0 auto}
  .hero-media{max-width:460px;margin:0 auto}
  .partners-media .ph{min-height:420px}
  .zrow:nth-child(even) .zmedia,.split.flip .sp-media{order:0}
  .svc-grid,.testi-grid{grid-template-columns:repeat(2,1fr)}
  .yb-points{grid-template-columns:1fr 1fr}
  .timeline{grid-template-columns:1fr 1fr;gap:44px 34px}
  .tstep::before{display:none}
  .scale-panel{gap:30px;text-align:left}
  .split .sp-media{max-width:520px}
}
@media (max-width:680px){
  .wrap{padding:0 24px}
  .nav-links{display:none}.nav-right .btn-blue,.nav-right .find,.nav-right .sep{display:none}.menu-btn{display:flex}
  .hero{padding:120px 0 70px}
  .section{padding:74px 0}
  .svc-grid,.testi-grid,.timeline,.yb-points{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr;gap:40px}
  .hero-stats{grid-template-columns:1fr 1fr;gap:34px 0;padding:32px 16px;margin-top:48px}
  .hero-stats .stat{padding:0 18px}
  .hero-stats .stat:nth-child(3){border-left:none}
}
@media (max-width:460px){
  .hero .cta-row .btn,.cta .cta-row .btn{width:100%;justify-content:center}
  .foot-grid{grid-template-columns:1fr 1fr}
  .trust .wrap{gap:12px 22px}
}
@media (prefers-reduced-motion:reduce){.rv{opacity:1;transform:none;transition:none}html{scroll-behavior:auto}}

/* ==============================================================
   SHARED SUB-PAGE SCAFFOLDING (pillars, resources, ordering)
   ============================================================== */
.phero{padding:150px 0 clamp(52px,8vh,88px);
  background:radial-gradient(1100px 520px at 88% 2%, var(--soft) 0%, rgba(233,241,255,0) 60%), var(--white)}
.crumbs{font-size:.8rem;font-weight:600;color:var(--slate-2);margin-bottom:20px}
.crumbs a:hover{color:var(--blue)}.crumbs span{opacity:.5;margin:0 6px}
.phero h1{font-size:clamp(2.3rem,4.6vw,3.7rem);font-weight:700;letter-spacing:-.025em;line-height:1.06;margin-top:14px}
.phero .lead{max-width:620px;margin-top:22px;font-size:1.2rem;color:var(--slate);line-height:1.6}
.phero .cta-row{display:flex;gap:13px;margin-top:32px;flex-wrap:wrap}
.prose{max-width:720px}
.prose p{font-size:1.08rem;color:var(--slate);line-height:1.75;margin-top:18px}
/* numbered step cards (ordering / how-it-works) */
.steps-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:26px;margin-top:60px}
.step-card{background:#fff;border:1px solid var(--frame);border-radius:22px;padding:32px 28px;box-shadow:var(--card-sm)}
.step-card .sn{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:50%;
  background:var(--soft);color:var(--blue);font-weight:800;font-size:1rem;margin-bottom:18px}
.step-card h3{font-size:1.22rem;font-weight:700;margin-bottom:10px}
.step-card p{font-size:.95rem;color:var(--slate);line-height:1.55}
.step-card ul{list-style:none;margin-top:12px;display:flex;flex-direction:column;gap:8px}
.step-card ul li{display:flex;gap:11px;font-size:.92rem;color:var(--ink)}
.step-card ul li::before{content:"";flex-shrink:0;width:6px;height:6px;border-radius:50%;background:var(--blue);margin-top:9px}
.help-note{margin-top:30px;display:inline-flex;align-items:center;gap:11px;background:var(--soft);border-radius:100px;
  padding:13px 22px;font-size:.9rem;color:var(--dark);font-weight:500}
.help-note .dot{width:7px;height:7px;border-radius:50%;background:var(--blue);flex-shrink:0}
@media (max-width:1000px){.steps-grid{grid-template-columns:1fr 1fr}}
@media (max-width:680px){.steps-grid{grid-template-columns:1fr}}

/* reusable feature cards (why-choose blocks on pillar pages) */
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:56px}
.feat{background:#fff;border:1px solid var(--frame);border-radius:20px;padding:32px 30px;box-shadow:var(--card-sm)}
.feat .ml{font-size:.68rem;font-weight:700;letter-spacing:.13em;text-transform:uppercase;color:var(--blue)}
.feat h3{font-size:1.24rem;font-weight:700;margin:12px 0 9px}
.feat p{font-size:.96rem;color:var(--slate);line-height:1.6}
@media(max-width:1000px){.feat-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:680px){.feat-grid{grid-template-columns:1fr}}

/* real brand logo in the nav */
.topbar .logo{flex-direction:row}
.logo-img{height:34px;width:auto;display:block}
@media (max-width:680px){.logo-img{height:30px}}

/* ---- Real-photo hero band (swap src for your own images later) ---- */
.hero-band{max-width:1200px;margin:-14px auto 8px;padding:0 24px}
.hero-band .frame{border-radius:24px;overflow:hidden;aspect-ratio:16/7;
  background:linear-gradient(150deg,#e9f2fd 0%,#c4d7ef 46%,#e6d6b9 100%);box-shadow:var(--card)}
.hero-band img{width:100%;height:100%;object-fit:cover;display:block}
@media(max-width:720px){.hero-band .frame{aspect-ratio:16/10}}

/* ---- Responsive video embed ---- */
.video-wrap{position:relative;width:100%;max-width:900px;margin:26px auto 0;aspect-ratio:16/9;
  border-radius:24px;overflow:hidden;box-shadow:var(--card);background:#0c1a33}
.video-wrap iframe{position:absolute;inset:0;width:100%;height:100%;border:0}

/* ---- DLS form styles ---- */
.form-card{max-width:720px;margin:0 auto;background:#fff;border:1px solid var(--frame);border-radius:24px;
  padding:34px 32px;box-shadow:var(--card)}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.form-row{display:flex;flex-direction:column;gap:7px}
.form-row.full{grid-column:1 / -1}
.form-row label{font-size:.82rem;font-weight:600;color:var(--ink)}
.form-row input,.form-row select,.form-row textarea{font:inherit;font-size:.95rem;color:var(--ink);
  background:#fff;border:1.5px solid var(--frame);border-radius:12px;padding:12px 14px;transition:border-color .2s}
.form-row input:focus,.form-row select:focus,.form-row textarea:focus{outline:none;border-color:var(--blue)}
.form-row textarea{min-height:120px;resize:vertical}
.form-card .btn{margin-top:6px}
.form-note{font-size:.82rem;color:var(--slate);margin-top:14px}
@media(max-width:640px){.form-grid{grid-template-columns:1fr}}

/* ---- Map embed ---- */
.mapframe{position:relative;width:100%;max-width:1000px;margin:0 auto;aspect-ratio:16/8;
  border-radius:24px;overflow:hidden;box-shadow:var(--card);background:#e9f2fd}
.mapframe iframe{position:absolute;inset:0;width:100%;height:100%;border:0}

/* ---- Local page area chips ---- */
.chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:22px}
.chip{font-size:.85rem;font-weight:600;color:var(--blue);background:#eaf1fe;border:1px solid #d3e2fd;
  border-radius:999px;padding:8px 15px}

/* ---- Blog cards ---- */
.blog-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:28px}
.blog-card{display:block;background:#fff;border:1px solid var(--frame);border-radius:20px;overflow:hidden;
  box-shadow:var(--card);transition:transform .3s var(--e2)}
.blog-card:hover{transform:translateY(-4px)}
.blog-card .bc-body{padding:24px 24px 28px}
.blog-card .bc-tag{font-size:.7rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--blue)}
.blog-card h3{margin:10px 0 8px;font-size:1.18rem;line-height:1.25}
.blog-card p{color:var(--slate);font-size:.95rem}
.post .prose h2{margin-top:34px}
.post .prose h3{margin-top:24px}
@media(max-width:720px){.blog-grid{grid-template-columns:1fr}}


/* footer polish */
.foot-brand .foot-tag{max-width:340px}
.foot-region{font-size:.9rem;font-weight:600;color:var(--ink);margin:2px 0 16px}
.foot-note{font-size:.86rem;color:var(--slate);margin-top:4px}
@media(max-width:900px){.foot-grid{grid-template-columns:1fr 1fr;gap:36px}}
@media(max-width:520px){.foot-grid{grid-template-columns:1fr}}

/* path cards */
.paths{display:grid;grid-template-columns:1fr 1fr;gap:22px;max-width:900px;margin:0 auto}
.path{background:#fff;border:1px solid var(--frame);border-radius:20px;padding:28px 26px;box-shadow:var(--card);display:flex;flex-direction:column;gap:8px}
.path .pk{font-size:.72rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--blue)}
.path h3{font-size:1.24rem;margin:2px 0 2px}
.path p{color:var(--slate);font-size:.95rem;flex:1}
.path .btn{margin-top:12px;align-self:flex-start}
@media(max-width:640px){.paths{grid-template-columns:1fr}}

/* ================= v2: mobile, footer, coverage, explore, drawer ================= */

/* Real images inside hero + partners media */
.hero-photo,.partners-media .ph{overflow:hidden}
.hero-photo img,.partners-media .ph img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.hero-photo{position:relative}
.partners-media .ph{position:relative}

/* hero stats -> 2x2 on mobile so nothing crams */
@media(max-width:680px){
  .hero-stats{grid-template-columns:1fr 1fr;gap:26px 0;margin-top:44px}
  .hero-stats .stat{padding:0 20px}
  .hero-stats .stat:nth-child(odd){padding-left:0;border-left:none}
  .hero-stats .num{font-size:1.5rem}
}
@media(max-width:680px){ .hero-grid{gap:34px} .hero .sub{font-size:1.06rem;margin-top:20px} }

/* ---- Coverage map ---- */
.coverage .wrap{display:grid;grid-template-columns:1fr 1.02fr;gap:56px;align-items:center}
.cov-figure{background:linear-gradient(160deg,#f4f8ff,#eaf1fb);border:1px solid var(--frame);border-radius:24px;padding:26px;box-shadow:var(--card-sm)}
.cov-map{width:100%;height:auto;display:block}
.cov-states{display:flex;flex-wrap:wrap;gap:10px;margin-top:26px}
.cov-chip{display:inline-flex;align-items:center;gap:8px;font-size:.92rem;font-weight:600;color:var(--ink);background:#fff;border:1px solid var(--frame);border-radius:999px;padding:9px 16px}
.cov-chip::before{content:"";width:11px;height:11px;border-radius:50%;background:var(--blue)}
.cov-note{margin-top:16px;font-size:.9rem;color:var(--slate)}
@media(max-width:860px){.coverage .wrap{grid-template-columns:1fr;gap:30px}}

/* ---- Explore more (findable pages) ---- */
.explore-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:44px}
.ex-card{display:flex;flex-direction:column;gap:5px;padding:24px 24px 26px;border:1px solid var(--frame);border-radius:18px;background:#fff;box-shadow:var(--card-sm);transition:transform .3s var(--e2),border-color .3s}
.ex-card:hover{transform:translateY(-4px);border-color:#cdd8ea}
.ex-card .ek{font-size:.7rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--blue)}
.ex-card h3{font-size:1.08rem;margin:3px 0 2px;line-height:1.25}
.ex-card p{font-size:.9rem;color:var(--slate);flex:1;line-height:1.5}
.ex-card .go{margin-top:10px;color:var(--blue);font-weight:600;font-size:.9rem}
@media(max-width:900px){.explore-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.explore-grid{grid-template-columns:1fr}}

/* ---- Footer redesign (v2) ---- */
.foot-top{display:grid;grid-template-columns:1.25fr 2fr;gap:56px;padding-bottom:50px;border-bottom:1px solid var(--frame)}
.foot-brand2 .foot-region{font-size:1.02rem;font-weight:600;color:var(--ink);line-height:1.55;margin:22px 0 0;max-width:330px}
.foot-brand2 .foot-contact{margin-top:20px}
.foot-social{display:flex;gap:10px;margin-top:22px}
.foot-social a{width:38px;height:38px;border:1px solid var(--frame);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:.78rem;font-weight:700;color:var(--slate);transition:.25s}
.foot-social a:hover{background:var(--blue);border-color:var(--blue);color:#fff}
.foot-links{display:grid;grid-template-columns:repeat(3,1fr);gap:34px}
.foot-bottom2{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;padding-top:26px;font-size:.85rem;color:var(--slate-2)}
.foot-bottom2 .fb-legal a{color:var(--slate-2)}.foot-bottom2 .fb-legal a:hover{color:var(--blue)}
@media(max-width:820px){.foot-top{grid-template-columns:1fr;gap:38px}}
@media(max-width:520px){.foot-links{grid-template-columns:1fr 1fr;gap:26px}.foot-brand2 .foot-region{max-width:none}}

/* ---- Mobile nav drawer ---- */
.mnav{position:fixed;inset:0;z-index:600;background:rgba(255,255,255,.98);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;flex-direction:column;padding:82px 30px 40px;transform:translateY(-101%);transition:transform .35s var(--e2);overflow-y:auto;visibility:hidden}
.mnav.open{transform:none;visibility:visible}
.mnav a{font-size:1.12rem;font-weight:600;color:var(--ink);padding:13px 0;border-bottom:1px solid var(--frame);text-decoration:none}
.mnav a:active{color:var(--blue)}
.mnav .mh{font-size:.7rem;letter-spacing:.15em;text-transform:uppercase;color:var(--slate-2);margin:24px 0 2px;font-weight:700}
.mnav .mcta{margin-top:26px;display:flex;flex-direction:column;gap:12px}
.mnav .mcta a{border:none;padding:14px 18px;border-radius:12px;text-align:center;font-weight:700}
.mnav .mcta .p{background:var(--blue);color:#fff}
.mnav .mcta .s{border:1.5px solid var(--frame);color:var(--ink)}
.mnav-close{position:absolute;top:22px;right:24px;background:none;border:none;font-size:2rem;line-height:1;color:var(--ink);cursor:pointer;padding:6px}
body.noscroll{overflow:hidden}

/* ================= v3: mobile spacing tighten + media sizing ================= */
@media(max-width:680px){
  .section{padding:48px 0 !important}
  .hero{padding:100px 0 34px !important}
  .hero h1{font-size:clamp(2.1rem,8vw,2.7rem)}
  .zig{gap:44px !important;margin-top:44px !important}
  .zrow{gap:22px !important}
  .hero-photo{aspect-ratio:4/3;max-height:300px}
  .hero-media{max-width:100% !important}
  .partners-media{max-width:100% !important}
  .partners-media .ph{min-height:220px !important;aspect-ratio:16/11}
  .hero-band{margin:2px auto 4px !important}
  .hero-band .frame{aspect-ratio:16/11}
  .coverage .wrap{gap:24px}
  .cov-figure{padding:16px}
  .sec-head h2,.partners-copy h2{font-size:clamp(1.7rem,6.5vw,2.1rem)}
  .scale-panel{padding:32px 24px !important}
  .cta{padding:60px 0 !important}
  .explore-grid{margin-top:26px}
  .zig .zmedia{max-height:260px}
}
/* keep zmedia from being a giant empty block if its bg image is decorative only */
@media(max-width:680px){
  .zrow .zmedia{aspect-ratio:16/11}
}

/* ================= v4: navy footer + partners mobile + spacing polish ================= */

/* ---- Clean navy footer ---- */
footer.site{background:#0f1c33;color:rgba(255,255,255,.62);border-top:none;padding:66px 0 32px}
.foot-main{display:grid;grid-template-columns:1.3fr 1.9fr;gap:64px;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.12)}
.foot-logo{font-size:1.4rem;font-weight:800;color:#fff;letter-spacing:-.01em;display:inline-block}
.foot-logo b{font-weight:500;color:rgba(255,255,255,.7)}
.foot-blurb{margin-top:16px;font-size:.97rem;line-height:1.65;color:rgba(255,255,255,.58);max-width:360px}
.foot-meta{margin-top:22px;display:flex;flex-direction:column;gap:9px;font-size:.93rem}
.foot-meta a{color:#fff;font-weight:600;width:fit-content;transition:color .2s}
.foot-meta a:hover{color:#8ab4ff}
.foot-meta span{color:rgba(255,255,255,.48)}
.foot-nav{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.foot-grp h6{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.85);margin:2px 0 14px;font-weight:700}
.foot-grp a{display:block;font-size:.95rem;color:rgba(255,255,255,.58);padding:6px 0;transition:color .2s}
.foot-grp a:hover{color:#fff}
.foot-end{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;padding-top:24px;font-size:.83rem;color:rgba(255,255,255,.42)}
.foot-soc{display:flex;gap:22px}
.foot-soc a{color:rgba(255,255,255,.58);font-size:.85rem;transition:color .2s}
.foot-soc a:hover{color:#fff}
@media(max-width:820px){.foot-main{grid-template-columns:1fr;gap:34px}.foot-nav{gap:24px}}
@media(max-width:560px){.foot-nav{grid-template-columns:1fr 1fr}.foot-end{flex-direction:column-reverse;align-items:flex-start;gap:16px}}

/* ---- Partners interactive box: show + place below list on mobile ---- */
@media(max-width:900px){
  .partners-media .ph{min-height:300px}
}
@media(max-width:680px){
  .partners-grid{gap:20px !important}
  .partners-media{order:2 !important;max-width:100% !important;margin:4px 0 0 !important}
  .partners-media .ph{min-height:210px !important;aspect-ratio:16/10}
  .aud-list{margin-top:24px}
  .aud-row{padding:16px 2px}
  .aud-row .an{font-size:1.08rem}
}

/* ---- Spacing polish (balanced, not bunched, not huge) ---- */
@media(max-width:680px){
  .section{padding:54px 0 !important}
  .hero{padding:96px 0 40px !important}
  .hero .sub{margin-top:18px}
  .hero .cta-row{margin-top:24px;gap:10px}
  .zig{gap:48px !important;margin-top:48px !important}
  .sec-head{margin-bottom:4px}
  .sec-head p{margin-top:12px}
  .feat-grid,.svc-grid,.steps-grid{gap:14px}
  .scale-panel{padding:34px 24px !important;gap:22px !important}
  .cta{padding:58px 0 !important}
  .testi-grid{gap:16px}
  .hero-photo{aspect-ratio:16/11;max-height:none}
}


/* coverage v5 — clean state cards (map removed) */
.coverage .wrap{display:block}
.coverage .sec-head{max-width:640px;margin-left:auto;margin-right:auto}
.cov-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:46px}
.cov-state{display:flex;flex-direction:column;gap:16px;background:#fff;border:1px solid var(--frame);border-radius:20px;padding:26px 24px;box-shadow:var(--card-sm);transition:transform .3s var(--e2),border-color .3s}
.cov-state:hover{transform:translateY(-4px);border-color:#cdd8ea}
.cs-abbr{width:54px;height:54px;border-radius:15px;background:linear-gradient(150deg,#2D6BE4,#1E54C2);color:#fff;font-weight:800;font-size:1.08rem;letter-spacing:.02em;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 22px -12px rgba(45,107,228,.7)}
.cov-state h3{font-size:1.12rem;margin:0 0 5px;color:var(--ink)}
.cov-state p{font-size:.9rem;color:var(--slate);line-height:1.55;margin:0}
.cov-note{text-align:center;margin-top:30px;font-size:.95rem;color:var(--slate)}
@media(max-width:900px){.cov-grid{grid-template-columns:1fr 1fr;gap:14px}}
@media(max-width:520px){.cov-grid{grid-template-columns:1fr}}

/* ================= footer v6 — light, authoritative, icon socials ================= */
footer.site{background:#fff;color:var(--slate);border-top:1px solid var(--frame);padding:58px 0 28px}
.foot-row{display:flex;justify-content:space-between;gap:56px;flex-wrap:wrap;padding-bottom:34px;border-bottom:1px solid var(--frame)}
.foot-brand3{max-width:380px}
.foot-brand3 .lg{height:34px;width:auto;display:block;margin-bottom:18px}
.foot-brand3 p{font-size:.94rem;line-height:1.65;color:var(--slate)}
.foot-links3{display:grid;grid-template-columns:1fr 1fr;gap:12px 44px;align-content:start}
.foot-links3 a{font-size:.95rem;color:var(--ink);font-weight:500;transition:color .2s}
.foot-links3 a:hover{color:var(--blue)}
.foot-base{display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;padding:24px 0}
.foot-contact3{display:flex;align-items:center;gap:12px;flex-wrap:wrap;font-size:.92rem}
.foot-contact3 a{color:var(--ink);font-weight:600;transition:color .2s}.foot-contact3 a:hover{color:var(--blue)}
.foot-contact3 span{color:var(--slate-2)}
.foot-soc3{display:flex;gap:11px}
.foot-soc3 a{width:38px;height:38px;border:1px solid var(--frame);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--slate);transition:.2s}
.foot-soc3 a svg{width:18px;height:18px}
.foot-soc3 a:hover{background:var(--blue);border-color:var(--blue);color:#fff}
.foot-legal{display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;padding-top:20px;border-top:1px solid var(--frame);font-size:.82rem;color:var(--slate-2)}
@media(max-width:700px){.foot-row{flex-direction:column;gap:28px}.foot-links3{gap:12px 30px}.foot-base{flex-direction:column;align-items:flex-start;gap:16px}}

/* footer legal links v7 */
.foot-legal{flex-wrap:wrap;gap:10px 20px}
.foot-legal-links{display:inline-flex;align-items:center;flex-wrap:wrap;gap:10px 18px}
.foot-legal-links a{color:var(--slate);text-decoration:none;opacity:.85;font-weight:500}
.foot-legal-links a:hover{color:var(--blue);opacity:1}

/* mobile drawer sub-items */
.mnav .msub{padding-left:22px;font-size:.95em;opacity:.82}

/* descriptive shot captions (AEO/SEO) */
.photo .tag.desc{right:14px;text-transform:none;letter-spacing:.005em;font-size:.6rem;font-weight:500;line-height:1.32;color:rgba(255,255,255,.94);background:rgba(20,24,34,.36)}

/* coverage map v9 — sizing */
.cov-map{max-width:440px;margin:8px auto 22px}
.cov-map svg{width:100%;height:auto;display:block}
@media(max-width:600px){.cov-map{max-width:360px}}

/* real photos in placeholder boxes */
.photo img.img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}

/* partners swatch images */
.partners-media .sw img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}

/* prose spacing (privacy / terms) */
.prose p{line-height:1.85;margin-top:22px;font-size:1.05rem}
.prose h2{margin-top:40px;margin-bottom:4px;font-size:1.42rem;line-height:1.3}
.prose h2:first-of-type{margin-top:8px}
.prose a{color:var(--blue)}

/* ordering "steps" — premium refresh */
.steps-grid{gap:22px;margin-top:46px}
.step-card{position:relative;padding:34px 26px 28px;transition:transform .25s var(--e2),box-shadow .25s var(--e2)}
.step-card::before{content:"";position:absolute;top:0;left:24px;right:24px;height:3px;border-radius:0 0 4px 4px;background:linear-gradient(90deg,var(--blue),#7aa2f0)}
.step-card:hover{transform:translateY(-5px);box-shadow:0 22px 46px -22px rgba(16,24,40,.28)}
.step-card .sn{width:50px;height:50px;background:var(--blue);color:#fff;font-weight:800;font-size:1.1rem;box-shadow:0 10px 22px -8px rgba(45,107,228,.55);margin-bottom:6px}
.step-card h3{font-size:1.28rem;margin-top:14px}

/* gallery finder (ordering search) */
.gf-search{max-width:560px;margin:26px auto 0}
.gf-input{width:100%;padding:16px 20px;border:1px solid var(--frame);border-radius:14px;font:inherit;font-size:1.02rem;background:#fff;box-shadow:var(--card-sm);transition:border-color .2s,box-shadow .2s}
.gf-input:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 4px rgba(45,107,228,.14)}
.gf-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(238px,1fr));gap:16px;margin-top:26px}
.gf-card{display:flex;flex-direction:column;gap:5px;background:#fff;border:1px solid var(--frame);border-radius:16px;padding:20px 20px 18px;box-shadow:var(--card-sm);text-decoration:none;color:var(--ink);transition:transform .2s var(--e2),box-shadow .2s var(--e2),border-color .2s}
.gf-card:hover{transform:translateY(-4px);box-shadow:0 20px 42px -22px rgba(16,24,40,.28);border-color:#cdd8ea}
.gf-card .dist{font-size:.68rem;text-transform:uppercase;letter-spacing:.09em;color:var(--blue);font-weight:700}
.gf-card h3{font-size:1.04rem;font-weight:700;line-height:1.25;margin:2px 0}
.gf-card .loc{font-size:.9rem;color:var(--slate)}
.gf-card .go{margin-top:10px;font-size:.88rem;font-weight:700;color:var(--blue)}
.gf-none{display:none;text-align:center;margin-top:24px;color:var(--slate);font-size:1rem}
@media(max-width:600px){.gf-grid{grid-template-columns:1fr 1fr;gap:12px}.gf-card{padding:16px}}

/* trusted-by logo strip */
.logostrip{padding:46px 0;border-top:1px solid var(--frame);border-bottom:1px solid var(--frame);background:#fff}
.ls-title{text-align:center;font-size:.8rem;text-transform:uppercase;letter-spacing:.12em;color:var(--slate-2);font-weight:700;margin-bottom:28px}
.ls-grid{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:28px 46px}
.ls-grid span{display:inline-flex;height:62px}
.ls-grid img{height:100%;width:auto;object-fit:contain;filter:grayscale(1);opacity:.6;transition:filter .25s,opacity .25s}
.ls-grid img:hover{filter:none;opacity:1}
@media(max-width:600px){.ls-grid{gap:18px 26px}.ls-grid span{height:46px}}

/* gallery finder logos */
.gf-logo{height:54px;display:flex;align-items:center;margin-bottom:8px}
.gf-logo img{max-height:54px;max-width:130px;width:auto;object-fit:contain}

/* partnerships: wider media panel + better image fit */
.partners-grid{grid-template-columns:0.9fr 1.2fr;gap:54px}
.partners-media .ph{min-height:560px}
.partners-media .sw img{object-position:center 30%}

/* coverage map image */
.cov-map{max-width:480px}
.cov-map img{width:100%;height:auto;display:block;border-radius:22px;box-shadow:0 24px 60px -30px rgba(45,107,228,.35),0 4px 14px -6px rgba(16,24,40,.12)}
