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

  --max-w: 1320px;
  --space-x: 2.1rem;
  --space-y: 1.5rem;
  --gap: 1.23rem;
  --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.31rem;
  --radius-lg: 0.83rem;
  --radius-md: 0.56rem;
  --radius-sm: 0.32rem;

  --shadow-sm: 0 1px 6px rgba(0,0,0,0.18);
  --shadow-md: 0 10px 22px rgba(0,0,0,0.23);
  --shadow-lg: 0 24px 34px rgba(0,0,0,0.28);

  --overlay: rgba(0,0,0,0.4);
  --anim-duration: 440ms;
  --anim-ease: cubic-bezier(0.2,0.8,0.2,1);
  --random-number: 1;

  --brand: #2B6B5E;
  --brand-contrast: #FFFFFF;
  --accent: #D97706;
  --accent-contrast: #FFFFFF;

  --neutral-0: #FFFFFF;
  --neutral-100: #F3F4F6;
  --neutral-300: #D1D5DB;
  --neutral-600: #6B7280;
  --neutral-800: #1F2937;
  --neutral-900: #111827;

  --page-bg: #F9FAFB;
  --page-fg: #1F2937;
  --muted-bg: #F3F4F6;
  --muted-fg: #6B7280;
  --card-bg: #FFFFFF;
  --card-fg: #1F2937;
  --card-border: #E5E7EB;
  --inverse-bg: #1F2937;
  --inverse-fg: #F9FAFB;
  --primary-bg: #2B6B5E;
  --primary-fg: #FFFFFF;
  --primary-hover: #1F4F45;
  --accent-bg: #D97706;
  --accent-fg: #FFFFFF;
  --accent-hover: #B45309;
  --gradient-hero-bg: linear-gradient(135deg, #2B6B5E 0%, #3D8B7A 100%);
  --gradient-hero-fg: #FFFFFF;
  --gradient-accent-bg: linear-gradient(135deg, #D97706 0%, #F59E0B 100%);
  --gradient-accent-fg: #FFFFFF;

  --ring: #2B6B5E;

  --link: #2B6B5E;
  --link-hover: #D97706;

  --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(--page-bg);
  border-bottom: 1px solid var(--card-border);
  width: 100%;
}

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

.logo {
  font-size: var(--font-size-h3);
  font-weight: 700;
  color: var(--page-fg);
  text-decoration: none;
  white-space: nowrap;
  flex-shrink: 0;
}

.main-nav {
  display: flex;
  align-items: center;
}

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

.nav-list a {
  text-decoration: none;
  color: var(--page-fg);
  font-size: var(--font-size-md);
  padding: 0.25rem 0;
  transition: color var(--anim-duration) var(--anim-ease);
  position: relative;
}

.nav-list a:hover,
.nav-list a:focus-visible {
  color: var(--primary-bg);
}

.nav-list a::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 100%;
  height: 2px;
  background-color: var(--primary-bg);
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform var(--anim-duration) var(--anim-ease);
}

.nav-list a:hover::after,
.nav-list a:focus-visible::after {
  transform: scaleX(1);
}

.cta-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background-color: var(--primary-bg);
  color: var(--primary-fg);
  font-size: var(--font-size-md);
  font-weight: 600;
  padding: 0.5rem 1.25rem;
  border-radius: var(--radius-md);
  text-decoration: none;
  white-space: nowrap;
  transition: background-color var(--anim-duration) var(--anim-ease), transform var(--anim-duration) var(--anim-ease);
  flex-shrink: 0;
}

.cta-button:hover,
.cta-button:focus-visible {
  background-color: var(--primary-hover);
  transform: translateY(-1px);
}

.burger {
  display: none;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 2.5rem;
  height: 2.5rem;
  background: none;
  border: none;
  cursor: pointer;
  padding: 0.5rem;
  gap: 4px;
  flex-shrink: 0;
}

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

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

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

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

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

  .main-nav {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: var(--page-bg);
    z-index: 1000;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    visibility: hidden;
    transition: opacity var(--anim-duration) var(--anim-ease), visibility var(--anim-duration) var(--anim-ease);
  }

  .main-nav.open {
    opacity: 1;
    visibility: visible;
  }

  .nav-list {
    flex-direction: column;
    align-items: center;
    gap: var(--space-y);
  }

  .nav-list a {
    font-size: var(--font-size-h3);
  }

  .cta-button {
    display: none;
  }
}

