/* ============================================================
   TAATUROU — Liquid Glass MAX design system v3
   Deep-navy aurora · glass typography · refracting lens · dock
============================================================ */
:root{
  --bg:#04070f;
  --bg-2:#0a0f1e;
  --fg:#eef2f8;
  --dim:#8b93ab;
  --dim-2:#525a75;
  --line:rgba(220,232,255,.13);
  --line-2:rgba(220,232,255,.26);
  --cyan:#7fd9ff;
  --violet:#9a7bff;
  --accent:#8fd4ff;
  --grad:linear-gradient(90deg,var(--cyan),var(--violet));
  --glass:rgba(255,255,255,.10);
  --glass-soft:rgba(255,255,255,.06);
  --glass-brd:rgba(255,255,255,.30);
  --glass-brd-soft:rgba(255,255,255,.18);
  --hi:inset 0 1px 0 rgba(255,255,255,.5);
  --ease:cubic-bezier(.19,1,.22,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:auto;background:var(--bg)}
body{background:transparent;color:var(--fg);font-family:"Space Grotesk","Noto Sans JP",sans-serif;font-weight:400;line-height:1.5;overflow-x:hidden;-webkit-font-smoothing:antialiased;padding-bottom:96px}
::selection{background:var(--cyan);color:#04121f}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.it{font-style:italic}
.acc{color:var(--cyan)}

/* ---- animated aurora ---- */
body::before{content:"";position:fixed;inset:-25%;z-index:-2;pointer-events:none;
  background:
    radial-gradient(38% 46% at 18% 30%,rgba(64,130,255,.72),transparent 60%),
    radial-gradient(42% 50% at 82% 76%,rgba(150,70,255,.55),transparent 60%),
    radial-gradient(30% 40% at 62% 4%,rgba(0,220,255,.42),transparent 58%),
    radial-gradient(24% 30% at 45% 88%,rgba(0,140,255,.4),transparent 60%);
  will-change:transform;animation:bgdrift 30s ease-in-out infinite alternate}
@keyframes bgdrift{
  0%{transform:translate3d(-3%,-2%,0) scale(1.05)}
  50%{transform:translate3d(2%,3%,0) scale(1.14)}
  100%{transform:translate3d(3%,-2%,0) scale(1.08)}}
/* specular sweep */
body::after{content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:linear-gradient(115deg,transparent 40%,rgba(255,255,255,.05) 50%,transparent 60%);
  background-size:220% 220%;animation:sweep 16s ease-in-out infinite alternate}
@keyframes sweep{from{background-position:0% 0%}to{background-position:100% 100%}}
@media(prefers-reduced-motion:reduce){body::before,body::after{animation:none}}

.grain{position:fixed;inset:0;z-index:200;pointer-events:none;opacity:.035;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='150' height='150'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
#prog{position:fixed;top:0;left:0;height:2px;width:100%;background:var(--grad);transform:scaleX(0);transform-origin:left;z-index:150;box-shadow:0 0 10px rgba(127,217,255,.6)}

/* ---- loader ---- */
#load{position:fixed;inset:0;z-index:400;background:var(--bg);display:flex;align-items:center;justify-content:center}
#load .lw{font-style:italic;font-weight:700;font-size:clamp(2.2rem,8vw,5.5rem);letter-spacing:-.03em;
  color:rgba(255,255,255,.14);-webkit-text-stroke:1.5px rgba(255,255,255,.6);text-shadow:0 0 40px rgba(130,190,255,.3)}
#load .lc{position:absolute;bottom:6vh;right:5vw;font-size:.9rem;color:var(--dim);font-variant-numeric:tabular-nums}

/* ---- cursor ---- */
#cur,#curr{position:fixed;top:0;left:0;border-radius:50%;pointer-events:none;z-index:300;transform:translate(-50%,-50%)}
#cur{width:6px;height:6px;background:#fff;mix-blend-mode:difference}
#curr{width:38px;height:38px;border:1px solid rgba(255,255,255,.5);transition:width .35s var(--ease),height .35s var(--ease);mix-blend-mode:difference}
#curr.big{width:84px;height:84px}
@media(hover:none){#cur,#curr{display:none}}

/* ---- pill nav ---- */
nav{position:fixed;top:14px;left:50%;transform:translateX(-50%);z-index:100;
  display:flex;align-items:center;gap:20px;padding:10px 18px;border-radius:999px;
  background:var(--glass);backdrop-filter:blur(20px) saturate(1.9);-webkit-backdrop-filter:blur(20px) saturate(1.9);
  border:1px solid var(--glass-brd);box-shadow:var(--hi),inset 0 -10px 20px rgba(140,180,255,.08),0 8px 30px rgba(0,8,30,.35);
  white-space:nowrap;max-width:94vw}
nav .logo{font-style:italic;font-weight:700;font-size:1.05rem;letter-spacing:-.02em;color:#fff}
nav .menu{display:flex;gap:16px;font-family:"Space Grotesk","Noto Sans JP",sans-serif;font-size:.64rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase}
nav .menu a{opacity:.6;transition:opacity .25s;color:#fff}
nav .menu a:hover,nav .menu a.on{opacity:1}
nav .nav-cta{font-family:"Space Grotesk","Noto Sans JP",sans-serif;font-size:.62rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:#04121f;background:linear-gradient(180deg,#fff,#cfeaff);padding:8px 15px;border-radius:999px;
  box-shadow:inset 0 1px 0 #fff,0 0 14px rgba(140,220,255,.35)}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;z-index:101;padding:4px}
.burger span{width:22px;height:2px;background:#fff;transition:.3s var(--ease)}
.mobile{position:fixed;inset:0;z-index:99;background:rgba(4,7,15,.82);backdrop-filter:blur(28px) saturate(1.8);-webkit-backdrop-filter:blur(28px) saturate(1.8);
  display:flex;flex-direction:column;justify-content:center;padding:0 8vw;gap:6px;transform:translateY(-101%);transition:transform .55s var(--ease)}
.mobile a{font-size:2.4rem;font-weight:700;letter-spacing:-.02em;padding:8px 0;color:var(--fg)}
.mobile a .mn{font-size:.8rem;color:var(--cyan);vertical-align:super;margin-right:10px}
body.nav-open .mobile{transform:translateY(0)}
body.nav-open .burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
body.nav-open .burger span:nth-child(2){opacity:0}
body.nav-open .burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
@media(max-width:760px){nav .menu{display:none}.burger{display:flex}nav{gap:14px}}

/* ---- glass dock (injected) ---- */
.dock{position:fixed;left:50%;bottom:14px;transform:translateX(-50%);z-index:95;
  display:flex;gap:10px;padding:10px;border-radius:22px;
  background:var(--glass-soft);backdrop-filter:blur(26px) saturate(2);-webkit-backdrop-filter:blur(26px) saturate(2);
  border:1px solid var(--glass-brd);box-shadow:var(--hi),0 12px 34px rgba(0,8,30,.45)}
.dock a{width:46px;height:46px;border-radius:14px;display:flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.12);border:1px solid var(--glass-brd);box-shadow:var(--hi);transition:transform .3s var(--ease),background .3s}
.dock a:hover{transform:translateY(-6px) scale(1.08);background:rgba(255,255,255,.2)}
.dock a.on{background:linear-gradient(180deg,rgba(255,255,255,.9),rgba(207,234,255,.85))}
.dock a.on svg{stroke:#04121f}
.dock svg{width:20px;height:20px;stroke:#fff;fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
body.nav-open .dock{opacity:0;pointer-events:none}

/* ---- lens orb (injected) ---- */
.hero-meta{z-index:3}
.lens{position:absolute;right:6vw;top:24vh;width:min(240px,30vw);aspect-ratio:1;border-radius:50%;pointer-events:none;z-index:2;
  background:radial-gradient(circle at 34% 30%,rgba(120,200,255,.5),rgba(90,110,255,.32) 45%,rgba(150,80,255,.28) 75%,rgba(255,255,255,.07));
  backdrop-filter:blur(6px) saturate(2.2);-webkit-backdrop-filter:blur(6px) saturate(2.2);
  border:1.5px solid rgba(255,255,255,.5);
  box-shadow:inset 0 2px 0 rgba(255,255,255,.7),inset -18px -24px 40px rgba(0,30,80,.35),inset 14px 18px 30px rgba(255,255,255,.2),0 20px 60px rgba(0,10,40,.35);
  will-change:transform}
.lens i{position:absolute;inset:6px;border-radius:50%;border:2px solid transparent;border-top-color:rgba(255,255,255,.85);transform:rotate(-38deg)}
.lens b{position:absolute;left:15%;top:12%;width:22%;height:10%;border-radius:50%;background:rgba(255,255,255,.55);filter:blur(4px);transform:rotate(-24deg)}
.shard{position:absolute;pointer-events:none;z-index:2;border-radius:16px;background:rgba(255,255,255,.09);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.3);box-shadow:var(--hi);will-change:transform}
.shard.s1{width:58px;height:58px;right:3vw;top:52vh;transform:rotate(18deg)}
.shard.s2{width:38px;height:38px;right:26vw;top:12vh;transform:rotate(-14deg);border-radius:12px}
@media(max-width:760px){.lens{right:-6vw;top:9vh;width:150px}.shard.s2{display:none}}

/* ---- hero ---- */
.hero{min-height:100vh;position:relative;display:flex;flex-direction:column;justify-content:flex-end;padding:0 5vw 12vh}
.hero-meta{position:absolute;top:15vh;left:5vw;right:5vw;display:flex;justify-content:space-between;font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--dim)}
.hero-meta .r{text-align:right}
.bigword{font-weight:700;letter-spacing:-.035em;line-height:.85;font-size:clamp(3.4rem,19vw,16rem)}
.bigword .ln{display:block;overflow:hidden;padding-bottom:.05em}
.bigword .ln i{display:inline-block;font-style:italic;will-change:transform;
  color:rgba(255,255,255,.13);-webkit-text-stroke:1.5px rgba(255,255,255,.78);
  text-shadow:0 1px 0 rgba(255,255,255,.3),0 0 50px rgba(130,190,255,.38)}
.bigword .acc{color:rgba(127,217,255,.3);-webkit-text-stroke:1.5px rgba(127,217,255,.85)}
.hero-sub{margin-top:26px;max-width:30em;color:var(--dim);font-size:1.02rem;overflow:hidden}
.hero-sub span{display:inline-block}
.kicker{font-family:"Space Grotesk","Noto Sans JP",sans-serif;font-size:.7rem;font-weight:700;letter-spacing:.34em;text-transform:uppercase;color:var(--cyan);text-shadow:0 0 12px rgba(120,220,255,.55);margin-bottom:16px}
.scrollcue{position:absolute;bottom:12vh;right:5vw;font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:var(--dim);display:flex;align-items:center;gap:10px}
.scrollcue::before{content:"";width:42px;height:1px;background:var(--dim);animation:cue 2s var(--ease) infinite}
@keyframes cue{0%,100%{transform:scaleX(.4);opacity:.4}50%{transform:scaleX(1);opacity:1}}

/* glass player capsule (hero) */
.gplayer{display:inline-flex;align-self:flex-start;gap:12px;align-items:center;margin-top:30px;padding:12px 16px;border-radius:18px;
  background:var(--glass);backdrop-filter:blur(24px) saturate(2);-webkit-backdrop-filter:blur(24px) saturate(2);
  border:1px solid var(--glass-brd);box-shadow:var(--hi),inset -12px -16px 26px rgba(120,160,255,.1),0 0 30px rgba(90,150,255,.16);transition:.3s var(--ease)}
.gplayer:hover{transform:translateY(-3px)}
.gplayer img{width:44px;height:44px;border-radius:10px;box-shadow:inset 0 1px 0 rgba(255,255,255,.4)}
.gplayer .gt{font-size:.86rem;color:#fff;font-weight:500}
.gplayer .bar{display:flex;align-items:center;gap:6px;margin-top:5px}
.gplayer .bar em{display:block;width:110px;height:3px;border-radius:2px;background:rgba(255,255,255,.2)}
.gplayer .bar em s{display:block;width:38%;height:3px;border-radius:2px;background:var(--grad);box-shadow:0 0 8px rgba(130,200,255,.8);text-decoration:none}
.gplayer .bar small{font-size:.62rem;color:var(--dim);font-family:"Space Grotesk","Noto Sans JP",sans-serif;letter-spacing:.08em}
.gplayer .pb{width:36px;height:36px;border-radius:50%;flex:none;display:flex;align-items:center;justify-content:center;font-size:.72rem;
  color:#04121f;background:linear-gradient(180deg,#fff,#d8f0ff);box-shadow:inset 0 1px 0 #fff,0 0 16px rgba(150,220,255,.4)}

/* ---- marquee ---- */
.mq{border-top:1px solid var(--line);border-bottom:1px solid var(--line);overflow:hidden;white-space:nowrap;padding:20px 0;background:rgba(4,8,18,.3)}
.mq .t{display:inline-flex;animation:mqf 32s linear infinite}
.mq .t span{font-size:1.5rem;font-weight:500;padding:0 32px;color:var(--dim)}
.mq .t span.o{color:transparent;-webkit-text-stroke:1px var(--dim-2)}
.mq .t span em{font-style:italic;color:var(--cyan)}
.mq .t span.cl{font-family:"Space Grotesk","Noto Sans JP",sans-serif;font-weight:800;font-size:1.35rem;letter-spacing:.34em;text-transform:uppercase;color:rgba(255,255,255,.88)}
.mq .t span.gr{font-style:italic;font-weight:700;font-size:1.6rem;letter-spacing:-.01em;color:rgba(255,255,255,.88)}
.mq .t span.cl.ol,.mq .t span.gr.ol{color:transparent;-webkit-text-stroke:1px rgba(228,234,245,.42)}
@keyframes mqf{to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){.mq .t{animation:none}.scrollcue::before{animation:none}}

/* ---- page head ---- */
.phead{padding:26vh 5vw 8vh;position:relative}
.phead .pk{font-family:"Space Grotesk","Noto Sans JP",sans-serif;font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;color:var(--cyan);text-shadow:0 0 12px rgba(120,220,255,.5);margin-bottom:16px}
.phead h1{font-weight:700;font-style:italic;letter-spacing:-.035em;line-height:.88;font-size:clamp(3rem,12vw,10rem);
  color:rgba(255,255,255,.15);-webkit-text-stroke:1.5px rgba(255,255,255,.6);text-shadow:0 1px 0 rgba(255,255,255,.25),0 0 40px rgba(130,190,255,.26)}
.phead .pd{margin-top:24px;max-width:40em;color:var(--dim)}
.phead .pno{position:absolute;top:26vh;right:5vw;font-size:.7rem;letter-spacing:.14em;color:var(--dim);font-family:"Space Grotesk","Noto Sans JP",sans-serif}

/* ---- sections ---- */
.sec{padding:10vh 5vw;border-top:1px solid var(--line);position:relative}
.sec-h{display:flex;justify-content:space-between;align-items:baseline;font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--dim);margin-bottom:44px;font-family:"Space Grotesk","Noto Sans JP",sans-serif}
.sec-h .t{color:var(--fg)}

/* ---- index rows ---- */
.row{position:relative;display:flex;align-items:center;gap:22px;padding:32px 0;border-top:1px solid var(--line)}
.row:last-child{border-bottom:1px solid var(--line)}
.row .no{font-size:.78rem;color:var(--dim);width:44px;flex:none;transition:color .3s;font-family:"Space Grotesk","Noto Sans JP",sans-serif}
.row .nm{font-size:clamp(2.1rem,7vw,5.6rem);font-weight:700;letter-spacing:-.025em;line-height:.95;transition:transform .5s var(--ease),color .3s,text-shadow .3s}
.row .ar{margin-left:16px;font-size:1.9rem;opacity:0;transform:translateX(-14px);transition:.5s var(--ease);color:var(--cyan)}
.row .meta{margin-left:auto;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--dim);max-width:15em;text-align:right}
.row:hover .nm{transform:translateX(26px);color:#fff;text-shadow:0 0 30px rgba(140,200,255,.4)}
.row:hover .ar{opacity:1;transform:translateX(0)}
.row:hover .no{color:var(--cyan)}
.preview{position:fixed;top:0;left:0;width:300px;height:376px;border-radius:18px;overflow:hidden;pointer-events:none;z-index:60;opacity:0;
  transform:translate(-50%,-50%) scale(.92);transition:opacity .3s var(--ease),transform .3s var(--ease);
  border:1px solid var(--glass-brd);box-shadow:var(--hi),0 24px 60px rgba(0,8,30,.5)}
.preview img{width:100%;height:100%;object-fit:cover}
.preview.on{opacity:1;transform:translate(-50%,-50%) scale(1)}
@media(max-width:760px){.row .meta,.row .ar{display:none}.preview{display:none}}

/* ---- release cards ---- */
.strip{display:flex;gap:20px;overflow-x:auto;padding:6px 2px 12px;scrollbar-width:thin}
.strip::-webkit-scrollbar{height:4px}.strip::-webkit-scrollbar-thumb{background:var(--line-2)}
.rcard{flex:0 0 264px;max-width:264px;padding:12px;border-radius:20px;background:var(--glass-soft);border:1px solid var(--glass-brd-soft);box-shadow:var(--hi);transition:transform .4s var(--ease),border-color .3s,box-shadow .3s}
.grid .rcard{flex:initial;max-width:none}
.rcard:hover{transform:translateY(-5px);border-color:var(--glass-brd);box-shadow:var(--hi),0 18px 44px rgba(0,10,40,.45),0 0 24px rgba(110,170,255,.12)}
.rcard .cv{aspect-ratio:1;border-radius:12px;overflow:hidden;position:relative}
.rcard .cv img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.rcard:hover .cv img{transform:scale(1.05)}
.rcard .cv .ty{position:absolute;top:10px;left:10px;font-family:"Space Grotesk","Noto Sans JP",sans-serif;font-size:.56rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:#04121f;background:linear-gradient(180deg,#fff,#cfeaff);padding:4px 9px;border-radius:999px;box-shadow:inset 0 1px 0 #fff}
.rcard .rt{margin-top:13px;padding:0 4px;font-size:.96rem;font-weight:500}
.rcard .ry{font-size:.72rem;color:var(--dim);margin-top:2px;padding:0 4px;letter-spacing:.06em;font-family:"Space Grotesk","Noto Sans JP",sans-serif}
.rcard .rs{font-size:.74rem;color:var(--dim);margin-top:1px;padding:0 4px}

.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
@media(max-width:860px){.grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.grid{grid-template-columns:1fr}}

/* ---- videos ---- */
.vids{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
@media(max-width:760px){.vids{grid-template-columns:1fr}}
.vid{padding:12px;border-radius:20px;background:var(--glass-soft);border:1px solid var(--glass-brd-soft);box-shadow:var(--hi);transition:transform .4s var(--ease),border-color .3s}
.vid:hover{transform:translateY(-4px);border-color:var(--glass-brd)}
.vid .yt{position:relative;padding-bottom:56.25%;height:0;border-radius:12px;overflow:hidden;background:#000}
.vid .yt iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.vid .vt{margin-top:13px;padding:0 4px;font-size:.98rem;font-weight:500}
.vid .vm{font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--dim);margin-top:3px;padding:0 4px;font-family:"Space Grotesk","Noto Sans JP",sans-serif}

/* ---- products ---- */
.prod{border-radius:22px;overflow:hidden;display:flex;flex-direction:column;background:var(--glass-soft);border:1px solid var(--glass-brd-soft);box-shadow:var(--hi);transition:transform .4s var(--ease),border-color .3s,box-shadow .3s}
.prod:hover{transform:translateY(-5px);border-color:var(--glass-brd);box-shadow:var(--hi),0 18px 44px rgba(0,10,40,.45)}
.prod .pt{aspect-ratio:16/10;position:relative;display:grid;place-items:center;overflow:hidden;background:radial-gradient(circle at 30% 70%,rgba(90,130,255,.35),transparent 60%),radial-gradient(circle at 75% 25%,rgba(150,80,255,.3),transparent 60%),#0a0f22}
.prod .pt img{width:100%;height:100%;object-fit:cover}
.prod .pt .g{font-size:2.3rem;opacity:.9}
.prod .pt .pc{position:absolute;top:12px;left:12px;font-family:"Space Grotesk","Noto Sans JP",sans-serif;font-size:.56rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#04121f;background:linear-gradient(180deg,#fff,#cfeaff);padding:4px 9px;border-radius:999px;box-shadow:inset 0 1px 0 #fff}
.prod .pb{padding:20px;display:flex;flex-direction:column;flex:1}
.prod .pb h3{font-size:1.12rem;font-weight:500;margin-bottom:8px}
.prod .pb .pd{font-size:.85rem;color:var(--dim);flex:1;margin-bottom:16px}
.prod .chips{display:flex;gap:7px;flex-wrap:wrap;margin-bottom:16px}
.prod .chip{font-size:.58rem;letter-spacing:.08em;color:var(--dim);border:1px solid var(--line);padding:4px 9px;border-radius:999px;text-transform:uppercase;font-family:"Space Grotesk","Noto Sans JP",sans-serif}
.prod .pr{display:flex;align-items:center;justify-content:space-between;gap:12px}
.prod .pp{font-weight:700;font-size:1.45rem;color:#fff}.prod .pp small{font-size:.68rem;color:var(--dim);font-weight:400}

/* ---- buttons ---- */
.lk{display:inline-flex;align-items:center;gap:10px;font-family:"Space Grotesk","Noto Sans JP",sans-serif;font-size:.72rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;
  padding:14px 26px;border-radius:999px;transition:.3s var(--ease);
  background:var(--glass-soft);border:1px solid var(--glass-brd-soft);color:var(--fg);box-shadow:var(--hi)}
.lk:hover{border-color:var(--glass-brd);background:var(--glass);transform:translateY(-2px)}
.lk.fill{color:#04121f;background:linear-gradient(180deg,#fff,#cfeaff);border-color:transparent;box-shadow:inset 0 1px 0 #fff,0 0 18px rgba(140,220,255,.35)}
.lk.fill:hover{box-shadow:inset 0 1px 0 #fff,0 0 26px rgba(150,225,255,.55);transform:translateY(-2px)}
.cta-row{display:flex;gap:14px;flex-wrap:wrap}

/* ---- split / spotify ---- */
.split{display:grid;grid-template-columns:290px 1fr;gap:48px;align-items:center}
@media(max-width:760px){.split{grid-template-columns:1fr}}
.split img.cov{width:100%;border-radius:18px;border:1px solid var(--glass-brd-soft);box-shadow:var(--hi),0 20px 50px rgba(0,10,40,.4)}
.split .lab{font-family:"Space Grotesk","Noto Sans JP",sans-serif;font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;color:var(--cyan);text-shadow:0 0 12px rgba(120,220,255,.5);margin-bottom:16px}
.split h2{font-weight:700;letter-spacing:-.025em;line-height:1;font-size:clamp(2rem,5vw,3.5rem);margin-bottom:16px}
.split p{color:var(--dim);max-width:34em;margin-bottom:26px}
.sp{border-radius:20px;overflow:hidden;border:1px solid var(--glass-brd-soft);box-shadow:var(--hi)}
.sp iframe{display:block;width:100%;border:0}

/* ---- about ---- */
.ab{display:grid;grid-template-columns:1.3fr .7fr;gap:52px;align-items:start}
@media(max-width:760px){.ab{grid-template-columns:1fr}}
.ab p{color:var(--dim);margin-bottom:1.4em;font-size:1.02rem}
.ab p strong{color:var(--fg);font-weight:500}
.ab .pcard{border-radius:22px;padding:24px;background:var(--glass-soft);border:1px solid var(--glass-brd-soft);box-shadow:var(--hi)}
.ab .pcard img{width:100%;border-radius:14px;margin-bottom:20px}
.ab dl{display:grid;gap:15px}
.ab dt{font-family:"Space Grotesk","Noto Sans JP",sans-serif;font-size:.58rem;letter-spacing:.18em;text-transform:uppercase;color:var(--cyan);margin-bottom:3px}
.ab dd{font-size:.9rem}
.tl{list-style:none;border-left:1px solid var(--line-2);margin-top:10px}
.tl li{position:relative;padding:0 0 22px 26px}
.tl li::before{content:"";position:absolute;left:-5px;top:9px;width:9px;height:9px;border-radius:50%;background:var(--grad);box-shadow:0 0 10px rgba(130,200,255,.7)}
.tl b{display:block}.tl span{font-size:.9rem;color:var(--dim)}

/* ---- collective ---- */
.plans{display:grid;grid-template-columns:1fr 1fr;gap:22px;max-width:760px;margin:0 auto}
@media(max-width:620px){.plans{grid-template-columns:1fr}}
.plan{border-radius:22px;padding:32px;background:var(--glass-soft);border:1px solid var(--glass-brd-soft);box-shadow:var(--hi)}
.plan.hot{background:var(--glass);border-color:var(--glass-brd);box-shadow:var(--hi),0 0 34px rgba(110,170,255,.14)}
.plan h3{font-family:"Space Grotesk","Noto Sans JP",sans-serif;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--cyan);margin-bottom:14px}
.plan .amt{font-weight:700;font-size:2.3rem;margin-bottom:6px;color:#fff}.plan .amt small{font-size:.76rem;color:var(--dim);font-weight:400}
.plan ul{list-style:none;margin:18px 0;display:grid;gap:10px}
.plan li{padding-left:24px;position:relative;color:var(--dim);font-size:.92rem}
.plan li::before{content:"→";position:absolute;left:0;color:var(--cyan)}
.feats{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
@media(max-width:640px){.feats{grid-template-columns:1fr}}
.feat{border-radius:22px;padding:32px 28px;background:var(--glass-soft);border:1px solid var(--glass-brd-soft);box-shadow:var(--hi)}
.feat .i{font-size:1.4rem;color:var(--cyan);margin-bottom:14px;text-shadow:0 0 14px rgba(120,220,255,.6)}
.feat h3{font-size:1.05rem;margin-bottom:8px;font-weight:500}.feat p{font-size:.88rem;color:var(--dim)}

/* ---- contact ---- */
.bigmail{display:block;font-weight:700;letter-spacing:-.03em;line-height:.92;font-size:clamp(2rem,7.5vw,6rem);margin:5vh 0;transition:.3s;
  color:rgba(255,255,255,.2);-webkit-text-stroke:1px rgba(255,255,255,.55)}
.bigmail:hover{color:rgba(127,217,255,.35);-webkit-text-stroke-color:rgba(127,217,255,.9);text-shadow:0 0 34px rgba(120,210,255,.35)}
.sociallist{display:grid;border-top:1px solid var(--line)}
.sociallist a{display:flex;justify-content:space-between;align-items:center;padding:22px 6px;border-bottom:1px solid var(--line);font-size:1.08rem;transition:padding .4s var(--ease),color .3s,background .3s;border-radius:8px}
.sociallist a:hover{padding-left:20px;color:var(--cyan);background:rgba(255,255,255,.03)}
.sociallist a span{font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--dim);font-family:"Space Grotesk","Noto Sans JP",sans-serif}

/* ---- footer ---- */
footer{padding:12vh 5vw 4vh;border-top:1px solid var(--line)}
.fbig{font-style:italic;font-weight:700;font-size:clamp(3rem,15vw,14rem);letter-spacing:-.035em;line-height:.85;display:inline-block;transition:.4s;
  color:rgba(255,255,255,.13);-webkit-text-stroke:1.5px rgba(255,255,255,.5)}
.fbig:hover{color:rgba(127,217,255,.28);-webkit-text-stroke-color:rgba(127,217,255,.85);text-shadow:0 0 50px rgba(120,210,255,.3)}
.frow{display:flex;justify-content:space-between;flex-wrap:wrap;gap:18px;margin-top:40px;font-size:.72rem;letter-spacing:.13em;text-transform:uppercase;color:var(--dim);font-family:"Space Grotesk","Noto Sans JP",sans-serif}
.frow .fsoc{display:flex;gap:18px}
.frow a{color:var(--dim);transition:color .3s}.frow a:hover{color:var(--cyan)}

/* ---- follow chips ---- */
.socials{display:flex;gap:12px;flex-wrap:wrap}
.social{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;font-weight:600;padding:13px 24px;border-radius:999px;
  background:var(--glass-soft);border:1px solid var(--glass-brd-soft);box-shadow:var(--hi);transition:.3s var(--ease);color:var(--fg);display:inline-flex;align-items:center;gap:8px}
.social:hover{border-color:var(--glass-brd);color:var(--cyan);transform:translateY(-2px)}
.social .dot{width:8px;height:8px;border-radius:50%;flex:none}

/* ---- worked with roster ---- */
.roster{display:flex;flex-wrap:wrap;align-items:baseline;row-gap:14px}
.roster span{font-weight:500;font-size:1.12rem;color:var(--fg);padding:2px 18px;position:relative;transition:color .3s}
.roster span:hover{color:var(--cyan)}
.roster span+span::before{content:"";position:absolute;left:0;top:22%;bottom:22%;width:1px;background:var(--line-2)}
@media(max-width:640px){.roster span{font-size:1rem;padding:2px 13px}}

/* ---- contact form ---- */
.cform{display:grid;gap:18px;max-width:640px}
.cform .hp{position:absolute;left:-9999px;opacity:0}
.cform .f2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media(max-width:640px){.cform .f2{grid-template-columns:1fr}}
.cform label{display:grid;gap:8px;font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--dim);font-weight:600}
.cform input,.cform select,.cform textarea{
  font-family:"Space Grotesk","Noto Sans JP",sans-serif;font-size:.95rem;color:var(--fg);
  background:var(--glass-soft);border:1px solid var(--glass-brd-soft);border-radius:14px;
  padding:14px 16px;box-shadow:var(--hi);outline:none;transition:border-color .25s,background .25s;
  letter-spacing:normal;text-transform:none;appearance:none;-webkit-appearance:none}
.cform select{background-image:linear-gradient(45deg,transparent 50%,var(--dim) 50%),linear-gradient(135deg,var(--dim) 50%,transparent 50%);background-position:calc(100% - 21px) 50%,calc(100% - 16px) 50%;background-size:5px 5px;background-repeat:no-repeat}
.cform textarea{resize:vertical;min-height:140px}
.cform input::placeholder,.cform textarea::placeholder{color:var(--dim-2)}
.cform input:focus,.cform select:focus,.cform textarea:focus{border-color:rgba(127,217,255,.6);background:var(--glass)}
.cform button{justify-content:center;cursor:pointer;border:0}

.rv{opacity:0;transform:translateY(22px)}
@media(prefers-reduced-motion:reduce){.rv{opacity:1;transform:none}#load{display:none}}
.note{margin-top:34px;padding:20px 24px;border-radius:18px;background:var(--glass-soft);border:1px dashed var(--glass-brd-soft);color:var(--dim);font-size:.86rem}
