:root{
  --red:#F50000;
  --red2:#B20000;
  --black:#000;
  --white:#fff;
  --muted:#bdbdbd;
  --muted2:#8a8a8a;
  --glass:rgba(10,10,10,.78);
  --lineR:rgba(245,0,0,.35);
  --lineW:rgba(255,255,255,.14);
  --shadowR:0 0 24px rgba(245,0,0,.22), 0 0 70px rgba(0,0,0,.58);
  --shadowT:0 0 10px rgba(245,0,0,.32);
  --radius:6px;

  --wrap:1180px;
  --padX:clamp(18px,5vw,64px);
  --secY:clamp(72px,10vw,132px);

  --font-en:"Montserrat", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  --font-jp:"Noto Sans JP", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  color:var(--white);
  background:var(--black);
  font-family:var(--font-jp);
  line-height:1.7;
  line-break: strict;
  overflow-x:hidden;
}
a{color:inherit}
img{max-width:100%;height:auto;display:block}
button,input,textarea{font:inherit}

.skip{
  position:absolute; left:-9999px; top:0;
  background:var(--red); color:#fff;
  padding:10px 14px; z-index:9999;
}
.skip:focus{left:14px;top:14px;outline:2px solid #fff}

.wrap{max-width:var(--wrap); margin:0 auto; padding:0 var(--padX)}

.u-red{color:var(--red); text-shadow:var(--shadowT)}
.u-muted{color:var(--muted)}

.header{
  position:sticky; top:0; z-index:50;
  backdrop-filter: blur(10px);
  background:linear-gradient(to bottom, rgba(0,0,0,.76), rgba(0,0,0,.26));
  border-bottom:1px solid rgba(245,0,0,.18);
}
.header__inner{
  max-width:var(--wrap); margin:0 auto;
  padding:14px var(--padX);
  display:flex; align-items:center; justify-content:space-between;
  gap:16px;
}
.brand{
  display:flex; align-items:center; gap:12px;
  text-decoration:none;
}
.brand__mark{
  width:14px; height:14px;
  background:var(--red);
  box-shadow:0 0 26px rgba(245,0,0,.4);
}
.brand__text{
  font-family:var(--font-en);
  letter-spacing:.18em;
  font-weight:900;
  font-size:14px;
}
.nav{display:flex; gap:18px; align-items:center}
.nav__link{
  font-family:var(--font-en);
  text-decoration:none;
  font-weight:800;
  font-size:12px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:rgba(255,255,255,.84);
  position:relative;
  padding:10px 2px;
}
.nav__link:after{
  content:"";
  position:absolute; left:0; right:0; bottom:2px;
  height:1px;
  background:linear-gradient(90deg, transparent, rgba(245,0,0,.8), transparent);
  transform:scaleX(0);
  transform-origin:center;
  transition:transform .35s ease;
}
.nav__link:hover{color:#fff}
.nav__link:hover:after{transform:scaleX(1)}
.nav__link.is-active{color:#fff}
.nav__link.is-active:after{transform:scaleX(1)}

/* mobile nav (hamburger) */
.navToggle{
  display:none;
  align-items:center;
  gap:10px;
  background:transparent;
  border:1px solid rgba(255,255,255,.16);
  color:#fff;
  padding:10px 12px;
  min-height:44px;
}
.navToggle:focus{outline:2px solid var(--red); outline-offset:3px}
.navToggle__label{
  font-family:var(--font-en);
  font-weight:900;
  letter-spacing:.22em;
  font-size:11px;
}
.navToggle__bars{
  width:22px;
  height:12px;
  position:relative;
  display:inline-block;
}
.navToggle__bars:before,
.navToggle__bars:after{
  content:"";
  position:absolute;
  left:0; right:0;
  height:2px;
  background:#fff;
  box-shadow:0 0 18px rgba(245,0,0,.18);
}
.navToggle__bars:before{top:0}
.navToggle__bars:after{bottom:0}

.navOverlay{
  display:none;
}

body.is-navOpen{overflow:hidden}

@media (max-width: 860px){
  .header__inner{gap:10px}
  .brand__text{letter-spacing:.14em}
  .navToggle{display:inline-flex}

  .navOverlay{
    display:block;
    position:fixed;
    inset:0;
    background:rgba(0,0,0,.62);
    opacity:0;
    pointer-events:none;
    transition:opacity .25s ease;
    z-index:110;
  }

  .nav{
    position:fixed;
    inset:0;
    padding:84px max(18px, 6vw) 28px;
    flex-direction:column;
    align-items:flex-start;
    gap:10px;
    background:
      radial-gradient(900px 520px at 30% 20%, rgba(245,0,0,.12), transparent 60%),
      linear-gradient(180deg, rgba(0,0,0,.92), rgba(0,0,0,.82));
    opacity:0;
    transform:translate3d(0,-10px,0);
    pointer-events:none;
    transition:opacity .25s ease, transform .35s cubic-bezier(.18,.92,.18,1);
    z-index:120;
  }
  .nav__link{
    width:100%;
    font-size:14px;
    letter-spacing:.22em;
    padding:14px 6px;
    border-bottom:1px solid rgba(255,255,255,.10);
  }
  .nav__link:after{display:none}

  body.is-navOpen .nav{
    opacity:1;
    transform:translate3d(0,0,0);
    pointer-events:auto;
  }
  body.is-navOpen .navOverlay{
    opacity:1;
    pointer-events:auto;
  }

  /* hamburger -> X */
  body.is-navOpen .navToggle__bars:before{
    top:5px;
    transform:rotate(45deg);
  }
  body.is-navOpen .navToggle__bars:after{
    bottom:5px;
    transform:rotate(-45deg);
  }
}

.hero{
  position:relative;
  padding:clamp(72px,10vw,120px) 0 var(--secY);
}
.hero--stage{
  min-height: 100svh;
  padding:0;
  display:flex;
  align-items:stretch;
}
.hero__bg{
  position:absolute; inset:0;
  pointer-events:none;
  overflow:hidden;
}
#bg-canvas{
  width:100%; height:100%;
  display:block;
  opacity:.9;
}
.hero__wrap{position:relative}
.hero--stage .hero__wrap{
  min-height:100svh;
  display:flex;
  flex-direction:column;
  justify-content:center;
  padding:clamp(64px,8vw,110px) 0 calc(clamp(64px,8vw,110px) + 70px);
}
.hero--stage:after{
  content:"";
  position:absolute;
  left:0; right:0; bottom:-1px;
  height:120px;
  background:linear-gradient(to bottom, rgba(0,0,0,0), rgba(0,0,0,.75));
  pointer-events:none;
  z-index:1;
}

/* hero HUD (tiny labels) */
.heroHud{
  position:absolute;
  inset:0;
  pointer-events:none;
  z-index:10;
}
.heroHud__item{position:absolute; opacity:0;}
.heroHud__item--tl{left:0; top:0;}
.heroHud__item--tc{left:50%; top:0; transform:translateX(-50%);}
.heroHud__item--tr{right:0; top:0;}
.heroHud__item--ml{left:0; top:50%; transform:translateY(-50%);}
.heroHud__item--mr{right:0; top:50%; transform:translateY(-50%);}

.hud{
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px 10px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(0,0,0,.22);
  backdrop-filter: blur(6px);
}
.hud--center{justify-content:center}
.hud__no{
  font-family:var(--font-en);
  font-weight:900;
  letter-spacing:.18em;
  font-size:10px;
  color:rgba(255,255,255,.8);
}
.hud__txt{
  font-family:var(--font-en);
  font-weight:900;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-size:10px;
  color:rgba(255,255,255,.78);
}
.hud__state{
  margin-left:8px;
  font-family:var(--font-en);
  font-weight:900;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-size:10px;
  color:rgba(245,0,0,.9);
  opacity:.9;
}
.hud.is-locked{
  border-color:rgba(245,0,0,.35);
  background:rgba(0,0,0,.32);
}
.hud.is-locked .hud__txt{color:#fff}
.hud:before{
  content:"+";
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:18px; height:18px;
  border:1px solid rgba(245,0,0,.25);
  color:rgba(245,0,0,.85);
  font-family:var(--font-en);
  font-weight:900;
}
.hud--center:before{display:none}

.kicker{
  font-family:var(--font-en);
  font-weight:900;
  letter-spacing:.28em;
  text-transform:uppercase;
  font-size:12px;
  color:rgba(255,255,255,.78);
  margin:0 0 18px;
}
.kicker--dark{color:rgba(0,0,0,.72)}

.hero__title{
  margin:0;
  font-family:var(--font-jp);
  font-weight:800;
  line-height:1.08;
  letter-spacing:-.02em;
  font-size:clamp(42px,6vw,74px);
}
.hero__titleLine{display:block}
.hero__titleLine--red{color:var(--red); text-shadow:var(--shadowT)}

.hero__lead{
  max-width:860px;
  margin:22px 0 0;
  font-size:clamp(15px,1.2vw,18px);
  color:rgba(255,255,255,.86);
}
.hero__lead strong{font-weight:800}

.heroStage{
  width:100%;
  position:relative;
}
.heroStage__word{
  margin:0;
  position:relative;
  z-index:3;
  font-family:var(--font-en);
  font-weight:900;
  letter-spacing:.12em;
  line-height:0.9;
  font-size:clamp(64px, 10.5vw, 168px);
  text-transform:uppercase;
  text-shadow:var(--shadowT);
  transform:translateZ(0);
}
.heroStage__under,
.heroStage__over{
  position:absolute;
  inset:-12px -10px -12px -10px;
  pointer-events:none;
}
.heroStage__under{z-index:0;}
.heroStage__over{z-index:4;}
.heroStage__dots{
  position:absolute;
  inset:0;
  opacity:.16;
  background:
    radial-gradient(circle at 1px 1px, rgba(255,255,255,.55) 1px, transparent 1.5px);
  background-size:62px 62px;
  mix-blend-mode:screen;
}
.heroStage__frame{
  position:absolute;
  inset:16px;
  border:1px solid rgba(255,255,255,.12);
  opacity:0;
}
.heroStage__shutter{
  position:absolute;
  left:-10%;
  width:120%;
  height:52%;
  background:#000;
  opacity:1;
  transform:scaleY(1);
  transform-origin:50% 50%;
  border:1px solid rgba(245,0,0,.12);
}
.heroStage__shutter--top{top:-1px; transform-origin:50% 0%;}
.heroStage__shutter--bottom{bottom:-1px; transform-origin:50% 100%;}
.heroStage__plate{
  position:absolute;
  left:-6%;
  top:50%;
  width:112%;
  height:clamp(78px, 16vh, 170px);
  transform:translateY(-50%) scaleX(0);
  transform-origin:0% 50%;
  background:var(--red);
  opacity:0;
  filter:drop-shadow(0 0 24px rgba(245,0,0,.22));
}
.heroStage__wipe{
  position:absolute;
  left:-10%;
  top:42%;
  width:120%;
  height:2px;
  background:linear-gradient(90deg, transparent, rgba(245,0,0,.95), transparent);
  filter:drop-shadow(0 0 14px rgba(245,0,0,.45));
  opacity:0;
  transform:translateY(-50%) scaleX(.2);
  transform-origin:50% 50%;
}
.heroStage__wipe--r{
  top:60%;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,.55), transparent);
  filter:drop-shadow(0 0 10px rgba(255,255,255,.18));
}
.heroStage__wipe--w2{
  top:34%;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,.42), transparent);
  filter:drop-shadow(0 0 10px rgba(255,255,255,.14));
}
.heroStage__wipe--k{
  top:72%;
  background:linear-gradient(90deg, transparent, rgba(0,0,0,.95), transparent);
  filter:none;
}
.heroStage__scan{
  position:absolute;
  inset:0;
  background:
    repeating-linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.06) 1px, transparent 1px, transparent 4px);
  opacity:0;
  mix-blend-mode:screen;
}

