:root{
  --bg:#02050c;
  --bg2:#07101e;
  --text:rgba(255,255,255,.96);
  --muted:rgba(255,255,255,.68);
  --faint:rgba(255,255,255,.46);
  --line:rgba(255,255,255,.12);
  --orange:#ff6a00;
  --orange2:#ff9b35;
  --blue:#79a8ff;
  --max:1060px;
  --edge:min(30px,5vw);
}

*{box-sizing:border-box}

html{
  scroll-behavior:smooth;
  background:var(--bg);
}

body{
  margin:0;
  min-height:100vh;
  color:var(--text);
  font-family:Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  background:var(--bg);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

a{color:inherit}
button,a{-webkit-tap-highlight-color:transparent}
button{font:inherit}

.cosmos{
  position:fixed;
  inset:0;
  z-index:-1;
  overflow:hidden;
  background:
    radial-gradient(circle at 52% 16%, rgba(255,255,255,.075), transparent 20%),
    radial-gradient(circle at 68% 28%, rgba(39,95,220,.18), transparent 26%),
    radial-gradient(circle at 23% 70%, rgba(255,106,0,.075), transparent 26%),
    linear-gradient(180deg,#030712 0%,#060b16 42%,#02050b 100%);
}

.cosmos::before{
  content:"";
  position:absolute;
  inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.016) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.016) 1px, transparent 1px);
  background-size:54px 54px;
  opacity:.22;
  mask-image:linear-gradient(180deg,black 0%,rgba(0,0,0,.70) 62%,transparent 100%);
}

.cosmos::after{
  content:"";
  position:absolute;
  width:980px;
  height:520px;
  left:50%;
  top:80px;
  transform:translateX(-50%) rotate(-13deg);
  border-top:1px solid rgba(94,147,255,.20);
  border-radius:50%;
  opacity:.58;
}

.floating-header{
  position:fixed;
  top:max(14px, env(safe-area-inset-top));
  left:50%;
  z-index:70;
  width:min(var(--max), calc(100% - 36px));
  min-height:74px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  padding:9px 10px 9px 22px;
  border:1px solid rgba(255,255,255,.10);
  border-radius:999px;
  background:linear-gradient(180deg, rgba(9,14,26,.74), rgba(3,7,15,.60));
  backdrop-filter:blur(24px) saturate(145%);
  -webkit-backdrop-filter:blur(24px) saturate(145%);
  box-shadow:
    0 22px 60px rgba(0,0,0,.26),
    inset 0 1px 0 rgba(255,255,255,.06),
    inset 0 -1px 0 rgba(255,255,255,.03);
  transform:translateX(-50%) translateY(0);
  opacity:1;
  transition:transform .32s cubic-bezier(.22,.9,.2,1), opacity .22s ease;
  will-change:transform, opacity;
}

.floating-header.is-hidden{
  transform:translateX(-50%) translateY(calc(-100% - 28px));
  opacity:0;
  pointer-events:none;
}

.mini-brand{
  display:inline-flex;
  align-items:center;
  gap:10px;
  text-decoration:none;
  font-size:22px;
  font-weight:900;
  letter-spacing:-.045em;
  white-space:nowrap;
}

.brand-dot{
  width:12px;
  height:12px;
  border-radius:50%;
  background:var(--orange);
  box-shadow:0 0 22px rgba(255,106,0,.85);
  flex:0 0 auto;
}

.brand-name{
  display:inline-flex;
  align-items:baseline;
  gap:0;
}

.brand-io{
  color:var(--blue);
  text-shadow:0 0 18px rgba(75,136,255,.34);
}

.desktop-nav{
  display:flex;
  align-items:center;
  gap:6px;
  margin-left:auto;
}

.desktop-nav a{
  color:rgba(255,255,255,.66);
  text-decoration:none;
  padding:11px 13px;
  border-radius:999px;
  font-weight:720;
  letter-spacing:-.01em;
  transition:background .18s ease,color .18s ease;
}

.desktop-nav a:hover{background:rgba(255,255,255,.07);color:white}

