/* Kivulink v9 — Navy Brand | Multi-page */
:root {
  --navy:#1C2E4A; --navy-deep:#111E30; --navy-mid:#243A5E;
  --action:#F26522; --action-h:#D4541A;
  --gold:#C8973A; --wa:#25D366;
  --bg:#FFFFFF; --soft:#F4F6F9; --soft2:#EEF1F6;
  --text:#0D1B2A; --mid:#4A5568; --light:#8896A8; --border:#DDE3EC;
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;font-size:16px;-webkit-tap-highlight-color:transparent;}
body{font-family:"Outfit",sans-serif;background:var(--bg);color:var(--text);overflow-x:hidden;line-height:1.65;}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:200;height:66px;padding:0 40px;
  display:flex;justify-content:space-between;align-items:center;
  background:rgba(17,30,48,.98);backdrop-filter:blur(20px);
  border-bottom:1px solid rgba(255,255,255,.06);}
.nav-logo{display:flex;align-items:center;text-decoration:none;cursor:pointer;}
.nav-logo img{height:52px;width:auto;max-width:200px;object-fit:contain;transition:opacity .2s,transform .2s;filter:drop-shadow(0 1px 3px rgba(0,0,0,.18));}
.nav-logo:hover img{opacity:.9;transform:scale(1.03);}
.nav-menu{display:flex;gap:4px;list-style:none;align-items:center;}
.nav-menu a{color:rgba(255,255,255,.72);text-decoration:none;font-size:.8125rem;
  font-weight:500;padding:6px 12px;border-radius:6px;transition:all .2s;display:block;}
.nav-menu a:hover,.nav-menu a.active{color:white;background:rgba(255,255,255,.08);}
.nav-cta{background:var(--action)!important;color:white!important;
  padding:8px 18px!important;border-radius:8px!important;font-weight:700!important;}
.nav-cta:hover{background:var(--action-h)!important;}
.nav-right{display:flex;align-items:center;gap:10px;}
.lang-wrap{position:relative;}
.lang-btn{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);
  color:rgba(255,255,255,.85);padding:6px 11px;border-radius:7px;cursor:pointer;
  font-size:.8125rem;font-family:"Outfit",sans-serif;display:flex;align-items:center;gap:5px;transition:all .2s;}
.lang-btn:hover{background:rgba(255,255,255,.18);}
.lang-drop{display:none;position:absolute;top:calc(100% + 8px);right:0;
  background:var(--navy-deep);border:1px solid rgba(255,255,255,.1);
  border-radius:11px;padding:6px;min-width:200px;z-index:300;
  box-shadow:0 16px 48px rgba(0,0,0,.6);}
