/* ============================================================
   ソクウリ LP v3 — 仕様書準拠（青基調・濃紺・Noto Sans JP）
   配色は7色＋黄系PRのみ／見出し700まで／数字は等幅／線画アイコン
   ============================================================ */
:root{
  --blue:#1f54de;
  --blue-deep:#1844b8;
  --navy:#1d3677;
  --navy-deep:#141f48;
  --pale:#eef4ff;
  --emerald:#10b981;
  --bg:#f8fafc;
  --body:#475569;
  --body-soft:#64748b;
  --heading:#0f172a;
  --line:#e2e8f0;
  --pr-bg:#fef9c3; --pr-text:#854d0e; --pr-border:#fde68a;

  --container:1180px;
  --radius:16px; --radius-sm:12px;

  --shadow-sm:0 1px 2px rgba(15,23,42,.06), 0 1px 3px rgba(15,23,42,.04);
  --shadow-md:0 8px 24px rgba(15,23,42,.08);
  --shadow-lg:0 24px 60px rgba(20,31,72,.18);
  --shadow-blue:0 14px 30px rgba(31,84,222,.32);

  --ease:cubic-bezier(.22,.61,.36,1);
}

/* ---------- reset ---------- */
*,*::before,*::after{box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;scroll-padding-top:84px;}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto;}}
body{
  margin:0;background:var(--bg);color:var(--body);
  font-family:"Noto Sans JP",system-ui,-apple-system,"Hiragino Kaku Gothic ProN","Yu Gothic",Meiryo,sans-serif;
  font-size:16px;line-height:1.75;letter-spacing:.01em;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
h1,h2,h3,h4,p,figure,ul{margin:0;}
a{color:inherit;text-decoration:none;}
img{display:block;max-width:100%;}
button{font-family:inherit;cursor:pointer;border:0;background:none;}
ul{list-style:none;padding:0;}
.num{font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1;}
strong{font-weight:700;}
svg.ic{width:1em;height:1em;fill:none;stroke:currentColor;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round;}

/* ---------- layout ---------- */
.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:24px;}
.section{padding:96px 0;}
@media(max-width:760px){.section{padding:68px 0;}}
@media(max-width:520px){.container{padding-inline:18px;}}
.topline{border-top:1px solid var(--line);}

