
:root {
  --navy:#06182b;
  --navy2:#092743;
  --blue:#149fe3;
  --cyan:#2dc7ff;
  --text:#102033;
  --muted:#607086;
  --page:#eef6fb;
  --card:#fbfdff;
  --line:#d8e8f3;
  --white:#ffffff;
}

* { box-sizing:border-box; }

html { scroll-behavior:smooth; }

body {
  margin:0;
  font-family: Inter, "Aptos", "Segoe UI", Roboto, Arial, sans-serif;
  color:var(--text);
  background:var(--page);
  line-height:1.6;
}

.container {
  width:min(1120px, 92%);
  margin:0 auto;
}

.site-header {
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(255,255,255,.96);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}

.nav {
  min-height:96px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
}

.brand img {
  height:72px;
  width:auto;
  display:block;
  border-radius:14px;
}

nav {
  display:flex;
  align-items:center;
  gap:16px;
}

nav a {
  color:var(--text);
  text-decoration:none;
  font-weight:800;
  font-size:.92rem;
}

.nav-cta { color:var(--blue); }

.lang-switch {
  display:flex;
  align-items:center;
  gap:8px;
  padding-left:14px;
  border-left:1px solid var(--line);
}

.lang-switch a {
  width:36px;
  height:36px;
  display:grid;
  place-items:center;
  font-size:1.15rem;
  border-radius:999px;
  background:#f4f8fc;
  border:1px solid var(--line);
  text-decoration:none;
}

.lang-switch a.active {
  background:#e6f5fd;
  border-color:#8fd4f4;
}

.hero {
  color:white;
  background:
    radial-gradient(circle at 78% 18%, rgba(45,199,255,.22), transparent 34%),
    linear-gradient(135deg, var(--navy), var(--navy2));
  padding:92px 0;
}

.hero-grid {
  display:grid;
  grid-template-columns:1.12fr .88fr;
  gap:54px;
  align-items:center;
}

.eyebrow {
  margin:0 0 12px;
  color:var(--cyan);
  font-size:.78rem;
  letter-spacing:.15em;
  text-transform:uppercase;
  font-weight:900;
}

h1 {
  font-size:clamp(2.35rem, 5vw, 4.6rem);
  line-height:1.02;
  margin:0 0 24px;
}

h2 {
  font-size:clamp(2rem, 3.4vw, 3rem);
  line-height:1.12;
  margin:0 0 18px;
}

h3 {
  font-size:1.32rem;
  margin:0 0 12px;
}

.lead {
  font-size:1.2rem;
  color:#d8eaf8;
  max-width:780px;
}

.trust-line {
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.24);
  border-radius:18px;
  padding:16px 18px;
  margin-top:24px;
  color:#eaf7ff;
}

.trust-line strong {
  display:block;
  margin-bottom:5px;
  color:white;
}

.actions {
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  margin-top:32px;
}

.btn {
  display:inline-block;
  text-decoration:none;
  border:0;
  border-radius:999px;
  padding:14px 22px;
  font-weight:900;
  cursor:pointer;
}

.btn.primary {
  background:linear-gradient(135deg, var(--blue), var(--cyan));
  color:white;
}

.btn.secondary {
  background:rgba(255,255,255,.08);
  color:white;
  border:1px solid rgba(255,255,255,.24);
}

.micro-copy {
  color:#b9dff4;
  font-weight:800;
  margin-top:18px;
}

.hero-card {
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.16);
  border-radius:30px;
  padding:34px;
  box-shadow:0 30px 80px rgba(0,0,0,.24);
}

.logo-motion-card {
  text-align:center;
  overflow:hidden;
}

.logo-light-wrap {
  position:relative;
  min-height:230px;
  display:grid;
  place-items:center;
  overflow:hidden;
  border-radius:26px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.14);
  margin-bottom:26px;
}

.motion-logo {
  width:min(270px, 82%);
  max-height:155px;
  object-fit:contain;
  border-radius:18px;
  position:relative;
  z-index:2;
  filter:drop-shadow(0 18px 34px rgba(0,0,0,.28));
  animation:logoPulse 3.5s ease-in-out infinite;
}

.light-line {
  position:absolute;
  left:-48%;
  width:44%;
  height:3px;
  border-radius:999px;
  background:linear-gradient(90deg, transparent, rgba(45,199,255,.95), transparent);
  box-shadow:0 0 18px rgba(45,199,255,.88);
  animation:lightTravel 2.6s linear infinite;
}