.lang-drop.open{display:block;animation:fadeDown .18s ease;}
@keyframes fadeDown{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
.lang-opt{display:flex;align-items:center;gap:9px;padding:9px 12px;border-radius:7px;
  cursor:pointer;text-decoration:none;transition:background .15s;}
.lang-opt:hover{background:rgba(255,255,255,.07);}
.lang-flag{font-size:1.125rem;}
.lang-name{font-size:.8125rem;font-weight:600;color:white;}
.lang-sub{font-size:.625rem;color:rgba(255,255,255,.38);}
.lang-opt.cur{background:rgba(242,101,34,.15);border:1px solid rgba(242,101,34,.2);}
.nav-ham{display:none;background:none;border:none;color:white;font-size:1.5rem;cursor:pointer;padding:4px;}
.mob-menu{display:none;position:fixed;inset:0;z-index:199;background:var(--navy-deep);
  padding:80px 24px 40px;flex-direction:column;gap:4px;overflow-y:auto;}
.mob-menu.open{display:flex;}
.mob-menu a{color:rgba(255,255,255,.8);text-decoration:none;font-size:1rem;
  font-weight:600;padding:13px 16px;border-bottom:1px solid rgba(255,255,255,.06);display:block;}
.mob-menu a:hover{color:white;}
.mob-menu .m-cta{background:var(--action);color:white!important;
  border-radius:10px;border:none;margin-top:10px;text-align:center;}

/* PAGE HERO */
.page-hero{background:var(--navy-deep);padding:118px 40px 72px;position:relative;overflow:hidden;}
.page-hero::before{content:"";position:absolute;inset:0;
  background:url("https://images.unsplash.com/photo-1573497019236-17f8177b81e8?auto=format&fit=crop&w=1200&q=50") center/cover;opacity:.05;}
.page-hero-inner{position:relative;z-index:1;max-width:860px;}
.page-crumb{font-size:.75rem;color:rgba(255,255,255,.4);margin-bottom:12px;}
.page-crumb a{color:rgba(255,255,255,.5);text-decoration:none;}
.page-crumb a:hover{color:white;}
.page-h1{font-size:clamp(2rem,5vw,3.125rem);font-weight:900;color:white;line-height:1.1;margin-bottom:12px;}
.page-h1 em{font-style:normal;color:var(--action);}
.page-sub{font-size:1rem;color:rgba(255,255,255,.65);line-height:1.7;max-width:620px;}

/* CONTAINER */
.container{max-width:1160px;margin:0 auto;padding:0 40px;}
.sec{padding:72px 40px;}
.sec.soft{background:var(--soft);}
.sec.navy{background:var(--navy-deep);}
.sec.navy-mid{background:var(--navy);}

/* TYPE */
.sec-label{font-size:.6875rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  color:var(--action);margin-bottom:8px;display:block;}
.sec-title{font-size:clamp(1.75rem,4vw,2.625rem);font-weight:800;color:var(--navy);line-height:1.15;margin-bottom:10px;}
.sec-title-light{color:white;}
.sec-sub{font-size:.9375rem;color:var(--mid);line-height:1.75;}
h3{font-size:1.125rem;font-weight:700;color:var(--navy);line-height:1.3;}
h4{font-size:.9375rem;font-weight:700;color:var(--navy);}
p{font-size:.9375rem;color:var(--mid);line-height:1.75;}
a{color:var(--action);}
a:hover{text-decoration:underline;}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:7px;padding:13px 24px;
  border-radius:10px;font-size:.9375rem;font-weight:700;text-decoration:none;
  transition:all .2s;font-family:"Outfit",sans-serif;border:none;cursor:pointer;
  white-space:nowrap;}
.btn-primary{background:var(--action);color:white;}
.btn-primary:hover{background:var(--action-h);transform:translateY(-2px);
  box-shadow:0 8px 24px rgba(242,101,34,.3);text-decoration:none;}