/* ---------- eyebrow ---------- */
.eyebrow{display:inline-flex;align-items:center;gap:10px;font-size:13px;font-weight:700;letter-spacing:.14em;color:var(--blue);}
.eyebrow::before{content:"";width:22px;height:2px;border-radius:2px;background:var(--blue);}
.eyebrow.c-light{color:#9db6ff;}
.eyebrow.c-light::before{background:#5b80f0;}

/* ---------- section head ---------- */
.section-head{max-width:720px;margin:0 auto 56px;text-align:center;}
.section-head h2{font-size:clamp(28px,4vw,40px);font-weight:700;line-height:1.4;color:var(--heading);margin-top:16px;letter-spacing:.01em;}
.section-head .sub{font-size:17px;color:var(--body-soft);margin-top:16px;line-height:1.85;}
.on-dark .section-head h2{color:#fff;}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;font-weight:700;font-size:16px;line-height:1;border-radius:999px;transition:background .2s var(--ease),transform .2s var(--ease),box-shadow .2s var(--ease);}
.btn-primary{background:var(--blue);color:#fff;padding:16px 26px;box-shadow:var(--shadow-blue);}
.btn-primary:hover{background:var(--blue-deep);transform:translateY(-2px);}
.btn-primary.lg{padding:19px 34px;font-size:17px;}
.btn .ic{font-size:19px;}
.btn-text{display:inline-flex;align-items:center;gap:9px;font-weight:700;font-size:16px;color:#dbe5fc;transition:gap .2s var(--ease);}
.btn-text .ic{font-size:18px;}
.btn-text:hover{gap:13px;}

/* ---------- PR badge ---------- */
.pr-badge{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:700;color:var(--pr-text);background:var(--pr-bg);border:1px solid var(--pr-border);border-radius:6px;padding:3px 8px;}

/* ---------- photo + fallback ---------- */
.photo{position:relative;overflow:hidden;background:linear-gradient(150deg,#eef4ff,#cfddff 55%,#a9c2ff);}
.photo>img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.photo>img.failed{display:none;}
.photo.ov::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(20,31,72,.82),rgba(20,31,72,.30) 48%,transparent);}

/* ============================================================
   1. HEADER
   ============================================================ */
.header{position:fixed;top:0;left:0;right:0;z-index:60;height:72px;
  background:rgba(255,255,255,.86);backdrop-filter:blur(12px);
  transition:box-shadow .3s,border-color .3s;border-bottom:1px solid transparent;}
.header.scrolled{border-bottom-color:var(--line);box-shadow:0 4px 20px rgba(15,23,42,.05);}
.header .inner{height:100%;display:flex;align-items:center;justify-content:space-between;gap:24px;}
.logo{display:inline-flex;align-items:center;gap:10px;}
.logo .tile{width:30px;height:30px;border-radius:9px;background:var(--blue);box-shadow:var(--shadow-blue);display:grid;place-items:center;color:#fff;}
.logo .tile .ic{font-size:18px;}
.logo .name{font-size:22px;font-weight:700;color:var(--heading);letter-spacing:.02em;white-space:nowrap;}
.logo.light .name{color:#fff;}
.nav{display:flex;align-items:center;gap:30px;}
.nav a{font-size:15px;font-weight:500;color:var(--body);transition:color .15s;white-space:nowrap;}
.nav a:hover{color:var(--blue);}
.header-cta{display:flex;align-items:center;gap:14px;}
.vendor-link{display:inline-flex;align-items:center;gap:7px;font-size:14px;font-weight:600;color:var(--body);
  padding:9px 15px;border-radius:999px;border:1px solid var(--line);background:#fff;transition:border-color .2s,color .2s,background .2s;}
.vendor-link .ic{font-size:17px;color:var(--body-soft);}
.vendor-link:hover{color:var(--blue);border-color:var(--blue);background:var(--pale);}
.vendor-link:hover .ic{color:var(--blue);}
.mm-vendor{display:flex;align-items:center;gap:9px;}
.mm-vendor .ic{font-size:18px;color:var(--blue);}
@media(max-width:980px){.vendor-link{display:none;}}
.hamburger{display:none;width:44px;height:44px;border:1px solid var(--line);background:#fff;border-radius:11px;place-items:center;color:var(--heading);}
.hamburger .ic{font-size:22px;}
.mobile-menu{position:fixed;top:72px;left:0;right:0;z-index:55;background:#fff;border-bottom:1px solid var(--line);box-shadow:var(--shadow-md);
  padding:18px 24px 24px;display:grid;gap:6px;opacity:0;transform:translateY(-12px);pointer-events:none;transition:opacity .25s var(--ease),transform .25s var(--ease);}
.mobile-menu.open{opacity:1;transform:none;pointer-events:auto;}
.mobile-menu a{padding:13px 8px;font-size:16px;font-weight:600;color:var(--heading);border-radius:10px;}
.mobile-menu a:hover{background:var(--pale);color:var(--blue);}
.mobile-menu .btn-primary{width:100%;margin-top:10px;}
@media(max-width:980px){
  .nav,.header-cta .btn-primary,.vendor-link{display:none;}
  .hamburger{display:grid;}
}

/* ============================================================
   2. HERO
   ============================================================ */
.hero{position:relative;overflow:hidden;color:#fff;padding:148px 0 96px;
  background:
    radial-gradient(120% 90% at 85% 0%, rgba(31,84,222,.55), transparent 55%),
    linear-gradient(158deg,#234399 0%,#1d3677 42%,#141f48 100%);}
.hero::after{content:"";position:absolute;left:-10%;bottom:-20%;width:60%;height:80%;
  background:radial-gradient(circle at 30% 70%, rgba(31,84,222,.5), transparent 60%);opacity:.5;pointer-events:none;}
@media(max-width:760px){.hero{padding:120px 0 72px;}}
.hero-grid{position:relative;z-index:2;display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center;}
@media(max-width:980px){.hero-grid{grid-template-columns:1fr;gap:44px;}}

.hero-eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:700;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.22);color:#cfdcff;
  padding:8px 15px;border-radius:999px;}
.hero-eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--emerald);}
.hero h1{font-size:clamp(33px,5.1vw,56px);font-weight:700;line-height:1.28;margin-top:20px;text-wrap:balance;}
.hero h1 .hl{position:relative;}
.hero h1 .hl::after{content:"";position:absolute;left:-2px;right:-2px;top:88%;height:.32em;border-radius:3px;z-index:-1;
  background-image:linear-gradient(90deg,#1f54de,#4f7dff);}
.hero h1 .hl{z-index:1;}
.hero-sub{font-size:17px;line-height:1.95;color:#d4ddf3;max-width:540px;margin-top:22px;}
.hero-cta{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-top:30px;}
.hero-note{font-size:13px;color:#9fb0d8;margin-top:18px;max-width:520px;}
.trust-badges{display:grid;grid-template-columns:1fr 1fr;gap:14px 22px;margin-top:30px;max-width:520px;}
.trust-badges li{display:flex;align-items:center;gap:11px;font-size:14.5px;font-weight:500;color:#e7edfb;}
.trust-badges .tb{flex:none;width:24px;height:24px;border-radius:50%;background:rgba(16,185,129,.16);display:grid;place-items:center;color:var(--emerald);}
.trust-badges .tb .ic{font-size:14px;stroke-width:2.4;}

/* hero media */
.hero-media{position:relative;width:100%;max-width:440px;margin-inline:auto;}
.hero-photo{aspect-ratio:4/4.4;border-radius:24px;box-shadow:var(--shadow-lg);border:1px solid rgba(255,255,255,.16);}
.hero-float{position:absolute;top:24px;right:-14px;display:flex;align-items:center;gap:9px;
  background:#fff;border-radius:14px;padding:11px 14px;box-shadow:var(--shadow-lg);color:var(--heading);font-size:13px;font-weight:600;}
.hero-float .ic{font-size:17px;color:var(--blue);}
.hero-chip{position:absolute;left:-18px;bottom:30px;display:flex;align-items:center;gap:12px;
  background:#fff;border-radius:14px;padding:12px 15px;box-shadow:var(--shadow-lg);}
.hero-chip .ct{width:40px;height:40px;border-radius:11px;background:var(--pale);display:grid;place-items:center;color:var(--blue);flex:none;}
.hero-chip .ct .ic{font-size:20px;}
.hero-chip .cl{font-size:11.5px;color:var(--body-soft);}
.hero-chip .cv{font-size:21px;font-weight:700;color:var(--heading);}
@media(max-width:520px){
  .hero-float{right:-6px;}
  .hero-chip{left:-6px;}
}

/* ============================================================
   3. STRENGTHS
   ============================================================ */
.strengths{background:var(--bg);}
.s-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
@media(max-width:980px){.s-grid{grid-template-columns:1fr;}}
.s-card{background:#fff;border:1px solid var(--line);border-top:3px solid var(--blue);border-radius:var(--radius);
  padding:34px 30px;box-shadow:var(--shadow-sm);transition:transform .25s var(--ease),box-shadow .25s var(--ease);}
.s-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);}
.s-card .sn{font-size:13px;font-weight:700;color:var(--blue);}
.s-card .si{width:54px;height:54px;border-radius:14px;background:var(--pale);display:grid;place-items:center;color:var(--blue);margin:14px 0 18px;}
.s-card .si .ic{font-size:27px;}
.s-card h3{font-size:20px;font-weight:700;color:var(--heading);}
.s-card p{font-size:15px;color:var(--body);line-height:1.85;margin-top:12px;}

/* ============================================================
   4. STORY
   ============================================================ */
.story{background:#fff;}
.story-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;}
@media(max-width:980px){.story-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:520px){.story-grid{grid-template-columns:repeat(2,1fr);gap:12px;}}
.scene{position:relative;aspect-ratio:3/3.5;border-radius:14px;}
.scene .snum{position:absolute;top:12px;left:12px;z-index:3;min-width:30px;height:30px;padding:0 8px;border-radius:9px;
  background:var(--blue);color:#fff;font-size:14px;font-weight:700;display:grid;place-items:center;box-shadow:var(--shadow-blue);}
.scene .scap{position:absolute;left:14px;right:14px;bottom:14px;z-index:3;color:#fff;font-size:13.5px;font-weight:600;line-height:1.5;text-shadow:0 1px 6px rgba(0,0,0,.4);}

/* ============================================================
   5. STEPS
   ============================================================ */
.steps{background:#fff;}
.steps-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;}
@media(max-width:980px){.steps-grid{grid-template-columns:repeat(2,1fr);gap:32px 22px;}}
@media(max-width:520px){.steps-grid{grid-template-columns:1fr;}}
.step{position:relative;text-align:left;}
.step .sbadge{width:52px;height:52px;border-radius:50%;background:var(--blue);color:#fff;font-size:21px;font-weight:700;
  display:grid;place-items:center;box-shadow:var(--shadow-blue);}
.step .si{margin:16px 0 12px;color:var(--blue);}
.step .si .ic{font-size:28px;}
.step h3{font-size:18px;font-weight:700;color:var(--heading);}
.step p{font-size:14.5px;color:var(--body-soft);margin-top:8px;line-height:1.8;}
.step .step-line{position:absolute;top:26px;left:64px;right:-11px;height:2px;
  background:repeating-linear-gradient(90deg,var(--line) 0 6px,transparent 6px 12px);}
.step:last-child .step-line{display:none;}
@media(max-width:980px){.step .step-line{display:none;}}

/* ============================================================
   6. AUCTION（ヤマ場）
   ============================================================ */
.auction{position:relative;overflow:hidden;color:#fff;
  background:linear-gradient(160deg,#1d3677,#18285c 55%,#141f48);}
.auction::before{content:"";position:absolute;top:-10%;right:-5%;width:55%;height:70%;
  background:radial-gradient(circle at 70% 30%, rgba(31,84,222,.5), transparent 60%);pointer-events:none;}
.auction .container{position:relative;z-index:2;}
.auction-head{max-width:720px;margin:0 auto 48px;text-align:center;}
.auction-head h2{font-size:clamp(28px,4vw,40px);font-weight:700;line-height:1.4;color:#fff;margin-top:16px;}
.auction-head .sub{font-size:17px;color:#c2cdec;margin-top:16px;line-height:1.85;}

.auction-board{max-width:760px;margin:0 auto;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.14);
  backdrop-filter:blur(4px);border-radius:20px;padding:30px;}
@media(max-width:520px){.auction-board{padding:22px 18px;}}
.board-top{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:18px;flex-wrap:wrap;}
.board-top .bl{display:inline-flex;align-items:center;gap:9px;font-size:13px;font-weight:600;color:#9db6ff;}
.board-top .bl .ic{font-size:17px;}

.bid{display:grid;grid-template-columns:64px 1fr;gap:0 14px;align-items:center;padding:16px 0;border-top:1px solid rgba(255,255,255,.1);}
.bid:first-of-type{border-top:0;}
.bid .rank{width:46px;height:46px;border-radius:13px;background:rgba(255,255,255,.08);display:grid;place-items:center;font-size:18px;font-weight:700;color:#cfdcff;}
.bid .bmain{min-width:0;}
.bid .brow{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:9px;}
.bid .bco{display:inline-flex;align-items:center;gap:9px;font-size:15px;font-weight:600;color:#fff;}
.bid .bid-tag{font-size:11px;font-weight:700;color:#062e22;background:var(--emerald);border-radius:999px;padding:3px 9px;}
.bid .bamt{font-size:21px;font-weight:700;color:#fff;}
.bid .btrack{height:9px;border-radius:999px;background:rgba(255,255,255,.1);overflow:hidden;}
.bid .bbar{height:100%;border-radius:999px;background:linear-gradient(90deg,#3a64e8,#6b8eff);
  transform:scaleX(.06);transform-origin:left;transition:transform 1s var(--ease);}
.auction-board.in-view .bbar{transform:scaleX(var(--w));}
@media (prefers-reduced-motion:reduce){.bid .bbar{transition:none;transform:scaleX(var(--w));}}
.bid.win .rank{background:var(--blue);color:#fff;box-shadow:var(--shadow-blue);}
.bid.win .bbar{background:linear-gradient(90deg,#1f54de,#4f7dff);}
.bid.out{opacity:.62;}
.bid.out .bbar{background:rgba(255,255,255,.28);}
.bid .bout{display:inline-flex;align-items:center;gap:7px;font-size:14px;color:#9fb0d8;}
.bid .bout .ic{font-size:15px;}

.auction-disclaimer{font-size:12.5px;color:#8fa1cc;text-align:center;margin-top:18px;line-height:1.7;}

/* reassure band */
.reassure{max-width:760px;margin:30px auto 0;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.14);
  border-radius:18px;padding:22px;display:grid;grid-template-columns:210px 1fr;gap:22px;align-items:center;}
@media(max-width:760px){.reassure{grid-template-columns:1fr;text-align:center;}}
.reassure .photo{aspect-ratio:4/3;border-radius:13px;}
.reassure p{font-size:14.5px;line-height:1.85;color:#dde5f7;}
.reassure p strong{color:#fff;}

/* ============================================================
   7. CATS
   ============================================================ */
.cats{background:var(--bg);}
.cats-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:18px;}
@media(max-width:980px){.cats-grid{grid-template-columns:repeat(4,1fr);}}
@media(max-width:520px){.cats-grid{grid-template-columns:repeat(2,1fr);}}
.cat{background:#fff;border:1px solid var(--line);border-radius:14px;padding:24px 14px;text-align:center;
  transition:transform .2s var(--ease),border-color .2s var(--ease),box-shadow .2s var(--ease);}
.cat:hover{transform:translateY(-4px);border-color:var(--blue);box-shadow:var(--shadow-sm);}
.cat .ci{width:48px;height:48px;border-radius:13px;background:var(--pale);display:grid;place-items:center;color:var(--blue);margin:0 auto 12px;}
.cat .ci .ic{font-size:24px;}
.cat .cl{font-size:14px;font-weight:600;color:var(--heading);}

/* ============================================================
   8. AREA
   ============================================================ */
.area{background:#fff;padding:64px 0;}
.area .inner{display:flex;align-items:center;justify-content:center;gap:28px;flex-wrap:wrap;}
.area .label{display:inline-flex;align-items:center;gap:13px;font-size:18px;font-weight:700;color:var(--heading);}
.area .label .pin{width:46px;height:46px;border-radius:13px;background:var(--pale);display:grid;place-items:center;color:var(--blue);}
.area .label .pin .ic{font-size:23px;}
.area-chips{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;}
.area-chip{background:var(--pale);color:var(--blue);border-radius:999px;padding:9px 20px;font-size:15px;font-weight:700;}
.area .note{font-size:13.5px;color:var(--body-soft);width:100%;text-align:center;margin-top:6px;}

/* ============================================================
   9. FAQ
   ============================================================ */
.faq{background:#fff;}
.faq-list{max-width:780px;margin:0 auto;}
.faq-item{border:1px solid var(--line);border-radius:14px;margin-bottom:14px;transition:border-color .2s,box-shadow .2s;background:#fff;}
.faq-item.open{border-color:var(--blue);box-shadow:var(--shadow-sm);}
.faq-q{width:100%;display:flex;align-items:center;gap:14px;padding:20px 22px;text-align:left;}
.faq-q .qt{flex:none;width:28px;height:28px;border-radius:8px;background:var(--pale);color:var(--blue);font-size:14px;font-weight:700;display:grid;place-items:center;}
.faq-q .qx{flex:1;font-size:16.5px;font-weight:600;color:var(--heading);line-height:1.5;}
.faq-q .chev{flex:none;color:var(--body-soft);transition:transform .3s var(--ease);}
.faq-q .chev .ic{font-size:20px;}
.faq-item.open .chev{transform:rotate(180deg);}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s var(--ease);}
.faq-a .inner{padding:0 22px 22px 68px;font-size:15px;line-height:1.9;color:var(--body);}
@media(max-width:520px){.faq-a .inner{padding-left:24px;}}

/* ============================================================
   10. VALUE
   ============================================================ */
.value{background:var(--bg);}
.value-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;}
@media(max-width:980px){.value-grid{grid-template-columns:1fr;}}
.value-card{position:relative;aspect-ratio:16/10;border-radius:18px;}
.value-card .vtext{position:absolute;left:26px;right:26px;bottom:24px;z-index:3;}
.value-card .vstep{font-size:12px;font-weight:700;color:#bcd0ff;letter-spacing:.06em;}
.value-card h3{font-size:22px;font-weight:700;color:#fff;margin-top:8px;}
.value-card p{font-size:14px;color:#e7edfb;margin-top:8px;line-height:1.7;}

/* ============================================================
   11. FINAL CTA
   ============================================================ */
.final{background:var(--pale);}
.final .inner{max-width:680px;margin:0 auto;text-align:center;}
.final h2{font-size:clamp(28px,4.4vw,44px);font-weight:700;line-height:1.35;color:var(--heading);margin-top:16px;}
.final h2 .q{color:var(--blue);}
.final p{font-size:17px;color:var(--body-soft);margin-top:18px;line-height:1.85;}
.final .btn-primary{margin-top:30px;}
.final-note{font-size:13px;color:var(--body-soft);margin-top:20px;line-height:1.7;}

/* ============================================================
   12. FOOTER
   ============================================================ */
.footer{background:var(--navy-deep);color:#aeb9d8;padding:72px 0 36px;}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.3fr;gap:40px;padding-bottom:36px;border-bottom:1px solid rgba(255,255,255,.12);}
@media(max-width:980px){.footer-grid{grid-template-columns:1fr 1fr;gap:32px;}}
@media(max-width:520px){.footer-grid{grid-template-columns:1fr;}}
.footer .about{font-size:13.5px;color:#94a2c6;max-width:300px;margin-top:16px;line-height:1.85;}
.footer h5{font-size:13px;font-weight:700;color:#cfd8ee;margin-bottom:14px;letter-spacing:.04em;}
.footer .fcol a,.footer .fcol li{font-size:13.5px;color:#aeb9d8;line-height:1;}
.footer .fcol ul{display:grid;gap:12px;}
.footer .fcol a:hover{color:#fff;}
.footer .req{color:#7fa0ff;}
.footer-legal{padding-top:24px;}
.footer-legal .legal{font-size:12px;color:#7e8db3;max-width:880px;line-height:1.8;}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-top:18px;}
.footer-bottom .cright{font-size:12px;color:#7e8db3;}
.footer-bottom .fright{display:flex;align-items:center;gap:16px;flex-wrap:wrap;}
.footer-bottom .fright a{font-size:12px;color:#aeb9d8;}
.footer-bottom .fright a:hover{color:#fff;}

/* ---------- scroll reveal (subtle, optional) ---------- */
.reveal-on .rv{opacity:0;transform:translateY(20px);transition:opacity .7s var(--ease),transform .7s var(--ease);}
.reveal-on .rv.in{opacity:1;transform:none;}
.rv[data-d="1"]{transition-delay:.07s;}.rv[data-d="2"]{transition-delay:.14s;}.rv[data-d="3"]{transition-delay:.21s;}
@media (prefers-reduced-motion:reduce){.reveal-on .rv{opacity:1;transform:none;transition:none;}}
