:root {
  --font-family: "Space Grotesk", sans-serif;
  --font-size-base: 18.4px;
  --line-height-base: 1.77;

  --max-w: 1460px;
  --space-x: 2.45rem;
  --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.24rem;
  --radius-lg: 0.95rem;
  --radius-md: 0.43rem;
  --radius-sm: 0.26rem;

  --shadow-sm: 0 2px 6px rgba(0,0,0,0.15);
  --shadow-md: 0 12px 20px rgba(0,0,0,0.19);
  --shadow-lg: 0 22px 52px rgba(0,0,0,0.23);

  --overlay: rgba(30,30,30,0.7);
  --anim-duration: 480ms;
  --anim-ease: ease;
  --random-number: 2;

  --brand: #b87333;
  --brand-contrast: #ffffff;
  --accent: #4a4a4a;
  --accent-contrast: #ffffff;

  --neutral-0: #ffffff;
  --neutral-100: #f5f5f5;
  --neutral-300: #d4d4d4;
  --neutral-600: #737373;
  --neutral-800: #404040;
  --neutral-900: #1a1a1a;

  --page-bg: #f0f0f0;
  --page-fg: #1a1a1a;
  --muted-bg: #e0e0e0;
  --muted-fg: #404040;
  --card-bg: #ffffff;
  --card-fg: #1a1a1a;
  --card-border: #d4d4d4;
  --inverse-bg: #2d2d2d;
  --inverse-fg: #ffffff;
  --primary-bg: #b87333;
  --primary-fg: #ffffff;
  --primary-hover: #a0652d;
  --accent-bg: #4a4a4a;
  --accent-fg: #ffffff;
  --accent-hover: #3a3a3a;
  --gradient-hero-bg: linear-gradient(135deg, #4a4a4a 0%, #2d2d2d 100%);
  --gradient-hero-fg: #ffffff;
  --gradient-accent-bg: linear-gradient(135deg, #b87333 0%, #a0652d 100%);
  --gradient-accent-fg: #ffffff;

  --ring: #b87333;

  --link: #b87333;
  --link-hover: #4a4a4a;

  --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 {
  width: 100%;
  background-color: var(--page-bg, #ffffff);
  border-bottom: 1px solid var(--muted-bg, #e5e7eb);
  box-shadow: var(--shadow-sm, 0 1px 3px rgba(0,0,0,0.08));
  font-family: var(--font-family, system-ui, sans-serif);
  font-size: var(--font-size-base, 1rem);
  line-height: var(--line-height-base, 1.5);
  color: var(--page-fg, #1f2937);
}

/* contenedor interno – centrado y ancho máximo */
.wrapper {
  max-width: var(--max-w, 1200px);
  margin: 0 auto;
  padding-left: var(--space-x, 1.5rem);
  padding-right: var(--space-x, 1.5rem);
}

/* ----- UTILITY BAR (fila superior) ----- */
.utility-bar {
  background-color: var(--muted-bg, #f3f4f6);
  color: var(--muted-fg, #4b5563);
  font-size: var(--font-size-sm, 0.875rem);
  border-bottom: 1px solid var(--card-border, #e5e7eb);
  padding: 0.35rem 0;
}

.utility-wrapper {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.utility-tagline {
  font-weight: 450;
  letter-spacing: 0.01em;
}

.utility-contact {
  font-weight: 400;
  opacity: 0.85;
}

/* ----- MAIN BAR (fila inferior) ----- */
.main-bar {
  background-color: var(--page-bg, #ffffff);
  color: var(--page-fg, #1f2937);
  padding: 0.65rem 0;
}

.main-wrapper {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1.5rem;
}

/* LOGO */
.logo {
  font-size: var(--font-size-h3, 1.5rem);
  font-weight: 600;
  text-decoration: none;
  color: var(--page-fg, #1f2937);
  letter-spacing: -0.02em;
  white-space: nowrap;
  transition: opacity 0.2s ease;
  line-height: 1.2;
}

.logo:hover {
  opacity: 0.8;
}

/* BOTÓN BURGER (oculto en desktop) */
.burger {
  display: none;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 4px;
  width: 2.25rem;
  height: 2.25rem;
  background: transparent;
  border: 1px solid var(--card-border, #d1d5db);
  border-radius: var(--radius-sm, 6px);
  cursor: pointer;
  padding: 0.25rem;
  background-color: var(--card-bg, #f9fafb);
  transition: background 0.2s ease, border-color 0.2s ease;
}

.burger:hover {
  background-color: var(--muted-bg, #f3f4f6);
  border-color: var(--muted-fg, #9ca3af);
}

.burger-line {
  display: block;
  width: 20px;
  height: 2px;
  background-color: var(--page-fg, #1f2937);
  border-radius: 2px;
  transition: all 0.25s ease;
}

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

.nav-list {
  display: flex;
  list-style: none;
  margin: 0;
  padding: 0;
  gap: 0.25rem;
  flex-wrap: wrap;
}

.nav-link {
  display: inline-block;
  padding: 0.5rem 1rem;
  font-size: var(--font-size-md, 1rem);
  font-weight: 500;
  color: var(--page-fg, #1f2937);
  text-decoration: none;
  border-radius: var(--radius-md, 8px);
  transition: background-color 0.2s ease, color 0.2s ease;
  white-space: nowrap;
}

.nav-link:hover {
  background-color: var(--muted-bg, #f3f4f6);
  color: var(--link-hover, #2563eb);
}

.nav-link:focus-visible {
  outline: 2px solid var(--link, #3b82f6);
  outline-offset: 2px;
}

/* ===== MÓVIL (max-width: 767px) ===== */
@media (max-width: 767px) {
  .burger {
    display: flex; /* visible */
  }

  .nav-menu {
    display: none; /* oculto por defecto */
    position: absolute;
    top: 100%;
    left: 0;
    width: 100%;
    background-color: var(--page-bg, #ffffff);
    border-top: 1px solid var(--card-border, #e5e7eb);
    box-shadow: var(--shadow-md, 0 8px 20px rgba(0,0,0,0.08));
    padding: 0.75rem 0 1rem 0;
    z-index: 100;
  }

  .nav-menu.is-open {
    display: block; /* mostrar al abrir */
  }

  .nav-list {
    flex-direction: column;
    gap: 0.15rem;
    padding: 0 var(--space-x, 1.5rem);
  }

  .nav-link {
    display: block;
    padding: 0.7rem 0.75rem;
    border-radius: var(--radius-md, 8px);
    font-size: var(--font-size-md, 1rem);
  }

  .nav-link:hover {
    background-color: var(--muted-bg, #f3f4f6);
  }

  /* Ajuste para que el menú no se salga del flujo */
  .main-bar {
    position: relative; /* ancla para el menú absoluto */
  }

  /* la utility puede apilarse en móvil */
  .utility-wrapper {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.2rem;
  }
}

/* ===== PEQUEÑOS AJUSTES DE DENSIDAD ===== */
@media (min-width: 768px) {
  .main-bar {
    padding: 0.5rem 0;
  }

  .nav-link {
    padding: 0.45rem 1rem;
  }
}

/* ===== GARANTIZAR QUE EL HEADER NO ES STICKY/FIXED ===== */
.site-header {
  position: relative; /* normal flow, no sticky, no fixed */
  top: auto;
}

/* ===== TOQUES DE PERFIL: técnico, limpio ===== */
.utility-bar {
  letter-spacing: 0.02em;
}

.utility-tagline::before {
  content: "⚡ ";
  font-size: 0.9em;
}

footer {
    background: #1a1a2e;
    color: #e0e0e0;
    font-family: 'Segoe UI', Roboto, system-ui, sans-serif;
    padding: 2rem 1.5rem 1rem;
    line-height: 1.5;
    font-size: 0.95rem;
  }
  .footer-container {
    max-width: 1200px;
    margin: 0 auto;
  }
  .footer-row {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 1.5rem 2rem;
  }
  .footer-brand {
    flex: 1 1 280px;
    min-width: 220px;
  }
  .footer-logo {
    font-size: 1.4rem;
    font-weight: 700;
    color: #ffffff;
    text-decoration: none;
    letter-spacing: 0.02em;
  }
  .footer-logo:hover {
    color: #a0c4ff;
  }
  .footer-disclaimer {
    margin-top: 0.75rem;
    font-size: 0.8rem;
    color: #b0b0b0;
    line-height: 1.4;
    max-width: 400px;
  }
  .footer-nav ul {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
  }
  .footer-nav a {
    color: #c0c8d8;
    text-decoration: none;
    font-size: 0.95rem;
    transition: color 0.2s;
  }
  .footer-nav a:hover {
    color: #ffffff;
  }
  .footer-legal {
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
  }
  .footer-legal a {
    color: #c0c8d8;
    text-decoration: none;
    font-size: 0.9rem;
  }
  .footer-legal a:hover {
    color: #ffffff;
  }
  .footer-contact {
    font-style: normal;
    display: flex;
    flex-direction: column;
    gap: 0.3rem;
    font-size: 0.9rem;
    color: #c0c8d8;
  }
  .footer-contact a {
    color: #c0c8d8;
    text-decoration: none;
  }
  .footer-contact a:hover {
    color: #ffffff;
  }
  .footer-bottom {
    margin-top: 1.5rem;
    border-top: 1px solid #2a2a3e;
    padding-top: 1rem;
    text-align: center;
    font-size: 0.8rem;
    color: #888;
  }
  @media (max-width: 640px) {
    .footer-row {
      flex-direction: column;
      align-items: flex-start;
    }
    .footer-nav ul {
      flex-direction: row;
      flex-wrap: wrap;
      gap: 0.6rem 1.2rem;
    }
    .footer-legal {
      flex-direction: row;
      flex-wrap: wrap;
      gap: 0.6rem 1.2rem;
    }
    .footer-contact {
      flex-direction: row;
      flex-wrap: wrap;
      gap: 0.4rem 1rem;
    }
  }

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

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

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

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

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

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

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

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

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

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

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

.pathway{padding:calc(var(--space-y) * 1.9) var(--space-x);background:var(--muted-bg);color:var(--muted-fg);}

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

    .pathway h2,.pathway h3,.pathway p{margin:0;}

    .pathway a{text-decoration:none;}

    .pathway .center,.pathway .banner,.pathway .stack,.pathway .bar,.pathway .split,.pathway .duo article{padding:.9rem;border-radius:var(--radius-xl);background:var(--muted-bg);border:1px solid var(--card-border);color:var(--muted-fg);}

    .pathway .center{display:grid;gap:.5rem;justify-items:center;text-align:center;}

    .pathway .split{display:grid;grid-template-columns:1fr auto;gap:var(--gap);align-items:center;}

    .pathway .actions{display:flex;gap:.45rem;flex-wrap:wrap;}

    .pathway .actions a,.pathway .center a,.pathway .banner > a,.pathway .duo a{display:inline-flex;min-height:2.35rem;padding:0 .85rem;align-items:center;border-radius:var(--radius-sm);background:var(--primary-bg);color:var(--primary-fg);border:1px solid var(--ring);}

    .pathway .banner{display:grid;gap:.6rem;}

    .pathway .numbers{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.5rem;}

    .pathway .numbers div{padding:.6rem;border-radius:var(--radius-md);background:var(--muted-bg);color:var(--muted-fg);border:1px solid var(--card-border);}

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

    .pathway .duo article{display:grid;gap:.45rem;}

    .pathway .stack{display:grid;gap:.6rem;justify-items:start;}

    .pathway .chips{display:flex;gap:.35rem;flex-wrap:wrap;}

    .pathway .chips span{padding:.28rem .5rem;border-radius:var(--radius-sm);background:var(--muted-bg);color:var(--muted-fg);border:1px solid var(--card-border);}

    .pathway .bar{display:grid;grid-template-columns:1fr auto;gap:var(--gap);align-items:center;}

    @media (max-width: 820px){.pathway .split,.pathway .bar,.pathway .duo{grid-template-columns:1fr;}

        .pathway .numbers{grid-template-columns:1fr 1fr;}
    }

    @media (max-width: 620px){.pathway .numbers{grid-template-columns:1fr;}
    }

.details{padding:clamp(20px,3vw,44px);background:var(--gradient-hero-bg);color:var(--gradient-hero-fg);}.details .wrap{max-width:var(--max-w);margin:0 auto;}.details h2{margin:0;font-size:clamp(24px,4vw,40px);}.details>div>p{margin:8px 0 12px;color:color-mix(in srgb, currentColor 86%, transparent);}.details .stack{display:grid;gap:10px;}.details .stack article{border:1px solid color-mix(in srgb, currentColor 28%, transparent);border-radius:var(--radius-lg);background:color-mix(in srgb, currentColor 12%, transparent);}.details .stack button{width:100%;border:0;background:transparent;color:inherit;text-align:left;padding:12px;font:inherit;font-weight:700;}.details .stack 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);}.details .stack article.is-open p{max-height:220px;padding:0 12px 12px;}

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

.recommendations{padding:calc(var(--space-y)*2.9) var(--space-x);background:var(--gradient-hero-bg);color:var(--gradient-hero-fg);} .recommendations .shell{max-width:var(--max-w);margin:0 auto;display:grid;gap:var(--gap);} .recommendations h2{margin:0;font-size:clamp(1.85rem,3.6vw,2.8rem);line-height:1.1;} .recommendations .sub{margin:.35rem 0 0;opacity:.9;} .recommendations article,.recommendations li{padding:.85rem;border-radius:var(--radius-sm);background:var(--accent-bg);border:1px solid var(--btn-ghost-bg-hover);list-style:none;color:var(--accent-fg);} .recommendations p{margin:0;} .recommendations a{text-decoration:none;color:inherit;font-weight:700;} .recommendations .split{display:grid;grid-template-columns:1fr 1fr;gap:var(--gap);} .recommendations .panel{padding:1rem;border-radius:var(--radius-lg);background:var(--accent-bg);border:1px solid var(--btn-ghost-bg-hover);color:var(--accent-fg);} .recommendations .grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.55rem;} .recommendations article{transition:transform var(--anim-duration) var(--anim-ease),box-shadow var(--anim-duration) var(--anim-ease);} .recommendations article:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);} @media (max-width:860px){.recommendations .split,.recommendations .media,.recommendations .grid,.recommendations .cards,.recommendations .bento,.recommendations .foot{grid-template-columns:1fr;}}

.messages-desk{padding:var(--space-section-y) var(--space-section-x);background:var(--page-bg);color:var(--page-fg);}
.messages-desk__wrap{max-width:var(--max-w);margin:0 auto;display:grid;gap:var(--gap);}
.messages-desk__heading{display:grid;grid-template-columns:minmax(0,1fr) minmax(14rem,.35fr);gap:var(--gap);align-items:end;padding-bottom:var(--space-block);border-bottom:1px solid var(--card-border);}
.messages-desk h2,.messages-desk h3,.messages-desk h4,.messages-desk p{margin:0;}
.messages-desk h2{font-size:var(--font-size-h2);line-height:var(--line-height-tight);}
.messages-desk h3{font-size:var(--font-size-lg);line-height:var(--line-height-base);color:var(--neutral-600);}
.messages-desk__main{display:grid;grid-template-columns:minmax(0,.58fr) minmax(18rem,.42fr);gap:var(--gap);align-items:start;}
.messages-desk__timeline{display:grid;gap:.7rem;}
.messages-desk__row{display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:.85rem;align-items:start;padding:var(--space-card);border:1px solid var(--card-border);border-radius:var(--radius-md);background:var(--card-bg);color:var(--card-fg);}
.messages-desk__row:nth-child(even){margin-left:clamp(0rem,4vw,2.4rem);}
.messages-desk__initials{width:2.5rem;height:2.5rem;border-radius:var(--radius-sm);display:grid;place-items:center;background:var(--muted-bg);color:var(--muted-fg);font-weight:700;}
.messages-desk__row h4{font-size:var(--font-size-md);line-height:var(--line-height-tight);}
.messages-desk__row p{margin-top:.25rem;font-size:var(--font-size-sm);line-height:var(--line-height-base);color:var(--neutral-600);}
.messages-desk time{font-size:var(--font-size-sm);color:var(--neutral-600);}
.messages-desk__reply{position:sticky;top:var(--space-card);display:grid;gap:.75rem;padding:var(--space-card);border:1px solid var(--card-border);border-radius:var(--radius-lg);background:color-mix(in srgb,var(--card-bg) 92%,var(--primary-bg));color:var(--card-fg);}
.messages-desk__stack{display:grid;gap:.65rem;}
.messages-desk__message{padding:.8rem .9rem;border-radius:var(--radius-md);background:var(--page-bg);border:1px solid var(--card-border);}
.messages-desk__message:nth-child(even){background:var(--primary-bg);color:var(--primary-fg);border-color:var(--primary-bg);}
.messages-desk__message p{font-size:var(--font-size-sm);line-height:var(--line-height-base);}
.messages-desk__message time{display:block;margin-top:.35rem;color:inherit;opacity:.72;}
.messages-desk__form{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:.5rem;padding-top:.75rem;border-top:1px solid var(--card-border);}
.messages-desk__form input{min-width:0;border:1px solid var(--card-border);border-radius:var(--radius-sm);padding:.8rem .9rem;background:var(--card-bg);color:var(--card-fg);font:inherit;outline:none;}
.messages-desk__form button{border:0;border-radius:var(--radius-sm);padding:.8rem 1rem;background:var(--primary-bg);color:var(--primary-fg);font:inherit;font-weight:700;cursor:pointer;}
@media (max-width:900px){.messages-desk__heading,.messages-desk__main{grid-template-columns:1fr;}.messages-desk__reply{position:relative;top:auto;}.messages-desk__row:nth-child(even){margin-left:0;}.messages-desk__form{grid-template-columns:1fr;}}

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

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

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

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

    .opinions .h p{margin:0;}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

    .testimonials .card:hover{transform:rotateY(180deg);}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

.support{padding:clamp(50px,7vw,90px) clamp(16px,4vw,36px);background:var(--muted-bg);color:var(--muted-fg);}

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

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

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

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

    .support .table{border:1px solid var(--card-border);border-radius:var(--radius-lg);overflow:hidden;}

    .support .table article{display:grid;grid-template-columns:.8fr 1.2fr;gap:12px;padding:12px;border-bottom:1px solid var(--card-border);background:var(--muted-bg);color:var(--muted-fg);}

    .support .table article:last-child{border-bottom:0;}

    .support .table h3{margin:0;font-size:1rem;}

    .support .table p{margin:0;}

    @media (max-width: 700px){.support .table article{grid-template-columns:1fr;}
    }

.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; }
.faq-answer-indexgrid .note a { color: var(--link); }
.faq-answer-indexgrid .note a:hover { color: var(--link-hover); }
@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; }
}

.map{padding:clamp(3.1rem,7vw,5.7rem) var(--space-x);background:var(--muted-bg);color:var(--muted-fg);}

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

    .map .head{text-align:center;margin-bottom:1rem;}

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

    .map .head p{margin:.55rem 0 0;}

    .map .frame{overflow:hidden;border-radius:var(--radius-xl);border:1px solid var(--card-border);box-shadow:var(--shadow-sm);}

    .map .frame iframe{display:block;width:100%;height:24rem;}

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

    .map .grid article{padding:.95rem;border-radius:var(--radius-md);background:var(--card-bg);border:1px solid var(--card-border);color:var(--card-fg);}

    .map .grid p{margin:.35rem 0 0;}

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

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

.policy-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-items{padding:clamp(56px,8vw,96px) clamp(16px,4vw,36px);background:var(--card-bg);color:var(--card-fg);}

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

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

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

    .terms-items .section-head p{margin:10px auto 0;color:var(--neutral-600);max-width:70ch;}

    .terms-items ol{margin:0;padding-left:18px;display:grid;gap:10px;}

    .terms-items li{background:var(--muted-bg);border-radius:var(--radius-md);border:1px solid var(--card-border);padding:12px;color:var(--muted-fg);}

    .terms-items h3{margin:0;font-size:1rem;}

    .terms-items li p{margin:8px 0 0;color:var(--neutral-600);}

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

.not-found{padding:clamp(56px,10vw,112px) 20px;background:var(--muted-bg);color:var(--muted-fg);}

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

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

    .not-found p{margin:10px 0 0;}

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