/* Self-hosted fonts (Cormorant Garamond + DM Sans, latin + latin-ext) */
/* Cormorant Garamond italic 400 latin-ext */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url(/fonts/cormorant-garamond-italic-400-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* Cormorant Garamond italic 400 latin */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url(/fonts/cormorant-garamond-italic-400-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* Cormorant Garamond italic 500 latin-ext */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: italic;
  font-weight: 500;
  font-display: swap;
  src: url(/fonts/cormorant-garamond-italic-500-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* Cormorant Garamond italic 500 latin */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: italic;
  font-weight: 500;
  font-display: swap;
  src: url(/fonts/cormorant-garamond-italic-500-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* Cormorant Garamond normal 400 latin-ext */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(/fonts/cormorant-garamond-400-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* Cormorant Garamond normal 400 latin */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(/fonts/cormorant-garamond-400-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* Cormorant Garamond normal 500 latin-ext */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(/fonts/cormorant-garamond-500-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* Cormorant Garamond normal 500 latin */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(/fonts/cormorant-garamond-500-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* Cormorant Garamond normal 600 latin-ext */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(/fonts/cormorant-garamond-600-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* Cormorant Garamond normal 600 latin */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(/fonts/cormorant-garamond-600-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* DM Sans normal 400 latin-ext */
@font-face {
  font-family: 'DM Sans';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(/fonts/dm-sans-400-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* DM Sans normal 400 latin */
@font-face {
  font-family: 'DM Sans';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(/fonts/dm-sans-400-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* DM Sans normal 500 latin-ext */
@font-face {
  font-family: 'DM Sans';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(/fonts/dm-sans-500-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* DM Sans normal 500 latin */
@font-face {
  font-family: 'DM Sans';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(/fonts/dm-sans-500-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* DM Sans normal 600 latin-ext */
@font-face {
  font-family: 'DM Sans';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(/fonts/dm-sans-600-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* DM Sans normal 600 latin */
@font-face {
  font-family: 'DM Sans';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(/fonts/dm-sans-600-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* DM Sans normal 700 latin-ext */
@font-face {
  font-family: 'DM Sans';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(/fonts/dm-sans-700-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* DM Sans normal 700 latin */
@font-face {
  font-family: 'DM Sans';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(/fonts/dm-sans-700-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

    /* Fonts loaded via <link rel="stylesheet"> in each HTML head (faster, non-blocking). */

    /* ══════════════════════════════
       DESIGN TOKENS
    ══════════════════════════════ */
    :root {
      --black:     #0D0D0D;
      --black-2:   #161412;
      --espresso:  #1D1B1A;
      --cream:     #F8F4EF;
      --paper:     #FFFFFF;
      --bone:      #ECE6DD;
      --stone:     #C9C2B5;
      --gold:      #C2B299;
      --gold-dk:   #9B8E78;
      --gold-lt:   rgba(194,178,153,.18);
      --gold-line: rgba(194,178,153,.22);
      --ink:       #1C1B1B;
      --ink2:      rgba(28,27,27,.74);
      --gold-text: #7A6E58;
      --paper2:    rgba(248,244,239,.62);
      --t:         .35s cubic-bezier(.4,0,.2,1);
      --serif:     'Cormorant Garamond', Georgia, serif;
      --sans:      'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif;
    }

    *, *::before, *::after { box-sizing:border-box; margin:0; padding:0; }
    html { scroll-behavior:smooth; font-size:16px; }
    body { background:var(--cream); color:var(--ink); font-family:var(--sans); line-height:1.6; overflow-x:hidden; -webkit-font-smoothing:antialiased; }
    body.js-ready { cursor:none; }
    body.js-ready button, body.js-ready .hbg, body.js-ready a, body.js-ready input, body.js-ready textarea, body.js-ready select { cursor:none; }
    a { color:inherit; text-decoration:none; }
    img { display:block; max-width:100%; height:auto; }

    /* ── ACCESSIBILITY: focus-visible ── */
    :focus { outline: none; }
    :focus-visible {
      outline: 2px solid var(--gold-text);
      outline-offset: 3px;
      border-radius: 2px;
    }
    button:focus-visible, .hbg:focus-visible {
      outline: 2px solid var(--black);
      outline-offset: 3px;
    }
    a:focus-visible {
      outline: 2px solid var(--gold-text);
      outline-offset: 4px;
    }
    input:focus-visible, textarea:focus-visible, select:focus-visible {
      outline: 2px solid var(--gold-text);
      outline-offset: 2px;
    }
    .visually-hidden {
      position: absolute !important;
      width: 1px; height: 1px;
      padding: 0; margin: -1px;
      overflow: hidden; clip: rect(0,0,0,0);
      white-space: nowrap; border: 0;
    }
    .skip-link {
      position: fixed; top: -50px; left: 16px; z-index: 9999;
      background: var(--black); color: var(--cream);
      padding: 10px 18px; font-family: var(--sans); font-size: 13px;
      font-weight: 600; letter-spacing: .14em; text-transform: uppercase;
      text-decoration: none; border-radius: 4px;
      transition: top .2s;
    }
    .skip-link:focus { top: 12px !important; outline: 2px solid var(--gold); outline-offset: 2px; }
    @media (prefers-reduced-motion: reduce) {
      *, *::before, *::after { animation-duration: .01ms !important; animation-iteration-count: 1 !important; transition-duration: .01ms !important; scroll-behavior: auto !important; }
    }

    ::-webkit-scrollbar       { width:3px; height:3px; }
    ::-webkit-scrollbar-track { background:var(--cream); }
    ::-webkit-scrollbar-thumb { background:var(--gold); }
    ::selection { background:var(--gold); color:var(--black); }

    /* ── CUSTOM CURSOR ── */
    #cur {
      position:fixed; width:5px; height:5px; border-radius:50%;
      background:var(--gold); pointer-events:none; z-index:9999;
      transform:translate(-50%,-50%);
      transition:width .2s, height .2s, opacity .2s;
      will-change:left,top; mix-blend-mode:normal;
    }
    #cur-ring {
      position:fixed; width:28px; height:28px; border-radius:50%;
      border:1px solid rgba(194,178,153,.55); pointer-events:none; z-index:9998;
      transform:translate(-50%,-50%);
      transition:left .11s ease, top .11s ease, width .3s, height .3s, opacity .3s, border-color .3s;
      opacity:1; will-change:left,top;
    }
    body:has(a:hover) #cur, body:has(button:hover) #cur { width:3px; height:3px; opacity:.6; }
    body:has(a:hover) #cur-ring, body:has(button:hover) #cur-ring { width:48px; height:48px; border-color:rgba(194,178,153,.25); }

    /* ── PROGRESS BAR ── */
    #prog {
      position:fixed; top:0; left:0; height:2px;
      background:var(--gold); z-index:10000; width:0%;
      transition:width .12s linear;
    }

    /* ── SCROLL REVEAL ── */
    .rev { opacity:0; transform:translateY(28px); transition:opacity .9s cubic-bezier(.16,1,.3,1), transform .9s cubic-bezier(.16,1,.3,1); }
    .rev.in { opacity:1; transform:translateY(0); }
    .d1{transition-delay:.10s} .d2{transition-delay:.20s} .d3{transition-delay:.30s}
    .d4{transition-delay:.40s} .d5{transition-delay:.50s} .d6{transition-delay:.60s}

    /* ── COMMON ── */
    .container { max-width:1440px; margin:0 auto; padding:0 80px; width:100%; }
    .line { height:0.5px; width:80px; background:var(--gold); }
    .line-c { margin:18px auto; }
    .lbl {
      display:inline-block; font-family:var(--sans); font-size:11px; font-weight:600;
      letter-spacing:.22em; text-transform:uppercase; color:var(--gold);
    }
    .lbl-d { color:rgba(194,178,153,.85); }

    /* ── BUTTONS ── */
    .btn {
      display:inline-flex; align-items:center; gap:10px;
      padding:16px 36px; border:none; cursor:pointer;
      font-family:var(--sans); font-size:11px; font-weight:600;
      letter-spacing:.2em; text-transform:uppercase;
      transition:all var(--t); position:relative; overflow:hidden;
      white-space:nowrap;
    }
    .btn-g {
      background:var(--gold); color:var(--black);
    }
    .btn-g:hover { background:var(--paper); color:var(--black); letter-spacing:.24em; }
    .btn-ol {
      background:transparent; color:var(--gold); border:1px solid rgba(194,178,153,.45);
    }
    .btn-ol:hover { background:var(--gold-lt); border-color:var(--gold); letter-spacing:.24em; }
    .btn-dk {
      background:var(--black); color:var(--gold); border:1px solid var(--gold);
    }
    .btn-dk:hover { background:var(--gold); color:var(--black); }
    .btn .arr { transition:transform var(--t); font-size:14px; }
    .btn:hover .arr { transform:translateX(4px); }

    /* ══════════════════════════════
       NAV
    ══════════════════════════════ */
    #nav {
      position:fixed; inset:0 0 auto; z-index:1000; padding:24px 80px;
      display:flex; align-items:center; justify-content:space-between;
      transition:background var(--t), padding var(--t), border var(--t), backdrop-filter var(--t);
    }
    #nav.on {
      background:rgba(13,13,13,.92); padding:16px 80px;
      border-bottom:1px solid rgba(194,178,153,.15);
      backdrop-filter:blur(14px);
    }
    .n-logo {
      font-family:var(--serif); font-size:28px; font-weight:500;
      letter-spacing:.06em; color:var(--paper); flex-shrink:0;
      transition:color var(--t);
    }
    .n-logo:hover { color:var(--gold); }

    .n-links { display:flex; gap:38px; list-style:none; align-items:center; }
    .n-links a {
      font-family:var(--sans); font-size:11px; font-weight:500;
      letter-spacing:.2em; text-transform:uppercase;
      color:rgba(255,255,255,.78); transition:color var(--t);
      position:relative; padding:6px 0;
    }
    .n-links a::after {
      content:''; position:absolute; bottom:0; left:50%;
      width:0; height:1px; background:var(--gold);
      transition:all var(--t); transform:translateX(-50%);
    }
    .n-links a:hover { color:var(--gold); }
    .n-links a:hover::after { width:100%; }
    .n-cta {
      font-family:var(--sans); font-size:10px; font-weight:600;
      letter-spacing:.22em; text-transform:uppercase;
      padding:11px 26px; border:1px solid rgba(194,178,153,.45);
      color:var(--gold); background:transparent;
      transition:all var(--t); cursor:pointer;
    }
    .n-cta:hover { background:var(--gold); color:var(--black); border-color:var(--gold); }

    .hbg { display:none; flex-direction:column; gap:5px; cursor:pointer; padding:6px; background:transparent; border:none; }
    .hbg span { display:block; width:24px; height:1px; background:var(--paper); transition:all .3s; }
    .hbg.open span:nth-child(1) { transform:translateY(6px) rotate(45deg); }
    .hbg.open span:nth-child(2) { opacity:0; }
    .hbg.open span:nth-child(3) { transform:translateY(-6px) rotate(-45deg); }

    .mob-menu {
      display:flex; flex-direction:column; justify-content:safe center; align-items:center;
      gap:clamp(18px, 3.6vh, 36px);
      position:fixed; inset:0; background:var(--black);
      padding:96px 32px 40px; z-index:999;
      overflow-y:auto; -webkit-overflow-scrolling:touch;
      transform:translateY(-100%); transition:transform .55s cubic-bezier(.7,0,.2,1);
      pointer-events:none;
    }
    .mob-menu.open { transform:translateY(0); pointer-events:all; }
    .mob-menu a {
      font-family:var(--serif); font-size:clamp(25px, 6.4vw, 32px); font-weight:400; font-style:italic;
      color:var(--paper); transition:color var(--t);
    }
    .mob-menu a:hover { color:var(--gold); }
    .mob-menu .mob-cta { margin-top:24px; }

    /* ══════════════════════════════
       HERO
    ══════════════════════════════ */
    #hero {
      position:relative; min-height:100vh; min-height:100svh; background:var(--black);
      display:flex; align-items:center; padding:140px 80px 100px;
      overflow:hidden;
    }
    .hero-bg-line {
      position:absolute; inset:0; pointer-events:none; opacity:.14;
    }
    .hero-grid {
      position:relative; z-index:2; width:100%; max-width:1440px; margin:0 auto;
      display:grid; grid-template-columns:1.05fr .95fr; gap:96px; align-items:center;
    }
    .hero-col { display:flex; flex-direction:column; gap:30px; }

    .ha { opacity:0; animation:fadeUp 1.1s cubic-bezier(.16,1,.3,1) forwards; }
    .ha1{animation-delay:.20s} .ha2{animation-delay:.40s} .ha3{animation-delay:.60s}
    .ha4{animation-delay:.80s} .ha5{animation-delay:1.0s}

    .hero-tag {
      display:flex; align-items:center; gap:14px;
      font-family:var(--sans); font-size:11px; font-weight:500;
      letter-spacing:.28em; text-transform:uppercase; color:var(--gold);
    }
    .hero-tag::before { content:''; width:36px; height:0.5px; background:var(--gold); }
    .hero-h1 {
      font-family:var(--serif); font-size:clamp(52px,7vw,104px);
      font-weight:400; font-style:italic; line-height:1.02;
      color:var(--paper); letter-spacing:-.015em;
    }
    .hero-h1 em { font-style:normal; color:var(--gold); }
    .hero-sub {
      font-family:var(--serif); font-size:clamp(18px,1.4vw,21px); font-weight:400;
      color:rgba(255,255,255,.74); max-width:480px; line-height:1.55;
    }
    .hero-btns { display:flex; gap:14px; flex-wrap:wrap; margin-top:8px; }
    .hero-proof {
      display:flex; gap:24px; flex-wrap:wrap; padding-top:24px;
      border-top:0.5px solid rgba(194,178,153,.2); margin-top:18px;
    }
    .hp-it { display:flex; flex-direction:column; gap:4px; }
    .hp-n { font-family:var(--serif); font-size:26px; font-weight:500; color:var(--gold); line-height:1; display:flex; align-items:center; gap:5px; }
    .hp-l { font-family:var(--sans); font-size:10px; font-weight:500; letter-spacing:.2em; text-transform:uppercase; color:rgba(255,255,255,.55); }

    .hero-ph {
      position:relative; aspect-ratio:3/4; max-width:480px; margin:0 0 0 auto;
      opacity:0; animation:fadeRight 1.3s cubic-bezier(.16,1,.3,1) .65s forwards;
    }
    .hero-ph img {
      position:relative; z-index:2; width:100%; height:100%;
      object-fit:cover; object-position:center 15%;
    }
    .hero-ph::before {
      content:''; position:absolute; inset:24px -24px -24px 24px;
      border:0.5px solid var(--gold); pointer-events:none; z-index:1;
    }
    .hero-ph::after {
      content:'EST. 2019'; position:absolute; bottom:-44px; right:0;
      font-family:var(--sans); font-size:9px; font-weight:600; letter-spacing:.4em;
      color:var(--gold); z-index:3;
    }

    .scroll-ind {
      position:absolute; bottom:32px; left:50%; transform:translateX(-50%);
      display:flex; flex-direction:column; align-items:center; gap:10px;
      opacity:0; animation:fadeUp 1s ease 1.4s forwards;
    }
    .scroll-ind span {
      font-family:var(--sans); font-size:9px; letter-spacing:.32em;
      text-transform:uppercase; color:rgba(255,255,255,.45);
    }
    .scroll-arr {
      width:1px; height:42px; background:linear-gradient(180deg, transparent 0%, var(--gold) 100%);
      animation:scrollDrop 2.4s ease-in-out infinite;
    }

    /* ── FASHION PAGE — LIGHT EDITORIAL HERO ── */
    #hero.hero-fashion { background:var(--cream); }
    .hero-fashion .hero-bg-line { opacity:.22; }
    .hero-fashion .hero-h1 { color:var(--ink); }
    .hero-fashion .hero-h1 em { color:var(--gold-text); }
    .hero-fashion .hero-sub { color:var(--ink2); }
    .hero-fashion .hero-tag { color:var(--gold-text); }
    .hero-fashion .hero-proof { border-top-color:rgba(28,27,27,.14); }
    .hero-fashion .hp-l { color:rgba(28,27,27,.55); }
    .hero-fashion .btn-ol { color:var(--ink); border-color:var(--gold-dk); }
    .hero-fashion .btn-ol:hover { background:var(--gold-lt); border-color:var(--gold-dk); }
    .hero-fashion .scroll-ind span { color:var(--ink2); }

    .hero-fashion .hero-duo {
      position:relative; aspect-ratio:4/5; width:100%; max-width:520px; margin:0 0 0 auto;
      opacity:0; animation:fadeRight 1.3s cubic-bezier(.16,1,.3,1) .65s forwards;
    }
    .hero-fashion .hero-duo::before {
      content:''; position:absolute; top:-18px; left:-18px;
      width:66%; height:80%; border:0.5px solid var(--gold-dk);
      z-index:1; pointer-events:none;
    }
    .hero-frame { position:absolute; overflow:hidden; }
    .hero-frame img { width:100%; height:100%; object-fit:cover; display:block; }
    .hero-frame-a { top:0; left:0; width:66%; height:80%; z-index:2; }
    .hero-frame-b {
      bottom:0; right:0; width:54%; height:62%; z-index:3;
      border:7px solid var(--cream); box-shadow:0 24px 60px rgba(0,0,0,.18);
    }
    .hero-fashion .hero-est {
      position:absolute; left:2px; bottom:5%; z-index:4;
      font-family:var(--sans); font-size:9px; font-weight:600;
      letter-spacing:.4em; color:var(--gold-text);
    }

    /* ── MARQUEE ── */
    .marquee {
      overflow:hidden; background:var(--gold); padding:15px 0;
      border-top:1px solid var(--gold-dk); border-bottom:1px solid var(--gold-dk);
    }
    .marquee-in { display:flex; width:max-content; animation:marqueeScroll 38s linear infinite; }
    .marquee-in span {
      font-family:var(--sans); font-size:11px; font-weight:600;
      letter-spacing:.34em; text-transform:uppercase;
      color:var(--black); white-space:nowrap;
    }
    .marquee-in .dot { color:rgba(13,13,13,.35); margin:0 24px; }

    /* Brand collaboration logos marquee */
    .logos-band {
      background:var(--cream);
      border-top:1px solid var(--gold-line);
      border-bottom:1px solid var(--gold-line);
      padding:38px 0 30px;
    }
    .logos-band-hd { text-align:center; margin-bottom:24px; }
    .logos-band-hd .lbl {
      font-family:var(--sans); font-size:10px; font-weight:600;
      letter-spacing:.34em; text-transform:uppercase;
      color:var(--gold-dk);
    }
    .logos-marquee {
      overflow:hidden; display:flex; width:100%;
      mask-image:linear-gradient(90deg, transparent 0, #000 80px, #000 calc(100% - 80px), transparent 100%);
      -webkit-mask-image:linear-gradient(90deg, transparent 0, #000 80px, #000 calc(100% - 80px), transparent 100%);
    }
    .logos-track {
      display:flex; align-items:center; gap:64px;
      padding-right:64px;
      animation:logosScroll 60s linear infinite;
      flex-shrink:0;
    }
    .logos-track img {
      height:32px; width:auto; max-width:140px;
      object-fit:contain;
      opacity:.9;
      transition:opacity .3s var(--t), transform .3s var(--t);
    }
    .logos-track img:hover { opacity:1; transform:scale(1.05); }
    .logos-marquee:hover .logos-track { animation-play-state:paused; }
    @keyframes logosScroll {
      from { transform:translateX(0); }
      to { transform:translateX(-100%); }
    }
    @media (max-width:600px) {
      .logos-band { padding:28px 0 22px; }
      .logos-track { gap:44px; padding-right:44px; }
      .logos-track img { height:24px; max-width:110px; }
    }
    @media (prefers-reduced-motion: reduce) {
      .logos-track { animation-duration:0s; }
    }

    /* ══════════════════════════════
       WORLDS — Fashion / Beauty
    ══════════════════════════════ */
    #worlds { padding:160px 80px 140px; background:var(--cream); }
    .worlds-hd { text-align:center; margin-bottom:80px; }
    .worlds-t {
      font-family:var(--serif); font-size:clamp(40px,5vw,72px);
      font-weight:400; font-style:italic; line-height:1.05;
      color:var(--black); letter-spacing:-.01em;
    }
    .worlds-grid {
      max-width:1440px; margin:0 auto;
      display:grid; grid-template-columns:1fr 1fr; gap:28px;
    }
    .wc {
      position:relative; aspect-ratio:4/5; overflow:hidden; cursor:pointer;
      background:var(--black);
    }
    .wc img {
      position:absolute; inset:0; width:100%; height:100%;
      object-fit:cover; transition:transform 1.2s cubic-bezier(.16,1,.3,1);
    }
    .wc:hover img { transform:scale(1.06); }
    .wc::after {
      content:''; position:absolute; inset:0;
      background:linear-gradient(180deg, rgba(0,0,0,0) 40%, rgba(13,13,13,.88) 100%);
      transition:opacity var(--t);
    }
    .wc-cont {
      position:absolute; inset:auto 0 0 0; z-index:2;
      padding:40px 44px;
    }
    .wc-tag {
      font-family:var(--sans); font-size:10px; font-weight:600;
      letter-spacing:.32em; text-transform:uppercase; color:var(--gold);
      margin-bottom:12px; display:block;
    }
    .wc-title {
      font-family:var(--serif); font-size:clamp(36px,3.8vw,56px);
      font-weight:400; font-style:italic; color:var(--paper); line-height:1.05;
      margin-bottom:14px;
    }
    .wc-desc {
      font-family:var(--sans); font-size:14px; font-weight:300; line-height:1.65;
      color:rgba(255,255,255,.78); max-width:340px; margin-bottom:20px;
    }
    .wc-link {
      display:inline-flex; align-items:center; gap:10px;
      font-family:var(--sans); font-size:11px; font-weight:600;
      letter-spacing:.22em; text-transform:uppercase; color:var(--gold);
      border-bottom:0.5px solid var(--gold); padding-bottom:4px;
      transition:gap var(--t);
    }
    .wc:hover .wc-link { gap:18px; }

    .worlds-hint {
      text-align:center; margin-top:64px;
      font-family:var(--serif); font-size:17px; font-style:italic;
      color:var(--ink2);
    }
    .worlds-hint a {
      color:var(--black); border-bottom:0.5px solid var(--gold);
      padding-bottom:2px; margin-left:6px; font-style:normal;
      font-family:var(--sans); font-size:11px; font-weight:600;
      letter-spacing:.2em; text-transform:uppercase;
      transition:color var(--t);
    }
    .worlds-hint a:hover { color:var(--gold); }

    /* ══════════════════════════════
       SERVICES
    ══════════════════════════════ */
    #services { padding:160px 80px; background:var(--bone); }
    .svc-hd { margin-bottom:72px; max-width:1280px; margin-left:auto; margin-right:auto; display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:end; }
    .svc-h2 {
      font-family:var(--serif); font-size:clamp(40px,5vw,72px);
      font-weight:400; font-style:italic; line-height:1.05; color:var(--black);
    }
    .svc-intro { font-family:var(--serif); font-size:18px; color:var(--ink2); line-height:1.65; max-width:420px; }

    /* LIST LAYOUT — all services visible, no sideways scroll */
    .svc-list {
      max-width:1280px; margin:0 auto;
      border-top:0.5px solid rgba(194,178,153,.35);
    }
    .sc {
      display:grid; grid-template-columns:64px 1fr auto;
      gap:0 40px; align-items:center;
      padding:36px 0; position:relative;
      border-bottom:0.5px solid rgba(194,178,153,.2);
      transition:background var(--t);
    }
    .sc::before {
      content:''; position:absolute; inset:0;
      background:var(--cream); opacity:0; transition:opacity var(--t);
      z-index:0; margin:0 -80px;
    }
    .sc:hover::before { opacity:1; }
    .sc > * { position:relative; z-index:1; }
    .sc-num {
      font-family:var(--serif); font-size:12px; font-style:italic;
      color:rgba(155,142,120,.55); letter-spacing:.06em;
    }
    .sc-mid { display:flex; flex-direction:column; gap:5px; }
    .sc-tag {
      font-family:var(--sans); font-size:9px; font-weight:700;
      letter-spacing:.22em; text-transform:uppercase; color:var(--gold-dk);
    }
    .sc-name {
      font-family:var(--serif); font-size:clamp(19px,2vw,26px);
      font-weight:400; line-height:1.15; color:var(--black);
    }
    .sc-desc {
      font-family:var(--sans); font-size:12px; font-weight:300;
      color:var(--ink2); line-height:1.65; max-width:540px; margin-top:3px;
    }
    .sc-right { display:flex; align-items:center; gap:22px; flex-shrink:0; }
    .sc-price {
      font-family:var(--serif); font-size:22px; font-weight:400;
      color:var(--black); white-space:nowrap; text-align:right;
    }
    .sc-price span {
      font-size:10px; font-family:var(--sans); font-weight:600;
      letter-spacing:.16em; color:var(--gold-dk); text-transform:uppercase;
      margin-right:5px;
    }
    .sc-price.free { color:var(--gold); font-style:italic; }
    .sc-arr {
      width:40px; height:40px; border:0.5px solid rgba(194,178,153,.4);
      display:flex; align-items:center; justify-content:center; color:var(--gold);
      transition:all var(--t); font-size:14px; flex-shrink:0;
    }
    .sc:hover .sc-arr { background:var(--gold); color:var(--black); border-color:var(--gold); }
    .svc-cta { text-align:center; margin-top:64px; max-width:1280px; margin-left:auto; margin-right:auto; }

    /* ══════════════════════════════
       QUIZ
    ══════════════════════════════ */
    #quiz { padding:160px 80px; background:var(--black); color:var(--paper); position:relative; overflow:hidden; }
    .quiz-bg {
      position:absolute; top:50%; left:50%; transform:translate(-50%,-50%) rotate(-4deg);
      font-family:var(--serif); font-size:clamp(120px,18vw,300px); font-style:italic; font-weight:500;
      color:rgba(194,178,153,.04); white-space:nowrap; pointer-events:none; user-select:none;
    }
    .quiz-in { position:relative; z-index:2; max-width:780px; margin:0 auto; text-align:center; }
    .quiz-h2 {
      font-family:var(--serif); font-size:clamp(40px,5vw,68px); font-weight:400;
      font-style:italic; margin:14px 0 16px; color:var(--paper);
    }
    .quiz-sub { font-family:var(--serif); font-size:17px; color:rgba(255,255,255,.6); margin-bottom:56px; }

    .qdots { display:flex; justify-content:center; align-items:center; gap:14px; margin-bottom:56px; }
    .qd {
      width:36px; height:36px; border-radius:50%;
      border:0.5px solid rgba(194,178,153,.35);
      display:flex; align-items:center; justify-content:center;
      font-family:var(--serif); font-size:13px; font-style:italic;
      color:rgba(255,255,255,.4); transition:all var(--t);
    }
    .qd.active { background:var(--gold); border-color:var(--gold); color:var(--black); font-style:normal; font-weight:500; }
    .qd.done { background:transparent; border-color:var(--gold); color:var(--gold); }
    .qd-line { width:42px; height:0.5px; background:rgba(194,178,153,.25); }

    .qs-wrap { position:relative; }
    .qs { display:none; animation:slideIn .5s cubic-bezier(.16,1,.3,1); }
    .qs.active { display:block; }
    .qs.exit { animation:slideOut .35s cubic-bezier(.4,0,.2,1) forwards; }

    .qq {
      font-family:var(--serif); font-size:clamp(24px,2.6vw,34px); font-weight:400;
      font-style:italic; margin-bottom:44px; color:var(--paper); line-height:1.3;
    }
    .qopts { display:grid; grid-template-columns:1fr 1fr; gap:14px; text-align:left; }
    .qo {
      padding:24px 28px; border:0.5px solid rgba(194,178,153,.22);
      background:transparent; cursor:pointer;
      font-family:var(--serif); font-size:18px; font-weight:400;
      color:rgba(255,255,255,.82); line-height:1.4;
      transition:all var(--t); position:relative;
      text-align:left; width:100%; display:block;
    }
    .qo:hover { border-color:var(--gold); background:rgba(194,178,153,.06); color:var(--paper); }
    .qo.sel { border-color:var(--gold); background:var(--gold-lt); color:var(--gold); }

    #qres { display:none; animation:fadeIn .7s ease; }
    #qres.show { display:block; }
    .r-badge {
      display:inline-block; padding:8px 22px; margin-bottom:30px;
      border:0.5px solid var(--gold); color:var(--gold);
      font-family:var(--sans); font-size:10px; font-weight:600;
      letter-spacing:.28em; text-transform:uppercase;
    }
    .r-title {
      font-family:var(--serif); font-size:clamp(56px,7vw,96px); font-weight:400;
      font-style:italic; margin-bottom:24px; color:var(--gold); line-height:1.05;
    }
    .r-desc {
      font-family:var(--serif); font-size:19px; color:rgba(255,255,255,.78);
      line-height:1.65; max-width:560px; margin:0 auto 18px;
    }
    .r-rec {
      font-family:var(--sans); font-size:12px; font-weight:500;
      letter-spacing:.18em; text-transform:uppercase; color:var(--gold);
      margin-bottom:40px;
    }
    .r-btns { display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }
    .q-retry {
      background:none; border:none; cursor:pointer;
      font-family:var(--sans); font-size:11px; font-weight:500;
      letter-spacing:.2em; text-transform:uppercase;
      color:rgba(255,255,255,.5); border-bottom:0.5px solid rgba(255,255,255,.2);
      padding-bottom:3px; margin-top:32px;
      transition:all var(--t);
    }
    .q-retry:hover { color:var(--gold); border-color:var(--gold); }

    /* ══════════════════════════════
       TIPS — horizontal scroll
    ══════════════════════════════ */
    #tips { padding:160px 0 160px 80px; background:var(--cream); overflow:hidden; }
    .tips-hd {
      display:flex; justify-content:space-between; align-items:flex-end;
      max-width:1360px; margin-bottom:60px; gap:24px; flex-wrap:wrap;
      padding-right:80px;
    }
    .tips-h2 { font-family:var(--serif); font-size:clamp(40px,5vw,72px); font-weight:400; font-style:italic; color:var(--black); line-height:1.05; }
    .tips-sub { font-family:var(--serif); font-size:17px; color:var(--ink2); max-width:360px; line-height:1.55; }
    .tips-nav { display:flex; gap:10px; }
    .t-arr {
      width:48px; height:48px; border:0.5px solid var(--gold);
      background:transparent; color:var(--gold); font-size:18px;
      display:flex; align-items:center; justify-content:center;
      transition:all var(--t);
    }
    .t-arr:hover { background:var(--gold); color:var(--black); }

    .tips-row {
      display:flex; gap:24px; overflow-x:auto; padding-right:80px; padding-bottom:8px;
      scroll-snap-type:x mandatory; scrollbar-width:none; -ms-overflow-style:none;
    }
    .tips-row::-webkit-scrollbar { display:none; }
    .tc {
      flex:0 0 380px; scroll-snap-align:start;
      display:flex; flex-direction:column;
    }
    .tc-ph {
      aspect-ratio:4/5; overflow:hidden; position:relative; background:var(--bone);
      margin-bottom:22px;
    }
    .tc-ph img {
      width:100%; height:100%; object-fit:cover;
      filter:grayscale(.4) contrast(1.02);
      transition:filter .8s ease, transform 1.1s cubic-bezier(.16,1,.3,1);
    }
    .tc:hover .tc-ph img { filter:grayscale(0); transform:scale(1.04); }
    .tc-tag {
      font-family:var(--sans); font-size:10px; font-weight:600;
      letter-spacing:.28em; text-transform:uppercase; color:var(--gold-dk);
      margin-bottom:10px;
    }
    .tc-name {
      font-family:var(--serif); font-size:24px; font-weight:500;
      line-height:1.25; color:var(--black); margin-bottom:10px;
    }
    .tc-tip { font-family:var(--sans); font-size:13px; font-weight:400; color:var(--ink2); line-height:1.65; margin-bottom:14px; }
    .tc-link {
      font-family:var(--sans); font-size:11px; font-weight:600;
      letter-spacing:.18em; text-transform:uppercase; color:var(--black);
      border-bottom:0.5px solid var(--gold); padding-bottom:3px;
      align-self:flex-start; transition:all var(--t);
    }
    .tc-link:hover { color:var(--gold); }

    /* Shoppable items inside tip card */
    .tc-shop {
      margin-top:auto; padding-top:14px;
      border-top:0.5px solid var(--gold-line);
      display:flex; flex-direction:column; gap:6px;
    }
    .tc-shop-lbl {
      font-family:var(--sans); font-size:9px; font-weight:600;
      letter-spacing:.34em; text-transform:uppercase;
      color:var(--gold-dk);
      margin-bottom:4px;
    }
    .tc-shop-item {
      display:flex; align-items:baseline; gap:10px;
      padding:9px 12px;
      background:var(--bone);
      border:0.5px solid transparent;
      text-decoration:none;
      transition:border-color var(--t), background var(--t), transform var(--t);
    }
    .tc-shop-item:hover {
      border-color:var(--gold);
      background:var(--cream);
      transform:translateX(2px);
    }
    .tc-shop-brand {
      font-family:var(--sans); font-size:10px; font-weight:700;
      letter-spacing:.18em; text-transform:uppercase;
      color:var(--black);
      flex-shrink:0;
    }
    .tc-shop-prod {
      font-family:var(--sans); font-size:13px; font-weight:400;
      color:var(--ink2);
      flex:1;
      overflow:hidden; text-overflow:ellipsis; white-space:nowrap;
    }
    .tc-shop-arr {
      font-size:12px; color:var(--gold-dk);
      flex-shrink:0;
      transition:transform var(--t);
    }
    .tc-shop-item:hover .tc-shop-arr {
      transform:translate(2px, -2px);
      color:var(--black);
    }

    /* ══════════════════════════════
       PRODUCTS
    ══════════════════════════════ */
    /* ══ PRODUCTS SECTION ══ */
    #products { padding:140px 80px; background:var(--black); position:relative; overflow:hidden; }
    #products::before {
      content:''; position:absolute; inset:0;
      background:radial-gradient(ellipse 80% 60% at 50% 0%, rgba(194,178,153,.07) 0%, transparent 70%);
      pointer-events:none;
    }
    .prod-in { max-width:1400px; margin:0 auto; position:relative; z-index:1; }
    .prod-hd { text-align:center; margin-bottom:100px; }
    .prod-hd-eyebrow {
      display:inline-flex; align-items:center; gap:14px; margin-bottom:24px;
    }
    .prod-hd-eyebrow .line { background:rgba(194,178,153,.4); }
    .prod-h2 {
      font-family:var(--serif); font-size:clamp(48px,6vw,88px);
      font-weight:300; font-style:italic; color:var(--paper);
      line-height:1.0; margin-top:0; letter-spacing:-.02em;
    }
    .prod-h2 em { color:var(--gold); font-style:italic; }
    .prod-sub {
      font-family:var(--sans); font-size:15px; font-weight:300;
      color:rgba(255,255,255,.5); margin-top:20px; max-width:480px;
      margin-left:auto; margin-right:auto; line-height:1.7; letter-spacing:.02em;
    }

    /* FREE EBOOK CARDS */
    .prod-grid { display:grid; grid-template-columns:1fr 1fr; gap:2px; }
    .pc {
      padding:64px 56px 56px; position:relative; overflow:hidden;
      display:flex; flex-direction:column;
      transition:transform .6s cubic-bezier(.16,1,.3,1);
      min-height:560px;
    }
    .pc:hover { transform:translateY(-5px); }
    .pc-num {
      position:absolute; top:-20px; right:40px;
      font-family:var(--serif); font-size:180px; font-weight:300;
      line-height:1; font-style:italic; letter-spacing:-.05em;
      opacity:.06; pointer-events:none; user-select:none;
    }
    .pc-free { background:var(--espresso); color:var(--paper); }
    .pc-free:first-child { background:#1a1714; }
    .pc-paid { background:var(--black); color:var(--paper); position:relative; }
    .pc-badge {
      display:inline-flex; align-items:center; gap:8px;
      padding:7px 16px; margin-bottom:36px;
      font-family:var(--sans); font-size:9px; font-weight:700;
      letter-spacing:.28em; text-transform:uppercase; width:fit-content;
    }
    .badge-f { background:var(--gold); color:var(--black); }
    .badge-p { border:0.5px solid var(--gold); color:var(--gold); }
    .pc-title {
      font-family:var(--serif); font-size:clamp(26px,2.4vw,38px);
      font-weight:400; line-height:1.15; margin-bottom:20px; color:var(--paper);
    }
    .pc-desc {
      font-family:var(--sans); font-size:14px; font-weight:300;
      line-height:1.75; margin-bottom:40px; flex:1;
      color:rgba(255,255,255,.55); letter-spacing:.01em;
    }
    .pc-form { display:flex; gap:0; }
    .pc-inp {
      flex:1; padding:17px 20px; background:rgba(255,255,255,.06);
      border:0.5px solid rgba(194,178,153,.25); border-right:none;
      font-family:var(--sans); font-size:13px; color:var(--paper);
      outline:none; transition:border-color var(--t);
    }
    .pc-inp:focus { border-color:var(--gold); }
    .pc-inp::placeholder { color:rgba(255,255,255,.3); }
    .pc-ok {
      display:none; margin-top:16px; padding:12px 16px;
      background:rgba(194,178,153,.1); font-family:var(--sans);
      font-size:12px; color:var(--gold); border:0.5px solid rgba(194,178,153,.25);
    }

    /* PAID EBOOK CARDS — BIG EDITORIAL */
    .eb-grid {
      display:grid; grid-template-columns:1fr 1fr; gap:2px;
      margin-top:2px;
    }
    .eb-card {
      display:grid; grid-template-columns:280px 1fr;
      background:var(--espresso); position:relative; overflow:hidden;
      transition:transform .6s cubic-bezier(.16,1,.3,1);
      text-decoration:none; min-height:460px;
      border:none; text-align:left; font:inherit; cursor:pointer;
      width:100%; color:inherit; padding:0;
    }
    .eb-card:hover { transform:translateY(-5px); }
    .eb-card:disabled { opacity:.7; cursor:wait; }
    .eb-card:first-child { background:#1a1714; }
    .eb-cover {
      position:relative; overflow:hidden; flex-shrink:0;
    }
    .eb-cover img {
      width:100%; height:100%; object-fit:cover;
      filter:brightness(.75) saturate(.6);
      transition:transform .8s cubic-bezier(.16,1,.3,1), filter .6s;
    }
    .eb-card:hover .eb-cover img {
      transform:scale(1.05); filter:brightness(.85) saturate(.7);
    }
    .eb-cover-overlay {
      position:absolute; inset:0;
      background:linear-gradient(to right, transparent 60%, var(--espresso));
    }
    .eb-card:first-child .eb-cover-overlay { background:linear-gradient(to right, transparent 60%, #1a1714); }
    .eb-price-tag {
      position:absolute; top:24px; left:20px;
      background:var(--gold); color:var(--black);
      font-family:var(--sans); font-size:11px; font-weight:700;
      letter-spacing:.18em; text-transform:uppercase;
      padding:8px 16px;
    }
    .eb-body {
      padding:52px 48px; display:flex; flex-direction:column; justify-content:center;
    }
    .eb-cat {
      font-family:var(--sans); font-size:9px; font-weight:700;
      letter-spacing:.28em; text-transform:uppercase;
      color:var(--gold); margin-bottom:16px; display:block;
    }
    .eb-title {
      font-family:var(--serif); font-size:clamp(22px,2vw,32px);
      font-weight:400; color:var(--paper); line-height:1.2;
      margin-bottom:18px;
    }
    .eb-desc {
      font-family:var(--sans); font-size:13px; font-weight:300;
      color:rgba(255,255,255,.5); line-height:1.75; margin-bottom:32px; flex:1;
    }
    .eb-features {
      list-style:none; display:flex; flex-wrap:wrap; gap:8px 20px;
      margin-bottom:32px;
    }
    .eb-features li {
      font-family:var(--sans); font-size:10px; font-weight:600;
      letter-spacing:.15em; text-transform:uppercase;
      color:rgba(255,255,255,.35); display:flex; align-items:center; gap:6px;
    }
    .eb-features li::before { content:''; width:4px; height:4px; border-radius:50%; background:var(--gold); opacity:.6; }
    .eb-price-lg {
      font-family:var(--serif); font-size:54px; font-weight:300;
      font-style:italic; color:var(--gold); line-height:1;
      margin-bottom:28px; letter-spacing:-.02em;
    }
    .eb-btn {
      display:inline-flex; align-items:center; gap:10px;
      padding:15px 32px; background:var(--gold); color:var(--black);
      font-family:var(--sans); font-size:10px; font-weight:700;
      letter-spacing:.2em; text-transform:uppercase; border:none;
      cursor:pointer; text-decoration:none; width:fit-content;
      transition:background var(--t), transform .3s;
    }
    .eb-btn:hover { background:var(--paper); transform:translateY(-2px); }

    @media (max-width:1100px) {
      .eb-card { grid-template-columns:220px 1fr; }
      .eb-body { padding:40px 36px; }
    }

    /* ══════════════════════════════
       ABOUT
    ══════════════════════════════ */
    #about { padding:160px 80px; background:var(--cream); }
    .about-in { max-width:1440px; margin:0 auto; display:grid; grid-template-columns:1fr 1.1fr; gap:96px; align-items:center; }
    .about-ph { position:relative; }
    .about-ph img {
      width:100%; aspect-ratio:4/5; object-fit:cover; object-position:center 20%;
    }
    .about-ph::before {
      content:''; position:absolute; inset:-24px 24px 24px -24px;
      border:0.5px solid var(--gold); z-index:0; pointer-events:none;
    }
    .about-sig {
      position:absolute; bottom:-30px; right:24px;
      font-family:var(--serif); font-size:48px; font-style:italic; color:var(--gold);
      transform:rotate(-6deg); z-index:3;
    }
    .about-h2 {
      font-family:var(--serif); font-size:clamp(40px,5vw,68px); font-weight:400;
      font-style:italic; line-height:1.05; color:var(--black); margin:18px 0 30px;
    }
    .about-bio { font-family:var(--serif); font-size:19px; color:var(--ink2); line-height:1.65; margin-bottom:24px; }
    .about-bio strong { color:var(--black); font-weight:500; }
    .about-stats { display:grid; grid-template-columns:repeat(4,1fr); gap:24px; margin-top:48px; padding-top:42px; border-top:0.5px solid var(--gold-line); }
    .as-it { display:flex; flex-direction:column; gap:6px; }
    .as-n { font-family:var(--serif); font-size:48px; font-weight:500; color:var(--gold); line-height:1; font-style:italic; }
    .as-l { font-family:var(--sans); font-size:10px; font-weight:600; letter-spacing:.24em; text-transform:uppercase; color:var(--ink2); }

    .socs { display:flex; gap:12px; margin-top:42px; flex-wrap:wrap; }
    .soc {
      display:flex; align-items:center; gap:10px; padding:12px 20px;
      border:0.5px solid var(--gold-line); transition:all var(--t); cursor:pointer;
    }
    .soc:hover { border-color:var(--gold); background:var(--gold-lt); }
    .soc svg { color:var(--gold); }
    .soc-name { font-family:var(--sans); font-size:11px; font-weight:600; letter-spacing:.18em; text-transform:uppercase; color:var(--ink); }

    /* ══════════════════════════════
       INSTAGRAM
    ══════════════════════════════ */
    #gram { padding:160px 80px; background:var(--black); color:var(--paper); position:relative; overflow:hidden; }
    .gram-bg-txt {
      position:absolute; top:50%; left:50%; transform:translate(-50%,-50%) rotate(-6deg);
      font-family:var(--serif); font-size:clamp(120px,16vw,260px);
      font-style:italic; font-weight:500;
      color:rgba(194,178,153,.04); white-space:nowrap;
      pointer-events:none; user-select:none; letter-spacing:-.02em; z-index:0;
    }
    .gram-in { position:relative; z-index:2; max-width:1440px; margin:0 auto; }
    .gram-hd {
      display:flex; justify-content:space-between; align-items:flex-end;
      margin-bottom:64px; gap:32px; flex-wrap:wrap;
    }
    .gram-h2 { font-family:var(--serif); font-size:clamp(40px,5vw,72px); font-weight:400; font-style:italic; color:var(--paper); margin-top:14px; line-height:1.05; }
    .gram-sub { font-family:var(--serif); font-size:17px; color:rgba(255,255,255,.6); max-width:340px; line-height:1.55; padding-bottom:8px; }
    /* ── Instagram profile card ── */
    .ig-prof {
      display:flex; align-items:center; gap:24px;
      background:rgba(255,255,255,.04); border:0.5px solid rgba(194,178,153,.15);
      padding:24px 32px; margin-bottom:28px; flex-wrap:wrap;
    }
    .ig-prof-av {
      width:56px; height:56px; border-radius:50%; overflow:hidden; flex-shrink:0;
      background:linear-gradient(45deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888);
      padding:2.5px;
    }
    .ig-prof-av img { width:100%; height:100%; object-fit:cover; border-radius:50%; display:block; }
    .ig-prof-info { flex:1; min-width:0; }
    .ig-prof-handle {
      display:flex; align-items:center; gap:8px;
      font-family:var(--sans); font-size:14px; font-weight:600; color:var(--paper);
      letter-spacing:.03em; margin-bottom:8px;
    }
    .ig-prof-handle svg { opacity:.8; }
    .ig-prof-stats {
      display:flex; gap:20px; flex-wrap:wrap;
      font-family:var(--sans); font-size:11px; color:rgba(255,255,255,.55);
    }
    .ig-prof-stats strong { color:var(--paper); font-weight:600; }
    .ig-follow {
      display:inline-flex; align-items:center; gap:8px;
      font-family:var(--sans); font-size:11px; font-weight:700; letter-spacing:.14em;
      text-transform:uppercase; color:var(--black);
      background:var(--gold); padding:10px 22px;
      transition:background var(--t), color var(--t);
    }
    .ig-follow:hover { background:var(--gold-dk); }

    /* ── Instagram 3×3 grid ── */
    .ig-grid {
      display:grid; grid-template-columns:repeat(3,1fr);
      gap:3px; margin-bottom:60px;
    }
    .ig-post {
      position:relative; overflow:hidden; aspect-ratio:1;
      background:var(--black-2); display:block;
    }
    .ig-post img {
      position:absolute; inset:0; width:100%; height:100%;
      object-fit:cover;
      transition:transform .8s cubic-bezier(.16,1,.3,1), filter .4s;
    }
    .ig-post:hover img { transform:scale(1.06); filter:brightness(.75); }
    .ig-post-ov {
      position:absolute; inset:0;
      display:flex; flex-direction:column; align-items:center; justify-content:center; gap:8px;
      background:rgba(13,13,13,.45);
      opacity:0; transition:opacity .35s ease;
    }
    .ig-post:hover .ig-post-ov { opacity:1; }
    .ig-post-ov svg { filter:drop-shadow(0 1px 4px rgba(0,0,0,.4)); }
    .ig-post-lbl {
      font-family:var(--sans); font-size:9px; font-weight:700;
      letter-spacing:.2em; text-transform:uppercase; color:#fff;
    }
    /* reel badge in top-right corner */
    .ig-reel-ic {
      position:absolute; top:10px; right:10px;
      color:#fff; opacity:.9;
    }

    .gram-foot { text-align:center; }
    .gram-fl {
      display:inline-flex; align-items:center; gap:16px;
      font-family:var(--serif); font-size:clamp(28px,3.4vw,48px);
      font-weight:400; font-style:italic; color:var(--paper);
      padding-bottom:10px; border-bottom:0.5px solid rgba(194,178,153,.3);
      transition:all var(--t);
    }
    .gram-fl:hover { color:var(--gold); border-color:var(--gold); }
    .gram-fl .arr { font-style:normal; font-family:var(--sans); font-size:18px; transition:transform .3s; }
    .gram-fl:hover .arr { transform:translateX(6px); }

    /* ══════════════════════════════
       CONTACT
    ══════════════════════════════ */
    #contact { padding:160px 80px; background:var(--bone); }
    .con-in { max-width:1100px; margin:0 auto; text-align:center; }
    .con-h2 {
      font-family:var(--serif); font-size:clamp(46px,6vw,88px); font-weight:400;
      font-style:italic; line-height:1.02; color:var(--black); margin:18px 0 22px;
    }
    .con-sub { font-family:var(--serif); font-size:19px; color:var(--ink2); max-width:520px; margin:0 auto 64px; line-height:1.55; }
    .bform { display:grid; grid-template-columns:1fr 1fr; gap:36px; text-align:left; }
    .fg { display:flex; flex-direction:column; }
    .fg.full { grid-column:1/-1; }
    .fg label {
      font-family:var(--sans); font-size:10px; font-weight:600;
      letter-spacing:.24em; text-transform:uppercase; color:var(--gold-dk);
      margin-bottom:12px;
    }
    .fi {
      background:transparent; border:none; border-bottom:0.5px solid var(--gold-line);
      padding:14px 0; font-family:var(--serif); font-size:18px;
      color:var(--black); outline:none; width:100%; transition:border-color var(--t);
    }
    .fi:focus { border-bottom-color:var(--gold); }
    .fi::placeholder { color:rgba(28,27,27,.34); font-style:italic; }
    .fi option { background:var(--cream); color:var(--black); }
    textarea.fi { resize:none; min-height:110px; font-family:var(--serif); padding-top:14px; }
    .frow { grid-column:1/-1; display:flex; justify-content:center; align-items:center; gap:24px; flex-wrap:wrap; padding-top:24px; }
    .fok { display:none; font-family:var(--sans); font-size:13px; color:var(--gold-dk); font-style:italic; }

    .con-info {
      display:grid; grid-template-columns:repeat(4,1fr); gap:32px;
      margin-top:80px; padding-top:64px; border-top:0.5px solid var(--gold-line);
      text-align:left;
    }
    .ci-l { font-family:var(--sans); font-size:10px; font-weight:600; letter-spacing:.24em; text-transform:uppercase; color:var(--gold-dk); margin-bottom:10px; }
    .ci-v { font-family:var(--serif); font-size:18px; color:var(--black); }
    .ci-v a { border-bottom:0.5px solid transparent; transition:border-color var(--t); }
    .ci-v a:hover { border-bottom-color:var(--gold); }

    /* ══════════════════════════════
       NEWSLETTER
    ══════════════════════════════ */
    .nl { background:var(--black); padding:96px 80px; text-align:center; color:var(--paper); position:relative; overflow:hidden; }
    .nl-in { max-width:640px; margin:0 auto; position:relative; z-index:2; }
    .nl-h { font-family:var(--serif); font-size:clamp(32px,4vw,52px); font-weight:400; font-style:italic; color:var(--paper); margin:14px 0 16px; line-height:1.1; }
    .nl-sub { font-family:var(--serif); font-size:17px; color:rgba(255,255,255,.65); margin-bottom:40px; }
    .nl-form { display:flex; max-width:440px; margin:0 auto; }
    .nl-inp {
      flex:1; padding:16px 20px;
      border:0.5px solid rgba(194,178,153,.35); border-right:none;
      background:rgba(255,255,255,.04); font-family:var(--sans); font-size:13px;
      color:var(--paper); outline:none; transition:border-color var(--t);
    }
    .nl-inp:focus { border-color:var(--gold); }
    .nl-inp::placeholder { color:rgba(255,255,255,.4); }
    .nl-ok { display:none; margin-top:18px; font-family:var(--sans); font-size:12px; letter-spacing:.18em; color:var(--gold); text-transform:uppercase; }

    /* ══════════════════════════════
       FOOTER
    ══════════════════════════════ */
    footer { background:var(--black); border-top:0.5px solid rgba(194,178,153,.12); padding:64px 80px 40px; color:var(--paper); }
    .ft-grid { max-width:1440px; margin:0 auto; display:grid; grid-template-columns:1.5fr repeat(5, 1fr); gap:40px; padding-bottom:56px; border-bottom:0.5px solid rgba(194,178,153,.1); }
    .ft-col h4 { font-family:var(--sans); font-size:10px; font-weight:600; letter-spacing:.28em; text-transform:uppercase; color:var(--gold); margin-bottom:24px; }
    .ft-col ul { list-style:none; display:flex; flex-direction:column; gap:14px; }
    .ft-col a { font-family:var(--sans); font-size:13px; color:rgba(255,255,255,.55); transition:color var(--t); }
    .ft-col a:hover { color:var(--gold); }
    .ft-brand .ft-logo { font-family:var(--serif); font-size:36px; font-weight:500; color:var(--paper); margin-bottom:18px; display:block; }
    .ft-brand p { font-family:var(--serif); font-size:16px; color:rgba(255,255,255,.6); line-height:1.55; max-width:340px; font-style:italic; }
    .ft-bot { max-width:1440px; margin:32px auto 0; display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:18px; }
    .ft-cp { font-family:var(--sans); font-size:11px; color:rgba(255,255,255,.32); letter-spacing:.08em; }
    .ft-soc { display:flex; gap:18px; flex-wrap:wrap; }
    .ft-soc a, .ft-soc .ft-link-btn { font-family:var(--sans); font-size:10px; font-weight:600; letter-spacing:.28em; text-transform:uppercase; color:rgba(255,255,255,.4); transition:color var(--t); background:none; border:none; padding:0; cursor:pointer;}
    .ft-soc a:hover, .ft-soc .ft-link-btn:hover { color:var(--gold); }
    .ft-soc .ft-link-btn { font-family:var(--sans); font-size:10px; font-weight:600; letter-spacing:.28em; text-transform:uppercase; }

    /* ── COOKIE ── */
    #ck {
      position:fixed; inset:auto 24px 24px 24px; z-index:2000; max-width:520px; margin-left:auto;
      background:var(--black); border:0.5px solid var(--gold-line);
      padding:22px 26px; display:flex; flex-direction:column; gap:14px;
      backdrop-filter:blur(8px);
      transform:translateY(120%); opacity:0;
      transition:all .6s cubic-bezier(.16,1,.3,1);
    }
    #ck.show { transform:translateY(0); opacity:1; }
    .ck-txt { font-family:var(--sans); font-size:12px; color:rgba(255,255,255,.7); line-height:1.5; }
    .ck-txt a { color:var(--gold); border-bottom:0.5px solid var(--gold); }
    .ck-actions { display:flex; gap:10px; }
    .ck-btn { padding:10px 22px; font-family:var(--sans); font-size:10px; font-weight:600; letter-spacing:.22em; text-transform:uppercase; cursor:pointer; border:none; transition:all var(--t); }
    .ck-y { background:var(--gold); color:var(--black); }
    .ck-y:hover { background:var(--paper); }
    .ck-n { background:transparent; color:rgba(255,255,255,.55); border:0.5px solid rgba(255,255,255,.18); }
    .ck-n:hover { color:var(--gold); border-color:var(--gold); }

    /* ══════════════════════════════
       KEYFRAMES
    ══════════════════════════════ */
    @keyframes fadeUp { from{opacity:0;transform:translateY(28px)} to{opacity:1;transform:translateY(0)} }
    @keyframes fadeRight { from{opacity:0;transform:translateX(40px)} to{opacity:1;transform:translateX(0)} }
    @keyframes fadeIn { from{opacity:0} to{opacity:1} }
    @keyframes slideIn { from{opacity:0;transform:translateX(36px)} to{opacity:1;transform:translateX(0)} }
    @keyframes slideOut { from{opacity:1;transform:translateX(0)} to{opacity:0;transform:translateX(-36px)} }
    @keyframes scrollDrop { 0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}51%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom} }
    @keyframes marqueeScroll { from{transform:translateX(0)} to{transform:translateX(-50%)} }

    /* ══════════════════════════════
       RESPONSIVE
    ══════════════════════════════ */
    @media (max-width:1100px) {
      .container { padding:0 32px; }
      #nav { padding:20px 32px; } #nav.on { padding:14px 32px; }
      #hero,#worlds,#quiz,#products,#about,#gram,#contact,.nl,footer { padding-left:32px; padding-right:32px; }
      #tips { padding-left:32px; }
      .tips-hd,.tips-row { padding-right:32px; }
      .hero-grid { gap:48px; }
      .ft-grid { grid-template-columns:1fr 1fr; gap:40px; }
    }
    @media (max-width:820px) {
      body { cursor:auto; }
      #cur,#cur-ring,#cur-lbl { display:none; }
      .n-links,.n-cta { display:none; }
      .hbg { display:flex; }
      #nav { padding:18px 24px; } #nav.on { padding:14px 24px; }
      #hero { padding:120px 24px 80px; min-height:auto; }
      .hero-grid { grid-template-columns:1fr; gap:56px; }
      .hero-ph { max-width:380px; margin:0 auto; }
      .hero-ph::after { right:auto; left:0; }
      .hero-fashion .hero-duo { max-width:360px; margin:0 auto; }
      .hero-proof { gap:24px; }
      #worlds,#quiz,#products,#about,#gram,#contact { padding:90px 24px; }
      #tips { padding:90px 0 90px 24px; }
      .tips-hd { padding-right:24px; flex-direction:column; align-items:flex-start; }
      .tips-row { padding-right:24px; }
      .tc { flex:0 0 280px; }
      .worlds-grid { grid-template-columns:1fr; gap:18px; }
      .svc-hd { grid-template-columns:1fr; gap:24px; }
      .qopts { grid-template-columns:1fr; }
      .prod-grid { grid-template-columns:1fr; }
      .pc { padding:40px 32px; min-height:auto; }
      .about-in { grid-template-columns:1fr; gap:60px; }
      .about-ph::before { display:none; }
      .ig-grid { gap:2px; }
      .ig-prof { padding:18px 20px; gap:16px; }
      .ig-prof-stats { gap:12px; font-size:10px; }
      .gram-hd { flex-direction:column; align-items:flex-start; }
      .bform { grid-template-columns:1fr; gap:28px; }
      .con-info { grid-template-columns:1fr; gap:28px; }
      .nl { padding:72px 24px; }
      .nl-form { flex-direction:column; gap:10px; }
      .nl-inp { border-right:0.5px solid rgba(194,178,153,.35); }
      footer { padding:48px 24px 32px; }
      .ft-grid { grid-template-columns:1fr; gap:36px; padding-bottom:36px; }
      .ft-bot { flex-direction:column; text-align:center; }
      .about-stats { grid-template-columns:1fr 1fr; gap:24px; }
      #ck { inset:auto 16px 16px 16px; }
    }
    @media (max-width:480px) {
      .hero-btns { flex-direction:column; align-items:stretch; }
      .hero-btns .btn { justify-content:center; }
      .r-btns { flex-direction:column; align-items:stretch; }
      .r-btns .btn { justify-content:center; }
      .ck-actions { flex-direction:column; }
      .ck-btn { width:100%; }
      .about-stats { grid-template-columns:1fr 1fr; }
      .con-info { grid-template-columns:1fr 1fr; }
      .ft-grid { grid-template-columns:1fr 1fr; gap:40px; }
      .hero-proof { gap:18px; }
      .fab-wrap { bottom:20px; right:18px; gap:10px; }
      .fab-label { display:none; }
      .fab-btn { width:46px; height:46px; }
    }

    /* ══ HERO PROOF — social icons ══ */
    .hp-ic { display:flex; align-items:center; gap:6px; }
    .hp-ic svg { opacity:.6; flex-shrink:0; }

    /* ══ FLOATING ACTION BUTTONS ══ */
    .fab-wrap {
      position:fixed; bottom:32px; right:28px; z-index:7900;
      display:flex; flex-direction:column; align-items:flex-end; gap:12px;
      transition:opacity .25s ease, visibility .25s ease;
    }
    body:has(.mob-menu.open) .fab-wrap {
      opacity:0; visibility:hidden; pointer-events:none;
    }
    .fab {
      display:flex; align-items:center; gap:10px;
      text-decoration:none; cursor:pointer;
    }
    .fab-label {
      font-family:var(--sans); font-size:10px; font-weight:700;
      letter-spacing:.18em; text-transform:uppercase;
      background:var(--black); color:var(--gold);
      padding:7px 14px; white-space:nowrap;
      border:0.5px solid rgba(194,178,153,.28);
      opacity:0; transform:translateX(12px);
      transition:opacity .22s, transform .22s;
      pointer-events:none;
    }
    .fab:hover .fab-label, .fab:focus .fab-label { opacity:1; transform:translateX(0); }
    .fab-btn {
      width:52px; height:52px; border-radius:50%;
      display:flex; align-items:center; justify-content:center;
      box-shadow:0 4px 22px rgba(0,0,0,.28);
      transition:transform .2s, box-shadow .2s;
      flex-shrink:0;
    }
    .fab-btn:hover { transform:scale(1.1); box-shadow:0 8px 32px rgba(0,0,0,.38); }
    .fab-wa .fab-btn { background:#25D366; }
    .fab-mail .fab-btn { background:var(--black); border:0.5px solid rgba(194,178,153,.35); }
    /* pulse ring on WA button */
    .fab-wa .fab-btn::after {
      content:''; position:absolute; inset:-6px; border-radius:50%;
      border:1.5px solid rgba(37,211,102,.4);
      animation:pulse-fab 2.4s ease-in-out infinite;
    }
    .fab-wa { position:relative; }
    @keyframes pulse-fab {
      0%,100% { opacity:.6; transform:scale(1); }
      50% { opacity:0; transform:scale(1.35); }
    }

    /* ══ FOOTER COUNT BADGES ══ */
    .ft-cnt {
      font-family:var(--sans); font-size:9px; font-weight:700;
      letter-spacing:.1em; color:var(--gold); opacity:.75;
      margin-left:6px; vertical-align:middle;
    }

    /* ══ LEGAL MODALS ══ */
    .lm-ov {
      display:none; position:fixed; inset:0; z-index:9000;
      background:rgba(13,13,13,.88); backdrop-filter:blur(6px);
      overflow-y:auto; padding:40px 20px;
    }
    .lm-ov.open { display:flex; align-items:flex-start; justify-content:center; }
    .lm-box {
      background:var(--cream); max-width:760px; width:100%;
      padding:64px 56px; position:relative; margin:auto;
    }
    .lm-close {
      position:absolute; top:24px; right:28px;
      background:none; border:none; cursor:pointer;
      font-family:var(--sans); font-size:22px; color:var(--ink2);
      line-height:1; padding:0;
    }
    .lm-close:hover { color:var(--black); }
    .lm-ttl {
      font-family:var(--serif); font-size:36px; font-weight:400;
      font-style:italic; color:var(--black); margin-bottom:32px;
      padding-bottom:20px; border-bottom:0.5px solid var(--gold-line);
    }
    .lm-body { font-family:var(--serif); font-size:17px; line-height:1.7; color:var(--ink2); }
    .lm-body h3 { font-size:14px; font-family:var(--sans); font-weight:700; letter-spacing:.18em; text-transform:uppercase; color:var(--gold-dk); margin:28px 0 10px; }
    .lm-body p { margin-bottom:14px; }
    .lm-body ul { padding-left:20px; margin-bottom:14px; }
    .lm-body li { margin-bottom:6px; }
    .lm-body a { color:var(--black); border-bottom:0.5px solid var(--gold); }
    @media(max-width:600px){
      .lm-box { padding:48px 28px; }
      .lm-ttl { font-size:28px; }
    }

    /* ══════════════════════════════
       PREMIUM — grain, split, mag, parallax
    ══════════════════════════════ */

    /* ── GRAIN ── */
    body::after {
      content:''; position:fixed; inset:0; z-index:99998;
      pointer-events:none; opacity:.028;
      background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='320' height='320'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='320' height='320' filter='url(%23n)'/%3E%3C/svg%3E");
      mix-blend-mode:overlay;
    }

    /* ── CURSOR LABEL ── */
    #cur-lbl {
      position:fixed; z-index:9997; pointer-events:none;
      font-family:var(--sans); font-size:8px; font-weight:700;
      letter-spacing:.32em; text-transform:uppercase;
      color:var(--black); background:var(--gold); padding:5px 11px;
      transform:translate(-50%, 16px) scale(.8);
      opacity:0; transition:opacity .18s, transform .18s;
      white-space:nowrap;
    }
    #cur-lbl.vis { opacity:1; transform:translate(-50%, 16px) scale(1); }

    /* ── WORD SPLIT REVEAL ── */
    .sw { overflow:hidden; display:inline-block; vertical-align:bottom; line-height:1.2; }
    .sw-i {
      display:inline-block; transform:translateY(108%);
      transition:transform 1.05s cubic-bezier(0.16,1,0.3,1);
    }
    .rev.in .sw-i { transform:translateY(0); }

    /* ── MAGNETIC BUTTON ── */
    .mag { transition:transform .45s cubic-bezier(.16,1,.3,1) !important; }

    /* ── PARALLAX HERO ── */
    .hero-ph { will-change:transform; }

    /* ── SERVICES — HORIZONTAL SCROLL ── */
    #services { padding:160px 0 160px 80px; background:var(--bone); overflow:hidden; }
    .svc-hd { margin-bottom:72px; padding-right:80px; max-width:none; margin-left:0; margin-right:0;
      display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:end; }


    /* ── ABOUT PULL QUOTE ── */
    .about-quote {
      font-family:var(--serif); font-size:clamp(19px,2vw,26px); font-style:italic;
      line-height:1.45; color:var(--black);
      border-left:2px solid var(--gold); padding-left:22px;
      margin:32px 0; position:relative;
    }

    /* ── STAGGER GRID ── */
    .stg > * { opacity:0; transform:translateY(18px);
      transition:opacity .7s cubic-bezier(.16,1,.3,1), transform .7s cubic-bezier(.16,1,.3,1); }
    .stg.in > *:nth-child(1){opacity:1;transform:none;transition-delay:.04s}
    .stg.in > *:nth-child(2){opacity:1;transform:none;transition-delay:.14s}
    .stg.in > *:nth-child(3){opacity:1;transform:none;transition-delay:.24s}
    .stg.in > *:nth-child(4){opacity:1;transform:none;transition-delay:.34s}
    .stg.in > *:nth-child(5){opacity:1;transform:none;transition-delay:.44s}

    /* ── TC HOVER OVERLAY ── */
    .tc-ph { position:relative; }
    .tc-ph::after {
      content:'VIEW'; position:absolute; inset:0;
      display:flex; align-items:center; justify-content:center;
      font-family:var(--sans); font-size:8px; font-weight:700; letter-spacing:.44em;
      color:rgba(255,255,255,.92); background:rgba(13,13,13,.3);
      opacity:0; transition:opacity .3s;
    }
    .tc:hover .tc-ph::after { opacity:1; }

    /* ── WORLDS LABEL ── */
    .wc-explore {
      position:absolute; top:28px; right:28px; z-index:3;
      font-family:var(--sans); font-size:8px; font-weight:700;
      letter-spacing:.4em; text-transform:uppercase;
      color:rgba(255,255,255,.55); writing-mode:vertical-rl;
      opacity:0; transition:opacity .4s .1s;
    }
    .wc:hover .wc-explore { opacity:1; }

    /* ── HERO EYEBROW UNDERLINE ── */
    .hero-h1 .accent { position:relative; display:inline; }
    .hero-h1 .accent::after {
      content:''; position:absolute; bottom:-4px; left:0; right:0;
      height:0.5px; background:var(--gold); transform:scaleX(0); transform-origin:left;
      animation:lineIn 1s cubic-bezier(.16,1,.3,1) 1.4s forwards;
    }
    @keyframes lineIn { to { transform:scaleX(1); } }

    /* ── NEWSLETTER BG ── */
    .nl { position:relative; }
    .nl::before {
      content:''; position:absolute; inset:0; pointer-events:none;
      background:radial-gradient(ellipse 60% 50% at 50% 50%, rgba(194,178,153,.06) 0%, transparent 70%);
    }

    /* ── PAID EBOOKS responsive ── */
    @media (max-width:820px) {
      .eb-grid { grid-template-columns:1fr; }
      .eb-card { grid-template-columns:1fr; min-height:auto; }
      .eb-cover { height:260px; }
      .eb-cover-overlay { background:linear-gradient(to bottom, transparent 50%, var(--espresso)) !important; }
      .eb-body { padding:36px 32px; }
      .prod-grid { grid-template-columns:1fr; }
      .pc { padding:48px 36px; min-height:auto; }
    }
    @media (max-width:480px) {
      #products { padding:80px 24px; }
      .eb-body { padding:28px 24px; }
      .pc { padding:40px 28px; }
    }

    /* ══════════════════════════════
       COLOR QUIZ
    ══════════════════════════════ */
    #colorquiz { padding:160px 80px; background:var(--black); color:var(--paper); position:relative; overflow:hidden; }
    .cq-bg {
      position:absolute; top:50%; left:50%; transform:translate(-50%,-50%) rotate(-8deg);
      font-family:var(--serif); font-size:clamp(100px,16vw,260px); font-style:italic; font-weight:500;
      color:rgba(194,178,153,.03); white-space:nowrap; pointer-events:none; user-select:none;
    }
    .cq-in { position:relative; z-index:2; max-width:820px; margin:0 auto; }
    .cq-h2 { font-family:var(--serif); font-size:clamp(38px,4.5vw,64px); font-weight:400; font-style:italic; color:var(--paper); margin:14px 0 14px; line-height:1.06; }
    .cq-sub { font-family:var(--serif); font-size:17px; color:rgba(255,255,255,.6); margin-bottom:52px; max-width:540px; }

    /* progress bar */
    .cq-prog { display:flex; align-items:center; gap:8px; margin-bottom:48px; }
    .cq-step {
      height:2px; flex:1; background:rgba(194,178,153,.18);
      transition:background .5s;
    }
    .cq-step.done { background:var(--gold); }
    .cq-step.active { background:rgba(194,178,153,.6); }

    /* question */
    .cq-q { font-family:var(--serif); font-size:clamp(22px,2.5vw,30px); font-weight:400; font-style:italic; color:var(--paper); margin-bottom:32px; line-height:1.3; }
    .cq-qnum { font-family:var(--sans); font-size:9px; font-weight:700; letter-spacing:.36em; text-transform:uppercase; color:var(--gold); margin-bottom:14px; }
    .cq-opts { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
    .cq-opt {
      padding:20px 24px; border:0.5px solid rgba(194,178,153,.2);
      background:transparent; cursor:pointer;
      font-family:var(--sans); font-size:13px; font-weight:400;
      color:rgba(255,255,255,.78); text-align:left; line-height:1.45;
      transition:all .3s cubic-bezier(.16,1,.3,1);
    }
    .cq-opt:hover { border-color:var(--gold); background:rgba(194,178,153,.07); color:var(--paper); }
    .cq-opt.sel { border-color:var(--gold); background:rgba(194,178,153,.12); color:var(--gold); }

    /* result */
    #cq-res { display:none; animation:fadeIn .7s ease; }
    #cq-res.show { display:block; }
    .cq-season-tag {
      font-family:var(--sans); font-size:9px; font-weight:700; letter-spacing:.42em;
      text-transform:uppercase; color:var(--gold); margin-bottom:18px;
    }
    .cq-season-name {
      font-family:var(--serif); font-size:clamp(64px,9vw,120px); font-weight:400;
      font-style:italic; color:var(--paper); line-height:1; margin-bottom:10px;
    }
    .cq-season-sub {
      font-family:var(--sans); font-size:11px; font-weight:600; letter-spacing:.28em;
      text-transform:uppercase; color:var(--gold); margin-bottom:28px;
    }
    .cq-desc { font-family:var(--serif); font-size:18px; color:rgba(255,255,255,.78); line-height:1.65; max-width:560px; margin-bottom:36px; }
    .cq-palette { display:flex; gap:12px; flex-wrap:wrap; margin-bottom:12px; }
    .cq-sw-wrap {
      display:flex; flex-direction:column; align-items:center; gap:6px;
    }
    .cq-swatch {
      width:40px; height:40px; border-radius:50%;
      position:relative; cursor:pointer; transition:transform .2s; flex-shrink:0;
    }
    .cq-swatch:hover { transform:scale(1.18); }
    .cq-sw-label {
      font-family:var(--sans); font-size:8px; font-weight:500; letter-spacing:.08em;
      color:rgba(255,255,255,.5); white-space:nowrap; text-align:center;
      max-width:52px; overflow:hidden; text-overflow:ellipsis;
    }
    .cq-tip {
      font-family:var(--sans); font-size:12px; font-weight:500; line-height:1.7;
      color:rgba(255,255,255,.55); margin-top:44px; padding-top:28px;
      border-top:0.5px solid rgba(194,178,153,.2); max-width:560px;
    }
    .cq-tip strong { color:var(--gold); }
    .cq-retry {
      background:none; border:none; cursor:pointer;
      font-family:var(--sans); font-size:10px; font-weight:600; letter-spacing:.22em;
      text-transform:uppercase; color:rgba(255,255,255,.45);
      border-bottom:0.5px solid rgba(255,255,255,.18); padding-bottom:3px;
      margin-top:32px; display:inline-block; transition:all var(--t);
    }
    .cq-retry:hover { color:var(--gold); border-color:var(--gold); }
    @media (max-width:820px) {
      #colorquiz { padding:90px 24px; }
      .cq-opts { grid-template-columns:1fr; }
    }

    /* ══════════════════════════════
       INSPO SECTION
    ══════════════════════════════ */
    #inspo { padding:160px 80px; background:var(--cream); }
    .inspo-hd { text-align:center; margin-bottom:80px; }
    .inspo-h2 { font-family:var(--serif); font-size:clamp(38px,4.8vw,72px); font-weight:400; font-style:italic; color:var(--black); line-height:1.05; margin:14px 0 20px; }
    .inspo-sub { font-family:var(--serif); font-size:17px; color:var(--ink2); max-width:460px; margin:0 auto; line-height:1.55; }
    .inspo-grid {
      max-width:1440px; margin:0 auto;
      display:grid; gap:4px;
      grid-template-columns:1.4fr 1fr 1fr;
      grid-template-rows:auto auto;
    }
    .inspo-item {
      position:relative; overflow:hidden; cursor:pointer;
      background:var(--black-2);
    }
    .inspo-item:nth-child(1) { grid-row:1/3; }
    .inspo-item img {
      width:100%; height:100%; object-fit:cover; display:block;
      transition:transform 1.1s cubic-bezier(.16,1,.3,1), filter .5s;
      min-height:280px;
    }
    .inspo-item:hover img { transform:scale(1.06); filter:brightness(.72); }
    .inspo-ov {
      position:absolute; inset:auto 0 0 0;
      padding:28px 28px 24px;
      background:linear-gradient(0deg, rgba(13,13,13,.82) 0%, transparent 100%);
      transform:translateY(100%); transition:transform .45s cubic-bezier(.16,1,.3,1);
    }
    .inspo-item:hover .inspo-ov { transform:translateY(0); }
    .inspo-ov-tag { font-family:var(--sans); font-size:9px; font-weight:700; letter-spacing:.32em; text-transform:uppercase; color:var(--gold); margin-bottom:6px; }
    .inspo-ov-t { font-family:var(--serif); font-size:20px; font-style:italic; color:var(--paper); line-height:1.25; margin-bottom:6px; }
    .inspo-ov-tip { font-family:var(--sans); font-size:12px; color:rgba(255,255,255,.72); line-height:1.55; }
    @media (max-width:900px) {
      #inspo { padding:90px 24px; }
      .inspo-grid { grid-template-columns:1fr 1fr; grid-template-rows:auto; }
      .inspo-item:nth-child(1) { grid-row:auto; }
    }
    @media (max-width:580px) {
      .inspo-grid { grid-template-columns:1fr; }
    }

    /* ══════════════════════════════
       BLOG SECTION
    ══════════════════════════════ */
    #blog { padding:160px 80px; background:var(--bone); }
    .blog-hd { display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:end; margin-bottom:72px; }
    .blog-h2 { font-family:var(--serif); font-size:clamp(38px,4.8vw,72px); font-weight:400; font-style:italic; color:var(--black); line-height:1.05; margin:14px 0; }
    .blog-intro { font-family:var(--serif); font-size:17px; color:var(--ink2); line-height:1.65; max-width:420px; }
    .blog-grid { display:grid; grid-template-columns:1.6fr 1fr 1fr; grid-template-rows:auto auto; gap:3px; max-width:1440px; margin:0 auto; }
    .ba {
      background:var(--cream); display:flex; flex-direction:column;
      text-decoration:none; position:relative; overflow:hidden;
      transition:background var(--t);
    }
    .ba:hover { background:var(--paper); }
    .ba:nth-child(1) { grid-row:1/3; }
    .ba-img {
      aspect-ratio:4/3; overflow:hidden; background:var(--black-2); flex-shrink:0;
    }
    .ba:nth-child(1) .ba-img { aspect-ratio:3/4; }
    .ba-img img { width:100%; height:100%; object-fit:cover; transition:transform 1.1s cubic-bezier(.16,1,.3,1); display:block; }
    .ba:hover .ba-img img { transform:scale(1.05); }
    .ba-body { padding:28px 30px 30px; flex:1; display:flex; flex-direction:column; }
    .ba:nth-child(1) .ba-body { padding:36px 40px 40px; }
    .ba-meta { display:flex; gap:14px; align-items:center; margin-bottom:14px; }
    .ba-cat { font-family:var(--sans); font-size:9px; font-weight:700; letter-spacing:.3em; text-transform:uppercase; color:var(--gold); }
    .ba-time { font-family:var(--sans); font-size:9px; letter-spacing:.18em; color:var(--stone); }
    .ba-t { font-family:var(--serif); font-size:22px; font-weight:500; line-height:1.25; color:var(--black); margin-bottom:10px; }
    .ba:nth-child(1) .ba-t { font-size:clamp(26px,2.8vw,38px); }
    .ba-excerpt { font-family:var(--sans); font-size:12px; color:var(--ink2); line-height:1.65; flex:1; }
    .ba-link { font-family:var(--sans); font-size:10px; font-weight:700; letter-spacing:.2em; text-transform:uppercase; color:var(--black); margin-top:20px; align-self:flex-start; border-bottom:0.5px solid var(--gold); padding-bottom:3px; transition:color var(--t); }
    .ba:hover .ba-link { color:var(--gold); }
    @media (max-width:960px) {
      #blog { padding:90px 24px; }
      .blog-hd { grid-template-columns:1fr; gap:20px; }
      .blog-grid { grid-template-columns:1fr 1fr; grid-template-rows:auto; }
      .ba:nth-child(1) { grid-row:auto; }
      .ba:nth-child(1) .ba-img { aspect-ratio:4/3; }
      .ba:nth-child(1) .ba-t { font-size:clamp(22px,3vw,28px); }
      .ba:nth-child(1) .ba-body { padding:28px 30px 30px; }
    }
    @media (max-width:580px) {
      .blog-grid { grid-template-columns:1fr; }
    }

    /* ── CONTACT CTA ── */
    .con-h2 em { position:relative; }
    .con-h2 em::after {
      content:''; position:absolute; bottom:-6px; left:0; right:0;
      height:0.5px; background:var(--gold);
    }

    /* responsive overrides */
    @media (max-width:1100px) {
      #services { padding:140px 48px; }
      .svc-hd { margin-bottom:56px; }
      .sc::before { margin:0 -48px; }
    }
    @media (max-width:820px) {
      #services { padding:90px 24px !important; }
      .svc-hd { grid-template-columns:1fr; gap:20px; margin-bottom:40px; }
      .sc { grid-template-columns:40px 1fr; gap:0 20px; }
      .sc-right { display:none; }
      .sc::before { margin:0 -24px; }
    }
    @media (max-width:480px) {
      #services { padding:70px 16px !important; }
      .sc::before { margin:0 -16px; }
    }

/* ═══════════════════════════════════════════════════
   LANDING HUB — DRAMATIC WORLDS SPLIT
═══════════════════════════════════════════════════ */
#worlds.worlds-hub {
  padding: 0;
  background: var(--black);
  position: relative;
  overflow: hidden;
}
.worlds-hub .worlds-hd {
  text-align: center;
  padding: 80px 24px 50px;
  position: relative;
  z-index: 2;
}
.worlds-hub .worlds-hd .lbl { color: var(--gold); }
.worlds-hub .worlds-t {
  font-family: var(--serif);
  font-size: clamp(36px, 5vw, 64px);
  font-weight: 300;
  color: var(--cream);
  letter-spacing: -.01em;
  line-height: 1.05;
}
.worlds-hub .worlds-t em { color: var(--gold); font-style: italic; }

.worlds-hub-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1px;
  background: rgba(194,178,153,.15);
  min-height: 78vh;
}
.world-door {
  position: relative;
  overflow: hidden;
  background: var(--espresso);
  cursor: pointer;
  transition: flex-grow .7s ease;
  text-decoration: none;
  display: block;
}
.world-door img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  filter: brightness(.5) saturate(.9);
  transition: filter .9s cubic-bezier(.16,1,.3,1), transform 1.2s cubic-bezier(.16,1,.3,1);
}
.worlds-hub-grid:has(.world-door:hover) .world-door:not(:hover) img {
  filter: brightness(.22) saturate(.3) blur(2px);
}
.world-door:hover img {
  filter: brightness(.72) saturate(1.05);
  transform: scale(1.06);
}
.world-door::before {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,.1) 0%, rgba(0,0,0,.5) 60%, rgba(0,0,0,.85) 100%);
  z-index: 1;
  transition: background .8s ease;
}
.world-door:hover::before {
  background: linear-gradient(180deg, rgba(0,0,0,.05) 0%, rgba(0,0,0,.4) 60%, rgba(0,0,0,.78) 100%);
}
.wd-content {
  position: absolute;
  left: 0; right: 0; bottom: 0;
  padding: 70px 60px;
  z-index: 2;
  color: var(--cream);
  transition: transform .7s cubic-bezier(.16,1,.3,1);
}
.world-door:hover .wd-content { transform: translateY(-12px); }
.wd-num {
  font-family: var(--serif);
  font-size: 18px;
  font-weight: 400;
  color: var(--gold);
  letter-spacing: .15em;
  margin-bottom: 30px;
  display: block;
}
.wd-title {
  font-family: var(--serif);
  font-size: clamp(60px, 10vw, 140px);
  font-weight: 300;
  letter-spacing: -.03em;
  line-height: .9;
  margin-bottom: 18px;
  font-style: italic;
}
.wd-tag {
  font-family: var(--sans);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--gold);
  display: block;
  margin-bottom: 16px;
  opacity: .85;
}
.wd-desc {
  font-family: var(--sans);
  font-size: 15px;
  font-weight: 300;
  line-height: 1.6;
  color: rgba(248,244,239,.78);
  max-width: 420px;
  margin-bottom: 36px;
}
.wd-cta {
  display: inline-flex;
  align-items: center;
  gap: 16px;
  font-family: var(--sans);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--cream);
  border-bottom: 0.5px solid var(--gold);
  padding-bottom: 10px;
  transition: gap .4s ease, color .4s ease;
}
.world-door:hover .wd-cta { gap: 28px; color: var(--gold); }
.wd-cta .arr {
  display: inline-block;
  transition: transform .5s cubic-bezier(.16,1,.3,1);
}
.world-door:hover .wd-cta .arr { transform: translateX(8px); }

/* corner serial */
.wd-serial {
  position: absolute;
  top: 40px; right: 50px;
  font-family: var(--serif);
  font-size: 13px;
  letter-spacing: .25em;
  color: rgba(194,178,153,.6);
  z-index: 2;
  font-style: italic;
}

@media (max-width: 900px) {
  .worlds-hub-grid { grid-template-columns: 1fr; min-height: auto; }
  .world-door { min-height: 70vh; }
  .wd-content { padding: 50px 32px; }
  .wd-title { font-size: clamp(56px, 18vw, 110px); }
  .wd-serial { top: 24px; right: 28px; }
}

.worlds-cta {
  text-align: center;
  padding: 56px 24px 28px;
  display: flex; flex-direction: column; align-items: center; gap: 14px;
}
.worlds-cta-or {
  font-family: var(--sans);
  font-size: 10px; font-weight: 600;
  letter-spacing: .34em; text-transform: uppercase;
  color: var(--gold-dk);
  position: relative;
}
.worlds-cta-or::before,
.worlds-cta-or::after {
  content: ""; position: absolute; top: 50%; width: 38px; height: 1px;
  background: var(--gold-line);
}
.worlds-cta-or::before { right: calc(100% + 14px); }
.worlds-cta-or::after { left: calc(100% + 14px); }
.worlds-cta-link {
  font-family: var(--serif);
  font-size: clamp(18px, 2.4vw, 24px);
  color: var(--cream);
  text-decoration: none;
  border-bottom: 1px solid var(--gold-line);
  padding-bottom: 6px;
  transition: color var(--t), border-color var(--t), transform var(--t);
  display: inline-flex; align-items: baseline; gap: 12px;
}
.worlds-cta-link:hover {
  color: var(--gold);
  border-color: var(--gold);
}
.worlds-cta-link .arr {
  font-family: var(--sans);
  font-size: .9em;
  transition: transform var(--t);
}
.worlds-cta-link:hover .arr { transform: translateX(6px); }

@media (max-width: 600px) {
  .worlds-cta { padding: 40px 20px 20px; }
  .worlds-cta-link { font-size: 17px; }
}

/* ═══════════════════════════════════════════════════
   FEATURED CONTENT — Hub teaser grid
═══════════════════════════════════════════════════ */
#featured {
  padding: 140px 80px;
  background: var(--cream);
  position: relative;
}
.feat-hd {
  text-align: center;
  margin-bottom: 80px;
}
.feat-h2 {
  font-family: var(--serif);
  font-size: clamp(38px, 5vw, 62px);
  font-weight: 300;
  letter-spacing: -.01em;
  color: var(--ink);
  margin-top: 20px;
}
.feat-h2 em { color: var(--gold-dk); font-style: italic; }
.feat-tab {
  display: flex;
  justify-content: center;
  gap: 0;
  margin-top: 40px;
  border-bottom: 0.5px solid var(--gold-line);
  max-width: 480px;
  margin: 40px auto 0;
}
.feat-tab-b {
  flex: 1;
  background: none;
  border: none;
  padding: 18px 0;
  font-family: var(--sans);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--ink2);
  cursor: pointer;
  position: relative;
  transition: color .3s ease;
}
.feat-tab-b::after {
  content: '';
  position: absolute;
  bottom: -0.5px; left: 50%; transform: translateX(-50%);
  width: 0; height: 1.5px;
  background: var(--gold-dk);
  transition: width .4s ease;
}
.feat-tab-b.active { color: var(--ink); }
.feat-tab-b.active::after { width: 60%; }
.feat-tab-b:hover { color: var(--ink); }

.feat-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 40px;
  margin-top: 60px;
}
.feat-grid[data-tab="beauty"] .feat-card[data-cat="fashion"],
.feat-grid[data-tab="fashion"] .feat-card[data-cat="beauty"] {
  display: none;
}
.feat-card {
  text-decoration: none;
  color: var(--ink);
  display: block;
  transition: transform .6s cubic-bezier(.16,1,.3,1);
}
.feat-card:hover { transform: translateY(-6px); }
.feat-card-img {
  aspect-ratio: 4 / 5;
  overflow: hidden;
  background: var(--bone);
  margin-bottom: 24px;
  position: relative;
}
.feat-card-img img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 1s cubic-bezier(.16,1,.3,1);
}
.feat-card:hover .feat-card-img img { transform: scale(1.06); }
.feat-card-cat {
  font-family: var(--sans);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--gold-dk);
  margin-bottom: 10px;
  display: block;
}
.feat-card-ttl {
  font-family: var(--serif);
  font-size: 22px;
  font-weight: 400;
  line-height: 1.25;
  letter-spacing: -.005em;
  color: var(--ink);
}
.feat-card-meta {
  font-family: var(--sans);
  font-size: 12px;
  color: var(--ink2);
  margin-top: 10px;
}
@media (max-width: 900px) {
  #featured { padding: 80px 24px; }
  .feat-grid { grid-template-columns: 1fr; gap: 36px; }
}

/* ═══════════════════════════════════════════════════
   BEAUTY PAGE — own identity
═══════════════════════════════════════════════════ */
.is-beauty {
  --accent-rose: #C9968B;
  --accent-glow: #D9B8A8;
}
.is-beauty body, body.is-beauty {
  background: #FBF6F1;
}
.beauty-hero {
  min-height: 88vh;
  padding: 140px 80px 80px;
  background: linear-gradient(180deg, #FBF6F1 0%, #F6EAE0 100%);
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: center;
  overflow: hidden;
}
.beauty-hero::before {
  content: '';
  position: absolute;
  width: 480px; height: 480px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(217,184,168,.35) 0%, transparent 70%);
  top: 10%; right: -100px;
  z-index: 0;
}
.beauty-hero-text { position: relative; z-index: 1; }
.beauty-hero-tag {
  font-family: var(--sans);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .3em;
  text-transform: uppercase;
  color: var(--gold-dk);
  margin-bottom: 30px;
}
.beauty-hero h1 {
  font-family: var(--serif);
  font-size: clamp(56px, 7vw, 96px);
  font-weight: 300;
  letter-spacing: -.02em;
  line-height: 1;
  color: var(--ink);
  margin-bottom: 36px;
}
.beauty-hero h1 em {
  font-style: italic;
  color: var(--accent-rose);
}
.beauty-hero p {
  font-size: 17px;
  line-height: 1.7;
  color: var(--ink2);
  max-width: 480px;
  margin-bottom: 40px;
  font-weight: 300;
}
.beauty-hero-img {
  position: relative;
  z-index: 1;
  aspect-ratio: 4 / 5;
  overflow: hidden;
}
.beauty-hero-img img {
  width: 100%; height: 100%;
  object-fit: cover;
}
.beauty-hero-img::after {
  content: '';
  position: absolute; inset: 0;
  border: 1px solid var(--gold-line);
  pointer-events: none;
}
@media (max-width: 900px) {
  .beauty-hero { grid-template-columns: 1fr; padding: 100px 24px 60px; gap: 50px; }
}

/* BEAUTY SERVICES — editorial list */
#beauty-services {
  padding: 140px 80px;
  background: #FBF6F1;
  position: relative;
}
.bs-hd {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  margin-bottom: 100px;
  align-items: end;
}
.bs-hd h2 {
  font-family: var(--serif);
  font-size: clamp(40px, 5vw, 68px);
  font-weight: 300;
  letter-spacing: -.01em;
  line-height: 1.05;
  color: var(--ink);
}
.bs-hd h2 em { color: var(--accent-rose); font-style: italic; }
.bs-hd p {
  font-size: 16px;
  color: var(--ink2);
  line-height: 1.7;
  font-weight: 300;
}
.bs-list {
  max-width: 1280px;
  margin: 0 auto;
  border-top: 0.5px solid var(--gold-line);
}
.bs-row {
  display: grid;
  grid-template-columns: 80px 1fr auto;
  gap: 60px;
  align-items: center;
  padding: 44px 0;
  border-bottom: 0.5px solid var(--gold-line);
  position: relative;
  transition: background .4s ease;
  text-decoration: none;
  color: var(--ink);
}
.bs-row::before {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(90deg, rgba(217,184,168,.15) 0%, transparent 100%);
  opacity: 0;
  transition: opacity .5s ease;
  z-index: 0;
  margin: 0 -80px;
}
.bs-row:hover::before { opacity: 1; }
.bs-row > * { position: relative; z-index: 1; }
.bs-num {
  font-family: var(--serif);
  font-size: 14px;
  font-weight: 400;
  font-style: italic;
  color: var(--accent-rose);
  letter-spacing: .1em;
}
.bs-mid h3 {
  font-family: var(--serif);
  font-size: clamp(26px, 3vw, 40px);
  font-weight: 400;
  line-height: 1.15;
  letter-spacing: -.005em;
  color: var(--ink);
  margin-bottom: 14px;
  transition: transform .5s cubic-bezier(.16,1,.3,1), color .4s ease;
}
.bs-row:hover .bs-mid h3 { color: var(--accent-rose); transform: translateX(8px); }
.bs-mid p {
  font-family: var(--sans);
  font-size: 14px;
  line-height: 1.65;
  color: var(--ink2);
  font-weight: 300;
  max-width: 640px;
}
.bs-right {
  display: flex;
  align-items: center;
  gap: 32px;
}
.bs-price {
  font-family: var(--serif);
  font-size: 28px;
  font-weight: 400;
  font-style: italic;
  color: var(--ink);
  white-space: nowrap;
}
.bs-arr {
  font-family: var(--serif);
  font-size: 22px;
  color: var(--accent-rose);
  transition: transform .5s cubic-bezier(.16,1,.3,1);
}
.bs-row:hover .bs-arr { transform: translateX(10px); }
@media (max-width: 820px) {
  #beauty-services { padding: 80px 24px; }
  .bs-hd { grid-template-columns: 1fr; gap: 30px; margin-bottom: 50px; }
  .bs-row { grid-template-columns: 50px 1fr; gap: 24px; padding: 28px 0; }
  .bs-row::before { margin: 0 -24px; }
  .bs-right { display: none; }
  .bs-mid h3::after {
    content: ' — ' attr(data-price);
    font-style: italic;
    color: var(--accent-rose);
    font-size: 18px;
  }
}

/* BEAUTY PHILOSOPHY */
#beauty-philosophy {
  padding: 140px 80px;
  background: var(--black);
  color: var(--cream);
  position: relative;
}
.bp-in {
  max-width: 980px;
  margin: 0 auto;
  text-align: center;
}
.bp-in .lbl { color: var(--gold); }
.bp-in h2 {
  font-family: var(--serif);
  font-size: clamp(38px, 4vw, 58px);
  font-weight: 300;
  letter-spacing: -.005em;
  line-height: 1.2;
  font-style: italic;
  margin-top: 24px;
  margin-bottom: 40px;
}
.bp-in h2 em { color: var(--gold); }
.bp-in p {
  font-size: 17px;
  font-weight: 300;
  line-height: 1.8;
  color: rgba(248,244,239,.75);
  max-width: 720px;
  margin: 0 auto 24px;
}
.bp-cite {
  font-family: var(--serif);
  font-style: italic;
  color: var(--gold);
  font-size: 14px;
  margin-top: 30px;
  display: block;
  letter-spacing: .1em;
}

/* page-back link */
.page-back {
  position: fixed;
  top: 32px; left: 32px;
  z-index: 90;
  font-family: var(--sans);
  font-size: 11px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--ink2);
  display: inline-flex; align-items: center; gap: 8px;
  background: rgba(248,244,239,.92);
  backdrop-filter: blur(8px);
  padding: 12px 16px;
  border-radius: 0;
  transition: color .3s ease;
}
.page-back:hover { color: var(--ink); }

/* ═══════════════════════════════════════════════════
   FIX: BEAUTY PAGE NAV — light background needs dark text
═══════════════════════════════════════════════════ */
body.is-beauty #nav .n-logo {
  color: var(--ink);
}
body.is-beauty #nav .n-links a {
  color: var(--ink2);
}
body.is-beauty #nav .n-links a:hover { color: var(--accent-rose, var(--gold-dk)); }
body.is-beauty #nav .n-cta {
  color: var(--ink);
  border-color: rgba(28,27,27,.35);
}
body.is-beauty #nav .n-cta:hover {
  background: var(--ink);
  color: var(--cream);
  border-color: var(--ink);
}
body.is-beauty #nav.on { background: rgba(13,13,13,.92); }
body.is-beauty #nav.on .n-logo,
body.is-beauty #nav.on .n-links a { color: var(--paper); }
body.is-beauty #nav.on .n-links a:hover { color: var(--gold); }
body.is-beauty #nav.on .n-cta { color: var(--gold); border-color: rgba(194,178,153,.45); }
body.is-beauty .hbg span { background: var(--ink); }
body.is-beauty #nav.on .hbg span { background: var(--paper); }

/* ═══════════════════════════════════════════════════
   FIX: LIGHT PAGE NAV — cream/paper background needs dark text
   (služby pages + o-mne, blog, slovník — any light-hero subpage)
═══════════════════════════════════════════════════ */
body.srv-page #nav .n-logo,
body.lt-nav #nav .n-logo { color: var(--ink); }
body.srv-page #nav .n-links a,
body.lt-nav #nav .n-links a { color: var(--ink2); }
body.srv-page #nav .n-links a:hover,
body.lt-nav #nav .n-links a:hover { color: var(--gold-dk); }
body.srv-page #nav .n-cta,
body.lt-nav #nav .n-cta { color: var(--ink); border-color: rgba(28,27,27,.35); }
body.srv-page #nav .n-cta:hover,
body.lt-nav #nav .n-cta:hover { background: var(--ink); color: var(--cream); border-color: var(--ink); }
body.srv-page .hbg span,
body.lt-nav .hbg span { background: var(--ink); }
body.srv-page #nav.on,
body.lt-nav #nav.on { background: rgba(13,13,13,.92); }
body.srv-page #nav.on .n-logo,
body.srv-page #nav.on .n-links a,
body.lt-nav #nav.on .n-logo,
body.lt-nav #nav.on .n-links a { color: var(--paper); }
body.srv-page #nav.on .n-links a:hover,
body.lt-nav #nav.on .n-links a:hover { color: var(--gold); }
body.srv-page #nav.on .n-cta,
body.lt-nav #nav.on .n-cta { color: var(--gold); border-color: rgba(194,178,153,.45); }
body.srv-page #nav.on .hbg span,
body.lt-nav #nav.on .hbg span { background: var(--paper); }

/* ═══════════════════════════════════════════════════
   TYPOGRAPHY UPGRADE — elegant numbers everywhere
═══════════════════════════════════════════════════ */
/* Hero proof numbers (TikTok 59K, IG 13K, etc.) */
.hp-n {
  font-family: var(--serif) !important;
  font-size: 36px !important;
  font-weight: 400 !important;
  font-style: italic !important;
  letter-spacing: -.01em;
  line-height: 1;
}
.hp-l {
  font-family: var(--sans);
  font-size: 9px;
  font-weight: 500;
  letter-spacing: .25em;
  text-transform: uppercase;
}

/* About stats (59K, 13K, 500+, 7) */
.as-n {
  font-family: var(--serif) !important;
  font-size: 64px !important;
  font-weight: 400 !important;
  font-style: italic !important;
  letter-spacing: -.02em;
  color: var(--gold);
}

/* Service price (fashion) */
.sc-price {
  font-family: var(--serif) !important;
  font-size: 32px !important;
  font-weight: 400 !important;
  font-style: italic !important;
  letter-spacing: -.01em !important;
  color: var(--black);
}
.sc-price span {
  font-style: normal;
  font-family: var(--sans);
  font-size: 9px !important;
  font-weight: 600 !important;
  vertical-align: middle;
  margin-right: 8px;
}
.sc-price.free {
  font-style: italic !important;
  color: var(--gold);
}
.sc-num {
  font-family: var(--serif) !important;
  font-size: 16px !important;
  font-style: italic !important;
  color: rgba(155,142,120,.7);
}
.sc-name {
  font-family: var(--serif) !important;
  font-size: clamp(22px, 2.4vw, 32px) !important;
  font-weight: 400 !important;
  letter-spacing: -.005em;
  line-height: 1.15;
}

/* Beauty service prices */
.bs-price {
  font-family: var(--serif) !important;
  font-size: 36px !important;
  font-weight: 400 !important;
  font-style: italic !important;
  letter-spacing: -.015em !important;
  color: var(--ink);
}
.bs-num {
  font-family: var(--serif) !important;
  font-size: 16px !important;
  font-style: italic !important;
}
.bs-mid h3 {
  font-family: var(--serif) !important;
  font-weight: 400 !important;
  letter-spacing: -.01em !important;
}

/* Contact info — make elegant */
.ci-l {
  font-family: var(--sans);
  font-size: 10px !important;
  font-weight: 500 !important;
  letter-spacing: .3em !important;
  text-transform: uppercase;
  color: var(--gold-dk);
  margin-bottom: 12px !important;
}
.ci-v {
  font-family: var(--serif) !important;
  font-size: 24px !important;
  font-weight: 400 !important;
  font-style: italic;
  letter-spacing: -.005em;
  color: var(--ink);
  line-height: 1.3;
}
.ci-v a:hover { color: var(--gold-dk); }

/* Ebook prices on landing */
.eb-price-tag {
  font-family: var(--serif) !important;
  font-weight: 400 !important;
  font-style: italic !important;
  font-size: 18px !important;
}
.eb-price-lg {
  font-family: var(--serif) !important;
  font-style: italic !important;
  font-weight: 400 !important;
}

/* Footer counts (Sledovať column) */
.ft-cnt {
  font-family: var(--serif) !important;
  font-size: 14px !important;
  font-style: italic !important;
  color: var(--gold) !important;
}

/* ═══════════════════════════════════════════════════
   LANDING — EBOOK TEASER + IG SECTION
═══════════════════════════════════════════════════ */
#l-services {
  padding: 120px 80px;
  background: var(--cream);
  border-top: 0.5px solid var(--gold-line);
}
.ls-hd {
  text-align: center;
  margin-bottom: 80px;
}
.ls-h2 {
  font-family: var(--serif);
  font-size: clamp(38px, 5vw, 64px);
  font-weight: 300;
  letter-spacing: -.01em;
  font-style: italic;
  margin-top: 24px;
}
.ls-h2 em { color: var(--gold-dk); }
.ls-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2px;
  background: var(--gold-line);
  max-width: 1440px;
  margin: 0 auto;
}
.ls-col {
  background: var(--cream);
  padding: 70px 60px;
  display: flex;
  flex-direction: column;
}
.ls-col h3 {
  font-family: var(--serif);
  font-size: clamp(40px, 5vw, 64px);
  font-weight: 400;
  font-style: italic;
  letter-spacing: -.015em;
  line-height: 1;
  margin-bottom: 24px;
  color: var(--ink);
}
.ls-col .ls-tag {
  font-family: var(--sans);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--gold-dk);
  margin-bottom: 30px;
}
.ls-col p {
  font-size: 15px;
  line-height: 1.7;
  color: var(--ink2);
  font-weight: 300;
  margin-bottom: 30px;
  max-width: 460px;
}
.ls-svc-list {
  list-style: none;
  margin: 0 0 40px;
  padding: 0;
}
.ls-svc-list li {
  padding: 16px 0;
  border-bottom: 0.5px solid var(--gold-line);
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 20px;
  transition: padding-left .35s ease;
}
.ls-svc-list li:hover { padding-left: 6px; }
.ls-svc-list .ls-sn {
  font-family: var(--serif);
  font-size: 19px;
  font-weight: 400;
  color: var(--ink);
}
.ls-svc-list .ls-sp {
  font-family: var(--serif);
  font-size: 17px;
  font-style: italic;
  color: var(--gold-dk);
  white-space: nowrap;
}
.ls-more {
  font-family: var(--sans);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--ink);
  border-bottom: 0.5px solid var(--gold);
  padding-bottom: 8px;
  align-self: flex-start;
  margin-top: auto;
  transition: gap .4s ease, color .3s ease;
  display: inline-flex;
  align-items: center;
  gap: 12px;
}
.ls-more:hover { gap: 20px; color: var(--gold-dk); }
@media (max-width: 900px) {
  #l-services { padding: 80px 24px; }
  .ls-grid { grid-template-columns: 1fr; }
  .ls-col { padding: 50px 32px; }
}