.line-one { top:34%; animation-delay:0s; }
.line-two { top:50%; animation-delay:.65s; }
.line-three { top:66%; animation-delay:1.3s; }

@keyframes lightTravel {
  0% { transform:translateX(0); opacity:0; }
  12% { opacity:1; }
  88% { opacity:1; }
  100% { transform:translateX(365%); opacity:0; }
}

@keyframes logoPulse {
  0%,100% { transform:scale(1); }
  50% { transform:scale(1.025); }
}

.hero-service-list {
  text-align:left;
  margin:0;
  padding-left:1.2rem;
}

.hero-service-list li {
  color:#eaf7ff;
  font-weight:850;
  margin-bottom:10px;
}

.section {
  padding:84px 0;
  background:var(--page);
}

.section-intro {
  font-size:1.12rem;
  color:var(--muted);
  max-width:870px;
}

.quick-strip {
  background:var(--page);
  border-bottom:1px solid var(--line);
}

.strip-grid {
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
  padding:22px 0;
}

.strip-grid div,
.service-card,
.selector-card,
.analysis-card,
.price-card,
.card,
.terms-box,
.form-card,
.payment-box,
.single-price > div {
  background:var(--card);
  border:1px solid var(--line);
  border-radius:24px;
  padding:28px;
}

.strip-grid strong {
  display:block;
  color:var(--blue);
  font-size:1.35rem;
}

.strip-grid span,
.service-card p,
.service-card li,
.selector-card p,
.selector-card li,
.analysis-card p,
.card p,
.price-card p,
.terms-box p,
.note {
  color:var(--muted);
}

.service-stack {
  display:grid;
  gap:22px;
  margin-top:36px;
}

.service-card {
  display:grid;
  grid-template-columns:80px 1fr;
  gap:24px;
}

