/* =========================================================
   Cloud Liver — shared stylesheet
   - design tokens (:root)
   - site-wide background, header, footer
   - section primitives, fade-in
   - LP-specific blocks (hero, service, support, results, voices, flow, faq, cta)
   - company.html blocks (page-hero, message, vmv, info, timeline, access)
   ========================================================= */

/* ---------- design tokens ---------- */
:root{
  --ink:#1b1f3a;
  --ink-2:#4a4f6f;
  --muted:#8a90ab;
  --line:#e7e6f3;
  --bg:#fbfaff;
  --bg-soft:#f3f0fc;
  --blue:#3b6df8;
  --blue-2:#5a8bff;
  --purple:#9b5cf6;
  --purple-2:#c084fc;
  --pink:#ec4899;
  --pink-2:#f472b6;
  --grad: linear-gradient(90deg, #3b6df8 0%, #9b5cf6 50%, #ec4899 100%);
  --grad-soft: linear-gradient(135deg, #e0e8ff 0%, #efe4ff 55%, #ffe1ee 100%);
}

/* ---------- base ---------- */
*{box-sizing:border-box}
html{background:var(--bg);overflow-x:hidden}
html,body{margin:0;padding:0;color:var(--ink);font-family:"Noto Sans JP",system-ui,sans-serif;-webkit-font-smoothing:antialiased;position:relative}
body{overflow-x:hidden;padding-top:108px;background:transparent;max-width:100vw}
body.nav-locked{overflow:hidden}
@media (min-width:1200px){body{min-width:1280px}}

/* ---------- Hamburger toggle (hidden on desktop, shown on tablet/mobile) ---------- */
.nav-toggle{
  display:none;position:relative;width:44px;height:44px;
  flex:none;cursor:pointer;background:transparent;border:0;padding:0;
  z-index:201;color:inherit;
}
.nav-toggle .bar{
  position:absolute;left:10px;right:10px;height:2px;
  background:var(--ink);border-radius:2px;
  transition:transform .3s ease, opacity .3s ease, top .3s ease;
}
.nav-toggle .bar:nth-child(1){top:14px}
.nav-toggle .bar:nth-child(2){top:21px}
.nav-toggle .bar:nth-child(3){top:28px}
.nav-toggle[aria-expanded="true"] .bar{background:#fff}
.nav-toggle[aria-expanded="true"] .bar:nth-child(1){top:21px;transform:rotate(45deg)}
.nav-toggle[aria-expanded="true"] .bar:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] .bar:nth-child(3){top:21px;transform:rotate(-45deg)}

/* ---------- Drawer (slides in from right) ---------- */
.nav-drawer{
  position:fixed;inset:0;z-index:300;
  visibility:hidden;opacity:0;
  transition:opacity .3s ease, visibility 0s .3s;
}
.nav-drawer.is-open{visibility:visible;opacity:1;transition:opacity .3s ease}
.nav-drawer-backdrop{
  position:absolute;inset:0;
  background:rgba(15,8,30,.5);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
}
.nav-drawer-panel{
  position:absolute;top:0;right:0;bottom:0;
  width:min(86%, 360px);
  padding:78px 26px 30px;
  display:flex;flex-direction:column;gap:24px;
  color:#fff;
  background:
    radial-gradient(ellipse 600px 400px at 70% 10%, rgba(91,139,255,.22), transparent 60%),
    radial-gradient(ellipse 500px 360px at 10% 85%, rgba(236,72,153,.18), transparent 60%),
    linear-gradient(180deg, #1b1638 0%, #0c0a1e 100%);
  transform:translateX(100%);
  transition:transform .35s cubic-bezier(.2,.7,.2,1);
  box-shadow:-20px 0 60px -20px rgba(0,0,0,.55);
}
.nav-drawer.is-open .nav-drawer-panel{transform:translateX(0)}
.nav-drawer-close{
  position:absolute;top:18px;right:18px;
  width:44px;height:44px;border-radius:50%;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);
  color:#fff;font-size:22px;line-height:1;cursor:pointer;
  display:grid;place-items:center;
  transition:background .2s, transform .3s;
}
.nav-drawer-close:hover{background:rgba(255,255,255,.16);transform:rotate(90deg)}
.nav-drawer-brand{
  font-family:"Orbitron",sans-serif;font-weight:800;font-size:13px;letter-spacing:.4em;
  background:linear-gradient(90deg,#5a8bff,#9b5cf6 55%,#ec4899);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  text-transform:uppercase;margin-bottom:4px;
}
.nav-drawer-nav{display:flex;flex-direction:column;gap:0}
.nav-drawer-nav a{
  display:block;padding:15px 4px;
  font-size:17px;font-weight:600;color:rgba(255,255,255,.92);
  border-bottom:1px solid rgba(255,255,255,.08);
  transition:color .2s, padding-left .2s;
}
.nav-drawer-nav a:hover,.nav-drawer-nav a:focus-visible{color:#00e5ff;padding-left:8px;outline:0}
.nav-drawer-nav a.current{
  color:#fff;font-weight:800;
  background:linear-gradient(90deg, rgba(155,92,246,.18), transparent);
  padding-left:12px;border-radius:6px;border-bottom-color:transparent;
}
.nav-drawer-cta{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  margin-top:auto;
  padding:16px 28px;border-radius:999px;
  background:linear-gradient(90deg,#3b6df8 0%,#9b5cf6 55%,#ec4899 100%);
  color:#fff;font-weight:800;font-size:15px;
  box-shadow:0 16px 32px -10px rgba(155,92,246,.55), inset 0 0 0 1px rgba(255,255,255,.22);
  transition:transform .2s, box-shadow .2s;
}
.nav-drawer-cta .arr{transition:transform .2s}
.nav-drawer-cta:hover{transform:translateY(-2px);box-shadow:0 20px 38px -10px rgba(155,92,246,.65), inset 0 0 0 1px rgba(255,255,255,.3)}
.nav-drawer-cta:hover .arr{transform:translateX(3px)}
.nav-drawer-cta-wrap{display:flex;flex-direction:column;align-items:stretch;margin-top:auto}
.nav-drawer-cta-wrap .nav-drawer-cta{margin-top:0}
.nav-drawer-cta-wrap .line-note{text-align:center;margin-top:10px}


/* ---------- Loading Screen (page load splash, light brand style) ---------- */
.loading-screen{
  position:fixed;inset:0;z-index:9999;
  display:flex;align-items:center;justify-content:center;
  background:radial-gradient(ellipse 1200px 800px at center, #ffffff 0%, #f7f4fc 65%, #fdf5fa 100%);
  animation:loadingScreenOut .8s ease-out 2s forwards;
}
.loading-screen__inner{text-align:center;animation:loadingFadeIn .7s ease-out forwards}
.loading-screen__logo svg{
  width:62px;height:62px;display:block;margin:0 auto;
  filter:drop-shadow(0 6px 18px rgba(155,92,246,.32)) drop-shadow(0 0 22px rgba(236,72,153,.16));
}
.loading-screen__brand{
  margin:18px 0 26px;
  font-family:"Orbitron",sans-serif;font-weight:800;font-size:14px;
  letter-spacing:.42em;text-transform:uppercase;
  background:linear-gradient(90deg,#3b6df8,#9b5cf6 55%,#ec4899);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  filter:drop-shadow(0 2px 6px rgba(155,92,246,.18));
}
.loading-screen__bar{
  position:relative;width:192px;height:3px;
  background:rgba(60,40,140,.1);
  border-radius:999px;overflow:hidden;margin:0 auto;
}
.loading-screen__bar-fill{
  width:0%;height:100%;
  background:linear-gradient(90deg,#3b6df8 0%,#9b5cf6 50%,#ec4899 100%);
  border-radius:999px;
  animation:loadingBar 1.8s cubic-bezier(.4,.0,.2,1) forwards;
  box-shadow:0 0 8px rgba(155,92,246,.55), 0 0 16px rgba(236,72,153,.32);
}
@keyframes loadingFadeIn{
  from{opacity:0;transform:translateY(10px) scale(.95)}
  to{opacity:1;transform:translateY(0) scale(1)}
}
@keyframes loadingBar{
  0%{width:0%}
  50%{width:70%}
  100%{width:100%}
}
@keyframes loadingScreenOut{
  to{opacity:0;visibility:hidden;pointer-events:none}
}
@media (prefers-reduced-motion: reduce){
  .loading-screen{display:none}
}

img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit}

/* ---------- site-wide animated background ---------- */
.bg-layer{
  position:fixed;inset:0;z-index:-1;pointer-events:none;overflow:hidden;
  background:
    radial-gradient(ellipse 1200px 800px at 20% 0%, rgba(213,225,255,.28), transparent 60%),
    radial-gradient(ellipse 1100px 700px at 90% 18%, rgba(255,212,232,.22), transparent 60%),
    radial-gradient(ellipse 1000px 700px at 0% 60%, rgba(228,217,255,.24), transparent 60%),
    radial-gradient(ellipse 1100px 700px at 100% 80%, rgba(216,228,255,.22), transparent 60%),
    linear-gradient(180deg, #fbfaff 0%, #f8f6fc 50%, #fbf7fa 100%);
}
.bg-layer::before{
  content:"";position:absolute;inset:0;
  background-image:radial-gradient(rgba(155,92,246,.07) 1px, transparent 1.5px);
  background-size:32px 32px;
  mask-image:linear-gradient(180deg, #000 0%, #000 70%, transparent 100%);
  -webkit-mask-image:linear-gradient(180deg, #000 0%, #000 70%, transparent 100%);
  opacity:.7;
}
.bg-layer .orb{position:absolute;border-radius:50%;filter:blur(60px);opacity:.35;will-change:transform}
.bg-layer .orb.o1{left:-120px;top:8%;width:380px;height:380px;background:radial-gradient(circle at 30% 30%, #c5d6ff, #8aa9ff 70%);animation:driftA 22s ease-in-out infinite}
.bg-layer .orb.o2{right:-100px;top:24%;width:340px;height:340px;background:radial-gradient(circle at 30% 30%, #ffd6e7, #f7a8c8 70%);animation:driftB 28s ease-in-out infinite}
.bg-layer .orb.o3{left:25%;top:48%;width:300px;height:300px;background:radial-gradient(circle at 30% 30%, #e3d6ff, #c5a3f5 70%);animation:driftC 26s ease-in-out infinite}
.bg-layer .orb.o4{right:8%;top:62%;width:360px;height:360px;background:radial-gradient(circle at 30% 30%, #d6e6ff, #a8c5f9 70%);animation:driftA 30s ease-in-out -8s infinite}
.bg-layer .orb.o5{left:5%;top:80%;width:280px;height:280px;background:radial-gradient(circle at 30% 30%, #ffe3d6, #f5c4a3 70%);animation:driftB 24s ease-in-out -4s infinite;opacity:.26}
.bg-layer .orb.o6{right:30%;top:92%;width:320px;height:320px;background:radial-gradient(circle at 30% 30%, #e0c8ff, #b78de8 70%);animation:driftC 32s ease-in-out -12s infinite}

@keyframes driftA{0%,100%{transform:translate(0,0) scale(1)}33%{transform:translate(40px,-30px) scale(1.05)}66%{transform:translate(-30px,20px) scale(.96)}}
@keyframes driftB{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(-50px,30px) scale(1.08)}}
@keyframes driftC{0%,100%{transform:translate(0,0) scale(1)}25%{transform:translate(30px,40px) scale(1.04)}75%{transform:translate(-40px,-20px) scale(.94)}}
@media (prefers-reduced-motion: reduce){.bg-layer .orb{animation:none}}

/* ---------- neon geometric shapes (gaming PC RGB ambient) ---------- */
.bg-shapes{position:absolute;inset:0;pointer-events:none;overflow:hidden;z-index:-1}
.bg-shape{
  position:absolute;
  animation:shapeFloat var(--dur,22s) ease-in-out infinite;
  animation-delay:var(--delay,0s);
  will-change:transform;
}
.bg-shape svg{display:block;width:100%;height:100%;transform:rotate(var(--r,0deg))}
.bg-shape svg *{vector-effect:non-scaling-stroke}
.bg-shape.glow-cyan   svg{filter:
  drop-shadow(0 0 6px  #00e5ff)
  drop-shadow(0 0 18px rgba(0,229,255,.7))
  drop-shadow(0 0 40px rgba(0,229,255,.3))}
.bg-shape.glow-lime   svg{filter:
  drop-shadow(0 0 6px  #39ff14)
  drop-shadow(0 0 18px rgba(57,255,20,.6))
  drop-shadow(0 0 40px rgba(57,255,20,.25))}
.bg-shape.glow-purple svg{filter:
  drop-shadow(0 0 6px  #b14bff)
  drop-shadow(0 0 18px rgba(177,75,255,.65))
  drop-shadow(0 0 40px rgba(177,75,255,.28))}
.bg-shape.glow-pink   svg{filter:
  drop-shadow(0 0 6px  #ff2e93)
  drop-shadow(0 0 18px rgba(255,46,147,.65))
  drop-shadow(0 0 40px rgba(255,46,147,.28))}

@keyframes shapeFloat{
  0%,100%{transform:translateY(0) translateX(0)}
  33%{transform:translateY(-34px) translateX(16px)}
  66%{transform:translateY(22px) translateX(-20px)}
}
@media (prefers-reduced-motion: reduce){.bg-shape{animation:none}}

/* ---------- header ---------- */
header.site{
  position:fixed;top:0;left:0;right:0;z-index:200;
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 48px;
  background:rgba(251,250,255,.78);backdrop-filter:saturate(180%) blur(14px);-webkit-backdrop-filter:saturate(180%) blur(14px);
  border-bottom:1px solid rgba(231,230,243,0);transition:padding .25s ease, background .25s ease, border-color .25s ease, box-shadow .25s ease;
}
header.site.scrolled{padding:12px 48px;background:rgba(251,250,255,.92);border-bottom-color:#ecebf6;box-shadow:0 10px 24px -20px rgba(60,40,140,.25)}
header.site > *{position:relative;z-index:1}
.header-inner{max-width:1280px;margin:0 auto;width:100%;display:flex;align-items:center;justify-content:space-between;flex-wrap:nowrap;gap:24px}

/* brand lockup */
.brand{display:flex;align-items:center;gap:14px;position:relative;flex:none}
.brand .mark{position:relative;width:56px;height:56px;display:grid;place-items:center;flex:none}
.brand .mark .hex{position:absolute;inset:0;filter:drop-shadow(0 8px 22px rgba(123,86,247,.45))}
.brand .mark .pulse{position:absolute;right:-2px;top:-2px;width:13px;height:13px;border-radius:50%;background:#ff3358;box-shadow:0 0 0 2.5px #fbfaff,0 0 14px #ff3358;animation:livePulse 1.6s ease-out infinite}
@keyframes livePulse{0%{box-shadow:0 0 0 2px #fbfaff,0 0 0 0 rgba(255,51,88,.6)}70%{box-shadow:0 0 0 2px #fbfaff,0 0 0 8px rgba(255,51,88,0)}100%{box-shadow:0 0 0 2px #fbfaff,0 0 0 0 rgba(255,51,88,0)}}
.brand .word{display:flex;flex-direction:row;align-items:center;line-height:1;gap:12px;flex-wrap:nowrap}
.brand .word .name{padding:0;display:inline-flex;align-items:center;flex:none}
.brand .word .name svg{display:block}
/* Cloud Liver wordmark — text version (replaces SVG <text> for better glyph quality) */
.wordmark{
  font-family:"Orbitron",sans-serif;font-weight:800;letter-spacing:.108em;font-size:20px;line-height:1;
  background:linear-gradient(90deg,#3b6df8 0%,#9b5cf6 55%,#ec4899 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  -webkit-text-fill-color:transparent;
  white-space:nowrap;display:inline-block;
}
.wordmark.sm{font-size:18px;letter-spacing:.11em}
.brand .word .tag{display:inline-flex;align-items:center;gap:8px;font-size:10px;letter-spacing:.3em;color:#6b7090;font-weight:700;font-family:"Orbitron",sans-serif;white-space:nowrap;flex:none}
.brand .word .tag .live{display:inline-flex;align-items:center;gap:4px;padding:2px 7px 2px 7px;border-radius:4px;background:#ff3358;color:#fff;font-size:10px;letter-spacing:.18em;font-weight:900}
.brand .word .tag .live::before{content:"";width:7px;height:7px;border-radius:50%;background:#fff;animation:livePulse2 1.4s infinite}
@keyframes livePulse2{0%,100%{opacity:1}50%{opacity:.3}}

nav.main{display:flex;gap:26px;font-size:14px;font-weight:600;color:#3b3f5f;white-space:nowrap;flex:none}
nav.main a{position:relative;white-space:nowrap;transition:color .2s}
nav.main a:hover{color:var(--blue)}
nav.main a.current{color:var(--ink);font-weight:700}
nav.main a.current::after{content:"";position:absolute;left:0;right:0;bottom:-8px;height:2px;background:var(--grad);border-radius:2px}

.cta-pill{
  display:inline-flex;align-items:center;gap:10px;
  padding:13px 24px;border-radius:999px;color:#fff;font-weight:700;font-size:14px;
  background:linear-gradient(90deg,#3b6df8 0%,#9b5cf6 55%,#ec4899 100%);
  box-shadow:0 12px 26px -10px rgba(123,86,247,.55), inset 0 0 0 1px rgba(255,255,255,.25);
  cursor:pointer;border:0;white-space:nowrap;flex:none;font-family:inherit;
}
.cta-pill .arr{font-weight:600;transition:transform .2s}
.cta-pill:hover .arr{transform:translateX(3px)}

/* ---------- generic section ---------- */
section.block{
  position:relative;max-width:1200px;margin:28px auto;padding:54px 52px;
  /* white frosted panel — content sits above neon shapes while keeping them visible behind */
  background:rgba(252,250,248,.55);
  border-radius:36px;
  box-shadow:
    0 26px 52px -28px rgba(60,40,140,.28),
    inset 0 0 0 1px rgba(255,255,255,.6);
  backdrop-filter:blur(6px) saturate(115%);
  -webkit-backdrop-filter:blur(6px) saturate(115%);
}
.sec-num{
  font-family:"Bebas Neue",sans-serif;font-size:100px;line-height:.8;letter-spacing:.02em;
  background:linear-gradient(180deg,#cfd5f5 0%,#e7d6fb 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  opacity:.9;position:relative;z-index:0;
}
.sec-title{
  font-size:44px;font-weight:900;letter-spacing:-.015em;color:#11142d;line-height:1.15;
  margin:-30px 0 8px;position:relative;z-index:1;white-space:nowrap;
}
.sec-title.with-slash{margin-top:-14px}
.sec-title .slash{color:#cfd2e9;font-weight:700;margin:0 10px;font-size:.85em;display:inline-block}
.sec-eyebrow{
  display:inline-block;margin:0;font-family:"Bebas Neue",sans-serif;letter-spacing:.3em;font-size:22px;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;
}
/* yuijp-inspired colored accent line under section titles */
.sec-title[class*="line-"]::after{
  content:"";display:block;width:160px;height:2px;border-radius:1px;
  margin:16px 0 10px;background:var(--line-color,var(--ink));opacity:.6;
}
/* refined sparkle accents for section heads */
.sec-sparkles{position:absolute;inset:0;pointer-events:none;z-index:0}
.sec-sparkles .sparkle{
  position:absolute;display:block;
  fill:currentColor;
  animation:secSparkle 3.4s ease-in-out infinite;
  filter:drop-shadow(0 0 6px currentColor);
}
.sec-sparkles .sparkle.sp1{top:6px;right:48px;width:36px;height:36px;color:rgba(91,139,255,.55);animation-delay:0s}
.sec-sparkles .sparkle.sp2{top:54px;right:148px;width:24px;height:24px;color:rgba(236,72,153,.5);animation-delay:.8s}
.sec-sparkles .sparkle.sp3{top:104px;right:24px;width:28px;height:28px;color:rgba(155,92,246,.55);animation-delay:1.6s}
.sec-sparkles .sparkle.sp4{top:140px;right:220px;width:20px;height:20px;color:rgba(252,211,77,.5);animation-delay:2.2s}
@keyframes secSparkle{
  0%,100%{opacity:.3;transform:scale(.8) rotate(0deg)}
  50%{opacity:1;transform:scale(1.15) rotate(45deg)}
}
@media (prefers-reduced-motion: reduce){
  .sec-sparkles .sparkle{animation:none;opacity:.6}
}

.sec-title.line-blue   {--line-color:#0693e3}
.sec-title.line-purple {--line-color:#9b51e0}
.sec-title.line-pink   {--line-color:#ec4899}
.sec-title.line-orange {--line-color:#ff6900}
.sec-title.line-green  {--line-color:#00d084}



.sec-lead{margin:6px 0 0;color:#54597a;font-size:16px;line-height:1.75;max-width:900px;font-weight:500}
.sec-lead.narrow{max-width:380px}
.sec-head{display:grid;grid-template-columns:auto 1fr;gap:40px;align-items:end;position:relative}
.sec-head .sec-side{display:flex;align-items:flex-end;justify-content:flex-end;height:100%}

/* small decorative motifs sprinkled across sections (HERO continuity) */
.sec-deco{position:absolute;pointer-events:none;z-index:0;opacity:.85}
.sec-deco.spark{animation:sparkBlink 2.6s ease-in-out infinite}
.sec-deco.pad{animation:floatY 6s ease-in-out infinite;filter:drop-shadow(0 14px 22px rgba(123,86,247,.3))}
@keyframes floatY{0%,100%{transform:translateY(0) rotate(var(--r,0deg))}50%{transform:translateY(-10px) rotate(var(--r,0deg))}}

/* ---------- hero (LP) ---------- */
.hero{
  position:relative;max-width:1400px;margin:0 auto;
  padding:16px 60px 60px;min-height:660px;
  overflow:visible;
}
.hero-inner{position:relative;z-index:2;display:grid;grid-template-columns:480px 1fr;gap:48px;align-items:start}

.badge-row{display:flex;gap:8px;align-items:center;margin-top:14px}
.badge-pill{
  display:inline-flex;align-items:center;gap:5px;
  padding:8px 16px;border-radius:999px;font-size:14px;font-weight:700;color:#fff;
  background:linear-gradient(90deg,#3b6df8,#9b5cf6 70%,#ec4899);
  box-shadow:0 8px 18px -6px rgba(123,86,247,.45);
}
.badge-pill.outline{
  background:#fff;color:var(--ink);
  box-shadow:inset 0 0 0 1.5px var(--line);font-weight:600;
}
.badge-pill.outline::before{content:"";width:7px;height:7px;border-radius:50%;background:linear-gradient(135deg,#9b5cf6,#ec4899)}

.h1-wrap{margin-top:14px;position:relative}
.h1{font-size:58px;line-height:1.05;font-weight:900;letter-spacing:-.02em;color:#0c0f2c;white-space:nowrap}
.h1 .mirai{
  font-size:64px;font-weight:900;line-height:.9;display:inline-block;vertical-align:-6px;letter-spacing:-.02em;
  font-style:italic;
  background:linear-gradient(180deg,#9b5cf6 0%,#c084fc 50%,#ec4899 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  text-shadow:0 5px 0 rgba(155,92,246,.10);
  margin-left:-20px;margin-right:18px;padding-right:4px;
}
.h1 .grey{color:#cdd1e8;font-weight:900}

.pse{
  display:flex;align-items:center;gap:14px;margin-top:14px;
  font-family:"Bebas Neue",sans-serif;font-size:24px;letter-spacing:.08em;
}
.pse span:nth-child(1){background:linear-gradient(90deg,#3b6df8,#5a8bff);-webkit-background-clip:text;background-clip:text;color:transparent}
.pse span:nth-child(3){background:linear-gradient(90deg,#9b5cf6,#c084fc);-webkit-background-clip:text;background-clip:text;color:transparent}
.pse span:nth-child(5){background:linear-gradient(90deg,#ec4899,#f472b6);-webkit-background-clip:text;background-clip:text;color:transparent}
.pse i{color:#cdd1e8;font-style:normal;font-size:20px;font-weight:300}

.lead{margin-top:18px;font-size:18px;line-height:1.9;color:#3b3f5f;max-width:520px;font-weight:500}

.chip-grid{display:grid;grid-template-columns:repeat(2,max-content);gap:8px 10px;margin-top:20px}
.chip{
  display:inline-flex;align-items:center;gap:8px;
  padding:11px 18px;border-radius:999px;font-size:15px;font-weight:600;color:var(--ink);
  background:#fff;box-shadow:0 6px 18px -8px rgba(60,68,140,.18),inset 0 0 0 1.5px #ece9fb;
}
.chip .dot{
  width:23px;height:23px;border-radius:50%;display:inline-grid;place-items:center;color:#fff;font-size:11px;
}
.chip .dot.b{background:linear-gradient(135deg,#3b6df8,#5a8bff)}
.chip .dot.p{background:linear-gradient(135deg,#9b5cf6,#c084fc)}
.chip .dot.pk{background:linear-gradient(135deg,#ec4899,#f472b6)}
.chip .dot.bp{background:linear-gradient(135deg,#5a8bff,#9b5cf6)}

.hero-cta-wrap{position:relative;margin-top:26px;display:flex;flex-wrap:nowrap;align-items:center;gap:16px;white-space:nowrap}
.hero-cta{
  position:relative;
  padding:20px 40px;border:0;cursor:pointer;color:#fff;font-weight:800;font-size:21px;
  border-radius:999px;
  background:linear-gradient(90deg,#3b6df8 0%,#9b5cf6 50%,#ec4899 100%);
  box-shadow:0 18px 32px -14px rgba(123,86,247,.55), inset 0 0 0 1px rgba(255,255,255,.3);
  display:inline-flex;align-items:center;gap:14px;white-space:nowrap;flex:none;
}
.hero-cta .arr{font-weight:700;transition:transform .2s}
.hero-cta:hover .arr{transform:translateX(3px)}
.hero-cta::after{
  content:"";position:absolute;left:14px;right:14px;bottom:-8px;height:14px;
  background:linear-gradient(90deg,#3b6df8,#9b5cf6,#ec4899);filter:blur(14px);opacity:.45;z-index:-1;border-radius:999px;
}
.casual{
  font-family:"Yusei Magic","Noto Sans JP",sans-serif;color:var(--pink);font-weight:700;font-size:17px;
  transform:rotate(-6deg);position:relative;white-space:nowrap;flex:none;
}
.casual::before{
  content:"";position:absolute;left:-18px;top:50%;width:14px;height:1.5px;background:var(--pink);transform:translateY(-50%) rotate(-15deg);
}

.scroll-pill{
  position:absolute;left:18px;top:46%;writing-mode:vertical-rl;letter-spacing:.4em;
  font-size:11px;color:#9aa0c2;font-weight:600;display:flex;align-items:center;gap:14px;
}
.scroll-pill::after{content:"";width:1px;height:60px;background:#cfd2e9}

/* hero right — blob + pastel deco + gaming accents */
.hero-right{position:relative;height:680px;width:680px;margin-left:20px}

.pastel{position:absolute;border-radius:50%;pointer-events:none;background-size:cover;background-position:center}
.pastel.pink   {left:-30px;  top:-10px; width:220px;height:220px; background-image:url('../assets/deco_blur_pink.png')}
.pastel.yellow {right:60px;  top:-10px;  width:110px;height:110px; background:radial-gradient(circle at 35% 30%, #fff4a3 0%, #fde55c 80%)}
.pastel.mint   {left:-46px;  top:330px; width:80px; height:80px;  background:radial-gradient(circle at 30% 30%, #d8efe0 0%, #b9dfcb 90%)}
.pastel.lav    {left:-20px;  top:540px; width:110px;height:110px; background-image:url('../assets/deco_blur_lav.png')}
.pastel.lavbig {right:-10px; bottom:30px;width:220px;height:220px;background-image:url('../assets/deco_blur_blue.png')}
.pastel.blue   {right:230px; top:-10px; width:80px; height:80px;  background-image:url('../assets/deco_blur_blue.png')}
.pastel.tinyY  {right:-10px; top:230px; width:40px; height:40px;  background:#fde55c}

.blob-wrap{position:absolute;left:-10px;top:30px;width:620px;height:480px;z-index:2;animation:blobFloat 7s ease-in-out infinite}
.hero-right:hover .blob-wrap{animation-duration:3.5s}
@keyframes blobFloat{0%,100%{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-12px) rotate(1deg)}}
.blob-wrap svg.blob{position:absolute;inset:0;width:100%;height:100%;filter:drop-shadow(0 30px 60px rgba(60,40,140,.18))}
.blob-clipped{position:absolute;inset:0;overflow:hidden;clip-path:url(#blobClip)}
.scene{
  position:absolute;inset:0;
  background-image:url('../assets/streamer_photo.jpg');
  background-size:cover;background-position:center;
}
.scene .silhouette,.scene .crt-glow,.scene .photo-tag{display:none}

/* gaming HUD on top of blob */
.hud{position:absolute;inset:0;pointer-events:none}
.hud .live-chip{
  position:absolute;left:50%;top:20px;transform:translateX(-50%);
  background:rgba(20,12,32,.85);color:#fff;border-radius:10px;
  padding:6px 12px;display:flex;align-items:center;gap:8px;font-size:11px;font-weight:600;
  box-shadow:0 8px 20px -6px rgba(0,0,0,.4),inset 0 0 0 1px rgba(255,255,255,.08);
}
.hud .live-chip .live{background:#ef4444;color:#fff;font-weight:800;font-size:10px;padding:2px 6px;border-radius:4px;letter-spacing:.06em}
.hud .hpbar{position:absolute;left:24px;bottom:80px;width:200px;color:#fff;font-family:"Press Start 2P",monospace;font-size:8px}
.hud .hpbar .row{display:flex;justify-content:space-between;margin-bottom:4px;text-shadow:0 1px 0 #000}
.hud .hpbar .bar{height:8px;background:rgba(0,0,0,.5);border:1.5px solid #fff;border-radius:3px;overflow:hidden;box-shadow:0 0 0 1px rgba(0,0,0,.3)}
.hud .hpbar .bar i{display:block;height:100%;width:78%;background:linear-gradient(90deg,#22c55e,#84cc16)}
.hud .hpbar.mp .bar i{background:linear-gradient(90deg,#3b6df8,#5a8bff);width:54%}
.hud .hpbar.mp{bottom:54px}
.hud .combo{
  position:absolute;right:20px;top:60px;color:#facc15;font-family:"Press Start 2P",monospace;font-size:10px;
  text-shadow:0 2px 0 #b8770e, 0 4px 6px rgba(0,0,0,.5);transform:rotate(-6deg);
}
.hud .combo b{font-size:18px;color:#fff;text-shadow:0 2px 0 #b8770e}

/* floating gaming UI cards */
.chat-card,.follower-card,.levelup,.score-card,.coin-card{
  position:absolute;background:#fff;border-radius:18px;
  box-shadow:0 18px 40px -16px rgba(60,40,140,.3), inset 0 0 0 1px #efeafa;
  padding:12px 14px;z-index:5;
}
.chat-card{right:24px;top:60px;width:188px;padding:12px 12px 10px;z-index:5}
.chat-card .head{display:flex;align-items:center;justify-content:space-between;font-size:11px;color:#9b5cf6;font-weight:800;letter-spacing:.06em;margin-bottom:8px}
.chat-card .dots{display:flex;gap:4px}
.chat-card .dots i{width:6px;height:6px;border-radius:50%;background:#cfc0fb;display:block}
.chat-card .feed{height:148px;overflow:hidden;position:relative;-webkit-mask-image:linear-gradient(180deg,transparent 0,#000 14%,#000 86%,transparent 100%);mask-image:linear-gradient(180deg,transparent 0,#000 14%,#000 86%,transparent 100%)}
.chat-card .feed-track{display:flex;flex-direction:column;gap:5px;animation:chatScroll 22s linear infinite}
.hero-right:hover .chat-card .feed-track{animation-duration:11s}
.chat-card .msg{background:#f6f4ff;border-radius:10px;padding:7px 10px;font-size:11.5px;color:#3b3f5f;font-weight:600;flex:none;display:flex;align-items:center;gap:6px}
.chat-card .msg .avatar{width:14px;height:14px;border-radius:50%;background:linear-gradient(135deg,#fcd6c1,#e5b8a0);flex:none}
.chat-card .msg.u2 .avatar{background:linear-gradient(135deg,#c8b1e6,#a78bd6)}
.chat-card .msg.u3 .avatar{background:linear-gradient(135deg,#b8d4f5,#7da9e6)}
.chat-card .msg.u4 .avatar{background:linear-gradient(135deg,#ffd99b,#f5a623)}
.chat-card .msg.u5 .avatar{background:linear-gradient(135deg,#f9c7b4,#e29d80)}
@keyframes chatScroll{0%{transform:translateY(0)}100%{transform:translateY(-50%)}}
.chat-card .heart{
  position:absolute;right:-10px;bottom:-10px;width:36px;height:36px;border-radius:50%;
  background:linear-gradient(135deg,#ec4899,#f472b6);display:grid;place-items:center;color:#fff;
  box-shadow:0 10px 20px -6px rgba(236,72,153,.5);transform:rotate(-6deg);
}

.follower-card{right:-30px;top:400px;width:188px;transform:rotate(2deg)}
.follower-card .row{display:flex;align-items:center;gap:10px}
.follower-card .flame{width:34px;height:34px;border-radius:8px;background:linear-gradient(135deg,#f472b6,#9b5cf6);display:grid;place-items:center;color:#fff;font-size:16px}
.follower-card .lbl{font-size:9px;color:#9b5cf6;font-weight:800;letter-spacing:.1em}
.follower-card .num{font-weight:900;color:var(--ink);font-size:18px;line-height:1;margin-top:2px}
.follower-card .avs{display:flex;margin-top:8px}
.follower-card .avs i{
  width:22px;height:22px;border-radius:50%;display:block;margin-left:-5px;border:2px solid #fff;
  background:linear-gradient(135deg,#fcd6c1,#e5b8a0);
}
.follower-card .avs i:nth-child(2){background:linear-gradient(135deg,#c8b1e6,#a78bd6)}
.follower-card .avs i:nth-child(3){background:linear-gradient(135deg,#f9c7b4,#e29d80)}
.follower-card .avs i:nth-child(4){background:linear-gradient(135deg,#ffd99b,#f5a623)}
.follower-card .avs i:nth-child(5){background:linear-gradient(135deg,#b8d4f5,#7da9e6)}
.follower-card .avs i:nth-child(1){margin-left:0}

/* yellow sticker */
.sticker{
  position:absolute;right:0px;bottom:24px;width:128px;height:128px;border-radius:50%;
  background:radial-gradient(circle at 30% 28%, #fff7a1 0%, #fde55c 80%, #f6c800 100%);
  box-shadow:0 18px 30px -10px rgba(240,200,0,.55), 26px 14px 0 -20px #d2c8f6, -18px -8px 0 -16px #f9b7c5;
  display:grid;place-items:center;transform:rotate(-8deg);z-index:6;
}
.sticker .txt{
  font-family:"Caveat",cursive;color:#c2185b;font-weight:700;font-size:20px;line-height:1.05;text-align:center;
  text-shadow:0 1px 0 rgba(255,255,255,.6);
}
.sticker .txt b{font-size:28px;font-weight:700;display:block;letter-spacing:-.02em}
.sticker .underline{display:inline-block;border-bottom:2px wavy #c2185b;padding-bottom:1px}

/* decorative sparkles & squiggles */
.deco{position:absolute;pointer-events:none;z-index:7}
.deco.spark1{right:50px;top:30px;width:42px;height:42px}
.deco.spark2{right:30px;bottom:0;width:56px;height:56px}
.deco.spark3{left:0;top:200px;width:48px;height:48px}
.deco.chat-bubble{position:absolute;right:-20px;top:90px;width:70px;height:auto;z-index:7;filter:drop-shadow(0 8px 14px rgba(155,92,246,.35))}
.hero-right img.deco{display:block;height:auto}
.deco.heart-sq{left:30px;top:60px;width:60px;height:30px}
.deco.squig{left:80px;top:50px;width:54px;height:18px}
.deco.gamepad-3d{
  position:absolute;left:-70px;bottom:150px;width:200px;transform:rotate(-15deg);
  filter:drop-shadow(0 22px 32px rgba(123,86,247,.4));z-index:6;height:auto;
}
.deco.coin-sticker{position:absolute;right:-10px;top:540px;width:64px;transform:rotate(-12deg);z-index:6;filter:drop-shadow(0 8px 14px rgba(236,72,153,.5));height:auto}

.frame-ring{position:absolute;left:30px;top:0;width:580px;height:620px;pointer-events:none;z-index:3;opacity:.95}
.frame-ring.b{transform:rotate(-12deg) scale(1.05);top:20px;left:50px}

.swirl{position:absolute;inset:0;pointer-events:none;z-index:1;mix-blend-mode:multiply}

/* ---------- 02 SERVICE ---------- */
.service-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:46px;padding-top:12px;align-items:start}
.svc-card{
  position:relative;display:block;
  background:rgba(255,255,255,.78);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border-radius:24px;padding:36px 20px 26px;text-align:center;
  box-shadow:0 20px 44px -28px rgba(60,40,140,.25), inset 0 0 0 1px rgba(255,255,255,.8);
  transition:transform .35s cubic-bezier(.2,.7,.2,1), box-shadow .35s ease;
  color:inherit;
}
.svc-card::before{
  content:"";position:absolute;inset:0;border-radius:inherit;padding:1.5px;
  background:linear-gradient(135deg, rgba(91,139,255,.5), rgba(155,92,246,.5) 50%, rgba(236,72,153,.5));
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  opacity:.35;transition:opacity .35s ease;pointer-events:none;
}
.svc-card::after{
  content:"";position:absolute;left:50%;top:0;width:160%;height:60%;transform:translateX(-50%);
  background:radial-gradient(ellipse 50% 50% at 50% 50%, rgba(155,92,246,.16), transparent 70%);
  pointer-events:none;opacity:0;transition:opacity .35s ease;border-radius:inherit;
}
.svc-card:hover{transform:translateY(-4px);box-shadow:0 28px 48px -24px rgba(60,40,140,.32)}
.svc-card:hover::before{opacity:.9}
.svc-card:hover::after{opacity:1}
.service-grid .svc-card:nth-child(odd){margin-top:-18px}
.svc-num{
  position:absolute;top:14px;right:18px;font-family:"Bebas Neue",sans-serif;font-size:30px;line-height:1;
  color:#e7d6fb;font-weight:400;letter-spacing:.02em;z-index:1;
}
.svc-icon{
  width:80px;height:80px;margin:4px auto 12px;position:relative;display:grid;place-items:center;
  animation:iconBob 5s ease-in-out infinite;
}
.svc-icon .ring{position:absolute;inset:0;border-radius:50%;
  background:conic-gradient(from 0deg, #5a8bff, #9b5cf6 33%, #ec4899 66%, #5a8bff 100%);
  -webkit-mask:radial-gradient(circle, transparent 60%, #000 62%);
  mask:radial-gradient(circle, transparent 60%, #000 62%);
  opacity:.2;animation:spinSlow 14s linear infinite;
}
.svc-icon .glow{
  position:absolute;inset:14px;border-radius:50%;
  background:radial-gradient(circle at 35% 30%, #fff, #efe7ff 70%, #d2c2fb);
  box-shadow:inset 0 -10px 18px rgba(155,92,246,.2), 0 16px 30px -10px rgba(155,92,246,.35);
}
.svc-card.s1 .svc-icon .glow{background:radial-gradient(circle at 35% 30%, #fff, #e3edff 70%, #a8c5f9);box-shadow:inset 0 -10px 18px rgba(91,130,255,.2), 0 16px 30px -10px rgba(91,130,255,.4)}
.svc-card.s2 .svc-icon .glow{background:radial-gradient(circle at 35% 30%, #fff, #efe7ff 70%, #c5a3f5);box-shadow:inset 0 -10px 18px rgba(155,92,246,.2), 0 16px 30px -10px rgba(155,92,246,.4)}
.svc-card.s3 .svc-icon .glow{background:radial-gradient(circle at 35% 30%, #fff, #ffe3ef 70%, #f9a8c8);box-shadow:inset 0 -10px 18px rgba(236,72,153,.2), 0 16px 30px -10px rgba(236,72,153,.4)}
.svc-card.s4 .svc-icon .glow{background:radial-gradient(circle at 35% 30%, #fff, #fff4d6 70%, #fcd99c);box-shadow:inset 0 -10px 18px rgba(245,158,11,.2), 0 16px 30px -10px rgba(245,158,11,.4)}
.svc-icon svg{position:relative;z-index:2;width:42px;height:42px;filter:drop-shadow(0 4px 6px rgba(60,40,140,.25))}
.svc-card h3{font-size:21px;font-weight:900;color:#11142d;margin:6px 0 8px;letter-spacing:-.005em;position:relative;z-index:1}
.svc-card p{font-size:15px;line-height:1.7;color:#5a5f7a;margin:0;position:relative;z-index:1;font-weight:500}
.svc-card .pill-en{
  position:absolute;left:50%;top:-14px;transform:translateX(-50%);
  background:#fff;color:#9b5cf6;font-family:"Bebas Neue",sans-serif;letter-spacing:.18em;font-size:13px;
  padding:6px 14px;border-radius:999px;z-index:2;white-space:nowrap;
  box-shadow:0 6px 14px -4px rgba(155,92,246,.4), inset 0 0 0 1.5px #efe7fa;
}
@keyframes iconBob{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
@keyframes spinSlow{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}

/* ---------- 03 SUPPORT ---------- */
.support-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin-top:28px;align-items:stretch}
.sup-card{
  position:relative;display:flex;flex-direction:column;
  background:rgba(255,255,255,.86);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-radius:18px;overflow:hidden;color:inherit;
  box-shadow:0 20px 44px -28px rgba(60,40,140,.28), inset 0 0 0 1px rgba(255,255,255,.8);
  transition:transform .35s cubic-bezier(.2,.7,.2,1), box-shadow .35s ease;
}
.sup-card::before{
  content:"";position:absolute;inset:0;border-radius:inherit;padding:1.5px;
  background:linear-gradient(135deg, rgba(91,139,255,.5), rgba(155,92,246,.5) 50%, rgba(236,72,153,.5));
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  opacity:.35;transition:opacity .35s ease;pointer-events:none;z-index:4;
}
.sup-card::after{
  content:"";position:absolute;left:50%;top:0;width:160%;height:60%;transform:translateX(-50%);
  background:radial-gradient(ellipse 50% 50% at 50% 50%, rgba(155,92,246,.18), transparent 70%);
  pointer-events:none;opacity:0;transition:opacity .35s ease;border-radius:inherit;z-index:3;
  mix-blend-mode:soft-light;
}
.sup-card:hover{transform:translateY(-4px);box-shadow:0 28px 48px -24px rgba(60,40,140,.36)}
.sup-card:hover::before{opacity:.9}
.sup-card:hover::after{opacity:1}
.sup-card .scene{
  position:relative;aspect-ratio:5/4;flex:none;overflow:hidden;
  background:linear-gradient(135deg,#1f2547,#3e2557 50%,#4a2a5e);
}
.sup-card .scene::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(circle at 30% 30%, rgba(91,130,255,.55), transparent 55%),
    radial-gradient(circle at 70% 70%, rgba(236,72,153,.45), transparent 55%);
  mix-blend-mode:screen;
}
.sup-card .scene::after{
  content:"";position:absolute;inset:0;
  background:repeating-linear-gradient(0deg, rgba(255,255,255,.04) 0 1px, transparent 1px 28px),
             repeating-linear-gradient(90deg, rgba(255,255,255,.04) 0 1px, transparent 1px 28px);
}
.sup-card .scene .ico{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:62px;height:62px;
  border-radius:50%;background:radial-gradient(circle at 35% 30%, #fff, rgba(255,255,255,.85) 60%, rgba(255,255,255,.6));
  box-shadow:0 16px 32px -8px rgba(0,0,0,.4);display:grid;place-items:center;z-index:2;
  animation:iconBob 6s ease-in-out infinite;
}
.sup-card .scene .ico svg{width:34px;height:34px;filter:drop-shadow(0 3px 5px rgba(60,40,140,.3))}
.sup-card .scene .step-badge{
  position:absolute;left:10px;top:10px;font-family:"Bebas Neue",sans-serif;letter-spacing:.18em;font-size:13px;
  color:#fff;padding:5px 10px;border-radius:6px;z-index:3;
  background:rgba(255,255,255,.18);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.25);
}
.sup-card .body{padding:26px 22px 24px;flex:1;display:flex;flex-direction:column}
.sup-card .step-tag{
  align-self:flex-start;font-family:"Bebas Neue",sans-serif;letter-spacing:.22em;font-size:12px;
  color:#fff;padding:4px 10px 3px;border-radius:4px;margin-bottom:14px;
  background:linear-gradient(135deg,#9b5cf6,#ec4899);
}
.sup-card .eyebrow{font-family:"Bebas Neue",sans-serif;font-size:13px;color:#9b5cf6;font-weight:700;letter-spacing:.2em}
.sup-card h4{font-size:19px;font-weight:900;color:#11142d;margin:5px 0 10px;letter-spacing:-.005em;line-height:1.35}
.sup-card p{font-size:14.5px;line-height:1.75;color:#5a5f7a;margin:0;font-weight:500;white-space:pre-line}

/* ---------- 04 RESULTS ---------- */
.results-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:28px;align-items:stretch}
.res-card{
  position:relative;background:rgba(255,255,255,.82);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border-radius:20px;padding:24px 18px 22px;text-align:center;overflow:hidden;
  box-shadow:0 20px 44px -28px rgba(60,40,140,.28), inset 0 0 0 1px rgba(255,255,255,.8);
  transition:transform .35s cubic-bezier(.2,.7,.2,1), box-shadow .35s ease;display:flex;flex-direction:column;align-items:center;gap:4px;
}
.res-card:hover{transform:translateY(-10px);box-shadow:0 36px 60px -28px rgba(60,40,140,.4)}
.res-card:hover::before{opacity:1}
.res-card:hover::after{opacity:.9}
.res-card::after{
  content:"";position:absolute;inset:0;border-radius:inherit;padding:1.5px;
  background:linear-gradient(135deg, rgba(91,139,255,.55), rgba(155,92,246,.55) 50%, rgba(236,72,153,.55));
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  opacity:.35;transition:opacity .35s ease;pointer-events:none;z-index:3;
}
.res-card::before{
  content:"";position:absolute;left:50%;top:-50%;width:140%;height:120%;transform:translateX(-50%);
  background:radial-gradient(circle at 50% 50%, rgba(155,92,246,.18), transparent 65%);
  pointer-events:none;z-index:0;opacity:.7;transition:opacity .35s ease;
}
.res-card > *{position:relative;z-index:1}
.res-card .lbl{font-size:14px;color:#54597a;font-weight:700;letter-spacing:.04em;line-height:1.4}
.res-card .num-row{display:flex;align-items:baseline;justify-content:center;gap:5px;margin:10px 0 8px}
.res-card .num{
  font-family:"Bebas Neue",sans-serif;font-size:82px;letter-spacing:-.01em;line-height:1;
  background:linear-gradient(180deg,#5a8bff 0%,#3b6df8 50%,#7c4dff 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.res-card.r2 .num{background:linear-gradient(180deg,#a78bfa,#7c4dff);-webkit-background-clip:text;background-clip:text;color:transparent}
.res-card.r3 .num{background:linear-gradient(180deg,#c084fc,#9b5cf6 50%,#ec4899);-webkit-background-clip:text;background-clip:text;color:transparent}
.res-card.r4 .num{background:linear-gradient(180deg,#ec4899,#f472b6 50%,#fb7185);-webkit-background-clip:text;background-clip:text;color:transparent}
.res-card .unit{font-family:"Noto Sans JP",sans-serif;font-size:19px;font-weight:900;color:#3b3f5f;line-height:1}
.res-card .suf{font-size:13px;color:#9b5cf6;font-weight:800;letter-spacing:.08em}
.res-card .badge-suf{
  display:inline-block;padding:5px 14px;border-radius:999px;font-size:13px;font-weight:800;letter-spacing:.08em;
  background:linear-gradient(90deg,#fff7d4,#fde55c);color:#a86b00;
  box-shadow:0 6px 12px -4px rgba(250,200,21,.3), inset 0 0 0 1px #fbe78a;
}
.res-card .glyph{height:24px;margin-top:auto;padding-top:10px}
.res-card .corner-spark{position:absolute;top:12px;right:12px;width:18px;height:18px;animation:sparkBlink 2.6s ease-in-out infinite;z-index:2}
@keyframes sparkBlink{0%,100%{opacity:.4;transform:scale(.9)}50%{opacity:1;transform:scale(1.1)}}

/* ---------- 04 RESULTS - No.1 trophy ribbon (now in sec-head right) ---------- */
.no1{
  position:relative;border-radius:22px;padding:18px 26px 18px 100px;overflow:hidden;
  background:linear-gradient(160deg,#fff 0%, #fff5fb 100%);
  box-shadow:0 18px 38px -22px rgba(60,40,140,.32), inset 0 0 0 1px rgba(255,255,255,.85);
  display:inline-grid;grid-template-columns:auto auto;gap:6px 20px;align-items:center;justify-self:end;
  transform:rotate(-1.5deg);
}
.no1::before{
  /* trophy icon left */
  content:"";position:absolute;left:20px;top:50%;transform:translateY(-50%);
  width:64px;height:64px;border-radius:50%;
  background:radial-gradient(circle at 35% 30%, #fff7d4 0%, #fde55c 60%, #f6c800 100%);
  box-shadow:0 12px 24px -6px rgba(240,200,21,.6), inset 0 -8px 14px rgba(170,120,0,.28);
}
.no1::after{
  content:"🏆";position:absolute;left:20px;top:50%;transform:translate(0,-50%);
  width:64px;height:64px;display:grid;place-items:center;font-size:34px;
}
.no1 .ribbon-bg{
  position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  background:
    radial-gradient(circle at 20% 100%, rgba(236,72,153,.14), transparent 50%),
    radial-gradient(circle at 80% 0%, rgba(250,204,21,.14), transparent 50%);
}
.no1 > *{position:relative;z-index:1}
.no1 .no1-meta{display:flex;flex-direction:column;gap:3px;text-align:left}
.no1 .no1-eyebrow{font-size:12px;color:#9b5cf6;font-weight:800;letter-spacing:.22em;font-family:"Bebas Neue",sans-serif}
.no1 .no1-title{font-size:14.5px;color:#3b3f5f;font-weight:800;line-height:1.5;letter-spacing:-.005em}
.no1 .no1-num{
  font-family:"Bebas Neue",sans-serif;line-height:.85;letter-spacing:-.02em;
  display:flex;align-items:flex-end;
  background:linear-gradient(180deg,#facc15,#ec4899 60%,#9b5cf6);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  filter:drop-shadow(0 5px 12px rgba(236,72,153,.26));
}
.no1 .no1-num .no{font-size:34px;letter-spacing:.02em;margin-right:3px;align-self:flex-start;line-height:1}
.no1 .no1-num .one{font-size:80px;line-height:.85}
.no1 .no1-foot{grid-column:1 / -1;font-size:9.5px;color:#8a90ab;font-weight:600;letter-spacing:.02em;margin-top:6px;max-width:440px}

/* ---------- 05 FLOW ---------- */
.flow-wrap{position:relative;margin-top:30px}
.flow-grid{display:grid;grid-template-columns:repeat(5, 1fr);gap:14px;align-items:stretch}
.flow-card{
  position:relative;
  background:rgba(255,255,255,.85);backdrop-filter:blur(14px);
  border-radius:18px;padding:22px 16px 22px;text-align:center;overflow:hidden;
  box-shadow:0 20px 44px -28px rgba(60,40,140,.28), inset 0 0 0 1px rgba(255,255,255,.8);
  transition:transform .35s cubic-bezier(.2,.7,.2,1), box-shadow .35s ease;
}
.flow-card::before{
  content:"";position:absolute;inset:0;border-radius:inherit;padding:1.5px;
  background:linear-gradient(135deg, rgba(91,139,255,.5), rgba(155,92,246,.5) 50%, rgba(236,72,153,.5));
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  opacity:.35;transition:opacity .35s ease;pointer-events:none;z-index:3;
}
.flow-card::after{
  content:"";position:absolute;left:50%;top:0;width:160%;height:60%;transform:translateX(-50%);
  background:radial-gradient(ellipse 50% 50% at 50% 50%, rgba(155,92,246,.16), transparent 70%);
  pointer-events:none;opacity:0;transition:opacity .35s ease;border-radius:inherit;z-index:2;
}
.flow-card:hover{transform:translateY(-10px);box-shadow:0 36px 60px -28px rgba(60,40,140,.4)}
.flow-card:hover::before{opacity:.9}
.flow-card:hover::after{opacity:1}
.flow-card > *{position:relative;z-index:4}
.flow-card .step{
  font-family:"Bebas Neue",sans-serif;font-size:34px;line-height:1;
  background:linear-gradient(180deg,#5a8bff 0%,#9b5cf6 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;letter-spacing:.02em;
}
.flow-card .ico{height:58px;display:grid;place-items:center;margin:8px 0 4px}
.flow-card .ico .pill{
  width:50px;height:50px;border-radius:14px;display:grid;place-items:center;color:#fff;
  background:linear-gradient(135deg,#9b5cf6,#7c4dff);
  box-shadow:0 12px 22px -6px rgba(123,86,247,.5);
  animation:iconBob 5s ease-in-out infinite;
}
.flow-card .ico .pill svg{width:26px;height:26px}
.flow-card h4{font-size:17px;font-weight:900;color:#11142d;margin:10px 0 8px;letter-spacing:-.005em;line-height:1.35}
.flow-card p{font-size:14.5px;line-height:1.7;color:#5a5f7a;margin:0;font-weight:500;white-space:pre-line}
.flow-arrow{
  position:absolute;top:48px;right:-16px;width:26px;height:26px;border-radius:50%;
  background:linear-gradient(135deg,#5a8bff,#9b5cf6);color:#fff;display:grid;place-items:center;
  box-shadow:0 8px 14px -4px rgba(123,86,247,.5);
  font-size:12px;font-weight:700;
}

/* 5th flow card — turns into a CTA */
.flow-card.is-cta{
  background:linear-gradient(160deg, #ffeaf3 0%, #f3e7ff 60%, #e6efff 100%);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;cursor:pointer;color:inherit;
  border:1.5px dashed rgba(155,92,246,.35);
  position:relative;
}
.flow-card.is-cta::after{
  content:"";position:absolute;left:50%;top:50%;width:140%;height:140%;transform:translate(-50%,-50%);
  background:radial-gradient(ellipse 50% 50% at 50% 50%, rgba(236,72,153,.18), transparent 60%);
  z-index:0;pointer-events:none;
}
.flow-card.is-cta > *{position:relative;z-index:1}
.flow-card.is-cta .star{
  font-size:24px;line-height:1;margin-bottom:4px;animation:floatY 4s ease-in-out infinite;
}
.flow-card.is-cta h4{
  font-size:18px;font-weight:900;color:#11142d;margin:5px 0 10px;line-height:1.35;letter-spacing:-.005em;
}
.flow-card.is-cta h4 b{
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;
}
.flow-card.is-cta .btn{
  display:inline-flex;align-items:center;gap:6px;padding:11px 20px;border-radius:999px;
  background:linear-gradient(90deg,#3b6df8,#9b5cf6 55%,#ec4899);color:#fff;font-weight:900;font-size:13px;
  box-shadow:0 12px 20px -8px rgba(123,86,247,.5), inset 0 0 0 1px rgba(255,255,255,.3);
  white-space:nowrap;
}
.flow-card.is-cta .btn .arr{transition:transform .2s}
.flow-card.is-cta:hover .btn .arr{transform:translateX(3px)}
.flow-card.is-cta .sub{font-size:11px;color:#7d83a3;margin-top:8px;font-weight:600;letter-spacing:.02em}

/* ---------- 05 FLOW timeline (yuijp-inspired vertical) ---------- */
.flow-timeline{position:relative;margin-top:30px;padding:0 4px}
.flow-tl-item{
  position:relative;display:grid;
  grid-template-columns:38px 1fr 100px;
  gap:32px;align-items:center;
  padding:14px 4px;
  border-bottom:1px dashed rgba(60,40,140,.14);
  color:inherit;text-decoration:none;
}
.flow-tl-item:last-child{border-bottom:0}
.flow-tl-item .tl-left{
  position:relative;display:flex;justify-content:center;align-items:center;
  align-self:stretch;
}
/* connector line: from this dot down through to next dot */
.flow-tl-item:not(:last-child) .tl-left::after{
  content:"";position:absolute;left:50%;top:calc(50% + 14px);bottom:-18px;width:2px;
  background:linear-gradient(180deg,#5a8bff 0%,#9b5cf6 50%,#ec4899 100%);
  transform:translateX(-50%);opacity:.55;
}
.flow-tl-item .tl-left .dot{
  width:18px;height:18px;border-radius:50%;
  background:linear-gradient(135deg,#9b5cf6,#ec4899);
  box-shadow:0 0 0 3px #fff, 0 6px 14px -4px rgba(155,92,246,.45);
  position:relative;z-index:2;
}
.flow-tl-item .tl-mid{padding:2px 0}
.flow-tl-item .tl-mid .step-label{
  display:inline-block;font-family:"Bebas Neue",sans-serif;letter-spacing:.22em;
  font-size:20px;color:#9b5cf6;font-weight:700;margin-bottom:2px;line-height:1;
}
.flow-tl-item .tl-mid h4{
  font-size:22px;font-weight:900;color:#11142d;
  margin:4px 0 4px;letter-spacing:-.01em;line-height:1.3;
}
.flow-tl-item .tl-mid p{
  font-size:14.5px;line-height:1.7;color:#54597a;margin:0;font-weight:500;max-width:560px;
}
.flow-tl-item .tl-right{
  align-self:center;justify-self:end;display:flex;align-items:center;
}
.flow-tl-item .tl-right .ico .pill{
  width:80px;height:80px;border-radius:50%;
  background:linear-gradient(135deg,#5a8bff,#9b5cf6);
  display:grid;place-items:center;
  box-shadow:0 16px 30px -10px rgba(123,86,247,.5);
}
.flow-tl-item .tl-right .ico .pill svg{width:40px;height:40px}
/* NEXT (CTA) variant — aligned with other rows, just content-differentiated */
.flow-tl-item.is-cta{
  padding:14px 4px;margin-top:4px;
  background:linear-gradient(90deg,transparent 0%,rgba(243,233,255,.5) 22%,rgba(255,224,239,.5) 78%,transparent 100%);
  border-radius:0;border:0;
  transition:filter .25s ease;
}
.flow-tl-item.is-cta:hover{filter:brightness(1.04)}
.flow-tl-item.is-cta .tl-left .dot{background:linear-gradient(135deg,#ec4899,#facc15)}
/* CTA gets a wider right column for the big button */
.flow-tl-item.is-cta{grid-template-columns:38px 1fr 248px}
.flow-tl-item.is-cta .tl-right .btn{
  display:inline-flex;align-items:center;gap:12px;
  padding:22px 30px;border-radius:999px;
  color:#fff;font-weight:800;font-size:18px;letter-spacing:.02em;white-space:nowrap;
  background:linear-gradient(90deg,#3b6df8 0%,#9b5cf6 50%,#ec4899 100%);
  box-shadow:0 24px 44px -12px rgba(155,92,246,.55), inset 0 0 0 1px rgba(255,255,255,.28);
  transition:transform .25s ease, box-shadow .25s ease;
}
.flow-tl-item.is-cta .tl-right .btn .arr{font-size:22px;transition:transform .2s}
.flow-tl-item.is-cta:hover .tl-right .btn{transform:translateY(-2px);box-shadow:0 28px 50px -12px rgba(155,92,246,.65)}
.flow-tl-item.is-cta:hover .tl-right .btn .arr{transform:translateX(4px)}
.flow-tl-item.is-cta .tl-mid .step-label{color:#ec4899}
.flow-tl-item.is-cta .tl-mid h4 b{
  background:linear-gradient(90deg,#3b6df8,#9b5cf6 55%,#ec4899);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  margin-right:8px;
}
.flow-tl-item.is-cta .tl-mid .btn{
  display:inline-flex;align-items:center;gap:10px;margin-top:12px;
  padding:12px 24px;border-radius:999px;color:#fff;font-weight:800;font-size:15px;
  background:linear-gradient(90deg,#3b6df8 0%,#9b5cf6 50%,#ec4899 100%);
  box-shadow:0 14px 28px -10px rgba(155,92,246,.55);
}
.flow-tl-item.is-cta .tl-mid .btn .arr{transition:transform .2s}
.flow-tl-item.is-cta:hover .tl-mid .btn .arr{transform:translateX(3px)}
.flow-tl-item.is-cta .tl-mid .sub{
  display:block;margin-top:8px;font-size:12px;color:#9b5cf6;font-weight:600;letter-spacing:.02em;
}

/* ---------- 06 FAQ ---------- */
.faq-grid{display:grid;grid-template-columns:1fr 220px;gap:50px;align-items:start;margin-top:28px}
.faq-list{display:flex;flex-direction:column;gap:10px}
.faq-item{
  background:rgba(255,255,255,.85);backdrop-filter:blur(14px);border-radius:14px;padding:0;
  box-shadow:0 12px 28px -20px rgba(60,40,140,.28), inset 0 0 0 1px rgba(255,255,255,.8);
  transition:box-shadow .25s ease, transform .25s ease;
  overflow:hidden;
}
.faq-item:hover{transform:translateY(-2px);box-shadow:0 16px 32px -18px rgba(60,40,140,.4)}
.faq-item summary{
  list-style:none;cursor:pointer;padding:14px 18px;
  display:flex;align-items:center;justify-content:space-between;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item .left{display:flex;align-items:center;gap:12px}
.faq-item .q{
  width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,#5a8bff,#9b5cf6 60%,#ec4899);
  color:#fff;display:grid;place-items:center;font-weight:900;font-size:14px;font-family:"Bebas Neue",sans-serif;
  flex:none;letter-spacing:.04em;box-shadow:0 6px 12px -3px rgba(155,92,246,.45);
}
.faq-item .label{font-size:17px;font-weight:700;color:#11142d}
.faq-item .plus{font-size:24px;color:#9b5cf6;font-weight:300;transition:transform .35s cubic-bezier(.2,.7,.2,1);flex:none;margin-left:14px;display:grid;place-items:center;width:24px;height:24px}
.faq-item[open] .plus{transform:rotate(45deg)}
.faq-item .answer{padding:0 20px 22px 64px;font-size:15px;line-height:1.85;color:#3b3f5f;font-weight:500}
/* smooth accordion: animate block-size via ::details-content (Chromium/modern) */
:root{interpolate-size:allow-keywords}
.faq-item::details-content{
  block-size:0;overflow:clip;opacity:.0;
  transition:
    block-size .45s cubic-bezier(.22,.7,.18,1),
    opacity .35s ease,
    content-visibility .45s allow-discrete;
}
.faq-item[open]::details-content{
  block-size:auto;opacity:1;
}
.faq-q-glow{
  position:relative;display:grid;place-items:center;
  width:230px;height:260px;justify-self:end;
  animation:faqFloat 5s ease-in-out infinite;
}
.faq-q-glow img{width:100%;height:auto;display:block;filter:drop-shadow(0 24px 36px rgba(155,92,246,.45))}
@keyframes faqFloat{0%,100%{transform:translateY(0) rotate(-2deg)}50%{transform:translateY(-14px) rotate(2deg)}}

/* ---------- 07 CTA banner (shared between pages, content differs) ---------- */
.cta-banner{
  position:relative;max-width:1200px;margin:48px auto 60px;
  border-radius:48px 64px 56px 72px / 64px 56px 72px 48px;
  padding:50px 50px;overflow:hidden;
  background:linear-gradient(100deg,#3b6df8 0%,#7c4dff 35%,#c084fc 65%,#ec4899 100%);
  background-size:220% 220%;
  box-shadow:0 32px 64px -28px rgba(123,86,247,.55);
  animation:ctaMorph 14s ease-in-out infinite, ctaShift 18s ease-in-out infinite;
}
@keyframes ctaMorph{
  0%,100%{border-radius:48px 64px 56px 72px / 64px 56px 72px 48px}
  25%   {border-radius:72px 48px 64px 56px / 56px 72px 48px 64px}
  50%   {border-radius:64px 72px 48px 64px / 72px 48px 64px 56px}
  75%   {border-radius:56px 64px 72px 48px / 48px 64px 56px 72px}
}
@keyframes ctaShift{
  0%,100%{background-position:0% 50%}
  50%    {background-position:100% 50%}
}
@media (prefers-reduced-motion: reduce){
  .cta-banner{animation:none}
}
.cta-banner::before{
  content:"";position:absolute;inset:0;background:
    radial-gradient(ellipse 400px 240px at 20% 80%, rgba(255,255,255,.18), transparent 60%),
    radial-gradient(ellipse 600px 300px at 80% 20%, rgba(255,255,255,.18), transparent 60%);
  pointer-events:none;
}
.cta-banner::after{
  content:"";position:absolute;inset:0;pointer-events:none;border-radius:inherit;
  background:
    radial-gradient(circle at 20% 30%, rgba(255,255,255,.12) 0%, transparent 50%),
    radial-gradient(circle at 80% 70%, rgba(255,255,255,.10) 0%, transparent 55%);
  mix-blend-mode:overlay;animation:ctaShimmer 9s ease-in-out infinite;
}
@keyframes ctaShimmer{
  0%,100%{opacity:.7;transform:translate3d(0,0,0)}
  50%    {opacity:1;transform:translate3d(20px,-10px,0)}
}
/* floating decorative blobs inside CTA banner */
.cta-banner .cta-blob-a,
.cta-banner .cta-blob-b,
.cta-banner .cta-blob-c{
  position:absolute;border-radius:50%;pointer-events:none;
  filter:blur(40px);mix-blend-mode:screen;will-change:transform;
}
.cta-banner .cta-blob-a{
  left:-60px;top:30%;width:260px;height:260px;
  background:radial-gradient(circle at 30% 30%, rgba(255,200,230,.55), rgba(255,120,200,.25) 60%, transparent 80%);
  animation:ctaBlobA 11s ease-in-out infinite;
}
.cta-banner .cta-blob-b{
  right:8%;top:-40px;width:300px;height:300px;
  background:radial-gradient(circle at 30% 30%, rgba(200,220,255,.55), rgba(120,160,255,.25) 60%, transparent 80%);
  animation:ctaBlobB 13s ease-in-out infinite;
}
.cta-banner .cta-blob-c{
  right:20%;bottom:-50px;width:240px;height:240px;
  background:radial-gradient(circle at 30% 30%, rgba(230,200,255,.5), rgba(180,120,255,.25) 60%, transparent 80%);
  animation:ctaBlobC 15s ease-in-out infinite;
}
@keyframes ctaBlobA{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(40px,-20px) scale(1.1)}}
@keyframes ctaBlobB{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(-30px,30px) scale(.92)}}
@keyframes ctaBlobC{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(50px,-40px) scale(1.08)}}
@media (prefers-reduced-motion: reduce){
  .cta-banner .cta-blob-a,
  .cta-banner .cta-blob-b,
  .cta-banner .cta-blob-c{animation:none}
}
.cta-inner{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;text-align:center}
.cta-inner .ttl{
  font-size:50px;font-weight:900;color:#fff;text-align:center;line-height:1.1;letter-spacing:-.01em;
  text-shadow:0 5px 0 rgba(0,0,0,.06);white-space:nowrap;
}
.cta-inner .chip-row{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-top:16px}
.cta-inner .chip-w{
  background:rgba(255,255,255,.92);color:var(--ink);
  padding:7px 14px;border-radius:999px;font-size:13px;font-weight:700;display:inline-flex;gap:6px;align-items:center;
  box-shadow:0 6px 14px -6px rgba(0,0,0,.18);
}
.cta-inner .chip-w .dot{width:10px;height:10px;border-radius:50%}
.cta-inner .big-btn{
  margin:24px auto 0;display:flex;flex-direction:column;align-items:center;
  background:linear-gradient(90deg,#5a8bff,#9b5cf6 60%,#ec4899);
  padding:16px 48px 20px;border-radius:999px;color:#fff;font-weight:900;font-size:22px;
  box-shadow:0 16px 30px -12px rgba(0,0,0,.35), inset 0 0 0 1.5px rgba(255,255,255,.4);
  cursor:pointer;border:0;font-family:inherit;width:420px;max-width:100%;
}
.cta-inner .big-btn small{font-size:14px;font-weight:500;opacity:.9;margin-top:5px}
.cta-banner .sec07{
  position:absolute;left:30px;top:14px;font-family:"Bebas Neue",sans-serif;font-size:88px;
  color:rgba(255,255,255,.18);line-height:.8;letter-spacing:.02em;
}
.cta-inner .big-btn .arr{margin-left:10px}

.cta-pad{
  position:absolute;left:20px;bottom:10px;z-index:3;
  width:240px;height:auto;display:block;
  animation:ctaFloatA 6s ease-in-out infinite;
  filter:drop-shadow(0 24px 36px rgba(0,0,0,.45));
}
.cta-headset{
  position:absolute;right:24px;top:24px;z-index:3;
  width:160px;height:auto;display:block;
  animation:ctaFloatB 7s ease-in-out infinite;
  filter:drop-shadow(0 20px 34px rgba(0,0,0,.4));
}
@keyframes ctaFloatA{0%,100%{transform:translateY(0) rotate(-6deg)}50%{transform:translateY(-12px) rotate(-3deg)}}
@keyframes ctaFloatB{0%,100%{transform:translateY(0) rotate(6deg)}50%{transform:translateY(-14px) rotate(9deg)}}

/* CTA banner — company.html variant (centered text) */
.cta-banner.center{text-align:center;margin:32px auto 60px}
.cta-banner.center .inner{position:relative;z-index:2}
.cta-banner.center h2{color:#fff;font-size:38px;font-weight:900;margin:0;letter-spacing:-.01em;text-shadow:0 5px 0 rgba(0,0,0,.06)}
.cta-banner.center p{color:rgba(255,255,255,.85);margin:14px 0 24px;font-size:15px;line-height:1.9;font-weight:500}
.cta-banner.center .btn{display:inline-flex;align-items:center;gap:10px;background:linear-gradient(90deg,#5a8bff,#9b5cf6 60%,#ec4899);padding:16px 44px;border-radius:999px;color:#fff;font-weight:900;font-size:16px;box-shadow:0 16px 30px -12px rgba(0,0,0,.35), inset 0 0 0 1.5px rgba(255,255,255,.4);cursor:pointer;border:0;font-family:inherit}
.cta-banner.center .btn .arr{transition:transform .2s}
.cta-banner.center .btn:hover .arr{transform:translateX(3px)}

/* 公式LINE接続の控えめな注釈（あくまで気持ち程度に目立たせない） */
.line-note{display:block;font-size:10px;line-height:1.45;font-weight:500;letter-spacing:.02em;color:#8a90ab;opacity:.75;margin-top:8px;white-space:normal}
.line-note.on-dark{color:rgba(255,255,255,.72);opacity:1}
.hero-cta-wrap{flex-wrap:wrap}
.hero-cta-wrap .line-note{flex:0 0 100%;margin-top:0}
.cta-inner .line-note{text-align:center;margin-top:10px}

/* ---------- footer ---------- */
footer.site{
  max-width:none;padding:44px 48px 50px;margin:48px 0 0;
  position:relative;color:#fff;
  background:
    radial-gradient(ellipse 800px 400px at 10% -10%, rgba(91,139,255,.18), transparent 60%),
    radial-gradient(ellipse 700px 360px at 100% 0%, rgba(236,72,153,.16), transparent 60%),
    linear-gradient(180deg, #0c0f24 0%, #0a0d1f 100%);
}
footer.site::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(rgba(255,255,255,.03) 1px, transparent 1.5px);
  background-size:28px 28px;opacity:.6;
}
.footer-inner{
  position:relative;z-index:1;
  max-width:1280px;margin:0 auto;
  display:grid;grid-template-columns:240px 1fr;gap:32px;align-items:center;
}
footer.site .logo{display:flex;align-items:center;gap:14px}
footer.site .logo .mark{position:relative;width:48px;height:48px}
footer.site .logo .mark .hex{position:absolute;inset:0;filter:drop-shadow(0 6px 14px rgba(123,86,247,.5))}
footer.site .logo .word{display:flex;flex-direction:column;gap:4px;line-height:1}
footer.site .logo .word .name{display:inline-flex;align-items:center}
footer.site .logo .word .name svg{display:block}
footer.site .logo .word .tag{font-size:11px;letter-spacing:.32em;color:rgba(255,255,255,.55);font-weight:700;font-family:"Orbitron",sans-serif}
footer.site .logo img{height:40px}
footer.site .links{display:grid;grid-template-columns:repeat(3,1fr);gap:12px 20px;font-size:14px;color:rgba(255,255,255,.78)}
footer.site .links a{font-weight:600;transition:color .2s}
footer.site .links a:hover{color:#00e5ff}
footer.site .contact{display:flex;flex-direction:column;align-items:flex-end;gap:12px}
footer.site .contact-label{
  font-family:"Bebas Neue",sans-serif;font-size:14px;letter-spacing:.3em;
  color:rgba(255,255,255,.55);
}
footer.site .contact-mail{
  display:inline-flex;align-items:center;gap:12px;
  padding:14px 22px;border-radius:999px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.14);
  color:#fff;font-weight:600;font-size:14px;letter-spacing:.01em;
  transition:background .2s, border-color .2s, color .2s, transform .2s;
}
footer.site .contact-mail:hover{
  background:rgba(0,229,255,.12);
  border-color:rgba(0,229,255,.5);
  color:#00e5ff;
  transform:translateY(-2px);
}
footer.site .contact-mail svg{width:18px;height:18px;fill:currentColor;flex:none}

/* ---------- company.html page hero ---------- */
.page-hero{position:relative;max-width:1280px;margin:0 auto;padding:56px 52px 44px;overflow:hidden}
.page-hero .inner{position:relative;z-index:1;text-align:center}
.breadcrumb{font-size:13px;color:#8a90ab;font-weight:600;display:flex;justify-content:center;gap:10px;align-items:center;margin-bottom:14px}
.breadcrumb a:hover{color:var(--blue)}
.breadcrumb .sep{color:#cfd2e9}
.page-hero .eyebrow{font-family:"Bebas Neue",sans-serif;letter-spacing:.4em;font-size:16px;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.page-hero h1{margin:6px 0 0;font-size:50px;font-weight:900;letter-spacing:-.02em;color:#0c0f2c;line-height:1.05}
.page-hero h1 .accent{
  font-style:italic;
  background:linear-gradient(180deg,#9b5cf6 0%,#c084fc 50%,#ec4899 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.page-hero .sub{margin:20px auto 0;max-width:680px;font-size:16px;line-height:1.9;color:#54597a;font-weight:500}

/* ---------- company 01 message ---------- */
.message-wrap{display:grid;grid-template-columns:1fr 300px;gap:48px;align-items:start;margin-top:24px}
.message-wrap.solo{
  display:flex;justify-content:center;position:relative;margin-top:24px;
}
.message-card{
  background:#fff;border-radius:20px;padding:38px 40px;
  box-shadow:0 16px 36px -22px rgba(60,40,140,.2), inset 0 0 0 1px #eee7fa;
  position:relative;overflow:hidden;
  transition:transform .35s cubic-bezier(.2,.7,.2,1), box-shadow .35s ease;
}
.message-wrap.solo .message-card{
  max-width:780px;width:100%;padding:52px 56px;
  border-radius:26px;
  box-shadow:0 26px 52px -28px rgba(60,40,140,.3), inset 0 0 0 1px #eee7fa;
}
/* moved decorative blobs to real elements so ::before/::after can do hover */
.message-card .msg-blob{position:absolute;border-radius:50%;pointer-events:none}
.message-card .msg-blob.a{
  left:-30px;top:-30px;width:160px;height:160px;
  background:radial-gradient(circle at 30% 30%, #ffe3ef 0%, #f9a8c8 80%);opacity:.35;
}
.message-wrap.solo .message-card .msg-blob.a{
  width:240px;height:240px;left:-60px;top:-60px;opacity:.4;
}
.message-card .msg-blob.b{display:none}
.message-wrap.solo .message-card .msg-blob.b{
  display:block;right:-80px;bottom:-80px;width:280px;height:280px;
  background:radial-gradient(circle at 30% 30%, #e0e8ff 0%, #a8c5f9 80%);opacity:.35;
}
/* hover: foil edge + radial glow — matches SERVICE / VMV */
.message-card::before{
  content:"";position:absolute;inset:0;border-radius:inherit;padding:1.5px;
  background:linear-gradient(135deg, rgba(91,139,255,.5), rgba(155,92,246,.5) 50%, rgba(236,72,153,.5));
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  opacity:.35;transition:opacity .35s ease;pointer-events:none;z-index:3;
}
.message-card::after{
  content:"";position:absolute;left:50%;top:0;width:160%;height:60%;transform:translateX(-50%);
  background:radial-gradient(ellipse 50% 50% at 50% 50%, rgba(155,92,246,.16), transparent 70%);
  pointer-events:none;opacity:0;transition:opacity .35s ease;border-radius:inherit;z-index:2;
}
.message-card:hover{transform:translateY(-10px);box-shadow:0 36px 60px -28px rgba(60,40,140,.4)}
.message-card:hover::before{opacity:.9}
.message-card:hover::after{opacity:1}
.message-card > *{position:relative;z-index:4}
.message-card .quote{font-family:"Bebas Neue",sans-serif;font-size:64px;line-height:.6;color:#e7d6fb;position:absolute;top:24px;right:28px}
.message-wrap.solo .message-card .quote{font-size:110px;top:24px;right:38px;opacity:.7}
.message-card h3{font-size:24px;font-weight:900;line-height:1.55;letter-spacing:-.01em;color:#11142d;margin:0 0 22px;position:relative}
.message-card h3 .hl{background:linear-gradient(transparent 60%, #ffe5ee 60%);padding:0 3px}
.message-card p{font-size:16px;line-height:1.95;color:#3b3f5f;margin:0 0 14px;position:relative;font-weight:500}
.message-card .sign{margin-top:22px;display:flex;align-items:center;gap:14px;position:relative}
.message-card .sign .av{
  width:44px;height:44px;border-radius:50%;
  background:linear-gradient(135deg,#fcd6c1,#e5b8a0);
  box-shadow:inset 0 0 0 3px #fff, 0 0 0 1.5px #e7e2f5;
}
.message-card .sign .sign-mark{
  width:44px;height:44px;display:grid;place-items:center;flex:none;
  filter:drop-shadow(0 8px 18px rgba(123,86,247,.45));
}
.message-card .sign .sign-mark svg{width:100%;height:100%;display:block}
.message-card .sign .who .role{font-size:12px;color:#8a90ab;font-weight:600;letter-spacing:.06em}
.message-card .sign .who .name{font-size:17px;font-weight:800;color:#11142d;margin-top:2px}
.message-card .sign .who .name .kana{font-size:10px;font-weight:600;color:#8a90ab;margin-left:6px}
.message-card .sign .who .en{font-family:"Bebas Neue",sans-serif;font-size:12px;letter-spacing:.18em;color:#9b5cf6;margin-top:2px}

/* floating decorations around the solo message card */
.message-wrap.solo .message-star{
  position:absolute;right:6%;top:-16px;width:68px;height:68px;
  filter:drop-shadow(0 12px 20px rgba(245,158,11,.45));
  animation:floatA 5s ease-in-out infinite;pointer-events:none;
}
.message-wrap.solo .message-spark{
  position:absolute;left:6%;bottom:24px;width:38px;height:38px;
  filter:drop-shadow(0 6px 14px rgba(236,72,153,.5));
  animation:sparkBlink 2.6s ease-in-out infinite;pointer-events:none;
}
@keyframes floatA{0%,100%{transform:translateY(0) rotate(0)}50%{transform:translateY(-12px) rotate(8deg)}}

/* ---------- company 02 VMV ---------- */
.vmv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:28px}
.vmv-card{
  position:relative;background:#fff;border-radius:20px;padding:36px 24px 28px;text-align:center;
  box-shadow:0 16px 36px -22px rgba(60,40,140,.22), inset 0 0 0 1px #eee7fa;
  transition:transform .35s cubic-bezier(.2,.7,.2,1), box-shadow .35s ease;overflow:hidden;
}
.vmv-card::before{
  content:"";position:absolute;inset:0;border-radius:inherit;padding:1.5px;
  background:linear-gradient(135deg, rgba(91,139,255,.5), rgba(155,92,246,.5) 50%, rgba(236,72,153,.5));
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  opacity:.35;transition:opacity .35s ease;pointer-events:none;z-index:3;
}
.vmv-card::after{
  content:"";position:absolute;left:50%;top:0;width:160%;height:60%;transform:translateX(-50%);
  background:radial-gradient(ellipse 50% 50% at 50% 50%, rgba(155,92,246,.16), transparent 70%);
  pointer-events:none;opacity:0;transition:opacity .35s ease;border-radius:inherit;z-index:2;
}
.vmv-card.blue::after{background:radial-gradient(ellipse 50% 50% at 50% 50%, rgba(91,130,255,.18), transparent 70%)}
.vmv-card.pink::after{background:radial-gradient(ellipse 50% 50% at 50% 50%, rgba(236,72,153,.18), transparent 70%)}
.vmv-card:hover{transform:translateY(-10px);box-shadow:0 36px 60px -28px rgba(60,40,140,.35)}
.vmv-card:hover::before{opacity:.9}
.vmv-card:hover::after{opacity:1}
.vmv-card > *{position:relative;z-index:4}
.vmv-card .num{
  position:absolute;top:14px;right:18px;font-family:"Bebas Neue",sans-serif;font-size:70px;line-height:.8;
  color:#f3f0fc;font-weight:400;letter-spacing:.02em;
}
.vmv-card .icon{width:64px;height:64px;border-radius:50%;margin:0 auto 14px;display:grid;place-items:center;color:#fff;font-size:28px;
  background:linear-gradient(135deg,#5a8bff,#9b5cf6);
  box-shadow:inset 0 -8px 16px rgba(155,92,246,.25), 0 12px 24px -12px rgba(155,92,246,.5);
}
.vmv-card.pink .icon{background:linear-gradient(135deg,#ec4899,#f472b6);box-shadow:inset 0 -8px 16px rgba(236,72,153,.25), 0 12px 24px -12px rgba(236,72,153,.5)}
.vmv-card.blue .icon{background:linear-gradient(135deg,#5a8bff,#3b6df8);box-shadow:inset 0 -8px 16px rgba(91,130,255,.25), 0 12px 24px -12px rgba(91,130,255,.5)}
.vmv-card .lbl{font-family:"Bebas Neue",sans-serif;letter-spacing:.3em;font-size:12px;color:#9b5cf6;font-weight:600}
.vmv-card h3{font-size:22px;font-weight:900;margin:8px 0 12px;color:#11142d;letter-spacing:-.01em;line-height:1.4;position:relative;z-index:1}
.vmv-card p{font-size:15px;line-height:1.85;color:#54597a;margin:0;position:relative;z-index:1;font-weight:500}

/* ---------- company 03 INFO TABLE ---------- */
.info-card{
  background:#fff;border-radius:20px;overflow:hidden;margin-top:28px;
  box-shadow:0 16px 36px -22px rgba(60,40,140,.22), inset 0 0 0 1px #eee7fa;
}
.info-row{display:grid;grid-template-columns:220px 1fr;gap:24px;align-items:center;padding:18px 28px;border-top:1px solid #f3f0fc;font-size:15px;line-height:1.7}
.info-row:first-child{border-top:0}
.info-row dt{font-weight:700;color:#11142d;display:flex;align-items:center;gap:8px;margin:0}
.info-row dt::before{content:"";width:5px;height:5px;border-radius:50%;background:linear-gradient(135deg,#9b5cf6,#ec4899);flex:none}
.info-row dd{margin:0;color:#3b3f5f}
.info-row dd .small{font-size:13px;color:#8a90ab;margin-top:5px}
.info-row dd .biz{display:flex;flex-wrap:wrap;gap:6px;margin-top:5px}
.info-row dd .biz span{background:#f6f4ff;color:#54597a;border-radius:999px;padding:5px 14px;font-size:13px;font-weight:600}

/* ---------- company 04 HISTORY TIMELINE ---------- */
.timeline{position:relative;margin-top:28px;padding-left:48px}
.timeline::before{content:"";position:absolute;left:11px;top:6px;bottom:6px;width:2px;background:linear-gradient(180deg,#5a8bff,#9b5cf6 50%,#ec4899);border-radius:2px}
.tl-item{position:relative;padding-bottom:24px}
.tl-item:last-child{padding-bottom:0}
.tl-item .dot{position:absolute;left:-44px;top:4px;width:24px;height:24px;border-radius:50%;
  background:#fff;display:grid;place-items:center;
  box-shadow:0 0 0 3px #fbfaff, inset 0 0 0 2px transparent;
}
.tl-item .dot::before{content:"";width:11px;height:11px;border-radius:50%;background:linear-gradient(135deg,#9b5cf6,#ec4899)}
.tl-item .year{font-family:"Bebas Neue",sans-serif;font-size:26px;letter-spacing:.04em;color:#11142d;line-height:1}
.tl-item .year small{font-size:14px;color:#9b5cf6;margin-left:6px}
.tl-item h4{font-size:17px;font-weight:800;color:#11142d;margin:8px 0 6px}
.tl-item p{font-size:14.5px;line-height:1.85;color:#54597a;margin:0;max-width:680px;font-weight:500}

/* ---------- company 05 ACCESS ---------- */
.access-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:28px}
.access-card{
  background:#fff;border-radius:20px;padding:24px 28px;
  box-shadow:0 16px 36px -22px rgba(60,40,140,.22), inset 0 0 0 1px #eee7fa;
}
.access-card h3{font-size:19px;font-weight:900;color:#11142d;margin:0 0 16px;display:flex;align-items:center;gap:10px}
.access-card h3::before{content:"";width:5px;height:22px;border-radius:3px;background:linear-gradient(180deg,#5a8bff,#9b5cf6 50%,#ec4899)}
.access-card p{font-size:15px;line-height:1.9;color:#3b3f5f;margin:0;font-weight:500}
.access-card .addr{font-weight:700;font-size:16px;color:#11142d;margin-bottom:6px;line-height:1.55}
.access-card .route{margin-top:12px;display:flex;flex-direction:column;gap:5px}
.access-card .route span{font-size:14px;color:#54597a;display:flex;align-items:center;gap:8px;font-weight:500}
.access-card .route span::before{content:"";width:11px;height:11px;border-radius:50%;background:linear-gradient(135deg,#5a8bff,#9b5cf6);flex:none;display:inline-block}
.map-wrap{
  background:linear-gradient(135deg,#eef0fb 0%,#f4eef8 50%,#fce6f0 100%);
  border-radius:20px;height:220px;display:grid;place-items:center;color:#9b5cf6;position:relative;overflow:hidden;
  box-shadow:0 16px 36px -22px rgba(60,40,140,.22), inset 0 0 0 1px #eee7fa;
}
.map-wrap::before{
  content:"";position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(155,92,246,.12) 1px, transparent 1px),
    linear-gradient(90deg, rgba(155,92,246,.12) 1px, transparent 1px);
  background-size:28px 28px;
}
.map-wrap::after{
  content:"";position:absolute;left:42%;top:40%;width:32px;height:32px;border-radius:50% 50% 50% 0;
  background:linear-gradient(135deg,#ec4899,#9b5cf6);transform:rotate(-45deg);
  box-shadow:0 8px 18px -4px rgba(236,72,153,.5);
}
.map-wrap .pin-dot{position:absolute;left:42%;top:40%;width:32px;height:32px;display:grid;place-items:center;transform:rotate(0);color:#fff;font-weight:900;font-size:12px;z-index:1}

/* small decorations (company) */
.deco-blob{position:absolute;pointer-events:none;z-index:0;border-radius:50%;filter:blur(40px);opacity:.4}
.deco-blob.b1{left:-80px;top:30%;width:200px;height:200px;background:#a3c8e6}
.deco-blob.b2{right:-80px;top:60%;width:240px;height:240px;background:#d4c8f0}

/* tiny stars */
.stars{position:absolute;inset:0;pointer-events:none;z-index:1}
.stars span{position:absolute;color:#f4b22a;font-size:14px}

/* utility */
.container{max-width:1280px;margin:0 auto}

/* misc keyframes */
@keyframes pulse{50%{opacity:.4}}

/* ---------- scroll fade-in ---------- */
.fade-in{opacity:0;transform:translateY(24px);transition:opacity .9s cubic-bezier(.2,.7,.2,1), transform .9s cubic-bezier(.2,.7,.2,1)}
.fade-in.visible{opacity:1;transform:none}
.fade-in.delay-1{transition-delay:.08s}
.fade-in.delay-2{transition-delay:.16s}
.fade-in.delay-3{transition-delay:.24s}
.fade-in.delay-4{transition-delay:.32s}
.fade-in.delay-5{transition-delay:.40s}
.fade-in.delay-6{transition-delay:.48s}
.fade-in.from-left{transform:translateX(-30px) translateY(0)}
.fade-in.from-left.visible{transform:none}
.fade-in.from-right{transform:translateX(30px) translateY(0)}
.fade-in.from-right.visible{transform:none}
.fade-in.scale-in{transform:scale(.94)}
.fade-in.scale-in.visible{transform:none}
@media (prefers-reduced-motion: reduce){.fade-in{opacity:1;transform:none;transition:none}}

/* gentle float animations for hero decorations */
@keyframes floatB { 0%,100%{transform:translate(0,0) rotate(var(--r,0deg))} 50%{transform:translate(6px,-8px) rotate(calc(var(--r,0deg) - 3deg))} }
@keyframes floatC { 0%,100%{transform:translate(0,0) rotate(var(--r,0deg))} 50%{transform:translate(-5px,8px) rotate(calc(var(--r,0deg) + 4deg))} }
@keyframes pop { 0%,100%{transform:scale(1) rotate(var(--r,0deg))} 50%{transform:scale(1.06) rotate(calc(var(--r,0deg) + 2deg))} }

.hero-right .pastel,
.hero-right .deco,
.hero-right .sticker,
.hero-right .chat-card,
.hero-right .follower-card,
.hero-right .frame-ring{
  animation-duration: var(--dur,6s);
  animation-iteration-count: infinite;
  animation-timing-function: ease-in-out;
  transition: transform .35s cubic-bezier(.2,.7,.2,1), animation-duration .3s;
  will-change: transform;
}
.hero-right .pastel.pink   { --dur:7s;  animation-name:floatA }
.hero-right .pastel.yellow { --dur:5.5s;animation-name:floatB; animation-delay:-1s }
.hero-right .pastel.blue   { --dur:6s;  animation-name:floatC; animation-delay:-2s }
.hero-right .pastel.mint   { --dur:8s;  animation-name:floatA; animation-delay:-3s }
.hero-right .pastel.lav    { --dur:7s;  animation-name:floatB; animation-delay:-2s }
.hero-right .pastel.tinyY  { --dur:5s;  animation-name:floatC }
.hero-right .pastel.lavbig { --dur:9s;  animation-name:floatA; animation-delay:-4s }

.hero-right .deco.spark1   { --r:0deg;  --dur:3.2s; animation-name:pop }
.hero-right .deco.spark2   { --r:0deg;  --dur:2.6s; animation-name:pop; animation-delay:-1s }
.hero-right .deco.spark3   { --r:0deg;  --dur:3.6s; animation-name:pop; animation-delay:-2s }
.hero-right .deco.heart-sq { --dur:5s;  animation-name:floatA }
.hero-right .deco.squig    { --dur:4.5s;animation-name:floatB }
.hero-right .deco.gamepad-sticker { --r:-18deg; --dur:5s; animation-name:floatA }
.hero-right .deco.gamepad-3d { --r:-15deg; --dur:6s; animation-name:floatA }
.hero-right .deco.coin-sticker    { --r:-12deg; --dur:4s; animation-name:floatC; animation-delay:-1s }
.hero-right .deco.chat-bubble     { --dur:5s;  animation-name:floatB; animation-delay:-2s }
.hero-right .frame-ring           { --dur:14s; animation-name:spinSlow; animation-timing-function:linear; transform-origin:50% 50% }

.hero-right .sticker      { --r:-8deg; --dur:5s; animation-name:floatA }
.hero-right .chat-card    { --dur:6s;  animation-name:floatB; animation-delay:-1s }
.hero-right .follower-card{ --r:2deg;  --dur:7s; animation-name:floatA; animation-delay:-2s }

.hero-right:hover .pastel,
.hero-right:hover .deco,
.hero-right:hover .sticker,
.hero-right:hover .chat-card,
.hero-right:hover .follower-card{
  animation-duration: calc(var(--dur,6s) / 2.4);
}
.hero-right .sticker:hover{transform:rotate(var(--r,-8deg)) scale(1.06) translateY(-4px);animation-play-state:paused}
.hero-right .chat-card:hover,
.hero-right .follower-card:hover{transform:translateY(-6px) rotate(var(--r,0deg));animation-play-state:paused}
.hero-right .deco.gamepad-sticker:hover,
.hero-right .deco.gamepad-3d:hover,
.hero-right .deco.coin-sticker:hover,
.hero-right .deco.chat-bubble:hover{
  transform:rotate(var(--r,0deg)) scale(1.1) translateY(-6px);
  animation-play-state:paused;
}
.hero-right .pastel{pointer-events:auto}
.hero-right .pastel:hover{filter:brightness(1.05) saturate(1.1)}
.hero-right .deco.gamepad-sticker,
.hero-right .deco.gamepad-3d,
.hero-right .deco.coin-sticker,
.hero-right .deco.chat-bubble,
.hero-right .sticker,
.hero-right .chat-card,
.hero-right .follower-card{pointer-events:auto}

/* ============================================================
   RESPONSIVE OVERRIDES — placed at end so they win the cascade
   ============================================================ */
/* ---------- Header layout for tablet/mobile: hide PC nav+cta, show hamburger ---------- */
@media (max-width: 1199px){
  .nav-toggle{display:inline-grid}
  header.site nav.main{display:none}
  header.site .cta-pill{display:none}
}

/* ---------- Hero mobile badges (hidden on PC) ---------- */
.hero-mobile-badges{display:none}

/* ---------- Tablet + mobile HERO restructure ---------- */
@media (max-width: 1199px){
  .hero{position:relative;padding:24px 28px 48px;min-height:0;max-width:none;overflow:hidden}
  .hero-inner{grid-template-columns:1fr;gap:28px;position:relative;z-index:3}
  .hero-left{padding:8px 0;position:relative;z-index:3}

  /* Hide all floating HERO right decorations and the LIVE CHAT card */
  .hero-right .pastel,
  .hero-right .deco,
  .hero-right .chat-card,
  .hero-right .follower-card,
  .hero-right .frame-ring{display:none !important}

  /* HERO right becomes the background photo layer behind text */
  .hero-right{
    position:absolute !important;inset:0;width:auto !important;height:auto !important;
    margin:0 !important;padding:0;
    z-index:1;pointer-events:none;
    display:block;overflow:hidden;
  }
  .hero-right .blob-wrap{
    position:absolute !important;left:50% !important;top:50% !important;
    transform:translate(-50%, -50%) !important;
    width:200% !important;max-width:none !important;height:auto !important;
    aspect-ratio:520/560;
    margin:0 !important;
    opacity:.16;
    filter:saturate(.65) blur(0.5px);
    animation:none !important;
  }
  /* 角丸の有機ブロブ形を無効化して画面いっぱいに矩形で表示 */
  .hero-right .blob-wrap .blob-clipped{
    transform:none;
    clip-path:none !important;-webkit-clip-path:none !important;
    border-radius:0 !important;
  }
  .hero-right .blob-wrap .scene{border-radius:0 !important}

  /* Soft white overlay over silhouette for text readability */
  .hero::after{
    content:"";position:absolute;inset:0;pointer-events:none;z-index:2;
    background:
      radial-gradient(ellipse 80% 60% at 50% 50%, rgba(251,250,255,.55) 0%, rgba(251,250,255,.75) 50%, transparent 100%),
      linear-gradient(180deg, rgba(251,250,255,.4) 0%, transparent 30%, transparent 70%, rgba(251,250,255,.5) 100%);
  }
}

/* ---------- Mobile-specific HERO (silhouette背景 + 順次出現アニメ) ---------- */
@media (max-width: 767px){
  .hero{padding:16px 16px 28px}
  .hero-inner{gap:12px}

  .badge-row{flex-wrap:wrap;justify-content:center;gap:5px;margin-top:6px}
  .badge-pill{font-size:11px;padding:5px 11px}

  .h1-wrap{margin-top:10px;text-align:center;position:relative}
  /* HEROは2行で収まるサイズに */
  .h1{
    font-size:clamp(26px, 7.6vw, 36px) !important;
    white-space:normal;line-height:1.2;letter-spacing:-.02em;
    text-shadow:0 2px 16px rgba(255,255,255,.7), 0 1px 2px rgba(255,255,255,.5);
  }
  .h1 .mirai{
    font-size:clamp(44px, 13vw, 62px) !important;
    margin-left:-2px !important;margin-right:4px !important;
    vertical-align:-2px !important;
  }
  .h1-line{white-space:nowrap;display:inline-block}

  .pse{justify-content:center;font-size:13px;margin-top:6px;gap:6px}
  .pse i{font-size:11px}

  .lead{font-size:12px;max-width:none;text-align:center;margin-top:12px;line-height:1.75}

  /* HEROチップ: 小型化 + ドットを左端で揃える */
  .chip-grid{
    grid-template-columns:1fr 1fr;gap:6px;margin-top:12px;
    justify-content:center;max-width:320px;margin-left:auto;margin-right:auto;
  }
  .chip{
    display:flex;justify-content:flex-start;align-items:center;
    font-size:11px;padding:6px 10px;gap:6px;font-weight:600;
    background:rgba(255,255,255,.94);
  }
  .chip .dot{width:12px;height:12px;flex:none;font-size:0}

  .hero-cta-wrap{justify-content:center;margin-top:14px}
  .hero-cta{width:100%;justify-content:center;font-size:15px;padding:14px 18px;gap:8px}
  .hero-cta-wrap .casual{display:none}
  .hero-cta-wrap .line-note{text-align:center}
}

/* ---------- H1 line stagger animation (mobile/tablet only, after loader) ---------- */
@media (max-width: 1199px){
  .h1-line{display:inline-block;opacity:0;transform:translateY(24px);filter:blur(8px)}
  .h1-line-1{animation:h1LineIn 1.4s cubic-bezier(.2,.7,.2,1) 2.9s both}
  .h1-line-2{animation:h1LineIn 1.6s cubic-bezier(.2,.7,.2,1) 4.0s both}
  @keyframes h1LineIn{
    to{opacity:1;transform:translateY(0);filter:blur(0)}
  }
}
@media (prefers-reduced-motion: reduce){
  .h1-line{opacity:1;transform:none;filter:none;animation:none !important}
}

/* ---------- iPhone SE / 小型スマホ (<=374px) ---------- */
@media (max-width: 374px){
  body{padding-top:58px}
  header.site{padding:8px 12px;gap:8px}
  header.site.scrolled{padding:6px 12px}
  .header-inner{gap:8px}
  .brand{gap:8px}
  .brand .mark{width:34px;height:34px}
  .brand .word .name svg{height:14px}
  .brand .word .tag{display:none}
  .nav-toggle{width:38px;height:38px;flex:none}
  .nav-toggle .bar{left:8px;right:8px}
  .hero{padding:14px 14px 30px}
  .chip-grid{max-width:none}
  .chip{font-size:11.5px;padding:7px 10px}
  .chip .dot{width:14px;height:14px}
  section.block{padding:22px 12px;margin:10px 4px}
  .sec-num{font-size:48px}
  .sec-title{font-size:22px}
}

/* ---------- Header sizing for tablet/mobile ---------- */
@media (max-width: 1199px){
  body{padding-top:84px}
  header.site{padding:14px 28px}
  header.site.scrolled{padding:12px 28px}
  .brand{gap:14px}
  .brand .mark{width:56px;height:56px}
  .brand .word .name svg{height:22px;width:auto}
  .brand .word .tag{font-size:10px;letter-spacing:.28em}
}
@media (max-width: 767px){
  body{padding-top:48px}
  header.site{padding:6px 12px;width:100vw;box-sizing:border-box;justify-content:flex-start}
  header.site.scrolled{padding:5px 12px}
  .header-inner{gap:8px;max-width:100%;justify-content:flex-start}
  /* 左寄せ: brand は固定幅、その後 margin-left:auto でハンバーガーを右に飛ばす */
  .brand{gap:5px;min-width:0;flex:0 0 auto;margin-right:auto}
  .brand .mark{width:24px;height:24px}
  .brand .word{min-width:0;overflow:hidden;gap:4px !important}
  .brand .word .name svg{height:11px;max-width:100%}
  .brand .word .name .wordmark{font-size:10px;letter-spacing:.08em}
  .brand .word .tag{font-size:7px;letter-spacing:.18em;gap:4px}
  .brand .word .tag .live{padding:1px 3px;font-size:7px}
  .nav-toggle{flex:none;width:34px;height:34px;margin-left:auto}
  .nav-toggle .bar{left:7px;right:7px}
  .nav-toggle .bar:nth-child(1){top:10px}
  .nav-toggle .bar:nth-child(2){top:16px}
  .nav-toggle .bar:nth-child(3){top:22px}
}

/* ---------- Section panels ---------- */
@media (max-width: 1199px){
  section.block{padding:36px 28px;margin:20px auto;border-radius:24px;max-width:none}
  .sec-num{font-size:74px}
  .sec-title{font-size:32px;white-space:normal}
  .sec-eyebrow{font-size:18px}
  .sec-lead{font-size:15px;line-height:1.75}
  .sec-head{gap:24px}
}
@media (max-width: 767px){
  section.block{padding:22px 14px;margin:10px 6px;border-radius:16px}
  .sec-head{grid-template-columns:1fr;gap:10px}
  /* 統一: セクション見出し基準 */
  .sec-num{font-size:48px;margin-bottom:-12px}
  .sec-title{font-size:22px;margin:-16px 0 4px;letter-spacing:-.01em;line-height:1.25}
  .sec-eyebrow{font-size:13px;letter-spacing:.24em}
  .sec-lead{font-size:12px;line-height:1.7;margin-top:6px}
  .sec-title[class*="line-"]::after{width:96px;margin:10px 0 6px;height:2px}
}

/* ---------- SERVICE/SUPPORT/RESULTS grids ---------- */
@media (max-width: 1199px){
  .service-grid{grid-template-columns:repeat(2, 1fr);gap:16px;margin-top:32px}
  .service-grid .svc-card:nth-child(odd){margin-top:0}
  .support-grid{grid-template-columns:repeat(2, 1fr);gap:14px}
  .results-grid{grid-template-columns:repeat(2, 1fr);gap:14px}
}
@media (max-width: 767px){
  .service-grid{grid-template-columns:repeat(2,1fr);gap:8px;margin-top:18px}
  .support-grid{grid-template-columns:repeat(2,1fr);gap:8px}
  .results-grid{grid-template-columns:repeat(2, 1fr);gap:8px}
  /* 統一: カード見出し15px / 本文11px / ラベル9-10px */
  .svc-card{padding:14px 12px 12px;border-radius:14px}
  .svc-card h3{font-size:15px;margin:4px 0 4px;line-height:1.35}
  .svc-card p{font-size:11px;line-height:1.6}
  .svc-num{font-size:18px;top:8px;right:10px}
  .svc-card .pill-en{font-size:9px;padding:2px 8px;letter-spacing:.12em}
  .sup-card{border-radius:14px}
  .sup-card .body{padding:13px 12px 12px}
  .sup-card h4{font-size:15px;margin:4px 0 4px;line-height:1.35}
  .sup-card p{font-size:11px;line-height:1.6}
  .sup-card .eyebrow{font-size:10px;letter-spacing:.18em}
  .sup-card .step-tag{font-size:9px;padding:2px 7px 1px;letter-spacing:.18em}
  .res-card{padding:12px 10px;border-radius:12px}
  .res-card .num{font-size:26px}
  .res-card .unit{font-size:11px}
  .res-card .lbl{font-size:10px}
  .res-card .suf,.res-card .badge-suf{font-size:9px}
  /* No.1 リボン: 主張を抑えてコンパクトに */
  .no1{padding:14px 14px;max-width:none;border-radius:14px}
  .no1-eyebrow{font-size:11px !important;letter-spacing:.22em;opacity:.72}
  .no1-title{font-size:11px;line-height:1.5}
  .no1-meta{margin-bottom:4px}
  .no1-num{font-size:38px;line-height:1}
  .no1-num .no{font-size:14px !important}
  .no1-num .one{font-size:38px !important}
  .no1-foot{font-size:9px;line-height:1.5;margin-top:4px}
}

/* ---------- FLOW timeline ---------- */
@media (max-width: 1199px){
  .flow-tl-item{grid-template-columns:32px 1fr 84px;gap:22px;padding:12px 4px}
  .flow-tl-item .tl-right .ico .pill{width:64px;height:64px}
  .flow-tl-item .tl-right .ico .pill svg{width:30px;height:30px}
  .flow-tl-item.is-cta{grid-template-columns:32px 1fr 210px;padding:18px 22px}
  .flow-tl-item.is-cta .tl-right .btn{font-size:16px;padding:16px 22px}
}
@media (max-width: 767px){
  .flow-tl-item{grid-template-columns:18px 1fr;gap:12px;padding:10px 2px}
  .flow-tl-item .tl-right{display:none}
  .flow-tl-item .tl-mid .step-label{font-size:11px;letter-spacing:.18em}
  .flow-tl-item .tl-mid h4{font-size:15px;margin:2px 0 4px}
  .flow-tl-item .tl-mid p{font-size:11px;line-height:1.6}
  .flow-tl-item.is-cta{grid-template-columns:18px 1fr;padding:14px 12px;border-radius:14px}
  .flow-tl-item.is-cta .tl-right{display:flex;grid-column:1 / -1;justify-content:center;margin-top:8px}
  .flow-tl-item.is-cta .tl-right .btn{width:100%;justify-content:center;font-size:14px;padding:12px 16px;gap:6px}
  .flow-tl-item.is-cta .tl-right .btn .arr{font-size:15px}
}

/* ---------- FAQ ---------- */
@media (max-width: 1199px){
  .faq-grid{grid-template-columns:1fr;gap:24px;margin-top:24px}
  .faq-q-glow{display:none}
}
@media (max-width: 767px){
  .faq-item summary{padding:9px 12px;gap:6px}
  .faq-item .label{font-size:12px;line-height:1.4}
  .faq-item .q{font-size:15px !important}
  .faq-item .answer{font-size:11px;padding:0 12px 10px;line-height:1.7}
  .faq-item .plus{font-size:16px}
}

/* ---------- CTA banner ---------- */
@media (max-width: 1199px){
  .cta-banner{padding:36px 28px;border-radius:24px;margin:32px auto}
  .cta-banner .cta-inner{flex-direction:column;text-align:center;gap:18px}
  .cta-banner .ttl{font-size:34px;text-align:center}
  .cta-banner .chip-row{justify-content:center;flex-wrap:wrap}
  .cta-headset,.cta-pad{display:none}
}
@media (max-width: 767px){
  /* CTAをコンパクトに：タイトル + ボタンのみ。chip-row は完全削除 */
  .cta-banner{padding:18px 14px;border-radius:14px;margin:16px 6px}
  .cta-banner .cta-blob-a,
  .cta-banner .cta-blob-b,
  .cta-banner .cta-blob-c{display:none}
  .cta-banner .cta-inner > div{display:flex;flex-direction:column;align-items:stretch;gap:0}
  .cta-banner .ttl{order:1;font-size:18px;line-height:1.3;text-align:center}
  .cta-banner .big-btn{
    order:2;width:100%;padding:13px 16px;font-size:14px;line-height:1.3;
    margin-top:12px;gap:6px;
  }
  .cta-banner .big-btn small{font-size:9px;margin-top:2px}
  .cta-banner .line-note{order:3;text-align:center;margin-top:10px}
  .cta-banner .chip-row{display:none}
}

/* ---------- Footer: ロゴ/名前/リンクは左寄せ、CONTACTは右側 ---------- */
@media (max-width: 1199px){
  footer.site{padding:32px 24px 36px;margin-top:32px}
  .footer-inner{
    grid-template-columns:1fr auto;grid-template-rows:auto auto;
    gap:18px 16px;text-align:left;align-items:start;
  }
  footer.site .logo{
    grid-column:1;grid-row:1;justify-content:flex-start;
  }
  footer.site .contact{
    grid-column:2;grid-row:1;align-items:flex-end;
  }
  footer.site .links{
    grid-column:1 / -1;grid-row:2;
    grid-template-columns:repeat(3, max-content);gap:10px 28px;
    justify-content:start;justify-items:start;font-size:13px;
  }
  footer.site .links a{text-align:left}
  footer.site .logo .word .name svg{height:20px}
  footer.site .logo .word .tag{font-size:9px;letter-spacing:.28em}
  .contact-label{font-size:12px;letter-spacing:.28em}
  .contact-mail{padding:10px 16px;font-size:12.5px}
}
@media (max-width: 767px){
  footer.site{padding:22px 14px 24px}
  /* モバイルではCONTACTが右にあった行が見切れるので、縦3段に組み替え：ロゴ→リンク→CONTACT(右寄せ) */
  .footer-inner{
    grid-template-columns:1fr !important;grid-template-rows:auto auto auto !important;
    gap:14px !important;
  }
  footer.site .logo{grid-column:1 !important;grid-row:1 !important;justify-content:flex-start;gap:8px}
  footer.site .logo .mark{width:32px;height:32px}
  footer.site .logo .word .name svg{height:13px}
  footer.site .logo .word .tag{font-size:7px;letter-spacing:.22em}
  footer.site .links{
    grid-column:1 !important;grid-row:2 !important;
    grid-template-columns:1fr 1fr !important;gap:6px 16px;font-size:11px;
    justify-content:start;justify-items:start;
  }
  footer.site .contact{
    grid-column:1 !important;grid-row:3 !important;
    align-items:flex-end;width:100%;
  }
  .contact-label{font-size:8px;letter-spacing:.22em;padding-bottom:3px}
  .contact-label::after{width:26px;height:2px}
  .contact-mail{padding:6px 11px;font-size:10px;gap:4px}
  .contact-mail svg{width:11px;height:11px}
}

/* ---------- Decorations: sec-sparkles + bg-shapes ---------- */
@media (max-width: 1199px){
  .sec-sparkles .sparkle{transform:scale(.7)}
  .bg-shape{transform:scale(.7)}
}
@media (max-width: 767px){
  .sec-sparkles{display:none}
  /* Keep ~12 of the 23 bg-shapes on mobile, scale them down */
  .bg-shape{transform:scale(.5)}
  .bg-shapes .bg-shape:nth-child(n+13){display:none}
}

/* ---------- company.html specific ---------- */
@media (max-width: 1199px){
  .page-hero{padding:28px 24px 24px;max-width:none}
  .page-hero h1{font-size:34px}
  .page-hero .eyebrow{font-size:13px;letter-spacing:.32em}
  .page-hero .sub{font-size:14px;line-height:1.8;margin-top:14px}
  .message-wrap{grid-template-columns:1fr;gap:20px}
  .message-card{padding:24px 20px}
  .message-card h3{font-size:20px}
  .message-side{order:-1;max-width:280px;margin:0 auto}
  .vmv-grid{grid-template-columns:1fr;gap:14px}
  .info-card .info-row{grid-template-columns:120px 1fr;font-size:13px;padding:12px 14px}
  .access-grid{grid-template-columns:1fr;gap:14px}
  .timeline{padding-left:38px}
  .sp-only{display:none}
}
/* 本文の装飾改行はタブレット/スマホでは無効化し、自然な折り返しに（PC用の細かい<br>がブツ切れに見えるのを防ぐ） */
@media (max-width: 1199px){
  .page-hero .sub br,
  .message-card p br,
  .vmv-card p br{display:none}
}
/* スマホでは大幅にコンパクト化 + index.htmlのスマホ統一基準と揃える */
@media (max-width: 767px){
  /* SP専用改行 (CTA h2 等) を有効化 */
  .sp-only{display:inline}

  /* PAGE HERO */
  .page-hero{padding:16px 14px 14px}
  .page-hero h1{font-size:19px;line-height:1.3}
  .page-hero h1 .accent{display:inline-block}
  .page-hero .eyebrow{font-size:11px;letter-spacing:.26em}
  .page-hero .sub{font-size:11px;line-height:1.7;margin-top:10px;max-width:none}
  .breadcrumb{font-size:10px;margin-bottom:8px;gap:6px}

  /* MESSAGE */
  .message-wrap{gap:14px}
  .message-card{padding:16px 14px;border-radius:14px}
  .message-card h3{font-size:15px;line-height:1.45;margin:0 0 12px}
  .message-card p{font-size:12px;line-height:1.85;margin:0 0 10px}
  .message-card .quote{font-size:40px;top:14px;right:18px}
  .message-wrap.solo .message-card .quote{font-size:60px;top:18px;right:18px}
  .message-card .sign{margin-top:14px;gap:10px}
  .message-card .sign .av{width:34px;height:34px}
  .message-card .sign .sign-mark{width:34px;height:34px}
  .message-card .sign .who .role{font-size:9px;letter-spacing:.04em}
  .message-card .sign .who .name{font-size:13px}
  .message-card .sign .who .en{font-size:9px}

  /* VMV cards */
  .vmv-grid{gap:10px}
  .vmv-card{padding:14px 14px;border-radius:14px}
  .vmv-card h3{font-size:15px;line-height:1.4;margin:6px 0 6px}
  .vmv-card p{font-size:12px;line-height:1.75}
  .vmv-card .num{font-size:24px}
  .vmv-card .icon{font-size:16px}
  .vmv-card .lbl{font-size:9px;letter-spacing:.2em}

  /* INFO card */
  .info-card{border-radius:14px}
  .info-card .info-row{grid-template-columns:1fr;gap:2px;padding:10px 12px}
  .info-card .info-row dt{font-size:10px;color:var(--muted);font-weight:600;letter-spacing:.08em}
  .info-card .info-row dd{font-size:12.5px;line-height:1.6}
  .info-card .info-row dd .small{font-size:10px}
  .info-card .info-row dd .biz{gap:6px}
  .info-card .info-row dd .biz span{font-size:11px;padding:3px 8px}

  /* TIMELINE */
  .timeline{padding-left:24px;margin-top:18px}
  .timeline::before{left:8px}
  .tl-item{padding-bottom:14px}
  .tl-item:last-child{padding-bottom:0}
  .tl-item .dot{left:-22px;top:2px;width:14px;height:14px}
  .tl-item .dot::before{width:7px;height:7px}
  .tl-item .year{font-size:16px;letter-spacing:.04em}
  .tl-item .year small{font-size:11px;margin-left:4px}
  .tl-item h4{font-size:13px;font-weight:800;margin:4px 0 3px;line-height:1.4}
  .tl-item p{font-size:11px;line-height:1.65;max-width:none}

  /* ACCESS */
  .access-grid{gap:10px}
  .access-card{padding:14px 14px;border-radius:14px}
  .access-card h3{font-size:14px;margin:0 0 8px}
  .access-card p,.access-card dl,.access-card dd,.access-card dt{font-size:11px;line-height:1.65}

  /* CTA「あなたも Cloud Liver で。」セクション */
  .cta-banner.center{padding:18px 14px;border-radius:14px;margin:18px 6px}
  .cta-banner.center h2{font-size:18px;line-height:1.35}
  .cta-banner.center p{font-size:11px;line-height:1.65;margin:8px 0 14px}
  .cta-banner.center .btn{font-size:13px;padding:11px 26px;gap:6px}
}