/* RYDEN-like bands + microtype */
.heroStage__bands{
  position:absolute;
  inset:0;
  pointer-events:none;
  opacity:1;
}
.heroStage__band{
  position:absolute;
  left:-10%;
  width:120%;
  height:clamp(44px, 8vh, 92px);
  top:50%;
  transform:translateY(-50%) scaleX(0);
  transform-origin:0% 50%;
  opacity:0;
}
.heroStage__band.is-thin{height:clamp(10px, 2vh, 18px)}
.heroStage__band--red{background:var(--red)}
.heroStage__band--white{background:#fff}
.heroStage__band--black{background:#000}
.heroStage__band:nth-child(1){top:40%}
.heroStage__band:nth-child(2){top:52%}
.heroStage__band:nth-child(3){top:64%}
.heroStage__band:nth-child(4){top:32%}
.heroStage__band:nth-child(5){top:74%}

.heroStage__micro{
  position:absolute;
  left:0; right:0;
  top:16px;
  height:80px;
  opacity:0;
  font-family:var(--font-en);
  font-weight:900;
  letter-spacing:.24em;
  text-transform:uppercase;
  font-size:10px;
  color:rgba(255,255,255,.75);
  mix-blend-mode:screen;
  pointer-events:none;
  overflow:hidden;
}
.heroStage__microTrack{
  position:absolute;
  left:0; top:0;
  display:flex;
  gap:48px;
  white-space:nowrap;
  transform:translateX(0);
}

.heroStage__word .mask{
  display:inline-block;
  overflow:hidden;
  vertical-align:baseline;
}
.heroStage__word .mask__inner{
  display:inline-block;
  will-change:transform, opacity;
}

/* ghost layers for aggressive/mechanical look */
.heroStage__ghostWrap{
  position:absolute;
  left:0; top:0;
  width:100%;
  pointer-events:none;
  z-index:6;
}
.heroStage__ghost{
  position:absolute;
  left:0; top:0;
  margin:0;
  font-family:var(--font-en);
  font-weight:900;
  letter-spacing:.12em;
  line-height:0.9;
  font-size:clamp(64px, 10.5vw, 168px);
  text-transform:uppercase;
  opacity:0;
  will-change:transform, opacity, clip-path;
}
.heroStage__ghost--red{color:rgba(245,0,0,.92); mix-blend-mode:screen;}
.heroStage__ghost--white{color:rgba(255,255,255,.65); mix-blend-mode:screen;}
.heroStage__ghost--black{color:rgba(0,0,0,.98); mix-blend-mode:multiply;}
.heroStage__glow{
  position:absolute;
  left:0; top:50%;
  width:min(760px, 78vw);
  height:220px;
  transform:translateY(-50%);
  background:radial-gradient(closest-side, rgba(245,0,0,.22), transparent 70%);
  filter:blur(10px);
  pointer-events:none;
  opacity:.9;
  z-index:1;
}
.heroStage__sub{
  position:relative;
  z-index:3;
  margin-top:18px;
  font-family:var(--font-en);
  font-weight:900;
  letter-spacing:.28em;
  text-transform:uppercase;
  font-size:12px;
  color:rgba(255,255,255,.66);
}

/* "silence frame": one instant where only the main word remains */
body.is-silence .heroHud,
body.is-silence .heroStage__under,
body.is-silence .heroStage__over,
body.is-silence .heroStage__ghostWrap,
body.is-silence .heroStage__sub{
  opacity:0 !important;
}
body.is-silence #bg-canvas{
  opacity:0 !important;
}

/* tagline */
.section--tagline{
  padding:clamp(64px,9vw,120px) 0;
  border-top:none;
  position:relative;
  overflow:hidden;
}
.section--tagline:before{
  content:"";
  position:absolute;
  inset:-1px 0 -1px 0;
  background:
    radial-gradient(900px 520px at 30% 10%, rgba(245,0,0,.12), transparent 60%),
    radial-gradient(760px 520px at 70% 30%, rgba(245,0,0,.08), transparent 60%),
    radial-gradient(circle at 1px 1px, rgba(255,255,255,.55) 1px, transparent 1.5px);
  background-size:auto, auto, 62px 62px;
  opacity:.18;
  pointer-events:none;
  mix-blend-mode:screen;
}
.section--tagline:after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,.0), rgba(0,0,0,.35) 55%, rgba(0,0,0,.65));
  pointer-events:none;
}
.section--tagline > .wrap{position:relative; z-index:1;}
.tagline{
  margin:0;
  font-family:var(--font-jp);
  font-weight:900;
  letter-spacing:-.02em;
  line-height:1.05;
  font-size:clamp(34px,5.2vw,76px);
  word-break:keep-all;
  text-wrap:balance;
}
.tagline--minimal{margin-bottom:clamp(26px,4vw,40px)}
.tagline__core{
  margin:0 0 14px;
  max-width:860px;
  color:rgba(255,255,255,.86);
  font-weight:700;
}
.capabilities{
  display:flex;
  align-items:center;
  gap:12px;
  margin:0 0 18px;
  font-family:var(--font-en);
  font-weight:900;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-size:11px;
  color:rgba(255,255,255,.78);
}
.capabilities__sep{opacity:.35}
.tagline__sub{
  margin:16px 0 0;
  color:rgba(255,255,255,.82);
  max-width:860px;
}
.tagline .mask{
  display:inline-block;
  overflow:hidden;
}
.tagline .mask__inner{
  display:inline-block;
  will-change:transform, opacity;
}