.service-card.premium,
.selector-card.highlighted,
.analysis-card.highlight,
.price-card.highlighted {
  background:linear-gradient(135deg, #ffffff, #f3fbff);
  border-color:#8fd4f4;
  box-shadow:0 18px 50px rgba(6,24,43,.07);
}

.service-number,
.analysis-icon {
  width:58px;
  height:58px;
  display:grid;
  place-items:center;
  border-radius:18px;
  background:linear-gradient(135deg, var(--navy), var(--blue));
  color:white;
  font-weight:900;
  font-size:1.22rem;
}

.service-number { border-radius:50%; }

.disclaimer {
  background:white;
  border-left:4px solid var(--blue);
  padding:14px 16px;
  border-radius:12px;
  color:var(--text)!important;
}

.selector-grid,
.analysis-grid,
.pricing-grid,
.cards {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:22px;
  margin-top:34px;
}

.selector-card {
  display:flex;
  flex-direction:column;
  gap:10px;
}

.selector-tag,
.badge {
  width:max-content;
  background:var(--blue);
  color:white;
  border-radius:999px;
  padding:6px 10px;
  font-size:.78rem;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.08em;
}

.selector-price,
.price {
  font-size:1.85rem;
  color:var(--blue);
  font-weight:900;
  margin:.25rem 0;
}

.selector-card .btn {
  width:max-content;
  margin-top:auto;
}

.analysis-icon {
  margin-bottom:16px;
}

.single-price {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:22px;
  margin:34px 0;
}

.price span {
  font-size:1rem;
  color:var(--muted);
}

.payment-box {
  margin-top:28px;
}

.buy-section, .terms, .contact, .analyse-section, .pricing-section, .selector-section {
  background:var(--page);
}

.notice.dark-notice {
  margin-top:28px;
  background:var(--card);
  border:1px solid var(--line);
  color:var(--text);
}

.dual-forms {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:26px;
  margin-top:34px;
}

.form-card {
  box-shadow:0 24px 70px rgba(6,24,43,.07);
}

form {
  display:grid;
  gap:16px;
}

label {
  font-weight:800;
}

input, textarea, select {
  width:100%;
  margin-top:7px;
  padding:14px 16px;
  border-radius:12px;
  border:1px solid #d4e1ee;
  font:inherit;
  background:white;
}

button.btn {
  width:fit-content;
}

.center-note {
  text-align:center;
  margin-top:24px;
}

footer {
  background:#03111f;
  color:white;
  padding:34px 0;
}

.footer-grid {
  display:flex;
  justify-content:space-between;
  gap:24px;
}

footer p {
  color:#b9cada;
  margin:.35rem 0;
}

@media(max-width:960px) {
  nav { display:none; }
  .nav { min-height:88px; }
  .brand img { height:66px; }
  .hero-grid,
  .service-card,
  .single-price,
  .dual-forms {
    grid-template-columns:1fr;
  }
  .strip-grid,
  .selector-grid,
  .analysis-grid,
  .cards,
  .pricing-grid {
    grid-template-columns:1fr;
  }
  .hero { padding:72px 0; }
  .footer-grid { flex-direction:column; }
}

/* Round 2 updates */
.section,.selector-section,.analyse-section,.buy-section,.contact,.quick-strip{background:var(--page)!important}
.strip-grid div,.service-card,.selector-card,.analysis-card,.price-card,.card,.form-card,.payment-box,.single-price>div,.compact-terms{background:var(--card)!important}
.lang-switch a img{width:24px;height:16px;display:block;border-radius:2px;object-fit:cover}
.four-grid{grid-template-columns:repeat(4,1fr)}
.compact-terms{margin-top:24px;border:1px solid var(--line);border-radius:24px;padding:24px 28px}
.compact-terms p{color:var(--muted);margin-bottom:0}
@media(max-width:1100px){.four-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:700px){.four-grid{grid-template-columns:1fr}}



/* Premium visual polish: typography, spacing, fibre-light motion */
:root{
  --navy-dark:#06182B;
  --navy-mid:#0B1F33;
  --accent:#2DC7FF;
  --page-bg:#F6FAFD;
  --page-bg-2:#EEF6FB;
  --card-bg:#FFFFFF;
  --text-dark:#0B1F33;
  --text-muted:#66758A;
}

body{
  font-family:Inter,"Aptos","Segoe UI",Roboto,Arial,sans-serif;
  letter-spacing:-0.01em;
  background:var(--page-bg);
  color:var(--text-dark);
}

.container{width:min(1180px,92%);}

.site-header{box-shadow:0 6px 24px rgba(6,24,43,.04);}
.nav{min-height:92px;}
nav{gap:18px;}
nav a{
  font-size:.9rem;
  letter-spacing:.01em;
  position:relative;
}
nav a::after{
  content:"";
  position:absolute;
  left:0;
  bottom:-6px;
  width:0;
  height:2px;
  background:linear-gradient(90deg,var(--navy-dark),var(--accent));
  transition:width .25s ease;
}
nav a:hover::after{width:100%;}

.fiber-hero{
  position:relative;
  overflow:hidden;
  isolation:isolate;
}
.fiber-hero::before{
  content:"";
  position:absolute;
  inset:-20%;
  background:
    radial-gradient(circle at 15% 25%,rgba(45,199,255,.14),transparent 28%),
    radial-gradient(circle at 82% 18%,rgba(45,199,255,.18),transparent 30%),
    linear-gradient(115deg,transparent 0%,transparent 35%,rgba(45,199,255,.10) 47%,transparent 59%,transparent 100%);
  z-index:-2;
}
.fiber-hero::after{
  content:"";
  position:absolute;
  left:-35%;
  top:18%;
  width:36%;
  height:2px;
  background:linear-gradient(90deg,transparent,rgba(45,199,255,.95),transparent);
  box-shadow:0 70px 24px rgba(45,199,255,.30),0 150px 30px rgba(45,199,255,.18);
  animation:fibreSweep 5.8s linear infinite;
  z-index:-1;
  opacity:.8;
}
@keyframes fibreSweep{
  0%{transform:translateX(0) rotate(-8deg);opacity:0}
  10%{opacity:.85}
  85%{opacity:.85}
  100%{transform:translateX(410%) rotate(-8deg);opacity:0}
}

h1{letter-spacing:-.055em;max-width:900px;}
h2{letter-spacing:-.04em;max-width:920px;color:var(--navy-dark);}
h3{letter-spacing:-.025em;color:var(--navy-dark);}
.lead{font-size:clamp(1.1rem,1.8vw,1.32rem);line-height:1.65;max-width:820px;}
.section-intro{font-size:1.12rem;line-height:1.75;max-width:900px;}

.section{padding:96px 0;}
.section + .section{padding-top:88px;}

.section-divider{
  width:72px;
  height:4px;
  border-radius:999px;
  margin:22px 0 34px;
  background:linear-gradient(90deg,var(--navy-dark),var(--navy-mid),var(--accent));
  box-shadow:0 8px 18px rgba(20,159,227,.18);
}

.card,.service-card,.selector-card,.analysis-card,.form-card,.payment-box,.terms-box,.compact-terms,.single-price>div,.price-card{
  border-radius:28px;
  border:1px solid rgba(216,232,243,.95);
  box-shadow:0 16px 45px rgba(6,24,43,.055);
  transition:transform .28s ease,box-shadow .28s ease,border-color .28s ease;
}
.card:hover,.service-card:hover,.selector-card:hover,.analysis-card:hover,.form-card:hover{
  transform:translateY(-5px);
  box-shadow:0 24px 64px rgba(6,24,43,.095);
  border-color:rgba(45,199,255,.45);
}
.service-card{padding:34px;gap:28px;}
.selector-card,.analysis-card,.card,.form-card{padding:32px;}
.service-number,.analysis-icon{box-shadow:0 14px 28px rgba(6,24,43,.18);}
.selector-grid,.analysis-grid,.cards,.pricing-grid{gap:26px;}
.selector-tag,.badge{letter-spacing:.09em;padding:7px 12px;}
.selector-price,.price{letter-spacing:-.035em;}

.btn,.btn.primary{
  border-radius:999px;
  padding:14px 24px;
  letter-spacing:.005em;
  box-shadow:0 14px 28px rgba(20,159,227,.20);
  transition:transform .25s ease,box-shadow .25s ease,background .25s ease;
}
.btn:hover,.btn.primary:hover{
  transform:translateY(-2px);
  box-shadow:0 18px 38px rgba(20,159,227,.30);
}

input,textarea,select{
  border-radius:14px;
  border:1px solid rgba(212,225,238,.95);
  transition:border-color .2s ease,box-shadow .2s ease;
}
input:focus,textarea:focus,select:focus{
  outline:none;
  border-color:var(--accent);
  box-shadow:0 0 0 4px rgba(45,199,255,.14);
}

.logo-motion-card{backdrop-filter:blur(8px);}
.logo-light-wrap::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(110deg,transparent 0%,rgba(45,199,255,.12) 48%,transparent 58%),
    radial-gradient(circle at 50% 50%,rgba(45,199,255,.10),transparent 55%);
  animation:softGlow 4.8s ease-in-out infinite;
}
@keyframes softGlow{
  0%,100%{opacity:.45}
  50%{opacity:1}
}
.light-line{height:2px;}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.001ms!important;
    animation-iteration-count:1!important;
    transition-duration:.001ms!important;
    scroll-behavior:auto!important;
  }
}
@media(max-width:960px){
  .section{padding:72px 0;}
  h1{letter-spacing:-.04em;}
  .service-card,.selector-card,.analysis-card,.form-card{padding:26px;}
}



