:root {
  --font-family: "Rubik", sans-serif;
  --font-size-base: 16.5px;
  --line-height-base: 1.81;

  --max-w: 1480px;
  --space-x: 1.48rem;
  --space-y: 1.5rem;
  --gap: 1.52rem;
  --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.09rem;
  --radius-lg: 0.96rem;
  --radius-md: 0.54rem;
  --radius-sm: 0.33rem;

  --shadow-sm: 0 1px 6px rgba(0,0,0,0.16);
  --shadow-md: 0 6px 14px rgba(0,0,0,0.21);
  --shadow-lg: 0 20px 36px rgba(0,0,0,0.25);

  --overlay: rgba(15, 23, 42, 0.7);
  --anim-duration: 520ms;
  --anim-ease: cubic-bezier(0.4,0,0.2,1);
  --random-number: 1;

  --brand: #244238;
  --brand-contrast: #faf8f1;
  --accent: #a45f2a;
  --accent-contrast: #fff7ed;

  --neutral-0: #ffffff;
  --neutral-100: #f1f5f9;
  --neutral-300: #cbd5e1;
  --neutral-600: #64748b;
  --neutral-800: #1e293b;
  --neutral-900: #0f172a;

  --page-bg: #faf8f1;
  --page-fg: #24211d;
  --muted-bg: #ece7dc;
  --muted-fg: #24211d;
  --card-bg: #ffffff;
  --card-fg: #24211d;
  --card-border: #d9d0c0;
  --inverse-bg: #244238;
  --inverse-fg: #faf8f1;
  --primary-bg: #244238;
  --primary-fg: #faf8f1;
  --primary-hover: #31594c;
  --accent-bg: #a45f2a;
  --accent-fg: #fff7ed;
  --accent-hover: #874b20;
  --gradient-hero-bg: linear-gradient(135deg, #faf8f1 0%, #ece7dc 54%, #244238 100%);
  --gradient-hero-fg: #24211d;
  --gradient-accent-bg: linear-gradient(135deg, #244238 0%, #a45f2a 100%);
  --gradient-accent-fg: #faf8f1;

  --ring: #06b6d4;

  --link: #244238;
  --link-hover: #a45f2a;

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

/* ---- header reset / base ---- */
.site-header {
  width: 100%;
  background-color: var(--page-bg, #ffffff);
  border-bottom: 1px solid var(--card-border, #d0d5dd);
  box-shadow: var(--shadow-sm, 0 1px 3px rgba(0,0,0,0.06));
  margin: 0;
  padding: 0;
}

/* wrapper: centrado + max-width */
.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 row ---- */
.header-utility {
  background-color: var(--muted-bg, #f2f4f7);
  color: var(--muted-fg, #344054);
  font-size: var(--font-size-sm, 0.875rem);
  line-height: var(--line-height-base, 1.5);
  border-bottom: 1px solid var(--card-border, #d0d5dd);
}

.utility-inner {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: var(--gap, 1.5rem);
  padding-top: 0.35rem;
  padding-bottom: 0.35rem;
  flex-wrap: wrap;
}

.utility-text {
  white-space: nowrap;
}

/* ---- main row (logo + nav + burger) ---- */
.header-main {
  background-color: var(--card-bg, #ffffff);
  color: var(--card-fg, #1d2939);
}

.main-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: 0.6rem;
  padding-bottom: 0.6rem;
  min-height: 3.5rem;
}

/* logo */
.logo a {
  text-decoration: none;
  font-size: var(--font-size-h3, 1.5rem);
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--primary-bg, #155eef);
  background-color: transparent;
  transition: color var(--anim-duration, 0.2s) var(--anim-ease, ease);
}

.logo a:hover {
  color: var(--primary-hover, #004eeb);
}

/* horizontal nav */
.nav-horizontal {
  display: flex;
  align-items: center;
}

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

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

.nav-list a:hover,
.nav-list a:focus-visible {
  color: var(--primary-bg, #155eef);
  border-bottom-color: var(--primary-bg, #155eef);
}

/* burger button (hidden on 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, #d0d5dd);
  border-radius: var(--radius-sm, 6px);
  cursor: pointer;
  padding: 0.25rem;
  transition: background var(--anim-duration, 0.2s) ease;
}

.burger:hover {
  background-color: var(--muted-bg, #f2f4f7);
}

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

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

  .nav-horizontal {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background-color: var(--card-bg, #ffffff);
    border-top: 1px solid var(--card-border, #d0d5dd);
    box-shadow: var(--shadow-md, 0 4px 12px rgba(0,0,0,0.08));
    max-height: 0;
    overflow: hidden;
    visibility: hidden;
    opacity: 0;
    transition: max-height 0.35s ease, opacity 0.25s ease, visibility 0.25s ease;
    padding: 0 var(--space-x, 1.5rem);
  }

  .nav-horizontal.is-open {
    max-height: 500px; /* enough for menu items */
    visibility: visible;
    opacity: 1;
    padding-top: 0.75rem;
    padding-bottom: 0.75rem;
  }

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

  .nav-list a {
    display: block;
    padding: 0.6rem 0.5rem;
    border-bottom: 1px solid var(--card-border, #d0d5dd);
    white-space: normal;
  }

  .nav-list li:last-child a {
    border-bottom: none;
  }

  /* adjust main-inner to relative for absolute nav */
  .main-inner {
    position: relative;
  }
}

/* desktop: ensure nav is always visible */
@media (min-width: 768px) {
  .nav-horizontal {
    position: static;
    visibility: visible;
    opacity: 1;
    max-height: none;
    overflow: visible;
    background: transparent;
    box-shadow: none;
    border: none;
    padding: 0;
  }

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

/* ---- accessibility / focus ---- */
.burger:focus-visible,
.nav-list a:focus-visible {
  outline: 2px solid var(--primary-bg, #155eef);
  outline-offset: 2px;
}

/* ---- high density / technical mood tweaks ---- */
.site-header {
  font-family: var(--font-family, system-ui, -apple-system, sans-serif);
}

/* reduce padding for dense look */
.header-main .main-inner {
  padding-top: 0.5rem;
  padding-bottom: 0.5rem;
}

.utility-inner {
  padding-top: 0.25rem;
  padding-bottom: 0.25rem;
}

/* small adjustments */
.nav-list a {
  font-size: var(--font-size-sm, 0.875rem);
}

.logo a {
  font-size: var(--font-size-h2, 1.75rem);
}

.footer {
  background-color: #1a1a2e;
  color: #e0e0e0;
  font-family: 'Segoe UI', system-ui, -apple-system, sans-serif;
  font-size: 0.85rem;
  line-height: 1.5;
  padding: 1.5rem 1rem;
  border-top: 2px solid #2d2d44;
}
.footer__container {
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 1rem 2rem;
}
.footer__brand {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}
.footer__logo {
  font-size: 1.2rem;
  font-weight: 700;
  color: #00d4aa;
  text-decoration: none;
  letter-spacing: 0.5px;
}
.footer__logo:hover {
  color: #00f0c0;
}
.footer__copyright {
  margin: 0;
  font-size: 0.75rem;
  color: #9a9ab0;
}
.footer__nav-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem 1.5rem;
}
.footer__nav-link {
  color: #c0c0d0;
  text-decoration: none;
  font-weight: 500;
  transition: color 0.2s;
}
.footer__nav-link:hover {
  color: #00d4aa;
}
.footer__legal {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem 1.5rem;
}
.footer__legal-link {
  color: #9a9ab0;
  text-decoration: none;
  font-size: 0.8rem;
  transition: color 0.2s;
}
.footer__legal-link:hover {
  color: #00d4aa;
  text-decoration: underline;
}
.footer__contact {
  font-style: normal;
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem 1.5rem;
  color: #b0b0c8;
  font-size: 0.8rem;
}
.footer__contact-item a {
  color: #b0b0c8;
  text-decoration: none;
}
.footer__contact-item a:hover {
  color: #00d4aa;
  text-decoration: underline;
}
.footer__disclaimer {
  width: 100%;
  margin: 0.75rem 0 0;
  font-size: 0.7rem;
  color: #7a7a90;
  text-align: center;
  border-top: 1px solid #2d2d44;
  padding-top: 0.75rem;
  line-height: 1.4;
}
@media (max-width: 768px) {
  .footer__container {
    flex-direction: column;
    align-items: flex-start;
    gap: 1rem;
  }
  .footer__nav-list {
    flex-direction: column;
    gap: 0.5rem;
  }
  .footer__legal {
    flex-direction: column;
    gap: 0.5rem;
  }
  .footer__contact {
    flex-direction: column;
    gap: 0.25rem;
  }
  .footer__disclaimer {
    text-align: left;
  }
}

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

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

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

    .intro .hero{text-align:center;}

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

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

    .intro .hero strong{display:block;margin-top:.7rem;}

    .intro .panels{margin-top:1.15rem;display:grid;gap:.8rem;}

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

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

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

    .next-step h2,.next-step h3,.next-step p{margin:0;}

    .next-step a{text-decoration:none;}

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

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

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

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

    .next-step .actions a,.next-step .center a,.next-step .banner > a,.next-step .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);}

    .next-step .banner{display:grid;gap:.6rem;}

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

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

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

    .next-step .duo article{display:grid;gap:.45rem;}

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

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

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

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

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

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

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

.clarifications-native-folds{padding:var(--space-section-y) var(--space-section-x);background:var(--page-bg);color:var(--page-fg)}
.clarifications-native-folds .wrap{max-width:var(--max-w);margin:0 auto;display:grid;grid-template-columns:minmax(14rem,.34fr) minmax(0,1fr);gap:var(--space-block)}
.clarifications-native-folds .intro{align-self:start}
.clarifications-native-folds h2{margin:0;font-size:var(--font-size-h2);line-height:1.08}
.clarifications-native-folds .intro p{margin:var(--space-y) 0 0;color:var(--muted-fg);line-height:var(--line-height-base)}
.clarifications-native-folds .folds{align-self:start}
.clarifications-native-folds details{padding:var(--space-y) 0}
.clarifications-native-folds details+details{margin-top:var(--space-card)}
.clarifications-native-folds summary{cursor:pointer;font-size:var(--font-size-h3);line-height:1.18}
.clarifications-native-folds details p{max-width:46rem;margin:var(--space-y) 0 0;color:var(--muted-fg);line-height:var(--line-height-base)}
@media(max-width:720px){.clarifications-native-folds .wrap{display:block}.clarifications-native-folds .folds{margin-top:var(--space-block)}}

.advantages {
    padding: clamp(3.5rem, 8vw, 6.1rem) var(--space-x);
    background: var(--gradient-hero-bg);
    color: var(--gradient-hero-fg);
}

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

.advantages .head {
    margin-bottom: 1.1rem;
}

.advantages .head p {
    margin: 0;
    color: color-mix(in srgb, currentColor 76%, transparent);
    text-transform: uppercase;
    letter-spacing: .1em;
    font-size: .82rem;
}

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

.advantages .head span {
    display: block;
    margin-top: .8rem;
}

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

.advantages .grid article {
    padding: 1rem;
    border-radius: var(--radius-lg);
    background: color-mix(in srgb, currentColor 14%, transparent);
    border: 1px solid color-mix(in srgb, currentColor 18%, transparent);
}

.advantages .top {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.advantages .top i {
    font-style: normal;
}

.advantages .top strong {
}

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

.advantages .grid p {
    margin: 0;
}

.advantages .grid small {
    display: block;
    margin-top: .55rem;
    color: color-mix(in srgb, currentColor 76%, transparent);
}

.recommendations-closing-note{padding:var(--space-section-y) var(--space-section-x);background:var(--page-bg);color:var(--page-fg)}
.recommendations-closing-note .wrap{max-width:var(--max-w);margin:0 auto}
.recommendations-closing-note .note{max-width:38rem;margin-bottom:var(--space-block)}
.recommendations-closing-note .note p{margin:0;color:var(--muted-fg);line-height:var(--line-height-base)}
.recommendations-closing-note h2{margin:var(--space-y) 0 0;font-size:var(--font-size-h2);line-height:1.08}
.recommendations-closing-note .cards{display:flex;flex-direction:column;gap:var(--space-y)}
.recommendations-closing-note .card{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--gap);padding:var(--space-y) 0;display:flex;flex-direction:column;gap:var(--space-card)}
.recommendations-closing-note strong{font-size:var(--font-size-h3);line-height:1.08}
.recommendations-closing-note .card p{flex:1 1 0;margin:0;color:var(--muted-fg);line-height:var(--line-height-base)}
.recommendations-closing-note a{color:inherit;text-underline-offset:.22em}
@media(max-width:720px){.recommendations-closing-note .card{display:block}.recommendations-closing-note .top{margin-bottom:var(--space-card)}.recommendations-closing-note .card p{margin-top:var(--space-card)}}

.messages-board{padding:var(--space-section-y) var(--space-section-x);background:var(--gradient-hero-bg);color:var(--gradient-hero-fg);position:relative;overflow:hidden;isolation:isolate;}
.messages-board::before{content:'';position:absolute;inset:auto 0 18% 0;height:1px;background:linear-gradient(90deg,transparent,color-mix(in srgb,currentColor 25%,transparent),transparent);opacity:.45;pointer-events:none;}
.messages-board__wrap{max-width:var(--max-w);margin:0 auto;position:relative;z-index:1;display:grid;gap:var(--gap);}
.messages-board__top{display:grid;grid-template-columns:minmax(0,.62fr) minmax(15rem,.38fr);gap:var(--gap);align-items:end;}
.messages-board h2,.messages-board h4,.messages-board p{margin:0;}
.messages-board h2{font-size:var(--font-size-h2);line-height:var(--line-height-tight);}
.messages-board__top p{font-size:var(--font-size-lg);line-height:var(--line-height-base);opacity:.82;}
.messages-board__layout{display:grid;grid-template-columns:minmax(0,1fr) minmax(16rem,.34fr);gap:var(--gap);align-items:start;}
.messages-board__conversation{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem;}
.messages-board__note{min-height:9rem;display:grid;align-content:space-between;gap:var(--space-block);padding:var(--space-card);border:1px solid color-mix(in srgb,currentColor 18%,transparent);border-radius:var(--radius-lg);background:color-mix(in srgb,currentColor 8%,transparent);}
.messages-board__note:first-child{grid-row:span 2;min-height:18.75rem;background:var(--card-bg);color:var(--card-fg);}
.messages-board__note p{font-size:var(--font-size-md);line-height:var(--line-height-base);}
.messages-board time{font-size:var(--font-size-sm);opacity:.68;}
.messages-board__people{display:grid;gap:.55rem;}
.messages-board__person{display:grid;grid-template-columns:auto minmax(0,1fr);gap:.75rem;position:relative;padding:.75rem .85rem;border-radius:var(--radius-md);background:color-mix(in srgb,currentColor 10%,transparent);border:1px solid color-mix(in srgb,currentColor 14%,transparent);}
.messages-board__person>span{width:2.25rem;height:2.25rem;border-radius:999px;background:var(--accent-bg);color:var(--accent-fg);display:grid;place-items:center;font-weight:700;}
.messages-board__person h4{font-size:var(--font-size-md);line-height:var(--line-height-tight);}
.messages-board__person p{font-size:var(--font-size-sm);opacity:.78;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.messages-board__person time{grid-column:2;margin-top:.15rem;}
.messages-board__form{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:.55rem;padding:.65rem;border:1px solid color-mix(in srgb,currentColor 18%,transparent);border-radius:var(--radius-lg);background:color-mix(in srgb,currentColor 8%,transparent);}
.messages-board__form input{min-width:0;border:0;border-radius:var(--radius-md);padding:.85rem 1rem;background:var(--card-bg);color:var(--card-fg);font:inherit;outline:none;}
.messages-board__form button{border:0;border-radius:var(--radius-md);padding:.85rem 1.2rem;background:var(--primary-bg);color:var(--primary-fg);font:inherit;font-weight:700;cursor:pointer;}
@media (max-width:900px){.messages-board__top,.messages-board__layout{grid-template-columns:1fr;}.messages-board__conversation{grid-template-columns:1fr;}.messages-board__note:first-child{grid-row:auto;min-height:9rem;}.messages-board__form{grid-template-columns:1fr;}}

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

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

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

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

    .notes .h p{margin:0;}

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

    .notes .card{border-radius:var(--radius-xl);background:var(--muted-bg);border:1px solid var(--card-border);box-shadow:var(--shadow-md);padding:clamp(18px,3vw,26px);transform:translateY(28px);color:var(--muted-fg);}

    .notes .top{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;}

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

    .notes .who h3{margin:0;font-size:16px;font-weight:800;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:20ch;}

    .notes .who p{margin:2px 0 0;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:26ch;}

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

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

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

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

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

.faq-answer-table{padding:var(--space-section-y) var(--space-section-x);background:var(--primary-bg);color:var(--primary-fg)}
.faq-answer-table .wrap{max-width:var(--max-w);margin:0 auto}
.faq-answer-table .heading{display:flex;align-items:end;justify-content:space-between;gap:var(--gap);margin-bottom:var(--space-block)}
.faq-answer-table h2{max-width:14ch;margin:0;font-size:var(--font-size-h1);line-height:1}
.faq-answer-table .heading p{max-width:38rem;margin:0;font-size:var(--font-size-lg);line-height:var(--line-height-base)}
.faq-answer-table .table-wrap{overflow-x:auto}
.faq-answer-table table{width:100%;border-collapse:collapse}
.faq-answer-table th,.faq-answer-table td{padding:var(--space-y);vertical-align:top;text-align:left}
.faq-answer-table th{width:38%;font-size:var(--font-size-h3);font-weight:inherit}
.faq-answer-table td{line-height:var(--line-height-base)}
.faq-answer-table tr:nth-child(odd){background:color-mix(in srgb,currentColor 7%,transparent)}
.faq-answer-table .note{max-width:38rem;margin:var(--space-y) 0 0}
@media(max-width:680px){.faq-answer-table .heading{display:block}.faq-answer-table .heading p{margin-top:var(--space-y)}.faq-answer-table table,.faq-answer-table tbody,.faq-answer-table tr,.faq-answer-table th,.faq-answer-table td{display:block}.faq-answer-table tr{padding:var(--space-y) 0}.faq-answer-table th,.faq-answer-table td{width:auto;padding:0}.faq-answer-table td{margin-top:var(--space-card)}}

.contact-strip{padding:clamp(56px,8vw,96px) clamp(16px,3vw,36px);background:var(--page-bg);color:var(--page-fg);}

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

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

    .contact-strip .lead{margin:10px 0 14px;}

    .contact-strip .list{display:grid;gap:8px;}

    .contact-strip .row{border:1px solid var(--card-border);border-radius:var(--radius-md);background:var(--card-bg);padding:10px 12px;display:flex;justify-content:space-between;gap:10px;align-items:center;color:var(--card-fg);}

    .contact-strip .title{margin:0 0 4px;font-weight:600;}

    .contact-strip .text{margin:0;}

    .contact-strip .row a{text-decoration:none;}

    .contact-strip .cta{display:inline-block;margin-top:12px;text-decoration:none;padding:10px 16px;border-radius:var(--radius-md);background:var(--primary-bg);color:var(--primary-fg);}

.contacts-narrow-letter {
  padding: var(--space-section-y) var(--space-section-x);
  background: var(--inverse-bg);
  color: var(--inverse-fg);
}
.contacts-narrow-letter .letter {
  width: min(100%, calc(var(--max-w) * .56));
  margin: 0 auto;
}
.contacts-narrow-letter h2 {
  margin: 0;
  font-size: var(--font-size-h2);
  line-height: 1.08;
}
.contacts-narrow-letter .text {
  margin: var(--space-y) 0 var(--space-block);
  font-size: var(--font-size-lg);
  line-height: var(--line-height-base);
}
.contacts-narrow-letter .contact {
  display: flex;
  flex-direction: column;
  margin: 0;
  padding: var(--space-y) 0;
  border-top: 1px solid var(--card-border);
}
.contacts-narrow-letter .contact a {
  align-self: flex-start;
  color: var(--link);
  font-size: var(--font-size-h3);
  overflow-wrap: anywhere;
  text-decoration-thickness: 1px;
  text-underline-offset: .22em;
}
.contacts-narrow-letter .contact span {
  order: -1;
  margin-bottom: var(--space-card);
  color: var(--neutral-600);
  font-size: var(--font-size-sm);
}
.contacts-narrow-letter .closing {
  display: flex;
  gap: var(--gap);
  padding: var(--space-y) 0;
  border-top: 1px solid var(--card-border);
}
.contacts-narrow-letter .closing p {
  flex: 1 1 0;
  margin: 0;
  color: var(--neutral-600);
  line-height: var(--line-height-base);
}
.contacts-narrow-letter .links {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-y);
  padding-top: var(--space-y);
  border-top: 1px solid var(--card-border);
}
.contacts-narrow-letter .links a {
  color: inherit;
  text-decoration: none;
  transition: color var(--anim-duration) var(--anim-ease);
}
.contacts-narrow-letter .links a:hover {
  color: var(--link-hover);
}
@media (max-width: 520px) {
  .contacts-narrow-letter .closing {
    display: block;
  }
  .contacts-narrow-letter .closing p + p {
    margin-top: var(--space-y);
  }
}

.form-random-composition{padding:var(--space-section-y) var(--space-section-x);background:var(--gradient-accent-bg);color:var(--gradient-accent-fg)}
.form-random-composition .wrap{max-width:var(--max-w);margin:0 auto}
.form-random-composition .title{display:flex;align-items:end;justify-content:space-between;gap:var(--gap);margin-bottom:var(--space-block)}
.form-random-composition h2{max-width:14ch;margin:0;font-size:var(--font-size-h1);line-height:1}
.form-random-composition .title p{max-width:38rem;margin:0;font-size:var(--font-size-lg);line-height:var(--line-height-base)}
.form-random-composition form{display:flex;flex-wrap:wrap;align-items:flex-start;gap:var(--gap)}
.form-random-composition [data-random-field]{flex:1 1 18rem;order:var(--field-order,0);transform:translateY(var(--field-shift,0))}
.form-random-composition label span{display:block;margin-bottom:var(--space-card)}
.form-random-composition input,.form-random-composition textarea{width:100%;padding:var(--space-card);border:1px solid color-mix(in srgb,currentColor 32%,transparent);border-radius:var(--radius-sm);background:color-mix(in srgb,currentColor 7%,transparent);color:inherit;font:inherit}
.form-random-composition .message{flex:1 1 100%;order:8}
.form-random-composition textarea{resize:vertical}
.form-random-composition button{order:9;padding:var(--space-card) var(--space-y);border:0;border-radius:var(--radius-sm);background:var(--inverse-bg);color:var(--inverse-fg);font:inherit}
@media(max-width:680px){.form-random-composition .title{display:block}.form-random-composition .title p{margin-top:var(--space-y)}.form-random-composition [data-random-field]{transform:none}}

.policy{padding:calc(var(--space-y)*2.65) var(--space-x);color:var(--page-fg);background:var(--page-bg);}
.policy .grid{max-width:var(--max-w);margin:0 auto;display:grid;grid-template-columns:repeat(12,minmax(0,1fr));gap:.6rem;}
.policy .main{grid-column:span 12;padding:1rem;border-radius:var(--radius-xl);background:var(--card-bg);border:1px solid var(--card-border);color:var(--card-fg);}
.policy .main h2{margin:0;font-size:clamp(1.75rem,3.2vw,2.45rem);}
.policy .main p{margin:.38rem 0 0;}
.policy .card{grid-column:span 4;padding:.85rem;border-radius:var(--radius-md);background:var(--muted-bg);border:1px solid var(--card-border);color:var(--muted-fg);}
.policy .card h3{margin:0 0 .22rem;font-size:1rem;}
.policy .card p{margin:0;}
.policy .foot{grid-column:span 12;padding:.85rem;border-radius:var(--radius-md);background:color-mix(in srgb,var(--card-bg) 86%,var(--accent-bg) 14%);border:1px solid var(--card-border);color:var(--card-fg);}
.policy .foot h3{margin:0 0 .2rem;}
.policy .foot p{margin:0;}
@media (max-width:920px){.policy .card{grid-column:span 6;}}@media (max-width:620px){.policy .card{grid-column:1/-1;}}

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

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

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

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

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

    .conditions .timeline{border-left:3px solid var(--primary-bg);padding-left:14px;display:grid;gap:12px;}

    .conditions article{position:relative;background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-md);padding:12px;color:var(--card-fg);}

    .conditions .meta{margin:0;font-size:.9rem;font-weight:600;}

    .conditions h3{margin:7px 0;}

    .conditions article p{margin:0;}

.thank-switch-path{padding:var(--space-section-y) var(--space-section-x);background:var(--primary-bg);color:var(--primary-fg)}
.thank-switch-path .wrap{max-width:var(--max-w);margin:0 auto}
.thank-switch-path .hero{max-width:40rem;margin-bottom:var(--space-block)}
.thank-switch-path .hero p{margin:0;font-size:var(--font-size-lg);line-height:var(--line-height-base)}
.thank-switch-path h2{margin:var(--space-y) 0 0;font-size:var(--font-size-h1);line-height:1}
.thank-switch-path .path{display:flex;flex-direction:column}
.thank-switch-path .node{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--gap);padding:var(--space-y) 0;font-size:var(--font-size-h3);line-height:1.08}
.thank-switch-path span{flex:1 1 0;line-height:var(--line-height-base)}
@media(max-width:720px){.thank-switch-path .node{display:block}.thank-switch-path span{display:block;margin-top:var(--space-card)}}

.notfound-quiet-column{padding:var(--space-section-y) var(--space-section-x);background:var(--page-bg);color:var(--page-fg)}
.notfound-quiet-column .column{width:min(100%,calc(var(--max-w)*.58));margin:0 auto}
.notfound-quiet-column h1{margin:0;font-size:var(--font-size-h1);line-height:1.02}
.notfound-quiet-column p{max-width:38rem;margin:var(--space-y) 0 0;color:var(--muted-fg);font-size:var(--font-size-lg);line-height:var(--line-height-base)}
.notfound-quiet-column a{align-self:flex-start;margin-top:var(--space-block);padding-bottom:var(--space-card);border-bottom:1px solid currentColor;color:inherit;text-decoration:none;transition:padding var(--anim-duration) var(--anim-ease)}
.notfound-quiet-column a:hover{padding-left:var(--space-card)}