/* mask (generic) */
.mask{display:inline-block; overflow:hidden; vertical-align:baseline}
.mask__inner{display:inline-block; will-change:transform, opacity}

/* statement */
.statement{
  margin-top:clamp(26px,5vw,56px);
  display:block;
}
.statement__p{
  margin:0 0 16px;
  color:rgba(255,255,255,.86);
  max-width:860px;
}
.statement__p:last-child{margin-bottom:0}

/* corporate statement (tagline: rebuilt from scratch, calmer + sharper) */
.corpStatement{
  display:grid;
  grid-template-columns:minmax(160px, 240px) minmax(0, 1fr);
  gap:clamp(18px, 4vw, 60px);
  align-items:start;
}
.corpStatement__side{position:relative; padding-top:6px;}
.corpStatement__kicker{
  font-family:var(--font-en);
  font-weight:900;
  letter-spacing:.24em;
  text-transform:uppercase;
  font-size:11px;
  color:rgba(255,255,255,.72);
  line-height:1.2;
}
.corpStatement__rail{
  margin-top:16px;
  width:1px;
  height:clamp(260px, 52vh, 620px);
  background:linear-gradient(180deg, rgba(245,0,0,.65), rgba(255,255,255,.14), transparent);
  opacity:.95;
  transform:scaleY(0);
  transform-origin:top;
  transition:transform .85s cubic-bezier(.18,.92,.18,1) .05s;
}
.corpStatement__side.is-revealed .corpStatement__rail{transform:scaleY(1);}

.corpStatement__main{min-width:0;}
.corpStatement__lead{margin:0 0 clamp(14px, 2.5vw, 22px);}
.corpStatement__leadLine{
  display:block;
}
.corpStatement__leadPart{
  display:inline;
  font-family:var(--font-jp);
  font-weight:900;
  letter-spacing:-.02em;
  line-height:1.05;
  font-size:clamp(38px, 6.2vw, 92px);
  color:#fff;
  text-shadow:0 0 10px rgba(245,0,0,.18), 0 0 80px rgba(0,0,0,.55);
  word-break:keep-all;
  text-wrap:balance;
}

