/* ============================================================
   一般社団法人HAKKEN — shared design system
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Zen+Kaku+Gothic+New:wght@500;700;900&family=Noto+Sans+JP:wght@400;500;700&family=Cormorant+Garamond:wght@500;600&display=swap');

:root{
  --crimson:#c8102e;     /* deep crimson — serif hero, section bands */
  --red:#d80b30;         /* primary red — buttons, accents */
  --red-soft:#e0314e;
  --coral:#ff5b5f;       /* coral band */
  --cream:#fcf1ee;       /* warm hero / section bg */
  --gray:#eeeeee;        /* light gray section bg */
  --gray-2:#f4f4f4;
  --mint-a:#e6f4ef;      /* inner-page top gradient */
  --mint-b:#f3faf7;
  --blue:#dde9f8;        /* members / soft blue bg */
  --ink:#161616;         /* body text */
  --ink-soft:#3a3a3a;
  --muted:#7c7c7c;
  --black:#0a0a0a;       /* footer */
  --yellow:#fdf000;      /* highlighter */
  --line:#e2ddd8;
  --shadow:0 10px 30px rgba(40,20,15,.08);
  --shadow-sm:0 4px 16px rgba(40,20,15,.07);
  --maxw:1140px;
  --heading:"Zen Kaku Gothic New","Hiragino Kaku Gothic ProN","Hiragino Sans",sans-serif;
  --serif-jp:"Zen Kaku Gothic New","Hiragino Kaku Gothic ProN",sans-serif;
  --serif-en:"Cormorant Garamond",serif;
  --sans:"Hiragino Kaku Gothic ProN","Hiragino Sans","Noto Sans JP",system-ui,sans-serif;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;overflow-x:clip;}
body{
  margin:0;
  font-family:var(--sans);
  color:var(--ink);
  background:#fff;
  font-size:16px;
  line-height:1.85;
  -webkit-font-smoothing:antialiased;
  text-wrap:pretty;
  overflow-x:clip;
}
@media (max-width:620px){
  body{font-size:15px;line-height:1.8;}
}
img{max-width:100%;display:block;}
.visually-hidden{
  position:absolute;
  width:1px;height:1px;
  padding:0;margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}
a{color:inherit;text-decoration:none;}
h1,h2,h3,h4,h5,h6{font-family:var(--heading);}
.h-gothic,.band__en,.band__jp,.footer-tagline,.brand__name{font-family:var(--heading);}

