/* ===========================================================
   ON-bright kids — site styles
   =========================================================== */
:root{
  --rose-1:#fff5fb;
  --rose-2:#ffd9ee;
  --rose-3:#ff9fcf;
  --magenta:#ff1e8c;
  --magenta-2:#ff5cae;
  --berry:#c8005e;
  --berry-deep:#8a0247;
  --ink:#3a0f28;
  --cream:#fff3e0;
  --gold:#ffcf5c;
  --gold-deep:#d79a1f;
  --grape:#8a4be8;
  --mint:#34d8b4;
  --sky:#6fc3ee;
  --font-display:'Dela Gothic One', sans-serif;
  --font-round:'Zen Maru Gothic', sans-serif;
  --font-body:'Noto Sans JP', sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:var(--font-body);background:var(--rose-1);color:var(--ink);overflow-x:hidden;max-width:100%;-webkit-font-smoothing:antialiased;}
html{overflow-x:hidden;max-width:100%;}
::selection{background:var(--gold);color:var(--ink);}
img{max-width:100%;}
a{color:inherit;}

/* ===== global responsive safety: prevent any text/element from overflowing on mobile ===== */
h1,h2,h3,h4,h5,h6,p,span,a,li,dt,dd,figcaption,label,
.sec-title,.sec-lead,.kicker,.lede,.headline,.headline-statement,.statement,.story h2,.story p,.cta h2,.cta .sub,.page-hero h1{
  overflow-wrap:break-word;
  word-break:normal;
}
/* flex/grid children must be allowed to shrink below content size, else they force horizontal scroll */
.copy,.hero-inner,.wrap,.page-hero-inner,.cards,.dev-grid,.steps,.mvva,.domains,
.cards > *,.dev-grid > *,.steps > *,.mvva > *,.domains > *{min-width:0;}
*{box-sizing:border-box;}

.wrap{max-width:1200px;margin:0 auto;padding:0 clamp(20px,4vw,56px);}

/* ===== scroll reveal (capture-safe: opacity LOCKED at 1, transform-only ===== */
/* content stays visible even if the animation timeline is frozen/throttled */
[data-sr]{opacity:1;}
html.js [data-sr]{transform:translateY(42px);
  transition:transform .85s cubic-bezier(.22,1,.36,1);transition-delay:var(--d,0s);}
html.js [data-sr].in{transform:none;}
html.js [data-sr="zoom"]{transform:scale(.92);}
html.js [data-sr="left"]{transform:translateX(-48px);}
html.js [data-sr="right"]{transform:translateX(48px);}