@media (min-width: 768px) {
  .main-nav {
    position: static;
    opacity: 1;
    visibility: visible;
    background: none;
    width: auto;
    height: auto;
  }

  .nav-list {
    flex-direction: row;
  }
}

.footer-container {
      max-width: 1200px;
      margin: 0 auto;
      padding: 2rem 1.5rem;
      background-color: #f8f9fa;
      border-top: 2px solid #e0e0e0;
      font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
      color: #333;
      line-height: 1.6;
    }
    .footer-contact address {
      font-style: normal;
      display: flex;
      flex-wrap: wrap;
      gap: 1.5rem;
      margin-bottom: 1.5rem;
      padding: 0.5rem 0;
    }
    .contact-item {
      font-size: 0.95rem;
    }
    .contact-item a {
      color: #007bff;
      text-decoration: none;
      transition: color 0.2s;
    }
    .contact-item a:hover {
      color: #0056b3;
      text-decoration: underline;
    }
    .footer-brand {
      margin-bottom: 1rem;
    }
    .footer-logo {
      font-size: 1.8rem;
      font-weight: 700;
      color: #222;
      letter-spacing: 1px;
    }
    .footer-nav ul {
      list-style: none;
      padding: 0;
      margin: 0 0 1.5rem 0;
      display: flex;
      flex-wrap: wrap;
      gap: 1.2rem;
    }
    .footer-nav a {
      color: #555;
      text-decoration: none;
      font-size: 0.95rem;
      transition: color 0.2s;
    }
    .footer-nav a:hover {
      color: #007bff;
    }
    .footer-legal ul {
      list-style: none;
      padding: 0;
      margin: 0 0 1.5rem 0;
      display: flex;
      flex-wrap: wrap;
      gap: 1.2rem;
    }
    .footer-legal a {
      color: #555;
      text-decoration: none;
      font-size: 0.9rem;
      transition: color 0.2s;
    }
    .footer-legal a:hover {
      color: #007bff;
    }
    .footer-disclaimer {
      margin-bottom: 1rem;
      padding: 0.75rem 0;
      border-top: 1px solid #ddd;
      border-bottom: 1px solid #ddd;
    }
    .footer-disclaimer p {
      font-size: 0.85rem;
      color: #666;
      margin: 0;
      line-height: 1.5;
    }
    .footer-copyright {
      font-size: 0.85rem;
      color: #888;
      text-align: center;
      margin-top: 0.5rem;
    }
    @media (max-width: 600px) {
      .footer-container {
        padding: 1.5rem 1rem;
      }
      .footer-contact address {
        flex-direction: column;
        gap: 0.5rem;
      }
      .footer-nav ul,
      .footer-legal ul {
        flex-direction: column;
        gap: 0.5rem;
      }
      .footer-logo {
        font-size: 1.5rem;
      }
    }

.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: radial-gradient(circle at top right, var(--accent-bg), var(--primary-bg));
    color: var(--accent-fg);
    box-shadow: var(--shadow-lg);
    border: 1px solid rgba(148, 163, 184, 0.35);
}

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

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

.cookies .top a {
    text-decoration: underline;
    text-underline-offset: 2px;
    font-size: 13px;
}

.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, 0.45);
    padding: 9px 12px;
    color: var(--neutral-0);
    background: rgba(51, 65, 85, 0.65);
    cursor: pointer;
}

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

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