/* ---------- layout ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px;}
.wrap-narrow{max-width:880px;margin:0 auto;padding:0 32px;}

/* ---------- image / embed placeholders ---------- */
.ph{
  background-color:#e9e3dd;
  background-image:repeating-linear-gradient(45deg,rgba(0,0,0,.045) 0 9px,transparent 9px 18px);
  display:flex;align-items:center;justify-content:center;text-align:center;
  color:#998f86;font-family:ui-monospace,"SF Mono",Menlo,monospace;font-size:13px;
  letter-spacing:.02em;line-height:1.5;padding:14px;border-radius:4px;
}
.ph span{display:inline-block;max-width:90%;}
.ph{overflow:hidden;}
.ph:has(img){padding:0;background-image:none;}
.ph>img{width:100%;height:100%;object-fit:cover;display:block;}
.ph--dark{background-color:#111;background-image:repeating-linear-gradient(45deg,rgba(255,255,255,.05) 0 9px,transparent 9px 18px);color:#888;}

/* ---------- highlighter ---------- */
/* ---------- emphasis (yellow marker removed per request) ---------- */
.mark{background:none;padding:0;}
.mark--full{background:none;}

/* ============================================================
   HEADER
   ============================================================ */
.site-header{
  position:sticky;top:0;z-index:50;background:#fff;
  height:72px;border-bottom:1px solid var(--line);
}
.site-header__in{
  width:100%;max-width:none;margin:0;padding:0 0 0 28px;
  height:100%;display:flex;align-items:stretch;justify-content:space-between;gap:24px;
}
.brand{
  display:flex;align-items:center;flex-shrink:0;height:100%;padding:10px 0;
}
.brand__logo{
  display:block;height:52px;width:auto;max-width:200px;
  object-fit:contain;object-position:left center;
}
.nav{
  display:flex;align-items:center;justify-content:flex-end;
  gap:24px;margin-left:auto;
}
.nav a{
  font-weight:700;font-size:13px;letter-spacing:.14em;color:var(--ink-soft);
  transition:color .2s;white-space:nowrap;
}
.nav a:hover{color:var(--red);}
.nav__burger{
  display:flex;flex-shrink:0;align-self:stretch;
  width:72px;background:var(--red);
  align-items:center;justify-content:center;cursor:pointer;border:none;
  margin-left:0;
}
.nav__burger span{position:relative;width:30px;height:2px;background:#fff;display:block;}
.nav__burger span::before,.nav__burger span::after{content:"";position:absolute;left:0;width:30px;height:2px;background:#fff;}
.nav__burger span::before{top:-9px;}
.nav__burger span::after{top:9px;}
/* burger -> X when menu open */
.nav__burger.is-open span{background:transparent;}
.nav__burger.is-open span::before{top:0;transform:rotate(45deg);}
.nav__burger.is-open span::after{top:0;transform:rotate(-45deg);}

/* ============================================================
   FULL-HIERARCHY MENU (burger overlay)
   ============================================================ */
html.navmenu-lock{overflow:hidden;}
.navmenu{
  position:fixed;inset:0;z-index:100;
  background:rgba(20,8,8,.42);backdrop-filter:blur(3px);
  opacity:0;visibility:hidden;transition:opacity .32s ease,visibility .32s;
  display:flex;justify-content:flex-end;
}
.navmenu.is-open{opacity:1;visibility:visible;}
.navmenu__inner{
  width:min(440px,100%);height:100%;background:var(--cream);
  box-shadow:-18px 0 50px rgba(40,20,15,.22);
  padding:40px 46px 56px;overflow-y:auto;
  transform:translateX(40px);transition:transform .38s cubic-bezier(.2,.8,.2,1);
  display:flex;flex-direction:column;
}
.navmenu.is-open .navmenu__inner{transform:translateX(0);}
.navmenu__head{border-bottom:1px solid var(--line);padding-bottom:22px;margin-bottom:8px;}
.navmenu__brand{font-family:var(--serif-en);font-size:30px;font-weight:600;letter-spacing:.32em;color:var(--crimson);display:block;}
.navmenu__tag{font-size:11px;letter-spacing:.14em;color:var(--ink-soft);margin-top:8px;display:block;}
.navmenu__group{padding:22px 0;border-bottom:1px solid rgba(200,16,46,.10);}
.navmenu__group:last-child{border-bottom:none;}
.navmenu__gh{display:flex;align-items:baseline;gap:12px;margin-bottom:10px;}
.navmenu__gh-en{font-family:var(--heading);font-weight:900;font-size:13px;letter-spacing:.16em;color:var(--red);}
.navmenu__gh-jp{font-size:11.5px;letter-spacing:.22em;color:var(--muted);}
.navmenu__list{list-style:none;margin:0;padding:0;}
.navmenu__list--sub{padding-left:2px;}
.navmenu__link{
  display:flex;align-items:baseline;gap:14px;padding:13px 4px;
  border-radius:8px;transition:background .2s,padding-left .2s,color .2s;
}
.navmenu__link:hover,.navmenu__link:focus-visible{background:rgba(216,11,48,.07);padding-left:14px;}
.navmenu__jp{font-family:var(--heading);font-weight:700;font-size:20px;letter-spacing:.04em;color:var(--ink);}
.navmenu__list--sub .navmenu__jp{font-size:17px;}
.navmenu__en{font-size:10.5px;letter-spacing:.16em;color:var(--muted);font-weight:700;}
.navmenu__link.is-current{background:rgba(216,11,48,.10);}
.navmenu__link.is-current .navmenu__jp{color:var(--crimson);}
@media (max-width:520px){
  .navmenu__inner{width:100%;padding:32px 26px 48px;}
  .navmenu__jp{font-size:19px;}
}

/* ============================================================
   SECTION HEADER BAND (WHAT WE DO / 事業内容)
   ============================================================ */
.band{background:var(--red);color:#fff;text-align:center;padding:34px 20px;}
.band__en{font-size:34px;font-weight:900;letter-spacing:.16em;line-height:1;}
.band__jp{font-size:15px;letter-spacing:.5em;margin-top:14px;padding-left:.5em;font-weight:500;}

/* ---------- generic section heading (gothic + yellow) ---------- */
.h-gothic{
  font-weight:900;font-size:38px;letter-spacing:.04em;line-height:1.3;
  text-align:center;color:var(--ink);
}
.h-gothic.left{text-align:left;}
.sec{padding:90px 0;}
.sec-label{font-weight:500;font-size:13px;color:#222;margin-bottom:16px;letter-spacing:.02em;}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:18px;
  font-weight:700;font-size:16px;letter-spacing:.04em;cursor:pointer;border:none;
  transition:transform .15s, box-shadow .2s, background .2s, color .2s;
}
.btn--red{
  background:var(--red);color:#fff;padding:20px 34px;border-radius:8px;width:100%;
  justify-content:space-between;box-shadow:0 6px 18px rgba(216,11,48,.22);
}
.btn--red .arw{font-size:18px;}
.btn--red:hover{background:#c00a2b;transform:translateY(-1px);}
.btn--text{
  background:none;color:var(--red);padding:0;width:auto;max-width:100%;
  justify-content:flex-start;gap:8px;box-shadow:none;border-radius:0;
  font-weight:700;font-size:15px;letter-spacing:.02em;
}
.btn--text:hover{background:none;color:var(--crimson);transform:none;}
.btn--text .arw{font-size:16px;line-height:1;transition:transform .25s cubic-bezier(.2,.7,.2,1);}
.btn--text:hover .arw{transform:translateX(5px);}
.btn--pill{background:#fff;border:1px solid #cfcfcf;border-radius:999px;padding:16px 56px;color:#222;font-weight:500;}
.btn--pill:hover{border-color:#999;}
.btn--solid{background:var(--red);color:#fff;border-radius:8px;padding:18px 40px;box-shadow:0 6px 18px rgba(216,11,48,.22);}
.btn--solid:hover{background:#c00a2b;}
.btn--ghost{background:#fff;border:1px solid #d2d2d2;border-radius:8px;padding:18px 40px;color:#222;}
.btn-row{display:flex;gap:22px;flex-wrap:wrap;}

/* ============================================================
   CARDS
   ============================================================ */
.card{background:#fff;border-radius:12px;box-shadow:var(--shadow-sm);}

/* news cards */
.news-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:24px;margin-top:54px;}
.news-card{background:#fff;border-radius:10px;box-shadow:var(--shadow-sm);overflow:hidden;display:flex;flex-direction:column;}
.news-card .ph{aspect-ratio:16/10;border-radius:0;}
.news-card__body{padding:20px 20px 26px;display:flex;flex-direction:column;flex:1;}
.news-card__title{font-weight:700;font-size:15px;line-height:1.6;}
.news-card__date{margin-top:auto;padding-top:22px;color:var(--muted);font-size:14px;}

/* stat cards */
.stat-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:26px;margin-top:54px;}
.stat-card{background:#fff;border-radius:14px;box-shadow:var(--shadow);padding:30px 30px 32px;min-width:0;}
.stat-card__label{text-align:center;font-weight:700;font-size:16px;padding-bottom:14px;border-bottom:2px solid #f3c9cf;}
.stat-card__big{text-align:center;margin:22px 0 18px;font-weight:900;line-height:1;}
.stat-card__big b{color:var(--red);font-size:64px;}
.stat-card__big i{font-style:normal;font-size:26px;}
.stat-card__rows{display:flex;gap:20px;align-items:flex-end;justify-content:space-between;}
.stat-card__years{display:flex;flex-direction:column;gap:8px;font-size:15px;}
.stat-card__years div{display:flex;gap:12px;align-items:baseline;}
.stat-card__years .y{color:#555;}
.stat-card__years .v{color:var(--red);font-weight:900;font-size:22px;}
.stat-card__icon{width:96px;height:84px;flex:none;}
.stat-card__icon .ph{width:100%;height:100%;background:transparent;}
.stat-card__icon .ph>img{object-fit:contain;}

/* member cards */
.member-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:22px;margin-top:50px;}
.member-card{background:#fff;border-radius:10px;box-shadow:var(--shadow-sm);padding:30px 22px 28px;text-align:center;}
.member-card.is-red{background:var(--crimson);color:#fff;}
.member-card__photo{width:128px;height:128px;border-radius:50%;margin:0 auto 18px;overflow:hidden;
  background-color:#e7b9bf;background-image:repeating-linear-gradient(45deg,rgba(0,0,0,.05) 0 8px,transparent 8px 16px);
  display:flex;align-items:center;justify-content:center;color:#fff;font-family:ui-monospace,monospace;font-size:11px;}
.member-card__photo img{width:100%;height:100%;object-fit:cover;display:block;}
.member-card__role{font-size:13px;font-weight:700;}
.member-card__name{font-size:20px;font-weight:700;margin:6px 0 14px;}
.member-card__bio{font-size:13.5px;line-height:1.85;text-align:justify;}
.member-card.is-red .member-card__bio{color:#fff;}

/* feature box (effects / reasons) */
.fbox{background:#fff;border:1px solid #ececec;border-radius:16px;box-shadow:var(--shadow-sm);padding:40px 44px;}
.fbox__head{color:var(--red);font-weight:700;font-size:19px;margin:0 0 16px;}
.fbox ul{margin:0;padding:0;list-style:none;}
.fbox li{position:relative;padding-left:22px;margin:10px 0;font-size:16px;}
.fbox li::before{content:"・";position:absolute;left:0;}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{background:var(--black);color:#fff;padding:64px 0 60px;}
.site-footer__in{max-width:1240px;margin:0 auto;padding:0 40px;display:flex;justify-content:space-between;align-items:flex-end;gap:40px;}
.footer-tagline{font-size:46px;font-weight:900;line-height:1.35;letter-spacing:.02em;}
.footer-meta{text-align:right;font-size:13px;line-height:2;}
.footer-meta__org{font-weight:700;font-size:16px;letter-spacing:.08em;margin-bottom:10px;}
.footer-meta a{color:#fff;margin:0 .35em;letter-spacing:.06em;}
.footer-meta a:hover{color:var(--coral);}

/* ============================================================
   responsive
   ============================================================ */
@media (max-width:900px){
  .nav{gap:16px;}
  .nav a{font-size:12px;letter-spacing:.1em;}
  .news-grid{grid-template-columns:repeat(2,1fr);gap:20px;margin-top:40px;}
  .stat-grid{grid-template-columns:1fr;gap:20px;margin-top:40px;}
  .member-grid{grid-template-columns:repeat(2,1fr);gap:18px;margin-top:36px;}
  .footer-tagline{font-size:30px;}
  .site-footer__in{flex-direction:column;align-items:flex-start;}
  .footer-meta{text-align:left;}
  .fbox{padding:32px 28px;}
}
@media (max-width:768px){
  .site-header__in{padding:0 0 0 16px;}
  .nav{display:none;}
  .brand__logo{height:46px;max-width:min(180px,52vw);}
  .nav__burger{width:64px;}
  .site-footer{padding:48px 0 44px;}
  .site-footer__in{padding:0 24px;gap:32px;}
  .footer-meta{font-size:12.5px;line-height:1.9;}
  .footer-meta a{display:inline-block;margin:.15em .5em .15em 0;}
  /* members — larger profile photos on mobile */
  .member-grid{grid-template-columns:1fr;gap:20px;}
  .member-card{padding:32px 24px 28px;}
  .member-card__photo{width:172px;height:172px;margin-bottom:20px;}
  .member-card__name{font-size:19px;}
}
@media (max-width:620px){
  .wrap,.wrap-narrow{padding:0 18px;}
  .site-header{height:60px;}
  .nav__burger{width:60px;}
  .brand__logo{height:40px;max-width:min(160px,48vw);}
  .h-gothic{font-size:26px;line-height:1.35;}
  .band{padding:28px 16px;}
  .band__en{font-size:22px;letter-spacing:.12em;}
  .band__jp{font-size:13px;letter-spacing:.28em;margin-top:10px;}
  .news-grid{grid-template-columns:1fr;gap:18px;margin-top:32px;}
  .news-card__body{padding:18px 18px 22px;}
  .news-card__title{font-size:16px;line-height:1.65;}
  .member-grid{grid-template-columns:1fr;gap:16px;margin-top:28px;}
  .member-card{padding:26px 20px 24px;}
  .member-card__name{font-size:18px;}
  .member-card__bio{font-size:14px;line-height:1.75;}
  .sec{padding:52px 0;}
  .sec-label{font-size:12.5px;margin-bottom:12px;}
  .stat-grid{margin-top:32px;}
  .stat-card{padding:24px 20px 26px;border-radius:12px;}
  .stat-card__label{font-size:15px;padding-bottom:12px;}
  .stat-card__big{margin:18px 0 14px;}
  .stat-card__big b{font-size:52px;}
  .stat-card__big i{font-size:22px;}
  .stat-card__rows{flex-direction:column;align-items:flex-start;gap:16px;}
  .stat-card__years{font-size:14px;width:100%;}
  .stat-card__years .v{font-size:20px;}
  .stat-card__icon{width:88px;height:72px;align-self:center;}
  .btn{font-size:15px;}
  .btn--red{padding:18px 22px;min-height:52px;}
  .btn--pill{padding:14px 32px;width:100%;max-width:320px;}
  .btn--solid,.btn--ghost{padding:16px 28px;width:100%;max-width:340px;}
  .btn-row{flex-direction:column;align-items:stretch;}
  .btn-row .btn{width:100%;max-width:none;}
  .fbox{padding:28px 22px;border-radius:12px;}
  .fbox__head{font-size:17px;}
  .fbox li{font-size:15px;line-height:1.75;}
  .footer-tagline{font-size:24px;line-height:1.4;}
  .footer-meta__org{font-size:15px;}
}
@media (max-width:480px){
  .wrap,.wrap-narrow{padding:0 16px;}
  .h-gothic{font-size:23px;}
  .band__en{font-size:19px;}
  .band__jp{font-size:12px;letter-spacing:.22em;}
  .stat-card__big b{font-size:44px;}
  .stat-card__big i{font-size:20px;}
  .footer-tagline{font-size:21px;}
  .site-footer{padding:40px 0 36px;}
}

/* ============================================================
   INTERACTIONS & MOTION  (added)
   ============================================================ */

/* custom cursor (desktop pointer only, set by JS) */
html.has-cursor, html.has-cursor *{cursor:none !important;}
.cursor-dot,.cursor-ring{position:fixed;top:0;left:0;z-index:300;pointer-events:none;border-radius:50%;
  transform:translate(-50%,-50%);will-change:transform;}
.cursor-dot{width:7px;height:7px;background:var(--red);}
.cursor-ring{width:34px;height:34px;border:2px solid rgba(216,11,48,.55);
  transition:width .22s,height .22s,background .22s,border-color .22s;}
.cursor-ring.is-hot{width:58px;height:58px;background:rgba(216,11,48,.10);border-color:var(--red);}

/* header scroll state */
.site-header{transition:box-shadow .35s,background .35s;}
.site-header.scrolled{box-shadow:var(--shadow-sm);}
.brand__logo{transition:transform .35s,opacity .35s;}
.site-header.scrolled .brand__logo{transform:scale(.92);opacity:.95;}
.nav a{position:relative;}
.nav a::after{content:"";position:absolute;left:0;right:100%;bottom:-6px;height:2px;background:var(--red);
  transition:right .28s cubic-bezier(.2,.7,.2,1);}
.nav a:hover::after{right:0;}
.nav a.is-current{color:var(--red);}
.nav a.is-current::after{right:0;}
.nav__burger span,.nav__burger span::before,.nav__burger span::after{transition:transform .3s,width .3s;}
.nav__burger:hover span::before{transform:translateX(-4px);}
.nav__burger:hover span::after{transform:translateX(4px);}

/* ---- highlighter (disabled) ---- */

/* ---- scroll reveal ---- */
html.js [data-reveal]{opacity:0;transform:translateY(30px);
  transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1);
  transition-delay:var(--rd,0ms);will-change:opacity,transform;}
html.js [data-reveal="left"]{transform:translateX(-44px);}
html.js [data-reveal="right"]{transform:translateX(44px);}
html.js [data-reveal="zoom"]{transform:scale(.92);}
html.js [data-reveal].is-in{opacity:1;transform:none;}

/* ---- hover lifts / zoom ---- */
.news-card,.stat-card,.member-card,.flow-card,.fbox,.together__card,.kikkake__card,.sp-employ__card{
  transition:transform .4s cubic-bezier(.2,.7,.2,1),box-shadow .4s;}
.news-card .ph,.gallery .ph,.marche__row .ph,.member-card__photo{transition:transform .6s cubic-bezier(.2,.7,.2,1);}
.news-card{cursor:pointer;}
.news-card:hover{transform:translateY(-10px);box-shadow:0 22px 44px rgba(40,20,15,.16);}
.news-card:hover .ph{transform:scale(1.07);}
.stat-card:hover{transform:translateY(-8px) rotate(-.6deg);box-shadow:0 24px 48px rgba(200,16,46,.16);}
.member-card:hover{transform:translateY(-8px);box-shadow:0 22px 44px rgba(40,20,15,.16);}
.member-card:hover .member-card__photo{transform:scale(1.07) rotate(2deg);}
.flow-card:hover{transform:translateY(-8px);box-shadow:0 20px 40px rgba(40,20,15,.14);}
.gallery .ph{cursor:pointer;}
.gallery .ph:hover{transform:scale(1.06);box-shadow:0 16px 32px rgba(40,20,15,.16);z-index:2;}
.fbox:hover{transform:translateY(-5px);box-shadow:0 18px 38px rgba(40,20,15,.12);}

/* ---- buttons: arrow slide + sheen ---- */
.btn{position:relative;overflow:hidden;}
.btn .arw{transition:transform .3s cubic-bezier(.2,.7,.2,1);}
.btn:hover .arw{transform:translateX(7px);}
.btn--red::before,.btn--solid::before{content:"";position:absolute;top:0;left:-120%;width:60%;height:100%;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.32),transparent);transform:skewX(-18deg);
  transition:left .6s cubic-bezier(.2,.7,.2,1);}
.btn--text::before{display:none;}
.btn--red:hover::before,.btn--solid:hover::before{left:140%;}
.btn--pill,.btn--ghost{transition:transform .25s,border-color .25s,background .25s,color .25s,box-shadow .25s;}
.btn--pill:hover{transform:translateY(-2px);box-shadow:0 10px 24px rgba(40,20,15,.10);}
.btn--ghost:hover{transform:translateY(-2px);border-color:var(--red);color:var(--red);}

/* ---- count-up flip pop ---- */
.stat-card__big b{display:inline-block;transition:transform .25s;}
.stat-card.is-counted .stat-card__big b{animation:popNum .5s cubic-bezier(.2,1.4,.5,1);}
@keyframes popNum{0%{transform:scale(.6)}60%{transform:scale(1.12)}100%{transform:scale(1)}}

/* ---- red band: moving stripes + breathing ---- */
.band{position:relative;overflow:hidden;}
.band::before{content:"";position:absolute;inset:0;
  background:repeating-linear-gradient(115deg,rgba(255,255,255,.07) 0 14px,transparent 14px 38px);
  animation:bandSlide 11s linear infinite;}
.band__en,.band__jp{position:relative;}
@keyframes bandSlide{from{background-position:0 0}to{background-position:140px 0}}

/* ---- hero kinetic headline ---- */
.hero-h{margin:0;}
.hero-h .line{display:block;overflow:hidden;}
.hero-h .line > span{display:block;transform:none;}
html.js .hero-h .line > span{animation:lineUp 1s cubic-bezier(.16,1,.3,1) both;}
html.js .hero-h .line:nth-child(1) > span{animation-delay:.12s;}
html.js .hero-h .line:nth-child(2) > span{animation-delay:.30s;}
html.js .hero-h .line:nth-child(3) > span{animation-delay:.48s;}
@keyframes lineUp{from{transform:translateY(115%)}to{transform:translateY(0)}}
.hero-h .accent{position:relative;}

/* ---- "イノベーション" innovation effect ---- */
.innovate{display:inline-block;position:relative;color:var(--crimson);}
.innovate .ch{
  display:inline-block;color:var(--crimson);
  will-change:transform,opacity,color;
}
/* JS-driven: hidden until live so the decode reveal reads cleanly */
html.js .innovate .ch{opacity:0;transform:translateY(10%);transition:opacity .35s,transform .35s;}
html.js .innovate.is-live .ch{opacity:1;transform:none;}
/* traveling glow wave across the locked word */
.innovate .ch.flash{color:#ff7a3d;text-shadow:0 0 18px rgba(255,122,61,.55);}
.innovate .ch{transition:opacity .35s,transform .35s,color .45s,text-shadow .45s;}
/* circuit-scan underline (normal gradient bar — not text-clip) */
.innovate::after{content:"";position:absolute;left:0;right:0;bottom:-.04em;height:.07em;border-radius:2px;
  background:linear-gradient(90deg,transparent,var(--red),#ff7a3d,transparent);
  background-size:220% 100%;opacity:0;}
html.js .innovate.is-live::after{opacity:.85;animation:innoScan 3.2s ease-in-out infinite;}
@keyframes innoScan{0%{background-position:130% 0}100%{background-position:-130% 0}}

/* floating scroll cue on hero */
.scroll-cue{display:flex;flex-direction:column;align-items:center;gap:8px;margin:54px auto 0;width:max-content;
  color:var(--crimson);font-size:11px;letter-spacing:.3em;font-weight:700;opacity:0;animation:cueIn .6s 1.3s forwards;}
.scroll-cue i{width:1px;height:46px;background:var(--crimson);position:relative;overflow:hidden;}
.scroll-cue i::after{content:"";position:absolute;top:-50%;left:0;width:100%;height:50%;background:#fff;
  animation:cueRun 1.7s ease-in-out infinite;}
@keyframes cueIn{to{opacity:.85}}
@keyframes cueRun{0%{top:-60%}100%{top:120%}}

/* hero parallax target */
.hero__photo{will-change:transform;}

/* reduced motion: show everything, kill motion */
@media (prefers-reduced-motion: reduce){
  html.js [data-reveal]{opacity:1 !important;transform:none !important;}
  html.js .mark{background-size:100% 100% !important;transition:none;}
  .band::before,.scroll-cue,.scroll-cue i::after{animation:none !important;}
  html.js .hero-h .line > span{animation:none !important;transform:none !important;}
}
