/* ============ be Cold — Design System ============ */
:root{
  /* Brand (sampled from logo) */
  --blue:#0A9CE8;        /* snowflake sky */
  --blue-600:#0879C9;
  --blue-700:#0A5FB0;    /* "Cold" base */
  --navy:#0A2438;        /* deep section bg */
  --navy-2:#0E314B;
  --bolt:#FFC500;        /* lightning */
  --bolt-600:#F2A900;

  /* Neutrals (cool-toned) */
  --ink:#15181D;
  --ink-2:#2A3038;
  --slate:#566270;
  --slate-2:#8A95A3;
  --line:#E5ECF3;
  --line-2:#EEF3F8;
  --bg:#FFFFFF;
  --bg-cool:#F1F6FB;
  --bg-cool-2:#E9F2FA;

  --r:14px;
  --r-lg:22px;
  --r-sm:10px;
  --shadow:0 1px 2px rgba(16,40,64,.04), 0 12px 32px -12px rgba(16,40,64,.14);
  --shadow-lg:0 24px 60px -22px rgba(10,60,110,.30);
  --container:1200px;
  --ease:cubic-bezier(.22,.61,.36,1);

  --font-display:"Sora",system-ui,sans-serif;
  --font-body:"Manrope",system-ui,sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--bg);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
section{scroll-margin-top:96px}

.container{max-width:var(--container);margin:0 auto;padding:0 28px}

