:root {
  --font-family: "Fredoka", sans-serif;
  --font-size-base: 17.2px;
  --line-height-base: 1.77;

  --max-w: 1640px;
  --space-x: 2.25rem;
  --space-y: 1.5rem;
  --gap: 2.2rem;
  --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.28rem;
  --radius-lg: 0.89rem;
  --radius-md: 0.45rem;
  --radius-sm: 0.3rem;

  --shadow-sm: 0 1px 5px rgba(0,0,0,0.13);
  --shadow-md: 0 6px 26px rgba(0,0,0,0.16);
  --shadow-lg: 0 16px 38px rgba(0,0,0,0.2);

  --overlay: rgba(30,30,35,0.6);
  --anim-duration: 350ms;
  --anim-ease: ease-in-out;
  --random-number: 1;

  --brand: #4a6fa5;
  --brand-contrast: #ffffff;
  --accent: #fbbf24;
  --accent-contrast: #1e1e23;

  --neutral-0: #ffffff;
  --neutral-100: #f4f4f6;
  --neutral-300: #c8c8d0;
  --neutral-600: #6b6b78;
  --neutral-800: #2e2e36;
  --neutral-900: #1a1a20;

  --page-bg: #f4f4f6;
  --page-fg: #1a1a20;
  --muted-bg: #e8e8ee;
  --muted-fg: #2e2e36;
  --card-bg: #ffffff;
  --card-fg: #1a1a20;
  --card-border: #d4d4dc;
  --inverse-bg: #1a1a20;
  --inverse-fg: #f4f4f6;
  --primary-bg: #4a6fa5;
  --primary-fg: #ffffff;
  --primary-hover: #3b5d8a;
  --accent-bg: #fbbf24;
  --accent-fg: #1e1e23;
  --accent-hover: #f59e0b;
  --gradient-hero-bg: linear-gradient(135deg, #f4f4f6 0%, #e0e0e8 100%);
  --gradient-hero-fg: #1a1a20;
  --gradient-accent-bg: linear-gradient(135deg, #fbbf24 0%, #d97706 100%);
  --gradient-accent-fg: #1e1e23;

  --ring: #4a6fa5;

  --link: #4a6fa5;
  --link-hover: #fbbf24;

  --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;}

.site-header {
  background-color: var(--inverse-bg);
  color: var(--inverse-fg);
  width: 100%;
}

.header-utility {
  background-color: var(--muted-bg);
  color: var(--muted-fg);
  font-size: var(--font-size-sm);
  padding: 0.25rem 0;
}

.header-utility .header-wrapper {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.header-main {
  padding: 0.75rem 0;
}

.header-wrapper {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 var(--space-x);
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.logo {
  font-size: var(--font-size-h3);
  font-weight: 700;
  color: var(--inverse-fg);
  text-decoration: none;
  letter-spacing: -0.02em;
}

.logo:hover {
  color: var(--primary-bg);
}

.nav-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  gap: var(--gap);
}

.nav-list a {
  color: var(--inverse-fg);
  text-decoration: none;
  font-size: var(--font-size-md);
  padding: 0.25rem 0.5rem;
  border-radius: var(--radius-sm);
  transition: background-color var(--anim-duration) var(--anim-ease), color var(--anim-duration) var(--anim-ease);
}

.nav-list a:hover {
  background-color: var(--primary-bg);
  color: var(--primary-fg);
}

.burger {
  display: none;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 2.5rem;
  height: 2.5rem;
  background: none;
  border: 2px solid var(--inverse-fg);
  border-radius: var(--radius-sm);
  cursor: pointer;
  padding: 0.4rem;
  gap: 0.3rem;
}

.burger-line {
  display: block;
  width: 100%;
  height: 2px;
  background-color: var(--inverse-fg);
  border-radius: 1px;
  transition: transform var(--anim-duration) var(--anim-ease), opacity var(--anim-duration) var(--anim-ease);
}

.burger.active .burger-line:nth-child(1) {
  transform: translateY(0.35rem) rotate(45deg);
}

.burger.active .burger-line:nth-child(2) {
  opacity: 0;
}

.burger.active .burger-line:nth-child(3) {
  transform: translateY(-0.35rem) rotate(-45deg);
}

@media (max-width: 767px) {
  .burger {
    display: flex;
  }

  .nav-menu {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background-color: var(--inverse-bg);
    padding: 1rem var(--space-x);
    box-shadow: var(--shadow-lg);
    z-index: 100;
  }

  .nav-menu.open {
    display: block;
  }

  .header-main {
    position: relative;
  }

  .nav-list {
    flex-direction: column;
    gap: 0.5rem;
  }

  .nav-list a {
    display: block;
    padding: 0.5rem 0.75rem;
    font-size: var(--font-size-lg);
  }

  .utility-contact {
    display: none;
  }
}

.site-footer {
  background-color: #1a1a2e;
  color: #e0e0e0;
  padding: 2rem 1rem;
  font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
  line-height: 1.6;
}

.footer-container {
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

.footer-contact address {
  font-style: normal;
  display: flex;
  flex-wrap: wrap;
  gap: 1.5rem;
  justify-content: center;
  align-items: center;
  padding: 0.75rem 0;
  border-bottom: 1px solid #333;
}

.contact-item {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
}

.contact-item a {
  color: #a0c4ff;
  text-decoration: none;
  transition: color 0.2s;
}

.contact-item a:hover {
  color: #ffffff;
  text-decoration: underline;
}

.footer-brand {
  text-align: center;
  padding: 0.5rem 0;
}

.footer-logo {
  font-size: 1.6rem;
  font-weight: 700;
  color: #f0f0f0;
  letter-spacing: 1px;
  text-transform: uppercase;
}

.footer-nav ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 1.2rem;
}

.footer-nav a {
  color: #b0b0b0;
  text-decoration: none;
  font-size: 0.95rem;
  transition: color 0.2s;
  padding: 0.25rem 0.5rem;
}

.footer-nav a:hover {
  color: #ffffff;
  text-decoration: underline;
}

.footer-legal {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 1.5rem;
  padding: 0.5rem 0;
  border-top: 1px solid #333;
  border-bottom: 1px solid #333;
}

.footer-legal a {
  color: #a0c4ff;
  text-decoration: none;
  font-size: 0.85rem;
  transition: color 0.2s;
}

.footer-legal a:hover {
  color: #ffffff;
  text-decoration: underline;
}

.footer-disclaimer {
  text-align: center;
  font-size: 0.8rem;
  color: #999;
  max-width: 800px;
  margin: 0 auto;
  padding: 0.5rem 0;
}

.footer-disclaimer p {
  margin: 0;
  line-height: 1.5;
}

.footer-copyright {
  text-align: center;
  font-size: 0.8rem;
  color: #888;
  padding-top: 0.5rem;
}

.footer-copyright p {
  margin: 0;
}

@media (max-width: 600px) {
  .footer-contact address {
    flex-direction: column;
    gap: 0.75rem;
    text-align: center;
  }

  .footer-nav ul {
    flex-direction: column;
    align-items: center;
    gap: 0.75rem;
  }

  .footer-legal {
    flex-direction: column;
    align-items: center;
    gap: 0.75rem;
  }

  .footer-logo {
    font-size: 1.3rem;
  }
}

.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.8rem, 8vw, 6.8rem) var(--space-x);
    background: linear-gradient(160deg, var(--primary-bg), var(--primary-hover));
    color: var(--primary-fg);
}

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

.opening .left, .opening .right {
    padding: 1.1rem;
    border-radius: var(--radius-xl);
    background: color-mix(in srgb, currentColor 12%, transparent);
    border: 1px solid color-mix(in srgb, currentColor 18%, transparent);
}

.opening .tag {
    display: inline-flex;
    padding: .4rem .75rem;
    border-radius: 999px;
    background: var(--primary-fg);
    color: var(--primary-bg);
}

.opening .left h1 {
    margin: .8rem 0 0;
    font-size: clamp(2.5rem, 5vw, 4.6rem);
    line-height: 1;
}

.opening .left p {
    margin: .9rem 0 0;
}

.opening .right {
    display: grid;
    align-content: center;
    gap: .65rem;
}

.opening .right div {
    font-size: clamp(2.8rem, 5vw, 4rem);
    font-weight: 700;
}

.opening .right span {
    color: color-mix(in srgb, currentColor 82%, transparent);
}

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

.social-proof{padding:clamp(18px,3vw,44px);background:var(--page-bg);color:var(--page-fg);}

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

    .social-proof .h{margin-bottom:clamp(14px,2.2vw,22px);}

    .social-proof .title{margin:0;font-size:clamp(24px,4.2vw,40px);letter-spacing:-.02em;line-height:1.1;}

    .social-proof .sub{margin:10px 0 0;max-width:72ch;}

    .social-proof .grid{display:grid;grid-template-columns:repeat(12,1fr);gap:14px;}

    .social-proof .card{grid-column:span 4;border-radius:var(--radius-xl);background:var(--card-bg);border:1px solid var(--card-border);box-shadow:var(--shadow-md);padding:16px;position:relative;transform-style:preserve-3d;transition:transform 420ms var(--anim-ease);min-height:170px;color:var(--card-fg);}

    .social-proof .card:hover{transform:rotateY(180deg);}

    .social-proof .front,.social-proof .back{position:absolute;inset:0;padding:16px;backface-visibility:hidden;border-radius:inherit;}

    .social-proof .front::before{content:'';position:absolute;inset:-1px;background:radial-gradient(260px 130px at 20% 15%,rgba(0, 86, 179,0.12),transparent 60%),radial-gradient(240px 140px at 85% 35%,rgba(255, 107, 53,0.12),transparent 62%);pointer-events:none;border-radius:inherit;color:var(--neutral-0);}

    .social-proof .chip{display:inline-flex;padding:6px 10px;border-radius:999px;background:var(--accent-bg);color:var(--accent-fg);border:1px solid color-mix(in srgb, currentColor 6%, transparent);font-weight:900;position:relative;}

    .social-proof .big{margin-top:12px;font-weight:900;font-size:clamp(18px,2.4vw,28px);letter-spacing:-.01em;position:relative;}

    .social-proof .small{margin-top:8px;line-height:var(--line-height-base);position:relative;}

    .social-proof .back{transform:rotateY(180deg);background:var(--muted-bg);border:1px solid var(--card-border);color:var(--muted-fg);}

    .social-proof .backtitle{font-weight:900;letter-spacing:-.01em;margin-bottom:8px;}

    .social-proof .backtext{line-height:var(--line-height-base);}

    @media (max-width: 980px){.social-proof .card{grid-column:span 6;}
    }

    @media (max-width: 640px){.social-proof .card{grid-column:span 12;}
    }

    @media (prefers-reduced-motion: reduce){.social-proof .card{transition:none;}
    }

.faq-cascade-answers {
  background: var(--gradient-hero-bg);
  color: var(--gradient-hero-fg);
  padding: var(--space-section-y) var(--space-section-x);
}
.faq-cascade-answers .wrap {
  width: min(100%, var(--max-w));
  margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(0, .45fr) minmax(0, 1fr);
  gap: var(--gap);
}
.faq-cascade-answers h2,
.faq-cascade-answers h3,
.faq-cascade-answers p { margin: 0; }
.faq-cascade-answers h2 { font-size: var(--font-size-h2); line-height: 1.08; }
.faq-cascade-answers h3 { font-size: var(--font-size-h3); line-height: 1.16; }
.faq-cascade-answers p { font-size: var(--font-size-md); line-height: var(--line-height-base); }
.faq-cascade-answers .side {
  display: grid;
  gap: var(--space-y);
  align-content: start;
  padding-top: var(--space-block);
}
.faq-cascade-answers [data-block] span { color: var(--muted-fg); }
.faq-cascade-answers .cascade {
  display: grid;
  gap: var(--space-card);
}
.faq-cascade-answers [data-block] {
  gap: var(--space-y);
  padding: var(--space-y);
  border-radius: var(--radius-xl);
  background: var(--card-bg);
  color: var(--card-fg);
  border: 1px solid var(--card-border);
  animation: faqCascadeIn calc(var(--anim-duration) * 2.2) var(--anim-ease) both;
  animation-delay: var(--delay, 0ms);
}
.faq-cascade-answers [data-block]:nth-child(2n) { margin-left: clamp(0rem, 8vw, calc(var(--gap) * 1.1)); }
@keyframes faqCascadeIn {
  from { opacity: .2; transform: translateY(calc(var(--motion-distance) * .16)); }
  to { opacity: 1; transform: translateY(0); }
}
@media (max-width: 800px) {
  .faq-cascade-answers .wrap,
  .faq-cascade-answers [data-block] { grid-template-columns: 1fr; }
  .faq-cascade-answers .side { padding-top: 0; }
  .faq-cascade-answers [data-block]:nth-child(2n) { margin-left: 0; }
}

.case{padding:clamp(3rem,7vw,5.6rem) var(--space-x);background:var(--page-bg);color:var(--page-fg);}
.case .wrap{max-width:58rem;margin:0 auto;}
.case .why-intro{margin-bottom:1.4rem;}
.case .why-intro p{margin:0 0 .55rem;color:var(--neutral-600);}
.case h2{margin:0;font-size:clamp(2rem,4vw,3.15rem);line-height:1.06;}
.case .rows{display:grid;gap:.7rem;}
.case article{display:grid;grid-template-columns:3.5rem 1fr;gap:1rem;align-items:start;padding:1rem;border:1px solid var(--card-border);background:var(--card-bg);color:var(--card-fg);border-radius:var(--radius-md);}
.case span{width:2.7rem;height:2.7rem;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:var(--muted-bg);color:var(--muted-fg);font-size:1.25rem;}
.case h3{margin:0;font-size:1.05rem;}
.case article p{margin:.35rem 0 0;color:var(--neutral-600);line-height:var(--line-height-base);}
@media (max-width:560px){.case article{grid-template-columns:1fr;}}

.answers{padding:clamp(18px,3vw,44px);background:var(--gradient-hero-bg);color:var(--gradient-hero-fg);overflow:hidden;position:relative;}

    .answers::before{content:'';position:absolute;inset:-40%;background:radial-gradient(circle at 30% 30%,color-mix(in srgb, currentColor 16%, transparent),transparent 55%),radial-gradient(circle at 70% 60%,rgba(255, 107, 53,0.18),transparent 52%);filter:blur(18px);animation:c1Glow 6s var(--anim-ease) infinite;opacity:.8;pointer-events:none;}

    @keyframes c1Glow{
        0%, 100% {transform:translate3d(-1%, 0,0) scale(1);}
        50%{transform:translate3d(1.5%,-1%,0) scale(1.03);}
    }

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

    .answers .h{margin-bottom:clamp(14px,2.2vw,22px);}

    .answers .title{margin:0;font-size:clamp(24px,4.6vw,44px);line-height:1.1;letter-spacing:-.02em;}

    .answers .sub{margin:10px 0 0;max-width:70ch;color:color-mix(in srgb, currentColor 82%, transparent);}

    .answers .grid{display:grid;gap:12px;}

    .answers .item{border-radius:var(--radius-xl);background:color-mix(in srgb, currentColor 10%, transparent);border:1px solid color-mix(in srgb, currentColor 16%, transparent);box-shadow:var(--shadow-md);overflow:hidden;backdrop-filter:blur(8px);}

    .answers .q{width:100%;display:flex;align-items:center;gap:12px;padding:14px 16px;background:transparent;border:0;color:inherit;cursor:pointer;text-align:left;}

    .answers .dot{width:10px;height:10px;border-radius:999px;background:var(--accent-bg);box-shadow:0 0 0 6px color-mix(in srgb, currentColor 12%, transparent);flex:0 0 auto;animation:c1Dot 1.8s ease-in-out infinite;color:var(--accent-fg);}

    @keyframes c1Dot{
        0%, 100% {transform:scale(1);opacity:.9;}
        50%{transform:scale(1.15);opacity:1;}
    }

    .answers .qtext{font-weight:800;letter-spacing:-.01em;}

    .answers .chev{margin-left:auto;opacity:.85;transition:transform var(--anim-duration) var(--anim-ease);}

    .answers .a{display:none;padding:0 16px 16px 38px;color:color-mix(in srgb, currentColor 82%, transparent);line-height:var(--line-height-base);}

    .answers .item.is-open .chev{transform:rotate(180deg);}

    .answers .item.is-open .a{display:block;}

    @media (prefers-reduced-motion: reduce){.answers::before,.answers .dot{animation:none;}
    }

.review-list{color:var(--page-fg);background:var(--page-bg);padding:clamp(16px,3vw,40px);}

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

    .review-list .h{text-align:center;margin-bottom:var(--space-y);}

    .review-list h1{font-size:clamp(28px,5vw,48px);margin:0 0 1rem;}

    .review-list .rating{display:flex;align-items:center;justify-content:center;gap:1rem;}

    .review-list .rating-value{font-size:2rem;font-weight:700;}

    .review-list .stars{font-size:1.5rem;}

    .review-list .filters{display:flex;gap:0.5rem;flex-wrap:wrap;margin-bottom:var(--space-y);justify-content:center;}

    .review-list .filter{padding:0.5rem 1rem;border-radius:var(--radius-md);border:1px solid color-mix(in srgb, currentColor 30%, transparent);background:var(--primary-bg);color:var(--primary-fg);cursor:pointer;transition:all var(--anim-duration) var(--anim-ease);}

    .review-list .filter:hover{background:color-mix(in srgb, currentColor 20%, transparent);}

    .review-list .grid{display:grid;gap:var(--space-x);}

    @media (min-width: 768px){.review-list .grid{grid-template-columns:repeat(2,minmax(0,1fr));}
    }

    @media (min-width: 1024px){.review-list .grid{grid-template-columns:repeat(3,minmax(0,1fr));}
    }

    .review-list .card{background:color-mix(in srgb, currentColor 10%, transparent);backdrop-filter:blur(10px);padding:clamp(16px,2vw,24px);border-radius:var(--radius-xl);border:1px solid color-mix(in srgb, currentColor 20%, transparent);box-shadow:var(--shadow-md);}

    .review-list .author{display:flex;gap:1rem;margin-bottom:1rem;align-items:center;}

    .review-list .avatar{width:48px;height:48px;border-radius:50%;background:var(--page-fg);display:flex;align-items:center;justify-content:center;font-weight:600;color:var(--page-bg);}

    .review-list h4{margin:0 0 0.25rem;}

    .review-list p{line-height:1.6;margin:0 0 1rem;}

    .review-list .date{font-size:0.875rem;}

.add-review-thread-stack {
  background: var(--gradient-hero-bg);
  color: var(--gradient-hero-fg);
  padding: var(--space-section-y) var(--space-section-x);
}
.add-review-thread-stack .wrap {
  width: min(100%, var(--max-w));
  margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(0, .5fr) minmax(0, 1fr);
  gap: var(--gap);
}
.add-review-thread-stack h2,
.add-review-thread-stack h3,
.add-review-thread-stack p { margin: 0; }
.add-review-thread-stack h2 { font-size: var(--font-size-h2); line-height: 1.08; }
.add-review-thread-stack h3 { font-size: var(--font-size-h3); line-height: 1.16; }
.add-review-thread-stack p { font-size: var(--font-size-md); line-height: var(--line-height-base); }
.add-review-thread-stack .thread-title {
  display: grid;
  gap: var(--space-y);
  align-content: start;
}
.add-review-thread-stack .bubble span { color: var(--muted-fg); }
.add-review-thread-stack .threads {
  display: grid;
  gap: var(--space-card);
}
.add-review-thread-stack .bubble {
  width: min(100%, 46rem);
  display: grid;
  gap: var(--space-card);
  padding: var(--space-y);
  border-radius: var(--radius-xl) var(--radius-xl) var(--radius-xl) var(--radius-sm);
  background: var(--card-bg);
  color: var(--card-fg);
  border: 1px solid var(--card-border);
  animation: reviewBubbleIn calc(var(--anim-duration) * 2.2) var(--anim-ease) both;
  animation-delay: var(--delay, 0ms);
}
.add-review-thread-stack .bubble:nth-child(2n) {
  justify-self: end;
  border-radius: var(--radius-xl) var(--radius-xl) var(--radius-sm) var(--radius-xl);
}
.add-review-thread-stack .reply {
  grid-column: 1 / -1;
  display: flex;
  justify-content: space-between;
  gap: var(--gap);
  align-items: center;
  padding: var(--space-y);
  border-radius: var(--radius-lg);
  background: var(--gradient-accent-bg);
  color: var(--gradient-accent-fg);
}
.add-review-thread-stack .reply a {
  color: inherit;
  text-decoration: none;
  border-bottom: 1px solid currentColor;
}
@keyframes reviewBubbleIn {
  from { opacity: .2; transform: translateY(calc(var(--motion-distance) * .16)); }
  to { opacity: 1; transform: translateY(0); }
}
@media (max-width: 820px) {
  .add-review-thread-stack .wrap { grid-template-columns: 1fr; }
  .add-review-thread-stack .bubble,
  .add-review-thread-stack .bubble:nth-child(2n) { justify-self: stretch; }
  .add-review-thread-stack .reply { flex-direction: column; align-items: flex-start; }
}

.area-review-item{color:var(--gradient-hero-fg);background:var(--gradient-hero-bg);padding:clamp(16px,3vw,40px);}

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

    .area-review-item .review{background:var(--card-bg);padding:clamp(24px,3vw,40px);border-radius:var(--radius-lg);border:1px solid var(--ring);box-shadow:var(--shadow-md);color:var(--card-fg);}

    .area-review-item .author-info{display:flex;gap:1rem;margin-bottom:var(--space-y);align-items:flex-start;}

    .area-review-item .avatar{width:64px;height:64px;border-radius:50%;background:var(--gradient-hero-bg);color:var(--gradient-hero-fg);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.5rem;}

    .area-review-item h1{font-size:clamp(24px,4vw,36px);margin:0 0 0.5rem;}

    .area-review-item .author{margin-bottom:0.5rem;}

    .area-review-item .rating{font-size:1.25rem;}

    .area-review-item .content{line-height:1.8;margin-bottom:var(--space-y);}

    .area-review-item .meta{padding-top:var(--space-y);border-top:1px solid var(--ring);font-size:0.875rem;}

.testimonials{padding:clamp(20px,3vw,44px);background:var(--muted-bg);color:var(--muted-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.2vw,40px);}

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

    .testimonials .quotes{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:12px;}

    .testimonials .quotes article{border-radius:var(--radius-lg);border:1px solid var(--card-border);background:var(--card-bg);padding:14px;color:var(--card-fg);}

    .testimonials .quotes p{margin:0;}

    .testimonials .quotes strong{display:block;margin-top:10px;}

    .testimonials .quotes span{display:block;margin-top:4px;}

.reviews{padding:clamp(56px,8vw,96px) clamp(16px,4vw,40px);background:radial-gradient(circle at 82% 18%,color-mix(in srgb,currentColor 20%,transparent),transparent 38%),var(--gradient-hero-bg);color:var(--gradient-hero-fg);}
.reviews .wrap{max-width:62rem;margin:0 auto;}
.reviews .head{display:grid;grid-template-columns:1fr minmax(14rem,.44fr);gap:var(--gap);align-items:end;margin-bottom:1rem;}
.reviews .head p{margin:0;color:color-mix(in srgb,currentColor 78%,transparent);}
.reviews h2{margin:0;font-size:clamp(2rem,4.4vw,3.5rem);line-height:1.04;}
.reviews .stack{display:grid;gap:.8rem;}
.reviews .quote{display:grid;grid-template-columns:8rem 1fr minmax(12rem,.42fr);gap:1rem;align-items:center;background:color-mix(in srgb,currentColor 10%,transparent);border:1px solid color-mix(in srgb,currentColor 18%,transparent);border-radius:var(--radius-lg);padding:1rem;}
.reviews .score{display:grid;gap:.25rem;font-size:.85rem;color:color-mix(in srgb,currentColor 78%,transparent);}
.reviews .stars{letter-spacing:.08em;}
.reviews blockquote{margin:0;line-height:1.6;}
.reviews .person{display:flex;gap:.7rem;align-items:center;}
.reviews .person span{width:2.4rem;height:2.4rem;border-radius:999px;background:var(--accent-bg);color:var(--accent-fg);display:inline-flex;align-items:center;justify-content:center;}
.reviews b,.reviews small{display:block;}
.reviews small{color:color-mix(in srgb,currentColor 72%,transparent);}
@media (max-width:820px){.reviews .head,.reviews .quote{grid-template-columns:1fr;}}

.tpl-variant-next-step-light-v8{background-image:linear-gradient(135deg,color-mix(in srgb,currentColor 6%,transparent),transparent 48%);}
.tpl-variant-next-step-light-v8 .grid,.tpl-variant-next-step-light-v8 .cards,.tpl-variant-next-step-light-v8 .list,.tpl-variant-next-step-light-v8 .stack{gap:calc(var(--gap,1rem) * 1.08);}
.tpl-variant-next-step-light-v8 article:nth-child(even),.tpl-variant-next-step-light-v8 .card:nth-child(even),.tpl-variant-next-step-light-v8 .item:nth-child(even){transform:translateY(0.35rem);}
.pathway{padding:clamp(3.2rem,7vw,5.7rem) var(--space-x);background:var(--muted-bg);color:var(--muted-fg);}

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

    .pathway .copy{margin-bottom:1rem;text-align:center;}

    .pathway .copy p{margin:0;}

    .pathway .copy h2{margin:.5rem 0 0;font-size:clamp(2rem,4vw,3rem);}

    .pathway .copy span{display:block;margin-top:.8rem;}

    .pathway .grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(13rem,1fr));gap:var(--gap);}

    .pathway .grid article{padding:1rem;border-radius:var(--radius-lg);background:var(--muted-bg);border:1px solid var(--card-border);box-shadow:var(--shadow-sm);color:var(--muted-fg);}

    .pathway .grid div{display:inline-flex;width:2.4rem;height:2.4rem;align-items:center;justify-content:center;border-radius:50%;background:var(--muted-bg);color:var(--muted-fg);}

    .pathway .grid h3{margin:.75rem 0 .35rem;}

    .pathway .grid a{text-decoration:none;}

    .pathway .foot{margin-top:1rem;text-align:center;}

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

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

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

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

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

    .panel-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;}

    .panel-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);}
    }

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

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

