:root{
  --ink:#171a2f;--ink-deep:#10122a;--paper:#f4eeff;--lav:#d9c6ff;
  --indigo:#4541fe;--indigo-soft:#6f6bff;--pink:#ff4d97;
  --dim-on-dark:#a6abc4;--dim-on-light:#5d5775;--card-line:rgba(20,20,50,.08);
  --ease:cubic-bezier(.16,1,.3,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:"Inter","Zen Kaku Gothic New",system-ui,sans-serif;color:var(--ink);background:var(--ink);-webkit-font-smoothing:antialiased;line-height:1.7;overflow-x:hidden}
a{color:inherit;text-decoration:none}
::selection{background:var(--indigo);color:#fff}
.wrap{max-width:1180px;margin:0 auto;padding:0 40px}
.jp{font-family:"Zen Kaku Gothic New","Inter",sans-serif}

/* ===== PAGE LOADER ===== */
#loader{position:fixed;inset:0;z-index:200;background:var(--ink-deep);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:22px;transition:opacity .7s var(--ease),visibility .7s}
#loader.done{opacity:0;visibility:hidden}
#loader .lgo{font-family:"Inter";font-weight:800;letter-spacing:.22em;color:#fff;font-size:20px;display:flex;align-items:center;gap:10px;opacity:.9}
#loader .lgo .dot{width:10px;height:10px;border-radius:50%;background:linear-gradient(120deg,var(--pink),var(--indigo));animation:pulse 1.4s infinite}
#loader .barwrap{width:160px;height:3px;border-radius:3px;background:rgba(255,255,255,.12);overflow:hidden}
#loader .barwrap i{display:block;height:100%;width:40%;border-radius:3px;background:linear-gradient(90deg,var(--pink),var(--indigo),var(--indigo-soft));animation:load 1.1s var(--ease) infinite}
@keyframes load{0%{transform:translateX(-120%)}100%{transform:translateX(320%)}}
@keyframes pulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(.6);opacity:.45}}