/* narrow: force line-break after "明晰さで、" */
@media (max-width: 820px){
  .corpStatement__leadPart--break{
    display:block;
  }
}

/* quote = framed, corporate */
.corpStatement__quote{
  margin:0 0 clamp(16px, 2.8vw, 26px);
  padding:16px 18px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(0,0,0,.22);
  backdrop-filter:blur(6px);
  position:relative;
  overflow:hidden;
}
.corpStatement__quote:before{
  content:"";
  position:absolute; left:0; top:0; bottom:0;
  width:2px;
  background:linear-gradient(180deg, rgba(245,0,0,.95), rgba(245,0,0,.25));
  opacity:.95;
}
.corpStatement__quote:after{
  content:"";
  position:absolute; left:-20%; top:0; bottom:0;
  width:60%;
  background:linear-gradient(90deg, rgba(0,0,0,.92), rgba(0,0,0,0));
  transform:translateX(0);
  pointer-events:none;
  will-change:transform;
}
.corpStatement__quote.is-revealed:after{
  transform:translateX(180%);
  transition:transform .86s cubic-bezier(.18,.92,.18,1) var(--d, .06s);
}
.corpStatement__quoteText{
  margin:0;
  font-family:var(--font-jp);
  font-weight:800;
  color:rgba(255,255,255,.92);
  font-size:clamp(16px, 1.7vw, 22px);
  line-height:1.85;
  letter-spacing:.01em;
}

.corpStatement__body{
  position:relative;
  color:rgba(255,255,255,.84);
  font-size:clamp(15px, 1.55vw, 20px);
  line-height:1.95;
  letter-spacing:.01em;
  max-width:980px;
  padding-top:10px;
}
.corpStatement__body:before{
  content:"";
  position:absolute;
  left:-10px;
  right:-10px;
  top:0;
  height:1px;
  background:linear-gradient(90deg, transparent, rgba(255,0,0,.35), transparent);
  opacity:.9;
}
.corpStatement__body p{margin:0;}

.corpStatement__caps{
  margin-top:clamp(16px, 2.8vw, 22px);
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
.corpStatement__cap{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  height:34px;
  padding:0 12px;
  border:1px solid rgba(255,255,255,.16);
  background:rgba(255,255,255,.03);
  font-family:var(--font-en);
  font-weight:900;
  letter-spacing:.18em;
  text-transform:uppercase;
  font-size:10px;
  color:rgba(255,255,255,.72);
}

@media (max-width: 980px){
  .corpStatement{grid-template-columns:1fr}
  .corpStatement__rail{display:none}
  .corpStatement__quote{padding:14px 14px}
}

/* mantra section (graffiti-like) */
.section--mantra{
  position:relative;
  padding:clamp(72px,10vw,140px) 0;
  overflow:hidden;
}
.section--mantra:before{
  content:"";
  position:absolute;
  inset:-1px 0 -1px 0;
  background:
    radial-gradient(900px 520px at 30% 30%, rgba(245,0,0,.10), transparent 60%),
    radial-gradient(circle at 1px 1px, rgba(255,255,255,.55) 1px, transparent 1.5px);
  background-size:auto, 62px 62px;
  opacity:.14;
  pointer-events:none;
  mix-blend-mode:screen;
}
.section--mantra:after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,.65), rgba(0,0,0,.15) 40%, rgba(0,0,0,.75));
  pointer-events:none;
}
.section--mantra > .wrap{
  position:relative;
  z-index:1;
}

/* mantra background: use ink.svg as-is, single large piece */
.section--mantra > .wrap:before{
  content:"";
  position:absolute;
  inset:clamp(-90px,-8vw,-44px) clamp(-32px,-4vw,-12px);
  pointer-events:none;
  z-index:0;

  background:url("../img/ink.svg") center / clamp(820px, 110vw, 1600px) auto no-repeat;
  opacity:.12;
  /* black ink stays black; multiply lets it show on the (subtle) red/gradient field */
  mix-blend-mode:multiply;
  filter:blur(.25px);

  /* soften edges so the rectangular bounds never read */
  -webkit-mask-image:radial-gradient(circle at 50% 50%, #000 56%, transparent 100%);
  mask-image:radial-gradient(circle at 50% 50%, #000 56%, transparent 100%);
}

.graffiti{
  display:grid;
  gap:clamp(14px,2.6vw,22px);
  align-content:start;
  position:relative;
  z-index:2;
}
.graffiti__line{
  font-family:var(--font-en);
  font-weight:900;
  letter-spacing:-.02em;
  line-height:0.92;
  font-size:clamp(44px,7.2vw,112px);
  text-transform:none;
  position:relative;
}
/* layers: red/white/black in a bold way, but no diagonal positioning */
.graffiti__line--w{
  color:#fff;
  text-shadow:0 0 18px rgba(245,0,0,.18), 0 0 80px rgba(0,0,0,.55);
}
.graffiti__line--r{
  color:var(--red);
  text-shadow:0 0 16px rgba(245,0,0,.35), 0 0 80px rgba(0,0,0,.55);
}
.graffiti__line--k{
  color:#000;
  -webkit-text-stroke: 1px rgba(255,255,255,.18);
  text-shadow:0 0 0 rgba(0,0,0,0);
}
/* “spray” grain (still only white/red/black) */
.graffiti__line:after{
  content:"";
  position:absolute;
  left:0; right:0; top:50%;
  height:2px;
  transform:translateY(-50%);
  background:linear-gradient(90deg, transparent, rgba(255,255,255,.18), transparent);
  opacity:.14;
  pointer-events:none;
}

.graffiti__line{z-index:1;}

/* portal links (RYDEN-like sparse entry points) */
.portal{
  display:grid;
  grid-template-columns:repeat(2, minmax(0,1fr));
  gap:14px;
  max-width:980px;
}
.portal__link{
  text-decoration:none;
  display:flex;
  align-items:flex-start;
  gap:14px;
  padding:18px 16px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(0,0,0,.22);
  backdrop-filter: blur(6px);
  transition:border-color .25s ease, background-color .25s ease, transform .25s ease;
}
.portal__link:hover{
  border-color:rgba(245,0,0,.35);
  background:rgba(245,0,0,.06);
  transform:translateY(-1px);
}
.portal__mark{
  width:24px; height:24px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:1px solid rgba(245,0,0,.28);
  color:rgba(245,0,0,.9);
  font-family:var(--font-en);
  font-weight:900;
  flex:0 0 auto;
}
.portal__txt{display:flex; flex-direction:column; gap:6px}
.portal__k{
  font-family:var(--font-en);
  font-weight:900;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-size:10px;
  color:rgba(255,255,255,.72);
}
.portal__v{
  font-family:var(--font-en);
  font-weight:900;
  letter-spacing:.10em;
  text-transform:uppercase;
  font-size:14px;
  color:#fff;
}
.portal__arrow{
  margin-left:auto;
  color:rgba(255,255,255,.55);
  font-family:var(--font-en);
  font-weight:900;
}

/* portal section (placed under PROOF) */
.section--portal{
  position:relative;
  padding:clamp(56px,7vw,96px) 0;
  overflow:hidden;
  background:
    radial-gradient(900px 520px at 30% 30%, rgba(245,0,0,.10), transparent 60%),
    radial-gradient(circle at 1px 1px, rgba(255,255,255,.55) 1px, transparent 1.5px),
    linear-gradient(180deg, rgba(0,0,0,.78), rgba(0,0,0,.92));
  background-size:auto, 62px 62px, auto;
}
.section--portal:before{
  content:"";
  position:absolute;
  left:0; right:0; top:0;
  height:1px;
  background:linear-gradient(90deg, transparent, rgba(255,0,0,.35), transparent);
  opacity:.9;
  pointer-events:none;
}
.section--portal .portal{
  margin:0 auto;
}
.section--portal .portal__link{
  background:rgba(0,0,0,.28);
}

@media (max-width: 980px){
  .portal{grid-template-columns:1fr}
}
.pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:40px;
  padding:10px 14px;
  text-decoration:none;
  font-family:var(--font-en);
  font-weight:900;
  letter-spacing:.16em;
  text-transform:uppercase;
  font-size:11px;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.03);
  transition:transform .25s ease, background-color .25s ease, border-color .25s ease;
}
.pill:hover{
  transform:translateY(-1px);
  background:rgba(245,0,0,.10);
  border-color:rgba(245,0,0,.44);
}
.pill:focus{outline:2px solid var(--red); outline-offset:3px}

