:root {
  --font-family: "Exo 2", sans-serif;
  --font-size-base: 16.5px;
  --line-height-base: 1.83;

  --max-w: 1460px;
  --space-x: 2.27rem;
  --space-y: 1.5rem;
  --gap: 2.1rem;
  --space-section-y: calc(var(--space-y) * 2.4);
  --space-section-x: var(--space-x);
  --space-block: calc(var(--gap) * 1.5);
  --space-card: calc(var(--space-y) * .75);
  --font-size-sm: calc(var(--font-size-base) * .875);
  --font-size-md: var(--font-size-base);
  --font-size-lg: calc(var(--font-size-base) * 1.125);
  --font-size-h3: calc(var(--font-size-base) * 1.35);
  --font-size-h2: calc(var(--font-size-base) * 2);
  --font-size-h1: calc(var(--font-size-base) * 2.65);
  --motion-distance: calc(var(--gap) * var(--random-number));

  --radius-xl: 1.09rem;
  --radius-lg: 0.96rem;
  --radius-md: 0.52rem;
  --radius-sm: 0.25rem;

  --shadow-sm: 0 2px 6px rgba(0,0,0,0.11);
  --shadow-md: 0 8px 20px rgba(0,0,0,0.14);
  --shadow-lg: 0 18px 38px rgba(0,0,0,0.17);

  --overlay: rgba(10, 14, 23, 0.75);
  --anim-duration: 410ms;
  --anim-ease: ease;
  --random-number: 1;

  --brand: #1a3a6b;
  --brand-contrast: #ffffff;
  --accent: #e63946;
  --accent-contrast: #ffffff;

  --neutral-0: #0a0e17;
  --neutral-100: #141a2b;
  --neutral-300: #2a3348;
  --neutral-600: #6b7a99;
  --neutral-800: #b0bccf;
  --neutral-900: #e0e8f5;

  --page-bg: #0a0e17;
  --page-fg: #e0e8f5;
  --muted-bg: #141a2b;
  --muted-fg: #b0bccf;
  --card-bg: #1a2238;
  --card-fg: #e0e8f5;
  --card-border: #2a3348;
  --inverse-bg: #e0e8f5;
  --inverse-fg: #0a0e17;
  --primary-bg: #1a3a6b;
  --primary-fg: #ffffff;
  --primary-hover: #234a8a;
  --accent-bg: #e63946;
  --accent-fg: #ffffff;
  --accent-hover: #c1121f;
  --gradient-hero-bg: linear-gradient(135deg, #0a0e17 0%, #1a3a6b 100%);
  --gradient-hero-fg: #e0e8f5;
  --gradient-accent-bg: linear-gradient(135deg, #e63946 0%, #c1121f 100%);
  --gradient-accent-fg: #ffffff;

  --ring: #3a5a9a;

  --link: #1a3a6b;
  --link-hover: #e63946;

  --btn-ghost-bg: transparent;
  --btn-ghost-bg-hover: color-mix(in srgb, currentColor 10%, transparent);
  --input-placeholder: rgba(255,255,255,0.55);
}
body{margin:0;padding:0;font-family:var(--font-family);box-sizing: border-box;}
*{box-sizing:border-box;}
a{color:inherit;}
.btn-primary,.btn.btn-primary{background:var(--primary-bg)!important;color:var(--primary-fg)!important;border-color:var(--primary-bg)!important;}
.btn-primary:hover,.btn.btn-primary:hover{background:var(--primary-hover)!important;color:var(--primary-fg)!important;border-color:var(--primary-hover)!important;}
.btn-outline-primary{color:var(--primary-bg)!important;border-color:var(--primary-bg)!important;}
.btn-outline-primary:hover{background:var(--primary-bg)!important;color:var(--primary-fg)!important;}
.bg-primary{background:var(--primary-bg)!important;color:var(--primary-fg)!important;}
.text-primary{color:var(--primary-bg)!important;}
.border-primary{border-color:var(--primary-bg)!important;}
.bg-light{background:var(--page-bg)!important;color:var(--page-fg)!important;}
.bg-dark{background:var(--inverse-bg)!important;color:var(--inverse-fg)!important;}

/* ===== Header – futuristisch, breit, hell ===== */
header {
  background: var(--page-bg, #ffffff);
  border-bottom: 1px solid var(--card-border, rgba(0,0,0,0.08));
  width: 100%;
  box-shadow: var(--shadow-sm, 0 1px 4px rgba(0,0,0,0.04));
  /* kein fixed/sticky */
}

.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--gap, 1.5rem);
  max-width: var(--max-w, 1280px);
  margin: 0 auto;
  padding: var(--space-y, 0.75rem) var(--space-x, 1.5rem);
  /* medium density */
  min-height: 3.75rem;
}

/* Logo – dunkel auf hellem Grund */
.logo {
  font-size: var(--font-size-h3, 1.5rem);
  font-weight: 600;
  color: var(--page-fg, #1a1a2e);
  text-decoration: none;
  letter-spacing: -0.02em;
  white-space: nowrap;
  transition: opacity var(--anim-duration, 0.2s) var(--anim-ease, ease);
}
.logo:hover {
  opacity: 0.8;
}

/* Navigation – horizontal, links */
.nav-menu ul {
  display: flex;
  align-items: center;
  gap: var(--gap, 1.5rem);
  list-style: none;
  margin: 0;
  padding: 0;
}

.nav-menu a {
  font-size: var(--font-size-md, 1rem);
  color: var(--page-fg, #1a1a2e);
  text-decoration: none;
  padding: 0.25rem 0;
  position: relative;
  font-weight: 500;
  transition: color var(--anim-duration, 0.2s) var(--anim-ease, ease);
}
.nav-menu a::after {
  content: '';
  position: absolute;
  left: 0;
  bottom: -2px;
  width: 100%;
  height: 2px;
  background: var(--primary-bg, #4f46e5);
  transform: scaleX(0);
  transform-origin: right center;
  transition: transform var(--anim-duration, 0.25s) var(--anim-ease, ease);
}
.nav-menu a:hover {
  color: var(--primary-bg, #4f46e5);
}
.nav-menu a:hover::after {
  transform: scaleX(1);
  transform-origin: left center;
}

/* CTA – rechts, auffällig */
.cta-zone {
  flex-shrink: 0;
}

.cta-button {
  display: inline-block;
  background: var(--primary-bg, #4f46e5);
  color: var(--primary-fg, #ffffff);
  font-size: var(--font-size-sm, 0.9rem);
  font-weight: 600;
  padding: 0.6rem 1.6rem;
  border-radius: var(--radius-xl, 40px);
  text-decoration: none;
  letter-spacing: 0.01em;
  box-shadow: var(--shadow-md, 0 4px 12px rgba(79,70,229,0.25));
  transition: background var(--anim-duration, 0.2s) var(--anim-ease, ease),
              transform var(--anim-duration, 0.2s) var(--anim-ease, ease),
              box-shadow var(--anim-duration, 0.2s) var(--anim-ease, ease);
}
.cta-button:hover {
  background: var(--primary-hover, #4338ca);
  transform: translateY(-2px);
  box-shadow: var(--shadow-lg, 0 8px 24px rgba(79,70,229,0.3));
}

/* Burger – mobil */
.burger {
  display: none;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 5px;
  background: transparent;
  border: none;
  cursor: pointer;
  padding: 0.5rem;
  margin-left: auto;
  z-index: 10;
}
.burger-line {
  display: block;
  width: 26px;
  height: 2.5px;
  background: var(--page-fg, #1a1a2e);
  border-radius: 4px;
  transition: all var(--anim-duration, 0.25s) var(--anim-ease, ease);
}
.burger.active .burger-line:nth-child(1) {
  transform: translateY(7px) rotate(45deg);
}
.burger.active .burger-line:nth-child(2) {
  opacity: 0;
}
.burger.active .burger-line:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg);
}

/* ===== Mobile ≤ 767px ===== */
@media (max-width: 767px) {
  .header-inner {
    flex-wrap: wrap;
    padding: var(--space-y, 0.6rem) var(--space-x, 1rem);
  }

  .nav-menu {
    order: 4;
    flex-basis: 100%;
    display: none; /* скрыто по умолчанию */
    margin-top: 0.75rem;
    border-top: 1px solid var(--card-border, rgba(0,0,0,0.06));
    padding-top: 0.75rem;
  }
  .nav-menu.open {
    display: block;
  }

  .nav-menu ul {
    flex-direction: column;
    align-items: stretch;
    gap: 0.25rem;
  }

  .nav-menu a {
    display: block;
    padding: 0.7rem 0.5rem;
    border-radius: var(--radius-md, 8px);
    font-size: var(--font-size-md, 1rem);
  }
  .nav-menu a::after {
    display: none;
  }
  .nav-menu a:hover {
    background: var(--muted-bg, #f3f4f6);
    color: var(--primary-bg, #4f46e5);
  }

  .cta-zone {
    margin-left: auto;
  }

  .burger {
    display: flex;
  }

  .cta-button {
    padding: 0.5rem 1.2rem;
    font-size: var(--font-size-sm, 0.85rem);
  }
}

/* ===== Kleine Tabletten / großes Mobile (min-width: 768px) ===== */
@media (min-width: 768px) {
  .burger {
    display: none !important;
  }
  .nav-menu {
    display: block !important; /* immer sichtbar */
  }
}

/* ===== Extra breite Bildschirme: Container noch breiter ===== */
@media (min-width: 1400px) {
  .header-inner {
    max-width: calc(var(--max-w, 1280px) + 120px);
  }
}

footer {
    background: #0a0f1e;
    color: #e0e6f0;
    font-family: 'Inter', 'Segoe UI', system-ui, sans-serif;
    padding: 3rem 2rem 1.5rem;
    border-top: 2px solid #1f2a44;
    width: 100%;
    box-sizing: border-box;
  }
  .footer-container {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 2rem;
    max-width: 1280px;
    margin: 0 auto;
  }
  .footer-column {
    flex: 1 1 180px;
    min-width: 140px;
  }
  .footer-logo {
    font-size: 1.6rem;
    font-weight: 700;
    color: #ffffff;
    letter-spacing: 0.02em;
    margin: 0 0 0.5rem;
  }
  .footer-tagline {
    font-size: 0.9rem;
    color: #8e9bb5;
    margin: 0;
  }
  .footer-column h4 {
    font-size: 1rem;
    font-weight: 600;
    color: #b0c4e8;
    margin: 0 0 0.8rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
  }
  .footer-nav, .footer-legal {
    list-style: none;
    padding: 0;
    margin: 0;
  }
  .footer-nav li, .footer-legal li {
    margin-bottom: 0.5rem;
  }
  .footer-nav a, .footer-legal a {
    color: #c8d4ed;
    text-decoration: none;
    font-size: 0.95rem;
    transition: color 0.2s ease;
  }
  .footer-nav a:hover, .footer-legal a:hover {
    color: #ffffff;
    text-decoration: underline;
  }
  .contact-info p {
    margin: 0.3rem 0;
    font-size: 0.95rem;
    line-height: 1.5;
  }
  .contact-info a {
    color: #c8d4ed;
    text-decoration: none;
  }
  .contact-info a:hover {
    color: #ffffff;
    text-decoration: underline;
  }
  .footer-disclaimer {
    max-width: 1280px;
    margin: 2rem auto 1rem;
    padding-top: 1.5rem;
    border-top: 1px solid #2a3555;
    font-size: 0.8rem;
    color: #7a8aa8;
    line-height: 1.5;
    text-align: center;
  }
  .footer-bottom {
    max-width: 1280px;
    margin: 0 auto;
    text-align: center;
    font-size: 0.85rem;
    color: #6a7a98;
    padding-top: 0.5rem;
  }
  @media (max-width: 768px) {
    .footer-container {
      flex-direction: column;
      align-items: center;
      text-align: center;
    }
    .footer-column {
      flex: 1 1 auto;
      width: 100%;
    }
    .footer-disclaimer, .footer-bottom {
      text-align: center;
    }
  }

.cookies {
    position: fixed;
    left: var(--space-x);
    right: var(--space-x);
    bottom: var(--space-y);
    z-index: 1200;
}

.cookies .card {
    margin-left: auto;
    max-width: 440px;
    border-radius: var(--radius-xl);
    padding: var(--space-y) var(--space-x);
    background: var(--primary-bg);
    color: var(--primary-fg);
    box-shadow: var(--shadow-lg);
    border: 1px solid rgba(148, 163, 184, .35);
}

.cookies .top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.cookies .top strong {
    font-size: 16px;
}

.cookies .top button {
    border: 0;
    text-decoration: underline;
    text-underline-offset: 2px;
    font-size: 13px;
    cursor: pointer;
}

.cookies p {
    margin: 10px 0 0;
}

.cookies .actions {
    margin-top: 14px;
    display: flex;
    gap: 8px;
}

.cookies .actions button {
    flex: 1;
    border-radius: var(--radius-sm);
    border: 1px solid rgba(148, 163, 184, .45);
    padding: 9px 12px;
    color: var(--neutral-0);
    background: rgba(51, 65, 85, .65);
    cursor: pointer;
}

.cookies .actions button[data-choice='accept'] {
    color: var(--page-bg);
    border-color: transparent;
    color: var(--page-fg);
    font-weight: 700;
}

@media (max-width: 760px) {
    .cookies .card {
        max-width: none;
    }
}

.opening {
    padding: clamp(3.6rem, 8vw, 6.8rem) var(--space-x);
    background: var(--primary-fg);
    color: var(--primary-bg);
}

.opening .wrap {
    max-width: var(--max-w);
    margin: 0 auto;
    display: grid;
    grid-template-columns:1.05fr .95fr;
    gap: 1rem;
}

.opening .main {
    padding: 1.2rem;
    border-radius: var(--radius-xl);
    background: var(--muted-bg);
    color: var(--muted-fg);
}

.opening .main p {
    margin: 0;
    text-transform: uppercase;
    letter-spacing: .1em;
    font-size: .82rem;
}

.opening .main h1 {
    margin: .6rem 0 0;
    font-size: clamp(2.3rem, 5vw, 4rem);
    line-height: 1.03;
}

.opening .main strong {
    display: block;
    margin-top: .9rem;
}

.opening .side {
    padding: 1.2rem;
    border-radius: var(--radius-xl);
    border: 1px solid var(--card-border);
    display: grid;
    align-content: center;
    gap: .85rem;
}

.opening .side p {
    margin: 0;
}

.opening .actions {
    display: flex;
    gap: .75rem;
    flex-wrap: wrap;
}

.opening .actions a {
    display: inline-flex;
    min-height: 2.8rem;
    align-items: center;
    justify-content: center;
    padding: 0 1rem;
    border-radius: var(--radius-md);
    text-decoration: none;
    border: 1px solid var(--card-border);
    color: var(--card-fg);
    background: var(--card-bg);
}

.opening .actions a:first-child {
    background: var(--primary-bg);
    color: var(--primary-fg);
    border-color: var(--primary-bg);
}

@media (max-width: 860px) {
    .opening .wrap {
        grid-template-columns:1fr;
    }
}

.solutions{padding:calc(var(--space-y)*3) var(--space-x);background:var(--inverse-bg);color:var(--inverse-fg);}
.solutions .shell{max-width:var(--max-w);margin:0 auto;display:grid;gap:var(--gap);}
.solutions .banner{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:var(--gap);padding:1rem;border-radius:var(--radius-lg);background:var(--gradient-hero-bg);color:var(--gradient-hero-fg);}
.solutions h2{margin:0;font-size:clamp(1.7rem,3.3vw,2.5rem);}
.solutions .banner a{padding:.56rem .82rem;border-radius:var(--radius-sm);text-decoration:none;background:var(--card-bg);color:var(--card-fg);font-weight:700;}
.solutions .cards{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--gap);padding:0;margin:0;list-style:none;}
.solutions li{padding:1rem;border-radius:var(--radius-md);background:var(--accent-bg);color:var(--accent-fg);}
.solutions h3{margin:0 0 .45rem;}
.solutions p{margin:0;opacity:.9;}
.solutions small{display:block;margin-top:.5rem;font-weight:700;}
@media (max-width:980px){.solutions .cards{grid-template-columns:repeat(2,minmax(0,1fr));}}@media (max-width:640px){.solutions .cards{grid-template-columns:1fr;}}

.move{padding:clamp(56px,8vw,96px) clamp(16px,4vw,40px);background:var(--page-bg);color:var(--page-fg);}
.move .wrap{max-width:var(--max-w);margin:0 auto;display:grid;grid-template-columns:1.1fr .9fr;gap:12px;}
.move .main{border:1px solid var(--card-border);border-radius:var(--radius-lg);padding:14px;background:var(--muted-bg);color:var(--muted-fg);}
.move .main h2{margin:0;font-size:clamp(28px,4vw,42px);}
.move .main p{margin:8px 0 10px;}
.move .main a{display:inline-flex;padding:9px 12px;border-radius:var(--radius-sm);background:var(--primary-bg);color:var(--primary-fg);text-decoration:none;}
.move .notes{border:1px solid var(--card-border);border-radius:var(--radius-lg);padding:14px;background:var(--muted-bg);color:var(--muted-fg);}
.move .notes p{margin:0 0 8px;}
.move .notes p:last-child{margin-bottom:0;}
@media(max-width:820px){.move .wrap{grid-template-columns:1fr;}}

.testimonials{padding:clamp(20px,3vw,44px);background:var(--gradient-hero-bg);color:var(--gradient-hero-fg);}

    .testimonials .wrap{max-width:var(--max-w);margin:0 auto;}

    .testimonials .head{margin-bottom:14px;}

    .testimonials h2{margin:0;font-size:clamp(24px,4.6vw,44px);}

    .testimonials .head p{margin:10px 0 0;max-width:70ch;opacity:.92;}

    .testimonials .logos{display:grid;grid-template-columns:repeat(auto-fit,minmax(430px,1fr));gap:10px;}

    .testimonials .logos div{border-radius:var(--radius-lg);border:1px solid color-mix(in srgb, currentColor 22%, transparent);background:color-mix(in srgb, currentColor 10%, transparent);min-height:80px;height:320px;display:grid;place-items:center;padding:10px;}

    .testimonials .logos img{max-width:100%;height:100%;}

    .testimonials .stats{margin-top:14px;display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px;}

    .testimonials .stats article{border-radius:var(--radius-md);border:1px solid color-mix(in srgb, currentColor 22%, transparent);background:color-mix(in srgb, currentColor 12%, transparent);padding:12px;}

    .testimonials .stats strong,.testimonials .stats span{display:block;}

    .testimonials .stats span{margin-top:5px;opacity:.92;}

.faq-linestory {
  background: var(--page-bg);
  color: var(--page-fg);
  padding: var(--space-section-y) var(--space-section-x);
}
.faq-linestory .story {
  max-width: calc(var(--max-w) * .82);
  margin: 0 auto;
  display: grid;
  gap: var(--space-block);
}
.faq-linestory h2,
.faq-linestory h3,
.faq-linestory p {
  margin: 0;
}
.faq-linestory h2 {
  font-size: var(--font-size-h2);
  line-height: 1.05;
}
.faq-linestory .lines {
  border-top: 1px solid var(--card-border);
}
.faq-linestory .line {
  display: grid;
  grid-template-columns: minmax(4rem, .22fr) minmax(0, 1fr);
  gap: var(--gap);
  padding: var(--space-card) 0;
  border-bottom: 1px solid var(--card-border);
  animation: faq-linestory-draw calc(var(--anim-duration) * 2) var(--anim-ease) both;
}
.faq-linestory .line:nth-child(2) { animation-delay: calc(var(--anim-duration) * .25); }
.faq-linestory .line:nth-child(3) { animation-delay: calc(var(--anim-duration) * .5); }
.faq-linestory .line span {
  color: var(--primary-bg);
  font-size: var(--font-size-h3);
  line-height: 1;
}
.faq-linestory h3 {
  font-size: var(--font-size-h3);
  margin-bottom: calc(var(--space-card) * .35);
}
@keyframes faq-linestory-draw {
  from { opacity: 0; transform: translateX(calc(var(--motion-distance) * -.16)); }
  to { opacity: 1; transform: translateX(0); }
}
@media (max-width: 620px) {
  .faq-linestory .story {
    max-width: var(--max-w);
  }
  .faq-linestory .line {
    grid-template-columns: 1fr;
  }
}

.how-crestflow{padding:calc(var(--space-y)*3) var(--space-x);background:var(--gradient-hero-bg);color:var(--gradient-hero-fg);}
.how-crestflow .crestflow-wrap{max-width:var(--max-w);margin:0 auto;}.how-crestflow .crestflow-title{max-width:48rem;margin-bottom:1rem;}.how-crestflow h2{margin:0;font-size:clamp(2rem,4vw,3.25rem);line-height:1.03;}.how-crestflow .crestflow-title p{margin:.85rem 0 0;}
.how-crestflow .crestflow-cards{display:grid;grid-template-columns:1.2fr .9fr .9fr;gap:.75rem;}.how-crestflow .article{background:var(--card-bg);color:var(--card-fg);border-radius:var(--radius-xl);padding:1rem;min-height:15rem;display:flex;flex-direction:column;justify-content:flex-end;}.how-crestflow .article:first-child{background:var(--accent-bg);color:var(--accent-fg);}.how-crestflow h3{margin:2rem 0 .35rem;font-size:1.1rem;}.how-crestflow p{margin:0;color:inherit;opacity:.78;}
@media (max-width:800px){.how-crestflow .crestflow-cards{grid-template-columns:1fr;}.how-crestflow .article{min-height:auto;}}

.legal-quietpage{padding:calc(var(--space-y)*2.8) var(--space-x);background:var(--page-bg);color:var(--page-fg)}
.legal-quietpage .quietpage-wrap{max-width:var(--max-w);margin:0 auto;background:var(--card-bg);color:var(--card-fg);border:1px solid var(--card-border);border-radius:var(--radius-xl);padding:1.2rem;box-shadow:var(--shadow-sm)}
.legal-quietpage h1{margin:0;color:var(--card-fg);font-size:clamp(2rem,4.4vw,3.6rem);line-height:1.04}
.legal-quietpage .quietpage-date{color:var(--link);font-weight:700}
.legal-quietpage h2{margin:1.3rem 0 0;color:var(--card-fg);font-size:clamp(1.25rem,2.5vw,1.8rem);line-height:1.15}
.legal-quietpage p{margin:.75rem 0 0;color:var(--card-fg);opacity:.84;line-height:1.58}
.legal-quietpage ul{margin:.75rem 0 0;padding-left:1.2rem;color:var(--card-fg)}
.legal-quietpage li{margin:.35rem 0;line-height:1.5}

.opinions{background:radial-gradient(circle at 22% 18%,color-mix(in srgb, currentColor 75%, transparent),transparent 60%),var(--gradient-hero-bg);padding:clamp(56px,8vw,96px) clamp(16px,4vw,40px);}

    .opinions .c{max-width:var(--max-w);margin:0 auto;}

    .opinions .h{text-align:center;margin-bottom:clamp(22px,5vw,44px);transform:translateY(-18px);}

    .opinions .h h2{margin:0 0 10px;font-size:clamp(26px,4.4vw,44px);letter-spacing:-0.02em;}

    .opinions .h p{margin:0;}

    .opinions .list{display:grid;gap:12px;}

    .opinions .row{border-radius:var(--radius-lg);border:1px solid rgba(248, 225, 231,0.95);background:rgba(58, 46, 61,0.92);box-shadow:var(--shadow-sm);overflow:hidden;transform:translateY(24px);color:var(--neutral-0);}

    .opinions .q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:12px;cursor:pointer;padding:14px 16px;border:0;background:transparent;font:inherit;}

    .opinions .left{display:inline-flex;align-items:center;gap:10px;min-width:0;}

    .opinions .avatar{width:36px;height:36px;border-radius:12px;background:color-mix(in srgb, currentColor 8%, transparent);border:1px solid color-mix(in srgb, currentColor 12%, transparent);display:flex;align-items:center;justify-content:center;flex:0 0 auto;}

    .opinions .name{font-weight:800;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:18ch;}

    .opinions .meta{font-size:12px;color:color-mix(in srgb, currentColor 75%, transparent);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:24ch;}

    .opinions .right{display:inline-flex;align-items:center;gap:8px;flex:0 0 auto;padding:6px 10px;border-radius:999px;background:color-mix(in srgb, currentColor 8%, transparent);border:1px solid color-mix(in srgb, currentColor 14%, transparent);}

    .opinions .stars{letter-spacing:0.08em;font-size:13px;line-height:1;}

    .opinions .score{font-weight:800;font-size:12px;}

    .opinions .a{display:none;padding:0 16px 14px;color:color-mix(in srgb, currentColor 85%, transparent);overflow:hidden;}

    .opinions .quote{margin:0;font-size:14px;line-height:1.65;}

    .opinions .badge{display:inline-flex;margin-top:10px;padding:6px 10px;border-radius:999px;background:color-mix(in srgb, currentColor 8%, transparent);border:1px solid color-mix(in srgb, currentColor 12%, transparent);letter-spacing:0.14em;text-transform:uppercase;font-size:10px;color:color-mix(in srgb, currentColor 78%, transparent);}

.offerings{padding:calc(var(--space-y)*2.9) var(--space-x);background:var(--muted-bg);color:var(--muted-fg);}
.offerings .grid{max-width:var(--max-w);margin:0 auto;display:grid;grid-template-columns:1fr 1.25fr;gap:var(--gap);}
.offerings .cap-intro{padding:1.2rem;border-radius:var(--radius-xl);background:var(--card-bg);border:1px solid var(--card-border);color:var(--card-fg);}
.offerings .cap-intro h2{margin:0;font-size:clamp(1.8rem,3.2vw,2.5rem);}
.offerings .cap-intro p{margin:.55rem 0 1rem;}
.offerings .cap-intro a{display:inline-block;padding:.6rem .95rem;border-radius:var(--radius-md);background:var(--primary-bg);color:var(--primary-fg);text-decoration:none;}
.offerings .cards{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.7rem;}
.offerings article{padding:1rem;border-radius:var(--radius-lg);background:linear-gradient(180deg,var(--card-bg),var(--muted-bg));border:1px solid var(--card-border);color:var(--card-fg);}
.offerings .index{margin:0 0 .35rem;font-weight:700;}
.offerings h3{margin:0 0 .35rem;}
.offerings article p{margin:0;}
@media (max-width:900px){.offerings .grid{grid-template-columns:1fr;}.offerings .cards{grid-template-columns:1fr;}}

.tpl-variant-support-colored-v7{background-image:linear-gradient(135deg,color-mix(in srgb,currentColor 6%,transparent),transparent 48%);}
.tpl-variant-support-colored-v7 .grid,.tpl-variant-support-colored-v7 .cards,.tpl-variant-support-colored-v7 .list,.tpl-variant-support-colored-v7 .stack{gap:calc(var(--gap,1rem) * 1.08);}
.tpl-variant-support-colored-v7 article:nth-child(even),.tpl-variant-support-colored-v7 .card:nth-child(even),.tpl-variant-support-colored-v7 .item:nth-child(even){transform:translateY(0.35rem);}
.service-desk{padding:clamp(54px,7vw,94px) clamp(16px,4vw,36px);background:var(--gradient-hero-bg);color:var(--gradient-hero-fg);}

    .service-desk .wrap{max-width:900px;margin:0 auto;}

    .service-desk .head{margin-bottom:14px;}

    .service-desk .head h2{margin:0;font-size:clamp(28px,4vw,42px);}

    .service-desk .head p{margin:8px 0 0;opacity:.92;}

    .service-desk .list{display:grid;gap:10px;}

    .service-desk .item{border:1px solid color-mix(in srgb, currentColor 32%, transparent);border-radius:var(--radius-md);background:color-mix(in srgb, currentColor 12%, transparent);overflow:hidden;}

    .service-desk .item button{width:100%;border:0;background:transparent;color:inherit;text-align:left;font:inherit;font-weight:700;padding:11px 12px;cursor:pointer;}

    .service-desk .item p{margin:0;max-height:0;overflow:hidden;padding:0 12px;transition:max-height var(--anim-duration) var(--anim-ease),padding var(--anim-duration) var(--anim-ease);opacity:.95;}

    .service-desk .item.is-open p{max-height:220px;padding:0 12px 12px;}

.lead{padding:calc(var(--space-y)*2.9) var(--space-x);color:var(--page-fg);background:var(--page-bg);}
.lead .shell{max-width:var(--max-w);margin:0 auto;display:grid;grid-template-columns:.9fr 1.1fr;gap:var(--gap);}
.lead .form-intro{padding:1rem;border-radius:var(--radius-lg);background:var(--muted-bg);border:1px solid var(--card-border);color:var(--muted-fg);}
.lead h2{margin:0;font-size:clamp(1.85rem,3.5vw,2.65rem);}
.lead .form-intro p{margin:.45rem 0 0;}
.lead .panel{padding:1.1rem;border:1px solid var(--card-border);border-radius:var(--radius-xl);background:var(--card-bg);box-shadow:var(--shadow-md);display:grid;gap:.75rem;color:var(--card-fg);}
.lead .grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.62rem;}
.lead label{display:grid;gap:.28rem;}
.lead span{font-size:.84rem;font-weight:700;}
.lead input,.lead textarea{width:100%;padding:.78rem .82rem;border:1px solid var(--card-border);border-radius:var(--radius-md);background:var(--card-bg);color:var(--card-fg);font:inherit;outline:none;transition:border-color var(--anim-duration) var(--anim-ease),box-shadow var(--anim-duration) var(--anim-ease);}
.lead input:focus,.lead textarea:focus{border-color:var(--ring);box-shadow:0 0 0 3px color-mix(in srgb,var(--ring) 20%,transparent);}
.lead textarea{min-height:128px;resize:vertical;}
.lead button{justify-self:start;padding:.82rem 1.1rem;border:0;border-radius:var(--radius-md);background:var(--primary-bg);color:var(--primary-fg);font-weight:700;cursor:pointer;}
.lead button:hover{background:var(--primary-hover);color:var(--primary-fg);}
@media (max-width:920px){.lead .shell,.lead .grid{grid-template-columns:1fr;}}

.block-connect{color:var(--gradient-hero-fg);background:var(--gradient-hero-bg);padding:clamp(32px,5vw,64px) clamp(16px,4vw,40px);}

    .block-connect .c{max-width:var(--max-w);margin:0 auto;}

    .block-connect .title{font-size:clamp(28px,5vw,48px);text-align:center;margin:0 0 clamp(48px,7vw,72px);}

    .block-connect .grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:clamp(24px,4vw,32px);}

    .block-connect .item{display:flex;flex-direction:column;align-items:center;gap:var(--gap);padding:var(--space-x);background:var(--card-bg);border-radius:var(--radius-xl);border:1px solid var(--card-border);text-decoration:none;color:var(--card-fg);transition:transform 0.3s,border-color 0.3s;}

    .block-connect .item{border:1px solid var(--card-border);border-radius:var(--radius-md);animation:section-pulse-border 3s var(--anim-ease) infinite;}

    @keyframes section-pulse-border{
        0%, 100% {border-color:var(--card-border);box-shadow:none;}
        50%{border-color:var(--primary-bg);box-shadow:0 0 0 3px var(--accent-bg);}
    }

    .block-connect .item:hover{transform:translateY(-6px);border-color:var(--accent-bg);}

    .block-connect .item span{font-size:clamp(17px, 2.8vw, 20px);font-weight:600;}

.contacts-calmgrid{padding:calc(var(--space-y)*2.6) var(--space-x);background:var(--muted-bg);color:var(--muted-fg);}
.contacts-calmgrid .calmgrid-box{max-width:var(--max-w);margin:0 auto;}
.contacts-calmgrid .calmgrid-intro{max-width:45rem;margin-bottom:1.35rem;}
.contacts-calmgrid h2{margin:0;font-size:clamp(1.85rem,3.2vw,2.75rem);line-height:1.08;}
.contacts-calmgrid .calmgrid-intro p{margin:.75rem 0 0;color:var(--neutral-600);}
.contacts-calmgrid .calmgrid-info{display:grid;grid-template-columns:1.1fr .9fr .85fr .85fr;border:1px solid var(--card-border);background:var(--card-bg);color:var(--card-fg);}
.contacts-calmgrid .article{min-height:9.2rem;padding:1rem;border-right:1px solid var(--card-border);display:flex;flex-direction:column;justify-content:space-between;}
.contacts-calmgrid .article:last-child{border-right:0;}
.contacts-calmgrid b{font-size:.82rem;color:var(--neutral-600);}
.contacts-calmgrid .address,.contacts-calmgrid .article p{margin:0;font-style:normal;line-height:1.32;}
.contacts-calmgrid a{text-decoration:none;overflow-wrap:anywhere;}
.contacts-calmgrid .calmgrid-action a{font-weight:700;}
.contacts-calmgrid .calmgrid-chips{list-style:none;margin:.8rem 0 0;padding:0;display:flex;gap:.55rem;flex-wrap:wrap;}
.contacts-calmgrid .calmgrid-chips a{display:inline-flex;gap:.4rem;align-items:center;border-radius:var(--radius-sm);padding:.55rem .7rem;background:var(--card-bg);border:1px solid var(--card-border);color:var(--card-fg);}
.contacts-calmgrid .calmgrid-chips span{color:var(--neutral-600);}
@media (max-width:900px){.contacts-calmgrid .calmgrid-info{grid-template-columns:1fr 1fr;}.contacts-calmgrid .article:nth-child(2){border-right:0;}.contacts-calmgrid .article{border-bottom:1px solid var(--card-border);}}
@media (max-width:560px){.contacts-calmgrid .calmgrid-info{grid-template-columns:1fr;}.contacts-calmgrid .article{border-right:0;min-height:auto;gap:1.2rem;}.contacts-calmgrid .article:nth-child(2){border-bottom:1px solid var(--card-border);}}

.policy{padding:calc(var(--space-y)*2.7) var(--space-x);color:var(--page-fg);background:var(--page-bg);}
.policy .shell{max-width:var(--max-w);margin:0 auto;display:grid;gap:.72rem;}
.policy .banner{padding:1rem;border-radius:var(--radius-xl);border:1px solid var(--card-border);background:var(--card-bg);color:var(--card-fg);}
.policy h2{margin:0;font-size:clamp(1.74rem,3vw,2.42rem);}
.policy .banner p{margin:.38rem 0 0;}
.policy .matrix{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.6rem;}
.policy .matrix .article{padding:.85rem;border:1px solid var(--card-border);border-radius:var(--radius-md);background:var(--card-bg);color:var(--card-fg);}
.policy .matrix h3{margin:0 0 .2rem;font-size:1rem;}
.policy .matrix p{margin:0;}
.policy .end{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.6rem;}
.policy .end p{margin:0;padding:.75rem;border-radius:var(--radius-md);background:var(--muted-bg);color:var(--muted-fg);}
@media (max-width:760px){.policy .matrix,.policy .end{grid-template-columns:1fr;}}

.conditions{padding:clamp(56px,8vw,96px) clamp(16px,4vw,36px);background:var(--accent-bg);color:var(--accent-fg);}

    .conditions .wrap{max-width:var(--max-w);margin:0 auto;}

    .conditions .section-head{margin-bottom:16px;text-align:center;}

    .conditions h2{margin:0;font-size:clamp(28px,4vw,40px);}

    .conditions .section-head p{margin:10px auto 0;max-width:72ch;}

    .conditions .columns{columns:2 260px;column-gap:14px;}

    .conditions article{break-inside:avoid;margin-bottom:12px;border-radius:var(--radius-md);border:1px solid color-mix(in srgb, currentColor 22%, transparent);padding:12px;background:color-mix(in srgb, currentColor 5%, transparent);}

    .conditions h3{margin:0;}

    .conditions .meta{margin:7px 0 0;}

    .conditions article p:last-child{margin:7px 0 0;}

.done{padding:calc(var(--space-y)*2.9) var(--space-x);background:var(--gradient-hero-bg);color:var(--gradient-hero-fg);} .done .shell{max-width:var(--max-w);margin:0 auto;display:grid;gap:var(--gap);} .done h2{margin:0;font-size:clamp(1.85rem,3.6vw,2.8rem);line-height:1.1;} .done .sub{margin:.35rem 0 0;opacity:.9;} .done article,.done li{padding:.85rem;border-radius:var(--radius-sm);background:var(--accent-bg);border:1px solid var(--btn-ghost-bg-hover);list-style:none;color:var(--accent-fg);} .done p{margin:0;} .done a{text-decoration:none;color:inherit;font-weight:700;} .done .ranks{counter-reset:r;display:grid;gap:.5rem;} .done .ranks article{position:relative;padding-left:2.2rem;} .done .ranks article::before{counter-increment:r;content:counter(r);position:absolute;left:.7rem;top:.8rem;width:1.2rem;height:1.2rem;border-radius:50%;display:grid;place-items:center;background:var(--primary-bg);color:var(--primary-fg);font-size:.72rem;} .done article{transition:transform var(--anim-duration) var(--anim-ease),box-shadow var(--anim-duration) var(--anim-ease);} .done article:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);} @media (max-width:860px){.done .split,.done .media,.done .grid,.done .cards,.done .bento,.done .foot{grid-template-columns:1fr;}}

.error-page{padding:clamp(56px,10vw,112px) 20px;background:var(--card-bg);color:var(--card-fg);}

    .error-page .box{max-width:760px;margin:0 auto;text-align:center;padding:clamp(28px,4vw,46px);border-radius:var(--radius-lg);border:1px solid var(--card-border);box-shadow:var(--shadow-sm);}

    .error-page h1{margin:0;font-size:clamp(32px,6vw,56px);}

    .error-page p{margin:12px 0 0;}

    .error-page a{display:inline-block;margin-top:18px;text-decoration:none;border-bottom:2px solid var(--link);padding-bottom:2px;}