/* Typography & spacing refinement */
:root{
  --font-main: Inter, "Aptos", "Segoe UI", Roboto, Arial, sans-serif;
  --space-section: 96px;
  --space-section-mobile: 70px;
  --radius-card: 28px;
}

body{
  font-family:var(--font-main);
  font-size:16px;
  line-height:1.65;
  letter-spacing:-0.01em;
}

.container{
  width:min(1160px,92%);
}

h1,h2,h3{
  text-wrap:balance;
}

h1{
  font-size:clamp(2.6rem,5.4vw,4.85rem);
  line-height:1.02;
  letter-spacing:-0.06em;
  margin-bottom:26px;
}

h2{
  font-size:clamp(2rem,3.4vw,3.1rem);
  line-height:1.12;
  letter-spacing:-0.045em;
  margin-bottom:18px;
}

h3{
  font-size:1.32rem;
  line-height:1.25;
  letter-spacing:-0.025em;
  margin-bottom:12px;
}

p{
  margin-top:0;
}

.lead{
  max-width:780px;
  font-size:clamp(1.12rem,1.7vw,1.28rem);
  line-height:1.72;
}

.section-intro{
  max-width:860px;
  font-size:1.1rem;
  line-height:1.75;
  margin-bottom:0;
}

.eyebrow{
  font-size:.76rem;
  letter-spacing:.16em;
  margin-bottom:14px;
}

.section{
  padding:var(--space-section) 0;
}

.section + .section{
  padding-top:88px;
}

.hero{
  padding:104px 0 96px;
}

.hero-grid{
  gap:64px;
}

.actions{
  margin-top:34px;
  gap:16px;
}

.micro-copy{
  margin-top:20px;
}

.trust-line{
  max-width:760px;
  line-height:1.65;
}

.service-stack{
  margin-top:42px;
  gap:26px;
}

.service-card{
  gap:30px;
  padding:36px;
}

.selector-grid,
.analysis-grid,
.cards,
.pricing-grid{
  margin-top:40px;
  gap:28px;
}