/* manifesto section */
.section--manifesto{
  position:relative;
}
.section--manifesto:before{
  content:"";
  position:absolute; inset:0;
  background:
    radial-gradient(900px 520px at 20% 20%, rgba(245,0,0,.14), transparent 60%),
    radial-gradient(840px 520px at 85% 40%, rgba(245,0,0,.09), transparent 60%),
    linear-gradient(180deg, rgba(0,0,0,.25), rgba(0,0,0,.65));
  pointer-events:none;
}
.section--manifesto > .wrap{position:relative}
.manifestoGrid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:14px;
}
.manifestoBlock{
  background:linear-gradient(180deg, rgba(12,12,12,.86), rgba(4,4,4,.72));
  border:1px solid rgba(255,255,255,.14);
  padding:28px 22px;
  box-shadow:0 0 42px rgba(0,0,0,.55);
}
.manifestoBlock--red{
  border-color:rgba(245,0,0,.22);
  background:linear-gradient(180deg, rgba(245,0,0,.16), rgba(0,0,0,.78));
}
.manifestoBlock__k{
  font-family:var(--font-en);
  font-weight:900;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-size:11px;
  color:rgba(255,255,255,.74);
}
.manifestoBlock__p{
  margin:12px 0 0;
  color:rgba(255,255,255,.86);
  font-size:15px;
}

/* index section */
.section--index{
  position:relative;
}
.section--index:before{
  content:"";
  position:absolute; inset:0;
  background:
    radial-gradient(900px 420px at 70% 20%, rgba(245,0,0,.14), transparent 60%),
    linear-gradient(180deg, rgba(0,0,0,.25), rgba(0,0,0,.75));
  pointer-events:none;
}
.section--index > .wrap{position:relative}
.indexGrid{
  display:grid;
  grid-template-columns: 1.15fr .85fr;
  gap:16px;
  align-items:start;
}
.indexLeft{
  border:1px solid rgba(245,0,0,.18);
  background:linear-gradient(180deg, rgba(12,12,12,.86), rgba(4,4,4,.72));
  padding:28px 22px;
  box-shadow:0 0 42px rgba(0,0,0,.55);
}
.indexBrand__jp{font-weight:900; font-size:18px}
.indexBrand__en{
  margin-top:8px;
  font-family:var(--font-en);
  font-weight:900;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-size:11px;
  color:rgba(255,255,255,.66);
}
.indexPrinciples{margin-top:18px}
.indexPrinciples__k{
  font-family:var(--font-en);
  font-weight:900;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-size:11px;
  color:rgba(255,255,255,.72);
}
.indexPrinciples__list{
  margin:10px 0 0;
  padding-left:18px;
  color:rgba(255,255,255,.86);
  font-size:14px;
}
.indexPrinciples__list li{margin:8px 0}
.indexRight{
  border:1px solid rgba(255,255,255,.14);
  background:linear-gradient(180deg, rgba(12,12,12,.86), rgba(4,4,4,.72));
  padding:28px 22px;
  box-shadow:0 0 42px rgba(0,0,0,.55);
}
.indexPills{display:flex; flex-wrap:wrap; gap:10px}
.indexCta{margin-top:16px; display:flex; gap:12px; flex-wrap:wrap}

.hero__cta{
  display:flex;
  gap:14px;
  margin-top:28px;
  flex-wrap:wrap;
}

/* TOPで会社情報サマリーを外した分、下の余白を少しだけ作る */
.hero__cta{ margin-bottom: 18px; }
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  text-decoration:none;
  border-radius:0;
  padding:14px 18px;
  font-family:var(--font-en);
  font-weight:900;
  letter-spacing:.16em;
  text-transform:uppercase;
  font-size:12px;
  min-height:48px;
  transition:transform .25s ease, filter .25s ease, background-color .25s ease, border-color .25s ease;
  cursor:pointer;
  user-select:none;
}
.btn:focus{outline:2px solid var(--red); outline-offset:3px}
.btn--primary{
  background:var(--red);
  color:#fff;
  border:1px solid rgba(0,0,0,.25);
  box-shadow:var(--shadowR);
}
.btn--primary:hover{filter:brightness(1.06); transform:translateY(-1px)}
.btn--ghost{
  background:rgba(255,255,255,.02);
  border:1px solid rgba(255,255,255,.28);
  color:#fff;
}
.btn--ghost:hover{background:rgba(255,255,255,.08); transform:translateY(-1px)}