.lang-switch{
  display:inline-flex;
  align-items:center;
  gap:4px;
  margin-left:6px;
  padding:5px;
  border:1px solid rgba(255,255,255,.11);
  border-radius:999px;
  background:rgba(255,255,255,.045);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06);
  flex:0 0 auto;
}

.lang-switch button{
  min-width:42px;
  height:38px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:0;
  border-radius:999px;
  color:rgba(255,255,255,.62);
  background:transparent;
  font-size:13px;
  font-weight:900;
  letter-spacing:.05em;
  cursor:pointer;
}

.lang-switch button.is-active{
  color:#081022;
  background:rgba(255,255,255,.92);
  box-shadow:0 10px 28px rgba(0,0,0,.20), inset 0 1px 0 rgba(255,255,255,.18);
}

.hero-shell{
  position:relative;
  width:min(1120px, calc(100% - var(--edge)));
  min-height:clamp(690px, 96svh, 920px);
  margin:0 auto;
  padding:clamp(138px, 18svh, 205px) 18px 92px;
  display:grid;
  justify-items:center;
  align-content:center;
  text-align:center;
  isolation:isolate;
  overflow:hidden;
}

.hero-shell::before{
  content:"";
  position:absolute;
  inset:7% -2% 3%;
  z-index:-2;
  border-radius:74px;
  background:
    radial-gradient(circle at 50% 18%, rgba(255,255,255,.095), transparent 18%),
    radial-gradient(circle at 48% 51%, rgba(35,91,210,.34), transparent 36%),
    radial-gradient(circle at 31% 66%, rgba(255,106,0,.12), transparent 18%),
    radial-gradient(circle at 78% 42%, rgba(64,118,255,.18), transparent 22%);
  filter:blur(20px);
  opacity:.96;
}

.hero-shell::after{
  content:"";
  position:absolute;
  left:-12%;
  right:-12%;
  top:20%;
  height:520px;
  z-index:-1;
  border-top:1px solid rgba(103,155,255,.22);
  border-radius:50%;
  transform:rotate(-18deg);
  opacity:.34;
  box-shadow:0 -8px 40px rgba(76,129,255,.05);
}

.hero-title{
  max-width:900px;
  margin:0;
  color:white;
  font-size:clamp(56px, 9.4vw, 122px);
  line-height:.99;
  letter-spacing:-.04em;
  font-weight:950;
  text-wrap:balance;
  text-shadow:
    0 2px 0 rgba(255,255,255,.04),
    0 18px 58px rgba(49,98,200,.18),
    0 28px 110px rgba(0,0,0,.38);
}

.hero-copy{
  max-width:730px;
  margin:28px auto 0;
  color:rgba(255,255,255,.76);
  font-size:clamp(20px, 2.45vw, 30px);
  line-height:1.38;
  letter-spacing:-.035em;
  text-wrap:balance;
}

.hero-actions{
  display:flex;
  justify-content:center;
  gap:18px;
  flex-wrap:wrap;
  margin-top:38px;
  width:100%;
}

.btn{
  min-height:58px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:0 24px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  color:white;
  text-decoration:none;
  cursor:pointer;
  font-weight:860;
  letter-spacing:-.022em;
  background:rgba(255,255,255,.055);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06);
}

.btn-orange{
  border-color:rgba(255,122,0,.20);
  background:linear-gradient(135deg,#ff9c22,#ff6a00 66%,#e65300);
  box-shadow:0 20px 54px rgba(255,106,0,.22), inset 0 1px 0 rgba(255,255,255,.20);
}

.hero-main-cta{
  width:min(100%, 520px);
  min-height:74px;
  font-size:24px;
  box-shadow:0 0 0 1px rgba(255,255,255,.04) inset,0 0 42px rgba(255,106,0,.26),0 18px 44px rgba(255,106,0,.17);
}

.content-stack{
  width:min(var(--max), calc(100% - var(--edge)));
  margin:-42px auto 0;
  padding-bottom:54px;
}

.mini-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:14px;
  margin-bottom:24px;
}