/* ===== fixed petal field (drifts the whole page) ===== */
.petal-field{position:fixed;inset:0;z-index:40;pointer-events:none;overflow:hidden;}
.petal{position:absolute;top:-8%;width:16px;height:13px;
  background:radial-gradient(circle at 30% 30%,#ffd9ea,#ff7eb8);
  border-radius:60% 40% 55% 45%/55% 55% 45% 45%;
  will-change:transform;animation:fall linear infinite;}
@keyframes fall{
  0%{transform:translate3d(0,-12vh,0) rotate(0);}
  100%{transform:translate3d(var(--drift,40px),114vh,0) rotate(560deg);}
}

/* ===========================================================
   NAV
   =========================================================== */
nav{position:fixed;top:0;left:0;right:0;z-index:60;display:flex;align-items:center;justify-content:space-between;
  padding:18px clamp(20px,4vw,56px);transition:background .4s, padding .4s, box-shadow .4s, backdrop-filter .4s;}
nav.scrolled{background:rgba(255,255,255,.82);backdrop-filter:blur(16px);padding-top:12px;padding-bottom:12px;box-shadow:0 8px 30px rgba(176,0,90,.14);}
.brand{display:flex;align-items:center;gap:11px;font-family:var(--font-display);color:var(--berry-deep);font-size:20px;text-decoration:none;letter-spacing:-.02em;}
.brand .mark{width:40px;height:40px;border-radius:50%;display:grid;place-items:center;flex:none;
  background:radial-gradient(circle at 35% 30%,#ff8cc6,#ff1e8c);box-shadow:0 4px 12px rgba(176,0,90,.35);}
.menu{display:flex;gap:4px;align-items:center;}
.menu a{font-family:var(--font-round);font-weight:700;color:var(--berry-deep);text-decoration:none;font-size:14px;white-space:nowrap;
  padding:9px 13px;border-radius:999px;transition:transform .18s, background .18s, color .18s;}
.menu a:hover{background:var(--magenta);color:#fff;transform:translateY(-2px) rotate(-2deg);}
.menu a.active{background:var(--magenta);color:#fff;}
.menu a.active:hover{transform:translateY(-2px);}
.nav-cta{background:var(--gold)!important;color:var(--ink)!important;font-weight:900!important;box-shadow:0 4px 0 var(--gold-deep);}
.nav-cta:hover{transform:translateY(-2px) rotate(2deg) scale(1.04)!important;box-shadow:0 6px 0 var(--gold-deep);color:var(--ink)!important;}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:10px;z-index:80;}
.burger span{width:26px;height:3px;background:var(--berry-deep);border-radius:3px;transition:.3s;}
.burger.open span:nth-child(1){transform:translateY(8px) rotate(45deg);}
.burger.open span:nth-child(2){opacity:0;}
.burger.open span:nth-child(3){transform:translateY(-8px) rotate(-45deg);}
/* mobile drawer */
.drawer{position:fixed;inset:0;z-index:70;background:linear-gradient(160deg,#ff5cae,#c8005e);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;
  opacity:0;visibility:hidden;transition:opacity .35s;}
.drawer.open{opacity:1;visibility:visible;}
.drawer a{font-family:var(--font-round);font-weight:900;color:#fff;text-decoration:none;font-size:26px;padding:12px 22px;border-radius:999px;}
.drawer a:active{background:rgba(255,255,255,.18);}

/* ===========================================================
   HERO  (section 1)
   =========================================================== */
.hero{position:relative;min-height:100svh;width:100%;overflow:hidden;isolation:isolate;
  background:radial-gradient(78% 56% at 50% -8%, rgba(255,248,228,.95) 0%, rgba(255,248,228,0) 58%),
    radial-gradient(130% 105% at 72% 4%, #fff2fa 0%, #ffd9ee 40%, #ff9fcf 100%);}
.rays{position:absolute;inset:-20% -20% auto -20%;height:120%;
  background:repeating-conic-gradient(from 90deg at 50% -10%, rgba(255,255,255,.22) 0deg 4deg, rgba(255,255,255,0) 4deg 12deg);
  mix-blend-mode:screen;opacity:.7;z-index:0;pointer-events:none;transform-origin:50% 0;animation:raySpin 60s linear infinite;}
@keyframes raySpin{to{transform:rotate(8deg);}}
.bokeh{position:absolute;border-radius:50%;filter:blur(40px);z-index:0;pointer-events:none;}
.bk1{width:36vw;height:36vw;left:-8vw;top:8vh;background:radial-gradient(circle,rgba(255,255,255,.7),transparent 70%);}
.bk2{width:30vw;height:30vw;right:6vw;top:-6vh;background:radial-gradient(circle,rgba(255,221,150,.55),transparent 70%);}
.bk3{width:26vw;height:26vw;left:30vw;bottom:-8vh;background:radial-gradient(circle,rgba(255,140,198,.45),transparent 70%);}
.ghost{position:absolute;left:50%;top:30%;transform:translate(-50%,-50%) rotate(-3deg);font-family:var(--font-display);
  font-size:min(30vw,440px);line-height:.8;white-space:nowrap;color:transparent;-webkit-text-stroke:2px rgba(255,255,255,.55);
  z-index:0;pointer-events:none;user-select:none;letter-spacing:-.02em;}
.hero-inner{position:relative;z-index:10;max-width:1440px;margin:0 auto;min-height:100svh;
  padding:120px clamp(20px,4vw,56px) 80px;display:grid;grid-template-columns:1fr;align-items:center;}
.copy{position:relative;z-index:12;max-width:780px;}
.eyebrow{display:inline-flex;align-items:center;gap:10px;font-family:var(--font-round);font-weight:900;font-size:clamp(12px,1.1vw,15px);
  color:#fff;background:linear-gradient(90deg,var(--magenta),var(--magenta-2));padding:8px 18px 8px 14px;border-radius:999px;
  box-shadow:0 8px 22px rgba(255,30,140,.4);transform:rotate(-2deg);}
.eyebrow .pin{width:10px;height:10px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 3px rgba(255,255,255,.6);}
.headline{font-family:var(--font-display);line-height:1.0;letter-spacing:-.02em;margin:22px 0 0;}
.headline .l1{display:block;white-space:nowrap;font-size:clamp(46px,11.5vw,196px);color:var(--magenta);line-height:1.05;word-break:keep-all;
  text-shadow:-3px -3px 0 #fff,3px -3px 0 #fff,-3px 3px 0 #fff,3px 3px 0 #fff,-3px 0 0 #fff,3px 0 0 #fff,0 -3px 0 #fff,0 3px 0 #fff,0 10px 0 #ffb3d9,0 20px 34px rgba(176,0,90,.28);}
.headline .l1 .bang{display:inline-block;color:var(--gold);animation:bangpop 2.6s ease-in-out infinite;}
@keyframes bangpop{0%,100%{transform:rotate(-4deg) scale(1);}50%{transform:rotate(7deg) scale(1.12);}}
.headline .l2{display:block;font-size:clamp(26px,5.8vw,98px);margin-top:.12em;color:var(--berry-deep);line-height:1.15;word-break:keep-all;overflow-wrap:break-word;
  text-shadow:-2px -2px 0 #fff,2px -2px 0 #fff,-2px 2px 0 #fff,2px 2px 0 #fff,0 8px 22px rgba(176,0,90,.18);}
.lede{font-family:var(--font-round);font-weight:900;color:var(--berry-deep);font-size:clamp(16px,1.85vw,26px);line-height:1.65;margin-top:24px;max-width:20em;text-shadow:0 2px 10px rgba(255,255,255,.7);}
.lede .hl{color:#fff;background:linear-gradient(90deg,var(--magenta),var(--magenta-2));padding:.06em .4em;border-radius:9px;white-space:nowrap;
  box-decoration-break:clone;-webkit-box-decoration-break:clone;text-shadow:none;box-shadow:0 6px 16px rgba(255,30,140,.32);}
.cta-row{display:flex;gap:14px;margin-top:30px;flex-wrap:wrap;}
.btn{font-family:var(--font-round);font-weight:900;font-size:clamp(15px,1.3vw,18px);text-decoration:none;cursor:pointer;border:0;
  padding:18px 30px;border-radius:999px;white-space:nowrap;display:inline-flex;align-items:center;gap:10px;
  transition:transform .16s cubic-bezier(.34,1.56,.64,1), box-shadow .16s;}
.btn-primary{background:linear-gradient(90deg,var(--magenta),var(--magenta-2));color:#fff;box-shadow:0 8px 0 var(--berry),0 14px 26px rgba(255,30,140,.4);}
.btn-primary:hover{transform:translateY(-3px) scale(1.03);box-shadow:0 11px 0 var(--berry),0 18px 30px rgba(255,30,140,.45);}
.btn-primary:active{transform:translateY(3px);box-shadow:0 4px 0 var(--berry);}
.btn-ghost{background:rgba(255,255,255,.7);color:var(--berry);border:3px solid #fff;padding:15px 27px;box-shadow:0 8px 22px rgba(176,0,90,.14);}
.btn-ghost:hover{background:#fff;transform:translateY(-3px) rotate(-2deg);}
.btn .arrow{transition:transform .2s;}
.btn:hover .arrow{transform:translateX(4px);}
.btn-lg{padding:22px 40px;font-size:clamp(17px,1.5vw,22px);}
.trust{display:flex;gap:26px;margin-top:30px;flex-wrap:wrap;font-family:var(--font-round);font-weight:700;color:var(--berry-deep);}
.trust .item{display:flex;flex-direction:column;line-height:1;}
.trust .num{font-family:var(--font-display);font-size:clamp(22px,2.6vw,34px);color:var(--magenta);
  text-shadow:-1.5px -1.5px 0 #fff,1.5px -1.5px 0 #fff,-1.5px 1.5px 0 #fff,1.5px 1.5px 0 #fff;}
.trust .cap{font-size:12px;margin-top:6px;opacity:.92;line-height:1.35;}
.art-wrap{position:absolute;right:-2%;bottom:0;width:min(64vw,1000px);z-index:8;pointer-events:none;
  filter:drop-shadow(0 24px 40px rgba(176,0,90,.28));will-change:transform;}
.art-wrap img{display:block;width:100%;height:auto;animation:bob 6s ease-in-out infinite;}
@keyframes bob{0%,100%{transform:translateY(0) rotate(0);}50%{transform:translateY(-16px) rotate(-.6deg);}}
.art-glow{position:absolute;right:6%;bottom:-6%;width:min(50vw,760px);height:24vh;z-index:7;
  background:radial-gradient(ellipse at center,rgba(255,196,228,.85),transparent 70%);filter:blur(20px);pointer-events:none;}
.voice{position:absolute;z-index:13;font-family:var(--font-display);color:var(--magenta);background:#fff;padding:12px 18px;
  border-radius:20px 20px 20px 5px;box-shadow:0 12px 26px rgba(176,0,90,.22);font-size:clamp(14px,1.5vw,21px);}
.voice::after{content:"";position:absolute;left:14px;bottom:-9px;width:0;height:0;border:10px solid transparent;border-top-color:#fff;border-bottom:0;}
.v1{top:20%;right:30%;transform:rotate(-7deg);animation:pop 3.4s ease-in-out infinite;}
.v2{top:40%;right:6%;animation:pop2 3.4s .8s ease-in-out infinite;}
@keyframes pop{0%,100%{transform:rotate(-7deg) scale(1);}50%{transform:rotate(-3deg) scale(1.06);}}
@keyframes pop2{0%,100%{transform:rotate(6deg) scale(1);}50%{transform:rotate(3deg) scale(1.06);}}
.marquee{position:absolute;left:0;right:0;bottom:0;z-index:20;overflow:hidden;background:linear-gradient(90deg,var(--berry-deep),var(--berry));padding:12px 0;border-top:4px solid var(--gold);}
.marquee .track{display:flex;width:max-content;animation:scrollx 24s linear infinite;}
.marquee:hover .track{animation-play-state:paused;}
.marquee .item{font-family:var(--font-display);color:#fff;font-size:18px;padding:0 26px;white-space:nowrap;display:flex;align-items:center;gap:26px;}
.marquee .item::after{content:"❀";color:var(--gold);}
@keyframes scrollx{to{transform:translateX(-50%);}}
.scroll-cue{position:absolute;left:50%;bottom:60px;z-index:20;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;
  font-family:var(--font-round);font-weight:700;color:var(--berry-deep);font-size:12px;text-decoration:none;animation:cuebob 1.8s ease-in-out infinite;}
@keyframes cuebob{0%,100%{transform:translate(-50%,0);}50%{transform:translate(-50%,8px);}}
.scroll-cue .mouse{width:24px;height:38px;border:3px solid var(--berry-deep);border-radius:14px;position:relative;}
.scroll-cue .mouse::after{content:"";position:absolute;left:50%;top:7px;width:4px;height:8px;background:var(--berry-deep);border-radius:3px;transform:translateX(-50%);animation:wheel 1.6s ease-in-out infinite;}
@keyframes wheel{0%{opacity:1;top:7px;}60%{opacity:0;top:18px;}100%{opacity:0;}}
.reveal{opacity:1;transform:none;}

/* ===== back-to-top button ===== */
.to-top{position:fixed;right:24px;bottom:24px;z-index:55;width:60px;height:60px;border:0;cursor:pointer;
  border-radius:50%;display:grid;place-items:center;padding:0;overflow:hidden;
  background:radial-gradient(circle at 35% 30%,#ff8cc6,#ff1e8c);
  box-shadow:0 10px 26px rgba(255,30,140,.45),0 4px 10px rgba(176,0,90,.3);
  opacity:0;pointer-events:none;transform:translateY(16px) scale(.85);
  transition:opacity .4s, transform .4s cubic-bezier(.34,1.56,.64,1), box-shadow .3s;}
.to-top.show{opacity:1;pointer-events:auto;transform:none;}
.to-top:hover{transform:scale(1.1);box-shadow:0 14px 32px rgba(255,30,140,.6),0 6px 14px rgba(176,0,90,.4);}
.to-top:active{transform:scale(1.04);}
.to-top:focus-visible{outline:3px solid var(--gold);outline-offset:3px;}
.to-top .tt-face{width:40px;height:40px;border-radius:50%;object-fit:cover;border:2px solid #fff;pointer-events:none;}
.to-top .tt-arrow{display:none;}
@media (max-width:600px){
  .to-top{right:16px;bottom:16px;width:56px;height:56px;}
  .to-top .tt-face{width:38px;height:38px;}
}

/* ===== ripple ===== */
.ripple{position:absolute;border-radius:50%;background:rgba(255,255,255,.5);pointer-events:none;
  transform:scale(0);animation:rippleOut .62s ease-out forwards;z-index:2;mix-blend-mode:soft-light;}
@keyframes rippleOut{to{transform:scale(1);opacity:0;}}

/* ===== page transition fade (cinematic 0.6s) ===== */
.page-fx{position:fixed;inset:0;z-index:9998;background:linear-gradient(160deg,#fff2fa,#ffd9ee);
  opacity:0;visibility:hidden;pointer-events:none;transition:opacity .6s ease-in-out, visibility .6s ease-in-out;}
html.page-leaving .page-fx{opacity:1;visibility:visible;}
html.page-leaving body{opacity:0;transform:translateY(-20px);transition:opacity .6s ease-in, transform .6s ease-in;}

/* ===== loading splash ===== */
.loader{position:fixed;inset:0;z-index:9999;display:grid;place-items:center;
  background:radial-gradient(120% 100% at 50% 30%,#fff2fa,#ffb3d9 70%,#ff7eb8);
  transition:opacity .55s ease, visibility .55s ease;}
.loader.hide{opacity:0;visibility:hidden;}
.loader .l-face{width:128px;height:128px;border-radius:50%;border:7px solid #fff;object-fit:cover;
  box-shadow:0 18px 40px rgba(176,0,90,.35);animation:loadPop 1s cubic-bezier(.34,1.56,.64,1);}
.loader .l-cap{position:absolute;bottom:30%;font-family:var(--font-display);color:#fff;font-size:22px;letter-spacing:.04em;
  text-shadow:0 4px 14px rgba(176,0,90,.4);animation:loadPop 1s .12s cubic-bezier(.34,1.56,.64,1) both;}
@keyframes loadPop{0%{transform:translateY(60px) scale(.5);opacity:0;}55%{transform:translateY(-10px) scale(1.06);opacity:1;}100%{transform:none;opacity:1;}}
body.loading{overflow:hidden;}
@media (prefers-reduced-motion:reduce){
  .loader{display:none;}
}

/* ===========================================================
   SHARED section bits
   =========================================================== */
.section{position:relative;padding:clamp(80px,10vw,150px) 0;overflow:hidden;}
.kicker{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-round);font-weight:900;letter-spacing:.12em;
  font-size:13px;color:var(--magenta);text-transform:uppercase;}
.kicker::before{content:"";width:26px;height:3px;border-radius:3px;background:var(--magenta);}
.sec-title{font-family:var(--font-display);line-height:1.18;letter-spacing:-.01em;color:var(--berry-deep);
  font-size:clamp(28px,4.1vw,54px);margin:14px 0 0;text-wrap:balance;word-break:keep-all;overflow-wrap:break-word;}
.sec-title em{font-style:normal;color:var(--magenta);}
.sec-lead{font-family:var(--font-round);font-weight:700;color:var(--ink);font-size:clamp(15px,1.5vw,19px);line-height:1.9;margin-top:18px;max-width:36em;}
.center{text-align:center;}
.center .kicker{justify-content:center;}
.center .sec-lead{margin-left:auto;margin-right:auto;}

/* ===========================================================
   SECTION 2 — story gateway (full-bleed image3)
   =========================================================== */
.story{position:relative;min-height:100svh;display:flex;align-items:flex-end;overflow:hidden;background:#ffd9ee;}
.story .bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;will-change:transform;}
.story .scrim{position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(180deg, rgba(255,158,205,.30) 0%, rgba(138,2,71,0) 30%, rgba(138,2,71,.18) 60%, rgba(70,2,40,.78) 100%);}
.story .sparkle{position:absolute;left:48.5%;top:33%;width:min(13vw,150px);aspect-ratio:1;z-index:2;transform:translate(-50%,-50%);pointer-events:none;
  background:radial-gradient(circle, rgba(255,255,255,.95) 0%, rgba(255,255,255,.4) 18%, transparent 45%);opacity:0;}
.story .sparkle.twinkle{animation:twinkle 2.6s ease-in-out;}
@keyframes twinkle{0%{opacity:0;transform:translate(-50%,-50%) scale(.3);}20%{opacity:1;transform:translate(-50%,-50%) scale(1.1);}45%{opacity:.6;transform:translate(-50%,-50%) scale(.85);}70%{opacity:1;transform:translate(-50%,-50%) scale(1.15);}100%{opacity:0;transform:translate(-50%,-50%) scale(.6);}}
.story .star{position:absolute;color:#fff;font-size:22px;filter:drop-shadow(0 0 8px #fff);}
.story-inner{position:relative;z-index:3;width:100%;max-width:1200px;margin:0 auto;padding:0 clamp(20px,4vw,56px) clamp(70px,9vw,120px);}
.story .kicker{color:#ffd9ea;}
.story .kicker::before{background:var(--gold);}
.story h2{font-family:var(--font-display);color:#fff;line-height:1.3;letter-spacing:-.01em;
  font-size:clamp(26px,4.4vw,58px);margin:18px 0 0;text-shadow:0 6px 30px rgba(70,2,40,.6),0 2px 6px rgba(70,2,40,.5);max-width:16em;text-wrap:balance;word-break:keep-all;overflow-wrap:break-word;}
.story p{font-family:var(--font-round);font-weight:700;color:#fff;font-size:clamp(15px,1.6vw,21px);line-height:1.95;margin-top:22px;max-width:30em;
  text-shadow:0 2px 14px rgba(70,2,40,.7);}

/* ===========================================================
   SECTION 3 — three points
   =========================================================== */
.points{background:linear-gradient(180deg,#fff7fc 0%, #ffe9f5 100%);}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-top:54px;}
.card{position:relative;background:#fff;border-radius:30px;padding:40px 30px 34px;text-align:center;
  box-shadow:0 22px 44px rgba(176,0,90,.12);border:2px solid rgba(255,30,140,.08);transition:transform .3s, box-shadow .3s;}
.card:hover{transform:translateY(-10px) rotate(-1deg);box-shadow:0 30px 56px rgba(176,0,90,.22);}
.card .ic{width:128px;height:128px;border-radius:50%;margin:-86px auto 0;display:block;object-fit:cover;
  border:7px solid #fff;box-shadow:0 14px 28px rgba(176,0,90,.25);background:#ffe7f3;transition:transform .35s;}
.card:hover .ic{transform:scale(1.06) rotate(4deg);}
.card .no{font-family:var(--font-display);color:var(--magenta);font-size:14px;letter-spacing:.1em;margin-top:18px;}
.card h3{font-family:var(--font-round);font-weight:900;color:var(--berry-deep);font-size:clamp(19px,2vw,25px);margin:8px 0 0;line-height:1.4;}
.card h3 em{font-style:normal;color:var(--magenta);}
.card p{font-family:var(--font-body);color:#6b3850;font-size:14.5px;line-height:1.95;margin-top:14px;}
.cards-pad{padding-top:96px;}

/* ===========================================================
   SECTION 4 — day timeline
   =========================================================== */
.day{background:linear-gradient(180deg,#ffe9f5 0%, #fff1e9 100%);}
.timeline{position:relative;max-width:880px;margin:60px auto 0;}
.timeline::before{content:"";position:absolute;left:calc(86px + 18px);top:10px;bottom:10px;width:4px;border-radius:4px;
  background:linear-gradient(180deg,var(--magenta),var(--gold));opacity:.55;}
.tl-row{position:relative;display:grid;grid-template-columns:86px 56px 1fr;align-items:center;gap:18px;padding:14px 0;}
.tl-time{font-family:var(--font-display);color:var(--magenta);font-size:clamp(18px,2vw,24px);text-align:right;}
.tl-dot{width:56px;height:56px;border-radius:50%;background:#fff;display:grid;place-items:center;justify-self:center;
  box-shadow:0 8px 18px rgba(176,0,90,.18);border:3px solid #ffd0e6;color:var(--magenta);z-index:2;transition:transform .3s;}
.tl-row:hover .tl-dot{transform:scale(1.12) rotate(-6deg);background:var(--magenta);color:#fff;border-color:#fff;}
.tl-dot svg{width:26px;height:26px;}
.tl-card{background:#fff;border-radius:20px;padding:16px 22px;box-shadow:0 12px 26px rgba(176,0,90,.1);}
.tl-card h4{font-family:var(--font-round);font-weight:900;color:var(--berry-deep);font-size:clamp(16px,1.7vw,20px);}
.tl-card p{font-size:13.5px;color:#7a4359;margin-top:4px;line-height:1.7;}

/* ===========================================================
   SECTION 5 — testimonials
   =========================================================== */
.voices{background:linear-gradient(180deg,#fff1e9 0%, #ffe6f1 100%);}
.quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:54px;}
.quote{position:relative;background:#fff;border-radius:26px;padding:54px 30px 30px;box-shadow:0 20px 40px rgba(176,0,90,.12);}
.quote:nth-child(2){transform:rotate(1.4deg);}
.quote:nth-child(1){transform:rotate(-1.6deg);}
.quote .mark{position:absolute;top:14px;left:24px;font-family:var(--font-display);color:#ffd0e6;font-size:64px;line-height:.7;}
.quote p{font-family:var(--font-round);font-weight:700;color:var(--ink);font-size:16px;line-height:1.95;position:relative;}
.quote .who{display:flex;align-items:center;gap:12px;margin-top:22px;}
.quote .who .av{width:46px;height:46px;border-radius:50%;background:radial-gradient(circle at 35% 30%,#ff8cc6,#ff1e8c);flex:none;
  display:grid;place-items:center;color:#fff;font-family:var(--font-display);font-size:18px;}
.quote .who .nm{font-family:var(--font-round);font-weight:900;color:var(--berry-deep);font-size:13.5px;line-height:1.4;}
.quote .stars{color:var(--gold);font-size:14px;letter-spacing:2px;margin-top:4px;}

/* ===========================================================
   SECTION 6 — facility summary
   =========================================================== */
.facility{background:linear-gradient(180deg,#ffe6f1 0%, #fff5fb 100%);}
.fac-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:44px;align-items:center;margin-top:50px;}
.fac-list{list-style:none;display:flex;flex-direction:column;gap:4px;}
.fac-list li{display:grid;grid-template-columns:128px 1fr;gap:16px;padding:18px 0;border-bottom:2px dotted #ffc4e0;align-items:start;}
.fac-list .k{font-family:var(--font-round);font-weight:900;color:var(--magenta);font-size:14px;}
.fac-list .v{font-family:var(--font-round);font-weight:700;color:var(--ink);font-size:15.5px;line-height:1.7;}
.fac-tags{display:flex;flex-wrap:wrap;gap:8px;}
.fac-tags span{background:#fff;border:2px solid #ffd0e6;color:var(--berry);font-family:var(--font-round);font-weight:900;font-size:13px;padding:6px 14px;border-radius:999px;}
.fac-card{position:relative;border-radius:28px;overflow:hidden;box-shadow:0 24px 48px rgba(176,0,90,.2);border:6px solid #fff;background:#ffe7f3;}
.fac-card image-slot{display:block;width:100%;height:340px;}
.fac-pin{position:absolute;left:18px;bottom:18px;z-index:3;background:rgba(255,255,255,.92);border-radius:16px;padding:12px 18px;
  font-family:var(--font-round);font-weight:900;color:var(--berry-deep);font-size:14px;box-shadow:0 10px 22px rgba(176,0,90,.2);display:flex;align-items:center;gap:10px;}
.fac-pin .dot{width:12px;height:12px;border-radius:50%;background:var(--magenta);box-shadow:0 0 0 4px rgba(255,30,140,.25);}

/* ===========================================================
   SECTION 7 — CTA (full-bleed image4)
   =========================================================== */
.cta{position:relative;min-height:88svh;display:grid;place-items:center;text-align:center;overflow:hidden;background:#ff5cae;}
.cta .bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;will-change:transform;}
.cta .scrim{position:absolute;inset:0;z-index:1;background:radial-gradient(80% 80% at 50% 40%, rgba(255,30,140,.32), rgba(138,2,71,.74));}
.cta-inner{position:relative;z-index:3;max-width:980px;padding:0 clamp(20px,5vw,40px);}
.cta .kicker{color:#ffe1ef;justify-content:center;}
.cta .kicker::before{background:var(--gold);}
.cta h2{font-family:var(--font-display);color:#fff;line-height:1.32;letter-spacing:-.01em;font-size:clamp(25px,3.7vw,50px);margin:18px 0 0;
  text-shadow:0 6px 30px rgba(70,2,40,.55);text-wrap:balance;word-break:keep-all;overflow-wrap:break-word;}
.cta h2 em{font-style:normal;color:var(--gold);}
.cta .sub{font-family:var(--font-round);font-weight:700;color:#fff;font-size:clamp(15px,1.6vw,20px);margin-top:22px;line-height:1.9;text-shadow:0 2px 12px rgba(70,2,40,.6);}
.cta .btn-row{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-top:38px;}
.btn-gold{background:linear-gradient(90deg,#ffd76a,#ffb300);color:var(--ink);box-shadow:0 8px 0 #c98b00,0 16px 30px rgba(0,0,0,.25);}
.btn-gold:hover{transform:translateY(-3px) scale(1.03);box-shadow:0 11px 0 #c98b00,0 20px 34px rgba(0,0,0,.3);}
.btn-white-o{background:rgba(255,255,255,.12);border:3px solid #fff;color:#fff;padding:15px 27px;}
.btn-white-o:hover{background:#fff;color:var(--magenta);transform:translateY(-3px) rotate(-2deg);}

/* ===========================================================
   FOOTER (section 8)
   =========================================================== */
footer{position:relative;background:linear-gradient(160deg,#5a022f 0%, #2a0418 100%);color:#ffd9ea;padding:clamp(60px,8vw,96px) 0 30px;overflow:hidden;}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;}
.foot-brand .brand{color:#fff;font-size:24px;}
.foot-brand .brand .mark{box-shadow:0 4px 12px rgba(0,0,0,.3);}
.foot-brand p{font-family:var(--font-round);font-weight:500;color:#ffb8d6;font-size:14px;line-height:1.9;margin-top:18px;max-width:30em;}
.foot-col h5{font-family:var(--font-round);font-weight:900;color:#fff;font-size:14px;margin-bottom:16px;}
.foot-col a{display:block;font-family:var(--font-round);font-weight:500;color:#ffb8d6;text-decoration:none;font-size:14px;padding:7px 0;transition:color .2s, transform .2s;}
.foot-col a:hover{color:#fff;transform:translateX(4px);}
.foot-col .foot-addr{font-family:var(--font-round);color:#ffb8d6;font-size:13px;line-height:1.85;margin-bottom:12px;}
.drawer a.active{background:rgba(255,255,255,.2);}
.sns{display:flex;gap:12px;margin-top:6px;}
.sns a{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;background:rgba(255,255,255,.1);color:#fff;transition:.25s;}
.sns a:hover{background:var(--magenta);transform:translateY(-3px);}
.sns svg{width:20px;height:20px;}
.foot-bot{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;margin-top:54px;padding-top:24px;border-top:1px solid rgba(255,255,255,.14);
  font-family:var(--font-round);font-size:12px;color:#ff9ec6;}
.foot-priv{color:#ffd9ea;text-decoration:none;font-weight:700;transition:color .2s;}
.foot-priv:hover{color:#fff;text-decoration:underline;}

/* MEMBER OF ONGROUP — prominent footer signature (last element, all pages) */
.foot-sig{display:flex;flex-direction:column;align-items:center;gap:8px;text-decoration:none;
  margin-top:30px;padding-top:34px;border-top:1px solid rgba(255,255,255,.12);transition:transform .25s;}
.foot-sig-lbl{font-family:var(--font-round);font-weight:700;font-size:13px;letter-spacing:.34em;
  color:#ff9ec6;padding-left:.34em;transition:color .25s;}
.foot-sig-brand{position:relative;font-family:var(--font-display);font-size:clamp(34px,5.4vw,48px);
  letter-spacing:.03em;color:#fff;line-height:1;transition:color .25s;}
.foot-sig-brand::after{content:"";position:absolute;left:50%;bottom:-9px;width:0;height:3px;border-radius:3px;
  background:var(--magenta-2);transform:translateX(-50%);transition:width .3s cubic-bezier(.22,1,.36,1);}
.foot-sig:hover .foot-sig-brand{color:var(--magenta-2);}
.foot-sig:hover .foot-sig-lbl{color:#fff;}
.foot-sig:hover .foot-sig-brand::after{width:100%;}
.foot-sig:focus-visible{outline:3px solid var(--magenta-2);outline-offset:8px;border-radius:8px;}

/* ===========================================================
   PAGE GUIDE (index nav cards)
   =========================================================== */
.guide{background:linear-gradient(180deg,#fff7fc 0%,#ffe9f5 100%);}
.guide-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:54px;}
.guide-card{position:relative;display:flex;flex-direction:column;align-items:flex-start;text-decoration:none;
  background:#fff;border-radius:28px;padding:34px 30px 30px;box-shadow:0 20px 40px rgba(176,0,90,.1);
  border:2px solid rgba(255,30,140,.08);transition:transform .3s, box-shadow .3s;overflow:hidden;}
.guide-card::after{content:"";position:absolute;right:-30px;top:-30px;width:120px;height:120px;border-radius:50%;
  background:radial-gradient(circle,rgba(255,140,198,.22),transparent 70%);transition:transform .4s;}
.guide-card:hover{transform:translateY(-10px) rotate(-.6deg);box-shadow:0 30px 56px rgba(176,0,90,.2);}
.guide-card:hover::after{transform:scale(1.5);}
.gc-ic{width:62px;height:62px;border-radius:18px;display:grid;place-items:center;color:#fff;
  background:linear-gradient(135deg,var(--magenta),var(--magenta-2));box-shadow:0 12px 22px rgba(255,30,140,.32);transition:transform .35s;}
.gc-ic svg{width:32px;height:32px;}
.guide-card:hover .gc-ic{transform:scale(1.08) rotate(5deg);}
.gc-no{font-family:var(--font-display);color:#ffc4e0;font-size:13px;letter-spacing:.12em;margin-top:18px;}
.gc-title{font-family:var(--font-round);font-weight:900;color:var(--berry-deep);font-size:clamp(18px,2vw,22px);margin-top:6px;line-height:1.4;}
.gc-sub{font-family:var(--font-body);color:#6b3850;font-size:14px;line-height:1.9;margin-top:12px;}
.gc-go{display:inline-flex;align-items:center;gap:8px;margin-top:20px;font-family:var(--font-round);font-weight:900;
  color:var(--magenta);font-size:14.5px;}
.gc-go .arrow{transition:transform .2s;}
.guide-card:hover .gc-go .arrow{transform:translateX(5px);}

/* ===========================================================
   RESPONSIVE
   =========================================================== */
@media (max-width:980px){
  .cards,.quotes{grid-template-columns:1fr;}
  .cards-pad{padding-top:40px;}
  .card .ic{margin-top:0;}
  .quote:nth-child(n){transform:none;}
  .fac-grid{grid-template-columns:1fr;gap:30px;}
  .foot-grid{grid-template-columns:1fr 1fr;}
  .foot-brand{grid-column:1/-1;}
  .guide-grid{grid-template-columns:1fr 1fr;}
}
@media (max-width:1180px){
  .menu{display:none;}
  .burger{display:flex;}
}
@media (max-width:860px){
  /* hero: stack vertically, centered — image on top, then copy, then CTA */
  .hero{display:flex;flex-direction:column;justify-content:flex-start;}
  .art-glow{display:none;}
  .art-wrap{position:relative;right:auto;bottom:auto;transform:none;order:-1;
    width:min(80vw,400px);margin:100px auto 0;}
  .hero-inner{order:1;position:relative;min-height:auto;
    padding:22px 16px 96px;align-items:center;text-align:center;}
  .copy{max-width:none;margin:0 auto;display:flex;flex-direction:column;align-items:center;}
  .headline{width:100%;}
  .lede{max-width:34em;margin-left:auto;margin-right:auto;}
  .cta-row{justify-content:center;}
  .trust{justify-content:center;}
  .voice{display:none;}
  .ghost{font-size:60vw;top:18%;}
}
@media (max-width:600px){
  .headline .l1{font-size:clamp(40px,15.5vw,72px);}
  .trust{gap:16px;}
  .voice{display:none;}
  .timeline::before{left:calc(64px + 16px);}
  .tl-row{grid-template-columns:64px 48px 1fr;gap:12px;}
  .tl-dot{width:48px;height:48px;}
  .foot-grid{grid-template-columns:1fr;}
  .guide-grid{grid-template-columns:1fr;}
}
@media (max-width:768px){
  /* on mobile, never shift horizontally on reveal (prevents off-screen clipping) */
  html.js [data-sr="left"],html.js [data-sr="right"]{transform:translateY(38px);}
  /* allow big Japanese headings to wrap per-character so long phrases always fit */
  .sec-title,.story h2,.cta h2,.page-hero h1,.headline-statement,.statement h2,.headline .l2,.tl-card h4,.devcard h3,.fcard h3,.mv h3,.bigquote p{
    word-break:normal;overflow-wrap:anywhere;}
}
@media (prefers-reduced-motion: reduce){
  *{animation:none!important;}
  html.js [data-sr]{opacity:1!important;transform:none!important;}
}