*{box-sizing:border-box;}

    .intro{padding:clamp(3.6rem,8vw,6.5rem) var(--space-x);background:linear-gradient(180deg,var(--card-bg),var(--muted-bg));color:var(--card-fg);}

    .intro .wrap{max-width:var(--max-w);margin:0 auto;display:grid;grid-template-columns:1.1fr .9fr;gap:1rem;align-items:start;}

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

    .intro .copy h1{margin:.6rem 0 0;font-size:clamp(2.4rem,5vw,4.1rem);line-height:1.04;}

    .intro .copy span{display:block;margin-top:.9rem;}

    .intro .stats{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem;}

    .intro .stats div{padding:1rem;border-radius:var(--radius-lg);background:var(--card-bg);border:1px solid var(--card-border);color:var(--card-fg);}

    .intro .stats strong{display:block;font-size:1.35rem;}

    .intro .stats span{display:block;margin-top:.25rem;}

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

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

    .voices::before{content:'';position:absolute;inset:-30%;background:radial-gradient(circle at 25% 25%,color-mix(in srgb, currentColor 14%, transparent),transparent 55%),radial-gradient(circle at 80% 55%,rgba(255, 107, 53,0.18),transparent 55%);filter:blur(18px);animation:socialC2Bg 7s var(--anim-ease) infinite;pointer-events:none;}

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

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

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

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

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

    .voices .grid{display:grid;grid-template-columns:1.2fr 0.8fr;gap:14px;align-items:stretch;}

    .voices .quotes{position:relative;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-lg);overflow:hidden;}

    .voices .quote{display:none;padding:18px 18px 16px;}

    .voices .quote.is-on{display:block;}

    .voices .qtext{font-size:clamp(16px,2.2vw,20px);line-height:1.7;color:color-mix(in srgb, currentColor 92%, transparent);}

    .voices .qmeta{margin-top:14px;display:flex;gap:10px;align-items:baseline;flex-wrap:wrap;}

    .voices .qname{font-weight:900;}

    .voices .qrole{opacity:.85;}

    .voices .metrics{display:grid;gap:12px;}

    .voices .metric{border-radius:var(--radius-xl);background:color-mix(in srgb, currentColor 14%, transparent);border:1px solid color-mix(in srgb, currentColor 14%, transparent);box-shadow:var(--shadow-md);padding:16px;}

    .voices .mval{font-weight:900;font-size:clamp(22px,3vw,32px);letter-spacing:-.01em;}

    .voices .mlbl{margin-top:6px;color:color-mix(in srgb, currentColor 82%, transparent);}

    @media (max-width: 980px){.voices .grid{grid-template-columns:1fr;}
    }

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

.faq-receiptlist {
  background: var(--page-bg);
  color: var(--page-fg);
  padding: var(--space-section-y) var(--space-section-x);
}
.faq-receiptlist .receipt {
  max-width: calc(var(--max-w) * .72);
  margin: 0 auto;
  background: var(--card-bg);
  color: var(--card-fg);
  border: 1px solid var(--card-border);
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}
.faq-receiptlist .summary {
  background: var(--muted-bg);
  color: var(--muted-fg);
  padding: var(--space-card);
  display: grid;
  gap: var(--space-card);
}
.faq-receiptlist h2,
.faq-receiptlist p {
  margin: 0;
}
.faq-receiptlist h2 {
  font-size: var(--font-size-h2);
  line-height: 1.05;
}
.faq-receiptlist .list {
  display: grid;
}
.faq-receiptlist .row {
  padding: var(--space-card);
  border-bottom: 1px solid var(--card-border);
  animation: faq-receiptlist-soft calc(var(--anim-duration) * 2) var(--anim-ease) both;
}
.faq-receiptlist .row:nth-child(2) { animation-delay: calc(var(--anim-duration) * .25); }
.faq-receiptlist .row:nth-child(3) { animation-delay: calc(var(--anim-duration) * .5); }
.faq-receiptlist .row:last-child {
  border-bottom: 0;
}
.faq-receiptlist strong {
  display: block;
  font-size: var(--font-size-h3);
  margin-bottom: calc(var(--space-card) * .35);
}
@keyframes faq-receiptlist-soft {
  from { opacity: 0; transform: translateY(calc(var(--motion-distance) * .16)); }
  to { opacity: 1; transform: translateY(0); }
}
@media (max-width: 640px) {
  .faq-receiptlist .receipt {
    max-width: var(--max-w);
  }
}