.btn-navy{background:var(--navy);color:white;}
.btn-navy:hover{background:var(--navy-deep);transform:translateY(-2px);text-decoration:none;}
.btn-wa{background:var(--wa);color:white;}
.btn-wa:hover{background:#1ebe5c;transform:translateY(-2px);text-decoration:none;}
.btn-ghost{background:rgba(255,255,255,.1);color:white;border:1.5px solid rgba(255,255,255,.2);}
.btn-ghost:hover{background:rgba(255,255,255,.18);text-decoration:none;}
.btn-outline{background:transparent;color:var(--navy);border:2px solid var(--navy);}
.btn-outline:hover{background:var(--navy);color:white;text-decoration:none;}
.btn-sm{padding:9px 18px;font-size:.875rem;}
.btn-lg{padding:16px 32px;font-size:1.0625rem;}

/* CARDS */
.card{background:white;border:1.5px solid var(--border);border-radius:16px;padding:28px;transition:all .3s;}
.card:hover{border-color:var(--navy);box-shadow:0 12px 32px rgba(28,46,74,.08);transform:translateY(-3px);}

/* STORY BOX */
.story-box{background:rgba(28,46,74,.05);border-left:4px solid var(--action);
  border-radius:0 12px 12px 0;padding:20px 24px;margin:24px 0;}
.story-label{font-size:.6875rem;font-weight:700;letter-spacing:.1em;
  text-transform:uppercase;color:var(--action);margin-bottom:8px;display:block;}
.story-box p{font-size:.9375rem;color:var(--text);line-height:1.75;}
.story-box strong{color:var(--navy);}

/* CALC BOX */
.calc-box{background:var(--soft);border-radius:16px;padding:28px;border:1.5px solid var(--border);margin:28px 0;}
.calc-box h4{margin-bottom:4px;}
.c-sub{font-size:.8125rem;color:var(--light);margin-bottom:16px;}
.calc-box label{display:block;font-size:.6875rem;font-weight:600;color:var(--mid);
  text-transform:uppercase;letter-spacing:.05em;margin-bottom:5px;margin-top:14px;}
.calc-box input,.calc-box select{width:100%;padding:12px 14px;border:1.5px solid var(--border);
  border-radius:9px;font-size:.9375rem;font-family:"Outfit",sans-serif;
  color:var(--text);background:white;outline:none;transition:border-color .2s;}
.calc-box input:focus,.calc-box select:focus{border-color:var(--action);}
.f2{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.calc-btn{margin-top:18px;padding:14px 28px;background:var(--navy);color:white;border:none;
  border-radius:10px;font-size:.9375rem;font-weight:700;font-family:"Outfit",sans-serif;
  cursor:pointer;transition:all .2s;width:100%;}
.calc-btn:hover{background:var(--navy-deep);}
.calc-result{display:none;margin-top:18px;padding:20px;background:white;
  border:2px solid var(--action);border-radius:12px;}
.res-num{font-size:2.25rem;font-weight:900;color:var(--action);line-height:1;}
.res-lbl{font-size:.8125rem;color:var(--mid);margin-top:4px;}
.res-det{font-size:.9375rem;color:var(--text);line-height:1.7;margin-top:10px;}
.res-disc{font-size:.6875rem;color:var(--light);margin-top:8px;font-style:italic;}

/* LINK GRID */
.link-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:20px 0;}
.dlink{display:flex;align-items:flex-start;gap:9px;padding:12px 14px;
  background:var(--soft);border:1px solid var(--border);border-radius:10px;
  text-decoration:none;transition:all .2s;}
.dlink:hover{border-color:var(--navy);background:white;transform:translateY(-1px);}
.dlink-ico{font-size:1rem;flex-shrink:0;margin-top:2px;}
.dlink strong{display:block;font-size:.8125rem;font-weight:700;color:var(--navy);}
.dlink span{font-size:.6875rem;color:var(--light);}

/* IMM DISCLAIMER */
.imm-disc{background:var(--soft);border-left:3px solid var(--gold);
  border-radius:0 9px 9px 0;padding:12px 16px;margin:16px 0;
  font-size:.8125rem;color:var(--mid);line-height:1.6;}
.imm-disc strong{color:var(--navy);}

/* LOGO GRID — static, for service pages */
.logo-grid{display:flex;flex-wrap:wrap;gap:14px;margin:20px 0;align-items:center;}
.lg-item{display:flex;align-items:center;justify-content:center;
  background:white;border:1px solid var(--border);border-radius:10px;
  padding:12px 20px;min-width:120px;height:64px;transition:all .2s;}
.lg-item:hover{border-color:var(--navy);box-shadow:0 4px 14px rgba(28,46,74,.08);}
.lg-item img{height:28px;width:auto;max-width:120px;object-fit:contain;
  filter:grayscale(.4) opacity(.8);transition:filter .2s;}
.lg-item:hover img{filter:grayscale(0) opacity(1);}
.logo-section-label{font-size:.6875rem;font-weight:700;letter-spacing:.12em;
  text-transform:uppercase;color:var(--light);margin-bottom:10px;margin-top:24px;display:block;}

/* LOGO MARQUEE — home only */
.logobar{background:var(--soft);padding:22px 0;border-bottom:1px solid var(--border);overflow:hidden;}
.lb-lbl{text-align:center;font-size:.625rem;font-weight:700;letter-spacing:.14em;
  text-transform:uppercase;color:var(--light);margin-bottom:14px;}
.lm-wrap{overflow:hidden;position:relative;}
.lm-wrap::before,.lm-wrap::after{content:"";position:absolute;top:0;bottom:0;width:80px;z-index:2;pointer-events:none;}
.lm-wrap::before{left:0;background:linear-gradient(to right,var(--soft),transparent);}
.lm-wrap::after{right:0;background:linear-gradient(to left,var(--soft),transparent);}
.lm-track{display:flex;align-items:center;width:max-content;animation:marquee 44s linear infinite;}
.lm-track:hover{animation-play-state:paused;}
.lm-item{flex-shrink:0;padding:0 22px;height:48px;display:flex;align-items:center;}
.lm-item img{height:26px;width:auto;max-width:100px;object-fit:contain;
  filter:grayscale(1) opacity(.45);transition:filter .3s,transform .2s;}
.lm-item img:hover{filter:grayscale(0) opacity(1);transform:scale(1.08);}

/* STATS */
.stats-row{background:var(--navy);display:grid;grid-template-columns:repeat(4,1fr);}
.stat{padding:24px 16px;text-align:center;border-right:1px solid rgba(255,255,255,.08);}
.stat:last-child{border-right:none;}
.stat-num{font-size:2.25rem;font-weight:900;color:var(--action);line-height:1;}
.stat-lbl{font-size:.625rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;
  color:rgba(255,255,255,.5);margin-top:5px;}

/* HOME SERVICE BLOCKS — image dominant, minimal text */
.svc-blocks{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:32px;}
.svc-block{border-radius:16px;overflow:hidden;position:relative;
  display:block;text-decoration:none;cursor:pointer;
  aspect-ratio:3/4;background:var(--navy-deep);}
.svc-block img{width:100%;height:100%;object-fit:cover;transition:transform .4s;display:block;}
.svc-block:hover img{transform:scale(1.05);}
.svc-block-overlay{position:absolute;inset:0;
  background:linear-gradient(to top,rgba(17,30,48,.95) 0%,rgba(17,30,48,.4) 60%,transparent 100%);}
.svc-block-body{position:absolute;bottom:0;left:0;right:0;padding:20px 18px;}
.svc-block-badge{display:inline-block;background:var(--action);color:white;
  font-size:.625rem;font-weight:700;padding:3px 8px;border-radius:99px;margin-bottom:8px;}
.svc-block-name{font-size:1rem;font-weight:800;color:white;line-height:1.2;margin-bottom:10px;}
.svc-block-cta{display:inline-flex;align-items:center;gap:5px;
  background:rgba(255,255,255,.15);backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.25);color:white;
  padding:7px 13px;border-radius:7px;font-size:.75rem;font-weight:700;transition:all .2s;}