/* ═══════════════════════════════════════════════════
   LANDING — EBOOK MINI-SHOWCASE
═══════════════════════════════════════════════════ */
#l-ebooks {
  padding: 120px 80px;
  background: var(--black);
  color: var(--cream);
}
.le-hd {
  max-width: 1440px;
  margin: 0 auto 60px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: end;
}
.le-hd h2 {
  font-family: var(--serif);
  font-size: clamp(42px, 5vw, 68px);
  font-weight: 300;
  font-style: italic;
  letter-spacing: -.015em;
  line-height: 1.05;
}
.le-hd h2 em { color: var(--gold); }
.le-hd p {
  font-size: 16px;
  color: rgba(248,244,239,.7);
  line-height: 1.7;
  font-weight: 300;
}
.le-grid {
  max-width: 1440px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 40px;
}
.le-card {
  display: grid;
  grid-template-columns: 200px 1fr;
  gap: 30px;
  background: var(--espresso);
  padding: 30px;
  text-decoration: none;
  color: var(--cream);
  transition: transform .5s cubic-bezier(.16,1,.3,1);
  border: none;
  text-align: left;
  font: inherit;
  cursor: pointer;
  width: 100%;
}
.le-card:hover { transform: translateY(-6px); }
.le-card:disabled { opacity: .7; cursor: wait; }
.le-card-img {
  aspect-ratio: 3 / 4;
  overflow: hidden;
  position: relative;
}
.le-card-img img { width:100%; height:100%; object-fit:cover; transition: transform 1s ease; }
.le-card:hover .le-card-img img { transform: scale(1.05); }
.le-card-body { display: flex; flex-direction: column; justify-content: space-between; padding: 8px 0; }
.le-cat {
  font-family: var(--sans);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 16px;
}
.le-ttl {
  font-family: var(--serif);
  font-size: clamp(22px, 2.4vw, 30px);
  font-weight: 400;
  line-height: 1.2;
  margin-bottom: 16px;
}
.le-desc {
  font-size: 13px;
  color: rgba(248,244,239,.65);
  line-height: 1.6;
  font-weight: 300;
  margin-bottom: 18px;
}
.le-bottom {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding-top: 16px;
  border-top: 0.5px solid rgba(194,178,153,.2);
}
.le-price {
  font-family: var(--serif);
  font-size: 28px;
  font-weight: 400;
  font-style: italic;
  color: var(--gold);
}
.le-buy {
  font-family: var(--sans);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--gold);
  border-bottom: 0.5px solid var(--gold);
  padding-bottom: 6px;
}
@media (max-width: 900px) {
  #l-ebooks { padding: 80px 24px; }
  .le-hd { grid-template-columns: 1fr; gap: 20px; margin-bottom: 40px; }
  .le-grid { grid-template-columns: 1fr; }
  .le-card { grid-template-columns: 1fr; gap: 20px; }
}

