:root{--accent:#d20b19;--accent-deep:#9f0712;--accent-rgb:210,11,25;--ink:#101116;--muted:#6b7280;--line:rgba(16,17,22,.12);--paper:#fff;--soft:#f4f5f7;--dark:#111217;--font-en:'Inter',system-ui,sans-serif;--font-jp:'Noto Sans JP',system-ui,sans-serif}
body.nk-color-nkred{--accent:#d20b19;--accent-deep:#9f0712;--accent-rgb:210,11,25}body.nk-color-crimson{--accent:#b60022;--accent-deep:#7f0018;--accent-rgb:182,0,34}body.nk-color-scarlet{--accent:#ef233c;--accent-deep:#b81428;--accent-rgb:239,35,60}body.nk-color-wine{--accent:#8b1e3f;--accent-deep:#5b1028;--accent-rgb:139,30,63}body.nk-color-orange{--accent:#f05a24;--accent-deep:#b63b12;--accent-rgb:240,90,36}body.nk-color-amber{--accent:#ff9f1c;--accent-deep:#b86f08;--accent-rgb:255,159,28}body.nk-color-gold{--accent:#c9a227;--accent-deep:#8e7010;--accent-rgb:201,162,39}body.nk-color-lime{--accent:#89c540;--accent-deep:#5f8e24;--accent-rgb:137,197,64}body.nk-color-green{--accent:#16a34a;--accent-deep:#0f7734;--accent-rgb:22,163,74}body.nk-color-emerald{--accent:#10b981;--accent-deep:#087b56;--accent-rgb:16,185,129}body.nk-color-teal{--accent:#0f766e;--accent-deep:#084d49;--accent-rgb:15,118,110}body.nk-color-cyan{--accent:#00a8c8;--accent-deep:#00788e;--accent-rgb:0,168,200}body.nk-color-sky{--accent:#38bdf8;--accent-deep:#0d84bb;--accent-rgb:56,189,248}body.nk-color-blue{--accent:#2563eb;--accent-deep:#173ea4;--accent-rgb:37,99,235}body.nk-color-navy{--accent:#1e3a8a;--accent-deep:#13275f;--accent-rgb:30,58,138}body.nk-color-purple{--accent:#7c3aed;--accent-deep:#5524aa;--accent-rgb:124,58,237}body.nk-color-violet{--accent:#8b5cf6;--accent-deep:#5b34b8;--accent-rgb:139,92,246}body.nk-color-magenta{--accent:#d946ef;--accent-deep:#9c24b0;--accent-rgb:217,70,239}body.nk-color-mono{--accent:#232323;--accent-deep:#000;--accent-rgb:35,35,35}body.nk-color-bronze{--accent:#a16207;--accent-deep:#704303;--accent-rgb:161,98,7}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:var(--font-jp);color:var(--ink);background:#fff;line-height:1.8;overflow-x:hidden}a{color:inherit;text-decoration:none}img{max-width:100%;height:auto}.container{width:min(1180px,calc(100% - 44px));margin-inline:auto}.site-header{position:fixed;inset:0 0 auto;z-index:50;background:rgba(255,255,255,.92);backdrop-filter:blur(18px);border-bottom:1px solid rgba(0,0,0,.08);transition:.28s}.site-header.is-scrolled{box-shadow:0 16px 40px rgba(0,0,0,.10);background:rgba(255,255,255,.97)}.header-inner{display:flex;align-items:center;justify-content:space-between;min-height:82px}.brand{display:flex;align-items:center;gap:14px}.brand-logo img{display:block;max-width:116px;max-height:58px;object-fit:contain}.custom-logo-link img{max-height:58px;width:auto}.brand-text strong{display:block;font-weight:800;letter-spacing:.04em}.brand-text small{display:block;font-family:var(--font-en);font-size:11px;letter-spacing:.1em}.site-nav{display:flex;align-items:center;gap:26px}.primary-menu{display:flex;gap:28px;list-style:none;margin:0;padding:0}.primary-menu a{position:relative;font-weight:700;font-size:14px}.primary-menu a:after{content:"";position:absolute;left:0;right:0;bottom:-18px;height:2px;background:var(--accent);transform:scaleX(0);transition:.25s}.primary-menu a:hover:after,.primary-menu .current-menu-item>a:after{transform:scaleX(1)}.header-contact{display:inline-flex;align-items:center;gap:8px;background:var(--accent);color:#fff;padding:13px 20px;border-radius:4px;font-weight:800;box-shadow:0 12px 30px rgba(var(--accent-rgb),.2)}.header-contact:hover{background:var(--accent-deep)}.nav-toggle{display:none;background:transparent;border:0;width:44px;height:44px}.nav-toggle span{display:block;height:2px;background:#111;margin:7px 6px}.one-screen-stage{position:relative;min-height:100svh;overflow:hidden;background:#f7f8fa;padding:92px 0 26px;display:flex;align-items:stretch}.media-backdrop{position:absolute;inset:0;z-index:0}.hero-static-image,.hero-slideshow,.hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}.hero-static-image{background-size:cover;background-position:center;transform:scale(1.03);animation:mediaDrift 18s ease-in-out infinite}.hero-slideshow span{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;animation:slideShow 15s infinite;transform:scale(1.06)}.hero-video{filter:saturate(1.06) contrast(1.02)}.media-shade{position:absolute;inset:0;z-index:1;background:linear-gradient(90deg,rgba(255,255,255,.96) 0%,rgba(255,255,255,.91) 40%,rgba(255,255,255,.58) 72%,rgba(255,255,255,.46) 100%),radial-gradient(circle at 82% 28%,rgba(var(--accent-rgb),.20),transparent 40%)}@keyframes mediaDrift{0%,100%{transform:scale(1.03) translate3d(0,0,0)}50%{transform:scale(1.08) translate3d(-20px,8px,0)}}@keyframes slideShow{0%,28%{opacity:1;transform:scale(1.05)}34%,100%{opacity:0;transform:scale(1.11)}}.stage-gridline{position:absolute;inset:0;z-index:2;opacity:.34;background-image:linear-gradient(rgba(0,0,0,.045) 1px,transparent 1px),linear-gradient(90deg,rgba(0,0,0,.04) 1px,transparent 1px);background-size:62px 62px;mask-image:linear-gradient(90deg,transparent 0,#000 18%,#000 100%);animation:gridRun 16s linear infinite}@keyframes gridRun{to{background-position:124px 62px}}.stage-motion{position:absolute;inset:-8%;z-index:3;pointer-events:none}.stage-motion span{position:absolute;border:1px solid rgba(var(--accent-rgb),.32);box-shadow:0 0 40px rgba(var(--accent-rgb),.08);opacity:.95;will-change:transform}.stage-motion span:nth-child(1){width:70vw;height:22vw;right:-14vw;top:11vh;border-radius:50%;border-width:3px;animation:orbitStrong 8s ease-in-out infinite}.stage-motion span:nth-child(2){width:55vw;height:13vw;right:8vw;bottom:16vh;border-radius:50%;border-width:2px;animation:orbitStrong 10s ease-in-out infinite reverse}.stage-motion span:nth-child(3){width:32vw;height:32vw;left:-9vw;bottom:-18vw;border-radius:50%;animation:pulseStrong 5s ease-in-out infinite}.stage-motion span:nth-child(4){width:120vw;height:3px;left:-20vw;top:55%;background:linear-gradient(90deg,transparent,var(--accent),transparent);border:0;animation:beamMove 4.5s linear infinite}.stage-motion span:nth-child(5){width:42vw;height:42vw;right:8vw;top:20vh;border-radius:32%;border-style:dashed;animation:spinAccent 18s linear infinite}.stage-motion span:nth-child(6){width:30vw;height:2px;right:6vw;top:38%;background:linear-gradient(90deg,transparent,rgba(var(--accent-rgb),.7),transparent);border:0;animation:beamMove 3.4s linear infinite reverse}@keyframes orbitStrong{0%,100%{transform:translate3d(0,0,0) rotate(-8deg) scale(1)}50%{transform:translate3d(-42px,24px,0) rotate(-2deg) scale(1.06)}}@keyframes pulseStrong{50%{transform:scale(1.12);opacity:.35}}@keyframes beamMove{0%{transform:translateX(-35%) rotate(-9deg);opacity:0}12%,82%{opacity:.55}100%{transform:translateX(35%) rotate(-9deg);opacity:0}}@keyframes spinAccent{to{transform:rotate(360deg)}}.stage-particles{position:absolute;inset:0;z-index:4;pointer-events:none}.stage-particles i{position:absolute;width:8px;height:8px;border-radius:50%;background:var(--accent);opacity:.32;animation:particleFly 7s ease-in-out infinite}.stage-particles i:nth-child(1){left:18%;top:24%;animation-delay:.2s}.stage-particles i:nth-child(2){left:80%;top:18%;animation-delay:1s}.stage-particles i:nth-child(3){left:70%;top:68%;animation-delay:1.8s}.stage-particles i:nth-child(4){left:54%;top:32%;animation-delay:2.5s}.stage-particles i:nth-child(5){left:90%;top:52%;animation-delay:3s}.stage-particles i:nth-child(6){left:35%;top:75%;animation-delay:3.7s}.stage-particles i:nth-child(7){left:62%;top:84%;animation-delay:4.4s}.stage-particles i:nth-child(8){left:10%;top:58%;animation-delay:5s}@keyframes particleFly{0%,100%{transform:translate(0,0) scale(.7)}50%{transform:translate(36px,-28px) scale(1.5)}}.stage-inner{position:relative;z-index:5;display:grid;grid-template-rows:minmax(330px,1fr) auto auto;gap:18px;align-content:space-between;width:min(100%,calc(100% - 56px));max-width:1440px}.hero-fullwide{display:grid;grid-template-columns:minmax(520px,760px) 1fr;align-items:center}.eyebrow{font-size:clamp(16px,1.45vw,24px);font-weight:800;margin:0 0 10px}.hero h1{font-family:var(--font-en);font-size:clamp(48px,6.1vw,105px);line-height:1.02;letter-spacing:.06em;margin:0 0 18px;font-weight:900}.hero h1::after{content:"";display:inline-block;width:.24em;height:.24em;background:var(--accent);border-radius:50%;margin-left:.09em}.lead{font-size:clamp(14px,1.1vw,17px);max-width:660px;color:#2d333d;margin:0 0 22px}.hero-actions{display:flex;flex-wrap:wrap;gap:14px}.btn{position:relative;display:inline-flex;align-items:center;justify-content:center;min-height:52px;padding:0 26px;border-radius:4px;font-weight:800;overflow:hidden;border:1px solid rgba(0,0,0,.22)}.btn:before{content:"";position:absolute;inset:0;background:linear-gradient(120deg,transparent 0%,rgba(255,255,255,.45) 40%,transparent 70%);transform:translateX(-120%);transition:.55s}.btn:hover:before{transform:translateX(120%)}.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 12px 30px rgba(var(--accent-rgb),.22)}.btn-outline{background:rgba(255,255,255,.7);backdrop-filter:blur(10px)}.btn-white{background:#fff;color:var(--accent);border-color:#fff}.theme-indicator{position:absolute;right:0;top:50%;transform:translateY(-50%);display:flex;align-items:center;gap:10px;padding:13px 18px;background:rgba(255,255,255,.72);backdrop-filter:blur(14px);border:1px solid rgba(0,0,0,.07);border-radius:999px;box-shadow:0 20px 55px rgba(16,20,28,.09);font-weight:900;letter-spacing:.08em}.theme-indicator strong{color:var(--accent)}.theme-indicator span{font-size:12px}.panel-grid{display:grid;grid-template-columns:1.12fr .94fr .94fr;gap:18px}.panel{min-height:170px;padding:22px 24px;border-radius:16px;background:rgba(255,255,255,.82);backdrop-filter:blur(16px);box-shadow:0 18px 52px rgba(16,20,28,.13);border:1px solid rgba(255,255,255,.65);transition:.25s}.panel:hover,.service-card:hover{transform:translateY(-5px)}.panel-head{display:flex;align-items:center;gap:12px;padding-bottom:12px;margin-bottom:12px;border-bottom:1px solid var(--line)}.panel-icon{font-size:24px;color:var(--accent)}.panel-head h2{font-family:var(--font-en);color:var(--accent);font-size:18px;margin:0}.panel-head a{margin-left:auto;font-size:12px;font-weight:800}.panel p{font-size:14px;margin:0;line-height:1.75}.news-row{display:grid;grid-template-columns:82px 66px 1fr;gap:10px;align-items:center;padding:5px 0;font-size:13px}.news-row time{color:var(--accent);font-weight:800}.news-row span{background:#eef0f3;border-radius:4px;text-align:center;font-size:11px;padding:2px}.news-row strong{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mini-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}.mini-tags span{border:1px solid var(--line);border-radius:4px;padding:4px 10px;font-size:12px;background:rgba(255,255,255,.55)}.sector-ribbon{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:#16171a;border-radius:16px;overflow:hidden;color:#fff;box-shadow:0 24px 70px rgba(16,20,28,.18)}.sector-ribbon div{padding:18px 24px;background:linear-gradient(135deg,#16171a,#0e1013);position:relative}.sector-ribbon div:before{content:"";position:absolute;left:0;top:18px;bottom:18px;width:3px;background:var(--accent)}.sector-ribbon strong{display:block;font-size:16px}.sector-ribbon span{font-size:12px;color:#cfd3db}.section{padding:88px 0}.section-heading{text-align:center;margin-bottom:38px}.section-heading p{margin:0;color:var(--accent);font-family:var(--font-en);font-weight:900;letter-spacing:.18em}.section-heading h2{font-size:clamp(28px,4vw,46px);margin:4px 0 0}.services{background:#fff}.services-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}.service-card{padding:28px;border:1px solid var(--line);border-radius:18px;background:#fff;box-shadow:0 18px 45px rgba(16,20,28,.06);transition:.25s}.service-card small{color:var(--accent);font-weight:900;font-family:var(--font-en)}.service-card h3{margin:10px 0;font-size:20px}.service-card p{color:var(--muted);font-size:14px}.why{background:var(--soft)}.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.why-card{display:flex;align-items:center;gap:16px;padding:22px;border-radius:16px;background:#fff;border:1px solid var(--line)}.why-card span{background:var(--accent);color:#fff;width:44px;height:44px;border-radius:50%;display:grid;place-items:center;font-weight:900;box-shadow:0 0 0 8px rgba(var(--accent-rgb),.12)}.why-card strong{font-size:16px}.cta-section{background:#fff}.cta-box{position:relative;overflow:hidden;border-radius:24px;padding:56px;background:linear-gradient(135deg,var(--accent),var(--accent-deep));color:#fff}.cta-box:after{content:"";position:absolute;right:-8%;top:-40%;width:50%;height:160%;border:1px solid rgba(255,255,255,.25);border-radius:50%;transform:rotate(-18deg)}.cta-box h2{font-size:clamp(28px,4vw,44px);margin:0 0 10px}.site-footer{background:#101116;color:#fff;padding-top:56px}.footer-grid{display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:40px}.footer-brand{font-weight:900;font-size:20px}.site-footer p,.site-footer li{color:#c9cbd1}.site-footer ul{list-style:none;margin:0;padding:0}.footer-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:40px;padding:18px 0;color:#b9bcc3}.breadcrumb{margin:110px auto 18px;width:min(980px,calc(100% - 44px));font-size:13px;color:#6b7280}.breadcrumb a{color:var(--accent)}.breadcrumb span{margin:0 6px}.content-wrap{width:min(980px,calc(100% - 44px));margin:0 auto 80px}.page-hero,.archive-hero{padding:52px 0 22px}.entry-title{font-size:clamp(32px,5vw,56px);line-height:1.25}.entry-content{background:#fff;border:1px solid var(--line);border-radius:18px;padding:40px;box-shadow:0 18px 45px rgba(16,20,28,.06)}.post-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}.post-card{background:#fff;border:1px solid var(--line);border-radius:18px;overflow:hidden;box-shadow:0 16px 38px rgba(16,20,28,.06)}.post-card .post-thumb{aspect-ratio:16/9;background:#eef0f3}.post-card .post-body{padding:22px}.post-meta{font-size:13px;color:var(--accent);font-weight:800}.not-found{text-align:center;padding:140px 0}.reveal{opacity:0;transform:translateY(20px);transition:opacity .65s ease,transform .65s ease}.reveal.is-visible{opacity:1;transform:none}
/* 15 background motif overrides */
body.nk-bg-speed .stage-motion span:nth-child(4),body.nk-bg-speed .stage-motion span:nth-child(6){height:4px;animation-duration:2.8s}body.nk-bg-geometry .stage-motion span:nth-child(5){border-radius:8px;animation-duration:8s}body.nk-bg-chemistry .stage-particles i{box-shadow:0 0 0 12px rgba(var(--accent-rgb),.08)}body.nk-bg-beauty .stage-motion span{border-radius:42% 58% 48% 52%}body.nk-bg-japanese .stage-motion span:nth-child(1){border-width:18px;opacity:.16}body.nk-bg-western .stage-gridline{background-size:42px 90px}body.nk-bg-sports .stage-motion span:nth-child(2){animation-duration:4.4s}body.nk-bg-culture_people .stage-particles i{animation-duration:5s}body.nk-bg-network .stage-gridline{opacity:.55;animation-duration:7s}body.nk-bg-education .stage-motion span:nth-child(5){border-style:solid;border-radius:0;transform:rotate(45deg)}body.nk-bg-security .media-shade{background:linear-gradient(90deg,rgba(255,255,255,.97),rgba(255,255,255,.88) 54%,rgba(0,0,0,.10)),radial-gradient(circle at 80% 30%,rgba(var(--accent-rgb),.18),transparent 42%)}body.nk-bg-data_flow .stage-motion span:nth-child(4){animation-duration:1.9s;opacity:.7}body.nk-bg-urban .stage-gridline{background-size:90px 48px}body.nk-bg-human_touch .stage-particles i{border-radius:38% 62% 57% 43%;width:12px;height:12px}body.nk-bg-premium .panel{background:rgba(255,255,255,.9);box-shadow:0 30px 90px rgba(16,20,28,.16)}
@media(max-width:1200px){.theme-indicator{display:none}.stage-inner{grid-template-rows:auto auto auto}.hero-fullwide{grid-template-columns:1fr}.panel-grid{grid-template-columns:1fr 1fr}.services-grid{grid-template-columns:repeat(2,1fr)}.one-screen-stage{min-height:auto;padding-bottom:34px}}@media(max-width:900px){.site-nav{position:fixed;left:18px;right:18px;top:84px;background:#fff;border:1px solid var(--line);box-shadow:0 24px 70px rgba(0,0,0,.16);border-radius:18px;padding:22px;display:none;flex-direction:column;align-items:stretch}.site-nav.is-open{display:flex}.primary-menu{flex-direction:column;gap:10px}.primary-menu a:after{display:none}.nav-toggle{display:block}.brand-text{display:none}}@media(max-width:768px){.one-screen-stage{padding-top:92px}.stage-inner{width:min(100% - 32px,1180px);gap:16px}.hero h1{font-size:42px}.panel-grid,.sector-ribbon,.why-grid,.footer-grid{grid-template-columns:1fr}.panel{padding:20px}.sector-ribbon div{padding:15px 20px}.services-grid,.post-grid{grid-template-columns:1fr}.media-shade{background:linear-gradient(90deg,rgba(255,255,255,.96),rgba(255,255,255,.82))}.entry-content{padding:26px}.stage-motion{opacity:.78}}@media(max-width:480px){.hero h1{font-size:34px}.eyebrow{font-size:15px}.news-row{grid-template-columns:1fr;gap:3px}.sector-ribbon{display:none}.one-screen-stage{padding-bottom:22px}.hero-actions .btn{width:100%}.header-inner{min-height:74px}.brand-logo img{max-width:92px}}

/* V2.4: 20 adopted background animations + motion strength */
body.nk-motion-off .stage-motion,
body.nk-motion-off .stage-gridline,
body.nk-motion-off .stage-particles{display:none!important}
body.nk-motion-subtle .stage-motion{opacity:.42;filter:saturate(.9)}
body.nk-motion-subtle .stage-particles{opacity:.45}
body.nk-motion-subtle .stage-gridline{opacity:.18;animation-duration:28s}
body.nk-motion-subtle .stage-motion span{animation-duration:calc(var(--motion-speed, 1) * 1s)}
body.nk-motion-strong .stage-motion{opacity:1;filter:saturate(1.18) contrast(1.05)}
body.nk-motion-strong .stage-particles{opacity:1}
body.nk-motion-strong .stage-gridline{opacity:.48;animation-duration:8s}
body.nk-motion-strong .stage-motion span:nth-child(1){animation-duration:5.6s}
body.nk-motion-strong .stage-motion span:nth-child(2){animation-duration:6.4s}
body.nk-motion-strong .stage-motion span:nth-child(4){animation-duration:2.2s;height:5px}
body.nk-motion-strong .stage-motion span:nth-child(6){animation-duration:2.7s;height:4px}

/* 01 Future Orbit: logo swoosh orbit */
body.nk-bg-future_orbit .stage-motion span:nth-child(1),
body.nk-bg-future_orbit .stage-motion span:nth-child(2){border-width:4px;border-color:rgba(var(--accent-rgb),.44);box-shadow:0 0 52px rgba(var(--accent-rgb),.18);animation-name:orbitStrong}
body.nk-bg-future_orbit .stage-motion span:nth-child(5){border-style:solid;border-radius:50%;opacity:.42;animation-duration:12s}
body.nk-bg-future_orbit .stage-gridline{opacity:.22;background-size:88px 88px}

/* 02 Human Connection: rings and nodes spread outward */
body.nk-bg-human_connection .stage-particles i{width:13px;height:13px;box-shadow:0 0 0 18px rgba(var(--accent-rgb),.08),0 0 28px rgba(var(--accent-rgb),.22);animation-name:humanFloat;animation-duration:6.2s}
body.nk-bg-human_connection .stage-motion span:nth-child(3){border-width:2px;animation-name:connectionRipple;animation-duration:4.8s}
body.nk-bg-human_connection .stage-motion span:nth-child(4),body.nk-bg-human_connection .stage-motion span:nth-child(6){height:1px;opacity:.35}
@keyframes humanFloat{0%,100%{transform:translate(0,0) scale(.7)}40%{transform:translate(22px,-18px) scale(1.7)}70%{transform:translate(-16px,12px) scale(1)}}
@keyframes connectionRipple{0%{transform:scale(.82);opacity:.5}70%{transform:scale(1.22);opacity:.12}100%{transform:scale(.82);opacity:.5}}

/* 03 Corporate Depth: diagonal panels, subtle and professional */
body.nk-bg-corporate_depth .stage-motion span:nth-child(1),body.nk-bg-corporate_depth .stage-motion span:nth-child(2){border-radius:0;transform:skewX(-18deg);border-color:rgba(0,0,0,.08);background:linear-gradient(135deg,rgba(255,255,255,.18),rgba(var(--accent-rgb),.08));animation-name:depthSlide;animation-duration:10s}
body.nk-bg-corporate_depth .stage-motion span:nth-child(5){border-radius:18px;border-style:solid;opacity:.22;animation-duration:22s}
body.nk-bg-corporate_depth .stage-gridline{opacity:.12;background-size:120px 80px}
@keyframes depthSlide{0%,100%{transform:translateX(0) skewX(-18deg)}50%{transform:translateX(-56px) skewX(-18deg)}}

/* 04 Geometric Grid: polygons and precise grid */
body.nk-bg-geometric_grid .stage-gridline{opacity:.46;background-size:54px 54px;animation-duration:10s}
body.nk-bg-geometric_grid .stage-motion span:nth-child(5){border-radius:10px;border-style:dashed;animation-duration:7s}
body.nk-bg-geometric_grid .stage-motion span:nth-child(1){border-radius:22%;animation-name:polyMorph;animation-duration:7s}
@keyframes polyMorph{0%,100%{border-radius:18%;transform:rotate(0) scale(1)}50%{border-radius:4%;transform:rotate(12deg) scale(1.04)}}

/* 05 Network Nodes: stronger node network */
body.nk-bg-network_nodes .stage-gridline{opacity:.34;background-image:radial-gradient(circle,rgba(var(--accent-rgb),.20) 1.5px,transparent 2px),linear-gradient(90deg,rgba(0,0,0,.035) 1px,transparent 1px);background-size:52px 52px;animation-duration:11s}
body.nk-bg-network_nodes .stage-particles i{animation-duration:4.8s;box-shadow:0 0 22px rgba(var(--accent-rgb),.45)}
body.nk-bg-network_nodes .stage-motion span:nth-child(4),body.nk-bg-network_nodes .stage-motion span:nth-child(6){opacity:.52;height:2px}

/* 06 Speed Line: fast diagonal light streaks */
body.nk-bg-speed_line .stage-motion span:nth-child(4),body.nk-bg-speed_line .stage-motion span:nth-child(6){height:5px;animation-duration:1.9s;opacity:.85;filter:blur(.2px)}
body.nk-bg-speed_line .stage-gridline{opacity:.20;background-size:120px 48px;animation-duration:5s}
body.nk-bg-speed_line .stage-particles i{animation-name:speedParticle;animation-duration:3s}
@keyframes speedParticle{0%{transform:translate(-50px,20px) scale(.4);opacity:0}30%,75%{opacity:.55}100%{transform:translate(90px,-36px) scale(1.4);opacity:0}}

/* 07 Data Stream: horizontal data flow */
body.nk-bg-data_stream .stage-gridline{opacity:.38;background-image:repeating-linear-gradient(90deg,rgba(var(--accent-rgb),.14) 0 2px,transparent 2px 26px);background-size:220px 100%;animation-name:dataRun;animation-duration:5s}
body.nk-bg-data_stream .stage-motion span:nth-child(4),body.nk-bg-data_stream .stage-motion span:nth-child(6){transform:rotate(0);animation-name:dataBeam;height:2px;top:42%}
body.nk-bg-data_stream .stage-motion span:nth-child(6){top:66%}
@keyframes dataRun{to{background-position:220px 0}}@keyframes dataBeam{0%{transform:translateX(-48%);opacity:0}20%,80%{opacity:.62}100%{transform:translateX(48%);opacity:0}}

/* 08 AI Pulse: thinking pulse from center */
body.nk-bg-ai_pulse .stage-motion span:nth-child(1),body.nk-bg-ai_pulse .stage-motion span:nth-child(2),body.nk-bg-ai_pulse .stage-motion span:nth-child(3){border-radius:50%;animation-name:aiPulse;animation-duration:3.6s;opacity:.42}
body.nk-bg-ai_pulse .stage-particles i{animation-duration:4s;box-shadow:0 0 0 10px rgba(var(--accent-rgb),.08)}
@keyframes aiPulse{0%{transform:scale(.78);opacity:.55}72%{transform:scale(1.18);opacity:.1}100%{transform:scale(.78);opacity:.55}}

/* 09 Circuit Flow: circuit-like angular flow */
body.nk-bg-circuit_flow .stage-gridline{opacity:.44;background-image:linear-gradient(90deg,rgba(var(--accent-rgb),.18) 1px,transparent 1px),linear-gradient(rgba(0,0,0,.05) 1px,transparent 1px);background-size:72px 36px;animation-duration:8s}
body.nk-bg-circuit_flow .stage-motion span:nth-child(5){border-radius:0;border-style:solid;animation-duration:9s}
body.nk-bg-circuit_flow .stage-particles i{border-radius:2px;animation-name:circuitBlink;animation-duration:2.8s}
@keyframes circuitBlink{0%,100%{opacity:.16;transform:scale(.7)}50%{opacity:.68;transform:scale(1.6)}}

/* 10 Molecular Link: particles connect and separate */
body.nk-bg-molecular_link .stage-particles i{width:10px;height:10px;box-shadow:0 0 0 14px rgba(var(--accent-rgb),.09);animation-name:moleculeMove;animation-duration:5.4s}
body.nk-bg-molecular_link .stage-motion span:nth-child(4),body.nk-bg-molecular_link .stage-motion span:nth-child(6){height:1px;opacity:.42;animation-duration:4.8s}
@keyframes moleculeMove{0%,100%{transform:translate(0,0) scale(.8)}33%{transform:translate(36px,20px) scale(1.35)}66%{transform:translate(-22px,-26px) scale(1.05)}}

/* 11 Soft Wave: elegant light waves */
body.nk-bg-soft_wave .stage-motion span{border-radius:45% 55% 60% 40%;filter:blur(.6px);opacity:.45;animation-duration:12s}
body.nk-bg-soft_wave .stage-motion span:nth-child(4),body.nk-bg-soft_wave .stage-motion span:nth-child(6){height:18px;filter:blur(12px);opacity:.36}
body.nk-bg-soft_wave .stage-gridline{opacity:.08}

/* 12 Japanese Ripple: calm circular ripples */
body.nk-bg-japanese_ripple .stage-motion span:nth-child(1),body.nk-bg-japanese_ripple .stage-motion span:nth-child(2),body.nk-bg-japanese_ripple .stage-motion span:nth-child(3){border-radius:50%;animation-name:japaneseRipple;animation-duration:6s;border-width:2px;opacity:.32}
body.nk-bg-japanese_ripple .stage-gridline{opacity:.10;background-size:96px 96px}
@keyframes japaneseRipple{0%{transform:scale(.8);opacity:.35}75%{transform:scale(1.16);opacity:.08}100%{transform:scale(.8);opacity:.35}}

/* 13 Japanese Lattice: ordered lattice */
body.nk-bg-japanese_lattice .stage-gridline{opacity:.36;background-image:linear-gradient(45deg,rgba(var(--accent-rgb),.12) 1px,transparent 1px),linear-gradient(-45deg,rgba(0,0,0,.04) 1px,transparent 1px);background-size:44px 44px;animation-duration:18s}
body.nk-bg-japanese_lattice .stage-motion span:nth-child(5){border-radius:0;border-style:solid;opacity:.20;animation-duration:28s}

/* 14 Western Architecture: arches and depth */
body.nk-bg-western_arch .stage-motion span:nth-child(1),body.nk-bg-western_arch .stage-motion span:nth-child(2){border-radius:50% 50% 0 0;height:34vw;border-bottom:0;animation-name:archDepth;animation-duration:9s}
body.nk-bg-western_arch .stage-gridline{opacity:.24;background-size:48px 120px;animation-duration:15s}
@keyframes archDepth{0%,100%{transform:translateY(0) scale(1)}50%{transform:translateY(-24px) scale(1.05)}}

/* 15 Golden Ratio Curve: design beauty */
body.nk-bg-golden_curve .stage-motion span:nth-child(1),body.nk-bg-golden_curve .stage-motion span:nth-child(2),body.nk-bg-golden_curve .stage-motion span:nth-child(5){border-radius:60% 40% 60% 40%;animation-name:goldenCurve;animation-duration:14s;border-color:rgba(var(--accent-rgb),.36)}
body.nk-bg-golden_curve .stage-gridline{opacity:.12}
@keyframes goldenCurve{0%,100%{transform:rotate(-12deg) scale(1)}50%{transform:rotate(18deg) scale(1.08)}}

/* 16 Sports Trajectory: arcs and momentum */
body.nk-bg-sports_trajectory .stage-motion span:nth-child(1),body.nk-bg-sports_trajectory .stage-motion span:nth-child(2){border-radius:50%;border-top-color:transparent;border-left-color:transparent;animation-duration:4.2s}
body.nk-bg-sports_trajectory .stage-motion span:nth-child(4){animation-duration:2.4s;height:4px}
body.nk-bg-sports_trajectory .stage-particles i{animation-duration:3.8s}

/* 17 Performance Pulse: KPI waveform */
body.nk-bg-performance_pulse .stage-gridline{opacity:.18;background-size:80px 40px}
body.nk-bg-performance_pulse .stage-motion span:nth-child(4),body.nk-bg-performance_pulse .stage-motion span:nth-child(6){height:3px;animation-name:pulseLine;animation-duration:2.6s;transform:rotate(0)}
body.nk-bg-performance_pulse .stage-particles i{border-radius:1px;height:12px;animation-duration:2.4s}
@keyframes pulseLine{0%{clip-path:polygon(0 50%,10% 50%,15% 20%,20% 80%,25% 50%,100% 50%);transform:translateX(-35%)}100%{clip-path:polygon(0 50%,10% 50%,15% 20%,20% 80%,25% 50%,100% 50%);transform:translateX(35%)}}

/* 18 Cultural Mosaic: tiles assemble */
body.nk-bg-cultural_mosaic .stage-gridline{opacity:.22;background-image:linear-gradient(90deg,rgba(var(--accent-rgb),.10) 50%,transparent 50%),linear-gradient(rgba(0,0,0,.035) 50%,transparent 50%);background-size:54px 54px;animation-duration:14s}
body.nk-bg-cultural_mosaic .stage-particles i{border-radius:3px;animation-name:mosaicPop;animation-duration:4.6s}
@keyframes mosaicPop{0%,100%{transform:scale(.55) rotate(0);opacity:.18}50%{transform:scale(1.45) rotate(45deg);opacity:.55}}

/* 19 Security Shield: shield and scan */
body.nk-bg-security_shield .stage-motion span:nth-child(1),body.nk-bg-security_shield .stage-motion span:nth-child(2){border-radius:45% 45% 52% 52%;animation-name:shieldScan;animation-duration:6.6s;border-width:3px}
body.nk-bg-security_shield .media-shade{background:linear-gradient(90deg,rgba(255,255,255,.97),rgba(255,255,255,.90) 54%,rgba(0,0,0,.08)),radial-gradient(circle at 78% 32%,rgba(var(--accent-rgb),.16),transparent 42%)}
body.nk-bg-security_shield .stage-gridline{opacity:.28;background-size:72px 72px}
@keyframes shieldScan{0%,100%{transform:translateY(0) scale(1);box-shadow:0 0 20px rgba(var(--accent-rgb),.06)}50%{transform:translateY(-18px) scale(1.05);box-shadow:0 0 60px rgba(var(--accent-rgb),.18)}}

/* 20 Education Flow: layered learning paths */
body.nk-bg-education_flow .stage-gridline{opacity:.26;background-image:linear-gradient(0deg,rgba(var(--accent-rgb),.13) 1px,transparent 1px),linear-gradient(90deg,rgba(0,0,0,.035) 1px,transparent 1px);background-size:110px 42px;animation-duration:12s}
body.nk-bg-education_flow .stage-motion span:nth-child(4),body.nk-bg-education_flow .stage-motion span:nth-child(6){transform:rotate(0);height:2px;animation-name:educationPath;animation-duration:4.8s}
body.nk-bg-education_flow .stage-motion span:nth-child(5){border-radius:0;border-style:solid;opacity:.22}
@keyframes educationPath{0%{transform:translateX(-38%);opacity:0}15%,85%{opacity:.45}100%{transform:translateX(38%);opacity:0}}

@media (prefers-reduced-motion: reduce){.stage-motion span,.stage-gridline,.stage-particles i,.hero-static-image,.hero-slideshow span{animation:none!important}}

/* V2.4 final tuning: readable motion speeds */
body.nk-motion-subtle .stage-motion span:nth-child(1){animation-duration:18s!important}
body.nk-motion-subtle .stage-motion span:nth-child(2){animation-duration:22s!important}
body.nk-motion-subtle .stage-motion span:nth-child(3){animation-duration:16s!important}
body.nk-motion-subtle .stage-motion span:nth-child(4){animation-duration:9s!important;height:2px!important;opacity:.30!important}
body.nk-motion-subtle .stage-motion span:nth-child(5){animation-duration:34s!important}
body.nk-motion-subtle .stage-motion span:nth-child(6){animation-duration:11s!important;height:1px!important;opacity:.24!important}


/* =========================================================
   V2.5 Distinct Motion System
   20種類の背景を「線の違い」ではなく、形状・面・密度・リズムで明確に差別化
   ========================================================= */
.theme-visuals{position:absolute;inset:0;z-index:4;pointer-events:none;overflow:hidden;mix-blend-mode:multiply}.theme-visuals .motif{display:none;position:absolute;inset:0}.theme-visuals span,.theme-visuals i,.theme-visuals b{position:absolute;display:block;box-sizing:border-box}.nk-motion-off .theme-visuals,.nk-motion-off .stage-motion,.nk-motion-off .stage-gridline,.nk-motion-off .stage-particles{display:none!important}.nk-motion-subtle .theme-visuals{opacity:.42}.nk-motion-normal .theme-visuals{opacity:.72}.nk-motion-strong .theme-visuals{opacity:1}.nk-motion-strong .theme-visuals .motif *{animation-duration:calc(var(--d,7s)*.65)!important}.nk-motion-subtle .theme-visuals .motif *{animation-duration:calc(var(--d,7s)*1.75)!important}
body.nk-bg-future_orbit .visual-future-orbit,body.nk-bg-human_connection .visual-human-connection,body.nk-bg-corporate_depth .visual-corporate-depth,body.nk-bg-geometric_grid .visual-geometric-grid,body.nk-bg-network_nodes .visual-network-nodes,body.nk-bg-speed_line .visual-speed-line,body.nk-bg-data_stream .visual-data-stream,body.nk-bg-ai_pulse .visual-ai-pulse,body.nk-bg-circuit_flow .visual-circuit-flow,body.nk-bg-molecular_link .visual-molecular-link,body.nk-bg-soft_wave .visual-soft-wave,body.nk-bg-japanese_ripple .visual-japanese-ripple,body.nk-bg-japanese_lattice .visual-japanese-lattice,body.nk-bg-western_arch .visual-western-arch,body.nk-bg-golden_curve .visual-golden-curve,body.nk-bg-sports_trajectory .visual-sports-trajectory,body.nk-bg-performance_pulse .visual-performance-pulse,body.nk-bg-cultural_mosaic .visual-cultural-mosaic,body.nk-bg-security_shield .visual-security-shield,body.nk-bg-education_flow .visual-education-flow{display:block}
/* baseを弱め、専用モチーフの違いを見せる */
body[class*="nk-bg-"] .stage-motion{opacity:.32}body[class*="nk-bg-"] .stage-particles{opacity:.40}body[class*="nk-bg-"] .stage-gridline{opacity:.18}

/* 01 Future Orbit: ロゴのスウォッシュに連動する大きな軌道 */
.visual-future-orbit span{right:-10vw;top:6vh;width:64vw;height:28vw;border:3px solid rgba(var(--accent-rgb),.42);border-left-color:transparent;border-bottom-color:transparent;border-radius:50%;transform:rotate(-18deg);animation:v25Orbit 6s ease-in-out infinite;--d:6s}.visual-future-orbit span:nth-child(2){right:5vw;top:25vh;width:44vw;height:15vw;border-width:2px;animation-direction:reverse;animation-delay:-1.5s}.visual-future-orbit span:nth-child(3){right:17vw;top:37vh;width:24vw;height:8vw;border-width:1px;animation-delay:-2.5s}.visual-future-orbit b{right:14vw;top:29vh;width:14px;height:14px;background:var(--accent);border-radius:50%;box-shadow:0 0 0 16px rgba(var(--accent-rgb),.12),0 0 32px rgba(var(--accent-rgb),.55);animation:v25OrbitDot 4s ease-in-out infinite;--d:4s}@keyframes v25Orbit{50%{transform:translate(-34px,18px) rotate(-4deg) scale(1.06)}}@keyframes v25OrbitDot{50%{transform:translate(-110px,58px) scale(1.35)}}

/* 02 Human Connection: 大きめの円が重なり、人の輪を作る */
.visual-human-connection span{border-radius:50%;border:2px solid rgba(var(--accent-rgb),.24);background:rgba(255,255,255,.22);animation:v25HumanBubble 7s ease-in-out infinite;--d:7s}.visual-human-connection span:nth-child(1){width:180px;height:180px;right:28%;top:17%}.visual-human-connection span:nth-child(2){width:130px;height:130px;right:17%;top:39%;animation-delay:-1s}.visual-human-connection span:nth-child(3){width:110px;height:110px;right:37%;top:51%;animation-delay:-2s}.visual-human-connection span:nth-child(4){width:80px;height:80px;right:13%;top:21%;animation-delay:-3s}.visual-human-connection span:nth-child(5){width:95px;height:95px;right:50%;top:36%;animation-delay:-4s}.visual-human-connection span:nth-child(6){width:70px;height:70px;right:30%;top:70%;animation-delay:-5s}.visual-human-connection i{height:2px;background:linear-gradient(90deg,transparent,rgba(var(--accent-rgb),.55),transparent);transform-origin:left center;animation:v25HumanLine 5s ease-in-out infinite;--d:5s}.visual-human-connection i:nth-of-type(1){right:22%;top:36%;width:230px;transform:rotate(22deg)}.visual-human-connection i:nth-of-type(2){right:23%;top:54%;width:260px;transform:rotate(-12deg);animation-delay:-1.4s}.visual-human-connection i:nth-of-type(3){right:31%;top:45%;width:210px;transform:rotate(145deg);animation-delay:-2.2s}@keyframes v25HumanBubble{50%{transform:scale(1.14);background:rgba(var(--accent-rgb),.08)}}@keyframes v25HumanLine{0%,100%{opacity:.15}50%{opacity:.7}}

/* 03 Corporate Depth: 大きな半透明パネルが前後に動く */
.visual-corporate-depth span{right:4vw;width:38vw;height:17vh;border-radius:18px;background:linear-gradient(135deg,rgba(255,255,255,.52),rgba(var(--accent-rgb),.10));border:1px solid rgba(0,0,0,.08);box-shadow:0 30px 80px rgba(0,0,0,.10);transform:skewX(-14deg);animation:v25Depth 8s ease-in-out infinite;--d:8s}.visual-corporate-depth span:nth-child(1){top:16vh}.visual-corporate-depth span:nth-child(2){top:33vh;right:10vw;animation-delay:-1s}.visual-corporate-depth span:nth-child(3){top:50vh;right:1vw;animation-delay:-2s}.visual-corporate-depth span:nth-child(4){top:67vh;right:16vw;animation-delay:-3s}.visual-corporate-depth span:nth-child(5){top:7vh;right:27vw;width:18vw;height:70vh;opacity:.28;animation-delay:-4s}@keyframes v25Depth{50%{transform:translateX(-38px) skewX(-14deg);opacity:.86}}

/* 04 Geometric Grid: 三角形・六角形・四角形が明確に変形 */
.visual-geometric-grid span{right:12vw;top:19vh;width:140px;height:140px;border:2px solid rgba(var(--accent-rgb),.42);background:rgba(var(--accent-rgb),.035);clip-path:polygon(50% 0,100% 25%,100% 75%,50% 100%,0 75%,0 25%);animation:v25Geo 6s ease-in-out infinite;--d:6s}.visual-geometric-grid span:nth-child(2){right:28vw;top:42vh;width:95px;height:95px;clip-path:polygon(50% 0,100% 100%,0 100%);animation-delay:-1s}.visual-geometric-grid span:nth-child(3){right:42vw;top:21vh;width:75px;height:75px;clip-path:none;transform:rotate(45deg);animation-delay:-2s}.visual-geometric-grid span:nth-child(4){right:8vw;top:62vh;width:180px;height:180px;clip-path:polygon(25% 0,75% 0,100% 50%,75% 100%,25% 100%,0 50%);animation-delay:-3s}.visual-geometric-grid span:nth-child(5){right:34vw;top:68vh;width:120px;height:120px;border-radius:50%;clip-path:none;animation-delay:-4s}.visual-geometric-grid span:nth-child(6){right:54vw;top:48vh;width:55px;height:55px;clip-path:polygon(50% 0,61% 35%,98% 35%,68% 57%,79% 91%,50% 70%,21% 91%,32% 57%,2% 35%,39% 35%);animation-delay:-5s}@keyframes v25Geo{50%{transform:rotate(22deg) scale(1.18);border-color:rgba(var(--accent-rgb),.70)}}

/* 05 Network Nodes: ノード同士の接続が見える */
.visual-network-nodes span{width:18px;height:18px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 12px rgba(var(--accent-rgb),.10),0 0 30px rgba(var(--accent-rgb),.50);animation:v25Node 4s ease-in-out infinite;--d:4s}.visual-network-nodes span:nth-child(1){right:16%;top:18%}.visual-network-nodes span:nth-child(2){right:34%;top:28%;animation-delay:-.8s}.visual-network-nodes span:nth-child(3){right:23%;top:47%;animation-delay:-1.6s}.visual-network-nodes span:nth-child(4){right:48%;top:52%;animation-delay:-2.4s}.visual-network-nodes span:nth-child(5){right:12%;top:69%;animation-delay:-3.2s}.visual-network-nodes span:nth-child(6){right:38%;top:75%;animation-delay:-4s}.visual-network-nodes i{right:10%;top:16%;width:48vw;height:58vh;border:0;background:linear-gradient(35deg,transparent 0 24%,rgba(var(--accent-rgb),.22) 24.4% 24.8%,transparent 25.2% 47%,rgba(var(--accent-rgb),.18) 47.4% 47.8%,transparent 48.2%),linear-gradient(145deg,transparent 0 32%,rgba(var(--accent-rgb),.18) 32.4% 32.8%,transparent 33.2%);animation:v25Net 7s linear infinite;--d:7s}.visual-network-nodes i:nth-of-type(2){animation-direction:reverse;opacity:.55}@keyframes v25Node{50%{transform:scale(1.55)}}@keyframes v25Net{50%{transform:translate(-18px,12px)}}

/* 06 Speed Line: 太いスラッシュと光跡 */
.visual-speed-line span{left:-18vw;width:150vw;height:18px;border-radius:999px;background:linear-gradient(90deg,transparent,rgba(var(--accent-rgb),.05),rgba(var(--accent-rgb),.70),rgba(255,255,255,.8),transparent);transform:rotate(-14deg);animation:v25Speed 2.2s linear infinite;--d:2.2s}.visual-speed-line span:nth-child(1){top:20%;animation-delay:-.2s}.visual-speed-line span:nth-child(2){top:35%;height:8px;animation-delay:-.7s}.visual-speed-line span:nth-child(3){top:55%;height:28px;animation-delay:-1.1s}.visual-speed-line span:nth-child(4){top:72%;height:12px;animation-delay:-1.6s}.visual-speed-line span:nth-child(5){top:86%;height:5px;animation-delay:-2s}@keyframes v25Speed{0%{transform:translateX(-55%) rotate(-14deg);opacity:0}15%,80%{opacity:.85}100%{transform:translateX(35%) rotate(-14deg);opacity:0}}

/* 07 Data Stream: 横方向のデータ帯 */
.visual-data-stream{right:0;left:42%;top:8%;bottom:8%}.visual-data-stream span{left:0;right:0;height:22px;border-radius:3px;background:repeating-linear-gradient(90deg,rgba(var(--accent-rgb),.50) 0 14px,transparent 14px 28px,rgba(0,0,0,.10) 28px 42px,transparent 42px 62px);animation:v25Data 3s linear infinite;--d:3s}.visual-data-stream span:nth-child(1){top:8%}.visual-data-stream span:nth-child(2){top:23%;animation-direction:reverse;opacity:.5}.visual-data-stream span:nth-child(3){top:38%;height:12px;animation-delay:-.5s}.visual-data-stream span:nth-child(4){top:53%;animation-direction:reverse;animation-delay:-1s}.visual-data-stream span:nth-child(5){top:68%;height:16px;opacity:.65}.visual-data-stream span:nth-child(6){top:83%;height:10px;animation-delay:-1.8s}@keyframes v25Data{to{background-position:124px 0}}

/* 08 AI Pulse: 中央コアから反応波 */
.visual-ai-pulse span{right:18vw;top:31vh;width:22vw;height:22vw;border-radius:50%;border:2px solid rgba(var(--accent-rgb),.38);animation:v25AiPulse 3.2s ease-out infinite;--d:3.2s}.visual-ai-pulse span:nth-child(2){animation-delay:-1.05s}.visual-ai-pulse span:nth-child(3){animation-delay:-2.1s}.visual-ai-pulse b{right:27vw;top:40vh;width:80px;height:80px;border-radius:24px;background:radial-gradient(circle,#fff,rgba(var(--accent-rgb),.28));border:1px solid rgba(var(--accent-rgb),.45);box-shadow:0 0 40px rgba(var(--accent-rgb),.30);animation:v25AiCore 2.2s ease-in-out infinite;--d:2.2s}.visual-ai-pulse i{right:25vw;top:38vh;width:120px;height:120px;border-radius:34px;border:1px dashed rgba(var(--accent-rgb),.5);animation:v25Spin 8s linear infinite;--d:8s}@keyframes v25AiPulse{0%{transform:scale(.35);opacity:.75}100%{transform:scale(1.8);opacity:0}}@keyframes v25AiCore{50%{transform:scale(1.12) rotate(4deg)}}

/* 09 Circuit Flow: 回路の角線 */
.visual-circuit-flow span{background:rgba(var(--accent-rgb),.52);height:3px;right:10vw;transform-origin:left;animation:v25Circuit 3s ease-in-out infinite;--d:3s}.visual-circuit-flow span:nth-child(1){top:22vh;width:36vw}.visual-circuit-flow span:nth-child(2){top:22vh;width:15vh;right:30vw;transform:rotate(90deg);animation-delay:-.6s}.visual-circuit-flow span:nth-child(3){top:43vh;width:28vw;right:18vw;animation-delay:-1.2s}.visual-circuit-flow span:nth-child(4){top:61vh;width:32vw;right:5vw;animation-delay:-1.8s}.visual-circuit-flow i{width:24px;height:24px;border-radius:4px;border:3px solid var(--accent);right:12vw;animation:v25CircuitNode 2s ease-in-out infinite;--d:2s}.visual-circuit-flow i:nth-of-type(1){top:20.5vh}.visual-circuit-flow i:nth-of-type(2){top:41.5vh;right:45vw;animation-delay:-.7s}.visual-circuit-flow i:nth-of-type(3){top:59.5vh;right:35vw;animation-delay:-1.4s}@keyframes v25Circuit{50%{filter:brightness(1.8);box-shadow:0 0 22px rgba(var(--accent-rgb),.5)}}@keyframes v25CircuitNode{50%{transform:scale(1.35);background:rgba(var(--accent-rgb),.18)}}

/* 10 Molecular Link: 分子玉と結合線 */
.visual-molecular-link span{border-radius:50%;background:radial-gradient(circle,#fff 0 22%,var(--accent) 23% 100%);box-shadow:0 0 0 12px rgba(var(--accent-rgb),.10);animation:v25Molecule 5s ease-in-out infinite;--d:5s}.visual-molecular-link span:nth-child(1){width:72px;height:72px;right:20vw;top:20vh}.visual-molecular-link span:nth-child(2){width:48px;height:48px;right:38vw;top:32vh;animation-delay:-1s}.visual-molecular-link span:nth-child(3){width:64px;height:64px;right:28vw;top:55vh;animation-delay:-2s}.visual-molecular-link span:nth-child(4){width:36px;height:36px;right:10vw;top:50vh;animation-delay:-3s}.visual-molecular-link span:nth-child(5){width:54px;height:54px;right:44vw;top:68vh;animation-delay:-4s}.visual-molecular-link i{height:3px;background:rgba(var(--accent-rgb),.35);right:16vw;width:34vw;top:40vh;transform:rotate(18deg);animation:v25Bond 4s ease-in-out infinite;--d:4s}.visual-molecular-link i:nth-of-type(2){top:61vh;right:21vw;transform:rotate(-16deg);width:28vw;animation-delay:-1.5s}@keyframes v25Molecule{50%{transform:translate(22px,-18px) scale(1.08)}}@keyframes v25Bond{50%{opacity:.85;box-shadow:0 0 18px rgba(var(--accent-rgb),.34)}}

/* 11 Soft Wave: 面の波 */
.visual-soft-wave span{left:28%;right:-8%;height:26vh;border-radius:50%;background:linear-gradient(90deg,transparent,rgba(var(--accent-rgb),.14),rgba(255,255,255,.28),transparent);filter:blur(16px);animation:v25SoftWave 9s ease-in-out infinite;--d:9s}.visual-soft-wave span:nth-child(1){top:16%;transform:rotate(-8deg)}.visual-soft-wave span:nth-child(2){top:38%;transform:rotate(7deg);animation-delay:-3s}.visual-soft-wave span:nth-child(3){top:60%;transform:rotate(-5deg);animation-delay:-6s}@keyframes v25SoftWave{50%{transform:translateX(-56px) rotate(var(--r,0deg));filter:blur(23px)}}

/* 12 Japanese Ripple: 水面の波紋 */
.visual-japanese-ripple span{right:23vw;top:35vh;width:18vw;height:18vw;border-radius:50%;border:2px solid rgba(var(--accent-rgb),.38);animation:v25Ripple 5.5s ease-out infinite;--d:5.5s}.visual-japanese-ripple span:nth-child(2){animation-delay:-1.3s}.visual-japanese-ripple span:nth-child(3){animation-delay:-2.6s}.visual-japanese-ripple span:nth-child(4){right:42vw;top:62vh;width:12vw;height:12vw;animation-delay:-3.9s}@keyframes v25Ripple{0%{transform:scale(.12);opacity:.62}100%{transform:scale(2.7);opacity:0}}

/* 13 Japanese Lattice: 組子風の格子面 */
.visual-japanese-lattice{left:45%;right:0;top:0;bottom:0;background:linear-gradient(45deg,rgba(var(--accent-rgb),.18) 1px,transparent 1px),linear-gradient(-45deg,rgba(var(--accent-rgb),.11) 1px,transparent 1px),linear-gradient(90deg,rgba(0,0,0,.04) 1px,transparent 1px);background-size:48px 48px;mask-image:linear-gradient(90deg,transparent,#000 20%,#000);animation:v25Lattice 16s linear infinite;--d:16s}.visual-japanese-lattice span{inset:auto 8vw 12vh auto;width:28vw;height:28vw;border:1px solid rgba(var(--accent-rgb),.25);transform:rotate(45deg);animation:v25Spin 26s linear infinite;--d:26s}.visual-japanese-lattice span:nth-child(2){right:25vw;bottom:35vh;width:14vw;height:14vw;animation-direction:reverse}.visual-japanese-lattice span:nth-child(3){display:none}@keyframes v25Lattice{to{background-position:96px 96px}}

/* 14 Western Architecture: アーチと柱 */
.visual-western-arch span{bottom:12vh;width:18vw;height:46vh;border:3px solid rgba(var(--accent-rgb),.33);border-bottom:0;border-radius:50% 50% 0 0;animation:v25Arch 7s ease-in-out infinite;--d:7s}.visual-western-arch span:nth-child(1){right:8vw}.visual-western-arch span:nth-child(2){right:25vw;width:14vw;height:38vh;animation-delay:-1.8s}.visual-western-arch span:nth-child(3){right:39vw;width:10vw;height:30vh;animation-delay:-3.6s}.visual-western-arch i{bottom:10vh;width:4px;height:52vh;background:linear-gradient(transparent,rgba(var(--accent-rgb),.38),transparent);right:14vw;animation:v25Arch 8s ease-in-out infinite;--d:8s}.visual-western-arch i:nth-of-type(2){right:46vw}@keyframes v25Arch{50%{transform:translateY(-22px);opacity:.9}}

/* 15 Golden Ratio Curve: 渦巻き曲線 */
.visual-golden-curve span{right:18vw;top:22vh;width:34vw;height:34vw;border:3px solid rgba(var(--accent-rgb),.40);border-left-color:transparent;border-bottom-color:transparent;border-radius:50%;animation:v25Golden 10s ease-in-out infinite;--d:10s}.visual-golden-curve span:nth-child(2){width:23vw;height:23vw;right:23vw;top:31vh;animation-delay:-2.5s}.visual-golden-curve span:nth-child(3){width:14vw;height:14vw;right:27vw;top:39vh;animation-delay:-5s}.visual-golden-curve span:nth-child(4){width:7vw;height:7vw;right:30vw;top:45vh;animation-delay:-7.5s}@keyframes v25Golden{50%{transform:rotate(28deg) scale(1.08);border-color:rgba(var(--accent-rgb),.62);border-left-color:transparent;border-bottom-color:transparent}}

/* 16 Sports Trajectory: 放物線・軌道 */
.visual-sports-trajectory span{left:42%;top:20%;width:52vw;height:38vh;border:4px solid rgba(var(--accent-rgb),.45);border-left:0;border-bottom:0;border-radius:0 100% 0 0;transform:rotate(-10deg);animation:v25Trajectory 3.8s ease-in-out infinite;--d:3.8s}.visual-sports-trajectory span:nth-child(2){top:40%;width:36vw;height:23vh;animation-delay:-1.1s}.visual-sports-trajectory span:nth-child(3){top:59%;width:25vw;height:15vh;animation-delay:-2.2s}.visual-sports-trajectory b{left:48%;top:58%;width:22px;height:22px;border-radius:50%;background:var(--accent);box-shadow:0 0 24px rgba(var(--accent-rgb),.55);animation:v25Ball 2.8s cubic-bezier(.2,.75,.3,1) infinite;--d:2.8s}@keyframes v25Trajectory{50%{transform:translateY(-20px) rotate(-6deg)}}@keyframes v25Ball{0%{transform:translate(0,100px)}50%{transform:translate(300px,-80px)}100%{transform:translate(620px,80px);opacity:0}}

/* 17 Performance Pulse: 波形グラフ */
.visual-performance-pulse span{left:40%;right:4%;height:70px;background:linear-gradient(90deg,transparent,rgba(var(--accent-rgb),.12));clip-path:polygon(0 55%,8% 55%,11% 25%,15% 78%,19% 50%,29% 50%,33% 18%,39% 82%,45% 48%,100% 48%,100% 58%,45% 58%,39% 92%,33% 28%,29% 60%,19% 60%,15% 88%,11% 35%,8% 65%,0 65%);animation:v25Pulse 2.4s linear infinite;--d:2.4s}.visual-performance-pulse span:nth-child(1){top:26%}.visual-performance-pulse span:nth-child(2){top:47%;animation-delay:-.8s;opacity:.6}.visual-performance-pulse span:nth-child(3){top:68%;animation-delay:-1.6s;opacity:.45}@keyframes v25Pulse{0%{transform:translateX(-18%);filter:brightness(1)}50%{filter:brightness(1.8)}100%{transform:translateX(12%)}}

/* 18 Cultural Mosaic: タイルが組み上がる */
.visual-cultural-mosaic{right:3vw;top:14vh;width:45vw;height:66vh;display:grid!important;grid-template-columns:repeat(4,1fr);gap:14px}.visual-cultural-mosaic span{position:relative!important;width:100%;height:100%;border-radius:14px;background:linear-gradient(135deg,rgba(var(--accent-rgb),.22),rgba(255,255,255,.34));border:1px solid rgba(0,0,0,.06);animation:v25Tile 4.6s ease-in-out infinite;--d:4.6s}.visual-cultural-mosaic span:nth-child(2n){animation-delay:-1s}.visual-cultural-mosaic span:nth-child(3n){animation-delay:-2s}.visual-cultural-mosaic span:nth-child(5n){animation-delay:-3s}@keyframes v25Tile{0%,100%{transform:scale(.86) rotate(0);opacity:.42}50%{transform:scale(1) rotate(3deg);opacity:.86}}

/* 19 Security Shield: 盾型とスキャン */
.visual-security-shield span:nth-child(1){right:18vw;top:18vh;width:24vw;height:34vw;background:rgba(var(--accent-rgb),.08);border:3px solid rgba(var(--accent-rgb),.46);clip-path:polygon(50% 0,88% 13%,82% 70%,50% 100%,18% 70%,12% 13%);animation:v25Shield 5.5s ease-in-out infinite;--d:5.5s}.visual-security-shield span:nth-child(2){right:20vw;top:23vh;width:20vw;height:25vw;border:2px dashed rgba(var(--accent-rgb),.30);clip-path:polygon(50% 0,88% 13%,82% 70%,50% 100%,18% 70%,12% 13%);animation:v25Shield 4s ease-in-out infinite reverse;--d:4s}.visual-security-shield span:nth-child(3){right:13vw;top:42vh;width:34vw;height:4px;background:linear-gradient(90deg,transparent,var(--accent),transparent);animation:v25Scan 2.4s ease-in-out infinite;--d:2.4s}.visual-security-shield i{right:26vw;top:39vh;width:8vw;height:8vw;border-radius:50%;border:2px solid rgba(var(--accent-rgb),.38);animation:v25AiPulse 3s ease-out infinite;--d:3s}@keyframes v25Shield{50%{transform:scale(1.06);filter:drop-shadow(0 0 24px rgba(var(--accent-rgb),.24))}}@keyframes v25Scan{0%,100%{transform:translateY(-120px);opacity:0}50%{transform:translateY(120px);opacity:.85}}

/* 20 Education Flow: 階層と導線 */
.visual-education-flow span{right:8vw;width:38vw;height:64px;border-radius:12px;background:rgba(255,255,255,.38);border-left:7px solid var(--accent);box-shadow:0 16px 42px rgba(0,0,0,.08);animation:v25EduCard 5s ease-in-out infinite;--d:5s}.visual-education-flow span:nth-child(1){top:20vh}.visual-education-flow span:nth-child(2){top:35vh;right:15vw;animation-delay:-1s}.visual-education-flow span:nth-child(3){top:50vh;right:22vw;animation-delay:-2s}.visual-education-flow span:nth-child(4){top:65vh;right:29vw;animation-delay:-3s}.visual-education-flow i{right:44vw;width:3px;height:15vh;background:rgba(var(--accent-rgb),.38);animation:v25EduLine 3s ease-in-out infinite;--d:3s}.visual-education-flow i:nth-of-type(1){top:27vh}.visual-education-flow i:nth-of-type(2){top:42vh;right:51vw;animation-delay:-1s}.visual-education-flow i:nth-of-type(3){top:57vh;right:58vw;animation-delay:-2s}@keyframes v25EduCard{50%{transform:translateX(-30px);background:rgba(var(--accent-rgb),.10)}}@keyframes v25EduLine{50%{height:20vh;box-shadow:0 0 18px rgba(var(--accent-rgb),.34)}}
@keyframes v25Spin{to{transform:rotate(360deg)}}

@media(max-width:768px){.theme-visuals{opacity:.42}.visual-cultural-mosaic{right:-12vw;width:62vw}.visual-speed-line span{height:10px}.visual-human-connection,.visual-network-nodes,.visual-geometric-grid{transform:scale(.75);transform-origin:right center}.visual-corporate-depth span{width:60vw}.visual-education-flow span{width:58vw}.visual-security-shield span:nth-child(1){width:42vw;height:56vw;right:2vw}.visual-western-arch span{width:26vw}.visual-data-stream{left:28%}}

/* =========================================================
   V2.6 Footer Navigation Designer
   Navigationの折り返し・崩れを防ぎ、管理画面の設定で表示形式を切替
   ========================================================= */
.site-footer{
  position:relative;
  overflow:hidden;
  background:
    radial-gradient(circle at 12% 10%, rgba(var(--accent-rgb),.16), transparent 28%),
    radial-gradient(circle at 92% 90%, rgba(var(--accent-rgb),.10), transparent 34%),
    linear-gradient(135deg,#0b0d12 0%,#10131b 48%,#080a0f 100%);
  color:#fff;
  padding-top:72px;
  border-top:1px solid rgba(255,255,255,.08);
}
.site-footer .footer-accent-orbit{
  position:absolute;
  right:-14vw;
  bottom:-22vw;
  width:48vw;
  height:48vw;
  border:2px solid rgba(var(--accent-rgb),.28);
  border-radius:50%;
  transform:rotate(-16deg);
  pointer-events:none;
}
.site-footer .footer-accent-orbit:before,
.site-footer .footer-accent-orbit:after{
  content:"";
  position:absolute;
  inset:8%;
  border:1px solid rgba(var(--accent-rgb),.16);
  border-radius:50%;
}
.site-footer .footer-accent-orbit:after{inset:20%;opacity:.7}
.site-footer .footer-grid{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:minmax(260px,1.05fr) minmax(260px,1fr) minmax(300px,1.15fr);
  gap:56px;
  align-items:start;
}
.site-footer.footer-layout-two .footer-grid{grid-template-columns:minmax(280px,.9fr) minmax(520px,1.4fr)}
.site-footer.footer-layout-two .footer-services{grid-column:2;grid-row:1}
.site-footer.footer-layout-two .footer-navigation{grid-column:2;grid-row:2;margin-top:28px}
.site-footer.footer-layout-one .footer-grid{grid-template-columns:1fr;gap:36px}
.site-footer .footer-column{
  min-width:0;
  position:relative;
}
.site-footer.footer-layout-three .footer-column + .footer-column,
.site-footer.footer-layout-two .footer-services{
  border-left:1px solid rgba(255,255,255,.13);
  padding-left:48px;
}
.footer-brand-row{display:flex;gap:18px;align-items:center;margin-bottom:20px}
.footer-logo-mark{
  display:grid;
  place-items:center;
  width:72px;
  height:46px;
  font-family:var(--font-en);
  font-weight:900;
  letter-spacing:-.08em;
  font-size:29px;
  color:#fff;
  position:relative;
}
.footer-logo-mark:before{
  content:"";
  position:absolute;
  inset:8px -4px;
  border-top:3px solid var(--accent);
  border-bottom:3px solid var(--accent);
  border-radius:50%;
  transform:rotate(-13deg);
  opacity:.92;
}
.footer-brand{font-size:20px;line-height:1.35;font-weight:900;letter-spacing:.02em;color:#fff}
.site-footer .footer-en{margin:6px 0 0;color:#aeb4c0;font-family:var(--font-en);font-size:12px;letter-spacing:.13em;line-height:1.5}
.footer-red-line{display:block;width:58px;height:2px;background:var(--accent);margin:22px 0 24px;box-shadow:0 0 20px rgba(var(--accent-rgb),.28)}
.site-footer .footer-address,.site-footer .footer-phone{margin:0 0 8px;color:#e2e5ec;font-size:15px;line-height:1.8}
.site-footer h2{
  display:flex;
  align-items:center;
  gap:14px;
  margin:0 0 24px;
  font-family:var(--font-en),var(--font-jp);
  color:#fff;
  font-size:24px;
  letter-spacing:.04em;
  line-height:1.25;
}
.footer-heading-icon{color:var(--accent);font-size:22px;line-height:1}
.footer-service-list,.footer-nav-list{list-style:none;margin:0;padding:0}
.footer-service-list li{
  position:relative;
  padding:13px 0 13px 30px;
  border-bottom:1px solid rgba(255,255,255,.10);
  color:#edf0f5;
  font-weight:600;
  letter-spacing:.02em;
}
.footer-service-list li:before{
  content:"›";
  position:absolute;
  left:6px;
  top:50%;
  transform:translateY(-52%);
  color:var(--accent);
  font-size:24px;
  line-height:1;
}
.footer-nav-list a{
  position:relative;
  display:flex;
  align-items:center;
  gap:15px;
  min-height:54px;
  color:#f4f6fa;
  font-weight:800;
  letter-spacing:.02em;
  border-bottom:1px solid rgba(255,255,255,.10);
  transition:background .22s ease, transform .22s ease, border-color .22s ease, color .22s ease;
}
.footer-nav-list a:hover{color:#fff;transform:translateX(4px);border-color:rgba(var(--accent-rgb),.44)}
.footer-nav-icon{
  width:28px;
  height:28px;
  display:grid;
  place-items:center;
  color:#aeb4c0;
  flex:0 0 auto;
}
.footer-nav-icon svg{width:26px;height:26px;fill:none;stroke:currentColor;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
.footer-nav-list a:hover .footer-nav-icon{color:var(--accent)}
.footer-nav-label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}
.footer-nav-arrow{margin-left:auto;color:var(--accent);font-size:24px;line-height:1;opacity:.95}
.footer-bottom{position:relative;z-index:1;border-top:1px solid rgba(255,255,255,.12);margin-top:58px;padding:22px 0;color:#b7bdc8;background:rgba(0,0,0,.10)}
.footer-bottom-inner{display:flex;align-items:center;gap:22px}
.footer-bottom-line{display:block;width:150px;height:2px;background:var(--accent);box-shadow:0 0 20px rgba(var(--accent-rgb),.30)}

/* 表示形式1：縦リスト・アイコン付き */
.site-footer.footer-nav-list_icons .footer-navigation .footer-nav-list{display:block}
.site-footer.footer-nav-list_icons .footer-navigation .footer-nav-list a{padding:0 0}

/* 表示形式2：2カラムグリッド */
.site-footer.footer-nav-grid_2col .footer-nav-list{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
}
.site-footer.footer-nav-grid_2col .footer-nav-list a{
  min-height:58px;
  padding:0 14px;
  border:1px solid rgba(255,255,255,.11);
  border-radius:12px;
  background:rgba(255,255,255,.035);
}
.site-footer.footer-nav-grid_2col .footer-nav-list a:hover{background:rgba(var(--accent-rgb),.10);transform:translateY(-2px)}

/* 表示形式3：シンプル横並び */
.site-footer.footer-nav-simple_row .footer-nav-list{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}
.site-footer.footer-nav-simple_row .footer-nav-list a{
  min-height:42px;
  padding:0 15px;
  border:1px solid rgba(255,255,255,.12);
  border-radius:999px;
  background:rgba(255,255,255,.035);
}
.site-footer.footer-nav-simple_row .footer-nav-icon,.site-footer.footer-nav-simple_row .footer-nav-arrow{display:none}
.site-footer.footer-nav-simple_row .footer-nav-list a:hover{background:var(--accent);border-color:var(--accent);transform:translateY(-2px)}

/* 表示形式4：ボタンカード型 */
.site-footer.footer-nav-card_buttons .footer-nav-list{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
}
.site-footer.footer-nav-card_buttons .footer-nav-list a{
  min-height:74px;
  padding:14px 16px;
  border:1px solid rgba(255,255,255,.12);
  border-radius:16px;
  background:linear-gradient(135deg,rgba(255,255,255,.07),rgba(255,255,255,.025));
  box-shadow:0 16px 34px rgba(0,0,0,.18);
}
.site-footer.footer-nav-card_buttons .footer-nav-icon{
  width:36px;
  height:36px;
  border-radius:10px;
  background:rgba(var(--accent-rgb),.12);
  color:var(--accent);
}
.site-footer.footer-nav-card_buttons .footer-nav-list a:hover{background:linear-gradient(135deg,rgba(var(--accent-rgb),.18),rgba(255,255,255,.04));transform:translateY(-3px)}

@media(max-width:1024px){
  .site-footer .footer-grid,
  .site-footer.footer-layout-two .footer-grid{grid-template-columns:1fr 1fr;gap:38px}
  .site-footer.footer-layout-three .footer-column + .footer-column,
  .site-footer.footer-layout-two .footer-services{border-left:0;padding-left:0}
  .site-footer .footer-company{grid-column:1 / -1;padding-bottom:30px;border-bottom:1px solid rgba(255,255,255,.12)}
  .site-footer.footer-layout-two .footer-services,.site-footer.footer-layout-two .footer-navigation{grid-column:auto;grid-row:auto;margin-top:0}
}
@media(max-width:768px){
  .site-footer{padding-top:52px}
  .site-footer .footer-grid,
  .site-footer.footer-layout-two .footer-grid,
  .site-footer.footer-layout-one .footer-grid{grid-template-columns:1fr;gap:34px}
  .site-footer .footer-column{padding-left:0!important;border-left:0!important}
  .footer-brand-row{align-items:flex-start}
  .footer-brand{font-size:18px}
  .site-footer h2{font-size:22px;margin-bottom:18px}
  .site-footer.footer-nav-grid_2col .footer-nav-list,
  .site-footer.footer-nav-card_buttons .footer-nav-list{grid-template-columns:1fr}
  .site-footer.footer-nav-simple_row .footer-nav-list{display:grid;grid-template-columns:1fr 1fr}
  .site-footer.footer-nav-simple_row .footer-nav-list a{justify-content:center;text-align:center}
  .footer-bottom-inner{align-items:flex-start;flex-direction:column;gap:14px}
  .footer-bottom-line{width:96px}
}
@media(max-width:480px){
  .footer-logo-mark{width:56px;height:40px;font-size:23px}
  .site-footer.footer-nav-simple_row .footer-nav-list{grid-template-columns:1fr}
  .footer-nav-list a{min-height:50px}
}

/* =========================================================
   V2.8 Customizer-friendly controls
   入社3か月レベルでも破綻しにくいよう、数値設定はCSS変数で安全に反映
   ========================================================= */
.one-screen-stage{
  min-height:var(--nkts-hero-height,100svh);
  padding-top:var(--nkts-hero-top-padding,92px);
}
.stage-inner{
  width:min(100% - var(--nkts-hero-side-margin,56px),1440px);
}
.hero-fullwide{
  grid-template-columns:minmax(420px,var(--nkts-hero-copy-width,760px)) 1fr;
}
.hero-copy{max-width:var(--nkts-hero-copy-width,760px)}
.hero h1{
  font-size:clamp(44px,calc(6.1vw * var(--nkts-hero-title-scale,1)),140px);
}
.lead{
  font-size:clamp(14px,calc(1.1vw * var(--nkts-hero-lead-scale,1)),22px);
}
.panel{
  border-radius:var(--nkts-hero-panel-radius,16px);
  background:rgba(255,255,255,var(--nkts-hero-card-opacity,.86));
}
.panel-grid:empty{display:none}

.site-footer{
  padding-top:var(--nkts-footer-pad-top,72px);
}
.site-footer .footer-grid{
  gap:var(--nkts-footer-gap,56px);
}
.site-footer.footer-layout-three .footer-column + .footer-column,
.site-footer.footer-layout-two .footer-services{
  border-left-color:rgba(255,255,255,var(--nkts-footer-divider-opacity,.13));
}
.footer-logo-mark{
  width:var(--nkts-footer-logo-size,72px);
  height:calc(var(--nkts-footer-logo-size,72px) * .64);
  font-size:calc(var(--nkts-footer-logo-size,72px) * .40);
  flex:0 0 auto;
}
.footer-brand{font-size:var(--nkts-footer-company-size,20px)}
.site-footer .footer-en{font-size:var(--nkts-footer-en-size,12px)}
.site-footer .footer-address,.site-footer .footer-phone{font-size:var(--nkts-footer-address-size,15px)}
.site-footer h2{font-size:var(--nkts-footer-heading-size,24px)}
.footer-service-list li{font-size:var(--nkts-footer-service-size,16px)}
.footer-nav-list a{font-size:var(--nkts-footer-nav-size,16px)}
.footer-bottom{padding-top:var(--nkts-footer-pad-bottom,22px);padding-bottom:var(--nkts-footer-pad-bottom,22px)}
.footer-heading-icon{width:28px;height:28px;display:grid;place-items:center;color:var(--accent);flex:0 0 auto}
.footer-heading-icon svg{width:26px;height:26px;fill:none;stroke:currentColor;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.footer-nav-icon:empty{display:none}
.footer-nav-list a:has(.footer-nav-icon:empty){gap:8px}

@media(max-width:768px){
  .stage-inner{width:min(100% - 32px,1180px)}
  .hero-fullwide{grid-template-columns:1fr}
  .hero-copy{max-width:100%}
  .hero h1{font-size:clamp(34px,calc(12vw * var(--nkts-hero-title-scale,1)),68px)}
  .site-footer .footer-grid{gap:34px}
}

/* =========================
   V3.0 footer display cleanup
   ========================= */
.v30-footer.site-footer{
  background: radial-gradient(circle at 100% 0%, rgba(var(--accent-rgb),.12), transparent 30%), linear-gradient(180deg,#060b14 0%,#07101d 100%);
  padding-top: 64px;
}
.v30-footer .footer-accent-orbit{display:none}
.v30-footer .footer-grid-v30{
  display:grid;
  grid-template-columns: 1.15fr 1fr 1fr 1fr;
  gap: 48px;
  align-items:start;
}
.v30-footer .footer-column{
  min-width:0;
  padding-left:0;
  border-left:0;
  position:relative;
}
.v30-footer .footer-column:not(:first-child){
  padding-left:36px;
}
.v30-footer .footer-column:not(:first-child)::before{
  content:"";
  position:absolute;
  left:0;
  top:4px;
  bottom:4px;
  width:1px;
  background:rgba(255,255,255,.12);
}
.v30-footer h2{
  margin:0 0 28px;
  font-size:clamp(28px,var(--nkts-footer-heading-size,24px),28px);
  font-weight:800;
  line-height:1.2;
}
.v30-footer h2::after{
  content:"";
  display:block;
  width:56px;
  height:3px;
  margin-top:18px;
  background:var(--accent);
  box-shadow:0 0 18px rgba(var(--accent-rgb),.26);
}
.v30-footer .footer-brand-row-v30{margin-bottom:22px;gap:0}
.v30-footer .footer-brand{
  font-size:clamp(24px,var(--nkts-footer-company-size,20px),24px);
  line-height:1.45;
  word-break:keep-all;
}
.v30-footer .footer-en{
  margin-top:10px;
  color:#a7b1c3;
  font-size:clamp(12px,var(--nkts-footer-en-size,12px),13px);
  letter-spacing:.16em;
}
.v30-footer .footer-company-card{
  margin-top:24px;
  padding:22px 0;
  border-top:1px solid rgba(255,255,255,.12);
  border-bottom:1px solid rgba(255,255,255,.12);
}
.v30-footer .footer-place-row,
.v30-footer .footer-location-list li,
.v30-footer .footer-nav-list a{
  display:flex;
  align-items:flex-start;
  gap:14px;
}
.v30-footer .footer-place-icon,
.v30-footer .footer-location-icon{
  flex:0 0 44px;
  width:44px;
  height:44px;
  display:grid;
  place-items:center;
  border-radius:50%;
  color:#e7ecf6;
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.08);
}
.v30-footer .footer-place-icon svg,
.v30-footer .footer-location-icon svg{
  width:22px;height:22px;stroke-width:1.7;
}
.v30-footer .footer-place-row strong,
.v30-footer .footer-location-list strong{
  display:block;
  font-size:20px;
  line-height:1.45;
  color:#fff;
  margin-bottom:6px;
}
.v30-footer .footer-address,
.v30-footer .footer-phone,
.v30-footer .footer-location-list p,
.v30-footer .footer-tagline{
  margin:0;
  color:#d7ddeb;
  font-size:clamp(15px,var(--nkts-footer-address-size,15px),16px);
  line-height:1.8;
}
.v30-footer .footer-tagline{margin-top:24px;color:#afb7c8}
.v30-footer .footer-service-list-v30,
.v30-footer .footer-location-list,
.v30-footer .footer-nav-list-v30{list-style:none;margin:0;padding:0}
.v30-footer .footer-service-list-v30 li,
.v30-footer .footer-location-list li,
.v30-footer .footer-nav-list-v30 li{margin:0}
.v30-footer .footer-service-list-v30 li{
  position:relative;
  padding:16px 0 16px 24px;
  border-bottom:1px solid rgba(255,255,255,.12);
  color:#fff;
  font-size:clamp(17px,var(--nkts-footer-service-size,16px),18px);
  line-height:1.55;
}
.v30-footer .footer-service-list-v30 li:first-child{padding-top:4px}
.v30-footer .footer-service-list-v30 li::before{
  content:"";
  position:absolute;
  left:0;
  top:22px;
  width:2px;
  height:18px;
  background:var(--accent);
}
.v30-footer .footer-location-list li{
  padding:0 0 18px;
  margin-bottom:18px;
  border-bottom:1px solid rgba(255,255,255,.12);
}
.v30-footer .footer-location-list li:last-child,
.v30-footer .footer-service-list-v30 li:last-child{border-bottom:1px solid rgba(255,255,255,.12)}
.v30-footer .footer-nav-list-v30 a{
  min-height:auto;
  padding:0 0 18px;
  margin-bottom:18px;
  border-bottom:1px solid rgba(255,255,255,.12);
  border-top:0;
  border-right:0;
  border-left:0;
  border-radius:0;
  color:#fff;
  font-size:clamp(17px,var(--nkts-footer-nav-size,16px),18px);
  background:transparent;
  box-shadow:none;
}
.v30-footer .footer-nav-list-v30 .footer-nav-icon{
  flex:0 0 36px;
  width:36px;height:36px;
  display:grid;place-items:center;
  color:#b9c1d2;
}
.v30-footer .footer-nav-list-v30 .footer-nav-icon svg{width:22px;height:22px}
.v30-footer .footer-nav-list-v30 .footer-nav-label{white-space:normal;overflow:visible;text-overflow:clip;line-height:1.5}
.v30-footer .footer-nav-list-v30 a:hover{transform:none;color:#fff;border-color:rgba(var(--accent-rgb),.45)}
.v30-footer .footer-nav-list-v30 a:hover .footer-nav-icon,
.v30-footer .footer-nav-list-v30 a:hover .footer-nav-arrow{color:var(--accent)}
.v30-footer .footer-bottom{margin-top:34px}
.v30-footer .footer-bottom-inner{justify-content:flex-start}
@media(max-width:1200px){
  .v30-footer .footer-grid-v30{grid-template-columns:1fr 1fr;gap:40px}
  .v30-footer .footer-column:nth-child(3)::before{display:none}
  .v30-footer .footer-column:nth-child(3){padding-left:0}
}
@media(max-width:767px){
  .v30-footer .footer-grid-v30{grid-template-columns:1fr;gap:34px}
  .v30-footer .footer-column:not(:first-child){padding-left:0}
  .v30-footer .footer-column:not(:first-child)::before{display:none}
  .v30-footer h2{margin-bottom:22px;font-size:24px}
  .v30-footer .footer-brand{font-size:20px}
  .v30-footer .footer-place-row strong,
  .v30-footer .footer-location-list strong{font-size:18px}
}

/* V3.1 footer and admin-visible refinements */
.v30-footer .footer-location-type{
  display:inline-block;
  margin:0 0 6px;
  padding:2px 8px;
  border:1px solid rgba(var(--accent-rgb),.42);
  color:#ffccd1;
  background:rgba(var(--accent-rgb),.08);
  border-radius:999px;
  font-size:11px;
  font-weight:800;
  letter-spacing:.08em;
}
.v30-footer .footer-location-list li:empty{display:none}
.nkts-seo-box label{display:block;margin-bottom:4px}
.nkts-seo-box textarea,.nkts-seo-box input{box-sizing:border-box}


/* V3.3 footer icon implementation */
.v30-footer h2{display:flex;align-items:center;gap:12px;word-break:keep-all;overflow-wrap:anywhere;}
.v30-footer h2::after{display:none;}
.v30-footer h2 .footer-heading-icon{width:26px;height:26px;display:grid;place-items:center;color:var(--accent);}
.v30-footer h2 .footer-heading-icon svg{width:22px;height:22px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;}
.v30-footer h2:after{content:"";display:block;width:56px;height:3px;background:var(--accent);box-shadow:0 0 18px rgba(var(--accent-rgb),.26);position:absolute;margin-top:48px;}
.v30-footer .footer-brand,
.v30-footer .footer-location-list strong,
.v30-footer .footer-service-list-v30 li,
.v30-footer .footer-nav-list-v30 a{overflow-wrap:anywhere;word-break:normal;}
.v30-footer .footer-location-list div,.v30-footer .footer-place-row div{min-width:0;}
.v30-footer .footer-location-icon,.v30-footer .footer-place-icon{flex-shrink:0;}
.v30-footer .footer-nav-icon svg,.v30-footer .footer-heading-icon svg,.v30-footer .footer-location-icon svg,.v30-footer .footer-place-icon svg{fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round;}
.v30-footer .footer-nav-list-v30 a{align-items:center;}
@media(max-width:1200px){.v30-footer .footer-grid-v30{grid-template-columns:1fr 1fr!important;}}
@media(max-width:767px){.v30-footer .footer-grid-v30{grid-template-columns:1fr!important;}.v30-footer h2:after{margin-top:42px;}}


/* =========================
   V3.4 footer font-size bugfix
   - clamp() and media-query fixed sizes are disabled here.
   - The actual px values are supplied through wp_head inline CSS.
   ========================= */
.v30-footer h2{font-size:var(--nkts-footer-heading-size,24px)!important;}
.v30-footer .footer-brand{font-size:var(--nkts-footer-company-size,20px)!important;}
.v30-footer .footer-en{font-size:var(--nkts-footer-en-size,12px)!important;}
.v30-footer .footer-address,
.v30-footer .footer-phone,
.v30-footer .footer-place-row p,
.v30-footer .footer-tagline{font-size:var(--nkts-footer-address-size,15px)!important;}
.v30-footer .footer-service-list-v30 li,
.v30-footer .footer-service-list li{font-size:var(--nkts-footer-service-size,16px)!important;}
.v30-footer .footer-nav-list-v30 a,
.v30-footer .footer-nav-list a{font-size:var(--nkts-footer-nav-size,16px)!important;}
.v30-footer .footer-location-list strong{font-size:var(--nkts-v33-location-title-size,17px)!important;}
.v30-footer .footer-location-type{font-size:var(--nkts-v33-location-type-size,11px)!important;}
.v30-footer .footer-location-list p{font-size:var(--nkts-v33-location-text-size,13px)!important;}
.v30-footer .footer-heading-icon svg,
.v30-footer .footer-nav-icon svg,
.v30-footer .footer-place-icon svg,
.v30-footer .footer-location-icon svg{width:var(--nkts-v33-icon-size,22px)!important;height:var(--nkts-v33-icon-size,22px)!important;}
.v30-footer .footer-brand,
.v30-footer .footer-en,
.v30-footer h2,
.v30-footer .footer-service-list-v30 li,
.v30-footer .footer-nav-label,
.v30-footer .footer-location-list strong,
.v30-footer .footer-location-list p{overflow-wrap:anywhere;word-break:normal;}
@media(max-width:767px){
  .v30-footer h2{font-size:var(--nkts-footer-heading-size,24px)!important;}
  .v30-footer .footer-brand{font-size:var(--nkts-footer-company-size,20px)!important;}
  .v30-footer .footer-place-row strong,
  .v30-footer .footer-location-list strong{font-size:var(--nkts-v33-location-title-size,17px)!important;}
}

/* V3.8: clickable mini tags */
.mini-tags a.mini-tag-link{border:1px solid var(--line);border-radius:4px;padding:4px 10px;font-size:12px;background:rgba(255,255,255,.55);display:inline-flex;align-items:center;transition:.2s}
.mini-tags a.mini-tag-link:hover{border-color:rgba(var(--accent-rgb),.55);color:var(--accent);transform:translateY(-1px)}

/* =========================
   V4.1 Page / Post templates
   ========================= */
.nkts-template-hero{padding:140px 0 54px;background:linear-gradient(135deg,#f7f8fb,#fff);border-bottom:1px solid rgba(16,17,22,.08)}
.nkts-template-hero h1,.nkts-lp-hero h1,.nkts-recruit-hero h1,.nkts-shop-hero h1{font-size:clamp(38px,6vw,78px);line-height:1.14;margin:8px 0 0;font-weight:900;letter-spacing:.02em}
.template-kicker{font-family:var(--font-en);font-weight:900;letter-spacing:.18em;color:var(--accent);margin:0 0 8px;font-size:13px}
.template-lead{max-width:760px;font-size:clamp(16px,2vw,20px);color:#4b5563;margin:18px 0 0;line-height:1.9}.nkts-template-body{padding:76px 0;background:#fff}.narrow{max-width:920px}.template-grid-2{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:44px;align-items:start}.template-main,.template-side,.nkts-shop-info-card{background:#fff;border:1px solid var(--line);border-radius:22px;padding:34px;box-shadow:0 20px 60px rgba(16,20,28,.07)}.template-side{position:sticky;top:110px}.template-side h2{font-size:22px;margin:0 0 18px}.template-side ul{padding-left:1.3em;color:#4b5563}.template-featured-img,.nkts-wide-featured img{border-radius:24px;box-shadow:0 24px 80px rgba(16,20,28,.16)}.nkts-wide-featured{width:min(1400px,calc(100% - 44px));margin:46px auto 0}.nkts-fullwide-content{width:min(1180px,calc(100% - 44px));margin:64px auto}.nkts-lp-hero,.nkts-recruit-hero,.nkts-shop-hero{min-height:72vh;display:grid;place-items:center;padding:120px 0 70px;background:radial-gradient(circle at 85% 18%,rgba(var(--accent-rgb),.18),transparent 34%),linear-gradient(135deg,#050911,#121824);color:#fff}.nkts-lp-hero .template-lead,.nkts-recruit-hero .template-lead,.nkts-shop-hero .template-lead{color:#dce3ef}.template-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:28px}.nkts-template-cta{padding:70px 0;background:#fff}.case-dl{display:grid;grid-template-columns:90px 1fr;gap:10px 16px}.case-dl dt{font-weight:900;color:var(--accent)}.case-dl dd{margin:0;color:#4b5563}.column-entry{font-size:17px;line-height:2.05}.nkts-flow-block{margin:40px 0}.nkts-flow-list{list-style:none;margin:0;padding:0;display:grid;gap:16px;counter-reset:flow}.nkts-flow-list li{display:grid;grid-template-columns:72px minmax(0,1fr);gap:18px;padding:22px;border:1px solid var(--line);border-radius:18px;background:#fff;box-shadow:0 14px 40px rgba(16,20,28,.06)}.nkts-flow-list li>span{width:56px;height:56px;border-radius:50%;display:grid;place-items:center;background:var(--accent);color:#fff;font-weight:900;font-family:var(--font-en);box-shadow:0 0 0 8px rgba(var(--accent-rgb),.12)}.nkts-flow-list h3{margin:0 0 4px;font-size:20px}.nkts-flow-list p{margin:0;color:#5b6472}.nkts-faq-block{display:grid;gap:12px;margin-top:28px}.nkts-faq-block details{border:1px solid var(--line);border-radius:14px;background:#fff;overflow:hidden}.nkts-faq-block summary{cursor:pointer;font-weight:900;padding:18px 22px}.nkts-faq-block p{margin:0;padding:0 22px 20px;color:#4b5563}.nkts-price-table{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin:34px 0}.nkts-price-table article{padding:28px;border:1px solid var(--line);border-radius:20px;background:#fff;box-shadow:0 16px 48px rgba(16,20,28,.06)}.nkts-price-table article.featured{border-color:rgba(var(--accent-rgb),.35);box-shadow:0 24px 70px rgba(var(--accent-rgb),.12)}.nkts-price-table small{color:var(--accent);font-weight:900;letter-spacing:.15em}.nkts-price-table h3{font-size:24px;margin:8px 0}.nkts-price-table .price{font-size:22px;font-weight:900;color:#111}.nkts-shop-info-card dl{display:grid;grid-template-columns:110px 1fr;gap:12px 18px}.nkts-shop-info-card dt{font-weight:900;color:var(--accent)}.nkts-shop-info-card dd{margin:0;color:#4b5563}.nkts-shop-hero{background:radial-gradient(circle at 85% 20%,rgba(var(--accent-rgb),.18),transparent 36%),linear-gradient(135deg,#160b09,#31120e)}
@media(max-width:900px){.template-grid-2{grid-template-columns:1fr}.template-side{position:static}.nkts-price-table{grid-template-columns:1fr}.nkts-flow-list li{grid-template-columns:1fr}.nkts-template-hero{padding-top:110px}.nkts-shop-info-card dl{grid-template-columns:1fr}.nkts-lp-hero,.nkts-recruit-hero,.nkts-shop-hero{min-height:auto;text-align:left}}


/* ==========================================================
   NKTS V4.30 Template + Initial Content
   テンプレートはレイアウト専用、雛形は本文編集可能
========================================================== */
.nkts-initial-section {
  margin: 0 0 56px;
}
.nkts-initial-section h2 {
  margin: 0 0 18px;
  color: var(--nkts-navy, #071f3d);
  font-size: clamp(26px, 3.4vw, 40px);
  line-height: 1.35;
  font-weight: 800;
}
.nkts-initial-section p {
  margin-top: 0;
}
.nkts-initial-section .section-label,
.section-label {
  display: inline-block;
  margin: 0 0 10px !important;
  color: var(--nkts-blue, #0f6eb8);
  font-size: 13px;
  font-weight: 800;
  letter-spacing: .16em;
}
.nkts-initial-soft {
  background: linear-gradient(180deg, #fff, #f4f8fb);
  border: 1px solid rgba(15, 110, 184, .14);
  border-radius: 28px;
  padding: clamp(28px, 4vw, 48px);
}
.nkts-initial-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 22px;
  margin: 0 0 56px;
}
.nkts-initial-card,
.nkts-initial-list > div,
.nkts-initial-price > div {
  background: #fff;
  border: 1px solid rgba(15, 110, 184, .14);
  border-radius: 24px;
  padding: 28px;
  box-shadow: 0 12px 30px rgba(15, 50, 85, .07);
}
.nkts-initial-card h3,
.nkts-initial-list h3,
.nkts-initial-price h3 {
  margin: 0 0 10px;
  color: var(--nkts-navy, #071f3d);
  font-size: 20px;
  line-height: 1.45;
}
.nkts-initial-card p,
.nkts-initial-list p,
.nkts-initial-price p {
  margin: 0;
  color: #64748b;
}
.nkts-initial-list,
.nkts-initial-price {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}
.nkts-initial-price {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
.nkts-initial-price .price {
  color: var(--nkts-blue, #0f6eb8);
  font-size: 24px;
  font-weight: 800;
  margin-bottom: 10px;
}
.nkts-initial-table {
  width: 100%;
  border-collapse: collapse;
  background: #fff;
  border: 1px solid rgba(15, 110, 184, .14);
  border-radius: 20px;
  overflow: hidden;
  display: table;
}
.nkts-initial-table th,
.nkts-initial-table td {
  padding: 18px 20px;
  border-bottom: 1px solid rgba(15, 110, 184, .14);
  vertical-align: top;
}
.nkts-initial-table th {
  width: 220px;
  color: var(--nkts-navy, #071f3d);
  background: #f4f8fb;
  text-align: left;
}
.nkts-initial-flow {
  list-style: none;
  counter-reset: nkts-flow;
  padding: 0;
  margin: 0;
}
.nkts-initial-flow li {
  counter-increment: nkts-flow;
  position: relative;
  padding: 22px 22px 22px 72px;
  margin-bottom: 16px;
  background: #fff;
  border: 1px solid rgba(15, 110, 184, .14);
  border-radius: 20px;
  box-shadow: 0 10px 24px rgba(15, 50, 85, .06);
}
.nkts-initial-flow li::before {
  content: counter(nkts-flow);
  position: absolute;
  left: 22px;
  top: 22px;
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--nkts-blue, #0f6eb8), #36c2ff);
  color: #fff;
  display: grid;
  place-items: center;
  font-weight: 800;
}
.nkts-initial-faq details {
  background: #fff;
  border: 1px solid rgba(15, 110, 184, .14);
  border-radius: 18px;
  padding: 18px 22px;
  margin-bottom: 14px;
  box-shadow: 0 8px 22px rgba(15, 50, 85, .05);
}
.nkts-initial-faq summary {
  cursor: pointer;
  font-weight: 800;
  color: var(--nkts-navy, #071f3d);
}
.nkts-initial-faq p {
  margin: 12px 0 0;
  color: #64748b;
}
.nkts-initial-cta {
  text-align: center;
  background:
    radial-gradient(circle at 15% 15%, rgba(54,194,255,.16), transparent 30%),
    linear-gradient(135deg, #06152a, #0f4f84);
  color: #fff;
  border-radius: 28px;
  padding: clamp(34px, 5vw, 60px);
  margin: 56px 0;
}
.nkts-initial-cta h2 {
  margin: 0 0 12px;
  color: #fff;
  font-size: clamp(26px, 3.4vw, 40px);
}
.nkts-initial-cta p {
  color: #e8f6ff;
}
.nkts-v430-two-col {
  display: grid;
  gap: 32px;
  align-items: start;
}
.nkts-v430-two-col-7-3 {
  grid-template-columns: minmax(0, 7fr) minmax(260px, 3fr);
}
.nkts-v430-two-col-3-7 {
  grid-template-columns: minmax(260px, 3fr) minmax(0, 7fr);
}
.nkts-v430-side-card {
  background: #fff;
  border: 1px solid rgba(15, 110, 184, .14);
  border-radius: 22px;
  padding: 22px;
  margin: 0 0 18px;
  box-shadow: 0 12px 30px rgba(15,50,85,.07);
}
.nkts-v430-side-card img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 16px;
}
.nkts-v430-side-card h2 {
  margin: 0 0 8px;
  color: var(--nkts-navy, #071f3d);
  font-size: 20px;
}
.nkts-v430-three-content .nkts-initial-grid,
.nkts-v430-three-content .nkts-initial-price {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
@media (max-width: 900px) {
  .nkts-initial-grid,
  .nkts-initial-list,
  .nkts-initial-price,
  .nkts-v430-two-col,
  .nkts-v430-two-col-7-3,
  .nkts-v430-two-col-3-7 {
    grid-template-columns: 1fr;
  }
  .nkts-initial-table,
  .nkts-initial-table tbody,
  .nkts-initial-table tr,
  .nkts-initial-table th,
  .nkts-initial-table td {
    display: block;
    width: 100%;
  }
  .nkts-initial-table th {
    border-bottom: none;
    padding-bottom: 8px;
  }
  .nkts-initial-table td {
    padding-top: 8px;
  }
}


/* ==========================================================
   NKTS V4.61 Column Area Rendering
========================================================== */
.nkts-v461-managed-columns {
  display: grid;
  gap: 32px;
  align-items: start;
}
.nkts-v461-template-two-col-7-3 {
  grid-template-columns: minmax(0, 7fr) minmax(260px, 3fr);
}
.nkts-v461-template-two-col-3-7 {
  grid-template-columns: minmax(260px, 3fr) minmax(0, 7fr);
}
.nkts-v461-three {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
.nkts-v461-col {
  min-width: 0;
}
.nkts-v461-col > *:first-child {
  margin-top: 0;
}
.nkts-v461-col-left,
.nkts-v461-col-center,
.nkts-v461-col-right {
  overflow-wrap: anywhere;
}
@media (max-width: 900px) {
  .nkts-v461-template-two-col-7-3,
  .nkts-v461-template-two-col-3-7,
  .nkts-v461-three {
    grid-template-columns: 1fr;
  }
}


/* ==========================================================
   NKTS V4.62 Area Rendering for Service / Case / Recruit
========================================================== */
.nkts-v462-service-layout,
.nkts-v462-case-layout {
  display: grid;
  grid-template-columns: minmax(0, 7fr) minmax(280px, 3fr);
  gap: 32px;
  align-items: start;
}
.nkts-v462-service-main,
.nkts-v462-case-main,
.nkts-v462-service-side,
.nkts-v462-case-side,
.nkts-v462-recruit-main,
.nkts-v462-recruit-bottom {
  min-width: 0;
}
.nkts-v462-service-side,
.nkts-v462-case-side {
  background: #fff;
  border: 1px solid rgba(15, 110, 184, .14);
  border-radius: 22px;
  padding: 24px;
  box-shadow: 0 12px 30px rgba(15,50,85,.07);
}
.nkts-v462-service-bottom,
.nkts-v462-recruit-bottom {
  margin-top: 48px;
}
.nkts-v462-service-main > *:first-child,
.nkts-v462-case-main > *:first-child,
.nkts-v462-service-side > *:first-child,
.nkts-v462-case-side > *:first-child,
.nkts-v462-recruit-main > *:first-child,
.nkts-v462-recruit-bottom > *:first-child {
  margin-top: 0;
}
.template-featured-img-wrap {
  margin: 0 0 28px;
}
.template-featured-img {
  width: 100%;
  height: auto;
  border-radius: 22px;
  display: block;
}
@media (max-width: 900px) {
  .nkts-v462-service-layout,
  .nkts-v462-case-layout {
    grid-template-columns: 1fr;
  }
}


/* ==========================================================
   NKTS V4.63 Hide template name labels on front page
   テンプレート識別用ラベルをサイト表示から非表示
========================================================== */
.nkts-template-hero .template-kicker,
.nkts-lp-hero .template-kicker,
.nkts-shop-hero .template-kicker,
.nkts-recruit-hero .template-kicker,
.page-hero .template-kicker {
  display: none !important;
}


/* ==========================================================
   NKTS V5.07 Fullwide / Landing templates
   固定ページ本文をそのままフル幅表示するための調整
========================================================== */
.nkts-v507-full-template,
.nkts-v507-landing-template {
  width: 100%;
}

.nkts-v507-full-content {
  width: 100%;
  max-width: none;
  margin: 0;
}

.nkts-v507-full-content > * {
  max-width: none;
}

.nkts-v507-full-content .alignwide,
.nkts-v507-full-content .alignfull {
  width: 100%;
  max-width: none;
}

.nkts-v507-landing-template {
  padding-left: 0;
  padding-right: 0;
}

.nkts-v507-landing-template > .entry-content,
.nkts-v507-full-template > .entry-content {
  padding-left: 0;
  padding-right: 0;
}


/* ==========================================================
   NKTS V5.11 AI Custom HTML Safe Rendering
   100vw/calcに頼らず、テンプレート側の幅に自然追従させる
========================================================== */
.nkts-ai-fullwide-creative,
.nkts-ai-custom-html-safe {
  display: block;
  width: 100%;
  max-width: none;
  box-sizing: border-box;
}

.nkts-ai-fullwide-creative *,
.nkts-ai-custom-html-safe * {
  box-sizing: border-box;
}

.entry-content .nkts-ai-fullwide-creative,
.entry-content .nkts-ai-custom-html-safe {
  margin-left: 0;
  margin-right: 0;
}


/* ==========================================================
   NKTS V5.13 AI Generated HTML visible wrapper
========================================================== */
.nkts-ai-editor-visible {
  display: block;
  visibility: visible;
  opacity: 1;
  min-height: 160px;
  overflow: visible;
  position: relative;
  width: 100%;
  box-sizing: border-box;
}

.nkts-ai-editor-visible * {
  box-sizing: border-box;
}


/* ==========================================================
   NKTS V5.16 Reveal Fallback / AI HTML Visibility Fix
   フルワイド本文とAI生成HTMLはJSアニメーションに依存せず表示する
========================================================== */
.nkts-v507-full-template .reveal,
.nkts-v507-landing-template .reveal,
.nkts-v507-full-content.reveal,
.nkts-v507-full-content .reveal,
.nkts-ai-fullwide-creative,
.nkts-ai-custom-html-safe,
.nkts-ai-editor-visible {
  opacity: 1 !important;
  transform: none !important;
  visibility: visible !important;
  display: block;
}

.nkts-v507-full-content,
.nkts-v507-full-content > *,
.nkts-v507-landing-template .entry-content,
.nkts-v507-full-template .entry-content {
  opacity: 1 !important;
  visibility: visible !important;
}

.nkts-ai-fullwide-creative,
.nkts-ai-custom-html-safe,
.nkts-ai-editor-visible {
  min-height: 160px;
  overflow: visible !important;
}


/* ==========================================================
   NKTS V5.17 Frontend AI HTML visibility fallback
========================================================== */
.nkts-v507-full-content,
.nkts-v507-full-content > *,
.nkts-v507-full-content .wp-block-html,
.nkts-v507-full-content .wp-block-html > *,
.nkts-ai-fullwide-creative,
.nkts-ai-custom-html-safe,
.nkts-ai-editor-visible {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
  transform: none !important;
  overflow: visible !important;
  height: auto !important;
  max-height: none !important;
}

.nkts-v507-full-content .reveal,
.nkts-v507-landing-template .reveal,
.nkts-v507-full-template .reveal,
.nkts-ai-fullwide-creative .reveal,
.nkts-ai-custom-html-safe .reveal,
.nkts-ai-editor-visible .reveal {
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
}


/* ==========================================================
   NKTS V5.18 Default template content visibility
   デフォルト/標準/1カラムでも固定ページ本文を確実に表示
========================================================== */
.nkts-v518-default-page,
.nkts-v518-default-single,
.nkts-v518-standard-template,
.nkts-v518-one-column-template,
.nkts-v518-entry-content,
.nkts-v518-entry-content > *,
.nkts-v518-entry-content .wp-block-html,
.nkts-v518-entry-content .wp-block-html > * {
  visibility: visible !important;
  opacity: 1 !important;
  transform: none !important;
  overflow: visible;
}

.nkts-v518-entry-content {
  display: block;
  width: 100%;
}

.nkts-v518-entry-content .reveal,
.nkts-v518-entry-content .nkts-ai-fullwide-creative,
.nkts-v518-entry-content .nkts-ai-custom-html-safe,
.nkts-v518-entry-content .nkts-ai-editor-visible {
  visibility: visible !important;
  opacity: 1 !important;
  transform: none !important;
}


/* ==========================================================
   NKTS V5.19 Modern breadcrumb + compact fullwide/landing header
========================================================== */
.nkts-breadcrumb-strip {
  padding: 18px 0 12px;
  background: linear-gradient(180deg, rgba(248,250,252,.96), rgba(255,255,255,.96));
  border-bottom: 1px solid rgba(15, 23, 42, .06);
}

.nkts-breadcrumb-strip.is-compact {
  min-height: auto;
}

.nkts-breadcrumb-strip.has-visual-hero {
  padding-bottom: 8px;
  border-bottom: 0;
}

.nkts-modern-breadcrumb {
  display: inline-flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 7px;
  max-width: 100%;
  margin: 0;
  padding: 7px 10px;
  border: 1px solid rgba(15, 111, 184, .12);
  border-radius: 999px;
  background: rgba(255, 255, 255, .78);
  box-shadow: 0 8px 24px rgba(15, 31, 61, .05);
  backdrop-filter: blur(8px);
  font-size: 12px;
  line-height: 1.2;
  color: #526173;
}

.nkts-modern-breadcrumb a,
.nkts-modern-breadcrumb span {
  display: inline-flex;
  align-items: center;
  min-width: 0;
}

.nkts-modern-breadcrumb .breadcrumb-link {
  color: var(--accent);
  text-decoration: none;
  font-weight: 800;
  letter-spacing: .02em;
  padding: 3px 7px;
  border-radius: 999px;
  transition: background .18s ease, color .18s ease, transform .18s ease;
}

.nkts-modern-breadcrumb .breadcrumb-link:hover {
  background: rgba(var(--accent-rgb), .08);
  transform: translateY(-1px);
}

.nkts-modern-breadcrumb .breadcrumb-separator {
  color: rgba(15, 31, 61, .35);
  font-weight: 800;
  font-size: 13px;
}

.nkts-modern-breadcrumb .breadcrumb-current {
  color: #0f1f3d;
  font-weight: 800;
  padding: 3px 7px;
  border-radius: 999px;
  background: rgba(15, 31, 61, .04);
  max-width: min(48vw, 520px);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.nkts-v519-visual-hero.nkts-template-hero {
  padding: 74px 0 48px;
}

.nkts-v519-visual-hero.nkts-lp-hero {
  min-height: 42vh;
  padding: 74px 0 56px;
}

/* When no image/excerpt exists, do not reserve a huge hero area */
body.page-template-template-fullwide-php .nkts-breadcrumb-strip + .nkts-fullwide-main,
body.page-template-template-landing-php .nkts-breadcrumb-strip + .nkts-template-body {
  margin-top: 0;
}

@media (max-width: 782px) {
  .nkts-breadcrumb-strip {
    padding: 12px 0 8px;
  }
  .nkts-modern-breadcrumb {
    border-radius: 16px;
    font-size: 11px;
    padding: 7px 8px;
  }
  .nkts-modern-breadcrumb .breadcrumb-current {
    max-width: 72vw;
  }
}


/* ==========================================================
   NKTS V5.20 Dedicated visible compact breadcrumb
========================================================== */
.nkts-breadcrumb-strip {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
  position: relative;
  z-index: 5;
}

.nkts-breadcrumb-strip .container {
  display: flex;
  align-items: center;
  min-height: 38px;
}

.nkts-v520-breadcrumb {
  display: inline-flex !important;
  visibility: visible !important;
  opacity: 1 !important;
  align-items: center;
  flex-wrap: wrap;
  gap: 7px;
  max-width: 100%;
  margin: 0;
  padding: 8px 12px;
  border: 1px solid rgba(15, 111, 184, .16);
  border-radius: 999px;
  background: rgba(255,255,255,.92);
  color: #44546a;
  box-shadow: 0 10px 28px rgba(15,31,61,.07);
  backdrop-filter: blur(8px);
  font-size: 12px;
  line-height: 1.2;
  font-weight: 700;
}

.nkts-v520-breadcrumb a,
.nkts-v520-breadcrumb span {
  display: inline-flex;
  align-items: center;
}

.nkts-v520-breadcrumb-link {
  color: var(--accent, #0f6eb8) !important;
  text-decoration: none !important;
  padding: 3px 7px;
  border-radius: 999px;
  transition: background .18s ease, transform .18s ease;
}

.nkts-v520-breadcrumb-link:hover {
  background: rgba(var(--accent-rgb), .08);
  transform: translateY(-1px);
}

.nkts-v520-breadcrumb-sep {
  color: rgba(15,31,61,.38);
  font-weight: 900;
}

.nkts-v520-breadcrumb-current {
  color: #0f1f3d !important;
  background: rgba(15,31,61,.045);
  padding: 3px 8px;
  border-radius: 999px;
  max-width: min(52vw, 560px);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

@media (max-width: 782px) {
  .nkts-v520-breadcrumb {
    border-radius: 16px;
    font-size: 11px;
    padding: 7px 9px;
  }
  .nkts-v520-breadcrumb-current {
    max-width: 70vw;
  }
}


/* ==========================================================
   NKTS V5.21 Smartphone TOP video responsive fix
   スマホではTOP動画が見切れないように自動調整
========================================================== */
@media (max-width: 782px) {
  .one-screen-stage {
    min-height: auto;
    padding: 74px 0 28px;
    display: block;
    overflow: hidden;
  }

  .one-screen-stage .media-backdrop {
    position: relative;
    inset: auto;
    width: 100%;
    height: auto;
    min-height: 0;
    aspect-ratio: 16 / 9;
    overflow: hidden;
    background: #f7f8fa;
  }

  .one-screen-stage .hero-video {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: contain !important;
    object-position: center center !important;
    background: #f7f8fa;
  }

  .one-screen-stage .hero-static-image,
  .one-screen-stage .hero-slideshow {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    background-size: contain !important;
    background-repeat: no-repeat;
    background-position: center center !important;
    object-fit: contain !important;
  }

  .one-screen-stage .media-shade {
    background:
      linear-gradient(180deg, rgba(255,255,255,.38) 0%, rgba(255,255,255,.72) 82%, rgba(255,255,255,.94) 100%);
    pointer-events: none;
  }

  .one-screen-stage .stage-gridline,
  .one-screen-stage .stage-particles,
  .one-screen-stage .stage-motion,
  .one-screen-stage .stage-waves {
    opacity: .18;
  }
}

@media (max-width: 480px) {
  .one-screen-stage .media-backdrop {
    aspect-ratio: 4 / 3;
  }

  .one-screen-stage .hero-video {
    object-fit: contain !important;
  }
}

/* 横向きスマホでは画面高さを使いすぎない */
@media (max-width: 900px) and (orientation: landscape) {
  .one-screen-stage {
    min-height: auto;
  }

  .one-screen-stage .media-backdrop {
    aspect-ratio: 16 / 7;
  }
}


/* ==========================================================
   NKTS V5.22 Breadcrumb visibility upgrade
   小さすぎて見えない問題を修正。パンくずは「見えるナビ」として扱う。
========================================================== */
.nkts-breadcrumb-strip {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
  position: relative !important;
  z-index: 50 !important;
  min-height: 62px !important;
  padding: 18px 0 16px !important;
  background: linear-gradient(180deg, #f8fafc 0%, #ffffff 100%) !important;
  border-bottom: 1px solid rgba(15, 31, 61, .10) !important;
}

.nkts-breadcrumb-strip .container {
  display: flex !important;
  align-items: center !important;
  min-height: 28px !important;
}

.nkts-v520-breadcrumb,
.nkts-modern-breadcrumb,
.breadcrumb.nkts-modern-breadcrumb {
  display: inline-flex !important;
  visibility: visible !important;
  opacity: 1 !important;
  align-items: center !important;
  flex-wrap: wrap !important;
  gap: 10px !important;
  max-width: 100% !important;
  margin: 0 !important;
  padding: 10px 16px !important;
  border: 1px solid rgba(15, 111, 184, .22) !important;
  border-radius: 18px !important;
  background: #ffffff !important;
  color: #1f2a3d !important;
  box-shadow: 0 12px 32px rgba(15, 31, 61, .10) !important;
  font-size: 14px !important;
  line-height: 1.35 !important;
  font-weight: 800 !important;
  letter-spacing: .01em !important;
}

.nkts-v520-breadcrumb a,
.nkts-v520-breadcrumb span,
.nkts-modern-breadcrumb a,
.nkts-modern-breadcrumb span {
  display: inline-flex !important;
  align-items: center !important;
  visibility: visible !important;
  opacity: 1 !important;
}

.nkts-v520-breadcrumb-link,
.nkts-modern-breadcrumb .breadcrumb-link {
  color: var(--accent, #0f6eb8) !important;
  text-decoration: none !important;
  padding: 5px 9px !important;
  border-radius: 12px !important;
  background: rgba(15,111,184,.07) !important;
}

.nkts-v520-breadcrumb-current,
.nkts-modern-breadcrumb .breadcrumb-current {
  color: #0f1f3d !important;
  background: rgba(15,31,61,.07) !important;
  padding: 5px 10px !important;
  border-radius: 12px !important;
  max-width: min(62vw, 680px) !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}

.nkts-v520-breadcrumb-sep,
.nkts-modern-breadcrumb .breadcrumb-separator {
  color: rgba(15,31,61,.55) !important;
  font-weight: 900 !important;
  font-size: 16px !important;
}

/* スマホでは小さくしすぎず、必要なら折り返して見せる */
@media (max-width: 782px) {
  .nkts-breadcrumb-strip {
    min-height: 64px !important;
    padding: 14px 0 12px !important;
  }

  .nkts-breadcrumb-strip .container {
    align-items: flex-start !important;
  }

  .nkts-v520-breadcrumb,
  .nkts-modern-breadcrumb,
  .breadcrumb.nkts-modern-breadcrumb {
    width: 100% !important;
    padding: 10px 12px !important;
    border-radius: 14px !important;
    font-size: 13px !important;
    line-height: 1.45 !important;
    gap: 7px !important;
  }

  .nkts-v520-breadcrumb-current,
  .nkts-modern-breadcrumb .breadcrumb-current {
    max-width: 100% !important;
    white-space: normal !important;
    overflow: visible !important;
    text-overflow: clip !important;
  }

  .nkts-v520-breadcrumb-link,
  .nkts-modern-breadcrumb .breadcrumb-link,
  .nkts-v520-breadcrumb-current,
  .nkts-modern-breadcrumb .breadcrumb-current {
    padding: 4px 8px !important;
  }
}


/* ==========================================================
   NKTS V5.23 Fullwide / Landing stable rebuild
   デフォルトテンプレートの安定ヘッダーを使い、本文だけ広げる
========================================================== */
.nkts-v523-stable-hero.page-hero.compact {
  padding: 72px 0 34px;
  min-height: auto;
  background: linear-gradient(135deg, #f7f8fb, #ffffff);
  border-bottom: 1px solid rgba(16,17,22,.08);
}

.nkts-v523-stable-hero .container {
  display: block;
}

.nkts-v523-stable-hero .breadcrumb,
.nkts-v523-stable-hero .nkts-modern-breadcrumb {
  margin-bottom: 18px;
}

.nkts-v523-stable-hero h1 {
  margin: 0;
}

.nkts-v523-fullwide-template,
.nkts-v523-landing-template {
  width: 100%;
  background: #fff;
}

.nkts-v523-fullwide-content,
.nkts-v523-landing-content {
  width: 100%;
  max-width: none;
  margin: 0;
  padding: 0;
  display: block;
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
  overflow: visible;
}

.nkts-v523-fullwide-content > *,
.nkts-v523-landing-content > * {
  max-width: none;
}

.nkts-v523-fullwide-content .alignfull,
.nkts-v523-landing-content .alignfull,
.nkts-v523-fullwide-content .alignwide,
.nkts-v523-landing-content .alignwide {
  width: 100%;
  max-width: none;
}

/* 旧V5.19-5.22のパンくずストリップは、この2テンプレートでは使わない */
body.page-template-template-fullwide-php .nkts-breadcrumb-strip,
body.page-template-template-landing-php .nkts-breadcrumb-strip {
  display: none !important;
}

/* フルワイド/ランディング上のAI生成HTMLは表示を保証 */
body.page-template-template-fullwide-php .nkts-ai-fullwide-creative,
body.page-template-template-fullwide-php .nkts-ai-custom-html-safe,
body.page-template-template-fullwide-php .nkts-ai-editor-visible,
body.page-template-template-landing-php .nkts-ai-fullwide-creative,
body.page-template-template-landing-php .nkts-ai-custom-html-safe,
body.page-template-template-landing-php .nkts-ai-editor-visible {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
  transform: none !important;
  overflow: visible !important;
}

@media (max-width: 782px) {
  .nkts-v523-stable-hero.page-hero.compact {
    padding: 48px 0 26px;
  }

  .nkts-v523-stable-hero .breadcrumb,
  .nkts-v523-stable-hero .nkts-modern-breadcrumb {
    margin-bottom: 14px;
  }
}


/* ==========================================================
   NKTS V5.25 AI Responsive Common CSS
   生成HTML内に<style>を入れず、テーマ側でレスポンシブ制御する
========================================================== */
.nkts-ai-responsive {
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  overflow: visible;
}

.nkts-ai-responsive *,
.nkts-ai-responsive *::before,
.nkts-ai-responsive *::after {
  box-sizing: border-box;
  max-width: 100%;
}

.nkts-ai-responsive img {
  max-width: 100%;
  height: auto;
  display: block;
}

.nkts-ai-responsive table {
  width: 100%;
  border-collapse: collapse;
}

.nkts-ai-grid {
  display: grid;
  gap: clamp(18px, 3vw, 36px);
}

.nkts-ai-card {
  min-width: 0;
}

.nkts-ai-cta,
.nkts-ai-responsive .btn,
.nkts-ai-responsive a[class*="btn"] {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  max-width: 100%;
}

.nkts-ai-table-wrap {
  width: 100%;
  overflow-x: auto;
}

@media (max-width: 768px) {
  .nkts-ai-responsive {
    padding-left: 18px !important;
    padding-right: 18px !important;
  }

  .nkts-ai-responsive [style*="grid-template-columns"],
  .nkts-ai-grid {
    grid-template-columns: 1fr !important;
  }

  .nkts-ai-responsive [style*="display:grid"] {
    grid-template-columns: 1fr !important;
  }

  .nkts-ai-responsive [style*="display:flex"] {
    flex-wrap: wrap !important;
  }

  .nkts-ai-responsive h2 {
    font-size: clamp(26px, 8vw, 42px) !important;
    line-height: 1.18 !important;
  }

  .nkts-ai-responsive h3 {
    font-size: clamp(20px, 6vw, 28px) !important;
  }

  .nkts-ai-responsive p,
  .nkts-ai-responsive li {
    font-size: 15px !important;
    line-height: 1.8 !important;
  }

  .nkts-ai-responsive .btn,
  .nkts-ai-responsive a[class*="btn"],
  .nkts-ai-cta {
    width: 100%;
    text-align: center;
  }

  .nkts-ai-responsive table {
    display: block;
    overflow-x: auto;
    white-space: nowrap;
  }
}

@media (max-width: 480px) {
  .nkts-ai-responsive {
    padding-left: 14px !important;
    padding-right: 14px !important;
  }

  .nkts-ai-responsive [style*="padding:"] {
    padding: 24px 16px !important;
  }

  .nkts-ai-responsive [style*="gap:"] {
    gap: 16px !important;
  }
}


/* ==========================================================
   NKTS V5.32 Front assigned page content
   TOP動画/スライドショー/ヒーローを残したまま、指定固定ページ本文を表示
========================================================== */
.nkts-front-assigned-page-content {
  background: #fff;
  padding-top: clamp(48px, 7vw, 96px);
  padding-bottom: clamp(56px, 8vw, 110px);
  border-top: 1px solid rgba(15,31,61,.08);
}

.nkts-front-assigned-page-wrap {
  max-width: 1180px;
  margin-left: auto;
  margin-right: auto;
}

.nkts-front-assigned-entry {
  display: block;
  width: 100%;
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
  overflow: visible;
}

.nkts-front-assigned-entry > * {
  max-width: 100%;
}

.nkts-front-assigned-entry .nkts-ai-fullwide-creative,
.nkts-front-assigned-entry .nkts-ai-custom-html-safe,
.nkts-front-assigned-entry .nkts-ai-editor-visible,
.nkts-front-assigned-entry .nkts-ai-responsive {
  display: block !important;
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
  overflow: visible !important;
}

.nkts-front-assigned-featured {
  margin: 0 0 32px;
  border-radius: 22px;
  overflow: hidden;
}

.nkts-front-assigned-featured img {
  display: block;
  width: 100%;
  height: auto;
}

@media (max-width: 782px) {
  .nkts-front-assigned-page-content {
    padding-top: 40px;
    padding-bottom: 64px;
  }

  .nkts-front-assigned-page-wrap {
    padding-left: 18px;
    padding-right: 18px;
  }
}


/* ==========================================================
   NKTS V5.34 Front assigned page FULLWIDE content
   フロントページに指定した固定ページ本文を左右目いっぱい表示
========================================================== */
.nkts-front-assigned-page-content.nkts-front-assigned-fullwide {
  width: 100%;
  max-width: none;
  margin: 0;
  padding: 0;
  background: #fff;
  border-top: 1px solid rgba(15,31,61,.08);
  overflow: visible;
}

.nkts-front-assigned-fullwide .nkts-front-assigned-page-wrap {
  width: 100%;
  max-width: none;
  margin: 0;
  padding: 0;
}

.nkts-front-assigned-entry-fullwide {
  display: block;
  width: 100%;
  max-width: none;
  margin: 0;
  padding: 0;
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
  overflow: visible;
}

.nkts-front-assigned-entry-fullwide > * {
  max-width: none;
}

/* WordPress標準のwide/full配置もフロントページでは最大幅制限を外す */
.nkts-front-assigned-entry-fullwide .alignfull,
.nkts-front-assigned-entry-fullwide .alignwide,
.nkts-front-assigned-entry-fullwide .wp-block-group.alignfull,
.nkts-front-assigned-entry-fullwide .wp-block-cover.alignfull,
.nkts-front-assigned-entry-fullwide .wp-block-columns.alignfull {
  width: 100%;
  max-width: none;
  margin-left: 0;
  margin-right: 0;
}

/* 通常ブロックを読みやすくしたい場合の内側コンテナ用。AI生成HTMLや手動HTMLで任意使用 */
.nkts-front-assigned-entry-fullwide .nkts-inner,
.nkts-front-assigned-entry-fullwide .nkts-section-inner,
.nkts-front-assigned-entry-fullwide .nkts-content-inner {
  max-width: 1180px;
  margin-left: auto;
  margin-right: auto;
  padding-left: clamp(18px, 4vw, 42px);
  padding-right: clamp(18px, 4vw, 42px);
}

/* AI生成HTMLは左右いっぱいに表示しやすくする */
.nkts-front-assigned-entry-fullwide .nkts-ai-fullwide-creative,
.nkts-front-assigned-entry-fullwide .nkts-ai-custom-html-safe,
.nkts-front-assigned-entry-fullwide .nkts-ai-editor-visible,
.nkts-front-assigned-entry-fullwide .nkts-ai-responsive {
  display: block !important;
  width: 100% !important;
  max-width: none !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
  overflow: visible !important;
}

/* アイキャッチも横幅いっぱい */
.nkts-front-assigned-fullwide .nkts-front-assigned-featured {
  width: 100%;
  max-width: none;
  margin: 0;
  border-radius: 0;
  overflow: hidden;
}

.nkts-front-assigned-fullwide .nkts-front-assigned-featured img {
  display: block;
  width: 100%;
  height: auto;
}

@media (max-width: 782px) {
  .nkts-front-assigned-entry-fullwide {
    padding: 0;
  }

  .nkts-front-assigned-entry-fullwide .nkts-inner,
  .nkts-front-assigned-entry-fullwide .nkts-section-inner,
  .nkts-front-assigned-entry-fullwide .nkts-content-inner {
    padding-left: 18px;
    padding-right: 18px;
  }
}


/* ==========================================================
   NKTS V5.36 Parts design / video clarity / mobile video stability
========================================================== */
.one-screen-stage .media-shade {
  opacity: var(--nkts-video-shade-opacity, 1);
  transition: opacity .25s ease;
}

.one-screen-stage .hero-video {
  backface-visibility: hidden;
  transform: translateZ(0);
  will-change: transform;
}

.site-header,
.one-screen-stage,
.site-footer {
  transition: background-color .25s ease, color .25s ease;
}

/* Editable parts should inherit customizer colors more predictably */
.site-header .brand-text strong,
.site-header .brand-text small,
.primary-menu a,
.one-screen-stage .hero-copy h1,
.one-screen-stage .hero-copy p,
.site-footer,
.site-footer a {
  transition: color .2s ease, font-size .2s ease;
}


/* ==========================================================
   NKTS V5.37 TOP media visibility emergency fix
   V5.36のパーツ別設定後に、動画/画像/スライドが白く見える問題を修正
========================================================== */
.one-screen-stage.nkts-front-media-stage {
  isolation: isolate;
}

.one-screen-stage .media-backdrop,
.one-screen-stage .nkts-media-backdrop-active {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
  position: absolute !important;
  inset: 0 !important;
  z-index: 0 !important;
  overflow: hidden !important;
  background: #f7f8fa;
}

.one-screen-stage .hero-static-image,
.one-screen-stage .hero-slideshow,
.one-screen-stage .hero-video,
.one-screen-stage .nkts-hero-media-visible {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  min-height: 100% !important;
  z-index: 0 !important;
}

.one-screen-stage .hero-static-image {
  background-size: cover !important;
  background-position: center center !important;
  background-repeat: no-repeat !important;
}

.one-screen-stage .hero-video {
  object-fit: cover !important;
  object-position: center center !important;
  background: #f7f8fa !important;
}

/* slideshow itself needs explicit stacking. Individual spans are animated. */
.one-screen-stage .hero-slideshow span {
  display: block !important;
  visibility: visible !important;
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  background-size: cover !important;
  background-position: center center !important;
  background-repeat: no-repeat !important;
}

/* If animation is disabled or browser preview pauses animations, show first slide. */
.one-screen-stage .hero-slideshow span:first-child {
  opacity: 1;
}

/* Shade should never completely hide media. */
.one-screen-stage .media-shade {
  display: block !important;
  visibility: visible !important;
  pointer-events: none !important;
  z-index: 1 !important;
  opacity: var(--nkts-video-shade-opacity, .35) !important;
}

/* Content/decorative layers are above media. */
.one-screen-stage .stage-gridline { z-index: 2; }
.one-screen-stage .stage-particles,
.one-screen-stage .stage-motion,
.one-screen-stage .theme-visuals { z-index: 3; }
.one-screen-stage .stage-inner { position: relative; z-index: 5; }

/* Animation strength: media-only mode should hide decorations, NOT media. */
body.nk-motion-media_only .stage-motion,
body.nk-motion-media_only .stage-gridline,
body.nk-motion-media_only .stage-particles,
body.nk-motion-media_only .theme-visuals {
  display: none !important;
}

body.nk-motion-media_only .media-backdrop,
body.nk-motion-media_only .hero-static-image,
body.nk-motion-media_only .hero-slideshow,
body.nk-motion-media_only .hero-video {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
}

/* Customizer preview sometimes applies inline preview states: keep media visible there too. */
.customize-partial-edit-shortcut + .one-screen-stage .media-backdrop,
.wp-customizer .one-screen-stage .media-backdrop {
  display: block !important;
  opacity: 1 !important;
  visibility: visible !important;
}

@media (max-width: 782px) {
  .one-screen-stage .hero-video {
    object-fit: cover !important;
  }
}


/* ==========================================================
   NKTS V5.38 Media shade slider support
   TOPメディアシェード濃度をカスタマイザーから調整
========================================================== */
.one-screen-stage .media-shade {
  transition: opacity .25s ease, background .25s ease;
}

/* 0%設定時もクリック阻害しない */
.one-screen-stage .media-shade {
  pointer-events: none !important;
}


/* ==========================================================
   NKTS V5.39 Authoritative TOP media/text recovery
========================================================== */
.one-screen-stage.nkts-front-media-stage {
  isolation: isolate !important;
}

.one-screen-stage .media-backdrop,
.one-screen-stage .nkts-media-backdrop-active {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
  z-index: 0 !important;
}

.one-screen-stage .hero-static-image,
.one-screen-stage .hero-slideshow,
.one-screen-stage .hero-video,
.one-screen-stage .nkts-hero-media-visible {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
}

.one-screen-stage .media-shade {
  pointer-events: none !important;
}

body.nk-motion-off .media-backdrop,
body.nk-motion-off .hero-static-image,
body.nk-motion-off .hero-slideshow,
body.nk-motion-off .hero-video,
body.nk-motion-off .nkts-hero-media-visible {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
}


/* ==========================================================
   NKTS V5.40 TOP media markup recovery
   V5.36以降のスマホ動画自動再開JSで崩れたメディア出力を復旧
========================================================== */
.one-screen-stage .media-backdrop,
.one-screen-stage .nkts-media-backdrop-active {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
  position: absolute !important;
  inset: 0 !important;
  z-index: 0 !important;
  overflow: hidden !important;
}

.one-screen-stage .hero-video,
.one-screen-stage .hero-static-image,
.one-screen-stage .hero-slideshow,
.one-screen-stage .nkts-hero-media-visible {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
}

.one-screen-stage .hero-video {
  object-fit: cover !important;
  object-position: center center !important;
}

.one-screen-stage .hero-static-image {
  background-size: cover !important;
  background-position: center center !important;
  background-repeat: no-repeat !important;
}

.one-screen-stage .hero-slideshow span {
  display: block !important;
  visibility: visible !important;
  position: absolute !important;
  inset: 0 !important;
  background-size: cover !important;
  background-position: center center !important;
  background-repeat: no-repeat !important;
}

.one-screen-stage .hero-slideshow span:first-child {
  opacity: 1;
}

.one-screen-stage .media-shade {
  z-index: 1 !important;
  pointer-events: none !important;
}

.one-screen-stage .stage-inner {
  position: relative !important;
  z-index: 5 !important;
}


/* ==========================================================
   NKTS V5.41 Media shade 0-100 direct control
   TOPメディアシェード濃度を0〜100でそのまま反映
========================================================== */
.one-screen-stage .media-shade {
  opacity: var(--nkts-v539-effective-shade, var(--nkts-video-shade-opacity, .35)) !important;
  pointer-events: none !important;
}

body .one-screen-stage .media-shade {
  opacity: var(--nkts-v539-effective-shade, var(--nkts-video-shade-opacity, .35)) !important;
}

/* 0%指定時は完全透明にする。背景メディアはそのまま表示 */
body .one-screen-stage .media-shade[style*="opacity:0"],
body .one-screen-stage .media-shade.is-zero {
  opacity: 0 !important;
}


/* ==========================================================
   NKTS V5.42 Background animation toggle / video beauty mode
========================================================== */

/* 背景アニメーションOFF：装飾だけ消す。動画・画像・スライドは残す */
body.nk-bg-animation-off .one-screen-stage .stage-motion,
body.nk-bg-animation-off .one-screen-stage .stage-gridline,
body.nk-bg-animation-off .one-screen-stage .stage-particles,
body.nk-bg-animation-off .one-screen-stage .theme-visuals {
  display: none !important;
  visibility: hidden !important;
  opacity: 0 !important;
}

body.nk-bg-animation-off .one-screen-stage .media-backdrop,
body.nk-bg-animation-off .one-screen-stage .hero-video,
body.nk-bg-animation-off .one-screen-stage .hero-static-image,
body.nk-bg-animation-off .one-screen-stage .hero-slideshow,
body.nk-bg-animation-off .one-screen-stage .nkts-hero-media-visible {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
}

/* 動画きれい表示：白かぶりと装飾を弱める */
body.nk-video-beauty-on .one-screen-stage .media-shade {
  opacity: 0 !important;
  background: transparent !important;
}

body.nk-video-beauty-on .one-screen-stage .stage-motion,
body.nk-video-beauty-on .one-screen-stage .stage-gridline,
body.nk-video-beauty-on .one-screen-stage .stage-particles,
body.nk-video-beauty-on .one-screen-stage .theme-visuals {
  opacity: .08 !important;
  filter: none !important;
}

body.nk-video-beauty-on .one-screen-stage .hero-video {
  filter: saturate(1.05) contrast(1.03) brightness(1.02) !important;
  opacity: 1 !important;
}

body.nk-video-beauty-on .one-screen-stage .hero-static-image,
body.nk-video-beauty-on .one-screen-stage .hero-slideshow span {
  filter: saturate(1.04) contrast(1.02) brightness(1.01) !important;
}


/* ==========================================================
   NKTS V5.43 Editable footer service links
========================================================== */
.footer-service-list-v543 a,
.footer-service-list-v543 span {
  color: inherit;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: .35em;
}

.footer-service-list-v543 a:hover {
  color: var(--accent, #d20b19);
  text-decoration: underline;
  text-underline-offset: 3px;
}


/* ==========================================================
   NKTS V5.44 PC/Smartphone fullscreen hamburger menu
========================================================== */

/* PCでも常時MENUボタンを表示 */
.site-header .nav-toggle.nkts-menu-button,
.nav-toggle.nkts-menu-button {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  gap: 9px;
  width: auto;
  min-width: 94px;
  height: 46px;
  padding: 0 16px;
  border: 1px solid rgba(15,31,61,.14);
  border-radius: 999px;
  background: rgba(255,255,255,.88);
  color: #111827;
  cursor: pointer;
  box-shadow: 0 10px 28px rgba(15,31,61,.08);
  transition: transform .2s ease, box-shadow .2s ease, background .2s ease;
}

.nav-toggle.nkts-menu-button:hover {
  transform: translateY(-1px);
  box-shadow: 0 14px 34px rgba(15,31,61,.12);
}

.nav-toggle.nkts-menu-button span {
  display: block;
  width: 18px;
  height: 2px;
  margin: 0;
  background: currentColor;
  border-radius: 999px;
}

.nav-toggle.nkts-menu-button {
  position: relative;
}

.nav-toggle.nkts-menu-button span:nth-child(1),
.nav-toggle.nkts-menu-button span:nth-child(2),
.nav-toggle.nkts-menu-button span:nth-child(3) {
  position: absolute;
  left: 16px;
}

.nav-toggle.nkts-menu-button span:nth-child(1) { transform: translateY(-6px); }
.nav-toggle.nkts-menu-button span:nth-child(2) { transform: translateY(0); }
.nav-toggle.nkts-menu-button span:nth-child(3) { transform: translateY(6px); }

.nav-toggle.nkts-menu-button em {
  margin-left: 28px;
  font-style: normal;
  font-weight: 900;
  font-size: 12px;
  letter-spacing: .12em;
  line-height: 1;
}

/* 既存のPC横並びナビを全画面オーバーレイ化 */
.site-nav.nkts-fullscreen-nav {
  position: fixed !important;
  inset: 0 !important;
  z-index: 9999 !important;
  display: flex !important;
  align-items: center;
  justify-content: center;
  padding: clamp(28px, 6vw, 72px);
  background:
    radial-gradient(circle at 82% 18%, rgba(var(--accent-rgb), .24), transparent 34%),
    linear-gradient(135deg, rgba(8,14,26,.98), rgba(20,25,36,.96));
  color: #fff !important;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: scale(1.015);
  transition: opacity .24s ease, visibility .24s ease, transform .24s ease;
  overflow-y: auto;
}

.site-nav.nkts-fullscreen-nav.is-open {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: scale(1);
}

.nkts-menu-panel {
  width: min(960px, 100%);
  display: grid;
  gap: 26px;
  text-align: center;
}

.nkts-menu-label {
  margin: 0;
  font-family: var(--font-en, system-ui, sans-serif);
  color: rgba(255,255,255,.58);
  font-size: 13px;
  letter-spacing: .28em;
  font-weight: 900;
}

.site-nav.nkts-fullscreen-nav .primary-menu {
  display: grid !important;
  grid-template-columns: 1fr;
  gap: clamp(12px, 2vw, 22px);
  width: 100%;
  margin: 0;
  padding: 0;
  list-style: none;
}

.site-nav.nkts-fullscreen-nav .primary-menu li {
  margin: 0;
}

.site-nav.nkts-fullscreen-nav .primary-menu a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #fff !important;
  font-size: clamp(28px, 5vw, 58px) !important;
  line-height: 1.08;
  font-weight: 900;
  letter-spacing: .04em;
  text-decoration: none;
  padding: 8px 14px;
}

.site-nav.nkts-fullscreen-nav .primary-menu a::after {
  display: none !important;
}

.site-nav.nkts-fullscreen-nav .primary-menu a:hover {
  color: #fff !important;
  text-shadow: 0 0 28px rgba(255,255,255,.28);
}

.site-nav.nkts-fullscreen-nav .header-contact {
  justify-self: center;
  display: inline-flex !important;
  margin-top: 12px;
  background: #fff !important;
  color: #111827 !important;
  border-radius: 999px;
  padding: 13px 22px;
  font-weight: 900;
}

.nkts-menu-close {
  position: fixed;
  top: 22px;
  right: 24px;
  width: 52px;
  height: 52px;
  border: 1px solid rgba(255,255,255,.22);
  border-radius: 50%;
  background: rgba(255,255,255,.10);
  color: #fff;
  font-size: 34px;
  line-height: 1;
  cursor: pointer;
  display: grid;
  place-items: center;
}

body.nkts-menu-open {
  overflow: hidden;
}

/* ヘッダー側はブランド + MENUの2要素に整理 */
.header-inner {
  gap: 16px;
}

@media (max-width: 782px) {
  .site-header .nav-toggle.nkts-menu-button {
    min-width: 86px;
    height: 42px;
    padding: 0 13px;
  }

  .nav-toggle.nkts-menu-button em {
    font-size: 11px;
    margin-left: 25px;
  }

  .site-nav.nkts-fullscreen-nav .primary-menu a {
    font-size: clamp(26px, 10vw, 46px) !important;
  }

  .nkts-menu-close {
    top: 16px;
    right: 16px;
  }
}


/* ==========================================================
   NKTS V5.45 Dedicated hamburger menu location
   Primaryとは別に「ハンバーガーメニュー」を全画面表示
========================================================== */

.nkts-hamburger-button {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  gap: 10px;
  height: 46px;
  min-width: 104px;
  padding: 0 17px;
  border: 1px solid rgba(15,31,61,.14);
  border-radius: 999px;
  background: rgba(255,255,255,.9);
  color: #111827;
  cursor: pointer;
  box-shadow: 0 10px 28px rgba(15,31,61,.08);
  transition: transform .2s ease, box-shadow .2s ease, background .2s ease;
  font: inherit;
}

.nkts-hamburger-button:hover {
  transform: translateY(-1px);
  box-shadow: 0 14px 34px rgba(15,31,61,.12);
}

.nkts-hamburger-lines {
  position: relative;
  display: inline-grid;
  gap: 4px;
  width: 20px;
}

.nkts-hamburger-lines i {
  display: block;
  width: 20px;
  height: 2px;
  border-radius: 999px;
  background: currentColor;
}

.nkts-hamburger-text {
  font-weight: 900;
  font-size: 12px;
  letter-spacing: .12em;
  line-height: 1;
}

.nkts-hamburger-overlay {
  position: fixed;
  inset: 0;
  z-index: 100000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: clamp(28px, 6vw, 72px);
  background:
    radial-gradient(circle at 82% 18%, rgba(var(--accent-rgb), .25), transparent 36%),
    linear-gradient(135deg, rgba(8,14,26,.98), rgba(20,25,36,.96));
  color: #fff;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: scale(1.015);
  transition: opacity .24s ease, visibility .24s ease, transform .24s ease;
  overflow-y: auto;
}

.nkts-hamburger-overlay.is-open {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: scale(1);
}

.nkts-hamburger-panel {
  width: min(980px, 100%);
  text-align: center;
}

.nkts-hamburger-label {
  margin: 0 0 24px;
  color: rgba(255,255,255,.58);
  font-family: var(--font-en, system-ui, sans-serif);
  font-size: 13px;
  letter-spacing: .28em;
  font-weight: 900;
}

.nkts-hamburger-nav {
  display: grid;
  justify-items: center;
  gap: 26px;
}

.nkts-hamburger-menu,
.nkts-hamburger-nav .primary-menu {
  display: grid !important;
  grid-template-columns: 1fr;
  gap: clamp(12px, 2vw, 22px);
  width: 100%;
  margin: 0;
  padding: 0;
  list-style: none;
}

.nkts-hamburger-menu li,
.nkts-hamburger-nav .primary-menu li {
  margin: 0;
}

.nkts-hamburger-menu a,
.nkts-hamburger-nav .primary-menu a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #fff !important;
  font-size: clamp(28px, 5vw, 58px) !important;
  line-height: 1.08;
  font-weight: 900;
  letter-spacing: .04em;
  text-decoration: none;
  padding: 8px 14px;
}

.nkts-hamburger-menu a:hover,
.nkts-hamburger-nav .primary-menu a:hover {
  color: #fff !important;
  text-shadow: 0 0 28px rgba(255,255,255,.28);
}

.nkts-hamburger-contact {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  margin-top: 12px;
  padding: 13px 24px;
  border-radius: 999px;
  background: #fff;
  color: #111827 !important;
  font-weight: 900;
  text-decoration: none;
}

.nkts-hamburger-close {
  position: fixed;
  top: 22px;
  right: 24px;
  width: 52px;
  height: 52px;
  border: 1px solid rgba(255,255,255,.22);
  border-radius: 50%;
  background: rgba(255,255,255,.10);
  color: #fff;
  font-size: 34px;
  line-height: 1;
  cursor: pointer;
  display: grid;
  place-items: center;
}

body.nkts-hamburger-open {
  overflow: hidden;
}

/* V5.44の旧site-nav全画面化の影響を受けないよう、header内にsite-navが残っていない場合でも安全化 */
.site-header .site-nav {
  display: none;
}

@media (max-width: 782px) {
  .nkts-hamburger-button {
    min-width: 92px;
    height: 42px;
    padding: 0 14px;
  }

  .nkts-hamburger-text {
    font-size: 11px;
  }

  .nkts-hamburger-menu a,
  .nkts-hamburger-nav .primary-menu a {
    font-size: clamp(26px, 10vw, 46px) !important;
  }

  .nkts-hamburger-close {
    top: 16px;
    right: 16px;
  }
}


/* ==========================================================
   NKTS V5.46 Hero accent dot toggle / header left alignment
========================================================== */

/* ヒーロー大見出し末尾のアクセント丸点 ON/OFF */
body.nk-hero-dot-off .hero h1::after,
body.nk-hero-dot-off .one-screen-stage .hero h1::after,
body.nk-hero-dot-off .one-screen-stage .hero-copy h1::after {
  content: none !important;
  display: none !important;
  width: 0 !important;
  height: 0 !important;
  margin: 0 !important;
  background: transparent !important;
}

body.nk-hero-dot-on .hero h1::after,
body.nk-hero-dot-on .one-screen-stage .hero h1::after,
body.nk-hero-dot-on .one-screen-stage .hero-copy h1::after {
  content: "";
  display: inline-block;
  width: .24em;
  height: .24em;
  background: var(--accent);
  border-radius: 50%;
  margin-left: .09em;
  vertical-align: baseline;
}

/* ヘッダー：ロゴ・会社名・英語表記を左寄せで安定 */
.site-header .header-inner {
  justify-content: space-between !important;
  align-items: center !important;
}

.site-header .brand {
  margin-right: auto !important;
  justify-content: flex-start !important;
  text-align: left !important;
  align-items: center !important;
}

.site-header .brand-logo {
  flex: 0 0 auto !important;
  text-align: left !important;
}

.site-header .brand-text {
  display: block !important;
  text-align: left !important;
  align-items: flex-start !important;
  justify-content: flex-start !important;
  line-height: 1.25 !important;
}

.site-header .brand-text strong,
.site-header .brand-text small {
  text-align: left !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
}

.site-header .nkts-hamburger-button {
  margin-left: auto !important;
  flex: 0 0 auto !important;
}


/* ==========================================================
   NKTS V5.47 Safe free placement buttons
========================================================== */
.site-header,
.one-screen-stage {
  position: relative;
}

.nkts-free-buttons {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 20;
}

.nkts-free-buttons-header {
  z-index: 60;
}

.nkts-free-buttons-hero {
  z-index: 8;
}

.nkts-free-button {
  position: absolute;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: var(--nkts-fb-width, 180px);
  height: var(--nkts-fb-height, 52px);
  min-width: 44px;
  min-height: 32px;
  padding: 0 18px;
  background: var(--nkts-fb-bg, var(--accent));
  color: var(--nkts-fb-color, #fff) !important;
  border: 1px solid var(--nkts-fb-border, transparent);
  font-size: var(--nkts-fb-font, 15px);
  font-weight: 900;
  letter-spacing: .04em;
  line-height: 1.2;
  text-align: center;
  text-decoration: none !important;
  box-shadow: 0 14px 36px rgba(15,31,61,.14);
  pointer-events: auto;
  white-space: nowrap;
  transform: translate(var(--nkts-fb-x, 0px), var(--nkts-fb-y, 0px));
  transition: transform .2s ease, box-shadow .2s ease, filter .2s ease;
}

.nkts-free-button:hover {
  filter: brightness(.98);
  box-shadow: 0 18px 44px rgba(15,31,61,.18);
}

.nkts-free-button-square {
  border-radius: 0;
}

.nkts-free-button-rounded {
  border-radius: 12px;
}

.nkts-free-button-pill {
  border-radius: 999px;
}

.nkts-free-button-circle {
  width: var(--nkts-fb-width, 72px);
  height: var(--nkts-fb-width, 72px);
  border-radius: 50%;
  padding: 0;
  white-space: normal;
  aspect-ratio: 1 / 1;
}

/* position presets */
.nkts-free-button-pos-top_left { left: 24px; top: 24px; }
.nkts-free-button-pos-top_center { left: 50%; top: 24px; transform: translate(calc(-50% + var(--nkts-fb-x, 0px)), var(--nkts-fb-y, 0px)); }
.nkts-free-button-pos-top_right { right: 24px; top: 24px; }
.nkts-free-button-pos-center_left { left: 24px; top: 50%; transform: translate(var(--nkts-fb-x, 0px), calc(-50% + var(--nkts-fb-y, 0px))); }
.nkts-free-button-pos-center { left: 50%; top: 50%; transform: translate(calc(-50% + var(--nkts-fb-x, 0px)), calc(-50% + var(--nkts-fb-y, 0px))); }
.nkts-free-button-pos-center_right { right: 24px; top: 50%; transform: translate(var(--nkts-fb-x, 0px), calc(-50% + var(--nkts-fb-y, 0px))); }
.nkts-free-button-pos-bottom_left { left: 24px; bottom: 24px; }
.nkts-free-button-pos-bottom_center { left: 50%; bottom: 24px; transform: translate(calc(-50% + var(--nkts-fb-x, 0px)), var(--nkts-fb-y, 0px)); }
.nkts-free-button-pos-bottom_right { right: 24px; bottom: 24px; }

.nkts-free-buttons-header .nkts-free-button {
  box-shadow: 0 8px 24px rgba(15,31,61,.12);
}

@media (max-width: 782px) {
  .nkts-free-button {
    width: min(var(--nkts-fb-width, 170px), calc(100vw - 36px));
    height: var(--nkts-fb-height, 48px);
    font-size: max(12px, calc(var(--nkts-fb-font, 15px) - 2px));
  }

  .nkts-free-button-hide-mobile {
    display: none !important;
  }

  .nkts-free-button-pos-top_left,
  .nkts-free-button-pos-center_left,
  .nkts-free-button-pos-bottom_left {
    left: 18px;
  }

  .nkts-free-button-pos-top_right,
  .nkts-free-button-pos-center_right,
  .nkts-free-button-pos-bottom_right {
    right: 18px;
  }

  .nkts-free-button-pos-top_left,
  .nkts-free-button-pos-top_center,
  .nkts-free-button-pos-top_right {
    top: 18px;
  }

  .nkts-free-button-pos-bottom_left,
  .nkts-free-button-pos-bottom_center,
  .nkts-free-button-pos-bottom_right {
    bottom: 18px;
  }
}


/* ==========================================================
   NKTS V5.48 Header brand position
   ロゴ・会社名・英語社名の左端/中央/右端配置
========================================================== */
.site-header .header-inner {
  position: relative !important;
}

.site-header .brand {
  z-index: 2 !important;
}

.site-header .nkts-hamburger-button {
  z-index: 3 !important;
}

/* 左端 */
body.nk-header-brand-left .site-header .header-inner {
  justify-content: space-between !important;
}

body.nk-header-brand-left .site-header .brand {
  position: relative !important;
  left: auto !important;
  right: auto !important;
  transform: none !important;
  margin-left: 0 !important;
  margin-right: auto !important;
  justify-content: flex-start !important;
  text-align: left !important;
}

/* 中央 */
body.nk-header-brand-center .site-header .header-inner {
  justify-content: flex-end !important;
}

body.nk-header-brand-center .site-header .brand {
  position: absolute !important;
  left: 50% !important;
  top: 50% !important;
  right: auto !important;
  transform: translate(-50%, -50%) !important;
  margin: 0 !important;
  justify-content: center !important;
  text-align: left !important;
}

/* 右端。MENUボタンと重ならないよう少し左に逃がす */
body.nk-header-brand-right .site-header .header-inner {
  justify-content: flex-start !important;
}

body.nk-header-brand-right .site-header .brand {
  position: relative !important;
  left: auto !important;
  right: auto !important;
  transform: none !important;
  margin-left: auto !important;
  margin-right: 120px !important;
  justify-content: flex-end !important;
  text-align: left !important;
}

body.nk-header-brand-right .site-header .nkts-hamburger-button {
  position: absolute !important;
  right: 0 !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  margin: 0 !important;
}

/* ブランド内の文字は読みやすさ優先で左揃え */
.site-header .brand-text,
.site-header .brand-text strong,
.site-header .brand-text small {
  text-align: left !important;
}

@media (max-width: 782px) {
  body.nk-header-brand-left .site-header .brand,
  body.nk-header-brand-center .site-header .brand,
  body.nk-header-brand-right .site-header .brand {
    position: relative !important;
    left: auto !important;
    top: auto !important;
    right: auto !important;
    transform: none !important;
    margin-left: 0 !important;
    margin-right: auto !important;
    max-width: calc(100% - 104px) !important;
  }

  body.nk-header-brand-left .site-header .header-inner,
  body.nk-header-brand-center .site-header .header-inner,
  body.nk-header-brand-right .site-header .header-inner {
    justify-content: space-between !important;
  }

  body.nk-header-brand-right .site-header .nkts-hamburger-button {
    position: relative !important;
    right: auto !important;
    top: auto !important;
    transform: none !important;
    margin-left: auto !important;
  }
}


/* ==========================================================
   NKTS V5.49 Hero accent dot visible setting fix
   設定表示位置をNKTS企業情報・トップ設定へ移動し、OFF時の非表示を強化
========================================================== */
body.nk-hero-dot-off .hero h1::after,
body.nk-hero-dot-off .one-screen-stage .hero h1::after,
body.nk-hero-dot-off .one-screen-stage .hero-copy h1::after,
body.nk-hero-dot-off .one-screen-stage h1::after,
body.nk-hero-dot-off .nkts-edit-hero-title::after {
  content: none !important;
  display: none !important;
  width: 0 !important;
  height: 0 !important;
  margin: 0 !important;
  background: transparent !important;
  border: 0 !important;
}

body.nk-hero-dot-off .hero-dot,
body.nk-hero-dot-off .accent-dot,
body.nk-hero-dot-off .nkts-hero-dot {
  display: none !important;
  visibility: hidden !important;
  opacity: 0 !important;
}


/* ==========================================================
   NKTS V5.50 Premium hamburger menu redesign
========================================================== */

/* Button quality upgrade */
.site-header .nkts-hamburger-button,
.nkts-hamburger-button {
  position: relative;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  gap: 14px;
  min-width: 144px;
  height: 60px;
  padding: 0 24px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.18);
  background: linear-gradient(180deg, rgba(255,255,255,.95), rgba(244,247,250,.96));
  color: #111827;
  box-shadow: 0 20px 40px rgba(0,0,0,.22), inset 0 1px 0 rgba(255,255,255,.82);
  overflow: hidden;
}

.site-header .nkts-hamburger-button::before {
  content: "";
  position: absolute;
  inset: 1px;
  border-radius: inherit;
  background: linear-gradient(135deg, rgba(255,255,255,.68), rgba(255,255,255,.12));
  pointer-events: none;
}

.site-header .nkts-hamburger-button:hover {
  transform: translateY(-1px);
  box-shadow: 0 26px 50px rgba(0,0,0,.26), inset 0 1px 0 rgba(255,255,255,.86);
}

.nkts-hamburger-lines {
  position: relative;
  width: 22px;
  gap: 5px;
}

.nkts-hamburger-lines i {
  width: 22px;
  height: 2px;
  background: #1f2937;
  border-radius: 999px;
  transition: transform .24s ease, opacity .24s ease;
}

.nkts-hamburger-text {
  position: relative;
  z-index: 1;
  font-family: var(--font-en, system-ui, sans-serif);
  font-size: 14px;
  line-height: 1;
  letter-spacing: .18em;
  font-weight: 900;
  color: #0f172a;
}

body.nkts-hamburger-open .nkts-hamburger-lines i:nth-child(1) {
  transform: translateY(7px) rotate(45deg);
}
body.nkts-hamburger-open .nkts-hamburger-lines i:nth-child(2) {
  opacity: 0;
}
body.nkts-hamburger-open .nkts-hamburger-lines i:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg);
}

/* Overlay premium visual */
.nkts-hamburger-overlay {
  background:
    radial-gradient(circle at 12% 14%, rgba(255,255,255,.11), transparent 28%),
    radial-gradient(circle at 88% 20%, rgba(var(--accent-rgb), .20), transparent 30%),
    linear-gradient(135deg, rgba(3,7,18,.98), rgba(8,13,27,.96) 46%, rgba(10,19,38,.94));
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
}

.nkts-hamburger-backdrop {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(120deg, transparent 0, rgba(255,255,255,.06) 18%, transparent 36%),
    radial-gradient(circle at 80% 80%, rgba(255,255,255,.05), transparent 28%);
  opacity: .95;
}

.nkts-hamburger-shell {
  position: relative;
  width: min(1320px, 100%);
}

.nkts-hamburger-panel {
  position: relative;
  display: grid;
  grid-template-columns: minmax(280px, 420px) minmax(440px, 1fr);
  gap: clamp(24px, 5vw, 72px);
  align-items: stretch;
  padding: clamp(32px, 4vw, 44px);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 32px;
  background: linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.04));
  box-shadow: 0 40px 120px rgba(0,0,0,.38);
  overflow: hidden;
}

.nkts-hamburger-panel::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(135deg, rgba(255,255,255,.08), transparent 36%),
    radial-gradient(circle at 0% 0%, rgba(var(--accent-rgb), .18), transparent 26%);
  pointer-events: none;
}

.nkts-hamburger-side,
.nkts-hamburger-nav {
  position: relative;
  z-index: 1;
}

.nkts-hamburger-side {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 20px;
  padding: clamp(18px, 2vw, 28px);
  border-right: 1px solid rgba(255,255,255,.10);
}

.nkts-hamburger-label,
.nkts-hamburger-nav-label {
  margin: 0;
  color: rgba(255,255,255,.58);
  font-family: var(--font-en, system-ui, sans-serif);
  font-size: 12px;
  letter-spacing: .28em;
  font-weight: 900;
}

.nkts-hamburger-title {
  margin: 0;
  color: #fff;
  font-family: var(--font-en, system-ui, sans-serif);
  font-size: clamp(28px, 2.8vw, 42px);
  line-height: 1.05;
  letter-spacing: .02em;
  font-weight: 900;
}

.nkts-hamburger-lead {
  margin: 0;
  color: rgba(255,255,255,.82);
  font-size: 15px;
  line-height: 2;
  letter-spacing: .03em;
}

.nkts-hamburger-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.nkts-hamburger-meta span {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 0 14px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.07);
  color: rgba(255,255,255,.86);
  font-size: 12px;
  letter-spacing: .08em;
  font-weight: 800;
}

.nkts-hamburger-nav {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 18px;
  padding: clamp(18px, 2vw, 28px) clamp(4px, 1vw, 10px);
}

.nkts-hamburger-menu {
  counter-reset: nktsmenu;
  gap: 8px !important;
}

.nkts-hamburger-menu > li {
  counter-increment: nktsmenu;
  position: relative;
}

.nkts-hamburger-menu > li > a {
  position: relative;
  display: grid !important;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 18px;
  width: 100%;
  padding: clamp(16px, 1.6vw, 20px) 18px;
  border-radius: 22px;
  color: #fff !important;
  font-size: clamp(22px, 2.5vw, 44px) !important;
  line-height: 1.08;
  text-align: left;
  transition: background .22s ease, transform .22s ease, box-shadow .22s ease;
}

.nkts-hamburger-menu > li > a::before {
  content: counter(nktsmenu, decimal-leading-zero);
  display: inline-block;
  min-width: 2.5em;
  color: rgba(255,255,255,.38);
  font-size: 12px;
  letter-spacing: .22em;
  font-weight: 900;
}

.nkts-hamburger-menu > li > a::after {
  content: "↗";
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  border-radius: 50%;
  background: rgba(255,255,255,.08);
  color: rgba(255,255,255,.9);
  font-size: 16px;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.1);
}

.nkts-hamburger-menu > li > a:hover {
  transform: translateX(6px);
  background: linear-gradient(90deg, rgba(255,255,255,.09), rgba(255,255,255,.03));
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.08);
  text-shadow: none !important;
}

.nkts-hamburger-menu .sub-menu {
  margin: 8px 0 6px 78px;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 8px;
}

.nkts-hamburger-menu .sub-menu a {
  color: rgba(255,255,255,.72) !important;
  font-size: 14px !important;
  line-height: 1.6;
  padding: 4px 0;
  text-decoration: none;
}

.nkts-hamburger-actions {
  display: flex;
  align-items: center;
  gap: 14px;
  padding-top: 8px;
}

.nkts-hamburger-contact {
  min-width: 220px;
  min-height: 56px;
  padding: 0 28px;
  background: linear-gradient(135deg, var(--accent), #ff4757);
  color: #fff !important;
  border: 1px solid rgba(255,255,255,.18);
  box-shadow: 0 18px 40px rgba(var(--accent-rgb), .26);
  font-size: 14px;
  letter-spacing: .14em;
  font-weight: 900;
}

.nkts-hamburger-contact:hover {
  transform: translateY(-1px);
  box-shadow: 0 22px 48px rgba(var(--accent-rgb), .32);
}

.nkts-hamburger-close {
  top: 22px;
  right: 24px;
  width: auto;
  min-width: 108px;
  height: 52px;
  padding: 0 16px;
  gap: 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.16);
  box-shadow: 0 16px 36px rgba(0,0,0,.28);
}

.nkts-hamburger-close span {
  font-size: 28px;
  line-height: 1;
}

.nkts-hamburger-close em {
  font-style: normal;
  font-family: var(--font-en, system-ui, sans-serif);
  font-size: 12px;
  letter-spacing: .16em;
  font-weight: 900;
}

.nkts-hamburger-close:hover {
  background: rgba(255,255,255,.14);
}

@media (max-width: 980px) {
  .nkts-hamburger-panel {
    grid-template-columns: 1fr;
    gap: 18px;
  }
  .nkts-hamburger-side {
    border-right: 0;
    border-bottom: 1px solid rgba(255,255,255,.10);
    padding-bottom: 24px;
  }
  .nkts-hamburger-nav {
    padding-top: 8px;
  }
}

@media (max-width: 782px) {
  .site-header .nkts-hamburger-button,
  .nkts-hamburger-button {
    min-width: 116px;
    height: 50px;
    padding: 0 18px;
    gap: 10px;
  }

  .nkts-hamburger-text {
    font-size: 12px;
    letter-spacing: .14em;
  }

  .nkts-hamburger-overlay {
    padding: 18px;
  }

  .nkts-hamburger-shell {
    width: 100%;
  }

  .nkts-hamburger-panel {
    padding: 20px;
    border-radius: 24px;
  }

  .nkts-hamburger-title {
    font-size: 24px;
  }

  .nkts-hamburger-lead {
    font-size: 13px;
    line-height: 1.85;
  }

  .nkts-hamburger-menu > li > a {
    padding: 14px 14px;
    gap: 12px;
    font-size: clamp(20px, 7vw, 28px) !important;
  }

  .nkts-hamburger-menu > li > a::before {
    min-width: 2.3em;
    font-size: 11px;
  }

  .nkts-hamburger-menu .sub-menu {
    margin-left: 56px;
  }

  .nkts-hamburger-contact {
    width: 100%;
    min-width: 0;
  }

  .nkts-hamburger-close {
    top: 14px;
    right: 14px;
    min-width: 92px;
    height: 46px;
  }
}


/* ==========================================================
   NKTS V5.51 Editable hamburger content
========================================================== */
.nkts-hamburger-side:has(.nkts-hamburger-title:only-child),
.nkts-hamburger-side {
  min-width: 0;
}

.nkts-hamburger-lead {
  white-space: pre-wrap;
}

.nkts-hamburger-actions:empty,
.nkts-hamburger-meta:empty {
  display: none !important;
}


/* ==========================================================
   NKTS V5.52 Customizer safe mode for free placement buttons
   カスタマイザー編集中のリンク遷移・操作不能化を防止
========================================================== */

/* 通常時：自由ボタンだけクリック可能。外側レイヤーは操作を奪わない */
.nkts-free-buttons {
  pointer-events: none !important;
}

.nkts-free-button {
  pointer-events: auto !important;
}

/* カスタマイザー編集中：リンクとしては押せる見た目だが、JSで遷移停止 */
body.nkts-customize-preview .nkts-free-button {
  cursor: default !important;
  position: absolute;
}

/* 編集中ラベル */
body.nkts-customize-preview .nkts-free-button::after {
  content: attr(data-customizer-note);
  position: absolute;
  top: -12px;
  right: -10px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 44px;
  height: 22px;
  padding: 0 8px;
  border-radius: 999px;
  background: rgba(30, 64, 175, .95);
  color: #fff;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .04em;
  box-shadow: 0 8px 20px rgba(30,64,175,.28);
  pointer-events: none;
  z-index: 3;
}

/* クリックされた時の軽い反応 */
body.nkts-customize-preview .nkts-free-button-preview-pulse {
  animation: nktsFreeButtonPreviewPulse .42s ease;
}

@keyframes nktsFreeButtonPreviewPulse {
  0% { transform: scale(1) translate(var(--nkts-fb-x, 0px), var(--nkts-fb-y, 0px)); }
  50% { filter: brightness(1.08); }
  100% { transform: scale(1) translate(var(--nkts-fb-x, 0px), var(--nkts-fb-y, 0px)); }
}

/* 中央系のtransformを使うボタンは、pulseで位置が崩れないよう個別補正 */
body.nkts-customize-preview .nkts-free-button-pos-top_center.nkts-free-button-preview-pulse,
body.nkts-customize-preview .nkts-free-button-pos-bottom_center.nkts-free-button-preview-pulse {
  animation: none;
  filter: brightness(1.08);
}

body.nkts-customize-preview .nkts-free-button-pos-center.nkts-free-button-preview-pulse,
body.nkts-customize-preview .nkts-free-button-pos-center_left.nkts-free-button-preview-pulse,
body.nkts-customize-preview .nkts-free-button-pos-center_right.nkts-free-button-preview-pulse {
  animation: none;
  filter: brightness(1.08);
}

/* ヘッダー設置ボタンがカスタマイザー操作全体を覆わないようにする */
body.nkts-customize-preview .nkts-free-buttons-header {
  z-index: 20 !important;
}

body.nkts-customize-preview .customize-partial-edit-shortcut {
  z-index: 99999 !important;
}


/* ==========================================================
   NKTS V5.53 Background animation NONE
   V5.52ベース：背景アニメーション「なし」だけを追加
========================================================== */

/* なし選択時：線・粒子・図形などの背景装飾を完全非表示 */
body.nk-bg-none .one-screen-stage .stage-motion,
body.nk-bg-none .one-screen-stage .stage-gridline,
body.nk-bg-none .one-screen-stage .stage-particles,
body.nk-bg-none .one-screen-stage .theme-visuals,
body.nk-bg-none .one-screen-stage .nkts-motion-layer,
body.nk-bg-none .one-screen-stage .nkts-bg-decoration,
body.nk-bg-theme-none .one-screen-stage .stage-motion,
body.nk-bg-theme-none .one-screen-stage .stage-gridline,
body.nk-bg-theme-none .one-screen-stage .stage-particles,
body.nk-bg-theme-none .one-screen-stage .theme-visuals,
body.nk-bg-theme-none .one-screen-stage .nkts-motion-layer,
body.nk-bg-theme-none .one-screen-stage .nkts-bg-decoration {
  display: none !important;
  visibility: hidden !important;
  opacity: 0 !important;
  animation: none !important;
}

/* 画像・動画・スライドショーなどの背景メディアは表示維持 */
body.nk-bg-none .one-screen-stage .media-backdrop,
body.nk-bg-none .one-screen-stage .hero-video,
body.nk-bg-none .one-screen-stage .hero-static-image,
body.nk-bg-none .one-screen-stage .hero-slideshow,
body.nk-bg-none .one-screen-stage .nkts-hero-media-visible,
body.nk-bg-theme-none .one-screen-stage .media-backdrop,
body.nk-bg-theme-none .one-screen-stage .hero-video,
body.nk-bg-theme-none .one-screen-stage .hero-static-image,
body.nk-bg-theme-none .one-screen-stage .hero-slideshow,
body.nk-bg-theme-none .one-screen-stage .nkts-hero-media-visible {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
}


/* ==========================================================
   NKTS V5.54 Responsive free placement buttons
   追加お問い合わせボタン等のスマホ崩れ・はみ出し・重なりを改善
========================================================== */
.nkts-free-button {
  max-width: calc(100vw - 36px);
  box-sizing: border-box;
  overflow: hidden;
  text-overflow: ellipsis;
}

.nkts-free-buttons-header {
  inset: 0 !important;
  pointer-events: none !important;
}

.nkts-free-buttons-header .nkts-free-button {
  pointer-events: auto !important;
}

@media (max-width: 782px) {
  .nkts-free-button {
    width: min(var(--nkts-fb-mobile-width, var(--nkts-fb-width, 170px)), calc(100vw - 36px)) !important;
    height: var(--nkts-fb-mobile-height, var(--nkts-fb-height, 48px)) !important;
    font-size: var(--nkts-fb-mobile-font, 13px) !important;
    padding-left: 12px;
    padding-right: 12px;
    line-height: 1.2;
    white-space: nowrap;
  }

  .nkts-free-button-circle {
    width: var(--nkts-fb-mobile-width, 60px) !important;
    height: var(--nkts-fb-mobile-width, 60px) !important;
    min-width: 44px;
    min-height: 44px;
    white-space: normal;
    padding: 0 6px;
    border-radius: 50%;
  }

  .nkts-free-button-pos-top_left {
    left: 18px !important;
    top: 18px !important;
    right: auto !important;
    bottom: auto !important;
    transform: translate(var(--nkts-fb-mobile-x, 0px), var(--nkts-fb-mobile-y, 0px)) !important;
  }

  .nkts-free-button-pos-top_center {
    left: 50% !important;
    top: 18px !important;
    right: auto !important;
    bottom: auto !important;
    transform: translate(calc(-50% + var(--nkts-fb-mobile-x, 0px)), var(--nkts-fb-mobile-y, 0px)) !important;
  }

  .nkts-free-button-pos-top_right {
    right: 18px !important;
    top: 18px !important;
    left: auto !important;
    bottom: auto !important;
    transform: translate(var(--nkts-fb-mobile-x, 0px), var(--nkts-fb-mobile-y, 0px)) !important;
  }

  .nkts-free-button-pos-center_left {
    left: 18px !important;
    top: 50% !important;
    right: auto !important;
    bottom: auto !important;
    transform: translate(var(--nkts-fb-mobile-x, 0px), calc(-50% + var(--nkts-fb-mobile-y, 0px))) !important;
  }

  .nkts-free-button-pos-center {
    left: 50% !important;
    top: 50% !important;
    right: auto !important;
    bottom: auto !important;
    transform: translate(calc(-50% + var(--nkts-fb-mobile-x, 0px)), calc(-50% + var(--nkts-fb-mobile-y, 0px))) !important;
  }

  .nkts-free-button-pos-center_right {
    right: 18px !important;
    top: 50% !important;
    left: auto !important;
    bottom: auto !important;
    transform: translate(var(--nkts-fb-mobile-x, 0px), calc(-50% + var(--nkts-fb-mobile-y, 0px))) !important;
  }

  .nkts-free-button-pos-bottom_left {
    left: 18px !important;
    bottom: 18px !important;
    right: auto !important;
    top: auto !important;
    transform: translate(var(--nkts-fb-mobile-x, 0px), var(--nkts-fb-mobile-y, 0px)) !important;
  }

  .nkts-free-button-pos-bottom_center {
    left: 50% !important;
    bottom: 18px !important;
    right: auto !important;
    top: auto !important;
    transform: translate(calc(-50% + var(--nkts-fb-mobile-x, 0px)), var(--nkts-fb-mobile-y, 0px)) !important;
  }

  .nkts-free-button-pos-bottom_right {
    right: 18px !important;
    bottom: 18px !important;
    left: auto !important;
    top: auto !important;
    transform: translate(var(--nkts-fb-mobile-x, 0px), var(--nkts-fb-mobile-y, 0px)) !important;
  }

  .nkts-free-button-hide-mobile {
    display: none !important;
  }

  .nkts-free-buttons-header .nkts-free-button {
    max-width: min(var(--nkts-fb-mobile-width, 148px), 42vw) !important;
    height: min(var(--nkts-fb-mobile-height, 42px), 46px) !important;
    font-size: min(var(--nkts-fb-mobile-font, 12px), 13px) !important;
    padding-left: 10px;
    padding-right: 10px;
  }

  .nkts-free-buttons-header .nkts-free-button-pos-top_right,
  .nkts-free-buttons-header .nkts-free-button-pos-center_right {
    top: calc(100% + 8px) !important;
    right: 18px !important;
    transform: translate(var(--nkts-fb-mobile-x, 0px), var(--nkts-fb-mobile-y, 0px)) !important;
  }

  .nkts-free-buttons-header .nkts-free-button-pos-center,
  .nkts-free-buttons-header .nkts-free-button-pos-top_center {
    top: calc(100% + 8px) !important;
    left: 50% !important;
    transform: translate(calc(-50% + var(--nkts-fb-mobile-x, 0px)), var(--nkts-fb-mobile-y, 0px)) !important;
  }
}

@media (max-width: 420px) {
  .nkts-free-button {
    max-width: calc(100vw - 28px) !important;
  }

  .nkts-free-buttons-header .nkts-free-button {
    max-width: 40vw !important;
    font-size: 11px !important;
  }
}

/* ==========================================================
   NKTS V5.55 Hamburger menu animations and typography
========================================================== */
.nkts-hamburger-overlay { --nkts-menu-open-duration:.56s; --nkts-menu-item-duration:.52s; }
.nkts-hamburger-overlay .nkts-hamburger-panel,
.nkts-hamburger-overlay .nkts-hamburger-menu > li { will-change: transform, opacity, filter; }

body.nkts-menu-animation-none .nkts-hamburger-overlay,
body.nkts-menu-animation-none .nkts-hamburger-overlay * {
  transition: none !important;
  animation: none !important;
}

body.nkts-menu-animation-swipe .nkts-hamburger-overlay { transform: translateX(4%) scale(1.01); }
body.nkts-menu-animation-swipe .nkts-hamburger-overlay.is-open { transform: translateX(0) scale(1); }
body.nkts-menu-animation-swipe .nkts-hamburger-overlay .nkts-hamburger-panel { opacity:0; transform:translateY(22px); }
body.nkts-menu-animation-swipe .nkts-hamburger-overlay.is-open .nkts-hamburger-panel { animation:nktsMenuSwipePanel var(--nkts-menu-open-duration) cubic-bezier(.2,.8,.2,1) both; }
@keyframes nktsMenuSwipePanel { from{opacity:0;transform:translateY(22px);} to{opacity:1;transform:translateY(0);} }

body.nkts-menu-animation-pop .nkts-hamburger-overlay.is-open .nkts-hamburger-panel { animation:nktsMenuPop .52s cubic-bezier(.2,1.25,.25,1) both; }
body.nkts-menu-animation-pop .nkts-hamburger-overlay.is-open .nkts-hamburger-menu > li { animation:nktsMenuItemPop .48s cubic-bezier(.2,1.25,.25,1) both; }
body.nkts-menu-animation-pop .nkts-hamburger-overlay.is-open .nkts-hamburger-menu > li:nth-child(1) { animation-delay:.05s; }
body.nkts-menu-animation-pop .nkts-hamburger-overlay.is-open .nkts-hamburger-menu > li:nth-child(2) { animation-delay:.10s; }
body.nkts-menu-animation-pop .nkts-hamburger-overlay.is-open .nkts-hamburger-menu > li:nth-child(3) { animation-delay:.15s; }
body.nkts-menu-animation-pop .nkts-hamburger-overlay.is-open .nkts-hamburger-menu > li:nth-child(4) { animation-delay:.20s; }
body.nkts-menu-animation-pop .nkts-hamburger-overlay.is-open .nkts-hamburger-menu > li:nth-child(5) { animation-delay:.25s; }
@keyframes nktsMenuPop { 0%{opacity:0;transform:scale(.92);filter:blur(8px);} 62%{opacity:1;transform:scale(1.025);filter:blur(0);} 100%{opacity:1;transform:scale(1);filter:blur(0);} }
@keyframes nktsMenuItemPop { from{opacity:0;transform:translateY(18px) scale(.92);} to{opacity:1;transform:translateY(0) scale(1);} }

body.nkts-menu-animation-scratch .nkts-hamburger-overlay.is-open .nkts-hamburger-panel::after {
  content:""; position:absolute; inset:-40%; z-index:0; pointer-events:none;
  background:repeating-linear-gradient(115deg,transparent 0 12px,rgba(255,255,255,.13) 13px 14px,transparent 15px 28px);
  mix-blend-mode:screen; opacity:0; animation:nktsMenuScratch .68s steps(5,end) both;
}
body.nkts-menu-animation-scratch .nkts-hamburger-overlay.is-open .nkts-hamburger-side,
body.nkts-menu-animation-scratch .nkts-hamburger-overlay.is-open .nkts-hamburger-nav { animation:nktsMenuScratchIn .62s ease both; }
@keyframes nktsMenuScratch { 0%{opacity:0;transform:translateX(-18%) skewX(-8deg);} 35%{opacity:.8;} 100%{opacity:0;transform:translateX(18%) skewX(-8deg);} }
@keyframes nktsMenuScratchIn { 0%{opacity:0;filter:contrast(1.4) brightness(1.2);transform:translateX(-8px);} 100%{opacity:1;filter:none;transform:translateX(0);} }

body.nkts-menu-animation-tornado .nkts-hamburger-overlay.is-open .nkts-hamburger-panel { animation:nktsMenuTornado .72s cubic-bezier(.16,.85,.24,1) both; transform-origin:50% 50%; }
body.nkts-menu-animation-tornado .nkts-hamburger-overlay.is-open .nkts-hamburger-menu > li { animation:nktsMenuTornadoItem .58s cubic-bezier(.16,.85,.24,1) both; }
body.nkts-menu-animation-tornado .nkts-hamburger-overlay.is-open .nkts-hamburger-menu > li:nth-child(1) { animation-delay:.06s; }
body.nkts-menu-animation-tornado .nkts-hamburger-overlay.is-open .nkts-hamburger-menu > li:nth-child(2) { animation-delay:.12s; }
body.nkts-menu-animation-tornado .nkts-hamburger-overlay.is-open .nkts-hamburger-menu > li:nth-child(3) { animation-delay:.18s; }
body.nkts-menu-animation-tornado .nkts-hamburger-overlay.is-open .nkts-hamburger-menu > li:nth-child(4) { animation-delay:.24s; }
@keyframes nktsMenuTornado { 0%{opacity:0;transform:rotate(-8deg) scale(.84);filter:blur(14px);} 72%{opacity:1;transform:rotate(1.5deg) scale(1.02);filter:blur(0);} 100%{opacity:1;transform:rotate(0) scale(1);filter:blur(0);} }
@keyframes nktsMenuTornadoItem { from{opacity:0;transform:translateX(48px) rotate(4deg);} to{opacity:1;transform:translateX(0) rotate(0);} }

body.nkts-menu-animation-splash .nkts-hamburger-overlay.is-open .nkts-hamburger-backdrop::after {
  content:""; position:absolute; left:50%; top:50%; width:20vmax; height:20vmax; border-radius:50%;
  background:radial-gradient(circle,rgba(var(--accent-rgb),.36),transparent 66%);
  transform:translate(-50%,-50%) scale(.1); opacity:0; animation:nktsMenuSplash .72s cubic-bezier(.16,.85,.24,1) both;
}
body.nkts-menu-animation-splash .nkts-hamburger-overlay.is-open .nkts-hamburger-panel { animation:nktsMenuSplashPanel .62s ease both; }
@keyframes nktsMenuSplash { 0%{opacity:0;transform:translate(-50%,-50%) scale(.1);} 34%{opacity:.95;} 100%{opacity:0;transform:translate(-50%,-50%) scale(5.6);} }
@keyframes nktsMenuSplashPanel { from{opacity:0;transform:translateY(24px) scale(.98);} to{opacity:1;transform:translateY(0) scale(1);} }

.nkts-hamburger-menu > li > a { font-size: clamp(18px,2.5vw,44px) !important; }
@media (max-width:782px){ .nkts-hamburger-menu > li > a { font-size:28px !important; } }
@media (prefers-reduced-motion:reduce){ .nkts-hamburger-overlay, .nkts-hamburger-overlay * { animation:none !important; transition:none !important; } }


/* ==========================================================
   NKTS V5.56 Hamburger settings force reflection
   MENU内設定が既存CSSに負けないよう最終上書き
========================================================== */
body .nkts-hamburger-overlay .nkts-hamburger-menu > li > a,
body .nkts-hamburger-overlay .nkts-hamburger-nav .primary-menu > li > a {
  font-size: var(--nkts-hm-main-size, 44px) !important;
  color: var(--nkts-hm-main-color, #fff) !important;
}

body .nkts-hamburger-overlay .nkts-hamburger-title,
body .nkts-hamburger-overlay .nkts-hamburger-menu a,
body .nkts-hamburger-overlay .nkts-hamburger-nav .primary-menu a {
  color: var(--nkts-hm-main-color, #fff) !important;
}

body .nkts-hamburger-overlay .nkts-hamburger-label,
body .nkts-hamburger-overlay .nkts-hamburger-nav-label,
body .nkts-hamburger-overlay .nkts-hamburger-menu > li > a::before,
body .nkts-hamburger-overlay .nkts-hamburger-nav .primary-menu > li > a::before,
body .nkts-hamburger-overlay .nkts-hamburger-lead,
body .nkts-hamburger-overlay .nkts-hamburger-meta span {
  color: var(--nkts-hm-sub-color, rgba(255,255,255,.58)) !important;
}

body .nkts-hamburger-overlay .nkts-hamburger-contact {
  color: var(--nkts-hm-cta-color, #fff) !important;
}

@media (max-width: 782px) {
  body .nkts-hamburger-overlay .nkts-hamburger-menu > li > a,
  body .nkts-hamburger-overlay .nkts-hamburger-nav .primary-menu > li > a {
    font-size: var(--nkts-hm-main-mobile-size, 28px) !important;
  }
}


/* ==========================================================
   NKTS V5.57 Complete hamburger menu controls
========================================================== */
.nkts-hamburger-custom-menu > li > a {
  cursor: pointer;
}


/* ==========================================================
   NKTS V5.58 Hamburger MENU button customization
========================================================== */
body .site-header .nkts-hamburger-button,
body .nkts-hamburger-button {
  width: var(--nkts-hb-width, 144px) !important;
  min-width: var(--nkts-hb-width, 144px) !important;
  height: var(--nkts-hb-height, 60px) !important;
  border-radius: var(--nkts-hb-radius, 999px) !important;
  background: var(--nkts-hb-bg, #fff) !important;
  border-color: var(--nkts-hb-border, rgba(15,31,61,.14)) !important;
  color: var(--nkts-hb-text, #0f172a) !important;
}

body .nkts-hamburger-button .nkts-hamburger-text {
  font-size: var(--nkts-hb-font, 14px) !important;
  color: var(--nkts-hb-text, #0f172a) !important;
}

body .nkts-hamburger-button .nkts-hamburger-lines,
body .nkts-hamburger-button .nkts-hamburger-lines i {
  color: var(--nkts-hb-icon-color, #0f172a) !important;
}

body .nkts-hamburger-button .nkts-hamburger-lines i {
  width: var(--nkts-hb-icon, 22px) !important;
  background: var(--nkts-hb-icon-color, #0f172a) !important;
}

body.nkts-hamburger-button-shape-square .nkts-hamburger-button { border-radius: 0 !important; }
body.nkts-hamburger-button-shape-rounded .nkts-hamburger-button { border-radius: 14px !important; }
body.nkts-hamburger-button-shape-pill .nkts-hamburger-button { border-radius: 999px !important; }
body.nkts-hamburger-button-shape-circle .nkts-hamburger-button {
  border-radius: 50% !important;
  padding: 0 !important;
  gap: 4px !important;
  flex-direction: column !important;
}

body.nkts-hamburger-button-shape-circle .nkts-hamburger-button .nkts-hamburger-text {
  font-size: calc(var(--nkts-hb-font, 14px) * .74) !important;
  letter-spacing: .08em !important;
}

@media (max-width: 782px) {
  body .site-header .nkts-hamburger-button,
  body .nkts-hamburger-button {
    width: var(--nkts-hb-mobile-width, 116px) !important;
    min-width: var(--nkts-hb-mobile-width, 116px) !important;
    height: var(--nkts-hb-mobile-height, 50px) !important;
  }

  body .nkts-hamburger-button .nkts-hamburger-text {
    font-size: var(--nkts-hb-mobile-font, 12px) !important;
  }
}


/* ==========================================================
   NKTS V5.59 Ultimate hamburger MENU button reflection
   Current + legacy selectors are all covered.
========================================================== */
body .site-header #nktsHamburgerButton,
body .site-header .nkts-hamburger-button,
body .site-header .nav-toggle,
body .site-header .nkts-menu-button,
body #nktsHamburgerButton,
body .nkts-hamburger-button {
  width: var(--nkts-v559-hb-width, var(--nkts-hb-width, 144px)) !important;
  min-width: var(--nkts-v559-hb-width, var(--nkts-hb-width, 144px)) !important;
  height: var(--nkts-v559-hb-height, var(--nkts-hb-height, 60px)) !important;
  border-radius: var(--nkts-v559-hb-radius, var(--nkts-hb-radius, 999px)) !important;
  background: var(--nkts-v559-hb-bg, var(--nkts-hb-bg, #fff)) !important;
  background-image: none !important;
  border-color: var(--nkts-v559-hb-border, var(--nkts-hb-border, rgba(15,31,61,.14))) !important;
  color: var(--nkts-v559-hb-text, var(--nkts-hb-text, #0f172a)) !important;
}

body .site-header #nktsHamburgerButton::before,
body .site-header .nkts-hamburger-button::before,
body .site-header .nav-toggle::before,
body .site-header .nkts-menu-button::before {
  background: transparent !important;
  background-image: none !important;
}

body #nktsHamburgerButton .nkts-hamburger-text,
body .nkts-hamburger-button .nkts-hamburger-text,
body .nav-toggle em,
body .nkts-menu-button em {
  font-size: var(--nkts-v559-hb-font, var(--nkts-hb-font, 14px)) !important;
  color: var(--nkts-v559-hb-text, var(--nkts-hb-text, #0f172a)) !important;
}

body #nktsHamburgerButton .nkts-hamburger-lines i,
body .nkts-hamburger-button .nkts-hamburger-lines i,
body .nav-toggle span,
body .nkts-menu-button span {
  width: var(--nkts-v559-hb-icon, var(--nkts-hb-icon, 22px)) !important;
  background: var(--nkts-v559-hb-icon-color, var(--nkts-hb-icon-color, #0f172a)) !important;
  color: var(--nkts-v559-hb-icon-color, var(--nkts-hb-icon-color, #0f172a)) !important;
}

@media (max-width: 782px) {
  body .site-header #nktsHamburgerButton,
  body .site-header .nkts-hamburger-button,
  body .site-header .nav-toggle,
  body .site-header .nkts-menu-button,
  body #nktsHamburgerButton,
  body .nkts-hamburger-button {
    width: var(--nkts-v559-hb-mobile-width, var(--nkts-hb-mobile-width, 116px)) !important;
    min-width: var(--nkts-v559-hb-mobile-width, var(--nkts-hb-mobile-width, 116px)) !important;
    height: var(--nkts-v559-hb-mobile-height, var(--nkts-hb-mobile-height, 50px)) !important;
  }

  body #nktsHamburgerButton .nkts-hamburger-text,
  body .nkts-hamburger-button .nkts-hamburger-text,
  body .nav-toggle em,
  body .nkts-menu-button em {
    font-size: var(--nkts-v559-hb-mobile-font, var(--nkts-hb-mobile-font, 12px)) !important;
  }
}


/* ==========================================================
   NKTS V5.60 Footer address color / hero hard stop / clean video
========================================================== */

/* 赤い波線・装飾が読み込み直後に一瞬見える問題を抑制 */
.one-screen-stage .stage-motion,
.one-screen-stage .theme-visuals,
.one-screen-stage .stage-particles,
.one-screen-stage .stage-gridline {
  animation-fill-mode: both !important;
}

/* ヒーロー装飾アニメーション完全停止 */
body.nkts-hero-hard-stop-on .one-screen-stage .stage-motion,
body.nkts-hero-hard-stop-on .one-screen-stage .stage-gridline,
body.nkts-hero-hard-stop-on .one-screen-stage .stage-particles,
body.nkts-hero-hard-stop-on .one-screen-stage .theme-visuals,
body.nkts-hero-hard-stop-on .one-screen-stage .nkts-motion-layer,
body.nkts-hero-hard-stop-on .one-screen-stage .nkts-bg-decoration {
  display: none !important;
  visibility: hidden !important;
  opacity: 0 !important;
  animation: none !important;
  transition: none !important;
}

/* 動画きれい表示：装飾・シェード・フィルターを外す */
body.nkts-clean-video-on .one-screen-stage .stage-motion,
body.nkts-clean-video-on .one-screen-stage .stage-gridline,
body.nkts-clean-video-on .one-screen-stage .stage-particles,
body.nkts-clean-video-on .one-screen-stage .theme-visuals,
body.nkts-clean-video-on .one-screen-stage .nkts-motion-layer,
body.nkts-clean-video-on .one-screen-stage .nkts-bg-decoration {
  display: none !important;
  visibility: hidden !important;
  opacity: 0 !important;
  animation: none !important;
  transition: none !important;
}

body.nkts-clean-video-on .one-screen-stage .media-shade {
  display: none !important;
  visibility: hidden !important;
  opacity: 0 !important;
  background: transparent !important;
}

body.nkts-clean-video-on .one-screen-stage .media-backdrop,
body.nkts-clean-video-on .one-screen-stage .hero-video,
body.nkts-clean-video-on .one-screen-stage .hero-static-image,
body.nkts-clean-video-on .one-screen-stage .hero-slideshow,
body.nkts-clean-video-on .one-screen-stage .hero-slideshow span,
body.nkts-clean-video-on .one-screen-stage .nkts-hero-media-visible {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
  filter: none !important;
  mix-blend-mode: normal !important;
}

body.nkts-clean-video-on .one-screen-stage .hero-video {
  object-fit: cover !important;
  object-position: center center !important;
}

/* フッター住所色は動的CSSで最終反映。ここはクラス系フォールバック */
.site-footer .footer-address,
.site-footer address,
.site-footer .footer-brand address,
.site-footer .footer-company-address,
.site-footer .nkts-footer-address {
  transition: color .2s ease;
}


/* ==========================================================
   NKTS V5.61 Footer location list color controls
   拠点一覧の文字色変更用。動的CSSが最終反映する前提のフォールバック。
========================================================== */
.site-footer .footer-location-list .footer-location-type,
.site-footer .footer-location-list strong,
.site-footer .footer-location-list p,
.site-footer .footer-locations h2 {
  transition: color .2s ease;
}


/* ==========================================================
   NKTS V5.62 Hamburger overlay typography and animation hard fix
========================================================== */

/* All possible menu item selectors in overlay */
body #nktsHamburgerOverlay .nkts-hamburger-menu > li > a,
body #nktsHamburgerOverlay .primary-menu > li > a,
body #nktsHamburgerOverlay nav ul.menu > li > a,
body #nktsHamburgerOverlay nav ul > li > a,
body .nkts-hamburger-overlay .nkts-hamburger-menu > li > a,
body .nkts-hamburger-overlay .primary-menu > li > a,
body .nkts-hamburger-overlay nav ul.menu > li > a,
body .nkts-hamburger-overlay nav ul > li > a {
  font-size: var(--nkts-hmo-font, 44px) !important;
  color: var(--nkts-hmo-main-color, #fff) !important;
}

body #nktsHamburgerOverlay .nkts-hamburger-title,
body #nktsHamburgerOverlay .nkts-hamburger-menu a,
body #nktsHamburgerOverlay .primary-menu a,
body #nktsHamburgerOverlay nav a,
body .nkts-hamburger-overlay .nkts-hamburger-title,
body .nkts-hamburger-overlay .nkts-hamburger-menu a,
body .nkts-hamburger-overlay .primary-menu a,
body .nkts-hamburger-overlay nav a {
  color: var(--nkts-hmo-main-color, #fff) !important;
}

body #nktsHamburgerOverlay .nkts-hamburger-label,
body #nktsHamburgerOverlay .nkts-hamburger-nav-label,
body #nktsHamburgerOverlay .nkts-hamburger-lead,
body #nktsHamburgerOverlay .nkts-hamburger-meta span,
body #nktsHamburgerOverlay .nkts-hamburger-menu > li > a::before,
body #nktsHamburgerOverlay .primary-menu > li > a::before,
body .nkts-hamburger-overlay .nkts-hamburger-label,
body .nkts-hamburger-overlay .nkts-hamburger-nav-label,
body .nkts-hamburger-overlay .nkts-hamburger-lead,
body .nkts-hamburger-overlay .nkts-hamburger-meta span,
body .nkts-hamburger-overlay .nkts-hamburger-menu > li > a::before,
body .nkts-hamburger-overlay .primary-menu > li > a::before {
  color: var(--nkts-hmo-sub-color, rgba(255,255,255,.58)) !important;
}

@media (max-width: 782px) {
  body #nktsHamburgerOverlay .nkts-hamburger-menu > li > a,
  body #nktsHamburgerOverlay .primary-menu > li > a,
  body #nktsHamburgerOverlay nav ul.menu > li > a,
  body #nktsHamburgerOverlay nav ul > li > a,
  body .nkts-hamburger-overlay .nkts-hamburger-menu > li > a,
  body .nkts-hamburger-overlay .primary-menu > li > a,
  body .nkts-hamburger-overlay nav ul.menu > li > a,
  body .nkts-hamburger-overlay nav ul > li > a {
    font-size: var(--nkts-hmo-mobile-font, 28px) !important;
  }
}

/* Animation engine directly uses classes on overlay too */
#nktsHamburgerOverlay.nkts-menu-animation-none,
#nktsHamburgerOverlay.nkts-menu-animation-none *,
.nkts-hamburger-overlay.nkts-menu-animation-none,
.nkts-hamburger-overlay.nkts-menu-animation-none * {
  animation: none !important;
  transition: none !important;
}

#nktsHamburgerOverlay.nkts-menu-animation-swipe.is-open.nkts-anim-replay .nkts-hamburger-panel,
.nkts-hamburger-overlay.nkts-menu-animation-swipe.is-open.nkts-anim-replay .nkts-hamburger-panel {
  animation: nktsMenuSwipePanel .56s cubic-bezier(.2,.8,.2,1) both !important;
}

#nktsHamburgerOverlay.nkts-menu-animation-pop.is-open.nkts-anim-replay .nkts-hamburger-panel,
.nkts-hamburger-overlay.nkts-menu-animation-pop.is-open.nkts-anim-replay .nkts-hamburger-panel {
  animation: nktsMenuPop .52s cubic-bezier(.2,1.25,.25,1) both !important;
}

#nktsHamburgerOverlay.nkts-menu-animation-pop.is-open.nkts-anim-replay .nkts-hamburger-menu > li,
.nkts-hamburger-overlay.nkts-menu-animation-pop.is-open.nkts-anim-replay .nkts-hamburger-menu > li {
  animation: nktsMenuItemPop .48s cubic-bezier(.2,1.25,.25,1) both !important;
}

#nktsHamburgerOverlay.nkts-menu-animation-scratch.is-open.nkts-anim-replay .nkts-hamburger-side,
#nktsHamburgerOverlay.nkts-menu-animation-scratch.is-open.nkts-anim-replay .nkts-hamburger-nav,
.nkts-hamburger-overlay.nkts-menu-animation-scratch.is-open.nkts-anim-replay .nkts-hamburger-side,
.nkts-hamburger-overlay.nkts-menu-animation-scratch.is-open.nkts-anim-replay .nkts-hamburger-nav {
  animation: nktsMenuScratchIn .62s ease both !important;
}

#nktsHamburgerOverlay.nkts-menu-animation-tornado.is-open.nkts-anim-replay .nkts-hamburger-panel,
.nkts-hamburger-overlay.nkts-menu-animation-tornado.is-open.nkts-anim-replay .nkts-hamburger-panel {
  animation: nktsMenuTornado .72s cubic-bezier(.16,.85,.24,1) both !important;
}

#nktsHamburgerOverlay.nkts-menu-animation-tornado.is-open.nkts-anim-replay .nkts-hamburger-menu > li,
.nkts-hamburger-overlay.nkts-menu-animation-tornado.is-open.nkts-anim-replay .nkts-hamburger-menu > li {
  animation: nktsMenuTornadoItem .58s cubic-bezier(.16,.85,.24,1) both !important;
}

#nktsHamburgerOverlay.nkts-menu-animation-splash.is-open.nkts-anim-replay .nkts-hamburger-panel,
.nkts-hamburger-overlay.nkts-menu-animation-splash.is-open.nkts-anim-replay .nkts-hamburger-panel {
  animation: nktsMenuSplashPanel .62s ease both !important;
}


/* ==========================================================
   NKTS V5.63 Safe hamburger animation
   MENUクリック時フリーズ対策：MutationObserver無限発火を廃止
========================================================== */
#nktsHamburgerOverlay.nkts-anim-replay,
.nkts-hamburger-overlay.nkts-anim-replay {
  pointer-events: auto;
}

/* none選択時は確実にアニメーション停止 */
body.nkts-menu-animation-none #nktsHamburgerOverlay,
body.nkts-menu-animation-none #nktsHamburgerOverlay *,
body.nkts-menu-animation-none .nkts-hamburger-overlay,
body.nkts-menu-animation-none .nkts-hamburger-overlay * {
  animation: none !important;
  transition: none !important;
}

/* replayクラスの付け外しで表示状態そのものを壊さない */
#nktsHamburgerOverlay.is-open,
.nkts-hamburger-overlay.is-open {
  visibility: visible;
  pointer-events: auto;
}


/* ==========================================================
   NKTS Hamburger Menu V6.0
   0ベース再実装：最小構成・安定優先
========================================================== */

/* 旧ハンバーガーを完全停止 */
#nktsHamburgerOverlay,
.nkts-hamburger-overlay,
#nktsHamburgerButton,
.nkts-hamburger-button {
  display: none !important;
}

/* V6 button */
.nkts-v600-menu-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  width: auto;
  min-width: 124px;
  height: 52px;
  padding: 0 22px;
  border: 1px solid rgba(15, 31, 61, .14);
  border-radius: var(--nkts-v600-btn-radius, 999px);
  background: var(--nkts-v600-btn-bg, #fff);
  color: var(--nkts-v600-btn-color, #111827);
  font: inherit;
  font-weight: 900;
  letter-spacing: .16em;
  cursor: pointer;
  box-shadow: 0 14px 34px rgba(0,0,0,.16);
  position: relative;
  z-index: 20;
}

.nkts-v600-menu-icon {
  display: grid;
  gap: 4px;
  width: 20px;
}

.nkts-v600-menu-icon i {
  display: block;
  width: 20px;
  height: 2px;
  border-radius: 999px;
  background: currentColor;
}

.nkts-v600-menu-label {
  font-size: 13px;
  line-height: 1;
}

/* V6 overlay */
.nkts-v600-menu-overlay {
  position: fixed;
  inset: 0;
  z-index: 100000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: clamp(24px, 5vw, 72px);
  background: var(--nkts-v600-overlay-bg, #050914);
  color: var(--nkts-v600-menu-color, #fff);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity .24s ease, visibility .24s ease, transform .24s ease;
  overflow-y: auto;
}

.nkts-v600-menu-overlay.is-open {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

/* animation */
.nkts-v600-menu-overlay[style*="--nkts-v600-animation:none"],
.nkts-v600-menu-overlay[data-animation="none"] {
  transition: none;
}

.nkts-v600-menu-overlay {
  transform: translateY(0);
}

.nkts-v600-menu-overlay:not(.is-open) {
  transform: translateY(0);
}

body .nkts-v600-menu-overlay {
  animation: none;
}

body.nkts-v600-menu-open .nkts-v600-menu-overlay {
  animation: nktsV600Fade .24s ease both;
}

body.nkts-v600-menu-open .nkts-v600-menu-overlay[style*="--nkts-v600-animation:slide"] {
  animation: nktsV600Slide .28s ease both;
}

.nkts-v600-menu-inner {
  width: min(980px, 100%);
  padding: clamp(28px, 5vw, 56px);
  border-radius: 28px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.055);
  box-shadow: 0 40px 120px rgba(0,0,0,.36);
  text-align: center;
}

.nkts-v600-menu-kicker {
  margin: 0 0 22px;
  color: rgba(255,255,255,.54);
  font-size: 12px;
  letter-spacing: .28em;
  font-weight: 900;
}

.nkts-v600-menu-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 14px;
}

.nkts-v600-menu-list li {
  margin: 0;
}

.nkts-v600-menu-list a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--nkts-v600-menu-color, #fff) !important;
  font-size: var(--nkts-v600-menu-size, 38px) !important;
  line-height: 1.15;
  font-weight: 900;
  text-decoration: none;
  letter-spacing: .04em;
  padding: 8px 12px;
}

.nkts-v600-menu-list .sub-menu {
  list-style: none;
  margin: 8px 0 0;
  padding: 0;
  display: grid;
  gap: 6px;
}

.nkts-v600-menu-list .sub-menu a {
  font-size: max(15px, calc(var(--nkts-v600-menu-size, 38px) * .42)) !important;
  color: rgba(255,255,255,.72) !important;
}

.nkts-v600-menu-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 210px;
  min-height: 52px;
  margin-top: 28px;
  padding: 0 24px;
  border-radius: 999px;
  background: var(--nkts-v600-cta-bg, #d20b19);
  color: var(--nkts-v600-cta-color, #fff) !important;
  font-weight: 900;
  text-decoration: none;
  box-shadow: 0 18px 42px rgba(210,11,25,.22);
}

.nkts-v600-menu-close {
  position: fixed;
  top: 20px;
  right: 22px;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,.22);
  background: rgba(255,255,255,.08);
  color: #fff;
  font-size: 30px;
  line-height: 1;
  cursor: pointer;
}

body.nkts-v600-menu-open {
  overflow: hidden;
}

@keyframes nktsV600Fade {
  from { opacity: 0; }
  to { opacity: 1; }
}

@keyframes nktsV600Slide {
  from { opacity: 0; transform: translateY(-18px); }
  to { opacity: 1; transform: translateY(0); }
}

@media (max-width: 782px) {
  .nkts-v600-menu-toggle {
    min-width: 104px;
    height: 46px;
    padding: 0 16px;
  }

  .nkts-v600-menu-label {
    font-size: 12px;
  }

  .nkts-v600-menu-inner {
    padding: 28px 18px;
    border-radius: 22px;
  }

  .nkts-v600-menu-list a {
    font-size: min(var(--nkts-v600-menu-size, 38px), 32px) !important;
  }

  .nkts-v600-menu-close {
    top: 14px;
    right: 14px;
  }
}


/* V6.0 animation class fix */
body.nkts-v600-anim-none .nkts-v600-menu-overlay,
body.nkts-v600-anim-none.nkts-v600-menu-open .nkts-v600-menu-overlay {
  animation: none !important;
  transition: none !important;
}

body.nkts-v600-anim-fade.nkts-v600-menu-open .nkts-v600-menu-overlay {
  animation: nktsV600Fade .24s ease both !important;
}

body.nkts-v600-anim-slide.nkts-v600-menu-open .nkts-v600-menu-overlay {
  animation: nktsV600Slide .28s ease both !important;
}


/* ==========================================================
   NKTS V6.0.1 Header brand alignment + V6 hamburger hard fixes
========================================================== */
.site-header .header-inner {
  position: relative !important;
  display: flex !important;
  align-items: center !important;
}

.site-header .brand {
  z-index: 5 !important;
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
}

.site-header .nkts-v600-menu-toggle {
  z-index: 10 !important;
  margin-left: auto !important;
}

/* Header brand position hard fallback */
body.nk-header-brand-left .site-header .header-inner {
  justify-content: space-between !important;
}

body.nk-header-brand-left .site-header .brand {
  position: relative !important;
  left: auto !important;
  right: auto !important;
  top: auto !important;
  transform: none !important;
  margin-left: 0 !important;
  margin-right: auto !important;
}

body.nk-header-brand-center .site-header .header-inner {
  justify-content: flex-end !important;
}

body.nk-header-brand-center .site-header .brand {
  position: absolute !important;
  left: 50% !important;
  top: 50% !important;
  right: auto !important;
  transform: translate(-50%, -50%) !important;
  margin: 0 !important;
}

body.nk-header-brand-right .site-header .header-inner {
  justify-content: flex-start !important;
}

body.nk-header-brand-right .site-header .brand {
  position: relative !important;
  left: auto !important;
  right: auto !important;
  top: auto !important;
  transform: none !important;
  margin-left: auto !important;
  margin-right: 28px !important;
}

/* V6 hamburger settings hard fallback */
.site-header .nkts-v600-menu-toggle,
.nkts-v600-menu-toggle {
  display: inline-flex !important;
  background: var(--nkts-v600-btn-bg, #fff) !important;
  color: var(--nkts-v600-btn-color, #111827) !important;
  border-radius: var(--nkts-v600-btn-radius, 999px) !important;
}

.nkts-v600-menu-toggle .nkts-v600-menu-label {
  color: var(--nkts-v600-btn-color, #111827) !important;
}

.nkts-v600-menu-toggle .nkts-v600-menu-icon i {
  background: var(--nkts-v600-btn-color, #111827) !important;
}

.nkts-v600-menu-overlay {
  background: var(--nkts-v600-overlay-bg, #050914) !important;
  color: var(--nkts-v600-menu-color, #fff) !important;
}

.nkts-v600-menu-list a {
  font-size: var(--nkts-v600-menu-size, 38px) !important;
  color: var(--nkts-v600-menu-color, #fff) !important;
}

.nkts-v600-menu-cta {
  background: var(--nkts-v600-cta-bg, #d20b19) !important;
  color: var(--nkts-v600-cta-color, #fff) !important;
}

@media (max-width: 782px) {
  body.nk-header-brand-left .site-header .brand,
  body.nk-header-brand-center .site-header .brand,
  body.nk-header-brand-right .site-header .brand {
    position: relative !important;
    left: auto !important;
    right: auto !important;
    top: auto !important;
    transform: none !important;
    margin-left: 0 !important;
    margin-right: auto !important;
    max-width: calc(100% - 116px) !important;
  }

  .site-header .header-inner {
    justify-content: space-between !important;
  }

  .nkts-v600-menu-list a {
    font-size: min(var(--nkts-v600-menu-size, 38px), 32px) !important;
  }
}


/* ==========================================================
   NKTS V6.0.2 Deterministic header brand position
   header.phpに直接付与したクラスで制御。body class依存をやめる。
========================================================== */
#siteHeader {
  position: relative !important;
}

#siteHeader .header-inner {
  position: relative !important;
  display: flex !important;
  align-items: center !important;
  min-height: 72px !important;
}

#siteHeader .brand {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  z-index: 20 !important;
  text-decoration: none !important;
}

#siteHeader .nkts-v600-menu-toggle {
  z-index: 30 !important;
  position: relative !important;
  margin-left: auto !important;
}

#siteHeader.nkts-header-brand-left .header-inner {
  justify-content: space-between !important;
}

#siteHeader.nkts-header-brand-left .brand {
  position: relative !important;
  left: auto !important;
  right: auto !important;
  top: auto !important;
  transform: none !important;
  margin-left: 0 !important;
  margin-right: auto !important;
  justify-content: flex-start !important;
}

#siteHeader.nkts-header-brand-center .header-inner {
  justify-content: flex-end !important;
}

#siteHeader.nkts-header-brand-center .brand {
  position: absolute !important;
  left: 50vw !important;
  top: 50% !important;
  right: auto !important;
  transform: translate(-50%, -50%) !important;
  margin: 0 !important;
  justify-content: center !important;
}

#siteHeader.nkts-header-brand-right .header-inner {
  justify-content: flex-start !important;
}

#siteHeader.nkts-header-brand-right .brand {
  position: absolute !important;
  right: clamp(120px, 9vw, 180px) !important;
  left: auto !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  margin: 0 !important;
  justify-content: flex-end !important;
}

@media (max-width: 782px) {
  #siteHeader .header-inner {
    justify-content: space-between !important;
    min-height: 64px !important;
  }

  #siteHeader.nkts-header-brand-left .brand,
  #siteHeader.nkts-header-brand-center .brand,
  #siteHeader.nkts-header-brand-right .brand {
    position: relative !important;
    left: auto !important;
    right: auto !important;
    top: auto !important;
    transform: none !important;
    margin-left: 0 !important;
    margin-right: auto !important;
    max-width: calc(100% - 112px) !important;
  }
}


/* ==========================================================
   NKTS V6.0.3 Hamburger overlay structural fix
   Overlay is rendered outside header and forced full viewport.
========================================================== */

/* V6 overlay must never be clipped by header/container */
body .nkts-v600-menu-overlay#nktsV600MenuOverlay {
  position: fixed !important;
  inset: 0 !important;
  width: 100vw !important;
  height: 100vh !important;
  min-height: 100dvh !important;
  z-index: 2147483000 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: clamp(24px, 5vw, 72px) !important;
  background: var(--nkts-v600-overlay-bg, #050914) !important;
  color: var(--nkts-v600-menu-color, #fff) !important;
  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  transform: none !important;
}

body .nkts-v600-menu-overlay#nktsV600MenuOverlay.is-open {
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
}

body.nkts-v600-menu-open {
  overflow: hidden !important;
}

/* Inner panel: centered, responsive and not dependent on header */
body .nkts-v600-menu-overlay#nktsV600MenuOverlay .nkts-v600-menu-inner {
  width: min(1040px, 100%) !important;
  max-height: calc(100dvh - 80px) !important;
  overflow-y: auto !important;
  padding: clamp(28px, 5vw, 64px) !important;
  border-radius: 28px !important;
  border: 1px solid rgba(255,255,255,.12) !important;
  background: rgba(255,255,255,.065) !important;
  box-shadow: 0 40px 120px rgba(0,0,0,.44) !important;
  text-align: center !important;
}

body .nkts-v600-menu-overlay#nktsV600MenuOverlay .nkts-v600-menu-list {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
  display: grid !important;
  gap: clamp(10px, 2vw, 18px) !important;
}

body .nkts-v600-menu-overlay#nktsV600MenuOverlay .nkts-v600-menu-list a {
  color: var(--nkts-v600-menu-color, #fff) !important;
  font-size: clamp(24px, 5vw, var(--nkts-v600-menu-size, 38px)) !important;
  line-height: 1.15 !important;
  font-weight: 900 !important;
  text-decoration: none !important;
  letter-spacing: .04em !important;
  word-break: keep-all !important;
  overflow-wrap: anywhere !important;
}

body .nkts-v600-menu-overlay#nktsV600MenuOverlay .nkts-v600-menu-cta {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-width: 210px !important;
  min-height: 52px !important;
  margin-top: 28px !important;
  padding: 0 24px !important;
  border-radius: 999px !important;
  background: var(--nkts-v600-cta-bg, #d20b19) !important;
  color: var(--nkts-v600-cta-color, #fff) !important;
  font-weight: 900 !important;
  text-decoration: none !important;
}

body .nkts-v600-menu-overlay#nktsV600MenuOverlay .nkts-v600-menu-close {
  position: fixed !important;
  top: max(14px, env(safe-area-inset-top)) !important;
  right: max(14px, env(safe-area-inset-right)) !important;
  width: 52px !important;
  height: 52px !important;
  border-radius: 50% !important;
  z-index: 2147483001 !important;
  border: 1px solid rgba(255,255,255,.22) !important;
  background: rgba(255,255,255,.08) !important;
  color: #fff !important;
  font-size: 30px !important;
  line-height: 1 !important;
  cursor: pointer !important;
}

/* Simple animation, no observer */
body.nkts-v600-menu-open.nkts-v600-anim-fade .nkts-v600-menu-overlay#nktsV600MenuOverlay,
body.nkts-v600-menu-open .nkts-v600-menu-overlay#nktsV600MenuOverlay {
  animation: nktsV600Fade .24s ease both !important;
}

body.nkts-v600-menu-open.nkts-v600-anim-slide .nkts-v600-menu-overlay#nktsV600MenuOverlay {
  animation: nktsV600Slide .28s ease both !important;
}

body.nkts-v600-menu-open.nkts-v600-anim-none .nkts-v600-menu-overlay#nktsV600MenuOverlay {
  animation: none !important;
  transition: none !important;
}

/* Mobile */
@media (max-width: 782px) {
  body .nkts-v600-menu-overlay#nktsV600MenuOverlay {
    align-items: flex-start !important;
    justify-content: center !important;
    padding: calc(76px + env(safe-area-inset-top)) 18px 28px !important;
  }

  body .nkts-v600-menu-overlay#nktsV600MenuOverlay .nkts-v600-menu-inner {
    width: 100% !important;
    max-height: calc(100dvh - 110px) !important;
    padding: 26px 18px !important;
    border-radius: 22px !important;
  }

  body .nkts-v600-menu-overlay#nktsV600MenuOverlay .nkts-v600-menu-kicker {
    font-size: 11px !important;
    margin-bottom: 18px !important;
  }

  body .nkts-v600-menu-overlay#nktsV600MenuOverlay .nkts-v600-menu-list {
    gap: 10px !important;
  }

  body .nkts-v600-menu-overlay#nktsV600MenuOverlay .nkts-v600-menu-list a {
    font-size: clamp(22px, 8vw, 32px) !important;
    padding: 8px 4px !important;
  }

  body .nkts-v600-menu-overlay#nktsV600MenuOverlay .nkts-v600-menu-list .sub-menu a {
    font-size: 15px !important;
  }

  body .nkts-v600-menu-overlay#nktsV600MenuOverlay .nkts-v600-menu-cta {
    width: min(100%, 280px) !important;
    min-height: 50px !important;
    margin-top: 22px !important;
  }

  body .nkts-v600-menu-overlay#nktsV600MenuOverlay .nkts-v600-menu-close {
    width: 46px !important;
    height: 46px !important;
    font-size: 28px !important;
  }
}


/* ==========================================================
   NKTS V6.0.4 Hamburger tier typography
   上段小・中段中・下段大のような段階的文字サイズに対応
========================================================== */

body #nktsV600MenuOverlay .nkts-v600-menu-kicker {
  font-size: var(--nkts-v604-kicker-size, 12px) !important;
  color: var(--nkts-v604-kicker-color, rgba(255,255,255,.62)) !important;
  line-height: 1.2 !important;
}

body #nktsV600MenuOverlay .nkts-v600-menu-list > li:not(:last-child) > a {
  font-size: var(--nkts-v604-second-size, 18px) !important;
  color: var(--nkts-v604-second-color, #fff) !important;
}

body #nktsV600MenuOverlay .nkts-v600-menu-list > li:last-child > a,
body #nktsV600MenuOverlay .nkts-v600-menu-list > li:only-child > a {
  font-size: var(--nkts-v604-main-size, 42px) !important;
  color: var(--nkts-v604-main-color, #fff) !important;
}

body #nktsV600MenuOverlay .nkts-v600-menu-list .sub-menu a {
  font-size: var(--nkts-v604-sub-size, 16px) !important;
  color: var(--nkts-v604-sub-color, rgba(255,255,255,.72)) !important;
}

@media (max-width: 782px) {
  body #nktsV600MenuOverlay .nkts-v600-menu-kicker {
    font-size: min(var(--nkts-v604-kicker-size, 12px), 14px) !important;
  }

  body #nktsV600MenuOverlay .nkts-v600-menu-list > li:not(:last-child) > a {
    font-size: clamp(16px, 5.5vw, var(--nkts-v604-second-size, 18px)) !important;
  }

  body #nktsV600MenuOverlay .nkts-v600-menu-list > li:last-child > a,
  body #nktsV600MenuOverlay .nkts-v600-menu-list > li:only-child > a {
    font-size: clamp(24px, 9vw, var(--nkts-v604-main-size, 42px)) !important;
  }

  body #nktsV600MenuOverlay .nkts-v600-menu-list .sub-menu a {
    font-size: clamp(13px, 4.2vw, var(--nkts-v604-sub-size, 16px)) !important;
  }
}


/* ==========================================================
   NKTS V6.0.5 Quick edit pencil shortcuts and CTA editing
========================================================== */
.nkts-v605-edit-wrap {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.hero-actions .nkts-v605-edit-wrap {
  display: inline-flex;
}

.nkts-v605-pencil {
  display: inline-grid;
  place-items: center;
  flex: 0 0 auto;
  width: 28px;
  height: 28px;
  border: 2px solid rgba(255,255,255,.92);
  border-radius: 50%;
  background: #2d8fd3;
  color: #fff;
  box-shadow: 0 8px 20px rgba(0,0,0,.22);
  font-size: 13px;
  font-weight: 900;
  line-height: 1;
  cursor: pointer;
  z-index: 50;
  vertical-align: middle;
  transition: transform .16s ease, background .16s ease, box-shadow .16s ease;
}

.nkts-v605-pencil:hover {
  transform: translateY(-1px) scale(1.04);
  background: #0f78bd;
  box-shadow: 0 12px 26px rgba(0,0,0,.28);
}

.nkts-v605-pencil.is-success {
  background: #16a34a;
}

.nkts-v605-pencil.is-failed {
  background: #dc2626;
}

.nkts-v605-pencil span {
  display: block;
  transform: translateY(-1px);
}

@media (max-width: 782px) {
  .nkts-v605-pencil {
    width: 24px;
    height: 24px;
    font-size: 12px;
  }

  .nkts-v605-edit-wrap {
    gap: 6px;
  }
}


/* ==========================================================
   NKTS V6.0.6 Hamburger settings consolidation
   設定箇所をV6に一本化。文字サイズは3パターン選択式。
========================================================== */
body #nktsV600MenuOverlay .nkts-v600-menu-kicker {
  font-size: var(--nkts-v606-menu-kicker-size, 12px) !important;
}

body #nktsV600MenuOverlay .nkts-v600-menu-list {
  gap: var(--nkts-v606-menu-gap, 12px) !important;
}

body #nktsV600MenuOverlay .nkts-v600-menu-list > li > a {
  font-size: var(--nkts-v606-menu-main-size, 36px) !important;
  color: var(--nkts-v600-menu-color, #fff) !important;
}

body #nktsV600MenuOverlay .nkts-v600-menu-list .sub-menu a {
  font-size: var(--nkts-v606-menu-sub-size, 16px) !important;
  color: rgba(255,255,255,.72) !important;
}

@media (max-width: 782px) {
  body #nktsV600MenuOverlay .nkts-v600-menu-list > li > a {
    font-size: clamp(22px, 7.6vw, var(--nkts-v606-menu-main-size, 36px)) !important;
  }

  body #nktsV600MenuOverlay .nkts-v600-menu-list .sub-menu a {
    font-size: clamp(13px, 4.4vw, var(--nkts-v606-menu-sub-size, 16px)) !important;
  }
}


/* ==========================================================
   NKTS V6.0.7 Footer settings consolidation / white text colors
========================================================== */

/* 動的CSSで色を最終反映するための対象整理 */
.site-footer .footer-brand,
.site-footer .footer-en,
.site-footer .footer-company-card strong,
.site-footer .footer-address,
.site-footer .footer-phone,
.site-footer .footer-tagline,
.site-footer .footer-service-list li,
.site-footer .footer-navigation a,
.site-footer .nkts-edit-copyright {
  transition: color .18s ease;
}


/* ==========================================================
   NKTS V6.0.8 Video hero preload fix
   動画読み込み前に赤い波線・粒子・背景装飾が一瞬表示される問題を防止
========================================================== */

body.nkts-hero-video-mode .one-screen-stage .stage-motion,
body.nkts-hero-video-mode .one-screen-stage .stage-gridline,
body.nkts-hero-video-mode .one-screen-stage .stage-particles,
body.nkts-hero-video-mode .one-screen-stage .theme-visuals,
body.nkts-hero-video-mode .one-screen-stage .nkts-motion-layer,
body.nkts-hero-video-mode .one-screen-stage .nkts-bg-decoration {
  display: none !important;
  visibility: hidden !important;
  opacity: 0 !important;
  animation: none !important;
  transition: none !important;
}

body.nkts-hero-video-mode .one-screen-stage .media-backdrop,
body.nkts-hero-video-mode .one-screen-stage .hero-video {
  filter: none !important;
  mix-blend-mode: normal !important;
}

body.nkts-hero-video-mode .one-screen-stage .media-shade {
  opacity: var(--nkts-video-shade-opacity, 0) !important;
}

body.nkts-hero-video-not-ready .one-screen-stage .hero-video {
  opacity: 0;
}

body.nkts-hero-video-ready .one-screen-stage .hero-video {
  opacity: 1 !important;
}


/* ==========================================================
   NKTS V6.0.9 Strong video-first hero fix
   動画開始前の背景画像・赤い波線・装飾レイヤーを完全停止
========================================================== */

body.nkts-v609-video-first .one-screen-stage .stage-motion,
body.nkts-v609-video-first .one-screen-stage .stage-gridline,
body.nkts-v609-video-first .one-screen-stage .stage-particles,
body.nkts-v609-video-first .one-screen-stage .theme-visuals,
body.nkts-v609-video-first .one-screen-stage .hero-static-image,
body.nkts-v609-video-first .one-screen-stage .hero-slideshow,
body.nkts-v609-video-first .one-screen-stage .hero-slideshow *,
body.nkts-v609-video-first .one-screen-stage .nkts-demo-bg,
body.nkts-v609-video-first .one-screen-stage .nkts-demo-image,
body.nkts-v609-video-first .one-screen-stage .demo-image,
body.nkts-v609-video-first .one-screen-stage .background-animation,
body.nkts-v609-video-first .one-screen-stage .nkts-motion-layer,
body.nkts-v609-video-first .one-screen-stage .nkts-bg-decoration {
  display: none !important;
  visibility: hidden !important;
  opacity: 0 !important;
  animation: none !important;
  transition: none !important;
  background-image: none !important;
}

body.nkts-v609-video-first .one-screen-stage .media-backdrop {
  background: #000 !important;
  background-image: none !important;
  filter: none !important;
  mix-blend-mode: normal !important;
}

body.nkts-v609-video-first .one-screen-stage .media-backdrop::before,
body.nkts-v609-video-first .one-screen-stage .media-backdrop::after,
body.nkts-v609-video-first .one-screen-stage::before,
body.nkts-v609-video-first .one-screen-stage::after {
  display: none !important;
  content: none !important;
  visibility: hidden !important;
  opacity: 0 !important;
  animation: none !important;
  background-image: none !important;
}

body.nkts-v609-video-first .one-screen-stage video,
body.nkts-v609-video-first .one-screen-stage .hero-video,
body.nkts-v609-video-first .one-screen-stage video.hero-video {
  display: block !important;
  visibility: visible !important;
  filter: none !important;
  mix-blend-mode: normal !important;
  object-fit: cover !important;
  object-position: center center !important;
  background: #000 !important;
}

body.nkts-v609-video-loading .one-screen-stage .hero-video,
body.nkts-v609-video-loading .one-screen-stage video {
  opacity: 0;
}

body.nkts-v609-video-ready .one-screen-stage .hero-video,
body.nkts-v609-video-ready .one-screen-stage video {
  opacity: 1 !important;
  transition: opacity .24s ease;
}


/* ==========================================================
   NKTS V6.1.0 Premium Hamburger Menu
   画像案に寄せたプレミアムUI + 親中サイズ/子小サイズ + ぷよんホバー
========================================================== */

body #nktsV600MenuOverlay {
  background:
    radial-gradient(circle at 16% 100%, color-mix(in srgb, var(--nkts-v610-accent, #e11d2e) 34%, transparent), transparent 34%),
    linear-gradient(135deg, #050914 0%, #0b1220 52%, #060913 100%) !important;
}

body #nktsV600MenuOverlay .nkts-v610-menu-inner {
  width: min(1280px, 100%) !important;
  max-height: calc(100dvh - 64px) !important;
  display: grid !important;
  grid-template-columns: minmax(260px, 34%) 1fr !important;
  gap: clamp(24px, 4vw, 56px) !important;
  padding: 0 !important;
  border-radius: 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  text-align: left !important;
}

body #nktsV600MenuOverlay .nkts-v610-menu-brand {
  min-height: min(680px, calc(100dvh - 96px));
  padding: clamp(34px, 5vw, 72px) clamp(24px, 4vw, 52px);
  border-right: 1px solid rgba(255,255,255,.08);
  display: flex;
  flex-direction: column;
  justify-content: center;
  position: relative;
}

body #nktsV600MenuOverlay .nkts-v610-menu-brand::after {
  content: "";
  position: absolute;
  left: 8%;
  right: 16%;
  bottom: 12%;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--nkts-v610-accent, #e11d2e), transparent);
  box-shadow: 0 0 38px var(--nkts-v610-accent, #e11d2e);
}

body #nktsV600MenuOverlay .nkts-v610-brand-mark {
  color: #fff;
  font-size: clamp(36px, 5vw, 64px);
  line-height: .92;
  letter-spacing: .06em;
  font-weight: 1000;
}

body #nktsV600MenuOverlay .nkts-v610-brand-mark::after {
  content: "";
  display: inline-block;
  width: .18em;
  height: .18em;
  margin-left: .08em;
  border-radius: 50%;
  background: var(--nkts-v610-accent, #e11d2e);
}

body #nktsV600MenuOverlay .nkts-v610-brand-sub {
  margin: 14px 0 0;
  color: rgba(255,255,255,.66);
  font-size: 14px;
  letter-spacing: .08em;
  line-height: 1.5;
}

body #nktsV600MenuOverlay .nkts-v610-brand-copy {
  margin: clamp(50px, 8vw, 110px) 0 0;
  color: #fff;
  font-size: clamp(24px, 3vw, 42px);
  line-height: 1.3;
  letter-spacing: .08em;
  font-weight: 500;
}

body #nktsV600MenuOverlay .nkts-v610-brand-lead {
  max-width: 420px;
  margin: 20px 0 0;
  color: rgba(255,255,255,.68);
  font-size: 15px;
  line-height: 2;
  letter-spacing: .08em;
}

body #nktsV600MenuOverlay .nkts-v610-menu-main {
  padding: clamp(28px, 4vw, 56px) 0;
}

body #nktsV600MenuOverlay .nkts-v600-menu-kicker {
  display: block !important;
  margin: 0 0 22px !important;
  color: rgba(255,255,255,.82) !important;
  text-align: center !important;
  font-size: 14px !important;
  font-weight: 900 !important;
  letter-spacing: .42em !important;
}

body #nktsV600MenuOverlay .nkts-v600-menu-kicker::after {
  content: "";
  display: block;
  width: 44px;
  height: 2px;
  margin: 12px auto 0;
  background: var(--nkts-v610-accent, #e11d2e);
  box-shadow: 0 0 18px var(--nkts-v610-accent, #e11d2e);
}

body #nktsV600MenuOverlay .nkts-v610-menu-list {
  display: grid !important;
  gap: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
  border-top: 1px solid rgba(255,255,255,.08);
}

body #nktsV600MenuOverlay .nkts-v610-menu-item {
  position: relative;
  margin: 0 !important;
  border-bottom: 1px solid rgba(255,255,255,.08);
}

body #nktsV600MenuOverlay .nkts-v610-parent-link {
  min-height: 74px;
  display: grid !important;
  grid-template-columns: 54px 52px minmax(0, 1fr) 34px;
  align-items: center;
  gap: 18px;
  padding: 0 clamp(18px, 3vw, 44px) !important;
  color: #fff !important;
  text-decoration: none !important;
  overflow: hidden;
  transform-origin: center;
  transition: background .22s ease, color .22s ease, transform .22s ease;
}

body #nktsV600MenuOverlay .nkts-v610-parent-link:hover {
  background: linear-gradient(90deg, var(--nkts-v610-accent-soft, rgba(225,29,46,.15)), rgba(255,255,255,.035));
}

body #nktsV600MenuOverlay .nkts-v610-menu-number {
  color: var(--nkts-v610-accent, #e11d2e) !important;
  font-size: 14px;
  font-weight: 900;
  letter-spacing: .08em;
  font-variant-numeric: tabular-nums;
}

body #nktsV600MenuOverlay .nkts-v610-menu-icon {
  color: rgba(255,255,255,.86) !important;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

body #nktsV600MenuOverlay .nkts-v610-menu-title {
  min-width: 0;
  display: block;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  color: #fff !important;
  font-size: var(--nkts-v606-menu-main-size, 30px) !important;
  line-height: 1.1 !important;
  font-weight: 900 !important;
  letter-spacing: .06em;
}

body #nktsV600MenuOverlay .nkts-v610-menu-arrow {
  color: var(--nkts-v610-accent, #e11d2e) !important;
  font-size: 30px;
  line-height: 1;
  text-align: right;
}

body #nktsV600MenuOverlay .nkts-v610-submenu {
  list-style: none !important;
  margin: -2px 0 14px !important;
  padding: 12px clamp(18px, 3vw, 44px) 14px calc(clamp(18px, 3vw, 44px) + 124px) !important;
  background: linear-gradient(90deg, rgba(255,255,255,.045), rgba(255,255,255,.015)) !important;
  border-top: 1px solid rgba(255,255,255,.045);
  position: relative;
}

body #nktsV600MenuOverlay .nkts-v610-submenu::before {
  content: "";
  position: absolute;
  left: calc(clamp(18px, 3vw, 44px) + 88px);
  top: 14px;
  bottom: 14px;
  width: 1px;
  border-left: 1px dotted rgba(255,255,255,.22);
}

body #nktsV600MenuOverlay .nkts-v610-submenu li {
  margin: 0 !important;
}

body #nktsV600MenuOverlay .nkts-v610-submenu a {
  min-height: 36px;
  display: grid !important;
  grid-template-columns: 14px minmax(0, 1fr) 24px;
  align-items: center;
  gap: 14px;
  color: rgba(255,255,255,.72) !important;
  text-decoration: none !important;
  font-size: var(--nkts-v606-menu-sub-size, 15px) !important;
  line-height: 1.2 !important;
  letter-spacing: .06em;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  transition: background .2s ease, color .2s ease, transform .2s ease;
}

body #nktsV600MenuOverlay .nkts-v610-submenu a:hover {
  color: #fff !important;
  background: var(--nkts-v610-accent-soft, rgba(225,29,46,.15));
}

body #nktsV600MenuOverlay .nkts-v610-submenu a span {
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: rgba(255,255,255,.35);
}

body #nktsV600MenuOverlay .nkts-v610-submenu a b {
  color: var(--nkts-v610-accent, #e11d2e);
  font-weight: 400;
  text-align: right;
}

body #nktsV600MenuOverlay .nkts-v600-menu-cta {
  width: min(760px, calc(100% - 88px)) !important;
  min-height: 62px !important;
  margin: 28px auto 0 !important;
  display: flex !important;
  border: 1px solid var(--nkts-v610-accent, #e11d2e) !important;
  border-radius: 8px !important;
  background: linear-gradient(90deg, var(--nkts-v610-accent-soft, rgba(225,29,46,.15)), rgba(255,255,255,.02)) !important;
  color: #fff !important;
  box-shadow: 0 0 36px var(--nkts-v610-accent-soft, rgba(225,29,46,.15)) !important;
}

/* Slime / puyo hover */
@keyframes nktsV610Puyo {
  0% { transform: scale(1, 1); }
  28% { transform: scale(1.035, .94); }
  52% { transform: scale(.975, 1.035); }
  74% { transform: scale(1.012, .988); }
  100% { transform: scale(1, 1); }
}

body.nkts-v610-puyo-hover #nktsV600MenuOverlay .nkts-v610-parent-link:hover,
body.nkts-v610-puyo-hover #nktsV600MenuOverlay .nkts-v610-submenu a:hover,
body.nkts-v610-puyo-hover #nktsV600MenuOverlay .nkts-v600-menu-cta:hover,
body.nkts-v610-puyo-hover .nkts-v600-menu-toggle:hover {
  animation: nktsV610Puyo .56s cubic-bezier(.2,1.35,.3,1) both !important;
}

/* Mobile */
@media (max-width: 900px) {
  body #nktsV600MenuOverlay .nkts-v610-menu-inner {
    display: block !important;
    max-height: calc(100dvh - 48px) !important;
    overflow-y: auto !important;
  }

  body #nktsV600MenuOverlay .nkts-v610-menu-brand {
    display: none !important;
  }

  body #nktsV600MenuOverlay .nkts-v610-menu-main {
    padding: 54px 0 22px !important;
  }

  body #nktsV600MenuOverlay .nkts-v610-parent-link {
    min-height: 62px;
    grid-template-columns: 42px 38px minmax(0, 1fr) 24px;
    gap: 12px;
    padding: 0 18px !important;
  }

  body #nktsV600MenuOverlay .nkts-v610-menu-number {
    font-size: 12px;
  }

  body #nktsV600MenuOverlay .nkts-v610-menu-svg {
    width: 21px;
    height: 21px;
  }

  body #nktsV600MenuOverlay .nkts-v610-menu-title {
    font-size: clamp(18px, 5.3vw, 24px) !important;
    letter-spacing: .04em;
  }

  body #nktsV600MenuOverlay .nkts-v610-submenu {
    margin: 0 0 8px !important;
    padding: 10px 18px 10px 92px !important;
  }

  body #nktsV600MenuOverlay .nkts-v610-submenu::before {
    left: 72px;
  }

  body #nktsV600MenuOverlay .nkts-v610-submenu a {
    font-size: clamp(13px, 3.8vw, 15px) !important;
  }

  body #nktsV600MenuOverlay .nkts-v600-menu-cta {
    width: calc(100% - 36px) !important;
    min-height: 54px !important;
  }
}