.svc-block:hover .svc-block-cta{background:var(--action);border-color:var(--action);}

/* SERVICES OVERVIEW (services.html) */
.svc-ov-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-top:28px;}
.svc-ov-card{border-radius:18px;overflow:hidden;background:white;border:1.5px solid var(--border);
  text-decoration:none;display:block;transition:all .3s;}
.svc-ov-card:hover{border-color:var(--navy);box-shadow:0 16px 40px rgba(28,46,74,.1);transform:translateY(-4px);}
.svc-ov-img{width:100%;height:200px;object-fit:cover;display:block;}
.svc-ov-body{padding:22px;}
.svc-ov-badge{display:inline-block;background:var(--action);color:white;
  font-size:.6875rem;font-weight:700;padding:4px 10px;border-radius:99px;margin-bottom:10px;}
.svc-ov-hook{font-size:.9375rem;font-weight:700;color:var(--mid);margin-bottom:4px;font-style:italic;}
.svc-ov-name{font-size:1.125rem;font-weight:800;color:var(--navy);margin-bottom:8px;}
.svc-ov-teaser{font-size:.875rem;color:var(--mid);line-height:1.65;margin-bottom:14px;}
.svc-ov-link{font-size:.8125rem;font-weight:700;color:var(--action);display:inline-flex;align-items:center;gap:4px;}

/* WHO WE SERVE */
.serve-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;}
.serve-cards-col{display:flex;flex-direction:column;gap:12px;}
.serve-card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);
  border-left:3px solid var(--action);padding:14px 18px;border-radius:0 10px 10px 0;}