.selector-card,
.analysis-card,
.card,
.form-card{
  padding:34px;
}

.selector-card ul,
.service-card ul,
.analysis-card ul{
  padding-left:1.1rem;
}

.selector-card li,
.service-card li,
.hero-service-list li{
  margin-bottom:9px;
}

.section-divider{
  margin:24px 0 38px;
}

.dual-forms{
  margin-top:40px;
  gap:30px;
}

form{
  gap:18px;
}

label{
  font-size:.95rem;
}

input,textarea,select{
  margin-top:8px;
  padding:15px 16px;
  line-height:1.45;
}

footer{
  padding:42px 0;
}

.footer-grid{
  align-items:flex-start;
}

@media(max-width:960px){
  body{
    font-size:15.5px;
  }

  .hero{
    padding:78px 0 72px;
  }

  .section{
    padding:var(--space-section-mobile) 0;
  }

  h1{
    font-size:clamp(2.25rem,10vw,3.4rem);
    letter-spacing:-0.045em;
  }

  h2{
    font-size:clamp(1.8rem,8vw,2.45rem);
  }

  .hero-grid{
    gap:38px;
  }

  .service-card,
  .selector-card,
  .analysis-card,
  .card,
  .form-card{
    padding:26px;
  }

  .selector-grid,
  .analysis-grid,
  .cards,
  .pricing-grid,
  .dual-forms{
    gap:22px;
    margin-top:30px;
  }
}