/* Apply elegant numbers on landing hub */
.hp-it { gap: 8px; align-items: baseline; }

/* ═══════════════════════════════════════════════════
   LANDING SERVICES — INTERACTIVE EDITORIAL ROWS (v2)
═══════════════════════════════════════════════════ */
#l-services {
  padding: 160px 0 0 !important;
}
#l-services .ls-hd { padding: 0 80px; margin-bottom: 80px; }
.ls-split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  background: var(--gold-line);
  border-top: 0.5px solid var(--gold-line);
  border-bottom: 0.5px solid var(--gold-line);
}
.ls-side {
  background: var(--cream);
  padding: 80px 70px;
  display: flex;
  flex-direction: column;
  position: relative;
}
.ls-side + .ls-side {
  margin-left: 1px;
  background: #FBF6F1;
}
.ls-side-hd {
  margin-bottom: 50px;
  padding-bottom: 30px;
  border-bottom: 0.5px solid var(--gold-line);
}
.ls-side-num {
  font-family: var(--serif);
  font-size: 14px;
  font-style: italic;
  color: var(--gold-dk);
  letter-spacing: .1em;
  margin-bottom: 16px;
  display: block;
}
.ls-side-h3 {
  font-family: var(--serif);
  font-size: clamp(40px, 4.5vw, 64px);
  font-weight: 300;
  font-style: italic;
  letter-spacing: -.02em;
  line-height: 1;
  color: var(--ink);
  margin-bottom: 18px;
}
.ls-side-h3 em { color: var(--gold-dk); font-style: italic; }
.ls-side-beauty .ls-side-h3 em { color: var(--accent-rose); }
.ls-side-sub {
  font-size: 14px;
  color: var(--ink2);
  font-weight: 300;
  line-height: 1.65;
  max-width: 460px;
}