.message{padding:calc(var(--space-y)*2.9) var(--space-x);color:var(--page-fg);background:var(--page-bg);}
.message .shell{max-width:var(--max-w);margin:0 auto;display:grid;grid-template-columns:.9fr 1.1fr;gap:var(--gap);}
.message .form-intro{padding:1rem;border-radius:var(--radius-lg);background:var(--muted-bg);border:1px solid var(--card-border);color:var(--muted-fg);}
.message h2{margin:0;font-size:clamp(1.85rem,3.5vw,2.65rem);}
.message .form-intro p{margin:.45rem 0 0;}
.message .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);}
.message .grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.62rem;}
.message label{display:grid;gap:.28rem;}
.message span{font-size:.84rem;font-weight:700;}
.message input,.message 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);}
.message input:focus,.message textarea:focus{border-color:var(--ring);box-shadow:0 0 0 3px color-mix(in srgb,var(--ring) 20%,transparent);}
.message textarea{min-height:128px;resize:vertical;}
.message 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;}
.message button:hover{background:var(--primary-hover);color:var(--primary-fg);}
@media (max-width:920px){.message .shell,.message .grid{grid-template-columns:1fr;}}

.contacts-emberline {
        padding: calc(var(--space-y) * 3) var(--space-x);
        background: var(--gradient-hero-bg);
        color: var(--gradient-hero-fg);
    }

    .contacts-emberline .emberline-frame {
        max-width: 980px;
        margin: 0 auto
    }

    .contacts-emberline .emberline-title {
        margin-bottom: 1.15rem
    }

    .contacts-emberline h2 {
        margin: 0;
        font-size: clamp(2.1rem, 5vw, 4rem);
        line-height: 1
    }

    .contacts-emberline .emberline-title p {
        margin: .75rem 0 0;
        max-width: 42rem;
    }

    .contacts-emberline .emberline-actions {
        display: flex;
        gap: .8rem;
        margin-bottom: .8rem
    }

    .contacts-emberline .emberline-actions a {
        flex: 1;
        background: var(--accent-bg);
        color: var(--accent-fg);
        border-radius: var(--radius-xl);
        padding: 1.1rem;
        text-decoration: none;
        min-height: 8rem;
        display: flex;
        flex-direction: column;
        justify-content: space-between;
        overflow-wrap: anywhere
    }

    .contacts-emberline span {
        display: block;
        font-size: .82rem;
        opacity: .75
    }

    .contacts-emberline strong {
        font-size: 1.15rem;
    }

    .contacts-emberline .emberline-place {
        background: var(--card-bg);
        color: var(--card-fg);
        border-radius: var(--radius-lg);
        padding: .15rem 1rem
    }

    .contacts-emberline .emberline-place div {
        display: flex;
        justify-content: space-between;
        gap: 1rem;
        padding: .95rem 0
    }

    .contacts-emberline .emberline-place div + div {
        border-top: 1px solid var(--card-border)
    }

    .contacts-emberline .emberline-place span {
        color: var(--neutral-600);
        opacity: 1
    }

    .contacts-emberline p {
        margin: 0;
        line-height: 1.34;
    }

    .contacts-emberline .emberline-channels {
        display: flex;
        flex-wrap: wrap;
        gap: .55rem;
        margin-top: .85rem
    }

    .contacts-emberline .emberline-channels a {
        border: 1px solid rgba(255, 255, 255, .3);
        border-radius: var(--radius-md);
        padding: .62rem .75rem;
        text-decoration: none
    }

    .contacts-emberline em {
        display: block;
        font-style: normal;
        opacity: .74;
        overflow-wrap: anywhere
    }

    @media (max-width: 680px) {
        .contacts-emberline .emberline-actions, .contacts-emberline .emberline-place div {
            display: block
        }

        .contacts-emberline .emberline-actions a + a {
            margin-top: .75rem
        }

        .contacts-emberline p {
            text-align: left;
            margin-top: .25rem
        }
    }