.mini-card{
  min-height:128px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
  padding:22px;
  border-radius:30px;
  border:1px solid rgba(255,255,255,.095);
  background:
    radial-gradient(circle at 18% 0%, rgba(255,106,0,.12), transparent 34%),
    radial-gradient(circle at 88% 14%, rgba(47,104,255,.11), transparent 34%),
    linear-gradient(180deg, rgba(255,255,255,.064), rgba(255,255,255,.024));
  box-shadow:0 22px 64px rgba(0,0,0,.20), inset 0 1px 0 rgba(255,255,255,.07);
}

.mini-card strong{
  display:block;
  width:100%;
  max-width:420px;
  color:white;
  font-size:22px;
  line-height:1.06;
  letter-spacing:-.045em;
}

.mini-card span{
  display:block;
  width:100%;
  max-width:420px;
  margin:10px auto 0;
  color:rgba(255,255,255,.62);
  font-size:15px;
  line-height:1.45;
}

.content-card{
  position:relative;
  overflow:hidden;
  display:grid;
  justify-items:center;
  text-align:center;
  border:1px solid rgba(255,255,255,.09);
  background:
    linear-gradient(180deg, rgba(18,23,36,.70), rgba(8,12,22,.82)),
    radial-gradient(circle at 15% 14%, rgba(255,106,0,.06), transparent 24%),
    radial-gradient(circle at 86% 22%, rgba(51,108,255,.10), transparent 22%);
  box-shadow:0 30px 88px rgba(0,0,0,.22), inset 0 1px 0 rgba(255,255,255,.06);
  padding:clamp(34px, 5vw, 56px) clamp(18px,4vw,46px);
  border-radius:40px;
}


.section-eyebrow{
  width:fit-content;
  margin:0 auto 16px;
  padding:11px 16px;
  border:1px solid rgba(255,255,255,.10);
  border-radius:999px;
  color:rgba(255,255,255,.82);
  background:rgba(255,255,255,.04);
  font-size:12px;
  font-weight:900;
  letter-spacing:.18em;
  text-transform:uppercase;
}

.section-intro{
  width:100%;
  max-width:680px;
  margin:16px auto 0;
  color:rgba(255,255,255,.68);
  font-size:18px;
  line-height:1.62;
}

.faq-section{
  margin-top:clamp(42px, 7vw, 78px);
  align-content:start;
}

.faq-list{
  width:100%;
  max-width:820px;
  display:grid;
  gap:12px;
  margin-top:26px;
}

.faq-item{
  overflow:hidden;
  border:1px solid rgba(255,255,255,.095);
  border-radius:24px;
  background:
    radial-gradient(circle at 18% 0%, rgba(255,106,0,.08), transparent 34%),
    radial-gradient(circle at 88% 14%, rgba(47,104,255,.10), transparent 34%),
    linear-gradient(180deg, rgba(255,255,255,.055), rgba(255,255,255,.020));
  box-shadow:0 18px 52px rgba(0,0,0,.16), inset 0 1px 0 rgba(255,255,255,.06);
}

.faq-question{
  width:100%;
  min-height:76px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  padding:20px 22px;
  border:0;
  color:white;
  background:transparent;
  text-align:left;
  cursor:pointer;
}

.faq-question span:first-child{
  font-size:20px;
  line-height:1.25;
  font-weight:880;
  letter-spacing:-.035em;
}

.faq-icon{
  position:relative;
  width:36px;
  height:36px;
  flex:0 0 36px;
  border-radius:50%;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.055);
}

.faq-icon::before,
.faq-icon::after{
  content:"";
  position:absolute;
  left:10px;
  right:10px;
  top:50%;
  height:2px;
  border-radius:999px;
  background:rgba(255,255,255,.88);
  transform:translateY(-50%);
  transition:transform .2s ease, opacity .2s ease;
}

.faq-icon::after{
  transform:translateY(-50%) rotate(90deg);
}

.faq-item.is-open .faq-icon::after{
  opacity:0;
  transform:translateY(-50%) rotate(0deg);
}