.stay-in-touch{padding:clamp(56px,8vw,96px) 16px;background:linear-gradient(145deg,var(--primary-bg),var(--accent-bg));color:var(--primary-fg);}

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

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

    .stay-in-touch .lead{margin:10px 0 14px;opacity:.92;}

    .stay-in-touch .lane{display:flex;gap:10px;overflow-x:auto;padding-bottom:6px;}

    .stay-in-touch .lane article{min-width:250px;border:1px solid color-mix(in srgb, currentColor 28%, transparent);border-radius:var(--radius-lg);background:color-mix(in srgb, currentColor 10%, transparent);padding:12px;}

    .stay-in-touch .lane h3{margin:0 0 8px;}

    .stay-in-touch .lane p{margin:0 0 8px;}

    .stay-in-touch .lane a{text-decoration:underline;}

    .stay-in-touch .main{display:inline-block;margin-top:12px;text-decoration:none;padding:10px 14px;border-radius:10px;background:var(--primary-fg);color:var(--primary-bg);}

.tpl-variant-review-list-colored-v2{background-image:linear-gradient(135deg,color-mix(in srgb,currentColor 6%,transparent),transparent 48%);}
.tpl-variant-review-list-colored-v2 .grid,.tpl-variant-review-list-colored-v2 .cards,.tpl-variant-review-list-colored-v2 .list,.tpl-variant-review-list-colored-v2 .stack{gap:calc(var(--gap,1rem) * 1.08);}
.tpl-variant-review-list-colored-v2 article:nth-child(even),.tpl-variant-review-list-colored-v2 .card:nth-child(even),.tpl-variant-review-list-colored-v2 .item:nth-child(even){transform:translateY(0.35rem);}
.panel-review-list{color:var(--gradient-hero-fg);background:var(--gradient-hero-bg);padding:clamp(16px,3vw,40px);}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

    .panel-review-list .avatar{width:48px;height:48px;border-radius:50%;background:color-mix(in srgb, currentColor 20%, transparent);display:flex;align-items:center;justify-content:center;font-weight:600;}

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

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

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

.addreview-stepnote {
  background: var(--muted-bg);
  color: var(--muted-fg);
  padding: var(--space-section-y) var(--space-section-x);
}
.addreview-stepnote .wrap {
  max-width: var(--max-w);
  margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(0, .7fr) minmax(0, 1.3fr);
  gap: var(--space-block);
}
.addreview-stepnote .steps {
  display: grid;
  gap: var(--space-card);
}
.addreview-stepnote .step {
  background: var(--page-bg);
  color: var(--page-fg);
  border-radius: var(--radius-lg);
  padding: var(--space-card);
  border: 1px solid var(--card-border);
}
.addreview-stepnote .step span {
  display: block;
  color: var(--primary-bg);
  font-size: var(--font-size-h3);
  margin-bottom: calc(var(--space-card) * .4);
}
.addreview-stepnote h2,
.addreview-stepnote p {
  margin: 0;
}
.addreview-stepnote .note {
  background: var(--card-bg);
  color: var(--card-fg);
  border: 1px solid var(--card-border);
  border-radius: var(--radius-xl);
  padding: var(--space-card);
  display: grid;
  gap: var(--gap);
}
.addreview-stepnote h2 {
  font-size: var(--font-size-h2);
  line-height: 1.04;
}
.addreview-stepnote label {
  display: grid;
  gap: calc(var(--space-card) * .4);
}
.addreview-stepnote textarea,
.addreview-stepnote input {
  width: 100%;
  min-width: 0;
  border: 1px solid var(--card-border);
  border-radius: var(--radius-md);
  background: var(--page-bg);
  color: var(--page-fg);
  padding: var(--space-card);
  font: inherit;
}
.addreview-stepnote .actions {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: var(--space-card);
}
.addreview-stepnote button {
  border: 0;
  border-radius: var(--radius-md);
  background: var(--primary-bg);
  color: var(--primary-fg);
  padding: var(--space-card);
  font: inherit;
  cursor: pointer;
}
@media (max-width: 780px) {
  .addreview-stepnote .wrap,
  .addreview-stepnote .actions {
    grid-template-columns: 1fr;
  }
}