.hero__meta{
  margin-top:40px;
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:12px;
}
.metaCard{
  background:linear-gradient(180deg, rgba(12,12,12,.86), rgba(4,4,4,.74));
  border:1px solid rgba(245,0,0,.22);
  padding:18px 18px;
  box-shadow:0 0 34px rgba(0,0,0,.55);
}
.metaCard__k{
  font-family:var(--font-en);
  font-weight:900;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-size:11px;
  color:rgba(255,255,255,.72);
}
.metaCard__v{
  margin-top:8px;
  font-family:var(--font-en);
  font-weight:900;
  letter-spacing:.02em;
  font-size:14px;
}

.scrollHint{
  position:absolute;
  right:var(--padX);
  bottom:clamp(18px,2.4vw,34px);
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:10px;
  opacity:.88;
}
.scrollHint--center{
  right:auto;
  left:50%;
  bottom:calc(26px + env(safe-area-inset-bottom));
  transform:translateX(-50%);
  opacity:0;
  transition:opacity .25s ease;
}
body.is-scrollHint-ready .scrollHint--center{opacity:.88}
.scrollHint__line{
  width:1px;
  height:clamp(48px, 8vh, 64px);
  background:linear-gradient(to bottom, rgba(245,0,0,0), rgba(245,0,0,.85), rgba(245,0,0,0));
  animation:scrollLine 1.4s ease-in-out infinite;
}
.scrollHint__label{
  font-family:var(--font-en);
  font-weight:900;
  letter-spacing:.28em;
  font-size:10px;
  color:rgba(255,255,255,.7);
  line-height:1.2;
}
@keyframes scrollLine{
  0%{transform:translateY(-8px); opacity:.35}
  50%{transform:translateY(10px); opacity:1}
  100%{transform:translateY(-8px); opacity:.35}
}

.section{padding:var(--secY) 0}
.section--red{
  background:linear-gradient(180deg, rgba(245,0,0,.98), rgba(120,0,0,.95));
  color:#070707;
}
.section--glass{
  position:relative;
}
.section--glass:before{
  content:"";
  position:absolute; inset:0;
  background:
    radial-gradient(900px 500px at 20% 10%, rgba(245,0,0,.16), transparent 60%),
    radial-gradient(800px 520px at 80% 30%, rgba(245,0,0,.10), transparent 60%),
    linear-gradient(180deg, rgba(0,0,0,.55), rgba(0,0,0,.75));
  pointer-events:none;
}
.section--glass > .wrap{position:relative}

