﻿    :root{
      --bg:#FAFAFA;
      --surface:#FFFFFF;
      --text:#1A1A1A;
      --muted:#666666;
      --muted-2:#8A8A8A;
      --line:rgba(26,26,26,.10);
      --line-strong:rgba(26,26,26,.16);
      --dark:#1A1A1A;
      --dark-2:#101010;
      --light:#FAFAFA;
      --light-muted:#CCCCCC;
      --accent:#E87722;
      --radius:14px;
      --radius-sm:10px;
      --shadow:0 18px 40px rgba(0,0,0,.06);
      --shadow-soft:0 10px 30px rgba(0,0,0,.04);
      --max:1350px;
      --nav-h:84px;
    }

    *{box-sizing:border-box}
    html{scroll-behavior:smooth}
    body{
      margin:0;
      font-family:"Inter",system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
      background:var(--bg);
      color:var(--text);
      -webkit-font-smoothing:antialiased;
      text-rendering:optimizeLegibility;
      background-image:
        radial-gradient(circle at 10% 8%, rgba(26,26,26,.045), transparent 40%),
        radial-gradient(circle at 92% 18%, rgba(26,26,26,.06), transparent 36%);
      background-attachment:fixed;
    }

    @media (max-width: 820px){
      body{background-attachment:scroll}
    }
    body::selection{
      background:rgba(26,26,26,.12);
      color:#1a1a1a;
    }

    /* Scoped so ValorX home page does not shrink header/footer logos (shell lives outside #valorx-home-root). */
    #valorx-home-root img{max-width:100%;display:block}
    a{color:inherit;text-decoration:none}
    button,input{font:inherit}
    ul{margin:0;padding:0;list-style:none}

    .container{
      width:min(var(--max), calc(100% - 40px));
      max-width:100%;
      margin:0 auto;
    }

    .eyebrow{
      display:inline-block;
      font-size:.74rem;
      letter-spacing:.22em;
      text-transform:uppercase;
      color:var(--accent);
      margin-bottom:16px;
      font-weight:600;
    }

    h1,h2,h3,h4{
      font-family:"Manrope", "Inter", sans-serif;
      font-weight:300;
      letter-spacing:-.04em;
      margin:0;
      line-height:.98;
    }

    h1{font-size:clamp(3rem, 7vw, 6.4rem)}
    h2{font-size:clamp(2.1rem, 4vw, 4.1rem)}
    h3{font-size:clamp(1.25rem, 2vw, 1.6rem)}
    p{
      margin:0;
      color:var(--muted);
      line-height:1.75;
      font-size:1rem;
    }

    .section{
      padding:96px 0;
      position:relative;
      isolation:isolate;
    }
    .section--visual{
      padding:88px 0 100px;
    }
    .section::before{
      content:"";
      position:absolute;
      left:0;
      right:0;
      top:0;
      height:1px;
      background:linear-gradient(to right, transparent, rgba(26,26,26,.08), transparent);
      pointer-events:none;
    }
    .section > .container{
      position:relative;
      z-index:1;
    }

    .section-head{
      display:grid;
      grid-template-columns:1.3fr .8fr;
      gap:40px;
      align-items:end;
      margin-bottom:32px;
    }

    .section-head p{max-width:420px;font-size:.95rem}
    .section--visual .section-head p{max-width:360px}

    /* Hierarchy: primary (hero narrative + closure) vs secondary (proof / explore band) */
    #problem,
    #standard,
    #featured-series,
    #faq{
      background:
        radial-gradient(circle at 88% 10%, rgba(26,26,26,.035), transparent 38%),
        linear-gradient(180deg, #ffffff 0%, #f7f9fc 100%);
      box-shadow:inset 0 1px 0 rgba(255,255,255,.92), inset 0 -1px 0 rgba(26,26,26,.05);
    }

    #comparison,
    .category-strip,
    #built-for,
    #video-reels{
      background:
        radial-gradient(circle at 12% 25%, rgba(26,26,26,.055), transparent 42%),
        linear-gradient(180deg, #eef1f6 0%, #e5e9f1 100%);
      box-shadow:inset 0 1px 0 rgba(255,255,255,.52), inset 0 -1px 0 rgba(26,26,26,.065);
    }

    #built-for{
      padding:120px 0;
    }

    .btn{
      display:inline-flex;
      align-items:center;
      justify-content:center;
      gap:10px;
      min-height:48px;
      padding:0 22px;
      border-radius:2px;
      cursor:pointer;
      white-space:nowrap;
      font-weight:600;
      letter-spacing:.01em;
    }

    .btn-ghost-light{
      color:#fff;
      border:1px solid rgba(255,255,255,.36);
      background:rgba(255,255,255,.02);
      backdrop-filter:blur(10px);
    }
    .btn-ghost-light:hover{
      background:rgba(255,255,255,.08);
      border-color:rgba(255,255,255,.55);
    }
    .btn-ghost-light:focus-visible,
    .btn-ghost-dark:focus-visible,
    .faq-question:focus-visible,
    .menu-toggle:focus-visible{
      outline:2px solid rgba(232,119,34,.65);
      outline-offset:2px;
    }

    .btn-ghost-dark{
      color:var(--text);
      border:1px solid var(--line-strong);
      background:transparent;
    }
    .btn-ghost-dark:hover{
      background:#fff;
      border-color:rgba(26,26,26,.28);
    }

    .soft-link{
      display:inline-flex;
      align-items:center;
      gap:10px;
      margin-top:18px;
      color:var(--text);
      font-weight:500;
      border-bottom:1px solid rgba(26,26,26,.2);
      padding-bottom:4px;
    }

    .fade-up{
      opacity:1;
      transform:none;
    }

    main .section *,
    main .category-strip *,
    main .hero *{
      transition:none !important;
      animation:none !important;
    }

    .site-header{
      position:fixed;
      top:0;
      left:0;
      right:0;
      z-index:100;
      transition:background-color .35s ease, border-color .35s ease, backdrop-filter .35s ease, padding .35s ease;
      padding:max(18px, env(safe-area-inset-top, 0px)) 0 18px;
    }
    .site-header.scrolled{
      background:rgba(12,12,12,.88);
      border-bottom:1px solid rgba(255,255,255,.08);
      backdrop-filter:blur(18px);
      padding:max(12px, env(safe-area-inset-top, 0px)) 0 12px;
      box-shadow:0 10px 30px rgba(0,0,0,.22);
    }

    .nav{
      display:flex;
      align-items:center;
      justify-content:space-between;
      gap:24px;
    }

    .brand{
      display:flex;
      align-items:center;
      gap:12px;
      color:#fff;
      font-weight:600;
      letter-spacing:.02em;
      flex-shrink:0;
      min-width:0;
    }

    .brand-mark{
      width:34px;
      height:34px;
      border-radius:10px;
      border:1px solid rgba(255,255,255,.24);
      display:grid;
      place-items:center;
      background:rgba(255,255,255,.04);
      backdrop-filter:blur(8px);
      font-size:.9rem;
      font-weight:700;
    }

    .brand-name{
      display:flex;
      align-items:baseline;
      gap:8px;
      font-size:.95rem;
    }
    .brand-name span:last-child{
      color:rgba(255,255,255,.62);
      font-weight:500;
      letter-spacing:.16em;
      font-size:.72rem;
    }

    .nav-links{
      display:flex;
      align-items:center;
      gap:28px;
      color:rgba(255,255,255,.86);
      font-size:.95rem;
    }

    .nav-links a{
      position:relative;
      padding:6px 0;
    }
    .nav-links a::after{
      content:"";
      position:absolute;
      left:0;
      right:100%;
      bottom:0;
      height:1px;
      background:var(--accent);
      transition:right .25s ease;
    }
    .nav-links a:hover::after{right:0}

    .menu-toggle{
      display:none;
      width:44px;
      height:44px;
      border-radius:50%;
      border:1px solid rgba(255,255,255,.22);
      background:rgba(255,255,255,.04);
      color:#fff;
      align-items:center;
      justify-content:center;
      cursor:pointer;
      backdrop-filter:blur(8px);
    }

    .mobile-menu{
      display:none;
      position:absolute;
      top:calc(100% + 10px);
      left:max(16px, env(safe-area-inset-left, 0px));
      right:max(16px, env(safe-area-inset-right, 0px));
      background:rgba(18,18,18,.96);
      border:1px solid rgba(255,255,255,.08);
      border-radius:14px;
      padding:16px;
      box-shadow:var(--shadow);
      backdrop-filter:blur(16px);
    }
    .mobile-menu.open{display:block}
    .mobile-menu a{
      display:block;
      padding:14px 10px;
      color:rgba(255,255,255,.9);
      border-bottom:1px solid rgba(255,255,255,.06);
    }
    .mobile-menu a:last-child{border-bottom:0}

    .hero{
      min-height:clamp(600px, 88svh, min(100dvh, 980px));
      display:flex;
      align-items:flex-end;
      color:#fff;
      position:relative;
      overflow:hidden;
      background:#111;
    }

    .hero-media,
    .story-media{
      position:absolute;
      inset:0;
      overflow:hidden;
      z-index:0;
    }

    .hero-media video{
      position:absolute;
      inset:0;
      width:100%;
      height:100%;
      min-width:100%;
      min-height:100%;
      object-fit:cover;
      object-position:center center;
      display:block;
      z-index:0;
      filter:saturate(.92) contrast(1.04) brightness(.78);
      transform:scale(1.03);
    }

    .story-media img{
      width:100%;
      height:100%;
      object-fit:cover;
      filter:saturate(.9) contrast(1.03) brightness(.62);
      transform:scale(1.03);
    }

    .hero-media::after{
      content:"";
      position:absolute;
      inset:0;
      z-index:1;
      pointer-events:none;
      background:
        linear-gradient(145deg, rgba(255,255,255,.06), transparent 42%),
        linear-gradient(to top, rgba(0,0,0,.55) 0%, rgba(0,0,0,.15) 45%, transparent 72%),
        rgba(0,0,0,.22);
      box-shadow:inset 0 0 120px rgba(0,0,0,.25);
    }

    .hero-inner{
      position:relative;
      z-index:2;
      width:min(var(--max), calc(100% - 40px));
      max-width:100%;
      margin:0 auto;
      padding-top:calc(var(--nav-h) + max(24px, env(safe-area-inset-top, 0px)));
      padding-right:max(0px, env(safe-area-inset-right, 0px));
      padding-bottom:44px;
      padding-left:max(0px, env(safe-area-inset-left, 0px));
      box-sizing:border-box;
    }

    .hero-copy{
      max-width:760px;
    }

    .hero-copy p{
      color:rgba(255,255,255,.78);
      font-size:clamp(1rem, 1.6vw, 1.18rem);
      max-width:560px;
      margin-top:20px;
    }

    .hero-copy h1 + .hero-actions{margin-top:28px}
    .hero-actions{
      margin-top:32px;
      display:flex;
      align-items:center;
      gap:14px;
      flex-wrap:wrap;
    }

    .hero-note{
      margin-top:44px;
      color:rgba(255,255,255,.48);
      font-size:.84rem;
      letter-spacing:.16em;
      text-transform:uppercase;
    }

    .media-card{
      position:relative;
      overflow:hidden;
      border-radius:var(--radius);
      background:#e8e8ea;
      box-shadow:var(--shadow-soft);
      border:1px solid rgba(26,26,26,.06);
    }
    .media-card:hover{
      box-shadow:0 20px 42px rgba(0,0,0,.10);
      border-color:rgba(26,26,26,.14);
    }

    .media-card img{
      width:100%;
      height:100%;
      object-fit:cover;
      filter:saturate(.92) contrast(1.02) brightness(.9);
    }

    .problem-grid{
      display:grid;
      grid-template-columns:1fr 1fr;
      gap:clamp(14px, 2vw, 18px);
      margin-bottom:clamp(18px, 3vw, 24px);
    }

    #problem.section--visual{
      padding:72px 0 84px;
    }

    #problem .section-head{
      margin-bottom:clamp(18px, 3vw, 26px);
    }

    #problem .stat-panel{
      padding:clamp(22px, 3vw, 28px);
    }

    .problem-grid .media-card{
      height:clamp(220px, min(360px, 40svh), 380px);
    }

    .problem-grid .muted img{
      filter:grayscale(1) contrast(1.02) brightness(.82);
    }

    .stat-panel{
      background:var(--surface);
      border:1px solid var(--line);
      border-radius:var(--radius);
      padding:34px;
      box-shadow:var(--shadow-soft);
    }

    .stat-number{
      font-family:"Manrope", sans-serif;
      font-size:clamp(2rem, 4vw, 3.4rem);
      line-height:1.02;
      letter-spacing:-.05em;
      margin-bottom:12px;
    }

    #problem .stat-number{
      font-size:clamp(1.45rem, 3.2vw, 2.35rem);
      line-height:1.08;
    }

    .standard-grid{
      display:grid;
      grid-template-columns:repeat(3, 1fr);
      gap:20px;
    }

    .standard-card{
      background:var(--surface);
      border:1px solid var(--line);
      border-radius:var(--radius);
      padding:22px;
      box-shadow:var(--shadow-soft);
    }
    .standard-card:hover{
      border-color:rgba(26,26,26,.16);
      box-shadow:0 16px 34px rgba(0,0,0,.10);
    }

    .feature-visual{
      height:260px;
      border-radius:14px;
      background:#151515;
      border:1px solid rgba(255,255,255,.06);
      display:grid;
      place-items:center;
      margin-bottom:22px;
      overflow:hidden;
    }

    .feature-visual svg{
      width:100%;
      height:100%;
      opacity:.96;
    }

    .feature-meta h3{margin-bottom:10px}
    .feature-meta p{font-size:.98rem}

    /* ——— Routines (interactive) ——— */
    .routines-inner{
      max-width:100%;
    }

    .routines-head{
      display:flex;
      flex-wrap:wrap;
      justify-content:space-between;
      align-items:flex-end;
      gap:28px 48px;
      margin-bottom:56px;
    }

    .routines-head h2{
      font-size:clamp(1.05rem, 2.6vw + 0.85rem, 3.35rem);
      font-weight:400;
      letter-spacing:-.045em;
      color:#1a1a1a;
      margin-top:4px;
      white-space:nowrap;
      line-height:1.08;
    }

    .routines-head .eyebrow{
      letter-spacing:.2em;
      color:var(--accent);
      opacity:.92;
    }

    .routines-head-sub{
      margin:0;
      max-width:280px;
      text-align:right;
      font-size:.94rem;
      line-height:1.65;
      color:#666;
    }

    .routines-layout{
      display:flex;
      flex-direction:row;
      align-items:flex-start;
      gap:max(80px, 6vw);
    }

    .routines-visual{
      flex:0 0 60%;
      width:60%;
      max-width:60%;
      position:relative;
    }

    .routines-visual-inner{
      position:relative;
      width:100%;
      overflow:hidden;
      border-radius:4px;
      background:#e8e6e2;
      min-height:260px;
    }

    .routines-visual-inner img{
      position:absolute;
      inset:0;
      width:100%;
      height:100%;
      object-fit:cover;
      opacity:0;
      pointer-events:none;
      filter:saturate(.9) contrast(1.03) brightness(.94);
    }

    .routines-visual-inner img.is-visible{
      opacity:1;
      z-index:1;
    }

    .routines-caption{
      position:absolute;
      left:0;
      right:0;
      bottom:0;
      z-index:2;
      padding:20px 22px 18px;
      font-size:.81rem;
      font-weight:400;
      letter-spacing:.06em;
      color:rgba(255,255,255,.92);
      background:linear-gradient(180deg, transparent 0%, rgba(0,0,0,.55) 42%, rgba(0,0,0,.72) 100%);
      pointer-events:none;
    }

    .routines-list-wrap{
      flex:1;
      min-width:0;
      width:40%;
      max-width:40%;
    }

    .routines-list{
      margin:0;
      padding:0;
      list-style:none;
    }

    .routines-item{
      --routines-divider:#e5e5e5;
      display:grid;
      grid-template-columns:2.75rem minmax(0, 1fr) 14px;
      grid-template-rows:auto auto;
      column-gap:clamp(12px, 2vw, 20px);
      row-gap:4px;
      width:100%;
      padding:28px 0;
      margin:0;
      border:0;
      border-bottom:1px solid var(--routines-divider);
      background:transparent;
      cursor:pointer;
      text-align:left;
      font:inherit;
      color:inherit;
      opacity:.55;
    }

    .routines-list li:first-child .routines-item{
      border-top:1px solid var(--routines-divider);
    }

    .routines-item.is-active{
      opacity:1;
    }

    .routines-item:focus-visible{
      outline:2px solid var(--accent);
      outline-offset:4px;
      opacity:1;
    }

    .routines-item__num{
      grid-row:1 / span 2;
      font-family:"Inter", ui-monospace, monospace;
      font-variant-numeric:tabular-nums;
      font-size:14px;
      line-height:1.35;
      color:#a0a0a0;
      padding-top:3px;
    }

    .routines-item__label{
      grid-column:2;
      grid-row:1;
      font-size:clamp(1.25rem, 2vw, 1.45rem);
      font-weight:400;
      letter-spacing:-.03em;
      color:#1a1a1a;
      line-height:1.2;
    }

    .routines-item.is-active .routines-item__label{
      font-weight:500;
    }

    .routines-item__desc{
      grid-column:2;
      grid-row:2;
      font-size:14px;
      line-height:1.45;
      color:#666;
      font-weight:400;
    }

    .routines-item__dot{
      grid-column:3;
      grid-row:1 / span 2;
      align-self:start;
      justify-self:end;
      width:7px;
      height:7px;
      margin-top:8px;
      border-radius:50%;
      background:var(--accent);
      opacity:0;
    }

    .routines-item.is-active .routines-item__dot{
      opacity:1;
    }

    @media (max-width: 767px){
      #built-for{padding:60px 0}
      .routines-head{
        flex-direction:column;
        align-items:flex-start;
        margin-bottom:36px;
      }
      .routines-head-sub{
        text-align:left;
        max-width:36ch;
      }
      .routines-layout{
        flex-direction:column;
        gap:32px;
      }
      .routines-visual,
      .routines-list-wrap{
        flex:none;
        width:100%;
        max-width:100%;
      }
      .routines-visual-inner{
        aspect-ratio:4 / 5;
        min-height:0;
        height:auto !important;
      }
    }

    .featured-slider{
      position:relative;
    }

    .featured-slider__viewport{
      position:relative;
      min-height:min(540px, 72vw);
    }

    .featured-slide{
      position:absolute;
      inset:0;
      display:grid;
      grid-template-columns:minmax(0, 1.12fr) minmax(260px, 0.88fr);
      border-radius:var(--radius);
      overflow:hidden;
      background:var(--surface);
      border:1px solid var(--line);
      box-shadow:0 22px 56px rgba(0,0,0,.07);
      opacity:0;
      visibility:hidden;
      pointer-events:none;
      z-index:0;
    }

    .featured-slide.is-active{
      opacity:1;
      visibility:visible;
      pointer-events:auto;
      z-index:1;
    }

    .featured-showcase__visual{
      position:relative;
      min-height:420px;
      background:#101010;
    }

    .featured-showcase__visual img{
      width:100%;
      height:100%;
      min-height:100%;
      object-fit:cover;
      display:block;
      filter:saturate(.93) contrast(1.02) brightness(.9);
    }

    .featured-slider__dots{
      position:absolute;
      left:58%;
      right:clamp(26px, 3.8vw, 46px);
      bottom:20px;
      display:flex;
      justify-content:flex-start;
      align-items:center;
      flex-wrap:wrap;
      gap:10px;
      z-index:3;
    }

    .featured-slider__dot{
      width:10px;
      height:10px;
      border-radius:50%;
      border:none;
      padding:12px;
      box-sizing:content-box;
      background:rgba(26,26,26,.22);
      background-clip:content-box;
      cursor:pointer;
    }

    .featured-slider__dot:hover{background-color:rgba(26,26,26,.38);background-clip:content-box}
    .featured-slider__dot.is-active{
      background:var(--accent);
      background-clip:content-box;
    }

    .featured-showcase__body{
      position:relative;
      padding:clamp(28px, 4.2vw, 52px) clamp(26px, 3.8vw, 46px);
      display:flex;
      flex-direction:column;
      justify-content:center;
      background:linear-gradient(165deg, #fff 0%, #f4f4f6 55%, #e9eaee 100%);
    }

    .featured-showcase__body::before{
      content:"";
      position:absolute;
      left:0;
      top:16%;
      bottom:16%;
      width:4px;
      border-radius:99px;
      background:linear-gradient(180deg, rgba(42,42,46,.85), rgba(26,26,26,.12));
    }

    .featured-showcase__body .eyebrow{margin-bottom:10px}

    .featured-showcase__body h2{
      font-family:"Manrope", sans-serif;
      font-size:clamp(2.1rem, 4.2vw, 3.15rem);
      font-weight:300;
      letter-spacing:-.045em;
      line-height:1.05;
      margin:0 0 14px;
    }

    .featured-showcase__lead{
      margin:0;
      max-width:38ch;
      color:var(--muted);
      font-size:1.04rem;
      line-height:1.65;
    }

    .featured-showcase__body .bullets{margin:24px 0 30px}

    .bullets{
      margin:28px 0 34px;
      display:grid;
      gap:14px;
    }

    .bullets li{
      display:flex;
      align-items:flex-start;
      gap:12px;
      color:var(--text);
      line-height:1.7;
    }

    .bullets li::before{
      content:"";
      width:8px;
      height:8px;
      border-radius:50%;
      background:var(--accent);
      margin-top:10px;
      flex:0 0 auto;
    }

    .table-wrap{
      overflow:auto;
      -webkit-overflow-scrolling:touch;
      overscroll-behavior-x:contain;
      border:1px solid var(--line);
      border-radius:var(--radius);
      background:var(--surface);
      box-shadow:var(--shadow-soft);
    }

    table{
      width:100%;
      border-collapse:collapse;
      min-width:760px;
    }

    th,td{
      padding:22px 24px;
      border-bottom:1px solid var(--line);
      text-align:left;
    }

    th{
      font-weight:600;
      color:var(--muted);
      background:#fcfcfc;
    }

    tr:last-child td{border-bottom:0}

    td:first-child, th:first-child{
      position:sticky;
      left:0;
      background:inherit;
      z-index:1;
    }

    .highlight-col{
      background:#f0f1f4;
    }

    .pill{
      display:inline-flex;
      align-items:center;
      gap:8px;
      padding:6px 10px;
      border:1px solid rgba(26,26,26,.14);
      border-radius:999px;
      color:var(--accent);
      font-size:.75rem;
      letter-spacing:.16em;
      text-transform:uppercase;
      font-weight:600;
    }

    .story{
      color:#fff;
      background:#0f0f0f;
      overflow:hidden;
      position:relative;
    }

    .section.story{
      padding:52px 0;
    }

    .story-media::after{
      content:"";
      position:absolute;
      inset:0;
      background:
        linear-gradient(90deg, rgba(0,0,0,.82) 0%, rgba(0,0,0,.45) 42%, rgba(0,0,0,.12) 72%, rgba(0,0,0,.28) 100%),
        linear-gradient(180deg, transparent 0%, rgba(0,0,0,.35) 100%);
      pointer-events:none;
    }

    .story-inner{
      position:relative;
      z-index:1;
      display:flex;
      align-items:center;
      padding:clamp(16px, 3vw, 28px) 0;
    }

    .story-copy{
      max-width:min(540px, 100%);
      padding:clamp(20px, 3vw, 30px) clamp(20px, 3.5vw, 32px);
      border-radius:var(--radius);
      background:rgba(10,10,10,.42);
      border:1px solid rgba(255,255,255,.12);
      backdrop-filter:blur(14px);
      box-shadow:0 28px 70px rgba(0,0,0,.42);
    }

    .story-copy h2{
      font-size:clamp(2rem, 4.4vw, 3.25rem);
      line-height:1.05;
      letter-spacing:-.045em;
      max-width:16ch;
    }

    .story-copy p{
      color:rgba(255,255,255,.82);
      margin-top:12px;
      max-width:38ch;
      font-size:1.02rem;
      line-height:1.6;
    }

    .story-points{
      margin:16px 0 0;
      padding:0;
      list-style:none;
      display:grid;
      gap:8px;
    }

    .story-points li{
      display:flex;
      align-items:flex-start;
      gap:10px;
      color:rgba(255,255,255,.88);
      font-size:.93rem;
      line-height:1.45;
    }

    .story-points li::before{
      content:"";
      width:6px;
      height:6px;
      border-radius:50%;
      background:var(--accent);
      margin-top:8px;
      flex-shrink:0;
    }

    .story-actions{
      display:flex;
      flex-wrap:wrap;
      gap:12px;
      margin-top:18px;
    }

    .story-actions .story-btn-soft{
      border-color:rgba(255,255,255,.22);
      background:rgba(255,255,255,.04);
    }

    .story-actions .story-btn-soft:hover{
      background:rgba(255,255,255,.1);
      border-color:rgba(255,255,255,.38);
    }

    .story-trust{
      margin-top:14px;
      font-size:.72rem;
      letter-spacing:.16em;
      text-transform:uppercase;
      color:rgba(255,255,255,.48);
      display:flex;
      flex-wrap:wrap;
      gap:6px 14px;
    }

    .story-trust-sep{
      color:rgba(255,255,255,.28);
      user-select:none;
    }

    .faq-layout{
      display:grid;
      grid-template-columns:.88fr 1.12fr;
      gap:28px;
      align-items:start;
    }

    .faq-intro{
      position:sticky;
      top:108px;
      background:var(--surface);
      border:1px solid var(--line);
      border-radius:var(--radius);
      padding:30px;
      box-shadow:var(--shadow-soft);
    }

    .faq-list{
      display:grid;
      gap:14px;
    }

    .faq-item{
      background:var(--surface);
      border:1px solid var(--line);
      border-radius:var(--radius);
      box-shadow:var(--shadow-soft);
      overflow:hidden;
      transition:border-color .25s ease, box-shadow .25s ease;
    }
    .faq-item:hover{
      border-color:rgba(26,26,26,.12);
      box-shadow:0 12px 28px rgba(0,0,0,.08);
    }

    .faq-question{
      width:100%;
      text-align:left;
      background:none;
      border:0;
      padding:22px 24px;
      display:flex;
      align-items:center;
      justify-content:space-between;
      gap:18px;
      color:var(--text);
      cursor:pointer;
    }

    .faq-question span{
      font-size:1.05rem;
      line-height:1.5;
      font-weight:500;
    }

    .faq-icon{
      width:34px;
      height:34px;
      border-radius:50%;
      border:1px solid var(--line);
      display:grid;
      place-items:center;
      flex:0 0 auto;
      transition:transform .25s ease, background-color .25s ease;
    }

    .faq-item.active .faq-icon{
      transform:rotate(45deg);
      background:#e8e9ec;
      border-color:rgba(26,26,26,.18);
    }

    .faq-answer{
      max-height:0;
      overflow:hidden;
      transition:max-height .35s ease;
    }

    .faq-answer-inner{
      padding:0 24px 24px;
    }

    .dark-break{
      background:var(--dark);
      color:#fff;
    }

    /* ——— SHOP BY EXPERIENCE ——— */
    .category-strip{
      border-top:1px solid rgba(26,26,26,.07);
      border-bottom:1px solid rgba(26,26,26,.07);
      padding:96px 0;
    }

    .category-shell{
      width:min(1280px, calc(100% - 64px));
      margin:0 auto;
    }

    .category-head{
      display:grid;
      grid-template-columns:1fr 1fr;
      gap:24px;
      align-items:end;
      margin-bottom:48px;
    }

    .category-title{
      color:#1a1a1a;
      font-family:"Inter",system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
      font-size:clamp(1.35rem, 1.9vw, 1.8rem);
      letter-spacing:-.02em;
      margin:0;
      font-weight:400;
      line-height:1.06;
    }

    .category-sub{
      color:#6b6b6b;
      max-width:460px;
      margin-left:auto;
      text-align:right;
      font-size:15px;
      line-height:1.6;
      font-weight:400;
    }

    .category-nav{
      display:grid;
      grid-template-columns:repeat(4, minmax(0, 1fr));
      gap:16px;
    }

    .category-item{
      position:relative;
      aspect-ratio:4 / 5;
      border-radius:9px;
      overflow:hidden;
      border:0.5px solid #dcdcdf;
      cursor:pointer;
      background:#efefef;
      display:block;
    }

    .category-item img{
      width:100%;
      height:100%;
      object-fit:cover;
      display:block;
    }

    .category-overlay{
      position:absolute;
      inset:0;
      background:rgba(236,237,240,.92);
      display:grid;
      place-items:center;
      text-align:center;
      padding:18px;
      opacity:0;
      pointer-events:none;
    }

    .category-copy strong{
      display:block;
      font-size:18px;
      line-height:1.28;
      color:#1a1a1a;
      font-weight:500;
      margin-bottom:8px;
    }

    .category-copy small{
      display:block;
      font-size:13px;
      line-height:1.4;
      color:#6b6b6b;
      font-weight:400;
      margin-bottom:10px;
    }

    .category-arrow{
      display:block;
      font-size:19px;
      color:#1a1a1a;
      line-height:1;
      font-weight:400;
    }

    .category-item:hover .category-overlay,
    .category-item:focus-visible .category-overlay,
    .category-item.is-revealed .category-overlay{
      opacity:1;
    }

    /* ——— VIDEO REELS ——— */
    .reels-section{
      overflow-x:hidden;
    }

    .reels-section .reels-inner{
      width:min(var(--max), calc(100% - 40px));
      margin-inline:auto;
      box-sizing:border-box;
      position:relative;
      z-index:1;
    }

    .reels-section .reels-shell{
      position:relative;
      width:100%;
      max-width:100%;
      box-sizing:border-box;
    }

    .reels-drag{
      overflow-x:auto;
      overflow-y:hidden;
      scroll-snap-type:x mandatory;
      scroll-padding-inline:0;
      -webkit-overflow-scrolling:touch;
      scrollbar-width:none;
      -ms-overflow-style:none;
      cursor:grab;
      touch-action:pan-x;
      user-select:none;
      -webkit-user-select:none;
    }
    .reels-drag::-webkit-scrollbar{display:none}
    .reels-drag.is-dragging{
      cursor:grabbing;
      scroll-snap-type:none;
    }
    .reels-drag.is-dragging .reel-thumb,
    .reels-drag.is-dragging .reel-card *{
      pointer-events:none;
    }

    .reels-track{
      display:flex;
      gap:16px;
      width:max-content;
      min-width:100%;
      padding:8px 0 22px;
      box-sizing:border-box;
    }

    .reel-card{
      flex:0 0 clamp(204px, 18.5vw, 318px);
      scroll-snap-align:start;
      cursor:pointer;
    }

    .reel-thumb{
      position:relative;
      width:100%;
      aspect-ratio:9 / 16;
      border-radius:14px;
      overflow:hidden;
      background:#121212;
      box-shadow:var(--shadow-soft);
    }

    .reel-card:hover .reel-thumb{
      box-shadow:var(--shadow);
    }

    .reel-thumb .reel-preview{
      position:absolute;
      inset:0;
      width:100%;
      height:100%;
      object-fit:cover;
      pointer-events:none;
      z-index:0;
    }

    .reel-thumb::after{
      content:"";
      position:absolute;
      inset:auto 0 0 0;
      height:55%;
      background:linear-gradient(to top, rgba(0,0,0,.72), rgba(0,0,0,0));
      pointer-events:none;
      z-index:1;
    }

    .reel-caption{
      position:absolute;
      left:14px;
      right:14px;
      bottom:14px;
      color:#fff;
      font-size:.88rem;
      font-weight:500;
      line-height:1.35;
      letter-spacing:.005em;
      z-index:2;
    }

    .reel-meta{
      padding:10px 2px 0;
    }

    .reel-name{
      font-size:.92rem;
      font-weight:600;
      color:var(--text);
      margin-bottom:3px;
      letter-spacing:-.005em;
    }

    .reel-role{
      font-size:.86rem;
      color:var(--muted);
    }

    /* ——— REEL MODAL ——— */
    .reel-modal{
      position:fixed;
      inset:0;
      z-index:200;
      display:none;
      align-items:center;
      justify-content:center;
      padding:24px;
    }
    .reel-modal.open{display:flex}

    .reel-modal-backdrop{
      position:absolute;
      inset:0;
      background:rgba(8,8,8,.86);
      backdrop-filter:blur(8px);
    }

    .reel-modal-content{
      position:relative;
      width:min(420px, 92vw);
      aspect-ratio:9 / 16;
      max-height:90vh;
      border-radius:var(--radius);
      overflow:hidden;
      background:#000;
      box-shadow:0 30px 80px rgba(0,0,0,.5);
      border:1px solid rgba(255,255,255,.12);
    }

    @media (prefers-reduced-motion: reduce){
      *,
      *::before,
      *::after{
        animation:none !important;
        transition:none !important;
        scroll-behavior:auto !important;
      }
      .hero-media video{display:none}
      .hero{
        background-image:url("https://images.unsplash.com/photo-1524758631624-e2822e304c36?auto=format&fit=crop&w=1800&q=80");
        background-size:cover;
        background-position:center;
      }
    }

    .reel-modal-content video,
    .reel-modal-content img{
      width:100%;
      height:100%;
      object-fit:cover;
      display:block;
    }

    .reel-modal-close{
      position:absolute;
      top:14px;
      right:14px;
      width:40px;
      height:40px;
      border-radius:50%;
      border:none;
      background:rgba(255,255,255,.14);
      color:#fff;
      font-size:1.3rem;
      line-height:1;
      cursor:pointer;
      backdrop-filter:blur(10px);
      z-index:3;
      display:grid;
      place-items:center;
      transition:background-color .25s ease;
    }

    .reel-modal-close:hover{background:rgba(255,255,255,.26)}

    .reel-modal-meta{
      position:absolute;
      left:16px;
      right:62px;
      bottom:18px;
      color:#fff;
      z-index:3;
    }
    .reel-modal-meta .reel-name{color:#fff; margin-bottom:2px}
    .reel-modal-meta .reel-role{color:rgba(255,255,255,.72)}

    @media (max-width: 900px){
      .problem-grid{
        grid-template-columns:1fr;
      }
      .problem-grid .media-card{
        height:clamp(200px, min(280px, 34svh), 300px);
      }
      #problem.section--visual{
        padding:64px 0 76px;
      }
    }

    @media (max-width: 1100px){
      .standard-grid{
        grid-template-columns:repeat(2, 1fr);
      }
      .section-head,
      .faq-layout{
        grid-template-columns:1fr;
      }
      .featured-slider__viewport{min-height:min(620px, 128vw)}
      .featured-slide{
        grid-template-columns:1fr;
      }
      .featured-showcase__visual{
        min-height:300px;
        aspect-ratio:16 / 10;
      }
      .featured-slider__dots{
        position:static;
        left:auto;
        right:auto;
        bottom:auto;
        margin-top:14px;
        justify-content:center;
      }
      .faq-intro{
        position:static;
        top:auto;
      }
      .category-head{
        grid-template-columns:1fr;
        margin-bottom:40px;
      }
      .category-sub{
        margin-left:0;
        text-align:left;
      }
      .category-nav{grid-template-columns:repeat(2, minmax(0, 1fr))}
    }

    @media (max-width: 820px){
      :root{--nav-h:74px}
      .container{
        width:min(var(--max), calc(100% - 32px));
      }
      .section{padding:84px 0}
      .section.story{padding:44px 0}
      .hero-inner{
        width:min(var(--max), calc(100% - 32px));
        padding-bottom:40px;
      }
      .hero{min-height:clamp(520px, 82svh, 880px)}
      .nav-links{display:none}
      .menu-toggle{display:inline-flex}
      .problem-grid,
      .standard-grid{
        grid-template-columns:1fr;
      }
      .problem-grid .media-card{
        height:clamp(190px, min(260px, 30svh), 280px);
      }
      #problem.section--visual{
        padding:56px 0 68px;
      }
      .featured-showcase__body{padding:26px 22px 30px}
      .reel-card{flex:0 0 252px}
      .category-strip{padding:64px 0}
      .category-shell{
        width:calc(100% - 24px);
      }
      .category-title{font-size:1.95rem}
      .category-sub{
        display:none;
      }
      .category-item{
        min-width:85%;
        scroll-snap-align:start;
      }
      .category-nav{
        display:flex;
        overflow-x:auto;
        gap:14px;
        scroll-snap-type:x mandatory;
        padding-bottom:2px;
        -webkit-overflow-scrolling:touch;
      }
      .category-nav::-webkit-scrollbar{display:none}
    }

    @media (max-width: 560px){
      .reels-section .reels-inner{width:min(var(--max), calc(100% - 24px))}
      .container{width:min(var(--max), calc(100% - 24px))}
      .hero-inner{width:min(var(--max), calc(100% - 24px))}
      .section-head{
        gap:22px;
        margin-bottom:26px;
      }
      .section--visual .section-head p{max-width:100%}
      .hero-copy p{max-width:100%}
      .stat-panel,
      .featured-showcase__body,
      .faq-intro,
      .standard-card{
        padding:22px;
      }
      th,td{padding:18px}
      .hero-actions{width:100%}
      .hero-actions .btn{width:100%}
      .reel-card{flex:0 0 204px}
      .category-shell{
        width:calc(100% - 16px);
      }
      .category-item{
        min-width:85%;
      }
      .reel-modal{
        padding:max(16px, env(safe-area-inset-top, 0px)) max(16px, env(safe-area-inset-right, 0px)) max(16px, env(safe-area-inset-bottom, 0px)) max(16px, env(safe-area-inset-left, 0px));
      }
      .reel-modal-content{
        width:min(420px, calc(100vw - (env(safe-area-inset-left, 0px) + env(safe-area-inset-right, 0px) + 32px)));
        max-height:min(90vh, 100dvh - (env(safe-area-inset-top, 0px) + env(safe-area-inset-bottom, 0px) + 32px));
      }
    }

    @media (max-width: 480px){
      .section{padding:64px 0}
      .section.story{padding:36px 0}
      .section--visual{padding:56px 0 68px}
      .category-strip{padding:48px 0}
      .faq-question{
        padding:16px 18px;
        gap:12px;
      }
      .faq-question span{
        font-size:1rem;
      }
      .faq-icon{
        width:32px;
        height:32px;
      }
      .faq-answer-inner{
        padding:0 18px 20px;
      }
      .faq-intro{padding:22px}
      .hero{min-height:clamp(480px, 78svh, 820px)}
      .hero-inner{
        width:min(var(--max), calc(100% - 20px));
      }
      h1{font-size:clamp(2.2rem, 9.5vw, 3.15rem)}
      .category-title{font-size:1.65rem}
    }