/* Interactive rows */
.ls-rows { display: flex; flex-direction: column; }
.ls-row {
  display: grid;
  grid-template-columns: 36px 1fr auto;
  gap: 24px;
  align-items: start;
  padding: 22px 0;
  border-bottom: 0.5px solid rgba(194,178,153,.2);
  cursor: pointer;
  position: relative;
  text-decoration: none;
  color: var(--ink);
  transition: padding .4s ease;
}
.ls-row::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(194,178,153,.13) 0%, transparent 100%);
  opacity: 0;
  transition: opacity .45s ease;
  z-index: 0;
  margin: 0 -30px;
  pointer-events: none;
}
.ls-side-beauty .ls-row::before {
  background: linear-gradient(90deg, rgba(201,150,139,.18) 0%, transparent 100%);
}
.ls-row:hover::before { opacity: 1; }
.ls-row > * { position: relative; z-index: 1; }
.ls-row:hover { padding-left: 6px; }
.ls-row-num {
  font-family: var(--serif);
  font-size: 15px;
  font-style: italic;
  color: rgba(155,142,120,.7);
  padding-top: 6px;
  letter-spacing: .08em;
}
.ls-side-beauty .ls-row-num { color: rgba(201,150,139,.7); }
.ls-row-info { min-width: 0; display: flex; flex-direction: column; }
.ls-row-name {
  font-family: var(--serif);
  font-size: clamp(20px, 1.7vw, 26px);
  font-weight: 400;
  line-height: 1.2;
  letter-spacing: -.005em;
  color: var(--ink);
  margin: 0;
  transition: color .35s ease;
}
.ls-row:hover .ls-row-name { color: var(--gold-dk); }
.ls-side-beauty .ls-row:hover .ls-row-name { color: var(--accent-rose); }
.ls-row-desc {
  font-family: var(--sans);
  font-size: 13px;
  font-weight: 300;
  line-height: 1.65;
  color: var(--ink2);
  max-height: 0;
  opacity: 0;
  overflow: hidden;
  transition: max-height .55s cubic-bezier(.16,1,.3,1), opacity .35s ease, margin-top .4s ease;
  margin: 0;
}
.ls-row:hover .ls-row-desc {
  max-height: 100px;
  opacity: 1;
  margin-top: 10px;
}
.ls-row-right {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 8px;
  padding-top: 4px;
}
.ls-row-price {
  font-family: var(--serif);
  font-size: clamp(22px, 1.9vw, 30px);
  font-weight: 400;
  font-style: italic;
  letter-spacing: -.01em;
  color: var(--ink);
  white-space: nowrap;
  transition: transform .4s cubic-bezier(.16,1,.3,1), color .3s ease;
  transform-origin: right center;
}
.ls-row:hover .ls-row-price {
  transform: scale(1.1);
  color: var(--gold-dk);
}
.ls-side-beauty .ls-row:hover .ls-row-price { color: var(--accent-rose); }
.ls-row-arr {
  font-family: var(--serif);
  font-size: 16px;
  color: var(--gold-dk);
  opacity: 0;
  transform: translateX(-8px);
  transition: opacity .35s ease, transform .45s ease;
}
.ls-row:hover .ls-row-arr { opacity: 1; transform: translateX(0); }
.ls-side-beauty .ls-row-arr { color: var(--accent-rose); }