.faq-answer{
  display:grid;
  grid-template-rows:0fr;
  min-height:0;
  overflow:hidden;
  transition:grid-template-rows .28s cubic-bezier(.22,.9,.2,1);
}

.faq-item.is-open .faq-answer{
  grid-template-rows:1fr;
}

.faq-answer-inner{
  min-height:0;
  overflow:hidden;
}

.faq-answer p{
  max-width:720px;
  margin:0;
  padding:0 22px 22px;
  color:rgba(255,255,255,.66);
  font-size:16px;
  line-height:1.65;
  text-align:left;
}

.selected-contact{
  min-height:380px;
  align-content:center;
  gap:22px;
  margin-top:clamp(84px, 10vw, 128px);
}

.contact-avatar-wrap{
  position:relative;
  width:118px;
  height:118px;
  border-radius:50%;
  padding:4px;
  background:
    radial-gradient(circle at 34% 22%, rgba(255,255,255,.22), transparent 28%),
    linear-gradient(145deg, rgba(31,71,148,.92), rgba(9,15,28,.94));
  box-shadow:
    0 22px 54px rgba(0,0,0,.26),
    0 0 42px rgba(72,135,255,.18),
    inset 0 1px 0 rgba(255,255,255,.12);
}

.contact-avatar-wrap picture,
.contact-avatar{
  display:block;
  width:100%;
  height:100%;
}

.contact-avatar{
  object-fit:cover;
  border-radius:50%;
  border:1px solid rgba(255,255,255,.13);
}

.mail-badge{
  position:absolute;
  right:-5px;
  bottom:-5px;
  width:48px;
  height:48px;
  display:grid;
  place-items:center;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.16);
  background:linear-gradient(135deg,#ff9c22,#ff6a00 66%,#e65300);
  box-shadow:0 14px 30px rgba(255,106,0,.24);
}

.mail-badge svg{
  width:24px;
  height:24px;
  fill:none;
  stroke:white;
  stroke-width:2.6;
  stroke-linecap:round;
  stroke-linejoin:round;
}

.content-card h2{
  width:100%;
  max-width:720px;
  margin:0 auto;
  color:white;
  font-size:clamp(34px,5vw,58px);
  line-height:.98;
  letter-spacing:-.05em;
  text-wrap:balance;
}

.contact-intro{
  width:100%;
  max-width:560px;
  margin:0 auto 6px;
  color:rgba(255,255,255,.70);
  font-size:18px;
  line-height:1.6;
}

.contact-main-cta{
  width:min(100%, 600px);
  min-height:68px;
  font-size:20px;
}

.footer-note{
  width:min(var(--max), calc(100% - var(--edge)));
  margin:0 auto;
  padding:0 0 28px;
  color:rgba(255,255,255,.38);
  text-align:center;
  font-size:13px;
}

@media (max-width:860px){
  .desktop-nav{display:none}
  .mini-grid{grid-template-columns:1fr}
}

@media (max-width:620px){
  .floating-header{
    width:calc(100% - 28px);
    min-height:70px;
    padding:7px 9px 7px 18px;
    gap:10px;
  }

  .mini-brand{font-size:21px}

  .lang-switch{
    padding:4px;
    gap:3px;
    margin-left:auto;
  }

  .lang-switch button{
    min-width:38px;
    height:36px;
    font-size:12px;
  }

  .hero-shell{
    width:100%;
    min-height:100svh;
    padding:122px 14px 82px;
    align-content:center;
  }

  .hero-shell::before{
    inset:16% -16% 12%;
    border-radius:52px;
    filter:blur(18px);
  }

  .hero-shell::after{
    left:-55%;
    right:-45%;
    top:33%;
    height:360px;
  }

  .hero-title{
    max-width:390px;
    font-size:clamp(48px, 14.8vw, 72px);
    line-height:1.02;
    letter-spacing:-.028em;
  }

  .hero-copy{
    max-width:390px;
    margin-top:26px;
    font-size:17px;
    line-height:1.52;
  }

  .hero-actions{margin-top:34px}
  .hero-main-cta{min-height:76px;font-size:20px;width:min(100%,390px)}

  .content-stack{
    width:calc(100% - 24px);
    margin-top:-18px;
    padding-bottom:36px;
  }

  .content-card{
    padding:32px 18px;
    border-radius:28px;
  }



.selected-contact{
    min-height:345px;
    gap:18px;
    margin-top:clamp(84px, 16vw, 118px);
  }

  .mini-card{
    min-height:128px;
    padding:20px 18px;
    border-radius:26px;
  }

  .content-card h2{font-size:clamp(32px,9vw,44px)}
  .contact-intro{font-size:16px;line-height:1.65}
  .contact-avatar-wrap{width:100px;height:100px}
  .mail-badge{width:42px;height:42px}
  .mail-badge svg{width:22px;height:22px}
  .contact-main-cta{min-height:64px;font-size:18px}
}