.opinions{background:var(--muted-bg);color:var(--muted-fg);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 .eyebrow{margin:0 0 10px;text-transform:uppercase;letter-spacing:0.22em;font-size:12px;}

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

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

    .opinions .row{border:1px solid var(--card-border);border-radius:var(--radius-lg);background:var(--muted-bg);box-shadow:var(--shadow-sm);overflow:hidden;transform:translateY(24px);color:var(--muted-fg);}

    .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;text-align:left;}

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

    .opinions .index-feedback-list__avatar{width:36px;height:36px;border-radius:12px;background:var(--accent-bg);border:1px solid var(--card-border);display:flex;align-items:center;justify-content:center;flex:0 0 auto;color:var(--accent-fg);}

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

    .opinions .meta{font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:24ch;}

    .opinions .rating{display:inline-flex;align-items:center;gap:8px;flex:0 0 auto;padding:6px 10px;border-radius:999px;background:var(--muted-bg);border:1px solid var(--card-border);color:var(--muted-fg);}

    .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;overflow:hidden;}

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

    .opinions .chip{display:inline-flex;margin-top:10px;padding:6px 10px;border-radius:999px;background:var(--primary-bg);border:1px solid var(--ring);color:var(--primary-fg);letter-spacing:0.14em;text-transform:uppercase;font-size:10px;}

    @media (max-width: 560px){.opinions .q{align-items:flex-start;}

        .opinions .rating{margin-top:2px;}

        .opinions .meta{display:none;}
    }

.connect-rivercall{padding:calc(var(--space-y)*3) var(--space-x);background:var(--primary-bg);color:var(--primary-fg)}
.connect-rivercall .rivercall-wrap{max-width:860px;margin:0 auto}
.connect-rivercall .rivercall-copy{max-width:44rem;margin-bottom:1rem}
.connect-rivercall h2{margin:0;color:var(--primary-fg);font-size:clamp(2rem,4.4vw,3.45rem);line-height:1.02}
.connect-rivercall p{margin:.7rem 0 0;color:var(--primary-fg);opacity:.9}
.connect-rivercall .rivercall-card{background:var(--card-bg);color:var(--card-fg);border-radius:var(--radius-xl);padding:.2rem 1rem;box-shadow:var(--shadow-lg)}
.connect-rivercall a{display:flex;justify-content:space-between;gap:1rem;padding:1rem 0;color:var(--card-fg);text-decoration:none}
.connect-rivercall a+a{border-top:1px solid var(--card-border)}
.connect-rivercall span{color:var(--neutral-600);font-size:.84rem}
.connect-rivercall b{max-width:34rem;text-align:right;color:var(--link);overflow-wrap:anywhere}
@media (max-width:620px){.connect-rivercall a{display:block}.connect-rivercall b{display:block;text-align:left;margin-top:.25rem}}

.rationale{background:var(--muted-bg);color:var(--muted-fg);padding:clamp(40px,6vw,80px) clamp(16px,3vw,40px);}

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

    .rationale .h{text-align:center;margin-bottom:clamp(32px,5vw,64px);}

    .rationale h2{font-size:clamp(32px,5vw,48px);margin:0 0 1rem;position:relative;display:inline-block;}

    .rationale h2::after{content:'';position:absolute;bottom:-8px;left:0;width:100%;height:4px;background:var(--primary-bg);border-radius:var(--radius-sm);transform-origin:left;color:var(--primary-fg);}

    .rationale .subtitle{font-size:clamp(16px,2vw,20px);margin:0;}

    .rationale .list{display:flex;flex-direction:column;gap:clamp(16px,2vw,24px);}

    .rationale .item{display:flex;gap:clamp(16px,2vw,24px);background:var(--card-bg);padding:clamp(20px,3vw,32px);border-radius:var(--radius-lg);border:1px solid var(--card-border);box-shadow:var(--shadow-sm);align-items:flex-start;position:relative;overflow:hidden;transition:transform var(--anim-duration) var(--anim-ease);color:var(--card-fg);}

    .rationale .wave{position:absolute;bottom:0;left:0;width:100%;height:4px;background:linear-gradient(90deg,var(--primary-bg),var(--accent-bg));transform:scaleX(.18);transform-origin:left;transition:transform var(--anim-duration) var(--anim-ease);color:var(--primary-fg);}

    .rationale .item:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);}

    .rationale .item:hover .wave{transform:scaleX(1);}

    .rationale .content{flex:1;}

    .rationale .item h3{font-size:clamp(18px,2.2vw,24px);margin:0 0 0.75rem;position:relative;}

    .rationale .item h3::before{content:'';position:absolute;left:-12px;top:50%;transform:translateY(-50%);width:4px;height:0;background:var(--primary-bg);border-radius:var(--radius-sm);transition:height var(--anim-duration) var(--anim-ease);color:var(--primary-fg);}

    .rationale .item:hover h3::before{height:100%;}

    .rationale .item p{margin:0;line-height:var(--line-height-base);}

