:root{
  --bg:#0a0a10; --bg2:#0e0e16; --ink:#0f0f14; --muted:#4b5563; --line:#e9e9f0; --soft:#f6f6fb;
  --base:#ffffff; --a1:#6c4cff; --a2:#ff4f8b;
  --ease:cubic-bezier(.2,.7,.2,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:90px}
body{font-family:"Zen Kaku Gothic New",sans-serif;color:var(--ink);background:var(--base);line-height:1.9;font-weight:400;-webkit-font-smoothing:antialiased;overflow-x:hidden;word-break:auto-phrase;line-break:strict}
h1,h2,h3,h4{text-wrap:balance}
p,.l,.intro,.body{text-wrap:pretty}
img{max-width:100%;display:block}
.dp{font-family:"Sora",sans-serif}
::selection{background:rgba(108,76,255,.22)}
:focus-visible{outline:2px solid var(--a1);outline-offset:3px;border-radius:4px}
::-webkit-scrollbar{width:11px}::-webkit-scrollbar-thumb{background:#cfcfe0;border-radius:8px;border:3px solid var(--base)}::-webkit-scrollbar-thumb:hover{background:var(--a1)}
.wrap{max-width:1160px;margin:0 auto;padding:0 28px}
section{padding:clamp(72px,9vw,128px) 0;position:relative}
.grad{background:linear-gradient(90deg,var(--a1),var(--a2));-webkit-background-clip:text;background-clip:text;color:transparent}
.noise:after{content:"";position:absolute;inset:0;pointer-events:none;z-index:1;opacity:.05;mix-blend-mode:overlay;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.noise>*{position:relative;z-index:2}
.head{margin-bottom:clamp(40px,6vw,60px)}
.ix{font-family:"Sora",sans-serif;font-size:.72rem;letter-spacing:.18em;color:var(--muted);font-weight:600;display:inline-flex;align-items:center;gap:10px;margin-bottom:16px}
.ix b{width:26px;height:1px;background:linear-gradient(90deg,var(--a1),var(--a2));display:inline-block}
.ey{font-family:"Sora",sans-serif;font-size:.74rem;letter-spacing:.3em;font-weight:700;background:linear-gradient(90deg,var(--a1),var(--a2));-webkit-background-clip:text;background-clip:text;color:transparent}
h2{font-size:clamp(1.65rem,3.6vw,2.25rem);font-weight:900;line-height:1.5;letter-spacing:.02em;margin-top:8px}
.btn{display:inline-flex;align-items:center;gap:9px;text-decoration:none;font-weight:700;padding:16px 36px;border-radius:50px;letter-spacing:.03em;transition:transform .28s var(--ease),box-shadow .28s var(--ease),background .28s,color .28s;font-size:.95rem}
.btn .arrow{transition:transform .3s var(--ease)}
.btn:hover .arrow{transform:translateX(5px)}
.btn-main{background:linear-gradient(90deg,var(--a1),var(--a2));color:#fff;box-shadow:0 12px 30px rgba(108,76,255,.3)}
.btn-main:hover{transform:translateY(-3px);box-shadow:0 18px 42px rgba(108,76,255,.4)}
.btn-line{border:1.5px solid rgba(255,255,255,.45);color:#fff}
.btn-line:hover{background:rgba(255,255,255,.1);transform:translateY(-3px)}

/* progress + top */
#prog{position:fixed;top:0;left:0;height:3px;width:0;background:linear-gradient(90deg,var(--a1),var(--a2));z-index:80}
#top{position:fixed;right:22px;bottom:22px;width:48px;height:48px;border-radius:50%;border:none;cursor:pointer;background:linear-gradient(135deg,var(--a1),var(--a2));color:#fff;font-size:1.1rem;opacity:0;pointer-events:none;transform:translateY(10px);transition:.35s var(--ease);z-index:55;box-shadow:0 12px 28px rgba(108,76,255,.42)}
#top.show{opacity:1;pointer-events:auto;transform:none}

/* reveal */
.js .reveal{opacity:0;transform:translateY(28px);transition:opacity 1s var(--ease),transform 1s var(--ease)}
.js .reveal.in{opacity:1;transform:none}
.js .reveal[data-d="1"]{transition-delay:.09s}
.js .reveal[data-d="2"]{transition-delay:.18s}
.js .reveal[data-d="3"]{transition-delay:.27s}
.js .reveal[data-d="4"]{transition-delay:.36s}

/* header */
header{position:fixed;top:0;left:0;width:100%;z-index:60;display:flex;justify-content:space-between;align-items:center;padding:24px 32px;transition:.4s var(--ease)}
header.scrolled{padding:13px 32px;background:rgba(10,10,16,.78);backdrop-filter:blur(14px);box-shadow:0 1px 0 rgba(255,255,255,.06)}
.logo{color:#fff;font-family:"Sora",sans-serif;font-weight:800;font-size:1.22rem;letter-spacing:.01em;text-decoration:none;display:inline-flex;align-items:center}
.logo img{height:22px;width:auto;display:block}
.fl img{height:20px;width:auto;display:block;margin-bottom:14px}
.logo b{background:linear-gradient(90deg,var(--a1),var(--a2));-webkit-background-clip:text;background-clip:text;color:transparent}
header nav{display:flex;align-items:center;gap:30px}
header nav a{color:#fff;text-decoration:none;font-size:.83rem;letter-spacing:.04em}
header nav a:not(.navcta){position:relative;opacity:.9}
header nav a:not(.navcta):after{content:"";position:absolute;left:0;bottom:-5px;width:100%;height:1px;background:#fff;transform:scaleX(0);transform-origin:right;transition:transform .4s var(--ease)}
header nav a:not(.navcta):hover:after{transform:scaleX(1);transform-origin:left}
header .navcta{border:1px solid rgba(255,255,255,.42);padding:9px 22px;border-radius:40px;font-weight:700;font-size:.78rem;transition:.25s}
header .navcta:hover{background:#fff;color:var(--ink)}
@media(max-width:880px){header nav a:not(.navcta){display:none}header{padding:16px 22px}}

/* hero */
.hero{background:var(--bg);color:#fff;padding:178px 0 132px;overflow:hidden}
.hero .blob{position:absolute;border-radius:50%;filter:blur(18px);z-index:0;animation:drift 16s ease-in-out infinite;will-change:transform}
.hero .b1{width:580px;height:580px;background:radial-gradient(circle,rgba(108,76,255,.55),transparent 62%);top:-200px;right:-130px}
.hero .b2{width:540px;height:540px;background:radial-gradient(circle,rgba(255,79,139,.4),transparent 62%);bottom:-240px;left:-160px;animation-delay:-7s}
@keyframes drift{0%,100%{transform:translate(0,0)}50%{transform:translate(32px,-28px)}}
.hero .wrap{position:relative;z-index:3}
.hgrid{display:grid;grid-template-columns:1.05fr .95fr;gap:34px;align-items:center}
.tagline{display:inline-flex;align-items:center;gap:9px;border:1px solid rgba(255,255,255,.25);font-size:.76rem;padding:8px 18px;border-radius:40px;letter-spacing:.12em;margin-bottom:30px;opacity:0;animation:up 1s var(--ease) .05s forwards}
.tagline i{width:7px;height:7px;border-radius:50%;background:linear-gradient(135deg,var(--a1),var(--a2));box-shadow:0 0 10px rgba(255,79,139,.8)}
.hero h1{font-size:clamp(2.2rem,6.2vw,3.5rem);font-weight:900;line-height:1.32;letter-spacing:.02em}
.hero h1 .ln{display:block;overflow:hidden;padding-bottom:.06em}
.hero h1 .in{display:block;transform:translateY(110%);animation:rise 1.15s cubic-bezier(.16,.84,.34,1) .28s forwards}
.hero h1 em{font-style:normal}
@keyframes rise{to{transform:none}}
.hero p{margin:28px 0 40px;max-width:560px;font-size:1.05rem;opacity:0;animation:up 1s var(--ease) .5s forwards}
.hbtns{display:flex;gap:14px;flex-wrap:wrap;opacity:0;animation:up 1s var(--ease) .64s forwards}
.hmeta{display:flex;gap:26px;margin-top:34px;opacity:0;animation:up 1s var(--ease) .8s forwards}
.hmeta div{font-size:.78rem;opacity:.66;letter-spacing:.04em}
.hmeta b{display:block;font-family:"Sora",sans-serif;font-weight:700;font-size:.92rem;opacity:1;color:#fff;margin-bottom:2px}
@keyframes up{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:none}}
.scrollcue{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);z-index:3;font-family:"Sora",sans-serif;font-size:.62rem;letter-spacing:.3em;color:rgba(255,255,255,.55);text-align:center}
.scrollcue i{display:block;width:1px;height:44px;background:linear-gradient(rgba(255,255,255,.6),transparent);margin:8px auto 0;animation:cue 1.9s ease-in-out infinite}
@keyframes cue{0%,100%{transform:scaleY(.35);transform-origin:top;opacity:.4}50%{transform:scaleY(1);opacity:1}}

/* phone */
.hvis{position:relative;display:flex;justify-content:flex-end;align-items:center;padding-right:8px}
.pwrap{position:relative;width:286px;opacity:0;animation:up 1.15s .55s var(--ease) forwards}
.phone{position:relative;width:286px;height:586px;border-radius:46px;background:linear-gradient(#16161e,#0a0a0f);padding:11px;box-shadow:0 44px 100px rgba(0,0,0,.62),inset 0 0 0 2px rgba(255,255,255,.07);transform:rotate(3deg);transition:transform .25s ease-out;will-change:transform}
.phone .screen{position:relative;width:100%;height:100%;border-radius:36px;overflow:hidden;background:#0c0a18}
.island{position:absolute;top:12px;left:50%;transform:translateX(-50%);width:92px;height:24px;background:#000;border-radius:20px;z-index:8}
.tt-video{position:absolute;inset:0;background:radial-gradient(120% 75% at 50% 8%,rgba(108,76,255,.22),transparent 52%),radial-gradient(130% 80% at 82% 96%,rgba(255,79,139,.16),transparent 55%),#07070c}
.tt-media{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.tt-video:after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(to bottom,rgba(0,0,0,.36),transparent 26%,transparent 48%,rgba(0,0,0,.68))}
.tt-trend{position:absolute;top:74px;left:14px;z-index:5;display:inline-flex;align-items:center;gap:5px;background:rgba(0,0,0,.42);backdrop-filter:blur(4px);color:#fff;font-size:11px;font-weight:700;padding:5px 11px;border-radius:30px;border:1px solid rgba(255,255,255,.16)}
.tt-top{position:absolute;top:44px;left:0;right:0;z-index:5;display:flex;justify-content:center;align-items:center;gap:18px;color:#fff}
.tt-top span{font-size:13px;opacity:.62;font-weight:500}
.tt-top span.on{opacity:1;font-weight:700;position:relative}
.tt-top span.on:after{content:"";position:absolute;left:50%;transform:translateX(-50%);bottom:-7px;width:18px;height:3px;border-radius:3px;background:#fff}
.tt-top .srch{position:absolute;right:16px;top:-1px;width:20px;height:20px;opacity:.92}
.tt-rail{position:absolute;right:12px;bottom:98px;z-index:5;display:flex;flex-direction:column;align-items:center;gap:17px;color:#fff}
.tt-rail .ic{display:flex;flex-direction:column;align-items:center;gap:3px}
.tt-rail .ic svg{width:30px;height:30px;filter:drop-shadow(0 1px 2px rgba(0,0,0,.45))}
.tt-rail .ic small{font-size:11px;font-weight:600}
.tt-ava{position:relative;width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,#6c4cff,#ff4f8b);border:2px solid #fff;margin-bottom:6px}
.tt-ava b{position:absolute;bottom:-8px;left:50%;transform:translateX(-50%);width:18px;height:18px;border-radius:50%;background:#fe2c55;color:#fff;font-size:13px;line-height:16px;text-align:center;border:1px solid #fff;font-weight:700}
.tt-disc{width:40px;height:40px;border-radius:50%;background:conic-gradient(#2a2540,#050507 70%);display:flex;align-items:center;justify-content:center;animation:spin 4s linear infinite;margin-top:4px}
.tt-disc:after{content:"";width:14px;height:14px;border-radius:50%;background:linear-gradient(135deg,#6c4cff,#ff4f8b)}
@keyframes spin{to{transform:rotate(360deg)}}
.tt-caption{position:absolute;left:16px;right:72px;bottom:78px;z-index:5;color:#fff}
.tt-caption .u{font-weight:700;font-size:14px;margin-bottom:6px}
.tt-caption .c{font-size:12.5px;line-height:1.6;opacity:.96}
.tt-caption .m{display:flex;align-items:center;gap:6px;font-size:12px;margin-top:9px;opacity:.96}
.tt-caption .m svg{width:13px;height:13px}
.tt-nav{position:absolute;left:0;right:0;bottom:0;height:52px;background:#000;display:flex;align-items:center;justify-content:space-around;z-index:6}
.tt-nav>svg{width:23px;height:23px;opacity:.85;fill:#fff}
.tt-nav .plus{position:relative;width:42px;height:27px;border-radius:8px;background:#fff;display:flex;align-items:center;justify-content:center}
.tt-nav .plus:before,.tt-nav .plus:after{content:"";position:absolute;background:#111}
.tt-nav .plus:before{width:13px;height:4px;border-radius:2px}
.tt-nav .plus:after{width:4px;height:13px;border-radius:2px}
.tt-nav .plus i{position:absolute;left:-3px;top:0;width:6px;height:100%;background:#25f4ee;border-radius:8px 0 0 8px}
.tt-nav .plus em{position:absolute;right:-3px;top:0;width:6px;height:100%;background:#fe2c55;border-radius:0 8px 8px 0}
.float-card{position:absolute;background:rgba(255,255,255,.95);backdrop-filter:blur(6px);border-radius:14px;padding:11px 15px;box-shadow:0 18px 44px rgba(0,0,0,.34);z-index:7;color:var(--ink)}
.float-card .ttl{font-size:11px;color:var(--muted);font-weight:600}
.float-card .v{font-family:"Sora",sans-serif;font-weight:800;font-size:1.12rem;line-height:1.2}
.f1{top:52px;left:-24px;animation:flo 5s ease-in-out infinite}
.f2{bottom:72px;right:-24px;animation:flo 6s ease-in-out infinite}
@keyframes flo{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
@media(max-width:920px){
  .hero{padding:148px 0 108px}
  .hgrid{grid-template-columns:1fr}
  .hero .hcopy,.hero .tagline{text-align:left}
  .hero p{margin-left:0;max-width:none}
  .hvis{display:none}
  .scrollcue{display:none}
}
@media(max-width:520px){.phone{transform:rotate(2deg) scale(.86);margin:-18px 0}.f1{left:6px}.f2{right:6px}.hmeta{gap:18px}}

/* marquee */
.marq{overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:22px 0;background:var(--soft);position:relative}
.marq:before,.marq:after{content:"";position:absolute;top:0;bottom:0;width:90px;z-index:2}
.marq:before{left:0;background:linear-gradient(90deg,var(--soft),transparent)}
.marq:after{right:0;background:linear-gradient(270deg,var(--soft),transparent)}
.marq .track{display:flex;width:max-content;white-space:nowrap;animation:scrollx 30s linear infinite}
.marq:hover .track{animation-play-state:paused}
.marq .track span{font-family:"Sora",sans-serif;font-weight:700;font-size:1.06rem;color:#6b7280;padding:0 26px;letter-spacing:.05em}
.marq .track span.g{background:linear-gradient(90deg,var(--a1),var(--a2));-webkit-background-clip:text;background-clip:text;color:transparent;font-size:.7rem}
@keyframes scrollx{to{transform:translateX(-50%)}}

/* about */
.about{position:relative;color:#fff;background:var(--bg);overflow:hidden;padding:clamp(104px,12vw,164px) 0}
.about .abg{position:absolute;inset:0;z-index:0}
.about .abg img{width:100%;height:100%;object-fit:cover}
.about .abg:after{content:"";position:absolute;inset:0;background:linear-gradient(110deg,rgba(8,8,14,.94) 6%,rgba(8,8,14,.74) 50%,rgba(42,15,36,.82)),radial-gradient(120% 95% at 88% 12%,rgba(108,76,255,.3),transparent 56%)}
.about .wrap{position:relative;z-index:2}
.about .ix{color:rgba(255,255,255,.72)}
.about h2{color:#fff}
.about .msg{font-size:clamp(1.7rem,4.2vw,2.45rem);font-weight:900;line-height:1.6;letter-spacing:.02em;color:#fff;margin-top:10px;max-width:17em}
.about .body{margin-top:28px;max-width:660px;color:rgba(255,255,255,.85);font-size:1.04rem}
.about .apill{display:inline-flex;align-items:center;gap:9px;margin-top:36px;border:1px solid rgba(255,255,255,.3);background:rgba(255,255,255,.07);backdrop-filter:blur(6px);border-radius:40px;padding:10px 19px;font-family:"Sora",sans-serif;font-weight:700;font-size:.74rem;letter-spacing:.06em;color:#fff}
.about .apill i{width:7px;height:7px;border-radius:50%;flex:0 0 auto;background:linear-gradient(135deg,var(--a1),var(--a2));box-shadow:0 0 8px rgba(255,79,139,.7)}

/* data band */
.data{background:var(--bg);color:#fff;overflow:hidden}
.data .blob{position:absolute;width:460px;height:460px;border-radius:50%;background:radial-gradient(circle,rgba(108,76,255,.32),transparent 62%);bottom:-220px;right:-120px;z-index:0;filter:blur(20px)}
.sgr{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center}
@media(max-width:780px){.sgr{grid-template-columns:1fr 1fr;gap:40px 20px}}
.stat .n{font-family:"Zen Kaku Gothic New",sans-serif;font-weight:900;font-size:clamp(2.4rem,5.6vw,3.2rem);line-height:1.05;display:inline-flex;align-items:baseline;gap:1px;background:linear-gradient(90deg,var(--a1),var(--a2));-webkit-background-clip:text;background-clip:text;color:transparent}
.stat .n .u{font-size:.46em;font-weight:800;margin-left:2px}
.stat .l{font-size:.85rem;opacity:.68;margin-top:14px;letter-spacing:.03em;line-height:1.6}

/* service */
.service{background:var(--soft)}
.flag{background:#fff;border:1px solid var(--line);border-radius:24px;padding:clamp(32px,5vw,52px);margin-bottom:26px;position:relative;overflow:hidden}
.flag:before{content:"";position:absolute;top:0;left:0;width:100%;height:4px;background:linear-gradient(90deg,var(--a1),var(--a2))}
.flag .badge{display:inline-block;background:linear-gradient(90deg,var(--a1),var(--a2));color:#fff;font-family:"Sora",sans-serif;font-weight:700;font-size:.72rem;padding:6px 16px;border-radius:30px;letter-spacing:.08em}
.flag h3{font-size:clamp(1.6rem,4vw,2.1rem);font-weight:900;margin:18px 0 4px}
.flag .cap{font-weight:700;margin-bottom:16px}
.flag p{font-size:.95rem;color:#2e333c;max-width:780px}
.sgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:860px){.sgrid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.sgrid{grid-template-columns:1fr}}
.scard{background:#fff;border:1px solid var(--line);border-radius:18px;padding:32px 28px;overflow:hidden;transition:transform .35s var(--ease),box-shadow .35s var(--ease),border-color .35s}
.scard:hover{transform:translateY(-8px);box-shadow:0 28px 60px rgba(20,20,40,.1);border-color:rgba(108,76,255,.3)}
.sthumb{aspect-ratio:16/9;margin:-32px -28px 24px;background:linear-gradient(135deg,#1a1430,#0c0a18);overflow:hidden}
.sthumb img{width:100%;height:100%;object-fit:cover;transition:transform .55s var(--ease)}
.scard:hover .sthumb img{transform:scale(1.06)}
.sic{width:52px;height:52px;border-radius:15px;background:linear-gradient(135deg,rgba(108,76,255,.12),rgba(255,79,139,.12));display:flex;align-items:center;justify-content:center;margin-bottom:20px;color:var(--a1);transition:.35s}
.scard:hover .sic{background:linear-gradient(135deg,var(--a1),var(--a2));color:#fff}
.sic svg{width:25px;height:25px}
.scard h4{font-size:1.14rem;font-weight:700;margin-bottom:9px}
.scard p{font-size:.89rem;color:var(--muted)}

/* process */
.proc{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;position:relative}
.proc:before{content:"";position:absolute;top:28px;left:12.5%;right:12.5%;height:1px;background:linear-gradient(90deg,rgba(108,76,255,.25),rgba(255,79,139,.25));z-index:0}
.pstep{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;text-align:center}
.pn{width:56px;height:56px;flex:0 0 auto;border-radius:50%;border:1px solid var(--line);background:#fff;display:flex;align-items:center;justify-content:center;font-family:"Sora",sans-serif;font-weight:800;color:var(--a1);margin:0 0 20px;transition:.35s}
.pstep:hover .pn{background:linear-gradient(135deg,var(--a1),var(--a2));color:#fff;border-color:transparent;transform:translateY(-4px)}
.pbody .pe{display:block;font-family:"Sora",sans-serif;font-size:.68rem;letter-spacing:.2em;color:var(--muted);font-weight:600}
.pbody h4{font-size:1.12rem;font-weight:700;margin:8px 0}
.pbody p{font-size:.88rem;color:var(--muted)}
@media(max-width:780px){
  .proc{grid-template-columns:1fr;gap:30px;max-width:460px;margin:0 auto}
  .proc:before{top:10px;bottom:10px;left:27px;right:auto;width:1px;height:auto}
  .pstep{flex-direction:row;align-items:flex-start;text-align:left;gap:22px}
  .pn{margin:0}
  .pbody{padding-top:2px}
  .pbody h4{margin:5px 0 7px}
}

/* strength */
.strength{background:var(--soft)}
.rgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
@media(max-width:860px){.rgrid{grid-template-columns:1fr}}
.ritem{background:#fff;border:1px solid var(--line);border-radius:18px;padding:36px 30px;transition:transform .35s var(--ease),box-shadow .35s var(--ease)}
.ritem:hover{transform:translateY(-8px);box-shadow:0 28px 60px rgba(20,20,40,.1)}
.ritem .no{font-family:"Sora",sans-serif;font-weight:800;font-size:1.05rem;background:linear-gradient(90deg,var(--a1),var(--a2));-webkit-background-clip:text;background-clip:text;color:transparent}
.ritem h3{font-size:1.18rem;font-weight:700;margin:14px 0 10px;line-height:1.5}
.ritem p{font-size:.9rem;color:var(--muted)}

/* news */
.feedbox{border:1px dashed #cfd2dd;border-radius:18px;padding:46px;text-align:center;color:var(--muted);background:var(--soft)}
.sns{display:flex;gap:14px;justify-content:center;margin-top:22px;flex-wrap:wrap}
.sns a{text-decoration:none;border:1px solid var(--line);border-radius:40px;padding:11px 24px;color:var(--ink);font-weight:700;font-size:.86rem;transition:.25s}
.sns a:hover{border-color:var(--a1);color:var(--a1);transform:translateY(-2px)}

/* company */
.company{background:var(--soft)}
.ctable{border-collapse:collapse;width:100%;max-width:860px}
.ctable th,.ctable td{text-align:left;padding:19px 8px;border-bottom:1px solid var(--line);font-size:.94rem;vertical-align:top}
.ctable th{width:30%;font-weight:700}
.ctable td{color:#2e333c}

/* column */
.colgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
@media(max-width:860px){.colgrid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.colgrid{grid-template-columns:1fr}}
.colcard{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:18px;overflow:hidden;text-decoration:none;color:var(--ink);transition:transform .35s var(--ease),box-shadow .35s var(--ease),border-color .35s}
.colcard:hover{transform:translateY(-8px);box-shadow:0 28px 60px rgba(20,20,40,.1);border-color:rgba(108,76,255,.3)}
.colthumb{aspect-ratio:16/9;background:linear-gradient(135deg,#1a1430,#0c0a18);overflow:hidden}
.colthumb img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.colcard:hover .colthumb img{transform:scale(1.05)}
.colbody{padding:22px 22px 26px;display:flex;flex-direction:column;flex:1}
.colmeta{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.coltag{display:inline-block;background:linear-gradient(90deg,var(--a1),var(--a2));color:#fff;font-weight:700;font-size:.64rem;letter-spacing:.06em;padding:5px 12px;border-radius:30px}
.coldate{font-size:.74rem;color:var(--muted);letter-spacing:.04em}
.coltitle{font-size:1.02rem;font-weight:700;line-height:1.6}
.colmore{text-align:center;margin-top:44px}

/* cta band */
.cta{background:linear-gradient(120deg,#150f33,#0c0a18 55%,#2a0f24);color:#fff;text-align:center;overflow:hidden}
.cta .blob{position:absolute;width:520px;height:520px;border-radius:50%;background:radial-gradient(circle,rgba(108,76,255,.4),transparent 60%);top:-180px;left:50%;transform:translateX(-50%);z-index:0;filter:blur(20px)}
.cta h2{font-size:clamp(1.8rem,4.6vw,2.6rem);color:#fff}
.cta p{margin:18px auto 36px;max-width:560px;opacity:.84}

/* contact */
.cform{max-width:660px;background:#fff;border:1px solid var(--line);border-radius:22px;padding:clamp(30px,5vw,46px);box-shadow:0 24px 60px rgba(20,20,40,.06)}
.contact .intro{max-width:620px;color:var(--muted);margin-bottom:38px}
.cform label{display:block;font-size:.84rem;font-weight:700;margin:18px 0 7px}
.cform label span{color:var(--a2)}
.cform input,.cform select,.cform textarea{width:100%;border:1px solid var(--line);border-radius:11px;padding:13px 15px;font-family:inherit;font-size:.95rem;background:#fcfcff;transition:.2s}
.cform input:focus,.cform select:focus,.cform textarea:focus{outline:none;border-color:var(--a1);background:#fff;box-shadow:0 0 0 4px rgba(108,76,255,.1)}
.cform textarea{min-height:140px;resize:vertical}
.cform .submit{margin-top:30px;width:100%;border:none;cursor:pointer;color:#fff;background:linear-gradient(90deg,var(--a1),var(--a2));font-weight:700;font-size:1rem;padding:17px;border-radius:50px;transition:transform .25s var(--ease),box-shadow .25s}
.cform .submit:hover{transform:translateY(-3px);box-shadow:0 16px 38px rgba(108,76,255,.36)}
.cform .pp{font-size:.78rem;color:var(--muted);text-align:center;margin-top:16px}

/* footer */
footer{background:#07070c;color:rgba(255,255,255,.6);padding:70px 26px 36px;overflow:hidden}
.fgrid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;max-width:1160px;margin:0 auto}
@media(max-width:760px){.fgrid{grid-template-columns:1fr;gap:30px}}
.fgrid .fl{color:#fff;font-family:"Sora",sans-serif;font-weight:800;font-size:1.4rem;margin-bottom:14px}
.fgrid p{font-size:.84rem;line-height:1.9;max-width:320px}
.fcol h5{color:#fff;font-family:"Sora",sans-serif;font-size:.74rem;letter-spacing:.2em;margin-bottom:16px;font-weight:700}
.fcol a{display:block;color:rgba(255,255,255,.6);text-decoration:none;font-size:.86rem;padding:5px 0;transition:.2s}
.fcol a:hover{color:#fff;padding-left:5px}
.fbot{max-width:1160px;margin:46px auto 0;padding-top:24px;border-top:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:.78rem;opacity:.55}

@media (prefers-reduced-motion: reduce){
  *{animation:none!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  .js .reveal{opacity:1!important;transform:none!important}
  .hero h1 .in,.tagline,.hero p,.hbtns,.hmeta,.pwrap{opacity:1!important;transform:none!important}
}