@media (max-width:620px){
  .section-intro{
    font-size:16px;
    line-height:1.6;
  }

  .faq-section{
    margin-top:clamp(34px, 9vw, 54px);
  }

  .faq-list{
    margin-top:20px;
    gap:10px;
  }

  .faq-item{
    border-radius:22px;
  }

  .faq-question{
    min-height:68px;
    padding:18px 16px;
    gap:14px;
  }

  .faq-question span:first-child{
    font-size:18px;
  }

  .faq-answer p{
    padding:0 16px 18px;
    font-size:15px;
    line-height:1.62;
  }
}


/* D.U.K. kortelės uždarytos pagal nutylėjimą */
.faq-item:not(.is-open) .faq-answer{
  grid-template-rows:0fr;
}

.faq-item:not(.is-open) .faq-answer-inner{
  max-height:0;
}

.faq-item.is-open .faq-answer-inner{
  max-height:500px;
}


/* FAQ visual refresh inspired by provided reference, without copying its text */
.faq-section{
  justify-items:stretch;
  text-align:left;
  padding:clamp(34px, 5vw, 40px) clamp(18px,4vw,34px);
  border-radius:34px;
  background:
    linear-gradient(180deg, rgba(11,16,29,.88), rgba(7,12,24,.92)),
    radial-gradient(circle at 16% 10%, rgba(255,106,0,.08), transparent 26%),
    radial-gradient(circle at 84% 18%, rgba(56,112,255,.13), transparent 28%);
}

.faq-section .section-eyebrow,
.faq-section h2,
.faq-section .section-intro{
  margin-left:0;
  margin-right:0;
  text-align:left;
}

.faq-section .section-eyebrow{
  margin-bottom:22px;
  padding:14px 28px;
  font-size:15px;
  letter-spacing:.16em;
  border-radius:999px;
  background:linear-gradient(180deg, rgba(255,255,255,.055), rgba(255,255,255,.03));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.07);
}

.faq-section h2{
  max-width:820px;
  font-size:clamp(38px, 5.8vw, 66px);
  line-height:1.02;
}

.faq-section .section-intro{
  max-width:760px;
  margin-top:18px;
  font-size:clamp(17px, 2vw, 18px);
  color:rgba(255,255,255,.72);
}

.faq-list{
  max-width:none;
  margin-top:30px;
  gap:18px;
}

.faq-item{
  border-radius:32px;
  border:1px solid rgba(255,255,255,.09);
  background:
    radial-gradient(circle at 12% 0%, rgba(255,106,0,.10), transparent 30%),
    radial-gradient(circle at 88% 18%, rgba(57,110,255,.11), transparent 36%),
    linear-gradient(180deg, rgba(255,255,255,.055), rgba(255,255,255,.025));
  box-shadow:0 24px 54px rgba(0,0,0,.18), inset 0 1px 0 rgba(255,255,255,.05);
  transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease, background .22s ease;
}

.faq-item.is-open{
  border-color:rgba(255,255,255,.12);
  background:
    radial-gradient(circle at 12% 0%, rgba(255,106,0,.14), transparent 34%),
    radial-gradient(circle at 88% 18%, rgba(57,110,255,.15), transparent 36%),
    linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.03));
  box-shadow:0 30px 66px rgba(0,0,0,.24), inset 0 1px 0 rgba(255,255,255,.07);
}