.contacts-foldmark{padding:calc(var(--space-y)*2.9) var(--space-x);background:var(--inverse-bg);color:var(--inverse-fg)}
.contacts-foldmark .foldmark-shell{max-width:820px;margin:0 auto}
.contacts-foldmark .foldmark-title{position:relative;padding-left:1rem;margin-bottom:1rem}
.contacts-foldmark .foldmark-title:before{content:"";position:absolute;left:0;top:.25rem;bottom:.25rem;width:4px;background:var(--accent-bg);border-radius:99px}
.contacts-foldmark h2{margin:0;color:var(--inverse-fg);font-size:clamp(1.9rem,4vw,3.15rem);line-height:1.04}
.contacts-foldmark .foldmark-title p{margin:.8rem 0 0;color:var(--neutral-600)}
.contacts-foldmark .foldmark-directory{background:var(--muted-bg);color:var(--muted-fg);border-radius:var(--radius-xl);padding:.2rem 1rem}
.contacts-foldmark .foldmark-directory>div,.contacts-foldmark .foldmark-directory>a{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 0;color:var(--muted-fg);text-decoration:none}
.contacts-foldmark .foldmark-directory>*+*{border-top:1px solid var(--card-border)}
.contacts-foldmark small{color:var(--neutral-600);font-size:.82rem}
.contacts-foldmark strong{max-width:32rem;text-align:right;color:var(--muted-fg);line-height:1.32;overflow-wrap:anywhere}
.contacts-foldmark .foldmark-links{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:.8rem}
.contacts-foldmark .foldmark-links a{border:1px solid var(--card-border);color:var(--link);text-decoration:none;border-radius:999px;padding:.5rem .68rem;background:var(--inverse-bg)}
.contacts-foldmark .foldmark-links span{color:var(--neutral-600)}
@media (max-width:620px){.contacts-foldmark .foldmark-directory>div,.contacts-foldmark .foldmark-directory>a{display:block}.contacts-foldmark strong{display:block;text-align:left;margin-top:.25rem}}

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

.lead .shell {max-width:var(--max-w);margin:0 auto;display:grid;gap:var(--gap);}

.lead h2 {margin:0;font-size:clamp(1.85rem, 3.6vw, 2.8rem);line-height:1.1;}

.lead .sub {margin:.35rem 0 0;opacity:.9;}

.lead .panel, .lead .box {padding:1.1rem;border-radius:var(--radius-xl);background:var(--accent-bg);border:1px solid var(--btn-ghost-bg-hover);box-shadow:var(--shadow-md);color:var(--accent-fg);}

.lead form {display:grid;gap:.75rem;}

.lead .field {display:grid;gap:.28rem;}

.lead .field span {font-size:.82rem;font-weight:700;}

.lead input, .lead textarea {width:100%;padding:.8rem .85rem;border-radius:var(--radius-md);border:1px solid var(--card-border);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) 22%, transparent);}

.lead textarea {min-height:120px;resize:vertical;}

.lead button {padding:.82rem 1rem;border:0;border-radius:var(--radius-md);background:var(--primary-bg);color:var(--primary-fg);font-weight:700;cursor:pointer;transition:transform var(--anim-duration) var(--anim-ease), background var(--anim-duration) var(--anim-ease);}

.lead button:hover {transform:translateY(-1px);background:var(--primary-hover);color:var(--primary-fg);}

.lead .split {display:grid;grid-template-columns:1fr 1fr;gap:var(--gap);}

.lead .grid {display:grid;grid-template-columns:repeat(2, minmax(0, 1fr));gap:.65rem;}

.lead .line {padding:1rem;border-radius:var(--radius-lg);background:var(--accent-bg);border:1px solid var(--btn-ghost-bg-hover);color:var(--accent-fg);}

