:root {
  --font-family: "Sora", sans-serif;
  --font-size-base: 16.7px;
  --line-height-base: 1.68;

  --max-w: 1500px;
  --space-x: 2.24rem;
  --space-y: 1.5rem;
  --gap: 2.38rem;
  --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.06rem;
  --radius-lg: 0.81rem;
  --radius-md: 0.46rem;
  --radius-sm: 0.34rem;

  --shadow-sm: 0 1px 6px rgba(0,0,0,0.08);
  --shadow-md: 0 8px 18px rgba(0,0,0,0.11);
  --shadow-lg: 0 18px 40px rgba(0,0,0,0.13);

  --overlay: rgba(0,0,0,0.5);
  --anim-duration: 430ms;
  --anim-ease: ease;
  --random-number: 1;

  --brand: #D35400;
  --brand-contrast: #FFFFFF;
  --accent: #F39C12;
  --accent-contrast: #FFFFFF;

  --neutral-0: #FFFFFF;
  --neutral-100: #F8F9FA;
  --neutral-300: #CED4DA;
  --neutral-600: #6C757D;
  --neutral-800: #343A40;
  --neutral-900: #212529;

  --c-page-bg: #F4F6F7;
  --c-page-fg: #2C3E50;
  --c-muted-bg: #E8ECF0;
  --c-muted-fg: #2C3E50;
  --c-card-bg: #FFFFFF;
  --c-card-fg: #2C3E50;
  --c-card-border: #DEE2E6;
  --c-inverse-bg: #2C3E50;
  --c-inverse-fg: #FFFFFF;
  --c-primary-bg: #D35400;
  --c-primary-fg: #FFFFFF;
  --c-primary-hover: #E67E22;
  --c-accent-bg: #F39C12;
  --c-accent-fg: #FFFFFF;
  --c-accent-hover: #F1C40F;
  --g-hero-bg: linear-gradient(135deg, #2C3E50 0%, #34495E 100%);
  --g-hero-fg: #FFFFFF;
  --g-accent-bg: linear-gradient(135deg, #D35400 0%, #E67E22 100%);
  --g-accent-fg: #FFFFFF;

  --section-light-bg: var(--c-page-bg);
  --section-light-fg: var(--c-page-fg);
  --section-muted-bg: var(--c-muted-bg);
  --section-muted-fg: var(--c-muted-fg);
  --section-card-bg: var(--c-card-bg);
  --section-card-fg: var(--c-card-fg);
  --section-colored-bg: var(--c-inverse-bg);
  --section-colored-fg: var(--c-inverse-fg);
  --section-gradient-bg: var(--g-hero-bg);
  --section-gradient-fg: var(--g-hero-fg);

  --bg-page: var(--c-page-bg);
  --fg-on-page: var(--c-page-fg);

  --bg-alt: var(--c-muted-bg);
  --fg-on-alt: var(--c-muted-fg);

  --surface-1: var(--c-inverse-bg);
  --surface-2: var(--c-muted-bg);
  --fg-on-surface: var(--c-inverse-fg);
  --border-on-surface: var(--c-card-border);

  --surface-light: var(--c-card-bg);
  --fg-on-surface-light: var(--c-card-fg);
  --border-on-surface-light: var(--c-card-border);

  --bg-primary: var(--c-primary-bg);
  --fg-on-primary: var(--c-primary-fg);
  --bg-primary-hover: var(--c-primary-hover);
  --ring: #D35400;

  --bg-accent: var(--c-accent-bg);
  --fg-on-accent: var(--c-accent-fg);
  --bg-accent-hover: var(--c-accent-hover);

  --link: #D35400;
  --link-hover: #F39C12;

  --gradient-hero: var(--g-hero-bg);
  --gradient-hero-fg: var(--g-hero-fg);
  --gradient-accent: var(--g-accent-bg);
  --gradient-accent-fg: var(--g-accent-fg);

  --btn-ghost-bg: transparent;
  --chip-bg: color-mix(in srgb, var(--c-muted-bg) 82%, var(--c-card-bg) 18%);
  --chip-fg: var(--c-muted-fg);
  --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(--c-primary-bg)!important;color:var(--c-primary-fg)!important;border-color:var(--c-primary-bg)!important;}
.btn-primary:hover,.btn.btn-primary:hover{background:var(--c-primary-hover)!important;color:var(--c-primary-fg)!important;border-color:var(--c-primary-hover)!important;}
.btn-outline-primary{color:var(--c-primary-bg)!important;border-color:var(--c-primary-bg)!important;}
.btn-outline-primary:hover{background:var(--c-primary-bg)!important;color:var(--c-primary-fg)!important;}
.bg-primary{background:var(--c-primary-bg)!important;color:var(--c-primary-fg)!important;}
.text-primary{color:var(--c-primary-bg)!important;}
.border-primary{border-color:var(--c-primary-bg)!important;}
.bg-light{background:var(--section-light-bg)!important;color:var(--section-light-fg)!important;}
.bg-dark{background:var(--section-colored-bg)!important;color:var(--section-colored-fg)!important;}

/* ===== ESTILOS DEL HEADER ===== */
.site-header {
  width: 100%;
  background-color: var(--section-light-bg, #ffffff);
  border-bottom: 1px solid var(--c-card-border, #e0e0e0);
  /* Sin position fixed/sticky */
  position: relative;
  z-index: 100;
}

.header-wrapper {
  display: flex;
  align-items: center;
  justify-content: space-between;
  max-width: var(--max-w, 1200px);
  margin: 0 auto;
  padding: var(--space-y, 0.75rem) var(--space-x, 1.5rem);
  gap: var(--gap, 1rem);
  box-sizing: border-box;
}

/* LOGO */
.logo {
  font-size: var(--font-size-h2, 1.75rem);
  font-weight: 700;
  text-decoration: none;
  color: var(--section-light-fg, #1a1a1a);
  letter-spacing: -0.02em;
  line-height: 1.2;
  white-space: nowrap;
  flex-shrink: 0;
}

.logo:hover {
  opacity: 0.85;
}

/* NAVEGACIÓN (escritorio) */
.nav-menu {
  display: flex;
  align-items: center;
}

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

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

.nav-link:hover {
  border-bottom-color: var(--c-accent-bg, #0057b3);
  color: var(--c-accent-bg, #0057b3);
}

/* CTA */
.cta-wrapper {
  flex-shrink: 0;
}

.cta-button {
  display: inline-block;
  background-color: var(--c-primary-bg, #1a73e8);
  color: var(--c-primary-fg, #ffffff);
  font-size: var(--font-size-sm, 0.9rem);
  font-weight: 600;
  text-decoration: none;
  padding: 0.5rem 1.25rem;
  border-radius: var(--radius-md, 6px);
  transition: background-color var(--anim-duration, 0.2s) var(--anim-ease, ease);
  white-space: nowrap;
}

.cta-button:hover {
  background-color: var(--c-primary-hover, #1557b0);
}

/* BURGER (oculto en escritorio) */
.burger {
  display: none;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 2.5rem;
  height: 2.5rem;
  background: transparent;
  border: 1px solid var(--c-card-border, #d0d0d0);
  border-radius: var(--radius-sm, 4px);
  cursor: pointer;
  padding: 0.4rem;
  gap: 4px;
  transition: background var(--anim-duration, 0.2s);
  flex-shrink: 0;
}

.burger-line {
  display: block;
  width: 100%;
  height: 2px;
  background-color: var(--section-light-fg, #1a1a1a);
  border-radius: 2px;
  transition: all var(--anim-duration, 0.2s) var(--anim-ease, ease);
}

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

  .nav-menu {
    display: none; /* oculto por defecto */
    width: 100%;
    order: 3;
    margin-top: 0.75rem;
    border-top: 1px solid var(--c-card-border, #ddd);
    padding-top: 0.75rem;
  }

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

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

  .nav-link {
    display: block;
    padding: 0.5rem 0;
    border-bottom: none;
    font-size: var(--font-size-md, 1rem);
  }

  .nav-link:hover {
    border-bottom: none;
    background-color: var(--c-muted-bg, #f5f5f5);
    padding-left: 0.5rem;
    border-radius: var(--radius-sm, 4px);
  }

  .burger {
    display: flex; /* visible en móvil */
  }

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

/* ===== PEQUEÑO AJUSTE (opcional) ===== */
@media (min-width: 768px) {
  .burger {
    display: none !important;
  }
}

footer {
    background-color: #1a1a2e;
    color: #e0e0e0;
    padding: 2rem 1rem;
    font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
    font-size: 0.95rem;
    line-height: 1.6;
  }
  .footer-container {
    max-width: 1200px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 2rem;
  }
  .footer-col {
    padding: 0.5rem;
  }
  .brand-logo {
    font-size: 1.8rem;
    font-weight: 700;
    color: #ffffff;
    margin-bottom: 0.5rem;
  }
  .brand-offer {
    color: #b0b0b0;
    margin: 0;
  }
  .footer-nav {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
  }
  .footer-nav a {
    color: #c0c0c0;
    text-decoration: none;
    transition: color 0.2s;
  }
  .footer-nav a:hover {
    color: #ffffff;
  }
  .contact-info p {
    margin: 0.3rem 0;
  }
  .contact-info a {
    color: #c0c0c0;
    text-decoration: none;
  }
  .contact-info a:hover {
    color: #ffffff;
  }
  .disclaimer {
    margin-top: 1rem;
    font-size: 0.85rem;
    color: #999;
    border-top: 1px solid #333;
    padding-top: 0.8rem;
  }
  .footer-bottom {
    text-align: center;
    margin-top: 2rem;
    border-top: 1px solid #333;
    padding-top: 1rem;
    font-size: 0.85rem;
    color: #888;
  }
  @media (max-width: 768px) {
    .footer-container {
      grid-template-columns: 1fr;
      text-align: center;
    }
    .footer-nav {
      align-items: center;
    }
  }

.cookies{position:fixed;inset:0 0 auto 0;z-index:1200;}

    .cookies .inner{max-width:var(--max-w);margin:0 auto;padding:10px var(--space-x);background:var(--c-muted-bg);border:1px solid var(--c-card-border);border-radius:0 0 var(--radius-lg) var(--radius-lg);display:flex;align-items:center;justify-content:space-between;gap:var(--gap);flex-wrap:wrap;color:var(--c-muted-fg);}

    .cookies .inner p{margin:6px 0 0 6px;}

    .cookies .actions{display:flex;gap:8px;flex-wrap:wrap;}

    .cookies .actions a{text-decoration:none;border:1px solid var(--c-card-border);border-radius:999px;background:var(--c-card-bg);color:var(--c-card-fg);padding:6px 10px;}

    .cookies .actions a[data-choice='accept']{background:var(--c-primary-bg);border-color:var(--c-primary-bg);color:var(--c-primary-fg);}

.intro-linedock{padding:calc(var(--space-y)*3) var(--space-x);background:var(--c-card-bg);color:var(--c-card-fg);}
.intro-linedock .linedock-wrap{max-width:var(--max-w);margin:0 auto;border-top:1px solid var(--c-card-border);border-bottom:1px solid var(--c-card-border);padding:1rem 0;}.intro-linedock h1{margin:.8rem 0;font-size:clamp(2.4rem,6.2vw,5.6rem);line-height:.94;max-width:920px;}.intro-linedock .linedock-bottom{display:flex;justify-content:space-between;gap:var(--gap);align-items:center;}.intro-linedock span{max-width:38rem;color:var(--neutral-600);}.intro-linedock .nav{display:flex;gap:.5rem;flex-wrap:wrap;}.intro-linedock a{background:var(--c-primary-bg);color:var(--c-primary-fg);text-decoration:none;border-radius:var(--radius-sm);padding:.68rem .88rem;}.intro-linedock a+a{background:var(--c-muted-bg);color:var(--c-muted-fg);}
@media (max-width:760px){.intro-linedock .linedock-bottom{display:grid;}}

.followup {
    padding: clamp(3.6rem, 8vw, 6.1rem) var(--space-x);
    background: radial-gradient(circle at 50% 0, color-mix(in srgb, currentColor 16%, transparent), transparent 28%), var(--section-gradient-bg);
    text-align: center;
    color: var(--section-gradient-fg);
}

.followup .wrap {
    max-width: 54rem;
    margin: 0 auto;
}

.followup .wrap p:first-child {
    margin: 0;
    color: color-mix(in srgb, currentColor 76%, transparent);
}

.followup .wrap h2 {
    margin: .55rem 0 0;
    font-size: clamp(2.1rem, 4vw, 3.1rem);
}

.followup .row {
    margin-top: 1.15rem;
    display: flex;
    gap: .75rem;
    justify-content: center;
    flex-wrap: wrap;
}

.followup .row a {
    display: inline-flex;
    padding: .8rem 1rem;
    border-radius: 999px;
    background: color-mix(in srgb, currentColor 12%, transparent);
    border: 1px solid color-mix(in srgb, currentColor 18%, transparent);
    text-decoration: none;
    animation: next_pulse_c3 2.4s ease-in-out infinite;
}

.followup .row a:nth-child(2n) {
    animation-delay: .35s;
}

@keyframes next_pulse_c3 {
    0%, 100% {
        transform: translateY(0);
    }
    50% {
        transform: translateY(-3px);
    }
}

.followup .copy {
    margin-top: 1rem;
}

.followup .cta {
    display: inline-flex;
    margin-top: 1rem;
    min-height: 2.9rem;
    align-items: center;
    justify-content: center;
    padding: 0 1rem;
    border-radius: var(--radius-md);
    background: var(--c-accent-bg);
    color: var(--c-accent-fg);
    text-decoration: none;
}

.value-points{padding:clamp(3.1rem,7vw,5.7rem) var(--space-x);background:linear-gradient(180deg,var(--c-card-bg),var(--c-muted-bg));color:var(--c-card-fg);}

    .value-points .wrap{max-width:58rem;margin:0 auto;}

    .value-points .head{margin-bottom:1.1rem;text-align:center;}

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

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

    .value-points .head span{display:block;margin-top:.75rem;}

    .value-points .rows{display:grid;gap:.8rem;}

    .value-points .rows article{display:grid;grid-template-columns:3rem 1fr;gap:.9rem;padding:1rem;border-radius:var(--radius-lg);background:var(--c-card-bg);border:1px solid var(--c-card-border);color:var(--c-card-fg);}

    .value-points .rows strong{display:grid;place-items:center;width:3rem;height:3rem;border-radius:999px;background:var(--c-muted-bg);color:var(--c-muted-fg);}

    .value-points .rows h3{margin:0;}

    .value-points .rows p{margin:.35rem 0 0;}

    .value-points .rows small{display:block;margin-top:.55rem;}

.why-choose{background:var(--section-gradient-bg);color:var(--section-gradient-fg);padding:clamp(40px,6vw,80px) clamp(16px,3vw,40px);position:relative;overflow:hidden;}

    .why-choose .c{max-width:var(--max-w);margin:0 auto;position:relative;z-index:1;}

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

    .why-choose h2{font-size:clamp(32px,5vw,48px);margin:0 0 1rem;}

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

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

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

    .why-choose .item::before{content:'';position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--c-accent-bg);opacity:.75;transform:scaleY(.35);transform-origin:top;transition:transform .45s var(--anim-ease),opacity .45s var(--anim-ease);}

    .why-choose .item:hover{transform:translateY(-3px);box-shadow:0 12px 28px color-mix(in srgb, currentColor 14%, transparent);}

    .why-choose .item:hover::before{transform:scaleY(1);opacity:1;}

    .why-choose .number{flex-shrink:0;width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:var(--c-accent-bg);color:var(--c-accent-fg);border-radius:var(--radius-md);font-size:clamp(20px,2.5vw,28px);font-weight:700;position:relative;transition:transform var(--anim-duration) var(--anim-ease);}

    .why-choose .item:hover .number{transform:translateY(-2px);}

    .why-choose .number::after{content:'';position:absolute;inset:8px;border-radius:inherit;border:1px solid color-mix(in srgb, currentColor 38%, transparent);opacity:.45;}

    .why-choose .content{flex:1;}

    .why-choose .item h3{font-size:clamp(18px,2.2vw,24px);margin:0 0 0.75rem;transition:color var(--anim-duration) var(--anim-ease);}

    .why-choose .item:hover h3{}

    .why-choose .item p{margin:0;opacity:0.85;line-height:var(--line-height-base);}

.advice{padding:calc(var(--space-y)*2.7) var(--space-x);color:var(--section-light-fg);background:var(--section-light-bg);}
.advice .wrap{max-width:var(--max-w);margin:0 auto;display:grid;gap:.72rem;}
.advice .banner{padding:.95rem;border-radius:var(--radius-xl);background:var(--c-card-bg);border:1px solid var(--c-card-border);color:var(--c-card-fg);}
.advice h2{margin:0;font-size:clamp(1.74rem,3vw,2.43rem);}
.advice .banner p{margin:.4rem 0 0;}
.advice .scroller{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(260px,1fr);overflow:auto;gap:.6rem;padding-bottom:.3rem;}
.advice .scroller article{padding:.9rem;border:1px solid var(--c-card-border);border-radius:var(--radius-md);background:var(--c-card-bg);color:var(--c-card-fg);}
.advice h3{margin:0 0 .25rem;font-size:1rem;}
.advice article p{margin:0 0 .52rem;}
.advice a{text-decoration:none;font-weight:700;}

.messages{color:var(--section-light-fg);background:var(--section-light-bg);padding:clamp(16px,3vw,40px);}

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

    @media (max-width: 767px){.messages .c{grid-template-columns:1fr;height:auto;}

        .messages .chat-form{flex-direction:column;}
    }

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

    .messages .list{background:color-mix(in srgb, currentColor 10%, transparent);backdrop-filter:blur(10px);border-radius:var(--radius-lg);border:1px solid color-mix(in srgb, currentColor 20%, transparent);padding:1rem;overflow-y:auto;}

    .messages h2{margin:0 0 1rem;font-size:1.25rem;}

    .messages .items{display:flex;flex-direction:column;gap:0.5rem;}

    .messages .item{display:flex;gap:1rem;padding:1rem;border-radius:var(--radius-md);background:color-mix(in srgb, currentColor 10%, transparent);cursor:pointer;transition:all var(--anim-duration) var(--anim-ease);}

    .messages .item:hover{background:color-mix(in srgb, currentColor 20%, transparent);}

    .messages .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;flex-shrink:0;}

    .messages .info{flex:1;min-width:0;}

    .messages h4{margin:0 0 0.25rem;font-size:1rem;}

    .messages .info p{margin:0 0 0.25rem;font-size:0.875rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}

    .messages .time{font-size:0.75rem;}

    .messages .chat{background:color-mix(in srgb, currentColor 10%, transparent);backdrop-filter:blur(10px);border-radius:var(--radius-lg);border:1px solid color-mix(in srgb, currentColor 20%, transparent);display:flex;flex-direction:column;}

    .messages .chat-header{padding:1rem;border-bottom:1px solid color-mix(in srgb, currentColor 20%, transparent);}

    .messages h3{margin:0;}

    .messages .chat{flex:1;padding:1rem;overflow-y:auto;display:flex;flex-direction:column;gap:1rem;}

    .messages .message{background:color-mix(in srgb, currentColor 10%, transparent);padding:0.875rem 1rem;border-radius:var(--radius-md);max-width:70%;}

    .messages .message-text{margin-bottom:0.25rem;}

    .messages .message-time{font-size:0.75rem;}

    .messages .chat-form{display:flex;gap:0.5rem;padding:1rem;border-top:1px solid color-mix(in srgb, currentColor 20%, transparent);}

    .messages .chat-form input{flex:1;padding:0.875rem;border-radius:var(--radius-md);border:1px solid color-mix(in srgb, currentColor 30%, transparent);background:color-mix(in srgb, currentColor 10%, transparent);outline:none;}

    .messages .chat-form input::placeholder{}

    .messages .chat-form button{padding:0.875rem 1.5rem;border-radius:var(--radius-md);border:none;background:var(--c-page-bg);color:var(--c-page-fg);font-weight:600;cursor:pointer;}

.reviews{background:radial-gradient(circle at 20% 25%,color-mix(in srgb, currentColor 70%, transparent),transparent 60%),radial-gradient(circle at 85% 65%,rgba(212, 165, 165,0.35),transparent 55%),var(--section-gradient-bg);padding:clamp(56px,8vw,96px) clamp(16px,4vw,40px);overflow:hidden;}

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

    .reviews .h{text-align:center;margin-bottom:clamp(28px,6vw,60px);transform:translateY(-18px);}

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

    .reviews .h h2{margin:0;font-size:clamp(28px,4.6vw,48px);letter-spacing:-0.02em;}

    .reviews .grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(360px,1fr));gap:clamp(14px,2.6vw,22px);}

    .reviews .card{border-radius:var(--radius-xl);border:1px solid rgba(58, 46, 61,0.12);background:color-mix(in srgb, currentColor 60%, transparent);box-shadow:var(--shadow-lg);padding:clamp(18px,3vw,26px);backdrop-filter:blur(10px);transform:translateY(28px);position:relative;overflow:hidden;}

    .reviews .card::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,color-mix(in srgb, currentColor 60%, transparent),transparent 55%);opacity:0.6;pointer-events:none;}

    .reviews .top{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;position:relative;z-index:1;}

    .reviews .who{display:flex;align-items:center;gap:12px;min-width:0;}

    .reviews .name{margin:0;font-size:16px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:18ch;}

    .reviews .meta{margin:2px 0 0;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:22ch;}

    .reviews .index-feedback__rating{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:999px;background:var(--c-page-bg);border:1px solid var(--c-card-border);box-shadow:var(--shadow-sm);flex:0 0 auto;color:var(--c-page-fg);}

    .reviews .index-feedback__stars{font-size:14px;letter-spacing:0.08em;line-height:1;}

    .reviews .index-feedback__score{font-size:12px;font-weight:700;}

    .reviews .quote{margin:14px 0 0;position:relative;z-index:1;font-size:14px;line-height:1.65;}

    .reviews .badge{display:inline-flex;margin-top:12px;position:relative;z-index:1;padding:6px 10px;border-radius:999px;background:var(--c-accent-bg);color:var(--c-accent-fg);border:1px solid var(--c-card-border);font-size:11px;letter-spacing:0.14em;text-transform:uppercase;}

.explainer{padding:clamp(18px,3vw,44px);background:var(--section-muted-bg);color:var(--section-muted-fg);}

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

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

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

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

    .explainer .panel{position:relative;border-radius:var(--radius-xl);background:var(--section-muted-bg);border:1px solid var(--c-card-border);box-shadow:var(--shadow-lg);overflow:hidden;color:var(--section-muted-fg);}

    .explainer .scan{position:absolute;left:0;top:-40%;width:100%;height:42%;background:linear-gradient(180deg,transparent,rgba(0, 86, 179,0.08),transparent);animation:l2Scan 4.8s linear infinite;pointer-events:none;color:var(--neutral-0);}

    @keyframes l2Scan{
        0% {transform:translateY(0%);}
        100%{transform:translateY(240%);}
    }

    .explainer .list{display:grid;gap:10px;padding:12px;}

    .explainer .row{display:grid;grid-template-columns:110px 1fr;gap:12px;padding:12px 14px;text-align:left;border-radius:var(--radius-lg);background:var(--section-muted-bg);border:1px solid var(--c-card-border);cursor:pointer;transition:transform var(--anim-duration) var(--anim-ease),border-color var(--anim-duration) var(--anim-ease);color:var(--section-muted-fg);}

    .explainer .row:hover{transform:translateY(-2px);border-color:rgba(0, 86, 179,0.35);}

    .explainer .k{display:inline-flex;align-items:center;justify-content:center;height:34px;border-radius:999px;background:var(--c-accent-bg);color:var(--c-accent-fg);border:1px solid color-mix(in srgb, currentColor 6%, transparent);font-weight:900;}

    .explainer .q{display:block;font-weight:900;letter-spacing:-.01em;margin-bottom:6px;}

    .explainer .a{display:block;line-height:var(--line-height-base);}

    .explainer .row.is-focus{border-color:rgba(255, 107, 53,0.45);box-shadow:0 0 0 6px rgba(255, 107, 53,0.08);}

    @media (max-width: 720px){.explainer .row{grid-template-columns:1fr;}

        .explainer .k{justify-self:start;padding:0 12px;}
    }

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

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

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

    .connect .header{text-align:center;margin-bottom:clamp(40px,6vw,56px);}

    .connect .header h2{font-size:clamp(28px,5vw,48px);margin:0 0 0.5rem;}

    .connect .header p{font-size:clamp(16px,2vw,18px);margin:0;}

    .connect .grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:clamp(20px,3vw,28px);}

    .connect .item{display:flex;flex-direction:column;align-items:center;gap:clamp(12px,2vw,16px);padding:clamp(24px,4vw,32px);background:var(--c-page-bg);border-radius:var(--radius-lg);text-decoration:none;color:var(--c-page-fg);transition:transform 0.3s,box-shadow 0.3s;}

    .connect .item:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);}

    .connect .name{font-size:clamp(16px, 2.5vw, 18px);font-weight:600;}

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

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

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

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

    .support .head p{margin:8px 0 0;opacity:.92;}

    .support .list{display:grid;gap:10px;}

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

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

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

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

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

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

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

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

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

    .faq .cards{display:grid;gap:var(--gap);grid-template-columns:repeat(auto-fit,minmax(450px,1fr));}

    .faq .card{border-radius:var(--radius-lg);border:1px solid color-mix(in srgb, currentColor 22%, transparent);background:var(--c-accent-bg);color:var(--c-accent-fg);padding:var(--space-y) var(--space-x);}

    .faq .card h3{margin:0;font-size:1.05rem;}

    .faq .card p{margin:9px 0 0;}

.contacts{padding:calc(var(--space-y)*3) var(--space-x);background:var(--c-muted-bg);color:var(--c-muted-fg);}
.contacts .wrap{max-width:var(--max-w);margin:0 auto;}
.contacts h2{margin:0;font-size:clamp(1.75rem,3.2vw,2.5rem);}
.contacts .sub{margin:.42rem 0 1rem;}
.contacts .strips{display:grid;gap:.55rem;}
.contacts .strips article{display:flex;justify-content:space-between;gap:1rem;align-items:center;padding:.85rem 1rem;border-radius:var(--radius-lg);background:var(--c-card-bg);border-left:4px solid var(--c-primary-bg);color:var(--c-card-fg);}
.contacts h3{margin:0;font-size:1rem;}
.contacts .strips p{margin:0;}
.contacts a{text-decoration:none;}
.contacts .flow{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.6rem;margin-top:.8rem;}
.contacts .flow a{display:flex;justify-content:space-between;gap:.75rem;padding:.75rem .9rem;border-radius:var(--radius-md);background:var(--c-card-bg);border:1px solid var(--c-card-border);color:var(--c-card-fg);}
.contacts .flow span{}
@media (max-width:760px){.contacts .strips article{display:grid;}.contacts .flow{grid-template-columns:1fr;}}

.message {
    padding: calc(var(--space-y) * 2.9) var(--space-x);
    background: var(--section-gradient-bg);
    color: var(--section-gradient-fg);
  }
  .message .shell {
    max-width: var(--max-w);
    margin: 0 auto;
    display: grid;
    gap: var(--gap);
  }
  .message h2 {
    margin: 0;
    font-size: clamp(1.85rem, 3.6vw, 2.8rem);
    line-height: 1.1;
  }
  .message .sub {
    margin: .35rem 0 0;
    opacity: .9;
  }
  .message .panel,
  .message .box {
    padding: 1.1rem;
    border-radius: var(--radius-xl);
    background: var(--chip-bg);
    border: 1px solid var(--btn-ghost-bg-hover);
    box-shadow: var(--shadow-md);
    color: var(--chip-fg);
  }
  .message form {
    display: grid;
    gap: .75rem;
  }
  .message .field {
    display: grid;
    gap: .28rem;
  }
  .message .field span {
    font-size: .82rem;
    font-weight: 700;
  }
  .message input,
  .message textarea {
    width: 100%;
    padding: .8rem .85rem;
    border-radius: var(--radius-md);
    border: 1px solid var(--c-card-border);
    background: var(--c-card-bg);
    color: var(--c-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) 22%, transparent);
  }
  .message textarea {
    min-height: 120px;
    resize: vertical;
  }
  .message button {
    padding: .82rem 1rem;
    border: 0;
    border-radius: var(--radius-md);
    background: var(--c-primary-bg);
    color: var(--c-primary-fg);
    font-weight: 700;
    cursor: pointer;
    transition: transform var(--anim-duration) var(--anim-ease), background var(--anim-duration) var(--anim-ease);
  }
  .message button:hover {
    transform: translateY(-1px);
    background: var(--c-primary-hover);
    color: var(--c-primary-fg);
  }
  .message .split {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--gap);
  }
  .message .grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: .65rem;
  }
  .message .line {
    padding: 1rem;
    border-radius: var(--radius-lg);
    background: var(--chip-bg);
    border: 1px solid var(--btn-ghost-bg-hover);
    color: var(--chip-fg);
  }
  .message .bar {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: .65rem;
    padding: 1rem;
    border-radius: var(--radius-lg);
    background: var(--chip-bg);
    border: 1px solid var(--btn-ghost-bg-hover);
    color: var(--chip-fg);
  }
  .message .stack {
    padding: 1rem;
    border-radius: var(--radius-lg);
    background: var(--chip-bg);
    border: 1px solid var(--btn-ghost-bg-hover);
    color: var(--chip-fg);
  }
  .message .steps {
    display: flex;
    gap: .45rem;
    flex-wrap: wrap;
  }
  .message .steps span {
    padding: .33rem .55rem;
    border-radius: var(--radius-sm);
    background: var(--chip-bg);
    border: 1px solid var(--btn-ghost-bg-hover);
    font-size: .8rem;
    color: var(--chip-fg);
  }
  .message .agree {
    display: flex;
    align-items: center;
    gap: .45rem;
    font-size: .86rem;
  }
  .message .media {
    display: grid;
    grid-template-columns: .9fr 1.1fr;
    gap: var(--gap);
  }
  .message .media img,
  .message .frame img {
    width: 100%;
    height: 100%;
    min-height: 320px;
    object-fit: cover;
    border-radius: var(--radius-xl);
  }
  .message .frame {
    display: grid;
    grid-template-columns: 1.1fr .9fr;
    gap: var(--gap);
  }
  .message .full {
    grid-column: 1 / -1;
  }
  .message .panel {
    transition: transform var(--anim-duration) var(--anim-ease), box-shadow var(--anim-duration) var(--anim-ease);
  }
  .message .panel:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-lg);
  }
  @media (max-width: 860px) {
    .message .split,
    .message .media,
    .message .frame {
      grid-template-columns: 1fr;
    }
    .message .grid,
    .message .bar {
      grid-template-columns: 1fr;
    }
  }