.sectionHead{margin-bottom:clamp(26px,4vw,48px)}
.sectionTitle{
  margin:0;
  font-family:var(--font-en);
  font-weight:900;
  letter-spacing:-.02em;
  line-height:1.05;
  font-size:clamp(30px,4vw,52px);
}
.sectionTitle--dark{color:#050505}

.grid{display:grid; gap:14px}
.grid--services{grid-template-columns:repeat(3, minmax(0,1fr))}
.grid--proof{grid-template-columns:repeat(3, minmax(0,1fr)); gap:12px}
.grid--proof4{grid-template-columns:repeat(4, minmax(0,1fr))}

.card{
  position:relative;
  background:linear-gradient(180deg, rgba(12,12,12,.86), rgba(4,4,4,.72));
  border:1px solid rgba(245,0,0,.18);
  padding:28px 26px;
  box-shadow:0 0 42px rgba(0,0,0,.55);
  overflow:hidden;
  cursor:default;
}
.card:before{
  content:"";
  position:absolute; inset:-1px;
  background:
    radial-gradient(700px 260px at 0% 0%, rgba(245,0,0,.18), transparent 60%),
    radial-gradient(640px 280px at 100% 10%, rgba(255,255,255,.07), transparent 65%);
  opacity:.9;
  pointer-events:none;
}
.card > *{position:relative}
.card__title{
  margin:0;
  font-weight:800;
  letter-spacing:-.01em;
  font-size:18px;
}
.card__body{
  margin:12px 0 0;
  color:rgba(255,255,255,.84);
  font-size:15px;
}
.card__tags{margin-top:16px; display:flex; flex-wrap:wrap; gap:8px}
.tag{
  display:inline-flex;
  padding:6px 10px;
  border:1px solid rgba(255,255,255,.18);
  color:rgba(255,255,255,.78);
  font-family:var(--font-en);
  font-weight:800;
  letter-spacing:.16em;
  text-transform:uppercase;
  font-size:10px;
  background:rgba(255,255,255,.03);
}
.card--accent{
  border-color:rgba(255,255,255,.16);
  background:linear-gradient(180deg, rgba(245,0,0,.18), rgba(0,0,0,.78));
}
.card:hover{border-color:rgba(245,0,0,.44)}

.proof{
  background:rgba(0,0,0,.14);
  border:1px solid rgba(0,0,0,.22);
  padding:24px 22px;
  box-shadow:0 18px 48px rgba(0,0,0,.22);
  text-decoration:none;
  display:block;
}
.proof__num{
  font-family:var(--font-en);
  font-weight:900;
  letter-spacing:-.05em;
  font-size:clamp(22px,3.0vw,42px);
  line-height:0.98;
  max-width:100%;
  overflow-wrap:anywhere; /* prevent overflow for 1,500,000,000 etc */
  font-variant-numeric: tabular-nums;
}
.proof__unit{
  margin-top:10px;
  font-weight:700;
  color:rgba(0,0,0,.78);
}
.proof--link:hover{filter:brightness(1.02); transform:translateY(-1px)}
.proof--link{transition:transform .25s ease, filter .25s ease}
.proof__label{
  font-family:var(--font-en);
  font-weight:900;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-size:11px;
  color:rgba(0,0,0,.68);
}
.proof__cta{
  margin-top:10px;
  font-family:var(--font-en);
  font-weight:900;
  letter-spacing:.02em;
  font-size:22px;
}
.proof__hint{
  margin-top:12px;
  font-family:var(--font-en);
  font-weight:900;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-size:11px;
  color:rgba(0,0,0,.6);
}

.twoCol{
  display:grid;
  grid-template-columns: 1.6fr .9fr;
  gap:clamp(18px,4vw,48px);
  align-items:start;
}
.lead{font-size:18px; font-weight:700; color:rgba(255,255,255,.9)}

.quote{
  border:1px solid rgba(245,0,0,.22);
  background:linear-gradient(180deg, rgba(12,12,12,.86), rgba(4,4,4,.72));
  padding:26px 22px;
  box-shadow:0 0 42px rgba(0,0,0,.55);
}
.quote__line{
  font-family:var(--font-en);
  font-weight:900;
  letter-spacing:-.02em;
  font-size:clamp(18px,2.2vw,26px);
  line-height:1.12;
  margin:0 0 14px;
}
.quote__line:last-child{margin-bottom:0}
.quote__line--red{color:var(--red); text-shadow:var(--shadowT)}

.ctaBand{
  margin-top:clamp(26px,5vw,56px);
  padding:22px 20px;
  border:1px solid rgba(245,0,0,.22);
  background:linear-gradient(90deg, rgba(245,0,0,.18), rgba(12,12,12,.76));
  display:flex; align-items:center; justify-content:space-between;
  gap:18px;
}
.ctaBand__k{
  font-family:var(--font-en);
  font-weight:900;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-size:11px;
  color:rgba(255,255,255,.74);
}
.ctaBand__v{margin-top:6px; font-weight:700}

.footer{
  border-top:1px solid rgba(245,0,0,.18);
  background:linear-gradient(to top, rgba(0,0,0,.9), rgba(0,0,0,.65));
}
.footer__wrap{
  padding:22px var(--padX);
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:16px;
}
.footer__brand{font-weight:900; letter-spacing:.02em}
.footer__sub{
  margin-top:6px;
  font-family:var(--font-en);
  font-weight:900;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-size:11px;
  color:rgba(255,255,255,.62);
}
.footer__right{display:flex; gap:16px; flex-wrap:wrap}
.footer__link{
  font-family:var(--font-en);
  font-weight:900;
  letter-spacing:.18em;
  text-transform:uppercase;
  font-size:11px;
  color:rgba(255,255,255,.76);
  text-decoration:none;
}
.footer__link:hover{color:#fff}
.footer__link.is-active{color:#fff}
.footer__bottom{
  padding:0 var(--padX) 20px;
  color:rgba(255,255,255,.55);
}

/* page */
.pageHero{
  padding:clamp(60px,8vw,100px) 0 clamp(26px,5vw,56px);
  position:relative;
}
.pageHero:before{
  content:"";
  position:absolute; inset:0;
  background:
    radial-gradient(900px 400px at 25% 5%, rgba(245,0,0,.22), transparent 60%),
    radial-gradient(800px 420px at 90% 25%, rgba(245,0,0,.12), transparent 60%),
    linear-gradient(180deg, rgba(0,0,0,.35), rgba(0,0,0,.65));
  pointer-events:none;
}
.pageHero > .wrap{position:relative}
.pageHero--compact{padding-bottom:clamp(16px,3vw,26px)}
.pageTitle{
  margin:0;
  font-family:var(--font-jp);
  font-weight:900;
  letter-spacing:-.02em;
  line-height:1.06;
  font-size:clamp(40px,6vw,74px);
}
.pageLead{
  margin:14px 0 0;
  max-width:880px;
  color:rgba(255,255,255,.82);
  font-size:15px;
}

.stackCard{
  background:linear-gradient(180deg, rgba(12,12,12,.86), rgba(4,4,4,.72));
  border:1px solid rgba(255,255,255,.14);
  padding:22px 20px;
  box-shadow:0 0 42px rgba(0,0,0,.55);
}
.stackCard__label{
  font-family:var(--font-en);
  font-weight:900;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-size:11px;
  color:rgba(255,255,255,.7);
}
.stackCard__row{
  margin-top:12px;
  display:flex; justify-content:space-between; gap:12px;
  font-family:var(--font-en);
  font-weight:900;
}
.stackCard__row span:last-child{font-family:var(--font-jp); font-weight:700}

.message{
  background:var(--glass);
  border:1px solid rgba(245,0,0,.22);
  padding:28px 24px;
  box-shadow:0 0 42px rgba(0,0,0,.55);
}
.message__role{
  font-family:var(--font-en);
  font-weight:900;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-size:11px;
  color:rgba(255,255,255,.7);
}
.message__person{margin-top:8px; font-weight:900; font-size:18px}
.message__body{margin-top:14px; color:rgba(255,255,255,.86)}

.infoGrid{
  display:grid;
  grid-template-columns: 1.5fr .9fr;
  gap:16px;
}
.info{
  margin:0;
  background:linear-gradient(180deg, rgba(12,12,12,.86), rgba(4,4,4,.72));
  border:1px solid rgba(245,0,0,.18);
  padding:10px 18px;
  box-shadow:0 0 42px rgba(0,0,0,.55);
}
.info__row{
  display:grid;
  grid-template-columns: 140px 1fr;
  gap:16px;
  padding:16px 0;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.info__row:last-child{border-bottom:none}
.info dt{
  font-family:var(--font-en);
  font-weight:900;
  letter-spacing:.18em;
  text-transform:uppercase;
  font-size:11px;
  color:rgba(255,255,255,.7);
}
.info dd{margin:0; color:rgba(255,255,255,.9)}
.infoAside{display:grid; gap:12px}
.asideCard{
  position:relative;
  text-decoration:none;
  border:1px solid rgba(255,255,255,.14);
  padding:22px 18px;
  background:linear-gradient(180deg, rgba(12,12,12,.86), rgba(4,4,4,.72));
  box-shadow:0 0 42px rgba(0,0,0,.55);
  transition:transform .25s ease, border-color .25s ease, filter .25s ease;
}
.asideCard:hover{transform:translateY(-1px); border-color:rgba(245,0,0,.44)}
.asideCard__k{
  font-family:var(--font-en);
  font-weight:900;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-size:11px;
  color:rgba(255,255,255,.72);
}
.asideCard__v{margin-top:10px; font-weight:900; font-size:18px}
.asideCard__arrow{position:absolute; right:16px; top:16px; color:rgba(255,255,255,.7)}
.asideCard--muted{border-color:rgba(245,0,0,.18)}

/* contact */
.form{
  background:linear-gradient(180deg, rgba(12,12,12,.86), rgba(4,4,4,.72));
  border:1px solid rgba(245,0,0,.18);
  padding:28px 22px;
  box-shadow:0 0 42px rgba(0,0,0,.55);
}
.form__row{margin-top:14px}
.form__row:first-child{margin-top:0}
.form__label{display:block; font-weight:800; margin-bottom:8px}
.form__input,.form__textarea{
  width:100%;
  background:rgba(0,0,0,.55);
  color:#fff;
  border:1px solid rgba(255,255,255,.18);
  padding:12px 12px;
  outline:none;
}
.form__input:focus,.form__textarea:focus{border-color:rgba(245,0,0,.6); box-shadow:0 0 0 3px rgba(245,0,0,.18)}
.form__foot{
  margin-top:18px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:14px;
  flex-wrap:wrap;
}
.form__note{color:rgba(255,255,255,.7); font-size:13px}
.form__note a{color:#fff}
.form__hint{margin-top:14px; font-size:12px}
.hp{position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden}

.notice{
  margin-bottom:16px;
  border:1px solid rgba(255,255,255,.16);
  padding:16px 14px;
  background:rgba(255,255,255,.04);
}
.notice--ok{border-color:rgba(245,0,0,.22); background:rgba(245,0,0,.08)}
.notice--ng{border-color:rgba(255,255,255,.18); background:rgba(255,255,255,.05)}
.notice__title{font-weight:900; margin-bottom:6px}
.notice__list{margin:8px 0 0; padding-left:18px}

/* prose */
.prose{
  background:linear-gradient(180deg, rgba(12,12,12,.86), rgba(4,4,4,.72));
  border:1px solid rgba(245,0,0,.18);
  padding:28px 22px;
  box-shadow:0 0 42px rgba(0,0,0,.55);
}
.prose h2{
  font-family:var(--font-en);
  font-weight:900;
  letter-spacing:.06em;
  font-size:18px;
  margin:24px 0 10px;
}
.prose p,.prose li{color:rgba(255,255,255,.86)}
.prose ul{margin:10px 0 0}

/* motion hooks */
.js-reveal{opacity:0; transform:translateY(14px)}
.is-revealed{opacity:1; transform:none}

.split{
  display:inline-block;
  will-change:transform, opacity;
}
.split--char{display:inline-block}
.split--word{display:inline-block; white-space:nowrap}

/* hover preview */
.hover-preview{
  position:fixed;
  left:0; top:0;
  width:320px; height:200px;
  pointer-events:none;
  opacity:0;
  transform:translate3d(-9999px,-9999px,0);
  z-index:60;
}
.hover-preview__frame{
  width:100%; height:100%;
  border:1px solid rgba(245,0,0,.22);
  background:rgba(0,0,0,.6);
  box-shadow:0 0 52px rgba(0,0,0,.6);
  overflow:hidden;
  position:relative;
}
.hover-preview__img{
  width:100%; height:100%;
  object-fit:cover;
  transform:scale(1.03);
  filter:contrast(1.05) saturate(1.02);
}
.hover-preview__noise{
  position:absolute; inset:0;
  background:
    radial-gradient(600px 200px at 20% 10%, rgba(245,0,0,.18), transparent 60%),
    repeating-linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.06) 1px, transparent 1px, transparent 3px);
  mix-blend-mode:screen;
  opacity:.22;
  animation:noiseMove 1.2s steps(2,end) infinite;
}
@keyframes noiseMove{
  0%{transform:translateY(-6px)}
  100%{transform:translateY(6px)}
}

.cursor-orb{
  position:fixed;
  left:0; top:0;
  width:18px; height:18px;
  border:1px solid rgba(245,0,0,.55);
  box-shadow:0 0 22px rgba(245,0,0,.18);
  pointer-events:none;
  z-index:80;
  transform:translate3d(-9999px,-9999px,0);
  opacity:.92;
  mix-blend-mode:screen;
}

/* responsive */
@media (max-width: 980px){
  .grid--services{grid-template-columns:repeat(2, minmax(0,1fr))}
  .grid--proof{grid-template-columns:1fr}
  .grid--proof4{grid-template-columns:repeat(2, minmax(0,1fr))}
  .twoCol{grid-template-columns:1fr}
  .infoGrid{grid-template-columns:1fr}
  .hero__meta{grid-template-columns:1fr}
  .scrollHint{display:none}
  .manifestoGrid{grid-template-columns:1fr}
  .indexGrid{grid-template-columns:1fr}
  .heroHud__item--ml,.heroHud__item--mr{display:none}
}
@media (max-width: 520px){
  .nav{gap:12px}
  .nav__link{letter-spacing:.18em}
  .card{padding:24px 18px}
  .metaCard{padding:16px 16px}
  .hover-preview{width:280px; height:175px}
  .grid--proof4{grid-template-columns:1fr}
  .heroStage__word{letter-spacing:.08em}
  .heroHud{display:none}
}

@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  .scrollHint__line{animation:none}
  .hover-preview__noise{animation:none}
  .heroStage__scan{display:none}
  .heroStage__dots{display:none}
}

/* works */
.caseGrid{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap:16px;
  align-items:start;
}
.caseCard{
  position:relative;
  text-decoration:none;
  background:linear-gradient(180deg, rgba(12,12,12,.86), rgba(4,4,4,.72));
  border:1px solid rgba(245,0,0,.18);
  padding:28px 24px;
  box-shadow:0 0 42px rgba(0,0,0,.55);
  overflow:hidden;
  transition:transform .25s ease, border-color .25s ease, filter .25s ease;
}
.caseCard:hover{transform:translateY(-1px); border-color:rgba(245,0,0,.44)}
.caseCard:before{
  content:"";
  position:absolute; inset:-1px;
  background:
    radial-gradient(900px 320px at 0% 0%, rgba(245,0,0,.16), transparent 60%),
    radial-gradient(760px 260px at 100% 10%, rgba(255,255,255,.06), transparent 65%);
  pointer-events:none;
}
.caseCard > *{position:relative}
.caseCard__top{display:flex; align-items:flex-end; justify-content:space-between; gap:16px}
.caseCard__badge{
  font-family:var(--font-en);
  font-weight:900;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-size:11px;
  color:rgba(255,255,255,.72);
  border:1px solid rgba(255,255,255,.16);
  padding:8px 10px;
  background:rgba(255,255,255,.03);
}
.caseCard__name{
  font-family:var(--font-en);
  font-weight:900;
  letter-spacing:.10em;
  font-size:36px;
  line-height:1.0;
}
.caseCard__desc{margin-top:14px; color:rgba(255,255,255,.86)}
.caseCard__meta{margin-top:16px; display:flex; gap:8px; flex-wrap:wrap}
.caseCard__go{
  margin-top:18px;
  font-family:var(--font-en);
  font-weight:900;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-size:11px;
  color:rgba(255,255,255,.72);
}
.caseNote{
  background:linear-gradient(180deg, rgba(12,12,12,.86), rgba(4,4,4,.72));
  border:1px solid rgba(255,255,255,.14);
  padding:26px 20px;
  box-shadow:0 0 42px rgba(0,0,0,.55);
}
.caseNote__k{
  font-family:var(--font-en);
  font-weight:900;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-size:11px;
  color:rgba(255,255,255,.72);
}
.caseNote__p{margin:12px 0 18px; color:rgba(255,255,255,.86)}

@media (max-width: 980px){
  .caseGrid{grid-template-columns:1fr}
}