/* ===== TOPBAR / HEADER ===== */
.topbar{background:linear-gradient(90deg,var(--pink),var(--indigo),var(--pink));background-size:200% 100%;animation:slidebg 6s linear infinite;color:#fff;font-size:13px;text-align:center;padding:9px 16px;letter-spacing:.02em;font-weight:500}
@keyframes slidebg{to{background-position:200% 0}}
header{position:sticky;top:0;z-index:50;display:flex;align-items:center;justify-content:space-between;padding:18px 40px;background:rgba(23,26,47,.72);backdrop-filter:blur(12px);transition:padding .35s var(--ease),background .35s}
header.tight{padding:12px 40px;background:rgba(16,18,42,.9)}
.logo{font-family:"Inter";font-weight:800;letter-spacing:.12em;font-size:19px;color:#fff;display:flex;align-items:center;gap:9px}
.logo .dot{width:9px;height:9px;border-radius:50%;background:linear-gradient(120deg,var(--pink),var(--indigo));animation:pulse 2.2s infinite}
.logo img{height:24px;width:auto;display:block}
.menu-logo img{height:24px;width:auto;display:block}
#loader .lgo img{height:30px;width:auto;display:block}
footer .logo img{height:24px;width:auto;display:block}
nav{display:flex;gap:30px;align-items:center;font-size:14px;color:rgba(255,255,255,.72);font-weight:500}
nav a:not(.cta){position:relative}
nav a:not(.cta)::after{content:"";position:absolute;left:0;bottom:-5px;width:0;height:2px;background:var(--indigo-soft);transition:width .3s var(--ease)}
nav a:not(.cta):hover{color:#fff}nav a:not(.cta):hover::after{width:100%}
nav a.active{color:#fff}
nav .cta{background:var(--indigo);color:#fff;padding:11px 22px;border-radius:40px;font-weight:600;transition:.3s;box-shadow:0 6px 22px rgba(69,65,254,.4)}
nav .cta:hover{background:var(--indigo-soft);transform:translateY(-2px)}

/* ===== hamburger button + fullscreen menu ===== */
.pagetitle{margin-left:auto;margin-right:20px;color:rgba(255,255,255,.85);font-size:14px;font-weight:700;letter-spacing:.04em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:48vw}
.menubtn{width:52px;height:52px;border-radius:50%;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.28);backdrop-filter:blur(6px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;cursor:pointer;transition:background .3s,transform .3s;padding:0;flex:0 0 auto}
.menubtn:hover{background:rgba(255,255,255,.18);transform:translateY(-1px)}
.menubtn span{display:block;width:22px;height:2px;background:#fff;border-radius:2px}
.menu{position:fixed;inset:0;z-index:100;gap:0;background:linear-gradient(150deg,#10122a,#1b1747 65%,#2a2480);display:flex;flex-direction:column;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity .45s var(--ease),visibility .45s}
.menu.open{opacity:1;visibility:visible}
.menu-logo{position:absolute;top:24px;left:40px;font-family:"Inter";font-weight:800;letter-spacing:.14em;color:#fff;font-size:19px;display:flex;align-items:center;gap:9px}
.menu-logo .dot{width:9px;height:9px;border-radius:50%;background:linear-gradient(120deg,var(--pink),var(--indigo))}
.menuclose{position:absolute;top:22px;right:36px;width:52px;height:52px;border-radius:50%;border:1px solid rgba(255,255,255,.28);background:rgba(255,255,255,.08);color:#fff;font-size:28px;line-height:1;cursor:pointer;transition:background .3s,transform .4s}
.menuclose:hover{background:rgba(255,255,255,.18);transform:rotate(90deg)}
.menu-inner{display:flex;flex-direction:column;gap:2px;text-align:center}
.menu-inner a{font-family:"Inter","Zen Kaku Gothic New";font-weight:800;font-size:clamp(22px,3.6vw,38px);color:#fff;letter-spacing:-.01em;padding:6px 16px;opacity:0;transform:translateY(24px);transition:opacity .5s var(--ease),transform .5s var(--ease),color .25s}
.menu-inner a::after{content:none}
.menu.open .menu-inner a{opacity:1;transform:none}
.menu-inner a:hover{color:var(--lav)}
.menu-inner a.active{background:linear-gradient(110deg,var(--pink),var(--indigo) 55%,#3fe0d0);-webkit-background-clip:text;background-clip:text;color:transparent}
.menu.open .menu-inner a:nth-child(1){transition-delay:.06s}
.menu.open .menu-inner a:nth-child(2){transition-delay:.10s}
.menu.open .menu-inner a:nth-child(3){transition-delay:.14s}
.menu.open .menu-inner a:nth-child(4){transition-delay:.18s}
.menu.open .menu-inner a:nth-child(5){transition-delay:.22s}
.menu.open .menu-inner a:nth-child(6){transition-delay:.26s}
.menu.open .menu-inner a:nth-child(7){transition-delay:.30s}
.menu.open .menu-inner a:nth-child(8){transition-delay:.34s}
@media(max-width:640px){.pagetitle{display:none}.menu-logo{left:20px}.menuclose{right:20px}}

/* ===== BUTTONS (with sliding arrow) ===== */
.btn{font-family:"Inter","Zen Kaku Gothic New";font-weight:600;font-size:15px;padding:16px 30px;border-radius:40px;transition:transform .3s var(--ease),background .3s;display:inline-flex;align-items:center;gap:8px;border:none;cursor:pointer;position:relative;overflow:hidden}
.btn::before{content:"";position:absolute;top:0;left:-120%;width:60%;height:100%;background:linear-gradient(110deg,transparent,rgba(255,255,255,.5),transparent);transform:skewX(-20deg);transition:left .6s var(--ease)}
.btn:hover::before{left:140%}
.btn .ar{display:inline-block;transition:transform .35s var(--ease)}
.btn:hover .ar{transform:translateX(5px)}
.btn-w{background:#fff;color:var(--ink)}.btn-w:hover{transform:translateY(-2px)}
.btn-i{background:var(--indigo);color:#fff}.btn-i:hover{background:var(--indigo-soft);transform:translateY(-2px)}
.btn-o{background:rgba(255,255,255,.06);color:#fff;border:1px solid rgba(255,255,255,.25)}.btn-o:hover{border-color:#fff;transform:translateY(-2px)}
.ghostpill{display:inline-flex;align-items:center;gap:9px;margin-top:36px;background:var(--indigo);color:#fff;font-weight:600;font-size:14px;padding:14px 28px;border-radius:40px;transition:transform .3s var(--ease),background .3s}
.slab.dark .ghostpill{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.25)}
.ghostpill .ar{display:inline-block;transition:transform .35s var(--ease)}
.ghostpill:hover{transform:translateY(-2px);background:var(--indigo-soft)}.ghostpill:hover .ar{transform:translateX(5px)}

/* ===== HERO ===== */
.hero{background:var(--ink);position:relative;overflow:hidden;padding:120px 0 70px;text-align:center}
.ribbon{position:absolute;inset:0;z-index:0;pointer-events:none;will-change:transform;overflow:hidden}
.ribbon video.wave{position:absolute;top:46%;left:50%;transform:translate(-50%,-50%);width:118%;min-width:1300px;height:auto;mix-blend-mode:screen;opacity:.88;-webkit-mask-image:radial-gradient(90% 62% at 50% 50%,#000 42%,transparent 92%);mask-image:radial-gradient(90% 62% at 50% 50%,#000 42%,transparent 92%)}
.hero::after{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;background:radial-gradient(60% 40% at 50% 42%,rgba(16,18,42,.45),transparent 70%)}
#spark{position:absolute;inset:0;z-index:1;pointer-events:none}
.hero-in{position:relative;z-index:2}
.pill{display:inline-flex;align-items:center;gap:9px;border:1px solid rgba(255,255,255,.2);border-radius:40px;padding:8px 18px;font-size:12.5px;letter-spacing:.08em;color:rgba(255,255,255,.85);background:rgba(255,255,255,.04)}
.pill .d{width:7px;height:7px;border-radius:50%;background:var(--lav);box-shadow:0 0 10px var(--lav);animation:pulse 1.8s infinite}
h1.hero-h{font-family:"Inter","Zen Kaku Gothic New";font-weight:900;font-size:clamp(48px,9vw,112px);line-height:1.0;letter-spacing:-.03em;color:#fff;margin:34px auto 28px;max-width:14em;text-shadow:0 4px 40px rgba(0,0,0,.3)}
.shine{background:linear-gradient(110deg,#fff 30%,var(--lav) 45%,#9fd0ff 55%,#fff 70%);background-size:220% 100%;-webkit-background-clip:text;background-clip:text;color:transparent;animation:shine 4s linear infinite}
@keyframes shine{to{background-position:-220% 0}}
.hero p.sub{font-size:clamp(15px,1.6vw,19px);color:#cfd3e6;max-width:560px;margin:0 auto 38px;text-shadow:0 2px 18px rgba(10,10,25,.5)}
.btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.braglabel{margin:64px 0 22px;color:rgba(255,255,255,.45);font-size:12px;letter-spacing:.18em;text-transform:uppercase}
.logos{display:flex;flex-wrap:wrap;justify-content:center;gap:18px 40px;align-items:center}
.logos .lg{font-family:"Inter";font-weight:800;letter-spacing:.04em;color:#fff;opacity:.5;font-size:17px;display:flex;align-items:center;gap:8px}
.logos .lg::before{content:"";width:18px;height:18px;border-radius:5px;background:linear-gradient(120deg,var(--pink),var(--indigo))}

/* ===== MARQUEE ===== */
.marquee{background:var(--ink);overflow:hidden;border-top:1px solid rgba(255,255,255,.07);border-bottom:1px solid rgba(255,255,255,.07);padding:20px 0}
.marquee .track{display:flex;gap:48px;white-space:nowrap;width:max-content;animation:scrollx 22s linear infinite;font-family:"Inter";font-weight:700;font-size:20px;color:rgba(255,255,255,.5)}
.marquee .track b{color:var(--lav);font-weight:800}
@keyframes scrollx{to{transform:translateX(-50%)}}

/* ===== SLABS ===== */
.slab{padding:140px 0;text-align:center;border-radius:46px 46px 0 0;margin-top:-30px;position:relative;z-index:3}
.slab.dark{background:var(--ink);color:#fff;border-radius:0;margin-top:0}
.slab.dark.grad{background:linear-gradient(180deg,var(--ink) 0%,#221e63 65%,#322ca8 100%)}
.slab.indigo{background:var(--indigo);color:#fff}
.slab.paper{background:var(--paper);color:var(--ink)}
.slab.lav{background:var(--lav);color:var(--ink)}
.eyebrow{font-family:"Inter";font-size:19px;font-weight:800;letter-spacing:.16em;text-transform:uppercase;opacity:.8;margin-bottom:26px}
.slab.paper .eyebrow{color:var(--indigo);opacity:1}
.huge{font-family:"Inter","Zen Kaku Gothic New";font-weight:900;font-size:clamp(32px,5.6vw,74px);line-height:1.06;letter-spacing:-.025em;max-width:16em;margin:0 auto}
.slab .sub{font-size:18px;margin-top:28px;opacity:.82;max-width:30em;margin-left:auto;margin-right:auto}
.page-hero{padding:150px 0 30px}

/* ===== 3D blobs / floating media ===== */
.blob3d{position:absolute;border-radius:46% 54% 60% 40%/55% 45% 55% 45%;filter:blur(2px);opacity:.9;z-index:0;pointer-events:none;background:conic-gradient(from 120deg,#4541fe,#ff4d97,#33a0ff,#a24bff,#4541fe);box-shadow:inset -20px -30px 60px rgba(0,0,0,.35),inset 20px 20px 50px rgba(255,255,255,.25);animation:spin 26s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-18px)}}

/* ===== device mockup ===== */
.stage{position:relative;margin-top:70px;display:flex;justify-content:center}
.device{position:relative;z-index:2;width:min(880px,92%);background:#fff;border-radius:16px;box-shadow:0 40px 90px rgba(30,20,80,.28);overflow:hidden;text-align:left;animation:floaty 7s ease-in-out infinite}
.device .bar{display:flex;align-items:center;gap:8px;padding:12px 16px;background:#f1eef9;border-bottom:1px solid var(--card-line)}
.device .bar i{width:11px;height:11px;border-radius:50%;display:inline-block}
.device .bar .r{background:#ff5f57}.device .bar .y{background:#febc2e}.device .bar .g{background:#28c840}
.device .bar .url{margin-left:14px;font-size:12px;color:#9a93b5;background:#fff;border:1px solid var(--card-line);border-radius:20px;padding:5px 14px}
.dash{display:grid;grid-template-columns:200px 1fr;min-height:380px}
.dash .side{background:#faf8ff;border-right:1px solid var(--card-line);padding:20px 16px;display:flex;flex-direction:column;gap:10px}
.dash .side .brand{font-weight:800;color:var(--indigo);font-size:14px;margin-bottom:10px;display:flex;align-items:center;gap:8px}
.dash .side .brand::before{content:"";width:16px;height:16px;border-radius:5px;background:linear-gradient(120deg,var(--pink),var(--indigo))}
.dash .side .item{font-size:13px;color:#6c6588;padding:8px 10px;border-radius:8px}
.dash .side .item.on{background:#ece6ff;color:var(--indigo);font-weight:700}
.dash .main{padding:24px}
.dash .main h4{font-size:15px;color:#2a2540;margin-bottom:16px}
.kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:18px}
.kpi{border:1px solid var(--card-line);border-radius:12px;padding:14px}
.kpi .l{font-size:11px;color:#9a93b5}
.kpi .v{font-size:22px;font-weight:800;color:#211c3a;margin-top:4px}
.kpi .v b{color:var(--indigo)}
.chart{border:1px solid var(--card-line);border-radius:12px;padding:16px;display:flex;align-items:flex-end;gap:10px;height:150px}
.chart .col{flex:1;border-radius:6px 6px 0 0;background:linear-gradient(180deg,var(--indigo-soft),var(--indigo));opacity:.85;height:10%;transition:height 1.1s var(--ease)}
.device.in .chart .col{height:var(--bh)}
.phone{position:absolute;right:6%;bottom:-30px;z-index:3;width:190px;height:390px;background:#0e1020;border-radius:34px;padding:10px;box-shadow:0 30px 70px rgba(20,10,60,.4);animation:floaty 6s ease-in-out infinite .8s}
.phone .scr{background:#fff;border-radius:26px;height:100%;overflow:hidden;padding:16px 14px}
.phone .notch{position:absolute;top:18px;left:50%;transform:translateX(-50%);width:60px;height:16px;background:#0e1020;border-radius:10px;z-index:2}
.phone h5{font-size:13px;color:var(--indigo);margin:14px 0 6px}
.phone .row{height:9px;border-radius:5px;background:#eee;margin:8px 0}
.phone .row.s{width:60%}
.phone .pillbtn{margin-top:16px;background:var(--indigo);color:#fff;text-align:center;font-size:12px;padding:9px;border-radius:20px;font-weight:700}

/* ===== photo band ===== */
.photoband{position:relative;min-height:78vh;display:flex;align-items:flex-end;overflow:hidden;background:#0e1020}
.photoband .ph{position:absolute;inset:0;background:linear-gradient(120deg,#2a2550,#4541fe 55%,#ff4d97);opacity:.9}
.photoband .ph::after{content:"写真（人物・現場）をここに ▶ 後で差替";position:absolute;inset:0;display:grid;place-items:center;color:rgba(255,255,255,.6);font-size:13px;letter-spacing:.1em}
.photoband .ov{position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(8,8,20,.75))}
.photoband .txt{position:relative;z-index:2;padding:0 0 70px;max-width:1180px;margin:0 auto;width:100%}
.photoband .txt .eyebrow{color:#fff;opacity:.85}
.photoband .txt h2{color:#fff;font-family:"Inter","Zen Kaku Gothic New";font-weight:900;font-size:clamp(34px,6vw,80px);line-height:1.03;letter-spacing:-.025em;max-width:13em}

/* ===== feature cards ===== */
.feat3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:60px;text-align:left}
.feat{background:rgba(255,255,255,.55);border:1px solid rgba(255,255,255,.6);border-radius:20px;padding:30px 28px;backdrop-filter:blur(6px)}
.slab.dark .feat{background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.1)}
.feat .ic{width:44px;height:44px;border-radius:12px;background:linear-gradient(135deg,var(--indigo),var(--pink));margin-bottom:16px}
.feat h3{font-family:"Zen Kaku Gothic New";font-weight:900;font-size:20px;margin-bottom:10px}
.feat p{font-size:14px;opacity:.82}

/* ===== service cards ===== */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:64px;text-align:left}
.c{border-radius:28px;padding:40px 32px;transition:transform .4s var(--ease),box-shadow .4s;min-height:320px;display:flex;flex-direction:column;background:#fff;border:1px solid var(--card-line)}
.c:nth-child(2){background:var(--lav);border-color:transparent}
.c:nth-child(3){background:var(--ink);color:#fff;border-color:transparent}
.c:hover{transform:translateY(-12px) scale(1.02) rotate(-.6deg);box-shadow:0 28px 56px rgba(40,30,90,.22)}
.c .n{font-family:"Inter";font-weight:800;font-size:14px;letter-spacing:.08em;opacity:.55}
.c h3{font-family:"Zen Kaku Gothic New";font-weight:900;font-size:22px;line-height:1.4;margin:auto 0 12px}
.c p{font-size:14px;opacity:.82}
.c .arrow{margin-top:20px;width:46px;height:46px;border-radius:50%;display:grid;place-items:center;background:rgba(69,65,254,.12);color:var(--indigo);font-size:18px;transition:transform .35s var(--ease)}
.c:nth-child(3) .arrow{background:rgba(255,255,255,.14);color:#fff}
.c:hover .arrow{transform:translate(5px,-5px) rotate(-8deg)}

/* ===== detailed service rows (service page) ===== */
.svc-row{display:grid;grid-template-columns:.8fr 1.2fr;gap:50px;padding:60px 0;border-top:1px solid var(--card-line);text-align:left;align-items:start}
.svc-row .idx{font-family:"Inter";font-weight:800;font-size:14px;color:var(--indigo);letter-spacing:.08em;margin-bottom:12px}
.svc-row h3{font-family:"Zen Kaku Gothic New";font-weight:900;font-size:clamp(24px,3vw,34px);line-height:1.3}
.svc-row .body p{color:var(--dim-on-light);margin-bottom:18px}
.svc-row ul{list-style:none;display:flex;flex-direction:column;gap:12px}
.svc-row li{display:flex;gap:12px;color:#3a3458;font-size:15px}
.svc-row li::before{content:"";flex:0 0 8px;height:8px;margin-top:9px;border-radius:50%;background:linear-gradient(120deg,var(--indigo),var(--pink))}

/* ===== stats ===== */
.stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:60px}
.stat-row .k{font-family:"Inter","Zen Kaku Gothic New";font-weight:900;font-size:clamp(34px,4.6vw,58px);line-height:1;letter-spacing:-.02em}
.stat-row .v{margin-top:10px;opacity:.78;font-size:14px}

/* ===== testimonials ===== */
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:60px;text-align:left}
.tcard{background:#fff;border:1px solid var(--card-line);border-radius:22px;padding:30px 28px}
.tcard .q{font-size:15px;color:#2c2745;line-height:1.8;margin-bottom:22px}
.tcard .who{display:flex;align-items:center;gap:12px}
.tcard .av{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--indigo),var(--pink))}
.tcard .nm{font-weight:700;font-size:14px}
.tcard .ro{font-size:12px;color:#9a93b5}

/* ===== blog ===== */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:60px;text-align:left}
.post{background:#fff;border:1px solid var(--card-line);border-radius:20px;overflow:hidden;transition:transform .35s var(--ease),box-shadow .35s}
.post:hover{transform:translateY(-8px);box-shadow:0 20px 44px rgba(40,30,90,.16)}
.post .th{height:160px;background:linear-gradient(135deg,var(--indigo),var(--pink))}
.post:nth-child(2) .th{background:linear-gradient(135deg,#33a0ff,var(--indigo))}
.post:nth-child(3) .th{background:linear-gradient(135deg,var(--pink),#a24bff)}
.post .bd{padding:22px}
.post .tag{font-size:11px;font-weight:700;letter-spacing:.08em;color:var(--indigo);text-transform:uppercase}
.post h3{font-family:"Zen Kaku Gothic New";font-weight:700;font-size:17px;margin:8px 0;line-height:1.5}
.post .dt{font-size:12px;color:#9a93b5}

/* ===== company table / message ===== */
.info-table{width:100%;border-collapse:collapse;margin-top:50px;text-align:left}
.info-table th,.info-table td{padding:22px 4px;border-bottom:1px solid var(--card-line);vertical-align:top}
.info-table th{width:210px;color:var(--dim-on-light);font-weight:700;font-size:12.5px;font-family:"Inter";letter-spacing:.1em;text-transform:uppercase}
.info-table td{font-size:15.5px}
.message{display:grid;grid-template-columns:.9fr 1.4fr;gap:50px;align-items:start;margin-top:30px;text-align:left}
.message .photo{width:100%;border-radius:20px;aspect-ratio:2/3;object-fit:cover;box-shadow:0 24px 60px rgba(30,20,80,.22);display:block}
.message .txt p{color:var(--dim-on-light);margin-bottom:18px}
.message .sign{margin-top:26px}.message .sign b{font-size:20px;font-family:"Zen Kaku Gothic New";display:block;margin-top:6px}

/* ===== contact form ===== */
.form{max-width:680px;margin:50px auto 0;text-align:left}
.field{margin-bottom:24px}
.field label{display:block;font-size:14px;color:var(--dim-on-light);margin-bottom:9px}
.field label .req{color:var(--indigo);margin-left:6px;font-size:12px}
.field input,.field textarea{width:100%;background:#fff;border:1px solid var(--card-line);border-radius:12px;padding:15px 18px;color:var(--ink);font-family:inherit;font-size:15px;transition:border .3s,box-shadow .3s}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--indigo);box-shadow:0 0 0 4px rgba(69,65,254,.1)}
.field textarea{min-height:150px;resize:vertical}
.field select{width:100%;background:#fff;border:1px solid var(--card-line);border-radius:12px;padding:15px 18px;font-family:inherit;font-size:15px;color:var(--ink)}
.checks{display:flex;flex-wrap:wrap;gap:12px}
.checks label{display:inline-flex;align-items:center;gap:9px;background:#fff;border:1px solid var(--card-line);border-radius:30px;padding:11px 18px;font-size:14px;cursor:pointer;transition:border .2s,box-shadow .2s}
.checks label:hover{border-color:var(--indigo)}
.checks input{accent-color:var(--indigo);width:16px;height:16px}
.contact-meta{display:flex;flex-wrap:wrap;gap:14px 50px;margin:50px auto 0;max-width:680px;color:var(--dim-on-light);font-size:15px;text-align:left}
.contact-meta b{color:var(--ink)}

/* ===== blog article ===== */
.article{max-width:760px;margin:0 auto;text-align:left}
.article .amETA,.article .ameta{display:flex;gap:12px;align-items:center;margin-bottom:18px;flex-wrap:wrap}
.article .cat{background:var(--indigo);color:#fff;padding:5px 14px;border-radius:20px;font-weight:700;font-size:12px;letter-spacing:.04em}
.article .date{color:var(--dim-on-light);font-size:13px}
.article .lead{font-size:17px;line-height:2;color:#3a3458;margin-bottom:8px}
.article h2{font-family:"Zen Kaku Gothic New";font-weight:900;font-size:23px;margin:44px 0 14px;color:var(--ink)}
.article h3{font-family:"Zen Kaku Gothic New";font-weight:700;font-size:18px;margin:30px 0 12px;color:var(--ink)}
.article p{font-size:16px;line-height:2;color:#3a3458;margin-bottom:18px}
.article ul{margin:12px 0 20px;padding:0;list-style:none}
.article li{font-size:15.5px;line-height:1.9;color:#3a3458;padding-left:20px;position:relative}
.article li::before{content:"";position:absolute;left:2px;top:13px;width:7px;height:7px;border-radius:50%;background:linear-gradient(120deg,var(--indigo),var(--pink))}
.article img{width:100%;border-radius:16px;margin:26px 0;box-shadow:0 16px 40px rgba(30,20,80,.15)}
.backlink{display:inline-flex;align-items:center;gap:8px;margin-top:50px;color:var(--indigo);font-weight:700;font-size:14px}

/* ===== legal / policy page ===== */
.legal{max-width:780px;margin:0 auto;text-align:left}
.legal .intro{font-size:16px;line-height:2;color:#3a3458;margin-bottom:10px}
.legal h3{font-family:"Zen Kaku Gothic New";font-weight:900;font-size:20px;margin:42px 0 14px;color:var(--ink)}
.legal p{font-size:15.5px;line-height:2;color:#3a3458;margin-bottom:14px}
.legal ul{margin:12px 0 18px;padding:0;list-style:none}
.legal li{font-size:15px;line-height:1.9;color:#3a3458;padding-left:20px;position:relative}
.legal li::before{content:"";position:absolute;left:2px;top:13px;width:7px;height:7px;border-radius:50%;background:linear-gradient(120deg,var(--indigo),var(--pink))}
.legal .infobox{margin-top:18px;background:#fff;border:1px solid var(--card-line);border-radius:16px;padding:24px 28px;font-size:15px;line-height:2}
.legal .infobox b{color:var(--ink)}
.legal .date{margin-top:24px;color:var(--dim-on-light);font-size:14px}

/* ===== footer ===== */
footer{background:var(--ink-deep);color:rgba(255,255,255,.55);padding:80px 40px 40px}
.fcols{max-width:1180px;margin:0 auto;display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px}
footer .logo{font-size:18px;margin-bottom:16px}
footer p.desc{font-size:13px;max-width:24em;line-height:1.8}
.fcol h6{color:#fff;font-size:13px;letter-spacing:.06em;margin-bottom:16px;font-weight:700}
.fcol a{display:block;font-size:13px;margin-bottom:10px;color:rgba(255,255,255,.55);transition:color .2s}
.fcol a:hover{color:#fff}
.fbottom{max-width:1180px;margin:50px auto 0;padding-top:24px;border-top:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:12px}

/* ===== body copy (statement paragraphs) ===== */
.bodycopy{max-width:40em;margin:34px auto 0;font-size:17px;line-height:2;opacity:.86;text-align:left}
.bodycopy p+p{margin-top:20px}
.bodycopy.lead-strong p:first-child{font-weight:700;opacity:1;font-size:19px}

/* ===== 4-card grid ===== */
.cards.four{grid-template-columns:repeat(4,1fr)}
.cards.four .c{min-height:290px}
.cards.four .c:nth-child(1){background:#fff;color:var(--ink)}
.cards.four .c:nth-child(2){background:var(--lav);color:var(--ink)}
.cards.four .c:nth-child(3){background:var(--indigo);color:#fff}
.cards.four .c:nth-child(4){background:var(--ink);color:#fff}
.cards.four .c:nth-child(3) .arrow,.cards.four .c:nth-child(4) .arrow{background:rgba(255,255,255,.16);color:#fff}
.cards.four .c h3{margin:14px 0 12px}
.cardlink{margin-top:auto;display:inline-flex;align-items:center;gap:8px;font-weight:800;font-size:14px;color:var(--indigo);padding-top:18px}
.cards.four .c:nth-child(3) .cardlink,.cards.four .c:nth-child(4) .cardlink{color:#fff}
.cardlink .ar{transition:transform .35s var(--ease)}
.c:hover .cardlink .ar{transform:translateX(6px)}

/* ===== "needs" chips (補助金セクション) ===== */
.needs{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:42px auto 0;text-align:left}
.needs div{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.22);border-radius:14px;padding:20px 22px;font-size:15px;line-height:1.7}
.badge-tag{display:inline-block;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.3);color:#fff;font-size:12px;font-weight:700;letter-spacing:.08em;padding:7px 16px;border-radius:30px;margin-bottom:22px}
@media(max-width:1100px){.cards.four{grid-template-columns:repeat(2,1fr)}}
@media(max-width:760px){.cards.four{grid-template-columns:1fr}.needs{grid-template-columns:1fr}}

/* ===== extra ambient motion ===== */
.slab{overflow:hidden}
.slab .wrap{position:relative;z-index:2}
.slab.indigo{background:linear-gradient(120deg,#4f4bff,#6e6aff,#4541fe);background-size:220% 220%;animation:slabflow 13s ease-in-out infinite}
.slab.dark.grad{animation:slabflowv 16s ease-in-out infinite;background-size:100% 220%}
@keyframes slabflow{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}
@keyframes slabflowv{0%,100%{background-position:50% 0%}50%{background-position:50% 100%}}
.deco{position:absolute;z-index:0;border-radius:46% 54% 60% 40%/55% 45% 55% 45%;filter:blur(46px);background:conic-gradient(from 120deg,#4541fe,#ff4d97,#33a0ff,#a24bff,#4541fe);animation:spin 30s linear infinite,glow 7s ease-in-out infinite;pointer-events:none}
@keyframes glow{0%,100%{opacity:var(--o,.25)}50%{opacity:calc(var(--o,.25) * .5)}}
.tagm{display:inline-flex;align-items:center;gap:7px;background:#fff;color:var(--indigo);font-size:12.5px;font-weight:800;letter-spacing:.03em;padding:6px 14px;border-radius:30px;width:fit-content;margin-bottom:14px;box-shadow:0 4px 14px rgba(0,0,0,.14)}
.tagm::before{content:"";width:7px;height:7px;border-radius:50%;background:linear-gradient(120deg,var(--pink),var(--indigo))}

/* ===== detail page: bullet list ===== */
.biglist{display:grid;grid-template-columns:repeat(2,1fr);gap:14px 44px;max-width:780px;margin:42px auto 0;text-align:left;list-style:none}
.biglist li{display:flex;gap:12px;font-size:15.5px;line-height:1.7}
.biglist li::before{content:"";flex:0 0 8px;height:8px;margin-top:9px;border-radius:50%;background:linear-gradient(120deg,var(--indigo),var(--pink))}
.biglist.one{grid-template-columns:1fr;max-width:640px}
.chips{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;max-width:820px;margin:40px auto 0}
.chips span{background:rgba(255,255,255,.5);border:1px solid var(--card-line);border-radius:30px;padding:10px 20px;font-size:14.5px;font-weight:600}
.slab.dark .chips span,.slab.indigo .chips span{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.22);color:#fff}

/* ===== detail page: process flow ===== */
.flow{display:grid;gap:12px;max-width:740px;margin:44px auto 0;text-align:left;counter-reset:step}
.flow .st{counter-increment:step;display:flex;gap:18px;align-items:center;padding:18px 24px;border-radius:14px;background:#fff;border:1px solid var(--card-line);color:var(--ink);font-size:15.5px;font-weight:600}
.flow .st::before{content:counter(step);flex:0 0 36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--indigo),var(--pink));color:#fff;display:grid;place-items:center;font-weight:800;font-size:15px}

/* ===== detail page: theme/plan cards ===== */
.themegrid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:54px;text-align:left}
.themecard{background:rgba(255,255,255,.55);border:1px solid var(--card-line);border-radius:18px;padding:28px 26px}
.slab.dark .themecard,.slab.indigo .themecard{background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.14)}
.themecard h4{font-family:"Zen Kaku Gothic New";font-weight:900;font-size:18px;margin-bottom:10px}
.themecard p{font-size:14px;opacity:.82;line-height:1.7}
.themegrid.two{grid-template-columns:repeat(2,1fr)}
@media(max-width:900px){.themegrid.two{grid-template-columns:1fr}}
@media(max-width:900px){.biglist{grid-template-columns:1fr}.themegrid{grid-template-columns:1fr}}

/* ===== images: card thumbnail / feature / gallery ===== */
.cards.four .c{padding:0 0 32px;overflow:hidden}
.cards.four .c .thumb{display:block;height:150px;background-size:cover;background-position:center}
.cards.four .c .n{margin-top:22px}
.cards.four .c > :not(.thumb){padding-left:30px;padding-right:30px}
.feature-img{width:100%;max-width:920px;margin:50px auto 0;border-radius:24px;display:block;box-shadow:0 30px 70px rgba(30,20,80,.28);aspect-ratio:16/10;object-fit:cover}
.imgrow{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;max-width:920px;margin:50px auto 0}
.imgrow figure{margin:0;border-radius:18px;overflow:hidden;box-shadow:0 18px 40px rgba(30,20,80,.2);background:#fff}
.imgrow img{width:100%;height:200px;object-fit:cover;display:block}
.imgrow figcaption{padding:14px 18px;font-size:14px;font-weight:700;text-align:left;color:var(--ink)}
@media(max-width:760px){.imgrow{grid-template-columns:1fr}}

/* ===== 3D-ish floating shapes ===== */
.px{position:absolute;z-index:1;pointer-events:none;will-change:transform}
.sphere{display:block;border-radius:50%;background:radial-gradient(circle at 33% 27%,#fff 0%,#c3b4ff 16%,#6a66ff 46%,#36309e 100%);box-shadow:0 30px 60px rgba(40,20,90,.45),inset -8px -12px 26px rgba(0,0,0,.35);animation:floaty 7s ease-in-out infinite}
.sphere.pink{background:radial-gradient(circle at 33% 27%,#fff 0%,#ffbcd8 16%,#ff4d97 48%,#b81f60 100%)}
.sphere.cyan{background:radial-gradient(circle at 33% 27%,#fff 0%,#bfeaff 16%,#33a0ff 48%,#1d63b8 100%)}
.ring{display:block;border-radius:50%;border:16px solid transparent;background:linear-gradient(#11132a,#11132a) padding-box,conic-gradient(from 0deg,var(--pink),var(--indigo),#33a0ff,var(--pink)) border-box;box-shadow:0 24px 50px rgba(40,20,90,.4);animation:spin 16s linear infinite}
.cone{display:block;background:linear-gradient(160deg,#ff7db0,#5b54ff);clip-path:polygon(50% 0,100% 100%,0 100%);filter:drop-shadow(0 18px 22px rgba(40,20,90,.45));animation:floaty 6.5s ease-in-out infinite}

/* ===== live product mock cursor ===== */
.device{position:relative}
.cursor{position:absolute;top:0;left:0;z-index:6;pointer-events:none;transition:transform 1.3s var(--ease)}
.cursor::after{content:"";position:absolute;left:-7px;top:-7px;width:30px;height:30px;border-radius:50%;border:2px solid var(--indigo);opacity:0;animation:clickpulse 1.9s ease-in-out infinite}
@keyframes clickpulse{0%,68%{opacity:0;transform:scale(.4)}80%{opacity:.7;transform:scale(1)}100%{opacity:0;transform:scale(1.5)}}
.kpi .v{transition:color .3s}

@media(max-width:760px){.px{display:none}}

/* ===== ANIMATION UTILITIES (faithful Webflow-style) ===== */
.reveal{opacity:0;transform:translateY(48px);transition:opacity 1s var(--ease),transform 1s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal-media{clip-path:inset(0 0 100% 0);transform:scale(1.05);transition:clip-path 1.15s var(--ease),transform 1.15s var(--ease)}
.reveal-media.in{clip-path:inset(0 0 0 0);transform:scale(1)}
[data-parallax]{will-change:transform}
@media(prefers-reduced-motion:reduce){.reveal,.reveal-media{transition:none;opacity:1;transform:none;clip-path:none}}

@media(max-width:900px){
  header,.wrap,footer,.topbar{padding-left:20px;padding-right:20px}
  nav a:not(.cta){display:none}
  .cards,.feat3,.testi-grid,.blog-grid,.fcols,.svc-row,.message{grid-template-columns:1fr}
  .stat-row{grid-template-columns:repeat(2,1fr)}
  .slab{padding:90px 0;border-radius:34px 34px 0 0}
  .phone{display:none}.dash{grid-template-columns:1fr}.dash .side{display:none}
  .info-table th{width:120px}
}