.policy-crestnote{padding:calc(var(--space-y)*3) var(--space-x);background:var(--section-gradient-bg);color:var(--section-gradient-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(--c-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;}}

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

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

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

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

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

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

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

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

    .rules p,.rules li{}

.received {
    padding: calc(var(--space-y) * 2.9) var(--space-x);
    background: var(--section-gradient-bg);
    color: var(--section-gradient-fg);
  }
  .received .shell {
    max-width: var(--max-w);
    margin: 0 auto;
    display: grid;
    gap: var(--gap);
  }
  .received h2 {
    margin: 0;
    font-size: clamp(1.85rem, 3.6vw, 2.8rem);
    line-height: 1.1;
  }
  .received .sub {
    margin: 0.35rem 0 0;
    opacity: 0.9;
  }
  .received article,
  .received li {
    padding: 0.85rem;
    border-radius: var(--radius-sm);
    background: var(--chip-bg);
    border: 1px solid var(--btn-ghost-bg-hover);
    list-style: none;
    color: var(--chip-fg);
  }
  .received p {
    margin: 0;
  }
  .received a {
    text-decoration: none;
    color: inherit;
    font-weight: 700;
  }
  .received .bento {
    display: grid;
    grid-template-columns: repeat(12, minmax(0, 1fr));
    gap: 0.55rem;
  }
  .received .bento article:nth-child(1) {
    grid-column: span 6;
  }
  .received .bento article:nth-child(2) {
    grid-column: span 3;
  }
  .received .bento article:nth-child(3) {
    grid-column: span 3;
  }
  .received .bento article:nth-child(4) {
    grid-column: span 4;
  }
  .received .bento article:nth-child(5) {
    grid-column: span 4;
  }
  .received .bento article:nth-child(6) {
    grid-column: span 4;
  }
  .received article {
    transition: transform var(--anim-duration) var(--anim-ease), box-shadow var(--anim-duration) var(--anim-ease);
  }
  .received article:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-md);
  }
  @media (max-width: 860px) {
    .received .split,
    .received .media,
    .received .grid,
    .received .cards,
    .received .bento,
    .received .foot {
      grid-template-columns: 1fr;
    }
  }

.missing{padding:clamp(56px,10vw,112px) 20px;background:var(--section-gradient-bg);color:var(--section-gradient-fg);}

    .missing .box{max-width:760px;margin:0 auto;text-align:center;}

    .missing h1{margin:0;font-size:clamp(34px,6vw,58px);}

    .missing p{margin:12px 0 0;opacity:.92;}

    .missing a{display:inline-block;margin-top:18px;padding:10px 16px;border-radius:var(--radius-md);background:var(--c-card-bg);color:var(--c-card-fg);text-decoration:none;}