
@font-face { font-family: "Mortend"; src: url("/fonts/Mortend-Bold.woff2") format("woff2"); font-weight: 700; font-display: swap; }
@font-face { font-family: "Mortend"; src: url("/fonts/Mortend-Regular.woff2") format("woff2"); font-weight: 400; font-display: swap; }
@font-face { font-family: "Mortend"; src: url("/fonts/Mortend-Light.woff2") format("woff2"); font-weight: 300; font-display: swap; }
@font-face { font-family: "BeVietnamPro"; src: url("/fonts/BeVietnamPro-Regular.woff2") format("woff2"); font-weight: 400; font-display: swap; }
@font-face { font-family: "BeVietnamPro"; src: url("/fonts/BeVietnamPro-Medium.woff2") format("woff2"); font-weight: 500; font-display: swap; }
@font-face { font-family: "BeVietnamPro"; src: url("/fonts/BeVietnamPro-SemiBold.woff2") format("woff2"); font-weight: 600; font-display: swap; }
@font-face { font-family: "Ponypoket"; src: url("/fonts/Ponypoket.woff2") format("woff2"); font-weight: 400; font-display: swap; }

:root {
    --c-black: #000000;
    --c-bg: #050505;
    --c-bg-2: #0c0c0c;
    --c-bg-3: #141414;
    --c-fg: #ffffff;
    --c-fg-dim: rgba(255,255,255,0.55);
    --c-fg-dimmer: rgba(255,255,255,0.35);
    --c-fg-faint: rgba(255,255,255,0.12);
    --c-line: rgba(255,255,255,0.08);
    --c-line-strong: rgba(255,255,255,0.18);
    --c-green: #83EC4C;
    --c-green-bright: #9aff5e;
    --c-green-2: #00DA72;
    --c-green-pale: #E2F7D3;
    --c-teal: #008D95;
    --asterisk-green: url("/assets/asterisk_green.png");
  --asterisk-white: url("/assets/asterisk_white.png");
  --asterisk-black: url("/assets/asterisk_black.png");
  --ellipse-green: url("/assets/ellipse_green.png");
  --ellipse-green-2: url("/assets/ellipse_green_2.png");
  --arrow-green: url("/assets/arrow_green.png");
  --rect-green: url("/assets/rect_green.png");
  --speech-green: url("/assets/speech_green.png");
  --heart-green: url("/assets/heart_green.png");
  --ellipse-white: url("/assets/ellipse_white.png");
    --container: 1480px;
    --gutter: clamp(20px, 4vw, 56px);
    --radius: 4px;
    --f-display: 'Mortend', system-ui, sans-serif;
    --f-body: 'BeVietnamPro', system-ui, sans-serif;
    --f-hand: 'Ponypoket', cursive;
    --ease: cubic-bezier(0.65, 0, 0.35, 1);
    --ease-out: cubic-bezier(0.22, 1, 0.36, 1);
    --ease-in: cubic-bezier(0.7, 0, 0.84, 0);
  }
  *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
  html { scroll-behavior: auto; background: var(--c-bg); -webkit-text-size-adjust: 100%; }
  body { font-family: var(--f-body); background: var(--c-bg); color: var(--c-fg); overflow-x: hidden; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; line-height: 1.5; font-weight: 400; font-size: 16px; }
  ::selection { background: var(--c-green); color: var(--c-black); }
  img, svg { max-width: 100%; display: block; }
  a { color: inherit; text-decoration: none; }
  button, input, textarea, select { font: inherit; color: inherit; background: none; border: none; outline: none; }
  button { cursor: pointer; }

  /* Custom cursor (desktop) */
  .cursor { position: fixed; top: 0; left: 0; width: 8px; height: 8px; border-radius: 50%; background: var(--c-green); pointer-events: none; z-index: 9999; transform: translate(-50%, -50%); mix-blend-mode: difference; transition: width 0.3s var(--ease), height 0.3s var(--ease), background 0.3s var(--ease); }
  .cursor.hover { width: 48px; height: 48px; background: transparent; border: 1.5px solid var(--c-green); }
  @media (hover: none), (pointer: coarse) { .cursor { display: none; } }
  @media (hover: hover) and (pointer: fine) { body { cursor: none; } a, button, input, textarea, .interactive { cursor: none; } }

  /* Loader */
  .loader { position: fixed; inset: 0; background: var(--c-black); z-index: 10000; display: flex; align-items: center; justify-content: center; flex-direction: column; gap: 32px; transition: opacity 0.6s var(--ease), visibility 0s 0.6s; }
  .loader.gone { opacity: 0; visibility: hidden; }
  .loader__asterisk { width: 96px; height: 96px; background-image: var(--asterisk-green); background-size: contain; background-repeat: no-repeat; background-position: center; animation: spin 1.4s linear infinite; }
  @keyframes spin { to { transform: rotate(360deg); } }
  .loader__label { font-family: var(--f-display); font-weight: 400; font-size: 11px; letter-spacing: 0.4em; color: var(--c-fg-dim); text-transform: uppercase; }

  /* Typography */
  .display { font-family: var(--f-display); font-weight: 700; text-transform: uppercase; line-height: 0.92; letter-spacing: -0.01em; }
  .hand { font-family: var(--f-hand); font-weight: 400; text-transform: none; letter-spacing: 0; }
  .eyebrow { font-family: var(--f-display); font-weight: 400; font-size: 11px; letter-spacing: 0.32em; text-transform: uppercase; color: var(--c-fg-dim); }

  /* Nav */
  .nav { position: fixed; top: 0; left: 0; right: 0; z-index: 100; padding: 22px var(--gutter); display: flex; align-items: center; justify-content: space-between; gap: 12px; transition: background 0.4s var(--ease), backdrop-filter 0.4s var(--ease), padding 0.4s var(--ease); }
  .nav.scrolled { background: rgba(5,5,5,0.72); backdrop-filter: blur(20px) saturate(140%); -webkit-backdrop-filter: blur(20px) saturate(140%); padding: 14px var(--gutter); border-bottom: 1px solid var(--c-line); }
  .nav__brand { display: flex; align-items: center; gap: 12px; font-family: var(--f-display); font-weight: 700; font-size: 22px; letter-spacing: 0.01em; flex-shrink: 0; }
  .nav__brand-mark { width: 28px; height: 28px; background-image: var(--asterisk-green); background-size: contain; background-repeat: no-repeat; background-position: center; flex-shrink: 0; }
  .nav__brand-sub { font-family: var(--f-display); font-weight: 400; font-size: 9px; letter-spacing: 0.22em; color: var(--c-fg-dim); margin-left: 8px; border-left: 1px solid var(--c-line-strong); padding-left: 12px; }
  @media (max-width: 720px) { .nav__brand-sub { display: none; } .nav__brand { font-size: 18px; } .nav__brand-mark { width: 22px; height: 22px; } }
  .nav__links { display: flex; gap: 28px; align-items: center; font-family: var(--f-display); font-weight: 400; font-size: 12px; letter-spacing: 0.18em; text-transform: uppercase; }
  .nav__links a { color: var(--c-fg-dim); transition: color 0.3s var(--ease); position: relative; }
  .nav__links a:hover { color: var(--c-fg); }
  .nav__links a.cta { color: var(--c-fg); position: relative; padding: 10px 20px; white-space: nowrap; }
  .nav__links a.cta .ellipse { position: absolute; inset: -8px -14px; background-image: var(--ellipse-green); background-size: 100% 100%; background-repeat: no-repeat; transition: transform 0.4s var(--ease); pointer-events: none; }
  .nav__links a.cta:hover .ellipse { transform: rotate(-3deg) scale(1.05); }
  @media (max-width: 880px) { .nav__links { gap: 14px; } .nav__links a:not(.cta) { display: none; } }
  @media (max-width: 520px) {
    .nav__links a.cta { font-size: 10px; padding: 8px 14px; }
    .nav__links a.cta .ellipse { inset: -4px -8px; }
  }

  /* Hero */
  .hero { position: relative; min-height: 100vh; min-height: 100svh; padding: 110px var(--gutter) 40px; display: flex; flex-direction: column; justify-content: center; overflow: hidden; }
  .hero__bg-asterisk { position: absolute; top: 50%; right: -18vw; transform: translateY(-40%); width: 60vw; height: 60vw; max-width: 760px; max-height: 760px; background-image: var(--asterisk-green); background-size: contain; background-repeat: no-repeat; background-position: center; opacity: 0.85; will-change: transform; pointer-events: none; }
  @media (min-width: 1100px) { .hero__bg-asterisk { right: -10vw; } }
  .hero__inner { position: relative; z-index: 1; max-width: var(--container); margin: 0 auto; width: 100%; }
  .hero__eyebrow { margin-bottom: 20px; opacity: 0; transform: translateY(20px); animation: heroFadeIn 0.9s var(--ease-out) 0.2s forwards; }
  .hero__title { font-size: clamp(34px, 7.5vw, 132px); margin-bottom: 28px; max-width: 14ch; line-height: 0.95; }
  .hero__title .line { display: block; overflow: hidden; }
  .hero__title .line span { display: inline-block; will-change: transform; transform: translateY(110%); animation: heroLineUp 1.1s var(--ease-out) forwards; }
  .hero__title .line:nth-child(1) span { animation-delay: 0.30s; }
  .hero__title .line:nth-child(2) span { animation-delay: 0.40s; }
  .hero__title .line:nth-child(3) span { animation-delay: 0.50s; }
  .hero__title .line:nth-child(4) span { animation-delay: 0.60s; }
  .hero__title em { font-style: normal; color: var(--c-green); }
  .hero__sub { font-family: var(--f-body); font-weight: 400; font-size: clamp(15px, 1.3vw, 18px); line-height: 1.5; max-width: 56ch; color: rgba(255,255,255,0.75); margin-bottom: 32px; opacity: 0; transform: translateY(20px); animation: heroFadeIn 0.9s var(--ease-out) 0.95s forwards; }
  .hero__sub strong { color: var(--c-fg); font-weight: 600; }
  .hero__cta-row { display: flex; align-items: center; gap: 24px; flex-wrap: wrap; opacity: 0; transform: translateY(20px); animation: heroFadeIn 0.9s var(--ease-out) 1.15s forwards; }
  @keyframes heroFadeIn { to { opacity: 1; transform: translateY(0); } }
  @keyframes heroLineUp { to { transform: translateY(0); } }
  .hero.gsap-ready .hero__eyebrow,
  .hero.gsap-ready .hero__sub,
  .hero.gsap-ready .hero__cta-row { animation: none; }
  .hero.gsap-ready .hero__title .line span { animation: none; }

  /* Buttons */
  .btn { display: inline-flex; align-items: center; gap: 14px; padding: 18px 32px; background: var(--c-green); color: var(--c-black); font-family: var(--f-display); font-weight: 700; font-size: 13px; letter-spacing: 0.18em; text-transform: uppercase; border-radius: 100px; transition: transform 0.3s var(--ease), background 0.3s var(--ease); will-change: transform; }
  .btn:hover { transform: translateY(-2px); background: var(--c-green-bright); }
  .btn__arrow { width: 18px; height: 12px; transition: transform 0.3s var(--ease); }
  .btn:hover .btn__arrow { transform: translateX(4px); }
  .btn--ghost { background: transparent; color: var(--c-fg); border: 1px solid var(--c-line-strong); }
  .btn--ghost:hover { background: transparent; border-color: var(--c-green); color: var(--c-green); }

  /* Marquee */
  .marquee { overflow: hidden; border-top: 1px solid var(--c-line); border-bottom: 1px solid var(--c-line); padding: 24px 0; background: var(--c-bg); position: relative; }
  .marquee__track { display: flex; gap: 56px; width: max-content; animation: marquee 38s linear infinite; will-change: transform; }
  .marquee__item { display: flex; align-items: center; gap: 56px; font-family: var(--f-display); font-weight: 700; font-size: clamp(36px, 6vw, 92px); line-height: 1; letter-spacing: -0.01em; text-transform: uppercase; color: var(--c-fg); white-space: nowrap; }
  .marquee__item em { font-style: normal; color: var(--c-green); }
  .marquee__dot { width: 56px; height: 56px; background-image: var(--asterisk-green); background-size: contain; background-repeat: no-repeat; background-position: center; flex-shrink: 0; }
  @keyframes marquee { from { transform: translateX(0); } to { transform: translateX(-50%); } }

  /* Intro */
  .intro { padding: clamp(80px, 12vw, 180px) var(--gutter); max-width: var(--container); margin: 0 auto; }
  .intro__head { display: grid; grid-template-columns: 1fr 1.4fr; gap: clamp(40px, 6vw, 100px); align-items: start; margin-bottom: clamp(60px, 10vw, 140px); }
  @media (max-width: 880px) { .intro__head { grid-template-columns: 1fr; gap: 30px; } }
  .intro__eyebrow { display: flex; align-items: center; gap: 14px; margin-bottom: 0; }
  .intro__eyebrow::before { content: ""; width: 28px; height: 28px; background-image: var(--asterisk-green); background-size: contain; background-repeat: no-repeat; }
  .intro__title { font-size: clamp(36px, 5.5vw, 80px); margin-bottom: 32px; line-height: 0.95; }
  .intro__title em { font-style: normal; color: var(--c-green); }
  .intro__copy { font-size: clamp(16px, 1.3vw, 19px); line-height: 1.55; color: rgba(255,255,255,0.78); max-width: 58ch; }
  .intro__copy p + p { margin-top: 1em; }
  .stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--c-line); border: 1px solid var(--c-line); }
  @media (max-width: 880px) { .stats { grid-template-columns: repeat(2, 1fr); } }
  .stat { padding: 40px 28px; background: var(--c-bg); display: flex; flex-direction: column; gap: 12px; }
  .stat__value { font-family: var(--f-display); font-weight: 700; font-size: clamp(40px, 5vw, 72px); line-height: 1; color: var(--c-fg); }
  .stat__value em { font-style: normal; color: var(--c-green); }
  .stat__label { font-family: var(--f-display); font-weight: 400; font-size: 11px; letter-spacing: 0.24em; text-transform: uppercase; color: var(--c-fg-dim); }

  /* Index/TOC */
  /* Mini intro — the short bridge between hero/marquee and capabilities */
  .intro-mini { padding: clamp(60px, 8vw, 100px) var(--gutter); max-width: var(--container); margin: 0 auto; }
  .intro-mini__inner { max-width: 64ch; }
  .intro-mini__lede { font-family: var(--f-body); font-size: clamp(18px, 1.8vw, 26px); line-height: 1.4; color: rgba(255,255,255,0.82); font-weight: 400; }
  .intro-mini__lede em { font-style: normal; color: var(--c-green); font-weight: 500; }

  /* Index / Capabilities — pinned-headline scroll experience */
  .index { padding: clamp(80px, 10vw, 140px) var(--gutter) clamp(80px, 10vw, 140px); max-width: var(--container); margin: 0 auto; position: relative; }
  .index__wrap { display: grid; grid-template-columns: minmax(340px, 0.9fr) 1.4fr; gap: clamp(40px, 6vw, 100px); align-items: start; }
  @media (max-width: 980px) { .index__wrap { grid-template-columns: 1fr; gap: 40px; } }

  /* Left column — pinned headline + counter */
  .index__panel { position: sticky; top: 110px; align-self: start; padding-bottom: 40px; }
  @media (max-width: 980px) { .index__panel { position: static; padding-bottom: 0; } }
  .index__eyebrow { display: flex; align-items: center; gap: 14px; font-family: var(--f-display); font-size: 11px; letter-spacing: 0.32em; text-transform: uppercase; color: var(--c-fg-dim); margin-bottom: 28px; }
  .index__eyebrow::before { content: ""; width: 28px; height: 28px; background-image: var(--asterisk-green); background-size: contain; background-repeat: no-repeat; }
  .index__title { font-family: var(--f-display); font-weight: 700; text-transform: uppercase; font-size: clamp(48px, 6.5vw, 96px); line-height: 0.9; letter-spacing: -0.01em; margin-bottom: 32px; }
  .index__title em { font-style: normal; color: var(--c-green); }
  .index__counter { font-family: var(--f-display); font-weight: 700; font-size: clamp(120px, 18vw, 240px); line-height: 0.85; color: var(--c-green); letter-spacing: -0.02em; margin-bottom: 16px; display: flex; align-items: flex-start; gap: 0; }
  @media (max-width: 980px) { .index__counter { display: none; } }
  .index__counter-current { font-variant-numeric: tabular-nums; display: inline-block; min-width: 1.4em; transition: transform 0.5s var(--ease-out); }
  .index__counter-divider { font-size: 0.4em; padding-top: 0.15em; opacity: 0.35; }
  .index__counter-total { font-size: 0.4em; padding-top: 0.15em; opacity: 0.35; font-variant-numeric: tabular-nums; }
  .index__counter-current.flip { animation: counterFlip 0.5s var(--ease-out); }
  @keyframes counterFlip {
    0%   { transform: translateY(0); opacity: 1; }
    49%  { transform: translateY(-30%); opacity: 0; }
    51%  { transform: translateY(30%); opacity: 0; }
    100% { transform: translateY(0); opacity: 1; }
  }
  .index__note { font-family: var(--f-hand); font-size: clamp(16px, 1.4vw, 22px); color: var(--c-green); line-height: 1.3; transform: rotate(-2deg); max-width: 24ch; margin-top: 12px; }
  .index__progress { width: 100%; height: 2px; background: var(--c-line); margin-top: 28px; overflow: hidden; border-radius: 2px; }
  .index__progress-bar { height: 100%; background: var(--c-green); width: 0%; transition: width 0.5s var(--ease-out); }

  /* Right column — the scrolling list */
  .index__list { list-style: none; }
  .index__row { display: grid; grid-template-columns: 56px 1fr auto; gap: 24px; align-items: center; padding: clamp(28px, 3.5vw, 44px) 0; border-bottom: 1px solid var(--c-line); cursor: pointer; position: relative; will-change: transform; }
  .index__row:first-child { border-top: 1px solid var(--c-line); }

  /* Background sweep on hover */
  .index__row::before {
    content: "";
    position: absolute;
    inset: 0 -24px;
    background: linear-gradient(90deg, transparent, rgba(131,236,76,0.06) 30%, transparent 90%);
    opacity: 0;
    transition: opacity 0.5s var(--ease);
    pointer-events: none;
    border-radius: 4px;
  }
  .index__row:hover::before { opacity: 1; }

  .index__num {
    font-family: var(--f-display);
    font-weight: 700;
    font-size: 13px;
    letter-spacing: 0.18em;
    color: var(--c-fg-dimmer);
    transition: color 0.4s var(--ease), transform 0.4s var(--ease);
    font-variant-numeric: tabular-nums;
  }
  .index__row:hover .index__num { color: var(--c-green); transform: translateX(4px); }

  .index__name {
    font-family: var(--f-display);
    font-weight: 700;
    font-size: clamp(26px, 3.4vw, 48px);
    text-transform: uppercase;
    letter-spacing: -0.015em;
    line-height: 0.95;
    color: var(--c-fg);
    transition: color 0.4s var(--ease), letter-spacing 0.5s var(--ease-out);
    transform-origin: left center;
  }
  .index__name em { font-style: normal; color: var(--c-green); transition: color 0.4s var(--ease); }
  .index__row:hover .index__name { letter-spacing: 0.005em; }
  .index__row:hover .index__name em { color: var(--c-green-bright); }

  /* Word-by-word reveal */
  .index__name-word-wrap {
    display: inline-block;
    overflow: hidden;
    vertical-align: bottom;
    line-height: 0.95;
    padding-bottom: 0.05em;
  }
  .index__name-word {
    display: inline-block;
    transform: translateY(120%);
    opacity: 0;
    transition: transform 0.9s var(--ease-out), opacity 0.6s var(--ease-out);
  }
  .index__row.in-view .index__name-word {
    transform: translateY(0);
    opacity: 1;
  }
  .index__row.in-view .index__name-word-wrap:nth-child(1) .index__name-word { transition-delay: 0.05s; }
  .index__row.in-view .index__name-word-wrap:nth-child(2) .index__name-word { transition-delay: 0.14s; }
  .index__row.in-view .index__name-word-wrap:nth-child(3) .index__name-word { transition-delay: 0.23s; }
  .index__row.in-view .index__name-word-wrap:nth-child(4) .index__name-word { transition-delay: 0.32s; }

  /* Hover preview: tagline appears under the name */
  .index__name-wrap {
    display: flex;
    flex-direction: column;
    gap: 0;
    min-width: 0;
  }
  .index__tagline {
    font-family: var(--f-body);
    font-size: clamp(13px, 1.1vw, 15px);
    color: var(--c-fg-dim);
    line-height: 1.4;
    max-height: 0;
    opacity: 0;
    transform: translateY(-6px);
    transition: max-height 0.5s var(--ease-out), opacity 0.4s var(--ease-out), transform 0.5s var(--ease-out), margin-top 0.5s var(--ease-out);
    margin-top: 0;
  }
  .index__row:hover .index__tagline {
    max-height: 80px;
    opacity: 1;
    transform: translateY(0);
    margin-top: 12px;
  }

  /* Arrow / "Explore" pill — label is absolutely positioned so it doesn't reserve width */
  .index__cta {
    display: flex;
    align-items: center;
    gap: 0;
    position: relative;
  }
  .index__cta-label {
    font-family: var(--f-display);
    font-weight: 700;
    font-size: 11px;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--c-green);
    opacity: 0;
    transform: translateX(20px);
    transition: opacity 0.4s var(--ease), transform 0.4s var(--ease);
    white-space: nowrap;
    position: absolute;
    right: calc(100% + 14px);
    top: 50%;
    margin-top: -7px;
    pointer-events: none;
  }
  .index__row:hover .index__cta-label { opacity: 1; transform: translateX(0); }

  .index__arrow {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    border: 1px solid var(--c-line-strong);
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.5s var(--ease);
    flex-shrink: 0;
  }
  .index__row:hover .index__arrow {
    background: var(--c-green);
    border-color: var(--c-green);
    transform: rotate(-45deg) scale(1.05);
  }
  .index__arrow svg { width: 14px; height: 14px; transition: color 0.4s var(--ease); color: var(--c-fg-dim); }
  .index__row:hover .index__arrow svg { color: var(--c-black); }

  /* Active state (when a row is being viewed/at scroll mark) */
  .index__row.is-active .index__name { color: var(--c-green); }
  .index__row.is-active .index__num { color: var(--c-green); }

  @media (max-width: 980px) {
    .index__row { grid-template-columns: 40px 1fr 44px; gap: 16px; }
    .index__cta-label { display: none; }
    .index__name { font-size: clamp(24px, 6vw, 40px); }
    .index__row:hover .index__tagline { max-height: 80px; }
  }
  @media (max-width: 520px) {
    .index__name { font-size: 22px; }
  }

  /* Product */
  .product { position: relative; padding: clamp(80px, 12vw, 160px) var(--gutter); border-top: 1px solid var(--c-line); overflow: hidden; }
  .product__inner { max-width: var(--container); margin: 0 auto; position: relative; z-index: 1; }
  .product__head { display: grid; grid-template-columns: 1fr; gap: 16px; margin-bottom: clamp(40px, 6vw, 80px); position: relative; }
  .product__count { font-family: var(--f-display); font-weight: 400; font-size: 11px; letter-spacing: 0.32em; color: var(--c-fg-dimmer); margin-bottom: 4px; }
  .product__name { font-size: clamp(56px, 12vw, 200px); line-height: 0.88; margin-left: -0.06em; color: var(--c-fg); }
  .product__name em { font-style: normal; color: var(--c-green); }
  .product__tagline { font-family: var(--f-body); font-size: clamp(18px, 1.8vw, 24px); line-height: 1.4; color: rgba(255,255,255,0.82); max-width: 50ch; margin-top: 16px; font-weight: 400; }
  .product__tagline em { font-style: normal; color: var(--c-green); font-weight: 500; }
  .product__body { display: grid; grid-template-columns: 1.1fr 1fr; gap: clamp(40px, 6vw, 80px); align-items: start; }
  @media (max-width: 980px) { .product__body { grid-template-columns: 1fr; } }
  .product__visual { position: relative; aspect-ratio: 4 / 3; background: var(--c-bg-2); border-radius: var(--radius); overflow: hidden; border: 1px solid var(--c-line); }
  .product__visual img { width: 100%; height: 100%; object-fit: cover; transform: scale(1.08); transition: transform 1.2s var(--ease-out); }
  .product.is-visible .product__visual img { transform: scale(1); }
  .product__visual-placeholder { position: absolute; inset: 0; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 16px; background: linear-gradient(135deg, var(--c-bg-2) 0%, var(--c-bg-3) 100%); color: var(--c-fg-dim); text-align: center; padding: 20px; }
  .product__visual-placeholder::before { content: ""; width: 80px; height: 80px; background-image: var(--asterisk-green); background-size: contain; background-repeat: no-repeat; opacity: 0.3; }
  .product__visual-placeholder span { font-family: var(--f-display); font-size: 10px; letter-spacing: 0.3em; text-transform: uppercase; }
  .product__visual::before, .product__visual::after { content: ""; position: absolute; width: 24px; height: 24px; border: 1.5px solid var(--c-green); z-index: 2; opacity: 0; transition: opacity 0.6s var(--ease) 0.4s; }
  .product__visual::before { top: 12px; left: 12px; border-right: none; border-bottom: none; }
  .product__visual::after { bottom: 12px; right: 12px; border-left: none; border-top: none; }
  .product.is-visible .product__visual::before, .product.is-visible .product__visual::after { opacity: 1; }

  .product__content { padding-top: 8px; }
  .product__section-label { font-family: var(--f-display); font-weight: 400; font-size: 11px; letter-spacing: 0.32em; color: var(--c-green); text-transform: uppercase; margin-bottom: 18px; display: flex; align-items: center; gap: 12px; }
  .product__section-label::before { content: ""; width: 28px; height: 1px; background: var(--c-green); }
  .product__points { list-style: none; margin-bottom: 40px; }
  .product__point { display: flex; gap: 16px; padding: 14px 0; border-bottom: 1px solid var(--c-line); font-size: 16px; line-height: 1.4; color: rgba(255,255,255,0.88); }
  .product__point::before { content: ""; flex-shrink: 0; width: 18px; height: 18px; background-image: var(--asterisk-green); background-size: contain; background-repeat: no-repeat; background-position: center; margin-top: 2px; }
  .product__uses { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 8px; }
  .product__use { padding: 8px 16px; border: 1px solid var(--c-line-strong); border-radius: 100px; font-family: var(--f-display); font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase; color: rgba(255,255,255,0.78); transition: all 0.3s var(--ease); }
  .product__use:hover { border-color: var(--c-green); color: var(--c-green); }

  .product__specs { margin-top: 56px; background: var(--c-bg-2); border: 1px solid var(--c-line); border-radius: var(--radius); overflow: hidden; }
  .product__specs-head { display: flex; align-items: center; justify-content: space-between; padding: 18px 24px; border-bottom: 1px solid var(--c-line); background: var(--c-bg-3); cursor: pointer; }
  .product__specs-head h4 { font-family: var(--f-display); font-size: 11px; letter-spacing: 0.3em; text-transform: uppercase; color: var(--c-fg); font-weight: 400; }
  .product__specs-toggle { font-family: var(--f-display); font-size: 10px; letter-spacing: 0.2em; color: var(--c-fg-dim); text-transform: uppercase; display: flex; align-items: center; gap: 8px; }
  .product__specs-toggle::after { content: ""; width: 8px; height: 8px; border-right: 1.5px solid currentColor; border-bottom: 1.5px solid currentColor; transform: rotate(45deg) translate(-2px, -2px); transition: transform 0.3s var(--ease); }
  .product__specs.is-open .product__specs-toggle::after { transform: rotate(-135deg) translate(-2px, -2px); }
  .product__specs-body { display: grid; grid-template-columns: 1fr 1fr; gap: 0; overflow: hidden; max-height: 0; transition: max-height 0.5s var(--ease); }
  .product__specs.is-open .product__specs-body { max-height: 1200px; }
  @media (max-width: 640px) { .product__specs-body { grid-template-columns: 1fr; } }
  .spec { display: flex; justify-content: space-between; align-items: baseline; gap: 16px; padding: 14px 24px; border-top: 1px solid var(--c-line); border-right: 1px solid var(--c-line); font-size: 13.5px; }
  .spec:nth-child(2n) { border-right: none; }
  @media (max-width: 640px) { .spec { border-right: none; } }
  .spec__label { color: var(--c-fg-dim); flex-shrink: 0; }
  .spec__value { color: var(--c-fg); text-align: right; font-variant-numeric: tabular-nums; font-weight: 500; }

  /* Magic break */
  .magic { background: var(--c-green-pale); color: var(--c-black); padding: clamp(80px, 12vw, 160px) var(--gutter); position: relative; overflow: hidden; }
  .magic__inner { max-width: var(--container); margin: 0 auto; position: relative; z-index: 1; }
  .magic__quote { font-family: var(--f-display); font-weight: 700; font-size: clamp(32px, 5vw, 76px); line-height: 0.98; letter-spacing: -0.01em; text-transform: uppercase; max-width: 22ch; color: var(--c-black); }
  .magic__quote em { font-style: normal; color: #00a635; position: relative; display: inline-block; }
  .magic__sub { margin-top: 40px; font-size: clamp(15px, 1.2vw, 18px); line-height: 1.55; max-width: 56ch; color: rgba(0,0,0,0.7); }
  .magic__asterisk { position: absolute; top: 50%; right: -10vw; transform: translateY(-50%) rotate(0); width: 60vw; height: 60vw; max-width: 700px; max-height: 700px; background-image: var(--asterisk-black); background-size: contain; background-repeat: no-repeat; background-position: center; opacity: 0.08; will-change: transform; pointer-events: none; }

  /* Contact */
  .contact { padding: clamp(80px, 14vw, 200px) var(--gutter); background: var(--c-bg); position: relative; overflow: hidden; }
  .contact__inner { max-width: var(--container); margin: 0 auto; text-align: center; position: relative; z-index: 1; }
  .contact__heart { width: 80px; height: 80px; background-image: var(--heart-green); background-size: contain; background-repeat: no-repeat; background-position: center; margin: 0 auto 32px; transform-origin: center; animation: heartbeat 1.8s ease-in-out infinite; }
  @keyframes heartbeat { 0%, 100% { transform: scale(1); } 20% { transform: scale(1.12); } 40% { transform: scale(1); } 60% { transform: scale(1.08); } }
  .contact__title { font-size: clamp(40px, 8vw, 120px); margin-bottom: 24px; line-height: 0.95; }
  .contact__title em { font-style: normal; color: var(--c-green); }
  .contact__sub { font-size: clamp(16px, 1.3vw, 19px); line-height: 1.55; color: rgba(255,255,255,0.7); max-width: 52ch; margin: 0 auto 48px; }
  .contact__email { display: inline-block; font-family: var(--f-display); font-weight: 700; font-size: clamp(20px, 2.5vw, 32px); text-transform: uppercase; letter-spacing: -0.005em; color: var(--c-fg); padding: 8px 0; border-bottom: 2px solid var(--c-green); transition: color 0.3s var(--ease); }
  .contact__email:hover { color: var(--c-green); }
  .contact__bg-asterisk { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); width: 90vw; height: 90vw; max-width: 1000px; max-height: 1000px; background-image: var(--asterisk-green); background-size: contain; background-repeat: no-repeat; background-position: center; opacity: 0.04; will-change: transform; pointer-events: none; }

  /* Footer */
  .footer { padding: 40px var(--gutter); border-top: 1px solid var(--c-line); display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 16px; font-family: var(--f-display); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--c-fg-dim); }
  .footer__brand { display: flex; align-items: center; gap: 10px; color: var(--c-fg); }
  .footer__brand-mark { width: 16px; height: 16px; background-image: var(--asterisk-green); background-size: contain; background-repeat: no-repeat; }
  .footer__admin { color: var(--c-fg-dimmer); transition: color 0.3s var(--ease); }
  .footer__admin:hover { color: var(--c-green); }

  /* Admin */
  .admin { position: fixed; inset: 0; z-index: 9000; background: var(--c-bg); overflow-y: auto; display: none; }
  .admin.is-open { display: block; }
  .admin__header { position: sticky; top: 0; z-index: 5; background: rgba(5,5,5,0.92); backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px); padding: 16px var(--gutter); border-bottom: 1px solid var(--c-line); display: flex; justify-content: space-between; align-items: center; gap: 16px; flex-wrap: wrap; }
  .admin__title { font-family: var(--f-display); font-weight: 700; font-size: 18px; text-transform: uppercase; letter-spacing: 0.02em; display: flex; align-items: center; gap: 12px; }
  .admin__title::before { content: ""; width: 24px; height: 24px; background-image: var(--asterisk-green); background-size: contain; background-repeat: no-repeat; }
  .admin__title small { font-weight: 400; font-size: 11px; letter-spacing: 0.3em; color: var(--c-fg-dim); margin-left: 8px; }
  .admin__actions { display: flex; gap: 12px; align-items: center; flex-wrap: wrap; }
  .admin__btn { padding: 10px 18px; border-radius: 100px; font-family: var(--f-display); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; transition: all 0.3s var(--ease); background: transparent; color: var(--c-fg-dim); border: 1px solid var(--c-line-strong); }
  .admin__btn:hover { color: var(--c-fg); border-color: var(--c-fg-dim); }
  .admin__btn--primary { background: var(--c-green); color: var(--c-black); border-color: var(--c-green); font-weight: 700; }
  .admin__btn--primary:hover { background: var(--c-green-bright); color: var(--c-black); border-color: var(--c-green-bright); }
  .admin__btn--danger { color: #ff6b6b; border-color: rgba(255,107,107,0.3); }
  .admin__btn--danger:hover { color: #ff6b6b; border-color: #ff6b6b; background: rgba(255,107,107,0.08); }
  .admin__layout { display: grid; grid-template-columns: 320px 1fr; min-height: calc(100vh - 73px); }
  @media (max-width: 880px) { .admin__layout { grid-template-columns: 1fr; } }
  .admin__sidebar { border-right: 1px solid var(--c-line); padding: 20px 0; background: var(--c-bg-2); }
  @media (max-width: 880px) { .admin__sidebar { border-right: none; border-bottom: 1px solid var(--c-line); } }
  .admin__sidebar-label { padding: 0 24px 12px; font-family: var(--f-display); font-size: 10px; letter-spacing: 0.28em; text-transform: uppercase; color: var(--c-fg-dimmer); }
  .admin__list { list-style: none; max-height: calc(100vh - 220px); overflow-y: auto; }
  .admin__list-item { padding: 14px 24px; border-left: 2px solid transparent; cursor: pointer; transition: all 0.2s var(--ease); display: flex; align-items: center; justify-content: space-between; gap: 12px; font-family: var(--f-display); font-size: 13px; letter-spacing: 0.04em; text-transform: uppercase; color: var(--c-fg-dim); }
  .admin__list-item:hover { background: var(--c-bg-3); color: var(--c-fg); }
  .admin__list-item.is-active { border-left-color: var(--c-green); background: var(--c-bg-3); color: var(--c-fg); }
  .admin__list-num { font-size: 10px; color: var(--c-fg-dimmer); font-weight: 400; letter-spacing: 0.2em; }
  .admin__add { width: calc(100% - 32px); margin: 16px; padding: 14px; border: 1px dashed var(--c-line-strong); background: transparent; color: var(--c-fg-dim); border-radius: var(--radius); font-family: var(--f-display); font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; transition: all 0.3s var(--ease); }
  .admin__add:hover { border-color: var(--c-green); color: var(--c-green); }
  .admin__main { padding: 32px var(--gutter); }
  .admin__form { max-width: 760px; }
  .admin__field { margin-bottom: 24px; }
  .admin__field label { display: block; font-family: var(--f-display); font-size: 10px; letter-spacing: 0.28em; text-transform: uppercase; color: var(--c-fg-dim); margin-bottom: 8px; }
  .admin__field input[type="text"], .admin__field textarea { width: 100%; padding: 14px 16px; background: var(--c-bg-2); border: 1px solid var(--c-line-strong); border-radius: var(--radius); color: var(--c-fg); font-family: var(--f-body); font-size: 15px; transition: border-color 0.2s var(--ease); }
  .admin__field input[type="text"]:focus, .admin__field textarea:focus { border-color: var(--c-green); }
  .admin__field textarea { resize: vertical; min-height: 100px; }
  .admin__field-help { font-size: 12px; color: var(--c-fg-dimmer); margin-top: 6px; }
  .admin__image-drop { border: 2px dashed var(--c-line-strong); border-radius: var(--radius); padding: 32px; text-align: center; color: var(--c-fg-dim); transition: all 0.3s var(--ease); cursor: pointer; position: relative; }
  .admin__image-drop:hover, .admin__image-drop.is-dragging { border-color: var(--c-green); color: var(--c-green); background: rgba(131,236,76,0.04); }
  .admin__image-drop input { display: none; }
  .admin__image-drop-preview { max-width: 100%; max-height: 320px; margin: 0 auto 12px; border-radius: var(--radius); display: none; }
  .admin__image-drop.has-image .admin__image-drop-preview { display: block; }
  .admin__image-drop.has-image .admin__image-drop-text { font-size: 12px; }
  .admin__image-drop-text { font-family: var(--f-display); font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase; }
  .admin__image-drop small { display: block; margin-top: 8px; font-size: 11px; letter-spacing: 0.05em; color: var(--c-fg-dimmer); text-transform: none; font-family: var(--f-body); }
  .admin__row-group { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
  @media (max-width: 640px) { .admin__row-group { grid-template-columns: 1fr; } }
  .admin__repeater { display: flex; flex-direction: column; gap: 8px; }
  .admin__repeater-item { display: flex; gap: 8px; align-items: center; }
  .admin__repeater-item input { flex: 1; }
  .admin__repeater-remove { width: 36px; height: 36px; flex-shrink: 0; border-radius: var(--radius); border: 1px solid var(--c-line); color: var(--c-fg-dim); font-size: 18px; line-height: 1; transition: all 0.2s var(--ease); }
  .admin__repeater-remove:hover { border-color: #ff6b6b; color: #ff6b6b; }
  .admin__repeater-add { padding: 10px 14px; background: transparent; border: 1px dashed var(--c-line-strong); border-radius: var(--radius); color: var(--c-fg-dim); font-family: var(--f-display); font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase; margin-top: 4px; transition: all 0.2s var(--ease); align-self: flex-start; }
  .admin__repeater-add:hover { border-color: var(--c-green); color: var(--c-green); }
  .admin__specs-row { display: grid; grid-template-columns: 1fr 1fr 40px; gap: 8px; align-items: center; }
  .admin__footer { margin-top: 32px; padding-top: 24px; border-top: 1px solid var(--c-line); display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 16px; }
  .admin__order-controls { display: flex; gap: 8px; }
  .admin__toast { position: fixed; bottom: 30px; left: 50%; transform: translateX(-50%) translateY(20px); background: var(--c-green); color: var(--c-black); padding: 14px 24px; border-radius: 100px; font-family: var(--f-display); font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase; font-weight: 700; opacity: 0; transition: all 0.3s var(--ease); z-index: 9999; pointer-events: none; }
  .admin__toast.is-visible { opacity: 1; transform: translateX(-50%) translateY(0); }
  .admin__empty { padding: 80px 20px; text-align: center; color: var(--c-fg-dim); }
  .admin__empty h3 { font-family: var(--f-display); font-size: 18px; text-transform: uppercase; margin-bottom: 12px; color: var(--c-fg); }

  /* Login */
  .login { position: fixed; inset: 0; background: rgba(0,0,0,0.92); backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px); z-index: 8500; display: none; align-items: center; justify-content: center; padding: 20px; }
  .login.is-open { display: flex; }
  .login__box { width: 100%; max-width: 440px; background: var(--c-bg-2); border: 1px solid var(--c-line); border-radius: var(--radius); padding: 48px 40px; text-align: center; }
  .login__asterisk { width: 56px; height: 56px; background-image: var(--asterisk-green); background-size: contain; background-repeat: no-repeat; margin: 0 auto 24px; }
  .login__title { font-family: var(--f-display); font-weight: 700; font-size: 24px; text-transform: uppercase; margin-bottom: 8px; }
  .login__sub { font-size: 13px; color: var(--c-fg-dim); margin-bottom: 28px; }
  .login__input { width: 100%; padding: 16px; background: var(--c-bg); border: 1px solid var(--c-line-strong); border-radius: var(--radius); color: var(--c-fg); font-family: var(--f-body); font-size: 15px; text-align: center; letter-spacing: 0.1em; margin-bottom: 16px; transition: border-color 0.2s var(--ease); }
  .login__input:focus { border-color: var(--c-green); }
  .login__input.is-error { border-color: #ff6b6b; animation: shake 0.4s; }
  @keyframes shake { 0%, 100% { transform: translateX(0); } 25% { transform: translateX(-6px); } 75% { transform: translateX(6px); } }
  .login__submit { width: 100%; padding: 16px; background: var(--c-green); color: var(--c-black); border-radius: var(--radius); font-family: var(--f-display); font-weight: 700; font-size: 12px; letter-spacing: 0.24em; text-transform: uppercase; transition: background 0.2s var(--ease); }
  .login__submit:hover { background: var(--c-green-bright); }
  .login__close { margin-top: 16px; color: var(--c-fg-dim); font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; font-family: var(--f-display); }
  .login__close:hover { color: var(--c-fg); }

  /* Animation utility classes */
  .fade-up { opacity: 0; transform: translateY(40px); transition: opacity 1s var(--ease-out), transform 1s var(--ease-out); }
  .fade-up.is-visible { opacity: 1; transform: translateY(0); }
  .reveal-line { overflow: hidden; }
  .reveal-line > * { display: inline-block; transform: translateY(110%); transition: transform 1s var(--ease-out); }
  .reveal-line.is-visible > * { transform: translateY(0); }
  .stagger > * { opacity: 0; transform: translateY(30px); transition: opacity 0.8s var(--ease-out), transform 0.8s var(--ease-out); }
  .stagger.is-visible > * { opacity: 1; transform: translateY(0); }
  .stagger.is-visible > *:nth-child(1) { transition-delay: 0.05s; }
  .stagger.is-visible > *:nth-child(2) { transition-delay: 0.12s; }
  .stagger.is-visible > *:nth-child(3) { transition-delay: 0.19s; }
  .stagger.is-visible > *:nth-child(4) { transition-delay: 0.26s; }
  .stagger.is-visible > *:nth-child(5) { transition-delay: 0.33s; }
  .stagger.is-visible > *:nth-child(6) { transition-delay: 0.40s; }
  .stagger.is-visible > *:nth-child(7) { transition-delay: 0.47s; }
  .stagger.is-visible > *:nth-child(8) { transition-delay: 0.54s; }

  .divider { border: 0; border-top: 1px solid var(--c-line); margin: 0; }
  .nav__brand-mark, .loader__asterisk, .hero__bg-asterisk, .magic__asterisk, .contact__bg-asterisk, .marquee__dot, .footer__brand-mark, .product__visual-placeholder::before, .intro__eyebrow::before, .product__point::before, .contact__heart, .nav__links a.cta .ellipse, .login__asterisk { user-select: none; -webkit-user-drag: none; }
  @media (max-width: 640px) { .hero { padding-top: 100px; } .product { padding: 80px var(--gutter); } .product__name { font-size: clamp(40px, 14vw, 80px); } .stats { grid-template-columns: 1fr 1fr; } }
  @media (prefers-reduced-motion: reduce) { *, *::before, *::after { animation-duration: 0.01ms !important; animation-iteration-count: 1 !important; transition-duration: 0.01ms !important; } .marquee__track { animation: none; } }
