
  /* ── Avenir Next LT Pro (brand font) ──────────────────────── */
  @font-face{
    font-family: "Avenir Next";
    src: url("../fonts/AvenirNext-UltLt.otf") format("opentype");
    font-weight: 200; font-style: normal; font-display: swap;
  }
  @font-face{
    font-family: "Avenir Next";
    src: url("../fonts/AvenirNext-Regular.otf") format("opentype");
    font-weight: 400; font-style: normal; font-display: swap;
  }
  @font-face{
    font-family: "Avenir Next";
    src: url("../fonts/AvenirNext-It.otf") format("opentype");
    font-weight: 400; font-style: italic; font-display: swap;
  }
  @font-face{
    font-family: "Avenir Next";
    src: url("../fonts/AvenirNext-Medium.otf") format("opentype");
    font-weight: 500; font-style: normal; font-display: swap;
  }
  @font-face{
    font-family: "Avenir Next";
    src: url("../fonts/AvenirNext-Demi.otf") format("opentype");
    font-weight: 600; font-style: normal; font-display: swap;
  }
  @font-face{
    font-family: "Avenir Next";
    src: url("../fonts/AvenirNext-DemiIt.otf") format("opentype");
    font-weight: 600; font-style: italic; font-display: swap;
  }
  @font-face{
    font-family: "Avenir Next";
    src: url("../fonts/AvenirNext-Heavy.otf") format("opentype");
    font-weight: 800; font-style: normal; font-display: swap;
  }
  @font-face{
    font-family: "Kangee";
    src: url("../fonts/Kangee.ttf") format("truetype");
    font-weight: 400; font-style: normal; font-display: swap;
  }
  :root{
    --midnight: #010C1C;
    --navy:     #091A2C;
    --navy-2:   #0E2238;
    --gold:     #D0B68C;
    --gold-2:   #B89464;
    --gold-3:   #E6D2B0;
    --ivory:    #F4EEEC;
    --pearl:    #FCF8F7;
    --line-dark: rgba(1,12,28,.14);
    --line-light: rgba(244,238,236,.18);
    --ink:      #010C1C;
    --ink-60:   rgba(1,12,28,.62);
    --ink-45:   rgba(1,12,28,.45);
    --ink-25:   rgba(1,12,28,.22);
    --ivo:      #F4EEEC;
    --ivo-70:   rgba(244,238,236,.74);
    --ivo-45:   rgba(244,238,236,.48);
    --ivo-22:   rgba(244,238,236,.22);

    --ff-sans: "Avenir Next", "Nunito Sans", -apple-system, BlinkMacSystemFont, "Helvetica Neue", Helvetica, Arial, sans-serif;
    --ff-serif: "Cormorant Garamond", "Times New Roman", serif;
    --ff-mono: "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace;
    --ff-brand: "Kangee", "Avenir Next", sans-serif;

    --maxw: 1280px;
    --pad-x: clamp(20px, 5vw, 80px);
    --section-y: clamp(80px, 12vw, 160px);
  }

  *,*::before,*::after{ box-sizing:border-box; }
  html,body{ margin:0; padding:0; }
  html{ scroll-behavior:smooth; overflow-x: hidden; }
  body{
    background: var(--ivory);
    color: var(--ink);
    font-family: var(--ff-sans);
    font-weight: 400;
    font-size: 17px;
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
    overflow-x: hidden;
  }

  img{ display:block; max-width:100%; height:auto; }
  figure{ margin: 0; }
  a{ color:inherit; text-decoration:none; }
  button{ font:inherit; color:inherit; cursor:pointer; border:0; background:none; padding:0; }

  /* ── Typography scale ───────────────────────────────────────── */
  .display-1{
    font-family: var(--ff-sans);
    font-weight: 300;
    font-size: clamp(40px, 5.2vw, 76px);
    line-height: 1.04;
    letter-spacing: -0.025em;
    text-wrap: balance;
  }
  .display-2{
    font-family: var(--ff-sans);
    font-weight: 300;
    font-size: clamp(36px, 4.8vw, 68px);
    line-height: 1.05;
    letter-spacing: -0.022em;
    text-wrap: balance;
  }
  .display-3{
    font-family: var(--ff-sans);
    font-weight: 300;
    font-size: clamp(30px, 3.6vw, 52px);
    line-height: 1.08;
    letter-spacing: -0.018em;
    text-wrap: balance;
  }
  .eyebrow{
    font-family: var(--ff-mono);
    font-weight: 400;
    font-size: 11px;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--ink-45);
    margin: 0 0 12px;
  }
  .eyebrow.on-dark{ color: var(--ivo-45); }
  .lede{
    font-size: clamp(17px, 1.3vw, 19px);
    line-height: 1.55;
    color: var(--ink-60);
    max-width: 56ch;
    text-wrap: pretty;
  }
  .lede.on-dark{ color: var(--ivo-70); }
  .body-lg{ font-size:18px; line-height:1.62; color: var(--ink-60); }
  .body-lg.on-dark{ color: var(--ivo-70); }

  /* Editorial italic accent (toggled via [data-display="editorial"]) */
  [data-display="editorial"] .ed-italic{
    font-family: var(--ff-serif);
    font-style: italic;
    font-weight: 400;
    letter-spacing: -0.005em;
  }
  [data-display="sans"] .ed-italic{
    font-style: italic;
    font-weight: 300;
  }

  /* ── Layout primitives ──────────────────────────────────────── */
  .section{
    padding-top: var(--section-y);
    padding-bottom: var(--section-y);
    padding-left: var(--pad-x);
    padding-right: var(--pad-x);
    position: relative;
  }
  .section.--tight{ padding-top: clamp(48px, 7vw, 96px); padding-bottom: clamp(48px, 7vw, 96px); }
  .section.--dark{ background: var(--midnight); color: var(--ivo); }
  .section.--ivory{ background: var(--ivory); color: var(--ink); }
  .section.--pearl{ background: var(--pearl); color: var(--ink); }
  .container{ max-width: var(--maxw); margin: 0 auto; width: 100%; }

  /* ── Buttons ────────────────────────────────────────────────── */
  .btn{
    display: inline-flex; align-items: center; gap: 12px;
    padding: 16px 28px;
    font-family: var(--ff-sans);
    font-size: 14px;
    font-weight: 600;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    border: 1px solid transparent;
    border-radius: 0;
    transition: background 220ms ease, color 220ms ease, border-color 220ms ease, transform 220ms ease;
    max-width: 100%;
  }
  .arrow{ width: 14px; height: 14px; flex-shrink: 0; }
  .btn .arrow{ display:inline-block; transition: transform 260ms ease; }
  .btn:hover .arrow{ transform: translateX(4px); }

  .btn--gold{
    background: var(--gold);
    color: var(--midnight);
  }
  .btn--gold:hover{ background: var(--gold-2); }

  .btn--outline-ivory{
    background: transparent;
    color: var(--ivo);
    border-color: var(--ivo-22);
  }
  .btn--outline-ivory:hover{ border-color: var(--ivo); }

  .btn--outline-dark{
    background: transparent;
    color: var(--ink);
    border-color: var(--ink-25);
  }
  .btn--outline-dark:hover{ border-color: var(--ink); }

  .btn--ghost-gold{
    color: var(--gold-2);
    padding: 12px 0;
    border-bottom: 1px solid var(--gold-2);
    background: transparent;
  }
  .btn--ghost-gold:hover{ color: var(--midnight); border-color: var(--midnight); }

  /* ── Brand line+2-circles divider ───────────────────────────── */
  .brandline{
    display: flex; align-items: center; gap: 10px;
    width: 100%; max-width: 240px;
  }
  .brandline .c{ width: 11px; height: 11px; border-radius: 50%; flex: 0 0 auto; }
  .brandline .l{ flex: 1; height: 1px; background: currentColor; opacity: .35; }
  .brandline .c--out{ border: 1px solid currentColor; }
  .brandline .c--fill{ background: currentColor; }
  .brandline.--gold .c{ color: var(--gold); }
  .brandline.--gold .c--out{ border-color: var(--gold); background: transparent; }
  .brandline.--gold .c--fill{ background: var(--gold); }
  .brandline.--gold .l{ background: var(--gold); opacity: .55; }

  /* ── Editorial image placeholders ───────────────────────────── */
  .ph{
    position: relative;
    width: 100%;
    aspect-ratio: 4/5;
    background: var(--pearl);
    color: var(--ink-45);
    overflow: hidden;
    isolation: isolate;
    margin: 0;
  }
  .ph.--dark{ background: var(--navy); color: var(--ivo-45); }
  .ph--real{ background: var(--midnight); }
  .ph--r-auto{ aspect-ratio: auto; }
  .ph--r-3-2{ aspect-ratio: 3/2; }
  .ph__img{
    position: absolute; inset: 0;
    width: 100%; height: 100%;
    object-fit: cover;
    object-position: center top;
    display: block;
  }
  .ph--p-18 .ph__img{ object-position: center 18%; }
  .ph--p-20 .ph__img{ object-position: center 20%; }
  .ph--p-30 .ph__img{ object-position: center 30%; }
  .ph::before{
    content: "";
    position: absolute; inset: 0;
    background-image: repeating-linear-gradient(
      135deg,
      transparent 0, transparent 14px,
      currentColor 14px, currentColor 14.6px
    );
    opacity: .14;
    z-index: 0;
  }
  .ph__label{
    position: absolute;
    left: 16px; bottom: 14px;
    font-family: var(--ff-mono);
    font-size: 10.5px;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: currentColor;
    background: var(--pearl);
    padding: 6px 10px;
    z-index: 1;
  }
  .ph.--dark .ph__label{ background: var(--navy); color: var(--ivo-70); }
  .ph__corner{
    position: absolute;
    right: 16px; top: 14px;
    font-family: var(--ff-mono);
    font-size: 10px;
    letter-spacing: .12em;
    color: currentColor;
    opacity: .6;
    z-index: 1;
  }

  /* ── Reveal animation ───────────────────────────────────────── */
  .reveal{ opacity: 0; transform: translateY(14px); transition: opacity 900ms ease, transform 900ms cubic-bezier(.2,.6,.2,1); }
  .reveal.in{ opacity: 1; transform: translateY(0); }
  @media (prefers-reduced-motion: reduce){
    .reveal{ opacity:1; transform:none; transition:none; }
    html{ scroll-behavior:auto; }
  }

  /* ── Sticky header ─────────────────────────────────────────── */
  .hdr{
    position: fixed; top: 0; left: 0; right: 0;
    z-index: 100;
    padding: 18px var(--pad-x);
    display: flex; align-items: center; justify-content: space-between;
    gap: 24px;
    background: transparent;
    transition: background 320ms ease, padding 320ms ease, border-color 320ms ease;
    border-bottom: 1px solid transparent;
  }
  .hdr.--scrolled{
    background: rgba(1,12,28,.92);
    backdrop-filter: blur(14px) saturate(140%);
    -webkit-backdrop-filter: blur(14px) saturate(140%);
    padding: 12px var(--pad-x);
    border-bottom-color: var(--ivo-22);
  }
  .hdr__logo{ height: 56px; display:flex; align-items:center; }
  .hdr__logo img{ height: 56px; width: auto; }
  .hdr__nav{
    display: flex; gap: 32px; align-items: center;
    font-size: 13px;
    letter-spacing: 0.02em;
    color: var(--ivo-70);
  }
  .hdr__nav a{ transition: color 200ms ease; }
  .hdr__nav a:hover{ color: var(--ivo); }
  .hdr__lang{
    font-family: var(--ff-mono);
    font-size: 11px;
    letter-spacing: .18em;
    color: var(--ivo-45);
  }
  .hdr__lang b{ color: var(--ivo); font-weight: 500; }
  .hdr__burger{ display:none; width:32px; height:32px; flex-direction:column; justify-content:center; gap:5px; }
  .hdr__burger span{ display:block; width:20px; height:1px; background: var(--ivo); margin: 0 auto; }

  @media (max-width: 880px){
    .hdr__nav, .hdr__lang{ display:none; }
    .hdr__burger{ display:flex; }
  }

  /* ── Floating WhatsApp ─────────────────────────────────────── */
  .wa{
    position: fixed;
    right: 22px; bottom: 22px;
    z-index: 90;
    display: flex; align-items: center; gap: 12px;
    padding: 14px 20px 14px 16px;
    background: #25D366;
    color: #fff;
    font-size: 13px;
    font-weight: 600;
    letter-spacing: 0.02em;
    transition: background 220ms ease, transform 220ms ease;
    box-shadow: 0 8px 32px rgba(37,211,102,.35);
  }
  .wa:hover{ background: #1ebe5d; transform: translateY(-1px); }
  .wa svg{ width: 26px; height: 26px; flex-shrink: 0; }
  @media (max-width: 600px){
    .wa__label{ display:none; }
    .wa{ padding: 14px; border-radius: 50%; }
    .wa svg{ width: 28px; height: 28px; }
  }

  /* ── Utilities ─────────────────────────────────────────────── */
  .sr{ position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); border:0; }
  .gold{ color: var(--gold); }
  .gold-2{ color: var(--gold-2); }
  hr.rule{ border:0; border-top:1px solid var(--line-dark); margin: 0; }
  hr.rule.on-dark{ border-top-color: var(--line-light); }