/* ==========================================================
   NKTS V6.1.1 Stage Plugin Style Hamburger
   アップロードされた NK Stage Hamburger Menu 風の表示へ切り替え
========================================================== */

body.nkts-hamburger-style-stage_plugin .nkts-v600-menu-overlay#nktsV600MenuOverlay {
  background: transparent !important;
  padding: 0 !important;
  align-items: stretch !important;
  justify-content: stretch !important;
}

.nkts-stage-overlay {
  position: fixed !important;
  inset: 0 !important;
  width: 100vw !important;
  height: 100dvh !important;
  z-index: 2147483000 !important;
  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
  display: block !important;
  overflow: hidden !important;
  color: var(--nkts-stage-text, #fff) !important;
}

.nkts-stage-overlay.is-open {
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
}

.nkts-stage-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.56);
  backdrop-filter: blur(4px);
}

.nkts-stage-panel {
  position: absolute;
  top: 0;
  bottom: 0;
  width: min(720px, 92vw);
  max-width: 100%;
  overflow-y: auto;
  padding: clamp(24px, 4vw, 48px);
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--nkts-stage-panel-bg, #2f2f31) calc(var(--nkts-stage-panel-opacity, 1) * 100%), transparent), color-mix(in srgb, var(--nkts-stage-panel-bg, #2f2f31) calc(var(--nkts-stage-panel-opacity, 1) * 100%), transparent)),
    var(--nkts-stage-panel-bg, #2f2f31);
  color: var(--nkts-stage-text, #fff);
  box-shadow: 0 32px 90px rgba(0,0,0,.42);
  transform: translateX(102%);
  transition: transform .38s cubic-bezier(.2,.8,.2,1);
}

body.nkts-stage-panel-left .nkts-stage-panel {
  left: 0;
  right: auto;
  transform: translateX(-102%);
}

body.nkts-stage-panel-right .nkts-stage-panel {
  right: 0;
  left: auto;
}

body.nkts-stage-panel-center .nkts-stage-panel {
  left: 50%;
  right: auto;
  top: 50%;
  bottom: auto;
  height: min(820px, calc(100dvh - 48px));
  border-radius: 18px;
  transform: translate(-50%, -45%) scale(.96);
}

.nkts-stage-overlay.is-open .nkts-stage-panel {
  transform: translateX(0);
}

body.nkts-stage-panel-center .nkts-stage-overlay.is-open .nkts-stage-panel {
  transform: translate(-50%, -50%) scale(1);
}

.nkts-stage-close {
  position: absolute !important;
  top: 18px !important;
  right: 18px !important;
  width: 48px !important;
  height: 48px !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  color: var(--nkts-stage-text, #fff) !important;
  box-shadow: none !important;
}

.nkts-stage-close span {
  position: absolute;
  top: 23px;
  left: 8px;
  width: 32px;
  height: 2px;
  background: currentColor;
}

.nkts-stage-close span:first-child { transform: rotate(45deg); }
.nkts-stage-close span:last-child { transform: rotate(-45deg); }

.nkts-stage-header {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 18px;
  align-items: start;
  padding: 24px 56px 24px 0;
}

.nkts-stage-company {
  margin: 0 0 8px;
  color: var(--nkts-stage-text, #fff);
  font-size: clamp(17px, 2vw, 22px);
  font-weight: 800;
  line-height: 1.35;
}

.nkts-stage-phone {
  margin: 0 0 6px;
  color: var(--nkts-stage-text, #fff);
  font-size: clamp(22px, 3vw, 32px);
  font-weight: 300;
  letter-spacing: .02em;
}

.nkts-stage-hours {
  margin: 0;
  color: var(--nkts-stage-subtext, #d5d5d5);
  font-size: 14px;
  font-weight: 600;
}

.nkts-stage-contact {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  padding: 0 18px;
  border-radius: 999px;
  border: 1px solid var(--nkts-stage-line, rgba(255,255,255,.24));
  color: var(--nkts-stage-text, #fff) !important;
  text-decoration: none;
  font-weight: 800;
  white-space: nowrap;
}

.nkts-stage-card {
  background: var(--nkts-stage-card-bg, #101113);
  border-radius: 10px;
  padding: 26px 18px 28px;
}

.nkts-stage-nav ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

.nkts-stage-item {
  border-top: 1px solid var(--nkts-stage-line, rgba(255,255,255,.24));
}

.nkts-stage-item:last-child {
  border-bottom: 1px solid var(--nkts-stage-line, rgba(255,255,255,.24));
}

.nkts-stage-main-link {
  min-height: 76px;
  display: grid;
  grid-template-columns: minmax(108px, 160px) minmax(0, 1fr) 20px;
  gap: 16px;
  align-items: center;
  padding: 18px 8px;
  text-decoration: none;
  color: var(--nkts-stage-text, #fff) !important;
}

.nkts-stage-en {
  font-family: Georgia, 'Times New Roman', serif;
  font-size: clamp(22px, 2.8vw, 32px);
  line-height: 1;
  letter-spacing: .03em;
  color: var(--nkts-stage-text, #fff);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.nkts-stage-ja {
  color: var(--nkts-stage-subtext, #d5d5d5);
  font-size: 15px;
  font-weight: 700;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.nkts-stage-arrow {
  color: var(--nkts-stage-accent, #fff);
  font-size: 26px;
  text-align: right;
  transform: translateY(-1px);
}

.nkts-stage-submenu {
  margin: -6px 0 18px;
  padding: 0 8px 16px min(176px, 34%);
  display: grid;
  gap: 8px;
}

.nkts-stage-submenu a {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 18px;
  align-items: center;
  gap: 10px;
  color: var(--nkts-stage-subtext, #d5d5d5) !important;
  text-decoration: none;
  font-size: 14px;
  line-height: 1.45;
  padding: 7px 0;
  border-top: 1px dashed color-mix(in srgb, var(--nkts-stage-line, rgba(255,255,255,.24)) 65%, transparent);
}

.nkts-stage-submenu a span {
  color: var(--nkts-stage-accent, #fff);
  text-align: right;
}

.nkts-stage-main-link:hover,
.nkts-stage-submenu a:hover,
.nkts-stage-contact:hover {
  color: var(--nkts-stage-text, #fff) !important;
  opacity: .82;
}

.nkts-stage-footer {
  padding-top: 18px;
  color: var(--nkts-stage-subtext, #d5d5d5);
  font-size: 12px;
  text-align: right;
}

/* Trigger button adjustment for stage mode */
body.nkts-hamburger-style-stage_plugin .nkts-v600-menu-toggle {
  background: var(--nkts-v600-btn-bg, #111) !important;
  border-color: var(--nkts-v600-btn-border, rgba(255,255,255,.18)) !important;
}

/* Mobile */
@media (max-width: 782px) {
  .nkts-stage-panel {
    width: 100vw;
    padding: 22px 16px 28px;
  }

  body.nkts-stage-panel-center .nkts-stage-panel {
    width: calc(100vw - 24px);
    height: calc(100dvh - 24px);
  }

  .nkts-stage-header {
    display: block;
    padding: 56px 0 20px;
  }

  .nkts-stage-contact {
    margin-top: 14px;
    width: 100%;
  }

  .nkts-stage-card {
    padding: 18px 14px 20px;
  }

  .nkts-stage-main-link {
    min-height: 64px;
    grid-template-columns: minmax(88px, 122px) minmax(0, 1fr) 18px;
    gap: 12px;
    padding: 14px 4px;
  }

  .nkts-stage-en {
    font-size: clamp(20px, 7vw, 25px);
  }

  .nkts-stage-ja {
    font-size: 13px;
  }

  .nkts-stage-submenu {
    padding-left: 92px;
  }
}


/* ==========================================================
   NKTS V6.1.2 Hamburger inner design controls
   メニュー内背景色・文字サイズ・文字色変更の対象整理
========================================================== */

body #nktsV600MenuOverlay .nkts-v610-menu-title,
body #nktsV600MenuOverlay .nkts-stage-en {
  transition: color .18s ease, font-size .18s ease, background .18s ease;
}

body #nktsV600MenuOverlay .nkts-v610-submenu a,
body #nktsV600MenuOverlay .nkts-stage-submenu a {
  transition: color .18s ease, font-size .18s ease, background .18s ease;
}


/* ==========================================================
   NKTS V6.1.3 Smaller hamburger menu typography
   初期表示の文字サイズを控えめに調整
========================================================== */

body #nktsV600MenuOverlay .nkts-v610-menu-title {
  font-size: 26px !important;
}

body #nktsV600MenuOverlay .nkts-stage-en {
  font-size: 24px !important;
}

body #nktsV600MenuOverlay .nkts-stage-ja {
  font-size: 13px !important;
}

body #nktsV600MenuOverlay .nkts-v610-submenu a,
body #nktsV600MenuOverlay .nkts-stage-submenu a {
  font-size: 13px !important;
}

body #nktsV600MenuOverlay .nkts-v600-menu-kicker {
  font-size: 11px !important;
}

@media (max-width: 900px) {
  body #nktsV600MenuOverlay .nkts-v610-menu-title {
    font-size: clamp(17px, 4.6vw, 22px) !important;
  }

  body #nktsV600MenuOverlay .nkts-stage-en {
    font-size: clamp(18px, 5.4vw, 23px) !important;
  }

  body #nktsV600MenuOverlay .nkts-stage-ja {
    font-size: 12px !important;
  }

  body #nktsV600MenuOverlay .nkts-v610-submenu a,
  body #nktsV600MenuOverlay .nkts-stage-submenu a {
    font-size: 12px !important;
  }
}


/* ==========================================================
   NKTS V6.2.0 Safe Hamburger Core CSS
   旧ハンバーガーを停止し、完全独立クラスで安全に動作
========================================================== */

/* Stop old experimental hamburger output */
#nktsHamburgerButton,
#nktsHamburgerOverlay,
.nkts-hamburger-button,
.nkts-hamburger-overlay,
.nkts-v600-menu-toggle,
#nktsV600MenuOverlay {
  display: none !important;
}

/* Button */
.nkts-safe-menu-toggle {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  gap: 12px;
  min-width: 118px;
  height: 50px;
  padding: 0 20px;
  border: 1px solid rgba(15,31,61,.16);
  border-radius: var(--nkts-safe-button-radius, 999px);
  background: var(--nkts-safe-button-bg, #fff);
  color: var(--nkts-safe-button-color, #111827);
  font: inherit;
  font-size: 13px;
  font-weight: 900;
  letter-spacing: .16em;
  cursor: pointer;
  position: relative;
  z-index: 50;
  box-shadow: 0 12px 30px rgba(0,0,0,.14);
}

.nkts-safe-menu-bars {
  display: grid;
  gap: 4px;
  width: 20px;
}

.nkts-safe-menu-bars i {
  display: block;
  width: 20px;
  height: 2px;
  border-radius: 999px;
  background: currentColor;
}

.nkts-safe-menu-button-text {
  line-height: 1;
}

/* Base overlay */
.nkts-safe-menu-overlay {
  position: fixed !important;
  inset: 0 !important;
  width: 100vw !important;
  height: 100vh !important;
  min-height: 100dvh !important;
  z-index: 2147483200 !important;
  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
  transition: opacity .24s ease, visibility .24s ease !important;
  overflow: hidden !important;
}

.nkts-safe-menu-overlay.is-open {
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
}

body.nkts-safe-menu-open {
  overflow: hidden !important;
}

/* Premium */
.nkts-safe-premium-overlay {
  display: flex !important;
  align-items: center;
  justify-content: center;
  padding: clamp(22px, 4vw, 60px);
  background:
    radial-gradient(circle at 16% 100%, color-mix(in srgb, var(--nkts-safe-accent, #e11d2e) 34%, transparent), transparent 34%),
    linear-gradient(135deg, var(--nkts-safe-overlay-bg, #050914), #070b12 60%, #05070b) !important;
}

.nkts-safe-premium-shell {
  width: min(1280px, 100%);
  max-height: calc(100dvh - 64px);
  display: grid;
  grid-template-columns: minmax(260px, 34%) 1fr;
  gap: clamp(24px, 4vw, 56px);
  color: var(--nkts-safe-parent-color, #fff);
}

.nkts-safe-brand-panel {
  min-height: min(680px, calc(100dvh - 96px));
  padding: clamp(34px, 5vw, 72px) clamp(24px, 4vw, 52px);
  border-right: 1px solid var(--nkts-safe-line-color, rgba(255,255,255,.12));
  display: flex;
  flex-direction: column;
  justify-content: center;
  position: relative;
}

.nkts-safe-brand-panel::after {
  content: "";
  position: absolute;
  left: 8%;
  right: 16%;
  bottom: 12%;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--nkts-safe-accent, #e11d2e), transparent);
  box-shadow: 0 0 36px var(--nkts-safe-accent, #e11d2e);
}

.nkts-safe-brand-mark {
  color: var(--nkts-safe-parent-color, #fff);
  font-size: clamp(36px, 5vw, 64px);
  line-height: .92;
  letter-spacing: .06em;
  font-weight: 1000;
}

.nkts-safe-brand-mark::after {
  content: "";
  display: inline-block;
  width: .18em;
  height: .18em;
  margin-left: .08em;
  border-radius: 50%;
  background: var(--nkts-safe-accent, #e11d2e);
}

.nkts-safe-brand-sub {
  margin: 14px 0 0;
  color: var(--nkts-safe-sub-color, rgba(255,255,255,.72));
  font-size: 14px;
  letter-spacing: .08em;
  line-height: 1.5;
}

.nkts-safe-brand-copy {
  margin: clamp(50px, 8vw, 110px) 0 0;
  color: var(--nkts-safe-parent-color, #fff);
  font-size: clamp(24px, 3vw, 42px);
  line-height: 1.3;
  letter-spacing: .08em;
  font-weight: 500;
}

.nkts-safe-brand-lead {
  max-width: 420px;
  margin: 20px 0 0;
  color: var(--nkts-safe-sub-color, rgba(255,255,255,.72));
  font-size: 15px;
  line-height: 2;
  letter-spacing: .08em;
}

.nkts-safe-premium-main {
  padding: clamp(28px, 4vw, 56px) 0;
}

.nkts-safe-menu-heading {
  display: block !important;
  margin: 0 0 22px !important;
  color: var(--nkts-safe-heading-color, rgba(255,255,255,.86)) !important;
  text-align: center !important;
  font-size: var(--nkts-safe-heading-size, 12px) !important;
  font-weight: 900 !important;
  letter-spacing: .42em !important;
}

.nkts-safe-menu-heading::after {
  content: "";
  display: block;
  width: 44px;
  height: 2px;
  margin: 12px auto 0;
  background: var(--nkts-safe-accent, #e11d2e);
  box-shadow: 0 0 18px var(--nkts-safe-accent, #e11d2e);
}

.nkts-safe-premium-list {
  display: grid !important;
  gap: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
  border-top: 1px solid var(--nkts-safe-line-color, rgba(255,255,255,.12));
}

.nkts-safe-premium-item {
  position: relative;
  margin: 0 !important;
  border-bottom: 1px solid var(--nkts-safe-line-color, rgba(255,255,255,.12));
}

.nkts-safe-parent-link {
  min-height: 68px;
  display: grid !important;
  grid-template-columns: 50px 48px minmax(0, 1fr) 30px;
  align-items: center;
  gap: 16px;
  padding: 0 clamp(16px, 3vw, 38px) !important;
  color: var(--nkts-safe-parent-color, #fff) !important;
  text-decoration: none !important;
  overflow: hidden;
  transform-origin: center;
  transition: background .22s ease, transform .22s ease;
}

.nkts-safe-parent-link:hover {
  background: var(--nkts-safe-hover-bg, rgba(225,29,46,.14)) !important;
}

.nkts-safe-number {
  color: var(--nkts-safe-accent, #e11d2e) !important;
  font-size: 13px;
  font-weight: 900;
  letter-spacing: .08em;
  font-variant-numeric: tabular-nums;
}

.nkts-safe-icon {
  color: var(--nkts-safe-parent-color, #fff) !important;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  opacity: .9;
}

.nkts-safe-menu-svg {
  width: 23px;
  height: 23px;
}

.nkts-safe-title {
  min-width: 0;
  display: block;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  color: var(--nkts-safe-parent-color, #fff) !important;
  font-size: var(--nkts-safe-parent-size, 24px) !important;
  line-height: 1.1 !important;
  font-weight: 900 !important;
  letter-spacing: .05em;
}

.nkts-safe-arrow {
  color: var(--nkts-safe-accent, #e11d2e) !important;
  font-size: 28px;
  line-height: 1;
  text-align: right;
}

.nkts-safe-submenu {
  list-style: none !important;
  margin: -2px 0 12px !important;
  padding: 10px clamp(16px, 3vw, 38px) 12px calc(clamp(16px, 3vw, 38px) + 112px) !important;
  background: color-mix(in srgb, var(--nkts-safe-panel-bg, #10131a) 68%, transparent) !important;
  border-top: 1px solid color-mix(in srgb, var(--nkts-safe-line-color, rgba(255,255,255,.12)) 60%, transparent);
  position: relative;
}

.nkts-safe-submenu::before {
  content: "";
  position: absolute;
  left: calc(clamp(16px, 3vw, 38px) + 82px);
  top: 13px;
  bottom: 13px;
  border-left: 1px dotted var(--nkts-safe-line-color, rgba(255,255,255,.22));
}

.nkts-safe-submenu li {
  margin: 0 !important;
}

.nkts-safe-submenu a {
  min-height: 32px;
  display: grid !important;
  grid-template-columns: 12px minmax(0, 1fr) 20px;
  align-items: center;
  gap: 12px;
  color: var(--nkts-safe-sub-color, rgba(255,255,255,.72)) !important;
  text-decoration: none !important;
  font-size: var(--nkts-safe-sub-size, 13px) !important;
  line-height: 1.25 !important;
  letter-spacing: .05em;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  transition: background .2s ease, color .2s ease, transform .2s ease;
}

.nkts-safe-submenu a:hover {
  background: var(--nkts-safe-hover-bg, rgba(225,29,46,.14)) !important;
}

.nkts-safe-submenu a span {
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: currentColor;
  opacity: .55;
}

.nkts-safe-submenu a em {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  font-style: normal;
}

.nkts-safe-submenu a b {
  color: var(--nkts-safe-accent, #e11d2e);
  font-weight: 400;
  text-align: right;
}

.nkts-safe-cta {
  width: min(720px, calc(100% - 76px)) !important;
  min-height: 56px !important;
  margin: 24px auto 0 !important;
  display: flex !important;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--nkts-safe-accent, #e11d2e) !important;
  border-radius: 10px !important;
  background: var(--nkts-safe-cta-bg, rgba(225,29,46,.14)) !important;
  color: var(--nkts-safe-cta-color, #fff) !important;
  text-decoration: none !important;
  font-weight: 900 !important;
  box-shadow: 0 0 32px color-mix(in srgb, var(--nkts-safe-accent, #e11d2e) 18%, transparent) !important;
}

.nkts-safe-premium-close {
  position: fixed !important;
  top: max(16px, env(safe-area-inset-top)) !important;
  right: max(16px, env(safe-area-inset-right)) !important;
  z-index: 2147483201 !important;
  width: 48px !important;
  height: 48px !important;
  border: 1px solid rgba(255,255,255,.2) !important;
  border-radius: 50% !important;
  background: rgba(255,255,255,.08) !important;
  color: #fff !important;
  font-size: 30px !important;
  line-height: 1 !important;
  cursor: pointer !important;
}

/* Stage Safe */
.nkts-safe-stage-overlay {
  background: transparent !important;
}

.nkts-safe-stage-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.56);
  backdrop-filter: blur(4px);
}

.nkts-safe-stage-panel {
  position: absolute;
  top: 0;
  bottom: 0;
  width: min(720px, 92vw);
  max-width: 100%;
  overflow-y: auto;
  padding: clamp(24px, 4vw, 48px);
  background: var(--nkts-safe-overlay-bg, #2f2f31);
  color: var(--nkts-safe-parent-color, #fff);
  box-shadow: 0 32px 90px rgba(0,0,0,.42);
  transform: translateX(102%);
  transition: transform .38s cubic-bezier(.2,.8,.2,1);
}

body.nkts-safe-stage-left .nkts-safe-stage-panel {
  left: 0;
  right: auto;
  transform: translateX(-102%);
}

body.nkts-safe-stage-right .nkts-safe-stage-panel {
  right: 0;
  left: auto;
}

body.nkts-safe-stage-center .nkts-safe-stage-panel {
  left: 50%;
  right: auto;
  top: 50%;
  bottom: auto;
  height: min(820px, calc(100dvh - 48px));
  border-radius: 18px;
  transform: translate(-50%, -45%) scale(.96);
}

.nkts-safe-stage-overlay.is-open .nkts-safe-stage-panel {
  transform: translateX(0);
}

body.nkts-safe-stage-center .nkts-safe-stage-overlay.is-open .nkts-safe-stage-panel {
  transform: translate(-50%, -50%) scale(1);
}

.nkts-safe-stage-close {
  position: absolute !important;
  top: 18px !important;
  right: 18px !important;
  width: 48px !important;
  height: 48px !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  color: var(--nkts-safe-parent-color, #fff) !important;
  box-shadow: none !important;
}

.nkts-safe-stage-close span {
  position: absolute;
  top: 23px;
  left: 8px;
  width: 32px;
  height: 2px;
  background: currentColor;
}

.nkts-safe-stage-close span:first-child { transform: rotate(45deg); }
.nkts-safe-stage-close span:last-child { transform: rotate(-45deg); }

.nkts-safe-stage-header {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 18px;
  align-items: start;
  padding: 24px 56px 24px 0;
}

.nkts-safe-stage-company {
  margin: 0 0 8px;
  color: var(--nkts-safe-parent-color, #fff);
  font-size: clamp(16px, 2vw, 21px);
  font-weight: 800;
}

.nkts-safe-stage-phone {
  margin: 0;
  color: var(--nkts-safe-parent-color, #fff);
  font-size: clamp(20px, 3vw, 28px);
  font-weight: 300;
}

.nkts-safe-stage-contact {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 0 18px;
  border-radius: 999px;
  border: 1px solid var(--nkts-safe-line-color, rgba(255,255,255,.18));
  color: var(--nkts-safe-parent-color, #fff) !important;
  text-decoration: none;
  font-weight: 800;
  white-space: nowrap;
}

.nkts-safe-stage-card {
  background: var(--nkts-safe-panel-bg, #10131a);
  border-radius: 10px;
  padding: 24px 18px 26px;
}

.nkts-safe-stage-list,
.nkts-safe-stage-submenu {
  list-style: none;
  margin: 0;
  padding: 0;
}

.nkts-safe-stage-item {
  border-top: 1px solid var(--nkts-safe-line-color, rgba(255,255,255,.12));
}

.nkts-safe-stage-item:last-child {
  border-bottom: 1px solid var(--nkts-safe-line-color, rgba(255,255,255,.12));
}

.nkts-safe-stage-link {
  min-height: 68px;
  display: grid;
  grid-template-columns: minmax(92px, 142px) minmax(0, 1fr) 20px;
  gap: 14px;
  align-items: center;
  padding: 14px 8px;
  text-decoration: none;
  color: var(--nkts-safe-parent-color, #fff) !important;
}

.nkts-safe-stage-en {
  font-family: Georgia, 'Times New Roman', serif;
  font-size: var(--nkts-safe-parent-size, 24px);
  line-height: 1;
  color: var(--nkts-safe-parent-color, #fff);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.nkts-safe-stage-ja {
  color: var(--nkts-safe-sub-color, rgba(255,255,255,.72));
  font-size: max(12px, calc(var(--nkts-safe-parent-size, 24px) * .48));
  font-weight: 700;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.nkts-safe-stage-arrow {
  color: var(--nkts-safe-accent, #e11d2e);
  font-size: 24px;
  text-align: right;
}

.nkts-safe-stage-submenu {
  margin: -4px 0 14px;
  padding: 0 8px 14px min(160px, 34%);
  display: grid;
  gap: 6px;
}

.nkts-safe-stage-submenu a {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 18px;
  align-items: center;
  color: var(--nkts-safe-sub-color, rgba(255,255,255,.72)) !important;
  text-decoration: none;
  font-size: var(--nkts-safe-sub-size, 13px);
  line-height: 1.45;
  padding: 7px 0;
  border-top: 1px dashed var(--nkts-safe-line-color, rgba(255,255,255,.12));
}

.nkts-safe-stage-footer {
  padding-top: 18px;
  color: var(--nkts-safe-sub-color, rgba(255,255,255,.72));
  font-size: 12px;
  text-align: right;
}

/* Puyo animation */
@keyframes nktsSafePuyo {
  0% { transform: scale(1, 1); }
  28% { transform: scale(1.035, .94); }
  52% { transform: scale(.975, 1.035); }
  74% { transform: scale(1.012, .988); }
  100% { transform: scale(1, 1); }
}

body.nkts-safe-puyo-on .nkts-safe-menu-toggle:hover,
body.nkts-safe-puyo-on #nktsSafeMenuOverlay a:hover {
  animation: nktsSafePuyo .56s cubic-bezier(.2,1.35,.3,1) both !important;
}

/* Mobile */
@media (max-width: 900px) {
  .nkts-safe-premium-overlay {
    align-items: flex-start;
    padding: calc(70px + env(safe-area-inset-top)) 16px 24px;
    overflow-y: auto !important;
  }

  .nkts-safe-premium-shell {
    display: block;
    max-height: none;
  }

  .nkts-safe-brand-panel {
    display: none;
  }

  .nkts-safe-premium-main {
    padding: 0;
  }

  .nkts-safe-parent-link {
    min-height: 58px;
    grid-template-columns: 38px 34px minmax(0,1fr) 22px;
    gap: 10px;
    padding: 0 14px !important;
  }

  .nkts-safe-title {
    font-size: clamp(17px, 4.7vw, 22px) !important;
  }

  .nkts-safe-menu-svg {
    width: 20px;
    height: 20px;
  }

  .nkts-safe-submenu {
    padding: 8px 14px 10px 78px !important;
  }

  .nkts-safe-submenu::before {
    left: 60px;
  }

  .nkts-safe-submenu a {
    font-size: 12px !important;
  }

  .nkts-safe-cta {
    width: calc(100% - 28px) !important;
  }

  .nkts-safe-stage-panel {
    width: 100vw;
    padding: 22px 16px 28px;
  }

  body.nkts-safe-stage-center .nkts-safe-stage-panel {
    width: calc(100vw - 24px);
    height: calc(100dvh - 24px);
  }

  .nkts-safe-stage-header {
    display: block;
    padding: 56px 0 20px;
  }

  .nkts-safe-stage-contact {
    width: 100%;
    margin-top: 14px;
  }

  .nkts-safe-stage-card {
    padding: 18px 14px 20px;
  }

  .nkts-safe-stage-link {
    min-height: 58px;
    grid-template-columns: minmax(82px, 118px) minmax(0,1fr) 18px;
    gap: 10px;
  }

  .nkts-safe-stage-en {
    font-size: clamp(18px, 5.4vw, 22px);
  }

  .nkts-safe-stage-ja {
    font-size: 12px;
  }

  .nkts-safe-stage-submenu {
    padding-left: 84px;
  }
}


/* ==========================================================
   NKTS V6.2.1 Hero video cover guard
   動画再生前に赤い線・デフォルト背景が一瞬映る問題をカバーで遮断
========================================================== */

body.nkts-video-cover-enabled .one-screen-stage,
body.nkts-video-cover-enabled .hero,
body.nkts-video-cover-enabled .front-hero {
  position: relative !important;
}

body.nkts-video-cover-enabled .one-screen-stage::after,
body.nkts-video-cover-enabled .hero::after,
body.nkts-video-cover-enabled .front-hero::after {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  z-index: 999999 !important;
  display: block !important;
  background: var(--nkts-v621-video-cover-bg, #000) !important;
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: none !important;
  transition: opacity var(--nkts-v621-video-cover-fade, 420ms) ease, visibility var(--nkts-v621-video-cover-fade, 420ms) ease !important;
}

body.nkts-video-cover-ready .one-screen-stage::after,
body.nkts-video-cover-ready .hero::after,
body.nkts-video-cover-ready .front-hero::after {
  opacity: 0 !important;
  visibility: hidden !important;
}

body.nkts-video-cover-white {
  --nkts-v621-video-cover-bg: #ffffff;
}

body.nkts-video-cover-black {
  --nkts-v621-video-cover-bg: #000000;
}

body.nkts-video-cover-brand {
  --nkts-v621-video-cover-bg: #050914;
}


/* ==========================================================
   NKTS V6.2.2 Section background image controls
   SERVICES / WHY / CTA 背景画像設定
========================================================== */

.nkts-section-bg {
  position: relative;
  overflow: hidden;
}

.nkts-section-bg > .container {
  position: relative;
  z-index: 1;
}


/* ==========================================================
   NKTS V6.2.3 Safe Core only / Customizable Premium brand panel
========================================================== */

/* 念押し：旧V6ハンバーガーは表示しない */
#nktsV600MenuOverlay,
.nkts-v600-menu-toggle {
  display: none !important;
}

.nkts-safe-brand-panel {
  transition: background .18s ease, color .18s ease;
}

.nkts-safe-brand-mark,
.nkts-safe-brand-sub,
.nkts-safe-brand-copy,
.nkts-safe-brand-lead {
  transition: color .18s ease, font-size .18s ease;
  word-break: keep-all;
  overflow-wrap: anywhere;
}

.nkts-safe-brand-sub,
.nkts-safe-brand-copy,
.nkts-safe-brand-lead {
  white-space: normal;
}


/* ==========================================================
   NKTS V6.2.4 Remove free buttons + header default layout
========================================================== */

/* 自由設置ボタンは不具合原因になるため完全停止 */
.nkts-free-buttons,
.nkts-free-button,
.nkts-free-button-link {
  display: none !important;
  visibility: hidden !important;
  pointer-events: none !important;
}

/* ヘッダーは「左：ロゴ・会社名」「右：MENU」を標準に固定 */
.site-header .header-inner,
.site-header .container.header-inner,
.header-inner {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 16px !important;
}

.site-header .brand,
.site-header .nkts-brand-position-left,
.site-header .nkts-brand-position-center,
.site-header .nkts-brand-position-right {
  margin-left: 0 !important;
  margin-right: auto !important;
  justify-self: flex-start !important;
  align-self: center !important;
  text-align: left !important;
}

.site-header .brand-text {
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  justify-content: center !important;
  text-align: left !important;
}

.site-header .nkts-hamburger-button,
.site-header .nkts-menu-button,
.site-header .nav-toggle,
.site-header .nkts-safe-hamburger-button {
  margin-left: auto !important;
  margin-right: 0 !important;
  justify-self: flex-end !important;
}


/* ==========================================================
   NKTS V6.2.5 Header layout + smartphone font controls
========================================================== */

.site-header .header-inner,
.site-header .container.header-inner {
  display: flex !important;
  align-items: center !important;
  gap: 16px !important;
  position: relative !important;
}

.site-header .brand {
  display: inline-flex !important;
  align-items: center !important;
  min-width: 0;
}

.site-header .brand-text {
  display: flex !important;
  flex-direction: column !important;
  min-width: 0;
}

@media (max-width: 782px) {
  .site-header .brand {
    min-width: 0 !important;
    max-width: calc(100% - 92px) !important;
  }

  .site-header .brand-text strong,
  .site-header .brand-text small {
    max-width: 100% !important;
    white-space: normal !important;
    overflow-wrap: anywhere !important;
    word-break: keep-all !important;
  }
}


/* ==========================================================
   NKTS V6.2.6 Unified Header static fallback
========================================================== */

.site-header .header-inner,
.site-header .container.header-inner {
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 14px !important;
  min-width: 0 !important;
}

.site-header .brand.nkts-brand-v626 {
  display: contents !important;
}

.site-header .brand-logo,
.site-header .nkts-brand-logo-v626,
.site-header .brand-text,
.site-header .nkts-brand-text-v626,
.site-header .nkts-safe-menu-toggle {
  min-width: 0;
}

.site-header .brand-text,
.site-header .nkts-brand-text-v626 {
  display: flex !important;
  flex-direction: column !important;
}

.site-header .brand-text strong,
.site-header .brand-text small {
  white-space: normal !important;
  overflow-wrap: anywhere !important;
  word-break: keep-all !important;
}

@media (max-width: 782px) {
  .site-header .header-inner,
  .site-header .container.header-inner {
    gap: 8px !important;
    flex-wrap: nowrap !important;
  }
}


/* ==========================================================
   NKTS V6.2.7 Hero responsive font fallback
========================================================== */

.hero .hero-title,
.hero h1,
.nkts-hero-title,
.top-hero h1 {
  line-height: 1.08;
}

.hero .hero-lead,
.hero .hero-subtitle,
.hero p.hero-lead,
.nkts-hero-lead,
.top-hero .hero-lead {
  line-height: 1.9;
}

@media (max-width: 782px) {
  .hero .hero-title,
  .hero h1,
  .nkts-hero-title,
  .top-hero h1 {
    line-height: 1.12;
  }

  .hero .hero-lead,
  .hero .hero-subtitle,
  .hero p.hero-lead,
  .nkts-hero-lead,
  .top-hero .hero-lead {
    line-height: 1.8;
  }
}


/* ==========================================================
   NKTS V6.2.8 Footer Navigation reliable fallback
========================================================== */
.footer-nav-list-v628 {
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

.footer-nav-list-v628 li {
  margin: 0 !important;
  padding: 0 !important;
}

.footer-nav-link-v628 {
  display: grid !important;
  grid-template-columns: 34px minmax(0, 1fr) 18px !important;
  align-items: center !important;
  gap: 10px !important;
  text-decoration: none !important;
}

.footer-nav-label-v628 {
  white-space: normal !important;
  word-break: keep-all !important;
  overflow-wrap: anywhere !important;
}


/* ==========================================================
   NKTS V6.2.9 Final Header Grid Fallback
========================================================== */
.site-header.nkts-header-v629 .header-inner.nkts-header-grid-v629 {
  display: grid !important;
  grid-template-columns: minmax(0,1fr) auto minmax(0,1fr) !important;
  align-items: center !important;
  gap: 12px !important;
  justify-content: initial !important;
}

.site-header.nkts-header-v629 .nkts-header-logo-link-v629,
.site-header.nkts-header-v629 .nkts-brand-text-v629,
.site-header.nkts-header-v629 .nkts-header-menu-slot-v629 {
  min-width: 0 !important;
  position: relative !important;
}

.site-header.nkts-header-v629 .nkts-brand-text-v629 {
  text-decoration: none !important;
}

.site-header.nkts-header-v629 .nkts-edit-company-name,
.site-header.nkts-header-v629 .nkts-edit-company-en {
  white-space: normal !important;
  word-break: keep-all !important;
  overflow-wrap: anywhere !important;
}

.site-header.nkts-header-v629 .nkts-header-menu-slot-v629 .nkts-safe-menu-toggle,
.site-header.nkts-header-v629 .nkts-header-menu-slot-v629 .nkts-hamburger-button,
.site-header.nkts-header-v629 .nkts-header-menu-slot-v629 .nkts-safe-hamburger-button,
.site-header.nkts-header-v629 .nkts-header-menu-slot-v629 .nkts-menu-button,
.site-header.nkts-header-v629 .nkts-header-menu-slot-v629 .nav-toggle {
  position: relative !important;
  inset: auto !important;
  transform: none !important;
  margin: 0 !important;
}


/* ==========================================================
   NKTS V6.3.0 Settings Integrity Fallback
========================================================== */
.site-header.nkts-header-v629 .header-inner.nkts-header-grid-v629{
  display:grid!important;
  grid-template-columns:minmax(0,1fr) auto minmax(0,1fr)!important;
  align-items:center!important;
  justify-content:initial!important;
}
.nkts-free-buttons,.nkts-free-button,.nkts-free-button-link{display:none!important;visibility:hidden!important;pointer-events:none!important;}


/* ==========================================================
   NKTS V6.3.1 Reliable Header/Footer Fallback
========================================================== */
.site-header .nkts-edit-company-name,
.site-header .brand-text strong {
  white-space: normal !important;
  word-break: keep-all !important;
  overflow-wrap: anywhere !important;
}

.site-header .nkts-edit-company-en,
.site-header .brand-text small {
  white-space: normal !important;
  word-break: keep-all !important;
  overflow-wrap: anywhere !important;
}

.site-footer .nkts-footer-nav-force-list-v631 {
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

.site-footer .nkts-footer-nav-force-link-v631 {
  text-decoration: none !important;
}

.site-footer .nkts-footer-nav-force-label-v631 {
  white-space: normal !important;
  word-break: keep-all !important;
  overflow-wrap: anywhere !important;
}


/* ==========================================================
   NKTS V6.3.2 Hamburger Restore Fallback
========================================================== */
.nkts-safe-title,
.nkts-safe-stage-ja,
.nkts-safe-parent-link .nkts-safe-title {
  word-break: keep-all !important;
  overflow-wrap: anywhere !important;
}

.nkts-safe-submenu a,
.nkts-safe-stage-submenu a {
  word-break: keep-all !important;
  overflow-wrap: anywhere !important;
}


/* ==========================================================
   NKTS V6.3.4 Header Brand Block Fallback
========================================================== */
.site-header .header-inner.nkts-header-layout-v634 {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
}

.site-header .nkts-brand-block-v634 {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  text-decoration: none !important;
  min-width: 0 !important;
}

.site-header .nkts-brand-text-v634 {
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  text-align: left !important;
  min-width: 0 !important;
}

.site-header .nkts-header-menu-slot-v634 {
  margin-left: auto !important;
  flex: 0 0 auto !important;
}

.site-header .nkts-brand-text-v634 .nkts-edit-company-name,
.site-header .nkts-brand-text-v634 .nkts-edit-company-en {
  white-space: normal !important;
  word-break: keep-all !important;
  overflow-wrap: anywhere !important;
}


/* ==========================================================
   NKTS V6.3.5 Navigation 1-10 Reliable Fallback
========================================================== */
.nkts-v635-footer-nav-list {
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

.nkts-v635-footer-nav-link {
  text-decoration: none !important;
}

.nkts-v635-footer-nav-label {
  white-space: normal !important;
  word-break: keep-all !important;
  overflow-wrap: anywhere !important;
}


/* ==========================================================
   NKTS V6.3.6 Definitive Header Fallback
========================================================== */
.site-header.nkts-header-v636 .header-inner.nkts-header-inner-v636 {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
}

.site-header.nkts-header-v636 .nkts-brand-v636 {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  text-decoration: none !important;
  min-width: 0 !important;
  margin-right: auto !important;
}

.site-header.nkts-header-v636 .nkts-brand-namebox-v636 {
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  text-align: left !important;
  min-width: 0 !important;
}

.site-header.nkts-header-v636 .nkts-menu-slot-v636 {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: flex-end !important;
  margin-left: auto !important;
  flex: 0 0 auto !important;
}

.site-header.nkts-header-v636 .nkts-company-name-v636,
.site-header.nkts-header-v636 .nkts-company-en-v636 {
  white-space: normal !important;
  word-break: keep-all !important;
  overflow-wrap: anywhere !important;
}