.faq-question{
  min-height:96px;
  padding:22px 22px 22px 26px;
  gap:16px;
}

.faq-question span:first-child{
  max-width:calc(100% - 84px);
  font-size:clamp(22px, 3vw, 26px);
  line-height:1.14;
  font-weight:900;
  letter-spacing:-.042em;
}

.faq-icon{
  width:60px;
  height:60px;
  flex:0 0 60px;
  border-radius:50%;
  border:1px solid rgba(255,255,255,.11);
  background:linear-gradient(180deg, rgba(255,255,255,.065), rgba(255,255,255,.04));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.05);
}

.faq-icon::before,
.faq-icon::after{
  left:17px;
  right:17px;
  height:3px;
}

.faq-item.is-open .faq-icon{
  border-color:rgba(255,122,0,.20);
  background:linear-gradient(180deg, rgba(72,54,44,.38), rgba(48,36,31,.28));
  box-shadow:0 10px 24px rgba(255,106,0,.08), inset 0 1px 0 rgba(255,255,255,.07);
}

.faq-answer p{
  max-width:760px;
  padding:0 26px 26px;
  color:rgba(255,255,255,.74);
  font-size:clamp(17px, 2vw, 18px);
  line-height:1.72;
}

@media (max-width:620px){
  .faq-section{
    padding:28px 16px;
    border-radius:28px;
  }

  .faq-section .section-eyebrow{
    margin-bottom:18px;
    padding:12px 22px;
    font-size:13px;
  }

  .faq-section h2{
    font-size:clamp(34px, 9.4vw, 56px);
  }

  .faq-section .section-intro{
    margin-top:16px;
    font-size:15px;
    line-height:1.72;
  }

  .faq-list{
    margin-top:24px;
    gap:14px;
  }

  .faq-item{
    border-radius:28px;
  }

  .faq-question{
    min-height:82px;
    padding:18px 16px 18px 18px;
    gap:14px;
  }

  .faq-question span:first-child{
    max-width:calc(100% - 70px);
    font-size:18px;
    line-height:1.18;
  }

  .faq-icon{
    width:54px;
    height:54px;
    flex-basis:54px;
  }

  .faq-icon::before,
  .faq-icon::after{
    left:15px;
    right:15px;
  }

  .faq-answer p{
    padding:0 18px 20px;
    font-size:15px;
    line-height:1.7;
  }
}

/* Global typography compact pass: mažiau gremėzdiškas, daugiau premium */
.floating-header{
  min-height:68px;
}

.mini-brand{
  font-size:20px;
}

.desktop-nav a{
  font-size:15px;
}

.hero-shell{
  min-height:clamp(610px, 86svh, 780px);
  padding:clamp(118px, 15svh, 170px) 18px 78px;
}

.hero-title{
  max-width:760px;
  font-size:clamp(48px, 7.1vw, 88px);
  line-height:1.02;
  letter-spacing:-.038em;
}

.hero-copy{
  max-width:620px;
  margin-top:24px;
  font-size:clamp(17px, 1.75vw, 22px);
  line-height:1.48;
}

.hero-main-cta{
  width:min(100%, 460px);
  min-height:64px;
  font-size:19px;
}

.btn{
  min-height:52px;
  padding:0 22px;
}

.content-stack{
  margin-top:-28px;
}

.mini-card{
  min-height:112px;
  padding:18px;
  border-radius:26px;
}

.mini-card strong{
  font-size:19px;
  line-height:1.12;
}

.mini-card span{
  margin-top:8px;
  font-size:14px;
  line-height:1.42;
}

.content-card{
  padding:clamp(28px, 4vw, 42px) clamp(18px,3.6vw,38px);
  border-radius:34px;
}

.content-card h2{
  font-size:clamp(30px, 4vw, 46px);
  line-height:1.04;
}

.section-intro{
  font-size:16px;
  line-height:1.58;
}

.faq-section{
  padding:clamp(28px, 4vw, 34px) clamp(18px,3.4vw,30px);
  border-radius:30px;
}