.serve-card strong{display:block;font-size:.875rem;color:white;margin-bottom:3px;}
.serve-card p{font-size:.8125rem;color:rgba(255,255,255,.55);line-height:1.55;}
.lang-pills{display:flex;flex-wrap:wrap;gap:6px;margin-top:16px;}
.lang-pill{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);
  color:rgba(255,255,255,.82);padding:7px 12px;font-size:.8125rem;border-radius:8px;
  display:flex;align-items:center;gap:6px;}

/* REVIEWS */
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:24px;}
.rev-card{background:var(--soft);border:1px solid var(--border);border-radius:14px;padding:22px;}
.rev-card.dark{background:var(--navy);border-color:rgba(242,101,34,.2);}
.r-stars{color:#F4B400;font-size:1rem;letter-spacing:1px;margin-bottom:10px;}
.r-quote{font-size:.9375rem;font-weight:600;color:var(--navy);font-style:italic;line-height:1.55;margin-bottom:12px;}
.rev-card.dark .r-quote{color:rgba(255,255,255,.88);}
.r-name{font-size:.8125rem;font-weight:700;color:var(--navy);}
.rev-card.dark .r-name{color:white;}
.r-loc{font-size:.6875rem;color:var(--light);}
.rev-card.dark .r-loc{color:rgba(255,255,255,.4);}
.r-badge{display:inline-flex;align-items:center;gap:4px;font-size:.625rem;
  font-weight:600;color:var(--light);background:var(--soft);border:1px solid var(--border);
  border-radius:4px;padding:2px 7px;margin-top:4px;}
.rev-card.dark .r-badge{background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.1);color:rgba(255,255,255,.35);}
.rev-invite{border:2px dashed var(--border);border-radius:14px;padding:28px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;gap:10px;background:white;}

/* CTA BANNER */
.cta-banner{background:var(--navy-deep);padding:72px 40px;text-align:center;position:relative;overflow:hidden;}
.cta-banner::before{content:"";position:absolute;inset:0;
  background:radial-gradient(ellipse at center,rgba(242,101,34,.08) 0%,transparent 70%);}
.cta-banner-inner{position:relative;z-index:1;max-width:660px;margin:0 auto;}
.cta-banner h2{font-size:clamp(1.75rem,4vw,2.625rem);font-weight:800;color:white;margin-bottom:12px;}
.cta-banner p{font-size:1rem;color:rgba(255,255,255,.6);margin-bottom:28px;line-height:1.7;}
.cta-btns{display:flex;justify-content:center;flex-wrap:wrap;gap:12px;}

/* FLOAT WA */
.float-wa{position:fixed;bottom:28px;right:24px;z-index:198;width:56px;height:56px;
  background:var(--wa);border-radius:50%;display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 20px rgba(37,211,102,.45);text-decoration:none;
  animation:popIn .4s 1s ease both;transition:transform .2s;}
.float-wa:hover{transform:scale(1.12);}
.float-wa svg{width:26px;height:26px;fill:white;}
.float-wa-tooltip{position:absolute;right:calc(100% + 10px);
  background:var(--navy-deep);color:white;font-size:.75rem;font-weight:600;
  padding:6px 11px;border-radius:7px;white-space:nowrap;
  opacity:0;pointer-events:none;transition:opacity .2s;}
.float-wa:hover .float-wa-tooltip{opacity:1;}

/* FOOTER */
footer{background:var(--navy-deep);border-top:1px solid rgba(255,255,255,.06);padding:52px 40px 32px;}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px;margin-bottom:40px;}
.footer-logo{display:flex;align-items:center;text-decoration:none;margin-bottom:14px;cursor:pointer;}
.footer-logo img{height:36px;width:auto;transition:opacity .2s;}
.footer-logo:hover img{opacity:.8;}
.footer-tagline{font-size:.8125rem;color:rgba(255,255,255,.45);line-height:1.65;margin-bottom:14px;}
.footer-contact a{display:flex;align-items:center;gap:6px;font-size:.8125rem;
  color:rgba(255,255,255,.55);text-decoration:none;margin-bottom:8px;transition:color .2s;}