.lead .bar {display:grid;grid-template-columns:repeat(2, minmax(0, 1fr));gap:.65rem;padding:1rem;border-radius:var(--radius-lg);background:var(--accent-bg);border:1px solid var(--btn-ghost-bg-hover);color:var(--accent-fg);}

.lead .stack {padding:1rem;border-radius:var(--radius-lg);background:var(--accent-bg);border:1px solid var(--btn-ghost-bg-hover);color:var(--accent-fg);}

.lead .steps {display:flex;gap:.45rem;flex-wrap:wrap;}

.lead .steps span {padding:.33rem .55rem;border-radius:var(--radius-sm);background:var(--accent-bg);border:1px solid var(--btn-ghost-bg-hover);font-size:.8rem;color:var(--accent-fg);}

.lead .agree {display:flex;align-items:center;gap:.45rem;font-size:.86rem;}

.lead .media {display:grid;grid-template-columns:.9fr 1.1fr;gap:var(--gap);}

.lead .media img, .lead .frame img {width:100%;height:100%;min-height:320px;object-fit:cover;border-radius:var(--radius-xl);}

.lead .frame {display:grid;grid-template-columns:1.1fr .9fr;gap:var(--gap);}

.lead .full {grid-column:1/-1;}

@media (max-width: 860px) {
    .lead .split, .lead .media, .lead .frame {grid-template-columns:1fr;}

    .lead .grid, .lead .bar {grid-template-columns:1fr;}
}

.policy-items{padding:calc(var(--space-y)*3) var(--space-x);background:var(--muted-bg);color:var(--muted-fg);}
.policy-items .max{max-width:var(--max-w);margin:0 auto;display:grid;gap:.82rem;}
.policy-items h2{margin:0;font-size:clamp(1.72rem,3.1vw,2.42rem);}
.policy-items .head p{margin:.38rem 0 0;}
.policy-items .stream{display:grid;gap:.54rem;}
.policy-items article{padding:.85rem .9rem;border-inline-start:4px solid var(--primary-bg);border-radius:var(--radius-sm);background:var(--card-bg);border:1px solid var(--card-border);color:var(--card-fg);}
.policy-items h3{margin:0 0 .24rem;font-size:1rem;}
.policy-items article p{margin:0;}
.policy-items .contact{margin:0;padding:.85rem;border-radius:var(--radius-md);background:var(--card-bg);border:1px dashed var(--card-border);color:var(--card-fg);}
.policy-items .contact a{color:var(--link);}
.policy-items .contact a:hover{color:var(--link-hover);}

.terms{padding:clamp(56px,8vw,96px) clamp(16px,4vw,36px);background:linear-gradient(180deg,var(--accent-bg),var(--card-bg));color:var(--accent-fg);}

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

    .terms .section-head{margin-bottom:14px;}

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

    .terms .section-head p{margin:10px 0 0;}

    .terms details{border:1px solid var(--card-border);border-radius:var(--radius-md);background:var(--card-bg);padding:10px 12px;margin-bottom:10px;color:var(--card-fg);}

    .terms summary{cursor:pointer;font-weight:700;}

    .terms h4{margin:10px 0 6px;}

    .terms p,.terms li{}

.done {
    padding: calc(var(--space-y) * 2.9) var(--space-x);
    background: var(--inverse-bg);
    color: var(--inverse-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: 0.35rem 0 0;
    opacity: 0.9;
  }
  .done article,
  .done li {
    padding: 0.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 .split {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--gap);
  }
  .done .panel {
    padding: 1rem;
    border-radius: var(--radius-lg);
    background: var(--accent-bg);
    border: 1px solid var(--btn-ghost-bg-hover);
    color: var(--accent-fg);
  }
  .done .grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.55rem;
  }
  @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,114px) 20px;background:linear-gradient(180deg,var(--accent-bg),var(--page-bg));color:var(--accent-fg);}

    .error-page .tile{max-width:760px;margin:0 auto;text-align:center;padding:clamp(28px,4vw,44px);background:var(--card-bg);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);border-top:8px solid var(--accent-bg);color:var(--card-fg);}

    .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;padding:10px 18px;border-radius:999px;border:1px solid var(--card-border);text-decoration:none;}