/* ---------- Type ---------- */
h1,h2,h3,h4{font-family:var(--font-display);font-weight:700;line-height:1.08;letter-spacing:-.02em;color:var(--ink)}
.eyebrow{
  font-family:var(--font-body);font-weight:700;font-size:13px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--blue-700);display:inline-flex;align-items:center;gap:9px;
}
.eyebrow::before{content:"";width:22px;height:2px;background:var(--bolt);border-radius:2px}
.h-sec{font-size:clamp(30px,4vw,46px)}
.lede{font-size:clamp(16px,1.4vw,19px);color:var(--slate);max-width:58ch}
.text-wrap{text-wrap:balance}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-family:var(--font-display);font-weight:600;font-size:15px;
  padding:14px 24px;border-radius:999px;border:1.5px solid transparent;
  cursor:pointer;transition:transform .18s var(--ease),box-shadow .25s var(--ease),background .2s,color .2s,border-color .2s;
  white-space:nowrap;
}
.btn svg{width:18px;height:18px}
.btn-bolt{background:var(--bolt);color:var(--ink);box-shadow:0 10px 22px -10px rgba(242,169,0,.7)}
.btn-bolt:hover{background:var(--bolt-600);transform:translateY(-2px);box-shadow:0 16px 30px -12px rgba(242,169,0,.8)}
.btn-blue{background:var(--blue-700);color:#fff;box-shadow:0 10px 24px -12px rgba(10,95,176,.7)}
.btn-blue:hover{background:var(--blue-600);transform:translateY(-2px)}
.btn-outline{background:transparent;border-color:var(--line);color:var(--ink)}
.btn-outline:hover{border-color:var(--blue);color:var(--blue-700);transform:translateY(-2px)}
.btn-ghost-light{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.25);color:#fff}
.btn-ghost-light:hover{background:rgba(255,255,255,.16);transform:translateY(-2px)}
.btn-lg{padding:17px 30px;font-size:16px}

/* ---------- Top utility bar ---------- */
.topbar{background:var(--navy);color:#cfe0ee;font-size:13.5px}
.topbar .container{display:flex;align-items:center;justify-content:space-between;height:42px}
.topbar .t-left{display:flex;align-items:center;gap:22px}
.topbar .t-item{display:flex;align-items:center;gap:7px}
.topbar .t-item svg{width:15px;height:15px;color:var(--blue)}
.topbar .t-right{display:flex;align-items:center;gap:18px}
.topbar a:hover{color:#fff}
.t-divider{width:1px;height:16px;background:rgba(255,255,255,.18)}
@media(max-width:860px){.topbar .t-left{display:none}.topbar .container{justify-content:center}}

/* ---------- Header ---------- */
.header{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.86);backdrop-filter:blur(12px);
  border-bottom:1px solid transparent;transition:box-shadow .25s,border-color .25s}
.header.scrolled{box-shadow:0 8px 28px -16px rgba(16,40,64,.22);border-color:var(--line)}
.header .container{display:flex;align-items:center;justify-content:space-between;height:78px;gap:24px}
.brand img{height:46px;width:auto}
.nav{display:flex;align-items:center;gap:30px}
.nav a{font-weight:600;font-size:15px;color:var(--ink-2);position:relative;padding:6px 0}
.nav a::after{content:"";position:absolute;left:0;bottom:-2px;height:2px;width:0;background:var(--blue);transition:width .25s var(--ease)}
.nav a:hover{color:var(--blue-700)}
.nav a:hover::after{width:100%}
.header-cta{display:flex;align-items:center;gap:14px}
.header-phone{display:flex;align-items:center;gap:9px;font-family:var(--font-display);font-weight:700;font-size:16px;color:var(--ink)}
.header-phone svg{width:18px;height:18px;color:var(--blue-700)}
.hamburger{display:none;background:none;border:0;cursor:pointer;width:44px;height:44px;align-items:center;justify-content:center}
.hamburger svg{width:26px;height:26px;color:var(--ink)}
@media(max-width:1140px){.header-phone{display:none}}
@media(max-width:900px){.nav{display:none}.hamburger{display:flex}}

/* Mobile menu */
.mobile-menu{position:fixed;inset:0 0 0 auto;width:min(86vw,380px);background:#fff;z-index:90;
  transform:translateX(100%);transition:transform .35s var(--ease);box-shadow:var(--shadow-lg);
  display:flex;flex-direction:column;padding:24px}
.mobile-menu.open{transform:translateX(0)}
.mm-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.mm-head img{height:38px}
.mm-close{background:none;border:0;cursor:pointer;width:42px;height:42px}
.mm-close svg{width:24px;height:24px}
.mobile-menu nav{display:flex;flex-direction:column;gap:4px;margin-top:8px}
.mobile-menu nav a{padding:14px 6px;font-family:var(--font-display);font-weight:600;font-size:18px;border-bottom:1px solid var(--line-2)}
.mm-cta{margin-top:22px;display:flex;flex-direction:column;gap:12px}
.overlay{position:fixed;inset:0;background:rgba(8,24,40,.42);opacity:0;visibility:hidden;transition:.3s;z-index:80}
.overlay.show{opacity:1;visibility:visible}

/* ---------- Placeholder image ---------- */
.ph{position:relative;background:
  repeating-linear-gradient(45deg,#dde8f1,#dde8f1 11px,#e7eff6 11px,#e7eff6 22px);
  border:1px solid var(--line);border-radius:var(--r);overflow:hidden;
  display:flex;align-items:center;justify-content:center}
.ph span{font-family:ui-monospace,"SF Mono",monospace;font-size:12.5px;letter-spacing:.03em;
  color:#6f8295;background:rgba(255,255,255,.72);padding:7px 12px;border-radius:7px;text-align:center}
.ph.dark{background:repeating-linear-gradient(45deg,#0e314b,#0e314b 11px,#123a59 11px,#123a59 22px);border-color:rgba(255,255,255,.1)}
.ph.dark span{color:#9fc1dc;background:rgba(8,24,40,.5)}

/* ---------- Hero ---------- */
.hero{position:relative;background:
  radial-gradient(1100px 520px at 88% -8%,var(--bg-cool-2),transparent 60%),
  linear-gradient(180deg,#fff, #fff 55%, var(--bg-cool));overflow:hidden}
.hero .container{display:grid;grid-template-columns:1.06fr .94fr;gap:56px;align-items:center;
  padding-top:72px;padding-bottom:80px}
.hero h1{font-size:clamp(38px,5.2vw,62px);font-weight:800}
.hero h1 .grad{background:linear-gradient(180deg,var(--blue),var(--blue-700));-webkit-background-clip:text;background-clip:text;color:transparent}
.hero .lede{margin-top:20px}
.hero-cta{display:flex;gap:14px;margin-top:32px;flex-wrap:wrap}
.hero-trust{display:flex;align-items:center;gap:22px;margin-top:34px;flex-wrap:wrap}
.stars{display:flex;gap:2px;color:var(--bolt)}
.stars svg{width:18px;height:18px}
.trust-chip{display:flex;align-items:center;gap:9px;font-size:14px;color:var(--slate);font-weight:600}
.trust-chip svg{width:18px;height:18px;color:var(--blue-700)}
.hero-media{position:relative}
.hero-media .ph{aspect-ratio:4/4.4;border-radius:var(--r-lg);box-shadow:var(--shadow-lg)}
.float-card{position:absolute;background:#fff;border-radius:16px;box-shadow:var(--shadow-lg);
  padding:16px 18px;display:flex;align-items:center;gap:13px;border:1px solid var(--line)}
.float-card .fc-ico{width:46px;height:46px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.float-card .fc-ico svg{width:24px;height:24px}
.float-card .fc-k{font-family:var(--font-display);font-weight:700;font-size:18px;line-height:1.1}
.float-card .fc-v{font-size:12.5px;color:var(--slate);font-weight:600}
.fc-a{top:26px;left:-26px}
.fc-b{bottom:30px;right:-24px}
.fc-snow{position:absolute;top:-18px;right:30px;width:80px;height:80px;color:var(--blue);opacity:.16}
@media(max-width:860px){
  .hero .container{grid-template-columns:1fr;gap:38px;padding-top:44px;padding-bottom:56px}
  .hero-media .ph{aspect-ratio:16/10}
  .fc-a{left:14px}.fc-b{right:14px}
}

/* ---------- Stats band ---------- */
.stats{background:linear-gradient(110deg,var(--blue-700),var(--blue));color:#fff;position:relative;overflow:hidden}
.stats::after{content:"";position:absolute;inset:0;background:
  radial-gradient(600px 200px at 90% 120%,rgba(255,255,255,.16),transparent)}
.stats .container{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;padding:40px 28px;position:relative;z-index:1}
.stat{display:flex;flex-direction:column;gap:3px}
.stat .num{font-family:var(--font-display);font-weight:800;font-size:clamp(30px,3.4vw,42px);line-height:1}
.stat .num b{color:var(--bolt)}
.stat .lbl{font-size:14px;color:#d6e9f7;font-weight:600}
@media(max-width:760px){.stats .container{grid-template-columns:repeat(2,1fr);gap:28px}}

/* ---------- Section base ---------- */
.sec{padding:96px 0}
.sec-head{max-width:720px;margin-bottom:48px}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
.sec-head .h-sec{margin-top:16px}
.sec-head p{margin-top:16px}

/* ---------- Services grid ---------- */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.svc-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:30px;
  transition:transform .25s var(--ease),box-shadow .3s var(--ease),border-color .25s;position:relative;overflow:hidden}
.svc-card::before{content:"";position:absolute;left:0;top:0;height:4px;width:0;background:linear-gradient(90deg,var(--blue),var(--blue-700));transition:width .35s var(--ease)}
.svc-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:transparent}
.svc-card:hover::before{width:100%}
.svc-ico{width:58px;height:58px;border-radius:16px;background:var(--bg-cool);display:flex;align-items:center;justify-content:center;margin-bottom:20px;transition:.25s}
.svc-ico svg{width:28px;height:28px;color:var(--blue-700);transition:.25s}
.svc-card:hover .svc-ico{background:var(--blue-700)}
.svc-card:hover .svc-ico svg{color:#fff}
.svc-card h3{font-size:21px;margin-bottom:10px}
.svc-card p{color:var(--slate);font-size:15px;margin-bottom:18px}
.svc-link{font-family:var(--font-display);font-weight:600;font-size:14px;color:var(--blue-700);display:inline-flex;align-items:center;gap:7px}
.svc-link svg{width:15px;height:15px;transition:transform .2s}
.svc-card:hover .svc-link svg{transform:translateX(4px)}
.svc-card.feature{background:linear-gradient(150deg,var(--navy),var(--navy-2));border-color:transparent;color:#fff}
.svc-card.feature h3{color:#fff}.svc-card.feature p{color:#b9d3e6}
.svc-card.feature .svc-ico{background:rgba(255,255,255,.1)}
.svc-card.feature .svc-ico svg{color:var(--bolt)}
.svc-card.feature .svc-link{color:var(--bolt)}
.svc-card.feature::before{background:var(--bolt)}
.svc-card.feature .badge-24{position:absolute;top:24px;right:24px;background:var(--bolt);color:var(--ink);
  font-family:var(--font-display);font-weight:700;font-size:12px;padding:5px 11px;border-radius:999px}
@media(max-width:980px){.svc-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.svc-grid{grid-template-columns:1fr}}

/* ---------- Why us (split) ---------- */
.why{background:var(--bg-cool)}
.split{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.split .ph{aspect-ratio:5/4.6;border-radius:var(--r-lg);height:100%}
.feat-list{display:flex;flex-direction:column;gap:18px;margin-top:30px}
.feat-item{display:flex;gap:16px}
.feat-item .fi-ico{width:46px;height:46px;border-radius:12px;background:#fff;border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.feat-item .fi-ico svg{width:22px;height:22px;color:var(--blue-700)}
.feat-item h4{font-size:17px;margin-bottom:3px}
.feat-item p{color:var(--slate);font-size:14.5px}
@media(max-width:900px){.split{grid-template-columns:1fr;gap:36px}.split .img-col{order:-1}}

/* ---------- Process ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;counter-reset:step}
.step{position:relative;padding-top:14px}
.step .num{font-family:var(--font-display);font-weight:800;font-size:15px;width:42px;height:42px;border-radius:50%;
  background:var(--bg-cool);color:var(--blue-700);display:flex;align-items:center;justify-content:center;margin-bottom:18px;border:1.5px solid var(--line)}
.step:not(:last-child)::after{content:"";position:absolute;top:35px;left:54px;right:-12px;height:2px;
  background:linear-gradient(90deg,var(--line),transparent)}
.step h4{font-size:18px;margin-bottom:8px}
.step p{color:var(--slate);font-size:14.5px}
@media(max-width:820px){.steps{grid-template-columns:repeat(2,1fr);gap:32px 24px}.step::after{display:none}}
@media(max-width:460px){.steps{grid-template-columns:1fr}}

/* ---------- Solar dark feature ---------- */
.solar{background:linear-gradient(135deg,var(--navy),#0c3a59 70%);color:#fff;position:relative;overflow:hidden}
.solar::before{content:"";position:absolute;width:520px;height:520px;border-radius:50%;
  background:radial-gradient(circle,rgba(255,197,0,.20),transparent 65%);top:-160px;right:-120px}
.solar .split{position:relative;z-index:1}
.solar h2{color:#fff}
.solar .lede{color:#bdd6e9}
.solar .ph.dark{aspect-ratio:5/4.4;height:100%}
.solar-points{display:flex;flex-direction:column;gap:14px;margin:26px 0 32px}
.solar-points li{display:flex;align-items:center;gap:12px;list-style:none;font-size:15.5px;color:#dcebf7}
.solar-points li svg{width:20px;height:20px;color:var(--bolt);flex:0 0 auto}

/* ---------- Who we serve ---------- */
.serve-grid{display:grid;grid-template-columns:1fr 1fr;gap:26px}
.serve-card{border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;background:#fff;transition:transform .25s var(--ease),box-shadow .3s}
.serve-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.serve-card .ph{aspect-ratio:16/8;border-radius:0;border:0;border-bottom:1px solid var(--line)}
.serve-body{padding:30px}
.serve-body .tag{font-family:var(--font-display);font-weight:700;font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--blue-700)}
.serve-body h3{font-size:24px;margin:10px 0 12px}
.serve-body p{color:var(--slate);font-size:15px;margin-bottom:18px}
.serve-tags{display:flex;flex-wrap:wrap;gap:8px}
.chip{font-size:13px;font-weight:600;color:var(--ink-2);background:var(--bg-cool);border:1px solid var(--line);padding:6px 13px;border-radius:999px}
@media(max-width:760px){.serve-grid{grid-template-columns:1fr}}

/* ---------- Reviews ---------- */
.reviews{background:var(--bg-cool)}
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.rev-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:28px;display:flex;flex-direction:column;gap:16px}
.rev-card .stars svg{width:17px;height:17px}
.rev-card p{font-size:15.5px;color:var(--ink-2);flex:1}
.rev-who{display:flex;align-items:center;gap:12px}
.rev-av{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--blue),var(--blue-700));
  color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:700;font-size:16px}
.rev-who .n{font-family:var(--font-display);font-weight:700;font-size:15px}
.rev-who .m{font-size:13px;color:var(--slate)}
@media(max-width:900px){.rev-grid{grid-template-columns:1fr}}

/* ---------- Service area ---------- */
.area .split{align-items:center}
.area .map{position:relative;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow)}
.area .map .ph{aspect-ratio:16/12;border:0;border-radius:0}
.city-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px 24px;margin-top:26px}
.city{display:flex;align-items:center;gap:10px;font-weight:600;color:var(--ink-2);font-size:15px}
.city svg{width:16px;height:16px;color:var(--blue-700)}

/* ---------- FAQ ---------- */
.faq{max-width:820px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{width:100%;background:none;border:0;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:20px;
  text-align:left;padding:24px 4px;font-family:var(--font-display);font-weight:600;font-size:18px;color:var(--ink)}
.faq-q .pm{width:34px;height:34px;border-radius:50%;border:1.5px solid var(--line);flex:0 0 auto;
  display:flex;align-items:center;justify-content:center;transition:.25s}
.faq-q .pm svg{width:18px;height:18px;color:var(--blue-700);transition:transform .3s var(--ease)}
.faq-item.open .pm{background:var(--blue-700);border-color:var(--blue-700)}
.faq-item.open .pm svg{color:#fff;transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s var(--ease)}
.faq-a p{padding:0 4px 24px;color:var(--slate);font-size:15.5px}

/* ---------- CTA band ---------- */
.cta-band{padding:0 0 96px}
.cta-inner{background:linear-gradient(120deg,var(--blue-700),var(--blue));border-radius:28px;
  padding:56px 56px;color:#fff;position:relative;overflow:hidden;
  display:flex;align-items:center;justify-content:space-between;gap:40px;flex-wrap:wrap}
.cta-inner::before{content:"";position:absolute;width:360px;height:360px;border-radius:50%;
  background:radial-gradient(circle,rgba(255,197,0,.28),transparent 62%);right:-80px;top:-120px}
.cta-inner h2{color:#fff;font-size:clamp(26px,3vw,38px);position:relative;z-index:1}
.cta-inner p{color:#dcecf9;margin-top:10px;position:relative;z-index:1}
.cta-actions{display:flex;gap:14px;position:relative;z-index:1;flex-wrap:wrap}

/* ---------- Contact / Quote ---------- */
.contact{background:var(--bg-cool)}
.contact-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:start}
.qform{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:38px;box-shadow:var(--shadow)}
.qform h3{font-size:24px;margin-bottom:6px}
.qform .sub{color:var(--slate);font-size:14.5px;margin-bottom:24px}
.fgrid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field{display:flex;flex-direction:column;gap:7px;margin-bottom:16px}
.field.full{grid-column:1/-1}
.field label{font-size:13px;font-weight:700;color:var(--ink-2)}
.field input,.field select,.field textarea{
  font-family:var(--font-body);font-size:15px;color:var(--ink);
  padding:13px 15px;border:1.5px solid var(--line);border-radius:var(--r-sm);background:#fff;transition:.2s}
.field textarea{resize:vertical;min-height:110px}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 4px rgba(10,156,232,.12)}
.form-note{font-size:12.5px;color:var(--slate-2);margin-top:8px}
.form-success{display:none;text-align:center;padding:30px 10px}
.form-success svg{width:58px;height:58px;color:var(--blue-700);margin:0 auto 14px}
.form-success h3{margin-bottom:8px}
.form-success p{color:var(--slate)}
.qform.sent .fwrap{display:none}.qform.sent .form-success{display:block}

.contact-info{display:flex;flex-direction:column;gap:14px}
.ci-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:22px;display:flex;gap:16px;align-items:flex-start}
.ci-card .ci-ico{width:48px;height:48px;border-radius:13px;background:var(--bg-cool);display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.ci-card .ci-ico svg{width:23px;height:23px;color:var(--blue-700)}
.ci-card .k{font-family:var(--font-display);font-weight:700;font-size:13px;letter-spacing:.04em;text-transform:uppercase;color:var(--slate);margin-bottom:4px}
.ci-card .v{font-size:17px;font-weight:600;color:var(--ink)}
.ci-card .v.small{font-size:14.5px;font-weight:500;color:var(--ink-2);line-height:1.5}
.ci-emerg{background:linear-gradient(135deg,var(--navy),var(--navy-2));border-color:transparent;color:#fff}
.ci-emerg .ci-ico{background:rgba(255,255,255,.1)}.ci-emerg .ci-ico svg{color:var(--bolt)}
.ci-emerg .k{color:#9fc1dc}.ci-emerg .v{color:#fff}
@media(max-width:900px){.contact-grid{grid-template-columns:1fr;gap:30px}.fgrid{grid-template-columns:1fr}}

/* ---------- Footer ---------- */
.footer{background:var(--navy);color:#a9c4d8;padding:70px 0 0}
.foot-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;padding-bottom:48px}
.foot-brand .logo-badge{background:#fff;border-radius:14px;padding:14px 18px;display:inline-block;margin-bottom:18px}
.foot-brand .logo-badge img{height:40px}
.foot-brand p{font-size:14.5px;max-width:34ch;color:#9bbace}
.foot-social{display:flex;gap:10px;margin-top:20px}
.foot-social a{width:40px;height:40px;border-radius:10px;background:rgba(255,255,255,.07);display:flex;align-items:center;justify-content:center;transition:.2s}
.foot-social a:hover{background:var(--blue-700)}
.foot-social svg{width:19px;height:19px;color:#cfe0ee}
.foot-col h5{font-family:var(--font-display);color:#fff;font-size:14px;letter-spacing:.06em;text-transform:uppercase;margin-bottom:18px}
.foot-col ul{list-style:none;display:flex;flex-direction:column;gap:11px}
.foot-col a{font-size:14.5px;color:#a9c4d8;transition:.2s}
.foot-col a:hover{color:#fff;padding-left:3px}
.foot-bottom{border-top:1px solid rgba(255,255,255,.1);padding:22px 0;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:13px;color:#7f9bb1}
.foot-bottom .badges{display:flex;gap:10px;flex-wrap:wrap}
.foot-bottom .badges span{border:1px solid rgba(255,255,255,.14);border-radius:999px;padding:5px 12px;font-weight:600}
@media(max-width:860px){.foot-top{grid-template-columns:1fr 1fr;gap:34px}}
@media(max-width:480px){.foot-top{grid-template-columns:1fr}}

/* ---------- Reveal (kept as a no-op hook; content always visible) ---------- */
.reveal{opacity:1}

/* ---------- Language toggle (ES / EN) in the utility bar ---------- */
.lang-toggle{display:inline-flex;align-items:center;gap:2px;padding:2px;margin-left:2px;
  border:1px solid rgba(255,255,255,.22);border-radius:999px;flex:0 0 auto}
.lang-toggle button{appearance:none;-webkit-appearance:none;background:none;border:0;cursor:pointer;
  font-family:var(--font-display);font-weight:700;font-size:11.5px;letter-spacing:.04em;
  color:#cfe0ee;padding:3px 9px;border-radius:999px;line-height:1.4;transition:background .2s,color .2s}
.lang-toggle button:hover{color:#fff}
.lang-toggle button.active{background:var(--blue);color:#fff}

/* ---------- Mobile polish: keep the top bar + header tidy on phones ---------- */
@media(max-width:520px){
  /* Trim the utility bar to just the phone + language toggle so it can't overflow */
  .topbar .t-right > span.t-item,
  .topbar .t-divider{display:none}
}
@media(max-width:480px){
  /* The header CTA lives in the slide-out menu on phones — drop it from the
     bar so the logo + hamburger don't crowd. Tighter gutters + smaller logo. */
  .header-cta{display:none}
  .container{padding:0 18px}
  .brand img{height:40px}
  .header .container{gap:12px}
}