.footer-contact a:hover{color:white;}
.footer-col h5{font-size:.6875rem;font-weight:700;letter-spacing:.12em;
  text-transform:uppercase;color:rgba(255,255,255,.4);margin-bottom:14px;}
.footer-col a{display:block;font-size:.8125rem;color:rgba(255,255,255,.55);
  text-decoration:none;margin-bottom:8px;transition:color .2s;}
.footer-col a:hover{color:white;}
.footer-bottom{border-top:1px solid rgba(255,255,255,.07);padding-top:24px;
  display:flex;justify-content:space-between;align-items:flex-start;gap:20px;flex-wrap:wrap;}
.footer-copy{font-size:.6875rem;color:rgba(255,255,255,.22);}
.footer-disc{font-size:.6rem;color:rgba(255,255,255,.18);line-height:1.65;max-width:560px;text-align:right;}

/* ANIMATIONS */
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@keyframes popIn{from{opacity:0;transform:scale(.4)}to{opacity:1;transform:scale(1)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}

@media(max-width:900px){
  nav{padding:0 16px;height:60px;}
  .nav-menu{display:none;}
  .nav-ham{display:block;}
  .page-hero{padding:88px 20px 52px;}
  .sec{padding:48px 20px;}
  .container{padding:0 20px;}
  .svc-blocks{grid-template-columns:repeat(2,1fr);gap:12px;}
  .svc-block{aspect-ratio:4/5;}
  .svc-ov-grid{grid-template-columns:1fr;}
  .serve-grid{grid-template-columns:1fr;gap:36px;}
  .rev-grid{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr 1fr;}
  .footer-bottom{flex-direction:column;}
  .footer-disc{text-align:left;max-width:100%;}
  .f2{grid-template-columns:1fr;}
  .link-grid{grid-template-columns:1fr;}
  .cta-banner{padding:52px 20px;}
  .stats-row{grid-template-columns:repeat(2,1fr);}
  .float-wa{bottom:16px;right:16px;width:52px;height:52px;}
  footer{padding:40px 20px 28px;}
  .logo-grid{gap:10px;}
  .lg-item{min-width:100px;padding:10px 14px;height:56px;}
}

/* ── CARRIER LOGOS ── */
.carrier-section{margin:32px 0;}
.carrier-label{font-size:.6875rem;font-weight:700;letter-spacing:.12em;
  text-transform:uppercase;color:var(--light);margin-bottom:16px;display:block;}
.carrier-sublabel{font-size:.625rem;font-weight:600;letter-spacing:.1em;
  text-transform:uppercase;color:var(--action);margin:14px 0 8px;display:block;}

/* Default: 3-column grid, clean and readable */
.carrier-logos{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;}
@media(max-width:640px){.carrier-logos{grid-template-columns:repeat(2,1fr);}}

/* Marquee override — used on pages that add .carrier-logos-track inside */
.carrier-logos-marquee{
  display:block;overflow:hidden;
  -webkit-mask-image:linear-gradient(to right,transparent 0,black 8%,black 92%,transparent 100%);
  mask-image:linear-gradient(to right,transparent 0,black 8%,black 92%,transparent 100%);
}
.carrier-logos-track{
  display:flex;gap:14px;align-items:center;
  width:max-content;
  animation:clScroll 30s linear infinite;
}
.carrier-logos-track:hover{animation-play-state:paused;}
@keyframes clScroll{from{transform:translateX(0);}to{transform:translateX(-50%);}}.cl-item{
  background:white;border:1.5px solid var(--border);border-radius:10px;
  padding:12px 16px;display:flex;align-items:center;justify-content:center;
  height:68px;transition:all .25s;
}
.cl-item:hover{border-color:var(--navy);box-shadow:0 4px 14px rgba(28,46,74,.1);}
.cl-item img{height:36px;width:auto;max-width:120px;object-fit:contain;
  filter:grayscale(.2);transition:filter .2s;}
.cl-item:hover img{filter:grayscale(0);}

/* ── Services nav dropdown ── */
.nav-has-drop{position:relative;}
.nav-drop-toggle{display:flex;align-items:center;gap:4px;cursor:pointer;}
.nav-drop{
  display:none;
  position:absolute;top:calc(100% + 8px);left:0;
  background:var(--navy-deep);
  border:1px solid rgba(255,255,255,0.1);
  border-radius:12px;padding:6px;
  min-width:220px;z-index:500;
  box-shadow:0 16px 48px rgba(0,0,0,0.5);
  list-style:none;
}
.nav-has-drop:hover .nav-drop,
.nav-has-drop:focus-within .nav-drop{display:block;}
.nav-drop li a{
  display:block;padding:10px 14px;border-radius:8px;
  font-size:.8125rem;font-weight:500;color:rgba(255,255,255,.78);
  text-decoration:none;transition:all .15s;white-space:nowrap;
}
.nav-drop li a:hover{background:rgba(255,255,255,.08);color:white;}

/* ============================================================
   KIVULINK MOBILE-FIRST RESPONSIVE PATCH
   Fixes: hero, nav, service cards, sticky bar, touch targets,
   form, stats, carrier logos, footer, pc-grid, svc-blocks
   ============================================================ */

/* ── Sticky mobile contact bar ── */
.mob-sticky{
  display:none;
  position:fixed;bottom:0;left:0;right:0;z-index:300;
  background:var(--navy-deep);
  border-top:1px solid rgba(255,255,255,.1);
  padding:10px 16px 10px;
  gap:10px;
  padding-bottom:max(10px, env(safe-area-inset-bottom));
}
.mob-sticky a{
  flex:1;display:flex;align-items:center;justify-content:center;gap:7px;
  padding:14px 8px;border-radius:10px;
  font-size:.9375rem;font-weight:700;text-decoration:none;
  min-height:48px;
}
.mob-sticky .ms-call{background:var(--action);color:white;}
.mob-sticky .ms-wa{background:var(--wa);color:white;}

/* ── Touch target minimum 48px ── */
.btn{min-height:48px;padding:13px 24px;}
.btn-sm{min-height:44px;}
.nav-drop li a{min-height:44px;display:flex;align-items:center;}

/* ── Clamp headings so they never overflow ── */
.hero-h1{font-size:clamp(1.75rem,8vw,3.75rem);}
.page-h1{font-size:clamp(1.5rem,6vw,3.125rem);}
.sec-title{font-size:clamp(1.375rem,5vw,2.625rem);}

/* ── Max-width container for ultra-wide screens ── */
.container{max-width:1200px;}
.sec{max-width:100%;}

@media(max-width:900px){

  /* ── Show sticky bar ── */
  .mob-sticky{display:flex;}

  /* ── Push float-wa above sticky bar ── */
  .float-wa{bottom:80px;right:16px;}

  /* ── Nav ── */
  nav{padding:0 16px;height:60px;}
  .nav-menu{display:none;}
  .nav-ham{display:flex;align-items:center;justify-content:center;
    width:44px;height:44px;border-radius:8px;background:rgba(255,255,255,.08);}
  .nav-has-drop{display:none;} /* dropdown only on desktop */

  /* ── Hero ── */
  .hero{min-height:100svh;min-height:100vh;align-items:flex-end;}
  .hero-bg{background-position:center top;}
  .hero-inner{
    grid-template-columns:1fr!important;
    gap:24px;
    padding:0 20px 80px; /* space for sticky bar */
  }
  .hero-photo-col{display:none!important;}
  .hero-form{
    border-radius:16px;
    padding:20px 16px;
    box-shadow:0 8px 32px rgba(0,0,0,.3);
  }
  .hero-h1{font-size:clamp(1.75rem,7vw,2.5rem);letter-spacing:-.01em;}
  .hero-sub{font-size:.9375rem;margin-bottom:20px;}
  .hero-ctas{flex-direction:column;gap:10px;}
  .hero-ctas .btn{width:100%;justify-content:center;min-height:52px;}

  /* ── Stats ── */
  .stats-row{grid-template-columns:repeat(2,1fr);}
  .stat{padding:20px 12px;}
  .stat-num{font-size:1.875rem;}

  /* ── Service blocks on home ── */
  .svc-blocks{grid-template-columns:repeat(2,1fr);gap:10px;}
  .svc-block{aspect-ratio:3/4;border-radius:14px;}
  .svc-block-name{font-size:.875rem;}

  /* ── Service overview cards ── */
  .svc-ov-grid{grid-template-columns:1fr;}
  .svc-ov-card{border-radius:14px;}
  .svc-ov-img{height:180px;}

  /* ── Who we serve ── */
  .serve-grid{grid-template-columns:1fr;gap:28px;}
  .serve-inner{grid-template-columns:1fr;gap:28px;}

  /* ── Reviews ── */
  .rev-grid{grid-template-columns:1fr;}

  /* ── Carrier logos: 2-col grid on mobile ── */
  .carrier-logos{grid-template-columns:repeat(2,1fr);gap:8px;}
  .cl-item{height:56px;padding:10px 12px;}
  .cl-item img{height:30px;}
  /* marquee: pause and stack on very small screens */
  .carrier-logos-marquee{overflow:hidden;}
  .carrier-logos-track{animation-duration:22s;}

  /* ── Form inputs ── */
  .fg input,.fg select,.calc-box input,.calc-box select{
    font-size:1rem; /* prevents iOS zoom on focus */
    padding:14px 16px;
    min-height:48px;
  }
  .f2{grid-template-columns:1fr;}
  .hf-s2 .fg,.hf-s .fg{margin-bottom:14px;}

  /* ── Page hero ── */
  .page-hero{padding:84px 20px 48px;}
  .page-hero-inner{max-width:100%;}
  .page-h1{font-size:clamp(1.5rem,6vw,2.5rem);}
  .page-sub{font-size:.9375rem;}

  /* ── Content sections ── */
  .sec{padding:44px 20px;}
  .container{padding:0 16px;}
  .two-col{grid-template-columns:1fr!important;gap:28px;}

  /* ── CTA banner ── */
  .cta-banner{padding:44px 20px;}
  .cta-btns{flex-direction:column;align-items:center;}
  .cta-btns .btn{width:100%;max-width:320px;justify-content:center;}

  /* ── Footer ── */
  .footer-grid{grid-template-columns:1fr;}
  footer{padding:36px 20px 100px;} /* space for sticky bar */
  .footer-bottom{flex-direction:column;gap:12px;}
  .footer-disc{text-align:left;max-width:100%;}

  /* ── Story box ── */
  .story-box{padding:16px 18px;}

  /* ── Link grid ── */
  .link-grid{grid-template-columns:1fr;}

  /* ── pc-grid (services.html P&C card) ── */
  .pc-grid,.svc-pc-grid{grid-template-columns:1fr!important;}
  .pc-grid img,.svc-pc-grid img{height:200px;object-fit:cover;width:100%;}

  /* ── Founder section ── */
  .founder-grid{grid-template-columns:1fr!important;gap:28px;}
  .founder-photo{max-width:220px;margin:0 auto;}
}

@media(max-width:480px){
  /* ── Extra small phones ── */
  .hero-h1{font-size:1.75rem;}
  .svc-blocks{grid-template-columns:1fr;max-width:320px;margin-left:auto;margin-right:auto;}
  .svc-block{aspect-ratio:16/9;}
  .stat-num{font-size:1.625rem;}
  .carrier-logos{grid-template-columns:repeat(2,1fr);}
  .page-h1{font-size:1.5rem;}
  .btn-lg{padding:14px 24px;font-size:1rem;}
}

/* ── Desktop: prevent ultra-wide stretch ── */
@media(min-width:1280px){
  .container{max-width:1200px;}
  .hero-inner{max-width:1200px;}
}
@media(min-width:1600px){
  .container{max-width:1320px;}
  .hero-inner{max-width:1320px;}
  .sec{padding:88px 40px;}
}