.ls-foot {
  margin-top: 50px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.ls-foot-btn {
  font-family: var(--sans);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--ink);
  display: inline-flex;
  align-items: center;
  gap: 14px;
  padding: 16px 28px;
  border: 0.5px solid var(--gold);
  transition: all .4s ease;
}
.ls-foot-btn:hover {
  background: var(--ink);
  color: var(--cream);
  border-color: var(--ink);
  gap: 22px;
}
.ls-side-beauty .ls-foot-btn { border-color: var(--accent-rose); }
.ls-side-beauty .ls-foot-btn:hover { background: var(--accent-rose); border-color: var(--accent-rose); color: var(--cream); }
.ls-foot-hint {
  font-family: var(--serif);
  font-style: italic;
  font-size: 13px;
  color: var(--ink2);
}

@media (max-width: 900px) {
  #l-services { padding: 80px 0 0 !important; }
  #l-services .ls-hd { padding: 0 24px; margin-bottom: 50px; }
  .ls-split { grid-template-columns: 1fr; }
  .ls-side { padding: 60px 24px; }
  .ls-row { grid-template-columns: 28px 1fr; gap: 16px; }
  .ls-row::before { margin: 0 -20px; }
  .ls-row-right { display: none; }
  .ls-row-name::after {
    content: ' — ' attr(data-price);
    font-style: italic;
    color: var(--gold-dk);
    font-size: 15px;
  }
  .ls-side-beauty .ls-row-name::after { color: var(--accent-rose); }
  .ls-foot { flex-direction: column; gap: 20px; align-items: stretch; text-align: center; }
}