.data-rules{padding:calc(var(--space-y)*2.95) var(--space-x);background:var(--muted-bg);color:var(--muted-fg);}
.data-rules .wrap{max-width:var(--max-w);margin:0 auto;}
.data-rules h2{margin:0 0 .85rem;font-size:clamp(1.76rem,3.1vw,2.45rem);}
.data-rules .cols{display:grid;grid-template-columns:.95fr 1.05fr;gap:var(--gap);}
.data-rules .left{padding:1rem;border-radius:var(--radius-lg);border:1px solid var(--card-border);background:var(--card-bg);color:var(--card-fg);}
.data-rules .left h3{margin:0 0 .32rem;}
.data-rules .left p{margin:0;}
.data-rules .right{list-style:none;margin:0;padding:0;display:grid;gap:.5rem;}
.data-rules .right li{padding:.8rem;border-radius:var(--radius-md);background:var(--card-bg);border:1px solid var(--card-border);color:var(--card-fg);}
.data-rules .right h4{margin:0 0 .2rem;font-size:1rem;}
.data-rules .right p{margin:0;}
.data-rules .note{display:flex;gap:.7rem;margin-top:.75rem;padding:.8rem;border-radius:var(--radius-md);background:var(--muted-bg);color:var(--muted-fg);}
@media (max-width:860px){.data-rules .cols{grid-template-columns:1fr;}.data-rules .note{display:grid;}}

