:root {
  --font-family: "Fira Sans", sans-serif;
  --font-size-base: 17.4px;
  --line-height-base: 1.74;

  --max-w: 1600px;
  --space-x: 2.24rem;
  --space-y: 1.5rem;
  --gap: 1.97rem;
  --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.18rem;
  --radius-lg: 1rem;
  --radius-md: 0.46rem;
  --radius-sm: 0.34rem;

  --shadow-sm: 0 2px 8px rgba(0,0,0,0.14);
  --shadow-md: 0 8px 18px rgba(0,0,0,0.18);
  --shadow-lg: 0 16px 54px rgba(0,0,0,0.22);

  --overlay: rgba(0,0,0,0.7);
  --anim-duration: 330ms;
  --anim-ease: cubic-bezier(0.22,1,0.36,1);
  --random-number: 2;

  --brand: #00e676;
  --brand-contrast: #0a0a0f;
  --accent: #00e676;
  --accent-contrast: #0a0a0f;

  --neutral-0: #0a0a0f;
  --neutral-100: #14141c;
  --neutral-300: #2a2a38;
  --neutral-600: #6b6b7a;
  --neutral-800: #b0b0c0;
  --neutral-900: #e0e0f0;

  --page-bg: #0a0a0f;
  --page-fg: #e0e0f0;
  --muted-bg: #14141c;
  --muted-fg: #b0b0c0;
  --card-bg: #1a1a26;
  --card-fg: #d0d0e0;
  --card-border: #2a2a3a;
  --inverse-bg: #e0e0f0;
  --inverse-fg: #0a0a0f;
  --primary-bg: #00e676;
  --primary-fg: #0a0a0f;
  --primary-hover: #00c853;
  --accent-bg: #00e676;
  --accent-fg: #0a0a0f;
  --accent-hover: #00c853;
  --gradient-hero-bg: linear-gradient(135deg, #0a0a0f 0%, #1a1a2e 50%, #0d0d1a 100%);
  --gradient-hero-fg: #e0e0f0;
  --gradient-accent-bg: linear-gradient(135deg, #00e676 0%, #00c853 100%);
  --gradient-accent-fg: #0a0a0f;

  --ring: #00e676;

  --link: #00e676;
  --link-hover: #00e676;

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

/* ===== ESTILOS DEL HEADER ===== */
.site-header {
  background-color: var(--primary-bg, #0b1a2f);
  color: var(--primary-fg, #ffffff);
  width: 100%;
  box-shadow: var(--shadow-sm, 0 2px 8px rgba(0,0,0,0.08));
  /* Sin position fixed/sticky */
}

.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  max-width: var(--max-w, 1200px);
  margin: 0 auto;
  padding: var(--space-y, 0.8rem) var(--space-x, 1.5rem);
  gap: var(--gap, 1.5rem);
  flex-wrap: nowrap;
}

/* Logo */
.logo {
  font-size: var(--font-size-h3, 1.5rem);
  font-weight: 700;
  color: var(--primary-fg, #ffffff);
  text-decoration: none;
  letter-spacing: -0.02em;
  white-space: nowrap;
  flex-shrink: 0;
}
.logo:hover {
  opacity: 0.9;
}

/* Navegación principal (desktop) */
.primary-nav {
  display: flex;
  align-items: center;
}

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

.nav-list a {
  color: var(--primary-fg, #ffffff);
  text-decoration: none;
  font-size: var(--font-size-md, 1rem);
  font-weight: 500;
  padding: 0.25rem 0;
  border-bottom: 2px solid transparent;
  transition: border-color var(--anim-duration, 0.2s) var(--anim-ease, ease);
}

.nav-list a:hover {
  border-bottom-color: var(--accent-bg, #f0b429);
}

/* CTA zona (desktop) */
.cta-area {
  display: flex;
  align-items: center;
  flex-shrink: 0;
}

.cta-button {
  display: inline-block;
  background-color: var(--accent-bg, #f0b429);
  color: var(--accent-fg, #0b1a2f);
  font-weight: 600;
  font-size: var(--font-size-sm, 0.9rem);
  padding: 0.6rem 1.4rem;
  border-radius: var(--radius-md, 6px);
  text-decoration: none;
  transition: background-color var(--anim-duration, 0.2s) var(--anim-ease, ease), transform 0.1s ease;
  white-space: nowrap;
}

.cta-button:hover {
  background-color: var(--accent-hover, #d49f1f);
  transform: scale(1.02);
}

/* Botón burger (móvil) */
.burger-btn {
  display: none;  /* oculto en desktop */
  flex-direction: column;
  justify-content: center;
  align-items: center;
  background: transparent;
  border: none;
  cursor: pointer;
  padding: 0.4rem;
  gap: 5px;
  width: 40px;
  height: 40px;
  border-radius: var(--radius-sm, 4px);
  transition: background-color 0.2s;
}

.burger-btn:hover {
  background-color: rgba(255,255,255,0.1);
}

.burger-line {
  display: block;
  width: 26px;
  height: 3px;
  background-color: var(--primary-fg, #ffffff);
  border-radius: 2px;
  transition: all 0.2s ease;
}

/* Mobile menu (oculto por defecto) */
.mobile-menu {
  display: none;
  background-color: var(--primary-bg, #0b1a2f);
  padding: 0 var(--space-x, 1.5rem) var(--space-y, 1rem) var(--space-x, 1.5rem);
  border-top: 1px solid rgba(255,255,255,0.1);
}

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

.mobile-nav-list {
  list-style: none;
  margin: 0;
  padding: 0.5rem 0 0 0;
}

.mobile-nav-list li {
  padding: 0.6rem 0;
  border-bottom: 1px solid rgba(255,255,255,0.08);
}

.mobile-nav-list a {
  color: var(--primary-fg, #ffffff);
  text-decoration: none;
  font-size: var(--font-size-md, 1rem);
  font-weight: 500;
  display: block;
}

.mobile-nav-list a:hover {
  color: var(--accent-bg, #f0b429);
}

.mobile-cta {
  margin-top: 1rem;
  padding-bottom: 0.5rem;
}

.mobile-cta .cta-button {
  display: block;
  text-align: center;
}

/* ===== RESPONSIVE ===== */
@media (max-width: 767px) {
  .header-inner {
    padding: var(--space-y, 0.8rem) var(--space-x, 1rem);
  }

  .primary-nav,
  .cta-area {
    display: none;  /* ocultar nav y cta en móvil */
  }

  .burger-btn {
    display: flex;  /* mostrar burger */
  }

  /* Ajuste de logo en móvil */
  .logo {
    font-size: var(--font-size-h3, 1.4rem);
  }
}

@media (min-width: 768px) {
  .mobile-menu {
    display: none !important; /* nunca visible en desktop */
  }
  .burger-btn {
    display: none !important;
  }
}

footer {
      background-color: #1a1a2e;
      color: #e0e0e0;
      padding: 2.5rem 1.5rem;
      font-family: 'Segoe UI', system-ui, -apple-system, sans-serif;
      font-size: 0.95rem;
      line-height: 1.6;
    }
    .footer-container {
      max-width: 1200px;
      margin: 0 auto;
      display: flex;
      flex-direction: column;
      gap: 1.8rem;
    }
    .footer-contact address {
      font-style: normal;
      display: flex;
      flex-direction: column;
      gap: 0.4rem;
    }
    .contact-item {
      margin: 0;
    }
    .contact-item a {
      color: #a0c4ff;
      text-decoration: none;
      transition: color 0.2s;
    }
    .contact-item a:hover {
      color: #cce0ff;
      text-decoration: underline;
    }
    .footer-brand .logo {
      font-size: 1.6rem;
      font-weight: 700;
      color: #ffffff;
      letter-spacing: 0.02em;
    }
    .footer-nav ul {
      list-style: none;
      padding: 0;
      margin: 0;
      display: flex;
      flex-wrap: wrap;
      gap: 1.2rem;
    }
    .footer-nav a {
      color: #b0c4de;
      text-decoration: none;
      font-weight: 500;
      transition: color 0.2s;
    }
    .footer-nav a:hover {
      color: #ffffff;
    }
    .footer-legal {
      display: flex;
      flex-wrap: wrap;
      gap: 1.5rem;
    }
    .footer-legal a {
      color: #8899aa;
      text-decoration: none;
      font-size: 0.85rem;
      transition: color 0.2s;
    }
    .footer-legal a:hover {
      color: #b0c4de;
    }
    .footer-disclaimer {
      border-top: 1px solid #2a2a4a;
      padding-top: 1.2rem;
      margin-top: 0.5rem;
    }
    .footer-disclaimer p {
      font-size: 0.8rem;
      color: #8899aa;
      margin: 0;
      max-width: 800px;
    }
    .footer-copyright {
      font-size: 0.8rem;
      color: #6b7b8d;
      margin-top: 0.5rem;
    }
    @media (min-width: 768px) {
      .footer-container {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 2rem 3rem;
      }
      .footer-contact {
        grid-column: 1 / 2;
        grid-row: 1 / 2;
      }
      .footer-brand {
        grid-column: 2 / 3;
        grid-row: 1 / 2;
        text-align: right;
      }
      .footer-nav {
        grid-column: 1 / 2;
        grid-row: 2 / 3;
      }
      .footer-legal {
        grid-column: 2 / 3;
        grid-row: 2 / 3;
        justify-content: flex-end;
      }
      .footer-disclaimer {
        grid-column: 1 / -1;
        grid-row: 3 / 4;
      }
      .footer-copyright {
        grid-column: 1 / -1;
        grid-row: 4 / 5;
        text-align: center;
      }
    }
    @media (min-width: 1024px) {
      .footer-container {
        grid-template-columns: 2fr 1fr 1fr;
        gap: 2rem;
      }
      .footer-contact {
        grid-column: 1 / 2;
        grid-row: 1 / 2;
      }
      .footer-brand {
        grid-column: 2 / 3;
        grid-row: 1 / 2;
        text-align: left;
      }
      .footer-nav {
        grid-column: 3 / 4;
        grid-row: 1 / 2;
        text-align: right;
      }
      .footer-legal {
        grid-column: 1 / 2;
        grid-row: 2 / 3;
        justify-content: flex-start;
      }
      .footer-disclaimer {
        grid-column: 1 / -1;
        grid-row: 3 / 4;
      }
      .footer-copyright {
        grid-column: 1 / -1;
        grid-row: 4 / 5;
      }
    }

.cookies-banner-line{position:fixed;left:0;right:0;bottom:0;z-index:1200;padding:12px}
.cookies-banner-line .shell{max-width:var(--max-w);margin:0 auto;padding:12px 14px;border:1px solid color-mix(in srgb,currentColor 22%,transparent);border-radius:18px;background:var(--gradient-hero-bg);color:var(--gradient-hero-fg);box-shadow:var(--shadow-lg);display:flex;align-items:center;justify-content:space-between;gap:var(--gap)}
.cookies-banner-line .copy{max-width:52rem}
.cookies-banner-line .copy strong{display:block;font-size:var(--font-size-h3)}
.cookies-banner-line .copy p{margin:6px 0 0;line-height:var(--line-height-base)}
.cookies-banner-line .actions{display:flex;gap:8px;flex-wrap:wrap}
.cookies-banner-line .actions button{border:1px solid color-mix(in srgb,currentColor 24%,transparent);background:color-mix(in srgb,currentColor 12%,transparent);color:inherit;border-radius:12px;padding:8px 12px;cursor:pointer;font-weight:700}
.cookies-banner-line .actions button[data-choice='accept']{background:var(--page-bg);color:var(--page-fg)}
@media(max-width:720px){.cookies-banner-line .shell{display:block}.cookies-banner-line .actions{margin-top:12px}}

.intro {
    padding: clamp(3.8rem, 8vw, 6.8rem) var(--space-x);
    background: linear-gradient(160deg, var(--primary-bg), var(--primary-hover));
    color: var(--primary-fg);
}

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

.intro .left, .intro .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);
}

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

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

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

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

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

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

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

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

.capabilities-wide-runs{position:relative;overflow:hidden;padding:var(--space-section-y) var(--space-section-x);background:var(--gradient-hero-bg);color:var(--gradient-hero-fg)}
.capabilities-wide-runs:before{content:"";position:absolute;inset:-15%;background:linear-gradient(112deg,transparent 38%,color-mix(in srgb,var(--accent-bg) 12%,transparent) 50%,transparent 62%);animation:capRunGlow calc(var(--anim-duration)*36) var(--anim-ease) infinite alternate}
.capabilities-wide-runs .wrap{position:relative;max-width:var(--max-w);margin:0 auto}
.capabilities-wide-runs .intro{display:flex;align-items:end;justify-content:space-between;gap:var(--gap);margin-bottom:var(--space-block)}
.capabilities-wide-runs h2{max-width:15ch;margin:0;font-size:var(--font-size-h1);line-height:1.02}
.capabilities-wide-runs .intro p{max-width:40rem;margin:0;font-size:var(--font-size-lg);line-height:var(--line-height-base)}
.capabilities-wide-runs .runs{border-top:1px solid color-mix(in srgb,currentColor 30%,transparent)}
.capabilities-wide-runs .runs a{display:flex;align-items:baseline;gap:var(--gap);padding:var(--space-y) 0;border-bottom:1px solid color-mix(in srgb,currentColor 24%,transparent);color:inherit;text-decoration:none;transition:padding var(--anim-duration) var(--anim-ease)}
.capabilities-wide-runs .runs a:hover{padding-left:var(--space-card)}
.capabilities-wide-runs h3{flex:0 1 30%;margin:0;font-size:var(--font-size-h3)}
.capabilities-wide-runs .runs p{flex:1 1 0;margin:0;line-height:var(--line-height-base)}
.capabilities-wide-runs .runs span{flex:0 1 22%;text-align:right;font-size:var(--font-size-sm)}
.capabilities-wide-runs .action{display:inline-block;margin-top:var(--space-y);color:inherit;text-underline-offset:.22em}
@keyframes capRunGlow{from{transform:translateX(-6%)}to{transform:translateX(6%)}}
@media(max-width:720px){.capabilities-wide-runs .intro,.capabilities-wide-runs .runs a{display:block}.capabilities-wide-runs .intro p,.capabilities-wide-runs .runs p,.capabilities-wide-runs .runs span{display:block;margin-top:var(--space-card);text-align:left}}
@media(prefers-reduced-motion:reduce){.capabilities-wide-runs:before{animation:none}}

.social-proof-columns-note{padding:var(--space-section-y) var(--space-section-x);background:var(--page-bg);color:var(--page-fg)}
.social-proof-columns-note .wrap{max-width:var(--max-w);margin:0 auto}
.social-proof-columns-note .intro{max-width:36rem;margin-bottom:var(--space-block)}
.social-proof-columns-note h2{margin:0;font-size:var(--font-size-h2);line-height:1.08}
.social-proof-columns-note .intro p{margin:var(--space-y) 0 0;color:var(--muted-fg);line-height:var(--line-height-base)}
.social-proof-columns-note .columns{display:flex;flex-wrap:wrap;gap:var(--space-block)}
.social-proof-columns-note .column{flex:1 1 16rem;padding:var(--space-y) 0;font-size:var(--font-size-h3);line-height:1.08}
.social-proof-columns-note p{margin:var(--space-card) 0 0;color:var(--muted-fg);line-height:var(--line-height-base)}
.social-proof-columns-note a{display:inline-block;margin-top:var(--space-card);color:inherit;text-underline-offset:.22em}

.faq-answer-indexgrid {
  background: var(--gradient-hero-bg);
  color: var(--gradient-hero-fg);
  padding: var(--space-section-y) var(--space-section-x);
}
.faq-answer-indexgrid .wrap {
  width: min(100%, var(--max-w));
  margin: 0 auto;
  display: block;
  gap: var(--gap);
}
.faq-answer-indexgrid h2,
.faq-answer-indexgrid h3,
.faq-answer-indexgrid p { margin: 0; }
.faq-answer-indexgrid h2 { font-size: var(--font-size-h2); line-height: 1.08; }
.faq-answer-indexgrid h3 { font-size: var(--font-size-h3); line-height: 1.16; }
.faq-answer-indexgrid p { font-size: var(--font-size-md); line-height: var(--line-height-base); }
.faq-answer-indexgrid .intro {
  display: grid;
  gap: var(--space-y);
  align-content: start;
  padding: var(--space-block);
  border-radius: var(--radius-xl);
  background: var(--gradient-accent-bg);
  color: var(--gradient-accent-fg);
    margin-bottom: 1rem;
}
.faq-answer-indexgrid .index {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-card);
}
.faq-answer-indexgrid .question {
  min-height: 13rem;
  display: grid;
  gap: var(--space-card);
  align-content: start;
  padding: var(--space-y);
  border-radius: var(--radius-lg);
  background: var(--card-bg);
  color: var(--card-fg);
  border: 1px solid var(--card-border);
  text-decoration: none;
  animation: faqIndexIn calc(var(--anim-duration) * 2.2) var(--anim-ease) both;
  animation-delay: var(--delay, 0ms);
}
.faq-answer-indexgrid .question:nth-child(3n) { transform: translateY(var(--space-y)); }
.faq-answer-indexgrid .question b,
.faq-answer-indexgrid .note { color: var(--muted-fg); }
.faq-answer-indexgrid .note { grid-column: 2; }
@keyframes faqIndexIn {
  from { opacity: .18; transform: translateY(calc(var(--motion-distance) * .18)); }
  to { opacity: 1; }
}
@media (max-width: 820px) {
  .faq-answer-indexgrid .wrap,
  .faq-answer-indexgrid .index { grid-template-columns: 1fr; }
  .faq-answer-indexgrid .question:nth-child(3n) { transform: none; }
  .faq-answer-indexgrid .note { grid-column: auto; }
}

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

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

    .blog-list .h{text-align:center;margin-bottom:var(--space-y);background:var(--primary-fg);border-radius:var(--radius-lg);color:var(--primary-bg);}

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

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

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

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

    .blog-list .card{background:var(--card-bg);color:var(--card-fg);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md);transition:transform var(--anim-duration) var(--anim-ease),box-shadow var(--anim-duration) var(--anim-ease);}

    .blog-list .card{position:relative;overflow:hidden;}

    .blog-list .card::after{animation-duration:6s;opacity:0.3;}

    @keyframes fall{
        from {transform:translateY(-80px);}
        to{transform:translateY(80px);}
    }

    .blog-list .card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);}

    .blog-list .image img{width:100%;height:200px;object-fit:cover;}

    .blog-list .content{padding:clamp(16px,2vw,24px);}

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

    .blog-list h3{margin:0.5rem 0;font-size:clamp(18px,2.2vw,22px);}

    .blog-list h3 a{text-decoration:none;}

    .blog-list p{margin:0.5rem 0 1rem;}

    .blog-list .read-more{text-decoration:none;font-weight:600;}

    .blog-list .read-more:hover{text-decoration:underline;}

.recommendations-quiet-map {
        padding: var(--space-section-y) var(--space-section-x);
        background: var(--muted-bg);
        color: var(--muted-fg)
    }

    .recommendations-quiet-map .wrap {
        max-width: var(--max-w);
        margin: 0 auto;
        width: min(100%, 48rem)
    }

    .recommendations-quiet-map h2 {
        margin: 0;
        font-size: var(--font-size-h2);
        line-height: 1.08;
    }

    .recommendations-quiet-map .lead {
        max-width: 38rem;
        margin: var(--space-y) 0 var(--space-block);
        line-height: var(--line-height-base)
    }

    .recommendations-quiet-map .map {
        display: flex;
        flex-direction: column;
        gap: var(--space-y);
        position: relative
    }

    .recommendations-quiet-map .map:before {
        content: "";
        position: absolute;
        inset: 0 auto 0 1rem;
        width: 1px;
        background: color-mix(in srgb, currentColor 16%, transparent)
    }

    .recommendations-quiet-map .stop {
        position: relative;
        padding-left: 2.5rem
    }

    .recommendations-quiet-map .stop:before {
        content: "";
        position: absolute;
        left: .68rem;
        top: .55em;
        width: .55rem;
        height: .55rem;
        border-radius: 50%;
        background: var(--inverse-fg)
    }

    .recommendations-quiet-map strong {
        display: block;
        font-size: var(--font-size-h3);
        line-height: 1.08;
    }

    .recommendations-quiet-map p {
        margin: var(--space-card) 0 0;
        line-height: var(--line-height-base)
    }

    .recommendations-quiet-map a {
        display: inline-block;
        margin-top: var(--space-card);
        text-underline-offset: .22em
    }

.stay-in-touch{padding:clamp(56px,8vw,96px) clamp(16px,3vw,36px);background:var(--gradient-hero-bg);color:var(--gradient-hero-fg);}

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

    .stay-in-touch .head{margin-bottom:14px;text-align:center;}

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

    .stay-in-touch .head p{margin:10px auto 0;max-width:64ch;opacity:.92;}

    .stay-in-touch .grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px;}

    .stay-in-touch .grid article{border:1px solid color-mix(in srgb, currentColor 32%, transparent);border-radius:var(--radius-md);background:color-mix(in srgb, currentColor 12%, transparent);padding:12px;}

    .stay-in-touch .grid h3{margin:0 0 7px;}

    .stay-in-touch .grid p{margin:0;}

    .stay-in-touch .grid a{display:inline-block;margin-top:8px;text-decoration:underline;}

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

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

    .panel-blog-item .c{max-width:var(--max-w);margin:0 auto;display:grid;gap:var(--space-x);}

    @media (min-width: 1024px){.panel-blog-item .c{grid-template-columns:1fr 300px;}
    }

    .panel-blog-item .header{margin-bottom:var(--space-y);}

    .panel-blog-item h1{font-size:clamp(28px,5vw,42px);margin:0 0 1rem;}

    .panel-blog-item .meta{display:flex;gap:1rem;font-size:0.875rem;}

    .panel-blog-item .content{line-height:1.8;}

    .panel-blog-item .related{background:var(--card-bg);padding:clamp(16px,2vw,24px);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);color:var(--card-fg);}

    .panel-blog-item .related h3{margin:0 0 1rem;font-size:1.25rem;}

    .panel-blog-item .related-list{display:flex;flex-direction:column;gap:0.75rem;}

    .panel-blog-item .related a{text-decoration:none;}

    .panel-blog-item .related a:hover{text-decoration:underline;}

.panel-author.light{padding:32px 20px;background:var(--page-bg);color:var(--page-fg);}

.panel-author .inner{max-width:520px;margin:0 auto;}

.panel-author .name{margin:0 0 4px;font-size:1.05rem;}

.panel-author .role{margin:0 0 8px;font-size:0.9rem;}

.panel-author .bio{margin:0;font-size:0.9rem;}

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

    .care .wrap{max-width:900px;margin:0 auto;display:grid;gap:12px;grid-template-columns:1fr 1fr;}

    .care .wrap article{border:1px solid var(--card-border);border-radius:var(--radius-lg);background:var(--muted-bg);padding:var(--space-y) var(--space-x);box-shadow:var(--shadow-sm);color:var(--muted-fg);}

    .care .wrap h3{margin:0 0 7px;}

    .care .wrap p{margin:0;}

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

.recommendations-braid-passage{padding:var(--space-section-y) var(--space-section-x);background:var(--primary-bg);color:var(--primary-fg)}
.recommendations-braid-passage .wrap{max-width:var(--max-w);margin:0 auto}
.recommendations-braid-passage .intro{display:flex;align-items:end;justify-content:space-between;gap:var(--gap);margin-bottom:var(--space-block)}
.recommendations-braid-passage .intro p{max-width:32rem;margin:0;font-size:var(--font-size-lg);line-height:var(--line-height-base)}
.recommendations-braid-passage h2{max-width:14ch;margin:0;font-size:var(--font-size-h1);line-height:1}
.recommendations-braid-passage .braid{position:relative;display:flex;gap:var(--gap);align-items:flex-start}
.recommendations-braid-passage .track{flex:1 1 0;display:flex;flex-direction:column;gap:var(--space-y)}
.recommendations-braid-passage .spine{flex:0 0 min(10rem,18vw);align-self:stretch;border-radius:var(--radius-xl);background:color-mix(in srgb,currentColor 10%,transparent)}
.recommendations-braid-passage .strand{display:block;padding:var(--space-y) 0;color:inherit;text-decoration:none;transform:translateY(var(--lift,0));animation:recommendBraidIn calc(var(--anim-duration)*1.15) var(--anim-ease) both}
.recommendations-braid-passage .strand strong{display:block;font-size:var(--font-size-h3);line-height:1.08}
.recommendations-braid-passage .strand span{display:block;margin:var(--space-card) 0;line-height:var(--line-height-base)}
.recommendations-braid-passage .strand em{font-style:normal;font-size:var(--font-size-sm)}
@keyframes recommendBraidIn{from{opacity:0;transform:translateY(calc(var(--motion-distance)*.08))}to{opacity:1;transform:translateY(0)}}
@media(max-width:760px){.recommendations-braid-passage .intro{display:block}.recommendations-braid-passage .intro p{margin-bottom:var(--space-y)}.recommendations-braid-passage .braid{display:block}.recommendations-braid-passage .spine{display:none}.recommendations-braid-passage .track{gap:0}.recommendations-braid-passage .track-b{margin-top:var(--space-y)}}

.feedback{background:var(--muted-bg);color:var(--muted-fg);padding:clamp(56px,8vw,96px) clamp(16px,4vw,40px);}

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

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

    .feedback .eyebrow{margin:0 0 10px;text-transform:uppercase;letter-spacing:0.22em;font-size:12px;}

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

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

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

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

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

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

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

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

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

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

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

    .feedback .a{display:none;padding:0 16px 14px;overflow:hidden;}

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

    .feedback .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){.feedback .q{align-items:flex-start;}

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

        .feedback .meta{display:none;}
    }

.form-progressive-steps{padding:var(--space-section-y) var(--space-section-x);background:var(--primary-bg);color:var(--primary-fg)}
.form-progressive-steps .wrap{max-width:var(--max-w);margin:0 auto}
.form-progressive-steps .heading{max-width:50rem;margin-bottom:var(--space-block)}
.form-progressive-steps h2{margin:0;font-size:var(--font-size-h1);line-height:1}
.form-progressive-steps .heading p{max-width:40rem;margin:var(--space-y) 0 0;font-size:var(--font-size-lg);line-height:var(--line-height-base)}
.form-progressive-steps .steps{display:flex;flex-wrap:wrap;gap:var(--gap)}
.form-progressive-steps [data-form-step]{flex:1 1 18rem;order:var(--step-order,0)}
.form-progressive-steps label span{display:block;margin-bottom:var(--space-card);font-size:var(--font-size-sm)}
.form-progressive-steps input,.form-progressive-steps textarea{width:100%;padding:var(--space-card);border:1px solid color-mix(in srgb,currentColor 36%,transparent);border-radius:var(--radius-sm);background:color-mix(in srgb,currentColor 8%,transparent);color:inherit;font:inherit;outline:none}
.form-progressive-steps input:focus,.form-progressive-steps textarea:focus{border-color:currentColor}
.form-progressive-steps .message{display:block;margin-top:var(--space-y)}
.form-progressive-steps textarea{resize:vertical}
.form-progressive-steps button{margin-top:var(--space-y);padding:var(--space-card) var(--space-y);border:0;border-radius:var(--radius-sm);background:var(--inverse-bg);color:var(--inverse-fg);font:inherit;cursor:pointer}

.contacts-formal-ledger {
  padding: var(--space-section-y) var(--space-section-x);
  background: var(--inverse-bg);
  color: var(--inverse-fg);
}
.contacts-formal-ledger .wrap {
  display: flex;
  gap: var(--space-block);
  max-width: var(--max-w);
  margin: 0 auto;
}
.contacts-formal-ledger .title {
  flex: 0 1 34%;
  align-self: flex-start;
}
.contacts-formal-ledger h2 {
  margin: 0;
  font-size: var(--font-size-h2);
  line-height: 1.08;
}
.contacts-formal-ledger .title p {
  margin: var(--space-y) 0 0;
  color: var(--neutral-600);
  line-height: var(--line-height-base);
}
.contacts-formal-ledger .ledger {
  flex: 1 1 0;
  min-width: 0;
  border-top: 1px solid var(--card-border);
}
.contacts-formal-ledger .line {
  display: flex;
  justify-content: space-between;
  gap: var(--gap);
  padding: var(--space-y) 0;
  border-bottom: 1px solid var(--card-border);
}
.contacts-formal-ledger .line span {
  flex: 0 0 28%;
  color: var(--neutral-600);
  font-size: var(--font-size-sm);
}
.contacts-formal-ledger .line p,
.contacts-formal-ledger .line a {
  max-width: 34rem;
  margin: 0;
  text-align: right;
  overflow-wrap: anywhere;
  line-height: var(--line-height-base);
}
.contacts-formal-ledger .direct a {
  color: var(--link);
  font-size: var(--font-size-lg);
  text-underline-offset: .2em;
}
.contacts-formal-ledger .links {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: var(--space-y);
  padding-top: var(--space-y);
}
.contacts-formal-ledger .links a {
  color: inherit;
  text-decoration-thickness: 1px;
  text-underline-offset: .2em;
}
@media (max-width: 760px) {
  .contacts-formal-ledger .wrap {
    display: block;
  }
  .contacts-formal-ledger .ledger {
    margin-top: var(--space-block);
  }
}
@media (max-width: 500px) {
  .contacts-formal-ledger .line {
    display: block;
  }
  .contacts-formal-ledger .line p,
  .contacts-formal-ledger .line a {
    display: block;
    margin-top: var(--space-card);
    text-align: left;
  }
  .contacts-formal-ledger .links {
    justify-content: flex-start;
  }
}

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

    .block-blog-item .c{max-width:var(--max-w);margin:0 auto;display:grid;gap:var(--space-x);}

    @media (min-width: 1024px){.block-blog-item .c{grid-template-columns:1fr 300px;}
    }

    .block-blog-item .header{margin-bottom:var(--space-y);}

    .block-blog-item h1{font-size:clamp(28px,5vw,42px);margin:0 0 1rem;}

    .block-blog-item .meta{display:flex;gap:1rem;font-size:0.875rem;}

    .block-blog-item .content{line-height:1.8;}

    .block-blog-item .related{background:var(--card-bg);padding:clamp(16px,2vw,24px);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);color:var(--card-fg);}

    .block-blog-item .related h3{margin:0 0 1rem;font-size:1.25rem;}

    .block-blog-item .related-list{display:flex;flex-direction:column;gap:0.75rem;}

    .block-blog-item .related a{text-decoration:none;}

    .block-blog-item .related a:hover{text-decoration:underline;}

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

    .blog-item .c{max-width:var(--max-w);margin:0 auto;display:grid;gap:var(--space-x);}

    @media (min-width: 1024px){.blog-item .c{grid-template-columns:1fr 300px;}
    }

    .blog-item .header{margin-bottom:var(--space-y);}

    .blog-item h1{font-size:clamp(28px,5vw,42px);margin:0 0 1rem;}

    .blog-item .meta{display:flex;gap:1rem;font-size:0.875rem;}

    .blog-item .content{line-height:1.8;}

    .blog-item .related{background:var(--card-bg);padding:clamp(16px,2vw,24px);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);color:var(--card-fg);}

    .blog-item .related h3{margin:0 0 1rem;font-size:1.25rem;}

    .blog-item .related-list{display:flex;flex-direction:column;gap:0.75rem;}

    .blog-item .related a{text-decoration:none;}

    .blog-item .related a:hover{text-decoration:underline;}

.policy-crestnote{padding:calc(var(--space-y)*3) var(--space-x);background:var(--gradient-hero-bg);color:var(--gradient-hero-fg);}
.policy-crestnote .crestnote-wrap{max-width:var(--max-w);margin:0 auto;}.policy-crestnote .crestnote-title{max-width:48rem;margin-bottom:1rem;}.policy-crestnote h2{margin:0;font-size:clamp(2rem,4vw,3.15rem);line-height:1.05;}.policy-crestnote .crestnote-title p{margin:.8rem 0 0;}.policy-crestnote .crestnote-cards{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.75rem;}.policy-crestnote .article{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.25);border-radius:var(--radius-lg);padding:1rem;color:var(--page-fg);}.policy-crestnote h3{margin:0 0 .5rem;color:var(--neutral-0);font-size:1.02rem;}.policy-crestnote .article p{margin:0;color:var(--neutral-300);}
@media (max-width:860px){.policy-crestnote .crestnote-cards{grid-template-columns:1fr;}}

.terms-cleanfold{padding:calc(var(--space-y)*2.8) var(--space-x);background:var(--card-bg);color:var(--card-fg);}
.terms-cleanfold .cleanfold-wrap{max-width:920px;margin:0 auto;}.terms-cleanfold h2{margin:0;font-size:clamp(1.9rem,3.5vw,2.85rem);line-height:1.06;}.terms-cleanfold .cleanfold-sub{margin:.75rem 0 1rem;color:var(--neutral-600);}.terms-cleanfold ol{margin:0;padding-left:1.2rem;display:grid;gap:.6rem;}.terms-cleanfold li{padding:.8rem 0;border-bottom:1px solid var(--card-border);}.terms-cleanfold h3{margin:0 0 .25rem;font-size:1rem;}.terms-cleanfold li p{margin:0;color:var(--neutral-600);}

.thank-soft-route{padding:var(--space-section-y) var(--space-section-x);background:var(--inverse-bg);color:var(--inverse-fg)}
.thank-soft-route .wrap{max-width:var(--max-w);margin:0 auto;width:min(100%,52rem)}
.thank-soft-route .hero{max-width:40rem;margin-bottom:var(--space-block)}
.thank-soft-route h2{margin:0;font-size:var(--font-size-h2);line-height:1.08}
.thank-soft-route .hero p{margin:var(--space-y) 0 0;line-height:var(--line-height-base)}
.thank-soft-route .route{display:flex;gap:var(--gap)}
.thank-soft-route .route>div{flex:1 1 0;padding:var(--space-y) 0;font-size:var(--font-size-h3);line-height:1.08}
.thank-soft-route p{margin:var(--space-card) 0 0;line-height:var(--line-height-base)}
@media(max-width:680px){.thank-soft-route .route{display:block}.thank-soft-route .route>div+div{margin-top:var(--space-y)}}

.notfound-wide-crossing{position:relative;overflow:hidden;padding:var(--space-section-y) var(--space-section-x);background:var(--gradient-hero-bg);color:var(--gradient-hero-fg)}
.notfound-wide-crossing:before{content:"";position:absolute;inset:-20%;background:linear-gradient(105deg,transparent 42%,color-mix(in srgb,var(--accent-bg) 14%,transparent) 50%,transparent 58%);animation:nfCross calc(var(--anim-duration)*34) var(--anim-ease) infinite alternate}
.notfound-wide-crossing .wrap{position:relative;max-width:var(--max-w);margin:0 auto}
.notfound-wide-crossing h1{max-width:12ch;margin:0;font-size:var(--font-size-h1);line-height:1}
.notfound-wide-crossing .way{display:flex;justify-content:space-between;align-items:end;gap:var(--gap);margin-top:var(--space-block);padding-top:var(--space-y);border-top:1px solid color-mix(in srgb,currentColor 30%,transparent)}
.notfound-wide-crossing p{max-width:38rem;margin:0;font-size:var(--font-size-lg);line-height:var(--line-height-base)}
.notfound-wide-crossing a{color:inherit;font-size:var(--font-size-lg);text-underline-offset:.24em}
@keyframes nfCross{from{transform:translateX(-7%);opacity:.4}to{transform:translateX(7%);opacity:.8}}
@media(max-width:620px){.notfound-wide-crossing .way{display:block}.notfound-wide-crossing a{display:inline-block;margin-top:var(--space-y)}}
@media(prefers-reduced-motion:reduce){.notfound-wide-crossing:before{animation:none}}