/* hide old layout */
.ls-grid { display: none !important; }


/* ═══════════════════════════════════════════════════
   FIX: Hero proof numbers (with social icons)
   Italic Cormorant looked weirdly low next to icons
═══════════════════════════════════════════════════ */
.hp-n {
  font-family: var(--sans) !important;
  font-size: 22px !important;
  font-weight: 600 !important;
  font-style: normal !important;
  letter-spacing: -.005em !important;
  line-height: 1 !important;
  color: var(--gold) !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 7px !important;
}
.hp-n svg { display: block; flex-shrink: 0; }
.hp-it {
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  gap: 6px !important;
}
.hp-l {
  font-family: var(--sans);
  font-size: 9px;
  font-weight: 500;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--ink2);
  line-height: 1;
}

/* ═══════════════════════════════════════════════════
   LANDING: FREE EBOOKS (with email capture)
═══════════════════════════════════════════════════ */
.le-section-lbl {
  max-width: 1440px;
  margin: 0 auto 30px;
  font-family: var(--serif);
  font-style: italic;
  font-size: 16px;
  color: var(--gold);
  letter-spacing: .08em;
  text-align: left;
}
.le-grid-free {
  margin-bottom: 40px;
}
.le-free-card {
  background: var(--espresso);
  padding: 50px;
  display: grid;
  grid-template-columns: 80px 1fr;
  gap: 30px;
  color: var(--cream);
  transition: transform .5s cubic-bezier(.16,1,.3,1);
  border-left: 0.5px solid rgba(194,178,153,.2);
}
.le-free-card:hover { transform: translateY(-4px); }
.le-free-num {
  font-family: var(--serif);
  font-size: 56px;
  font-weight: 300;
  font-style: italic;
  color: var(--gold);
  line-height: 1;
  letter-spacing: -.02em;
}
.le-free-body { display: flex; flex-direction: column; }
.le-free-body .le-cat {
  font-family: var(--sans);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 16px;
}
.le-free-body .le-ttl {
  font-family: var(--serif);
  font-size: 24px;
  font-weight: 400;
  line-height: 1.25;
  margin-bottom: 14px;
  color: var(--cream);
}
.le-free-body .le-desc {
  font-size: 13px;
  line-height: 1.65;
  color: rgba(248,244,239,.65);
  font-weight: 300;
  margin-bottom: 24px;
}
.le-free-form {
  display: flex;
  gap: 0;
  border-bottom: 0.5px solid rgba(194,178,153,.3);
}
.le-free-inp {
  flex: 1;
  background: transparent;
  border: none;
  color: var(--cream);
  font-family: var(--sans);
  font-size: 13px;
  padding: 14px 0;
  outline: none;
}
.le-free-inp::placeholder { color: rgba(248,244,239,.4); }
.le-free-btn {
  font-family: var(--sans);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .22em;
  text-transform: uppercase;
  background: transparent;
  border: none;
  color: var(--gold);
  padding: 14px 0 14px 28px;
  cursor: pointer;
  transition: color .3s ease, letter-spacing .3s ease;
}
.le-free-btn:hover { color: var(--cream); letter-spacing: .26em; }
.pc-ok {
  display: none;
  color: var(--gold);
  font-family: var(--sans);
  font-size: 12px;
  margin-top: 12px;
}
@media (max-width: 900px) {
  .le-free-card { grid-template-columns: 1fr; padding: 36px 28px; gap: 16px; }
  .le-free-num { font-size: 40px; }
}