.faq-section .section-eyebrow{
  margin-bottom:18px;
  padding:10px 20px;
  font-size:12px;
}

.faq-section h2{
  max-width:720px;
  font-size:clamp(32px, 4.2vw, 48px);
  line-height:1.05;
}

.faq-section .section-intro{
  max-width:680px;
  margin-top:14px;
  font-size:15.5px;
  line-height:1.62;
}

.faq-list{
  margin-top:24px;
  gap:13px;
}

.faq-item{
  border-radius:26px;
}

.faq-question{
  min-height:74px;
  padding:17px 18px 17px 22px;
  gap:14px;
}

.faq-question span:first-child{
  max-width:calc(100% - 64px);
  font-size:clamp(18px, 2.1vw, 21px);
  line-height:1.18;
  letter-spacing:-.035em;
}

.faq-icon{
  width:46px;
  height:46px;
  flex-basis:46px;
}

.faq-icon::before,
.faq-icon::after{
  left:13px;
  right:13px;
  height:2.5px;
}

.faq-answer p{
  max-width:700px;
  padding:0 22px 22px;
  font-size:15.5px;
  line-height:1.64;
}

.selected-contact{
  min-height:330px;
  gap:17px;
  margin-top:clamp(62px, 8vw, 92px);
}

.contact-avatar-wrap{
  width:102px;
  height:102px;
}

.mail-badge{
  width:42px;
  height:42px;
}

.mail-badge svg{
  width:21px;
  height:21px;
}

.contact-intro{
  font-size:16px;
  line-height:1.58;
}

.contact-main-cta{
  width:min(100%, 520px);
  min-height:60px;
  font-size:17px;
}

@media (max-width:620px){
  .floating-header{
    min-height:66px;
  }

  .mini-brand{
    font-size:19px;
  }

  .hero-shell{
    min-height:92svh;
    padding:112px 14px 68px;
  }

  .hero-title{
    max-width:360px;
    font-size:clamp(40px, 12.6vw, 58px);
    line-height:1.05;
  }

  .hero-copy{
    max-width:360px;
    margin-top:22px;
    font-size:15.5px;
    line-height:1.55;
  }

  .hero-actions{
    margin-top:28px;
  }

  .hero-main-cta{
    width:min(100%, 360px);
    min-height:66px;
    font-size:18px;
  }

  .mini-card{
    min-height:108px;
    padding:18px 16px;
  }

  .mini-card strong{
    font-size:20px;
  }

  .mini-card span{
    font-size:14.5px;
  }

  .content-card{
    padding:28px 16px;
    border-radius:26px;
  }

  .content-card h2{
    font-size:clamp(28px, 8vw, 38px);
    line-height:1.06;
  }

  .faq-section{
    padding:26px 16px;
  }

  .faq-section .section-eyebrow{
    margin-bottom:16px;
    padding:10px 18px;
    font-size:12px;
  }

  .faq-section h2{
    font-size:clamp(30px, 8.8vw, 44px);
  }

  .faq-section .section-intro{
    font-size:14.5px;
    line-height:1.65;
  }

  .faq-list{
    margin-top:22px;
    gap:12px;
  }

  .faq-item{
    border-radius:24px;
  }

  .faq-question{
    min-height:70px;
    padding:15px 14px 15px 16px;
  }

  .faq-question span:first-child{
    max-width:calc(100% - 58px);
    font-size:16.5px;
    line-height:1.2;
  }

  .faq-icon{
    width:46px;
    height:46px;
    flex-basis:46px;
  }

  .faq-answer p{
    padding:0 16px 18px;
    font-size:14.5px;
    line-height:1.62;
  }

  .selected-contact{
    min-height:310px;
    margin-top:clamp(58px, 13vw, 86px);
    gap:16px;
  }

  .contact-avatar-wrap{
    width:88px;
    height:88px;
  }

  .mail-badge{
    width:38px;
    height:38px;
  }

  .contact-intro{
    font-size:15px;
  }

  .contact-main-cta{
    min-height:58px;
    font-size:16px;
  }
}