.terms-indexsheet{padding:calc(var(--space-y)*2.75) var(--space-x);background:var(--muted-bg);color:var(--muted-fg);}
.terms-indexsheet .indexsheet-wrap{max-width:var(--max-w);margin:0 auto;display:grid;grid-template-columns:.8fr 1.2fr;gap:var(--gap);}.terms-indexsheet h2{margin:0;font-size:clamp(1.9rem,3.5vw,2.85rem);line-height:1.06;}.terms-indexsheet .header p{margin:.75rem 0 0;color:var(--neutral-600);}.terms-indexsheet .indexsheet-wrap>div{display:grid;gap:.6rem;}.terms-indexsheet .article{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-lg);padding:.9rem;color:var(--card-fg);}.terms-indexsheet h3{margin:0 0 .3rem;font-size:1rem;}.terms-indexsheet .article p{margin:0;color:var(--neutral-600);}
@media (max-width:800px){.terms-indexsheet .indexsheet-wrap{grid-template-columns:1fr;}}

.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 .hero{padding:1rem;border-radius:var(--radius-lg);background:var(--accent-bg);border:1px solid var(--btn-ghost-bg-hover);color:var(--accent-fg);} .done .stack{display:grid;gap:.45rem;margin-top:.7rem;} .done .stack p{padding:.65rem;border-radius:var(--radius-sm);background:var(--accent-bg);border:1px solid var(--btn-ghost-bg-hover);color:var(--accent-fg);} .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(--muted-bg);color:var(--muted-fg);}

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

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

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

    .error-page a{display:inline-block;margin-top:18px;padding:10px 16px;border-radius:var(--radius-sm);background:var(--primary-bg);color:var(--primary-fg);text-decoration:none;}