/* ═══════════════════════════════════════════════════
   FIX v2: Hero proof — proper editorial style
   6 items, clean alignment, refined typography
═══════════════════════════════════════════════════ */
.hero-proof {
  display: flex !important;
  flex-wrap: wrap;
  gap: 32px 36px !important;
  align-items: flex-start;
  margin-top: 50px;
}
.hp-it {
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  gap: 8px !important;
  min-width: 0;
}
.hp-n {
  font-family: var(--serif) !important;
  font-size: 30px !important;
  font-weight: 500 !important;
  font-style: normal !important;
  letter-spacing: -.015em !important;
  line-height: 1 !important;
  color: var(--gold) !important;
  display: inline-flex !important;
  align-items: baseline !important;
  gap: 8px !important;
  font-variant-numeric: tabular-nums;
}
.hp-ic-svg {
  width: 16px;
  height: 16px;
  color: var(--gold);
  opacity: .85;
  align-self: center;
  margin-bottom: 2px;
}
.hp-l {
  font-family: var(--sans);
  font-size: 9px;
  font-weight: 500;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--gold-dk);
  line-height: 1;
  white-space: nowrap;
}
@media (max-width: 900px) {
  .hero-proof { gap: 22px 24px !important; margin-top: 36px; }
  .hp-n { font-size: 24px !important; }
}