/* Hero revert: earlier premium split layout */
.hero,
.fiber-hero{
  color:white!important;
  background:
    radial-gradient(circle at 78% 18%, rgba(45,199,255,.20), transparent 34%),
    linear-gradient(135deg, #06182B 0%, #08233B 52%, #0B304A 100%)!important;
  padding:92px 0 72px!important;
  position:relative;
  overflow:hidden;
}

.hero-grid{
  display:grid!important;
  grid-template-columns:1.05fr .95fr!important;
  gap:54px!important;
  align-items:center!important;
}

.hero .eyebrow{
  color:#2DC7FF!important;
  font-size:.78rem!important;
  letter-spacing:.17em!important;
  font-weight:900!important;
  margin-bottom:20px!important;
}

.hero h1{
  color:#fff!important;
  font-size:clamp(3.25rem, 5.5vw, 5.7rem)!important;
  line-height:0.98!important;
  letter-spacing:-0.065em!important;
  max-width:760px!important;
  margin:0 0 28px!important;
}

.hero .lead{
  color:#D7E8F4!important;
  font-size:1.23rem!important;
  line-height:1.7!important;
  max-width:650px!important;
  margin-bottom:26px!important;
}

.hero .trust-line{
  max-width:650px!important;
  background:rgba(255,255,255,.085)!important;
  border:1px solid rgba(255,255,255,.22)!important;
  color:#EAF7FF!important;
  border-radius:18px!important;
  padding:18px 20px!important;
  margin:28px 0 0!important;
  box-shadow:none!important;
}

.hero .trust-line strong{
  color:#fff!important;
  display:block!important;
  margin-bottom:6px!important;
}

.hero .actions{
  margin-top:32px!important;
  display:flex!important;
  gap:16px!important;
  flex-wrap:wrap!important;
}

.hero .btn.primary{
  background:#28B9F2!important;
  color:#fff!important;
  box-shadow:none!important;
}

.hero .btn.secondary{
  background:rgba(255,255,255,.06)!important;
  color:#fff!important;
  border:1px solid rgba(255,255,255,.26)!important;
  box-shadow:none!important;
}

.hero .btn{
  border-radius:999px!important;
  padding:15px 25px!important;
  font-weight:900!important;
}

.hero .micro-copy{
  color:#B9DFF4!important;
  font-weight:800!important;
  margin-top:22px!important;
}

.logo-motion-card{
  background:rgba(255,255,255,.075)!important;
  border:1px solid rgba(255,255,255,.18)!important;
  border-radius:30px!important;
  padding:34px!important;
  box-shadow:none!important;
  text-align:left!important;
  transform:none!important;
}

.logo-motion-card:hover{
  transform:none!important;
  box-shadow:none!important;
}

.logo-light-wrap{
  min-height:230px!important;
  border-radius:26px!important;
  background:rgba(255,255,255,.075)!important;
  border:1px solid rgba(255,255,255,.16)!important;
  margin-bottom:28px!important;
  display:grid!important;
  place-items:center!important;
  overflow:hidden!important;
  position:relative!important;
}

.motion-logo{
  width:min(270px,72%)!important;
  max-height:160px!important;
  object-fit:contain!important;
  border-radius:0!important;
  position:relative!important;
  z-index:2!important;
  filter:drop-shadow(0 18px 34px rgba(0,0,0,.28))!important;
}

.hero-service-list{
  margin:0!important;
  padding-left:1.25rem!important;
  text-align:left!important;
}

.hero-service-list li{
  color:#F3FAFF!important;
  font-size:1rem!important;
  font-weight:900!important;
  margin-bottom:14px!important;
}

.light-line{
  position:absolute!important;
  left:-45%!important;
  width:42%!important;
  height:2px!important;
  border-radius:999px!important;
  background:linear-gradient(90deg,transparent,rgba(45,199,255,.95),transparent)!important;
  box-shadow:0 0 18px rgba(45,199,255,.85)!important;
  animation:lightTravel 2.6s linear infinite!important;
}

.line-one{top:34%!important;animation-delay:0s!important}
.line-two{top:50%!important;animation-delay:.65s!important}
.line-three{top:66%!important;animation-delay:1.3s!important}

@keyframes lightTravel{
  0%{transform:translateX(0);opacity:0}
  12%{opacity:1}
  88%{opacity:1}
  100%{transform:translateX(365%);opacity:0}
}

/* Disable later full-hero sweep to match earlier version */
.fiber-hero::after{
  display:none!important;
}

@media(max-width:960px){
  .hero-grid{
    grid-template-columns:1fr!important;
    gap:38px!important;
  }
  .hero h1{
    font-size:clamp(2.65rem, 12vw, 4rem)!important;
  }
  .hero{
    padding:74px 0 64px!important;
  }
}

.vat-note{
  margin-top:10px;
  text-align:center;
  font-size:.86rem;
  color:#66758A;
  font-weight:600;
}

.hidden {
  display:none;
}

.form-card [data-netlify-recaptcha="true"] {
  margin:18px 0;
}


/* GDPR / legal additions */
.consent-label{
  display:flex!important;
  gap:10px!important;
  align-items:flex-start!important;
  font-size:.88rem!important;
  line-height:1.45!important;
  color:#526176!important;
  margin:14px 0!important;
}
.consent-label input{
  width:auto!important;
  margin-top:3px!important;
  flex:0 0 auto!important;
}
footer a{color:inherit;text-decoration:underline;text-underline-offset:3px}
.legal-page{padding-top:70px!important;background:#F7FAFC!important;}
.legal-content{
  max-width:880px!important;
  background:#fff!important;
  border:1px solid rgba(17,35,55,.10)!important;
  border-radius:22px!important;
  padding:34px!important;
  box-shadow:0 18px 44px rgba(0,0,0,.06)!important;
}
.legal-content h1{margin-top:0!important;}
.legal-content h2{margin-top:30px!important;font-size:1.25rem!important;}
.legal-content p{color:#526176!important;line-height:1.75!important;}
.legal-content a{color:#006D92!important;font-weight:800!important;}


/* Mobile header fix: keep navigation and language switcher visible */
@media (max-width: 960px) {
  .site-header {
    position: sticky;
    top: 0;
    z-index: 100;
  }
  .nav {
    min-height: auto !important;
    padding: 10px 0 12px;
    display: flex !important;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 10px;
  }
  .brand img {
    height: 58px !important;
  }
  .nav nav,
  nav {
    display: flex !important;
    width: 100%;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    gap: 8px 12px;
  }
  .nav nav > a,
  nav > a {
    display: inline-flex;
    align-items: center;
    min-height: 34px;
    padding: 6px 8px;
    font-size: .78rem;
    line-height: 1.15;
    text-align: center;
    border-radius: 999px;
    background: #f4f8fc;
    border: 1px solid var(--line);
  }
  .nav-cta {
    color: #fff !important;
    background: var(--blue) !important;
    border-color: var(--blue) !important;
  }
  .lang-switch {
    display: flex !important;
    flex: 0 0 auto;
    padding-left: 8px;
    border-left: 1px solid var(--line);
    gap: 6px;
  }
  .lang-switch a {
    display: grid !important;
    width: 34px;
    height: 34px;
    padding: 0;
    background: #fff;
  }
  .lang-switch img {
    width: 24px;
    height: 24px;
  }
}

@media (max-width: 420px) {
  .nav nav > a,
  nav > a {
    font-size: .72rem;
    padding: 5px 7px;
  }
  .brand img {
    height: 52px !important;
  }
}