/* ═══════════════════════════════════════════════════
   Hero proof — magazine-style display serif
═══════════════════════════════════════════════════ */
.hp-n {
  font-family: 'Cormorant Garamond', Georgia, serif !important;
  font-size: 34px !important;
  font-weight: 500 !important;
  font-style: normal !important;
  letter-spacing: -.02em !important;
  line-height: 1 !important;
  color: var(--gold) !important;
  display: inline-flex !important;
  align-items: baseline !important;
  gap: 10px !important;
  font-variant-numeric: tabular-nums lining-nums;
  font-optical-sizing: auto;
}
.hp-ic-svg {
  width: 17px !important;
  height: 17px !important;
  color: var(--gold);
  opacity: .8;
  align-self: center;
  margin-bottom: 1px;
}
.hp-l {
  font-family: var(--sans);
  font-size: 9px;
  font-weight: 600;
  letter-spacing: .3em;
  text-transform: uppercase;
  color: rgba(155,142,120,.85);
  line-height: 1;
}
@media (max-width: 900px) {
  .hp-n { font-size: 26px !important; }
}

/* ═══════════════════════════════════════════════════
   FIX v4: Hero proof — bold sans masthead style
═══════════════════════════════════════════════════ */
.hp-n {
  font-family: 'DM Sans', -apple-system, sans-serif !important;
  font-size: 26px !important;
  font-weight: 700 !important;
  font-style: normal !important;
  letter-spacing: -.01em !important;
  line-height: 1 !important;
  color: var(--gold) !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 10px !important;
  font-variant-numeric: tabular-nums lining-nums;
}
.hp-ic-svg {
  width: 15px !important;
  height: 15px !important;
  color: var(--gold);
  opacity: .75;
  margin-bottom: 0;
}
.hp-l {
  font-family: var(--sans);
  font-size: 9px;
  font-weight: 600;
  letter-spacing: .3em;
  text-transform: uppercase;
  color: rgba(155,142,120,.7);
  line-height: 1;
  margin-top: 2px;
}
@media (max-width: 900px) {
  .hp-n { font-size: 22px !important; }
}

/* ── FAQ on home ── */
#faq { padding: 110px 32px; background: var(--bone); }
.faq-in { max-width: 860px; margin: 0 auto; }
.faq-hd { text-align: center; margin-bottom: 56px; }
.faq-hd .lbl { font-family: var(--sans); font-size: 11px; font-weight: 600; letter-spacing: .34em; text-transform: uppercase; color: var(--gold-text); display: block; margin-bottom: 14px; }
.faq-h2 { font-family: var(--serif); font-size: clamp(36px, 5vw, 56px); font-weight: 500; line-height: 1.15; color: var(--black); margin-bottom: 14px; }
.faq-h2 em { font-style: italic; color: var(--gold-text); }
.faq-sub { font-family: var(--sans); font-size: 16px; line-height: 1.7; color: var(--ink2); max-width: 560px; margin: 0 auto; }
.faq-list { display: flex; flex-direction: column; gap: 12px; }
.faq-item { background: var(--cream); border: 1px solid var(--gold-line); transition: border-color var(--t); }
.faq-item[open] { border-color: var(--gold); }
.faq-item summary { padding: 22px 28px; font-family: var(--serif); font-size: 19px; font-weight: 500; color: var(--black); cursor: pointer; list-style: none; display: flex; justify-content: space-between; align-items: center; gap: 18px; }
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after { content: "+"; font-family: var(--sans); font-size: 26px; color: var(--gold-text); transition: transform .25s; flex-shrink: 0; line-height: 1; }
.faq-item[open] summary::after { transform: rotate(45deg); }
.faq-item p { padding: 0 28px 26px; font-family: var(--sans); font-size: 15px; line-height: 1.75; color: var(--ink); margin: 0; }
.faq-item p a { color: var(--black); border-bottom: 1px solid var(--gold); }
.faq-item p a:hover { border-bottom-color: var(--gold-text); }
@media (max-width: 700px) {
  #faq { padding: 70px 20px; }
  .faq-item summary { padding: 18px 22px; font-size: 17px; }
  .faq-item p { padding: 0 22px 22px; font-size: 14px; }
}

/* Service description blog links */
.sc-link, .bs-link {
  display: inline-block;
  margin-top: 8px;
  font-family: var(--sans);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--gold-text);
  text-decoration: none;
  border-bottom: 1px solid var(--gold-line);
  padding-bottom: 1px;
  transition: color var(--t), border-color var(--t);
}
.sc-link:hover, .bs-link:hover { color: var(--black); border-bottom-color: var(--gold); }

/* Service heading anchors (link to /sluzby/* landing pages) */
.sc-name a, h3[data-price] a {
  color: inherit; text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: border-color var(--t);
}
.sc-name a:hover, h3[data-price] a:hover {
  border-bottom-color: var(--gold);
}
