/* ===== セクション別スタイル（後半） ===== */

/* ヒーロー */
#hero{position:relative;width:100%;min-height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden}
#hero-canvas{position:fixed;inset:0;z-index:0;width:100vw;height:100vh;pointer-events:none;will-change:transform}
.hero-ov{position:absolute;inset:0;z-index:1;background:radial-gradient(ellipse at 50% 40%,transparent 20%,var(--bg-deep) 75%)}
.hero-c{position:relative;z-index:10;text-align:center;padding:calc(var(--nav-h) + 1rem) clamp(1rem,4vw,3rem) 2rem;max-width:960px}
.hero-tag{font-family:var(--font-en);font-size:clamp(.68rem,1vw,.88rem);color:var(--accent);letter-spacing:.3em;margin-bottom:1.2rem;border-right:2px solid var(--accent);white-space:nowrap;display:inline-block;padding-right:4px;animation:blink .6s step-end infinite alternate,heroFadeIn 1.5s ease 1s both}
@keyframes blink{50%{border-color:transparent}}@keyframes heroFadeIn{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}
.hero-h1{font-size:clamp(2rem,6vw,4.2rem);font-weight:900;line-height:1.25;margin-bottom:1rem}
.hero-sub{font-size:clamp(.88rem,1.5vw,1.15rem);color:var(--text-sub);margin-bottom:.5rem;line-height:1.7}
.hero-en{font-family:var(--font-en);font-size:clamp(.68rem,1vw,.82rem);color:var(--accent);letter-spacing:.1em;margin-bottom:2rem;opacity:.7}
.hero-btns{display:flex;gap:1rem;justify-content:center;align-items:center;flex-wrap:wrap;margin-bottom:2rem}
.hero-trust{display:flex;gap:clamp(1.5rem,3vw,3rem);justify-content:center;flex-wrap:wrap;margin-top:2rem;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.06)}
.hero-trust-item{text-align:center}
.hero-trust-item .t-num{font-family:var(--font-en);font-size:clamp(1.5rem,3vw,2.2rem);font-weight:900;color:#fff;text-shadow:0 0 20px rgba(0,212,255,.5),0 0 40px rgba(0,102,255,.3)}
.hero-trust-item .t-label{font-size:.7rem;color:rgba(255,255,255,.7);margin-top:.2rem}
.scroll-ind{position:absolute;bottom:1.5rem;left:50%;transform:translateX(-50%);z-index:10;text-align:center}
.scroll-ind span{display:block;font-family:var(--font-en);font-size:.6rem;letter-spacing:.2em;color:var(--text-dim);margin-bottom:.4rem}
.scroll-arr{width:16px;height:16px;border-right:2px solid var(--accent);border-bottom:2px solid var(--accent);transform:rotate(45deg);margin:0 auto;animation:bounce 2s infinite}
@keyframes bounce{0%,20%,50%,80%,100%{transform:rotate(45deg) translateY(0)}40%{transform:rotate(45deg) translateY(8px)}60%{transform:rotate(45deg) translateY(4px)}}

/* ソーシャルプルーフバー */
.sp-bar{background:var(--bg-sec);border-bottom:1px solid var(--border);padding:1rem clamp(1rem,5vw,5rem);overflow:hidden}
.sp-track{display:flex;gap:3rem;animation:marquee 30s linear infinite;width:max-content}
.sp-track:hover{animation-play-state:paused}
.sp-item{white-space:nowrap;font-size:.78rem;color:var(--text-dim);display:flex;align-items:center;gap:.5rem}
.sp-item i{color:var(--accent);font-size:.9rem}
@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* 数値実績 */
#numbers{background:var(--bg-sec)}
.num-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
.num-card{text-align:center;padding:clamp(1.5rem,2.5vw,2.5rem) 1rem;background:var(--glass);border:1px solid var(--border);border-radius:var(--radius);position:relative;overflow:hidden}
.num-card::before{content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);width:40%;height:2px;background:linear-gradient(90deg,transparent,var(--accent),transparent)}
.num-card .ic{font-size:1.8rem;color:var(--accent);margin-bottom:.8rem;filter:drop-shadow(0 0 8px rgba(0,212,255,.3))}
.num-card .n{font-family:var(--font-en);font-size:clamp(2rem,4vw,3rem);font-weight:900;color:var(--accent)}
.num-card .ns{font-size:clamp(.9rem,1.5vw,1.2rem);color:var(--accent)}
.num-card .nl{font-size:.82rem;color:var(--text-sub);margin-top:.4rem}
@media(max-width:767px){.num-grid{grid-template-columns:repeat(2,1fr)}}

/* 私たちについて */
#about{background:var(--bg-deep)}
.about-g{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,4vw,4rem);align-items:center}
.about-text h3{font-size:1.15rem;color:var(--accent);margin-bottom:.5rem;font-weight:700}
.about-text p{font-size:.92rem;line-height:1.8;color:var(--text-sub);margin-bottom:1.3rem}
.vtags{display:flex;gap:.7rem;flex-wrap:wrap;margin-top:.4rem}
.vtag{padding:.35rem .9rem;border:1px solid var(--border);border-radius:50px;font-size:.75rem;color:var(--accent);transition:all .3s}
.vtag:hover{background:rgba(0,212,255,.08);border-color:var(--accent)}
.kw-box{position:relative;min-height:340px}
.kw-box .gc{width:100%;height:100%;min-height:340px;position:relative;overflow:hidden}
.kw-f{position:absolute;font-family:var(--font-en);color:var(--accent);opacity:.5;animation:fkw 6s ease-in-out infinite;white-space:nowrap}
@keyframes fkw{0%,100%{transform:translateY(0) rotate(0)}33%{transform:translateY(-14px) rotate(1.5deg)}66%{transform:translateY(8px) rotate(-1deg)}}
@media(max-width:767px){.about-g{grid-template-columns:1fr}.kw-box{min-height:240px}}

/* メリット */
#advantage{background:var(--bg-sec)}
.adv-lay{display:grid;grid-template-columns:1fr 1fr;gap:2.5rem;align-items:start}
.adv-lay--full{grid-template-columns:1fr}
.roi-wrap{overflow-x:auto}
.roi-t{width:100%;border-collapse:collapse;font-size:clamp(.82rem,1vw,.92rem)}
.roi-t th,.roi-t td{padding:.85rem 1rem;text-align:left;border-bottom:1px solid var(--border)}
.roi-t thead th{background:rgba(0,102,255,.12);color:var(--accent);font-weight:700}
.roi-t tbody td{color:var(--text-sub);line-height:1.6}
.roi-t .hl{color:var(--accent);font-weight:700}
.roi-t .gold{color:var(--gold);font-weight:900}
.merit-g{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.mc{padding:1.1rem;cursor:default}
.mc .mi{font-size:1.4rem;color:var(--accent);margin-bottom:.5rem}
.mc h4{font-size:.88rem;margin-bottom:.35rem;font-weight:700}
.mc p{font-size:.78rem;color:var(--text-sub);line-height:1.6}
@media(max-width:767px){.adv-lay{grid-template-columns:1fr}.merit-g{grid-template-columns:1fr}}

/* 課題解決 */
#challenges{background:var(--bg-deep)}
.ch-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.ch-c{cursor:default;position:relative;overflow:hidden}
.ch-c::before{content:'';position:absolute;top:0;left:0;width:3px;height:100%;background:linear-gradient(180deg,var(--accent),var(--accent2));border-radius:3px 0 0 3px;opacity:0;transition:opacity .3s}
.ch-c:hover::before{opacity:1}
.ch-c .ch-i{font-size:1.6rem;color:var(--accent);margin-bottom:.7rem}
.ch-c .ch-p{font-size:clamp(.92rem,1.2vw,1.05rem);font-weight:700;margin-bottom:.5rem;line-height:1.5}
.ch-c .ch-s{font-size:clamp(.82rem,1vw,.92rem);color:var(--accent);line-height:1.65;padding-top:.5rem;border-top:1px solid var(--border)}
.ch-arr{margin:.3rem 0;color:var(--primary);font-size:.7rem}
@media(max-width:1023px){.ch-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:767px){.ch-grid{grid-template-columns:1fr}}

/* お客様の声 */
#testimonials{background:var(--bg-sec)}
.test-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.test-card{padding:clamp(1.5rem,2vw,2rem);position:relative}
.test-card .stars{color:var(--gold);font-size:.85rem;margin-bottom:.8rem;letter-spacing:.1em}
.test-card .quote{font-size:clamp(.88rem,1.1vw,.95rem);line-height:1.9;color:var(--text-sub);margin-bottom:1.2rem;font-style:italic;word-break:break-all;overflow-wrap:break-word}
.test-card .author{display:flex;align-items:center;gap:.8rem}
.test-card .av{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--accent2));display:flex;align-items:center;justify-content:center;font-size:.9rem;font-weight:700;color:#fff}
.test-card .ainfo .aname{font-size:.82rem;font-weight:700}
.test-card .ainfo .arole{font-size:.7rem;color:var(--text-dim)}
@media(max-width:767px){.test-grid{grid-template-columns:1fr}}

/* サービス */
#services{background:var(--bg-deep)}
.srv-tabs{display:flex;gap:.5rem;justify-content:center;flex-wrap:wrap;margin-bottom:2.2rem}
.srv-tab{padding:.55rem 1.1rem;border:1px solid var(--border);border-radius:50px;font-size:.78rem;cursor:pointer;color:var(--text-sub);transition:all .3s;min-height:44px;display:flex;align-items:center}
.srv-tab.on,.srv-tab:hover{border-color:var(--accent);color:var(--accent);background:rgba(0,212,255,.06);box-shadow:0 0 15px rgba(0,212,255,.08)}
.srv-panel{display:none}.srv-panel.on{display:block;animation:fu .45s ease}
@keyframes fu{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.srv-det{max-width:800px;margin:0 auto}
.srv-det h3{font-size:clamp(1.15rem,2.2vw,1.6rem);margin-bottom:.8rem;color:var(--accent)}
.srv-det .sd{font-size:clamp(.92rem,1.2vw,1rem);line-height:1.9;color:var(--text-sub);margin-bottom:1.2rem}
.srv-det h4{font-size:clamp(.95rem,1.2vw,1.05rem);margin-bottom:.7rem;color:var(--text-main)}
.srv-det ul{margin-bottom:1.2rem}
.srv-det ul li{position:relative;padding-left:1.1rem;margin-bottom:.45rem;font-size:clamp(.85rem,1vw,.92rem);color:var(--text-sub);line-height:1.75}
.srv-det ul li::before{content:'▸';position:absolute;left:0;color:var(--accent)}
.srv-det .snote{font-size:clamp(.82rem,1vw,.88rem);color:var(--text-sub);padding:1rem 1.2rem;background:rgba(0,212,255,.04);border-left:3px solid var(--accent);border-radius:0 8px 8px 0;margin-top:.8rem;line-height:1.8}
.rbadge{display:inline-flex;align-items:center;gap:.4rem;padding:.3rem .85rem;background:linear-gradient(135deg,rgba(255,215,0,.12),rgba(255,215,0,.04));border:1px solid var(--gold);border-radius:50px;font-size:.72rem;color:var(--gold);font-weight:700;animation:pb 2s ease infinite}
@keyframes pb{0%,100%{box-shadow:0 0 5px rgba(255,215,0,.15)}50%{box-shadow:0 0 20px rgba(255,215,0,.35)}}
.rbadge .rd{width:6px;height:6px;border-radius:50%;background:var(--gold);animation:pd 1.5s ease infinite}
@keyframes pd{0%,100%{opacity:1}50%{opacity:.3}}

/* 導入フロー */
#flow{background:var(--bg-sec)}
.flow-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:0;position:relative;overflow:visible}
.flow-step{text-align:center;padding:2rem 1rem;position:relative}
.flow-step::after{content:'';position:absolute;top:3rem;right:-.8rem;width:1.6rem;height:2px;background:linear-gradient(90deg,var(--accent),transparent);animation:fl 2s ease infinite}
.flow-step:last-child::after{display:none}
@keyframes fl{0%,100%{opacity:.25}50%{opacity:1}}
.fn{width:52px;height:52px;border-radius:50%;border:2px solid var(--accent);display:flex;align-items:center;justify-content:center;margin:0 auto 1rem;font-family:var(--font-en);font-weight:900;font-size:1.1rem;color:var(--accent);box-shadow:0 0 20px rgba(0,212,255,.12);transition:all .3s}
.flow-step:hover .fn{background:rgba(0,212,255,.1);box-shadow:0 0 30px rgba(0,212,255,.25)}
.flow-step h4{font-size:.9rem;margin-bottom:.4rem;font-weight:700}
.flow-step p{font-size:.78rem;color:var(--text-sub);line-height:1.55}
@media(max-width:767px){.flow-steps{grid-template-columns:1fr}.flow-step::after{top:auto;bottom:-.3rem;right:50%;width:2px;height:1.2rem;background:linear-gradient(180deg,var(--accent),transparent);transform:translateX(50%)}}

/* 代表者挨拶 */
#ceo{background:var(--bg-deep)}
.ceo-g{display:grid;grid-template-columns:280px 1fr;gap:clamp(2rem,4vw,3.5rem);align-items:start}
.ceo-ph{width:100%;aspect-ratio:3/4;border-radius:var(--radius);background:linear-gradient(135deg,var(--glass),rgba(0,102,255,.06));border:1px solid var(--border);display:flex;align-items:center;justify-content:center;overflow:hidden}
.ceo-img{width:100%;height:100%;object-fit:cover}
.ceo-nm{text-align:center;margin-top:.8rem}
.ceo-nm .t{font-size:.72rem;color:var(--text-dim)}
.ceo-nm .nm{font-size:1.15rem;font-weight:700;margin-top:.15rem}
.ceo-msg p{font-size:clamp(.82rem,1vw,.95rem);line-height:2.1;color:var(--text-sub);margin-bottom:.9rem}
.ceo-msg .sign{text-align:right;font-weight:700;color:var(--text-main);margin-top:1.5rem;font-size:1.05rem}
@media(max-width:767px){.ceo-g{grid-template-columns:1fr}.ceo-ph{max-width:220px;margin:0 auto}}

/* 会社概要 */
#company{background:var(--bg-sec)}
.co-g{display:grid;grid-template-columns:1fr 1fr;gap:2.5rem}
.co-t{width:100%}
.co-t tr{border-bottom:1px solid var(--border)}
.co-t th,.co-t td{padding:.85rem .7rem;text-align:left;font-size:.85rem;vertical-align:top}
.co-t th{color:var(--accent);font-weight:700;width:28%;white-space:nowrap}
.co-t td{color:var(--text-sub);line-height:1.6}
.map-w{border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);min-height:340px}
.map-w iframe{width:100%;height:100%;min-height:340px;border:0;filter:invert(.9) hue-rotate(180deg) brightness(.8) contrast(1.2)}
@media(max-width:767px){.co-g{grid-template-columns:1fr}}

/* お知らせ */
#news{background:var(--bg-deep)}
.news-list{max-width:780px;margin:0 auto}
.news-item{display:flex;align-items:flex-start;gap:1.3rem;padding:1.3rem 0;border-bottom:1px solid var(--border);transition:background .3s;padding-left:.5rem;border-radius:6px}
.news-item:hover{background:rgba(0,212,255,.02)}
.news-d{font-family:var(--font-en);font-size:.78rem;color:var(--text-dim);white-space:nowrap;padding-top:.15rem}
.nb{display:inline-block;padding:.12rem .55rem;border-radius:50px;font-size:.62rem;font-weight:700;margin-left:.4rem;white-space:nowrap}
.nb.imp{background:rgba(255,59,48,.15);color:#ff6b6b;border:1px solid rgba(255,59,48,.25)}
.nb.inf{background:rgba(0,212,255,.08);color:var(--accent);border:1px solid var(--border)}
.nb.pr{background:rgba(123,47,255,.12);color:#a855f7;border:1px solid rgba(123,47,255,.25)}
.news-tl{font-size:.88rem;line-height:1.55}
.news-more{text-align:center;margin-top:1.8rem}
@media(max-width:767px){.news-item{flex-direction:column;gap:.4rem}}

/* FAQ */
.faq-list{max-width:780px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--border);overflow:hidden}
.faq-q{padding:1.1rem 0;display:flex;justify-content:space-between;align-items:center;cursor:pointer;gap:1rem;min-height:48px}
.faq-q h4{font-size:.9rem;font-weight:700;line-height:1.45}
.faq-ic{font-size:1.2rem;color:var(--accent);transition:transform .3s;flex-shrink:0}
.faq-item.on .faq-ic{transform:rotate(45deg)}
.faq-a{height:0;overflow:hidden;transition:height .35s cubic-bezier(.23,1,.32,1)}
.faq-a p{padding:0 0 1.1rem;font-size:.82rem;color:var(--text-sub);line-height:1.8}

/* お問い合わせ */
#contact{background:var(--bg-deep);position:relative;overflow:hidden}
#contact::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 20% 50%,rgba(0,102,255,.06),transparent 50%),radial-gradient(circle at 80% 50%,rgba(123,47,255,.05),transparent 50%);pointer-events:none}
.contact-w{position:relative;z-index:1;max-width:680px;margin:0 auto}
.contact-sub{text-align:center;font-size:.92rem;color:var(--text-sub);margin-bottom:1.5rem;line-height:1.7}
.contact-badges{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-bottom:2rem}
.cb{display:flex;align-items:center;gap:.4rem;font-size:.75rem;color:var(--text-dim);background:var(--glass);border:1px solid var(--border);border-radius:50px;padding:.35rem .8rem}
.cb i{color:var(--accent);font-size:.7rem}
.fg{margin-bottom:1.1rem}
.fl{display:block;font-size:.82rem;color:var(--text-sub);margin-bottom:.35rem}
.fl .req{color:var(--red);font-size:.68rem;margin-left:.2rem}
.fi,.fsel,.fta{width:100%;padding:.75rem 1rem;border-radius:var(--radius-sm);background:rgba(255,255,255,.025);border:1px solid var(--border);color:var(--text-main);font-size:.88rem;transition:border-color .3s,box-shadow .3s}
.fi:focus,.fsel:focus,.fta:focus{border-color:var(--accent);box-shadow:0 0 18px rgba(0,212,255,.12)}
.fta{resize:vertical;min-height:110px}
.fsel{cursor:pointer}.fsel option{background:var(--bg-deep);color:var(--text-main)}
.ferr{font-size:.72rem;color:var(--red);margin-top:.25rem;display:none}.ferr.show{display:block}
.cbg{display:flex;flex-wrap:wrap;gap:.7rem;margin-top:.2rem}
.cbl{display:flex;align-items:center;gap:.35rem;font-size:.82rem;color:var(--text-sub);cursor:pointer;min-height:44px}
.cbl input[type="checkbox"]{width:18px;height:18px;accent-color:var(--accent);cursor:pointer}
.fcon{display:flex;align-items:flex-start;gap:.5rem;margin:1.3rem 0;font-size:.78rem;color:var(--text-sub)}
.fcon input{margin-top:.15rem;flex-shrink:0;width:18px;height:18px;accent-color:var(--accent)}
.btn-sub{width:100%;padding:1rem;border-radius:50px;font-weight:900;font-size:1rem;cursor:pointer;background:linear-gradient(135deg,var(--primary),var(--accent2));color:#fff;box-shadow:0 4px 35px rgba(0,102,255,.3);transition:all .35s;min-height:52px;position:relative;overflow:hidden}
.btn-sub:hover{box-shadow:0 8px 50px rgba(0,102,255,.5);transform:translateY(-2px)}
.btn-sub:disabled{opacity:.4;cursor:not-allowed;transform:none}
.btn-sub::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.12),transparent);opacity:0;transition:opacity .3s}.btn-sub:hover::after{opacity:1}
.form-micro{text-align:center;font-size:.7rem;color:var(--text-dim);margin-top:.6rem}
.f-success{display:none;text-align:center;padding:3rem 1rem}
.f-success.show{display:block}
.f-success i{font-size:3rem;color:var(--accent);margin-bottom:1rem}
.f-success h3{font-size:1.2rem;margin-bottom:.7rem}
.f-success p{color:var(--text-sub);font-size:.9rem}

/* フッター */
.footer{background:#010510;padding:clamp(3rem,5vw,4.5rem) clamp(1rem,5vw,4rem) 1.5rem}
.ft-g{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:2.5rem;margin-bottom:2.5rem}
.ft-brand .ft-logo{font-family:var(--font-en);font-weight:900;font-size:1.4rem;margin-bottom:.8rem}
.ft-brand p{font-size:.75rem;color:var(--text-dim);line-height:1.7;margin-bottom:.8rem}
.ft-soc{display:flex;gap:.8rem}
.ft-soc a{width:38px;height:38px;border-radius:50%;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--text-dim);transition:all .3s;font-size:.85rem}
.ft-soc a:hover{border-color:var(--accent);color:var(--accent);box-shadow:0 0 12px rgba(0,212,255,.15)}
.ft-col h4{font-size:.78rem;color:var(--accent);margin-bottom:.8rem;letter-spacing:.1em;font-weight:700}
.ft-col a{display:block;font-size:.75rem;color:var(--text-dim);padding:.25rem 0;transition:color .3s}
.ft-col a:hover{color:var(--accent)}
.ft-bot{border-top:1px solid rgba(255,255,255,.04);padding-top:1.2rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.8rem}
.ft-bot p{font-size:.65rem;color:var(--text-dim)}
.ft-bot-links{display:flex;gap:1.3rem}
.ft-bot-links a{font-size:.65rem;color:var(--text-dim);transition:color .3s}
.ft-bot-links a:hover{color:var(--accent)}
@media(max-width:767px){.ft-g{grid-template-columns:1fr}.ft-bot{flex-direction:column;text-align:center}}

/* 固定CTA・モーダル */
.fix-cta{position:fixed;bottom:1.2rem;right:1.2rem;z-index:9999;padding:.7rem 1.3rem;border-radius:50px;background:linear-gradient(135deg,var(--primary),var(--accent2));color:#fff;font-size:.78rem;font-weight:700;box-shadow:0 4px 30px rgba(0,102,255,.4);cursor:pointer;display:flex;align-items:center;gap:.5rem;opacity:0;transform:translateY(20px);pointer-events:none;transition:opacity .4s,transform .4s;min-height:44px}
.fix-cta.vis{opacity:1;transform:translateY(0);pointer-events:auto}
.fix-cta .pd{width:7px;height:7px;border-radius:50%;background:var(--gold);animation:pd 1.5s ease infinite}
.modal-ov{position:fixed;inset:0;background:rgba(2,8,24,.85);backdrop-filter:blur(8px);z-index:100002;display:none;align-items:center;justify-content:center;padding:1rem}
.modal-ov.show{display:flex}
.modal-box{background:var(--bg-sec);border:1px solid var(--border2);border-radius:20px;padding:clamp(2rem,4vw,3rem);max-width:520px;width:100%;position:relative;text-align:center;box-shadow:0 20px 80px rgba(0,60,255,.15)}
.modal-close{position:absolute;top:1rem;right:1rem;width:36px;height:36px;border-radius:50%;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-dim);transition:all .3s;font-size:1rem}
.modal-close:hover{border-color:var(--accent);color:var(--accent)}
.modal-box h3{font-size:clamp(1.1rem,2.5vw,1.5rem);font-weight:900;margin-bottom:.5rem}
.modal-box p{font-size:.88rem;color:var(--text-sub);line-height:1.7;margin-bottom:1.5rem}
.modal-box .urgency{display:inline-flex;align-items:center;gap:.4rem;padding:.35rem .9rem;background:rgba(255,71,87,.1);border:1px solid rgba(255,71,87,.25);border-radius:50px;font-size:.75rem;color:var(--red);font-weight:700;margin-bottom:1rem}
.modal-box .urgency .ud{width:6px;height:6px;border-radius:50%;background:var(--red);animation:pd 1s ease infinite}

/* アクセシビリティ */
*:focus-visible{outline:2px solid var(--accent);outline-offset:3px}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.hero-tag{width:auto;border-right:none}.sp-track{animation:none}}

/* ===== サービスタイルグリッド ===== */
.srv-tile-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.srv-tile{display:flex;flex-direction:column;padding:clamp(1.5rem,2.5vw,2.2rem);position:relative;text-decoration:none;color:inherit;cursor:pointer;transition:transform .35s cubic-bezier(.23,1,.32,1),box-shadow .35s,border-color .35s}
.srv-tile:hover{transform:translateY(-8px);box-shadow:0 20px 60px rgba(0,60,255,.12),0 0 40px rgba(0,212,255,.08);border-color:var(--accent)}
.srv-tile-icon{font-size:2.2rem;color:var(--accent);margin-bottom:1rem;filter:drop-shadow(0 0 12px rgba(0,212,255,.3));transition:transform .3s}
.srv-tile:hover .srv-tile-icon{transform:scale(1.15)}
.srv-tile h3{font-size:clamp(1rem,1.4vw,1.2rem);font-weight:900;margin-bottom:.7rem;line-height:1.35}
.srv-tile p{font-size:clamp(.85rem,1vw,.95rem);color:var(--text-sub);line-height:1.8;margin-bottom:1rem;flex:1}
.srv-tile-tags{display:flex;gap:.4rem;flex-wrap:wrap;margin-bottom:1rem;list-style:none}
.srv-tile-tags li{padding:.2rem .6rem;border:1px solid var(--border);border-radius:50px;font-size:.65rem;color:var(--accent);white-space:nowrap;transition:all .3s}
.srv-tile:hover .srv-tile-tags li{border-color:rgba(0,212,255,.3);background:rgba(0,212,255,.04)}
.srv-tile-link{font-size:.78rem;font-weight:700;color:var(--accent);display:flex;align-items:center;gap:.4rem;margin-top:auto;transition:gap .3s}
.srv-tile:hover .srv-tile-link{gap:.7rem}
.srv-tile-badge{position:absolute;top:1rem;right:1rem}
.srv-tile--premium{border-color:rgba(255,215,0,.2);background:linear-gradient(135deg,rgba(255,215,0,.03),rgba(123,47,255,.03))}
.srv-tile--premium:hover{border-color:var(--gold);box-shadow:0 20px 60px rgba(255,215,0,.1),0 0 40px rgba(255,215,0,.06)}
.srv-tile--premium .srv-tile-icon{color:var(--gold);filter:drop-shadow(0 0 12px rgba(255,215,0,.3))}
@media(max-width:1023px){.srv-tile-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:767px){.srv-tile-grid{grid-template-columns:1fr}}

/* ===== CEO ネームプレート（写真なし版） ===== */
.ceo-g--nophoto{grid-template-columns:1fr;max-width:800px;margin:0 auto}
.ceo-nameplate{display:flex;align-items:center;gap:1.5rem;margin-bottom:2rem;padding:1.5rem 2rem;background:linear-gradient(135deg,rgba(0,212,255,.05),rgba(123,47,255,.03));border:1px solid var(--border);border-radius:var(--radius)}
.ceo-icon-wrap{font-size:2.5rem;color:var(--accent);opacity:.6}
.ceo-nameplate .ceo-nm{text-align:left}
.ceo-nameplate .nm{font-size:1.5rem}
.ceo-nameplate .nm-en{font-family:var(--font-en);font-size:.75rem;color:var(--text-dim);letter-spacing:.1em;margin-top:.2rem}

/* ===== 導入フロー見切れ修正 ===== */
.flow-step{padding:clamp(1.5rem,.8vw,2rem) 1rem;overflow:visible}
.fn{width:clamp(42px,4vw,52px);height:clamp(42px,4vw,52px);font-size:clamp(.9rem,1.2vw,1.1rem)}

/* ===== お客様の声グリッド拡張 ===== */
.test-grid{grid-template-columns:repeat(3,1fr)}
@media(max-width:1023px){.test-grid{grid-template-columns:repeat(2,1fr)}}

/* ===== ロゴ画像 ===== */
.n-logo-img{height:60px;width:auto;object-fit:contain;filter:brightness(1.1);background:transparent;mix-blend-mode:screen}

/* ===== ダッシュボード画像 ===== */
.adv-visual{margin-bottom:2rem;text-align:center}
.adv-dashboard-img{width:100%;max-width:900px;border-radius:var(--radius);border:1px solid var(--border);box-shadow:0 20px 60px rgba(0,60,255,.12)}

/* ===== KPIストリップ ===== */
.kpi-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;margin:2rem 0}
.kpi-item{text-align:center;padding:1.5rem 1rem}
.kpi-num{font-family:var(--font-en);font-size:clamp(2rem,4vw,3rem);font-weight:900;background:linear-gradient(135deg,var(--accent),var(--accent2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;line-height:1.1}
.kpi-unit{font-size:.5em;font-weight:700}
.kpi-label{font-size:.75rem;color:var(--text-sub);margin-top:.3rem}
@media(max-width:767px){.kpi-strip{grid-template-columns:repeat(2,1fr)}}

/* ===== テスティモニアルスライダー ===== */
.test-slider-wrap{position:relative;display:flex;align-items:center;gap:1rem}
.test-slider{display:flex;overflow:hidden;scroll-snap-type:x mandatory;scroll-behavior:smooth;gap:1.5rem;flex:1}
.test-slide{min-width:calc(33.333% - 1rem);max-width:calc(33.333% - 1rem);scroll-snap-align:start;flex-shrink:0;overflow:hidden}
.test-slide .test-card{height:100%;overflow:hidden}
.test-arrow{position:relative;width:44px;height:44px;border-radius:50%;background:var(--glass2);border:1px solid var(--border);color:var(--text-main);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s;flex-shrink:0}
.test-arrow:hover{background:var(--primary);border-color:var(--primary)}
.test-dots{display:flex;justify-content:center;gap:.5rem;margin-top:1.2rem}
.test-dot{width:8px;height:8px;border-radius:50%;background:var(--glass2);border:1px solid var(--border);cursor:pointer;transition:all .3s}
.test-dot.active{background:var(--accent);border-color:var(--accent);width:24px;border-radius:4px}
@media(max-width:1023px){.test-slide{min-width:calc(50% - .75rem)}}
@media(max-width:767px){.test-slide{min-width:100%}}

/* ===== CEO 画像付きレイアウト ===== */
.ceo-g--withimg{display:grid;grid-template-columns:1fr 1fr;gap:2.5rem;align-items:start}
.ceo-left{display:flex;flex-direction:column;gap:1rem}
.ceo-office-img,.ceo-team-img{width:100%;border-radius:var(--radius);border:1px solid var(--border);object-fit:cover}
.ceo-office-img{height:240px}
.ceo-team-img{height:180px;opacity:.85}
.ceo-right .ceo-nameplate{margin-bottom:1.5rem}
.ceo-right .ceo-msg p{font-size:.88rem;line-height:1.9;margin-bottom:.8rem}
@media(max-width:767px){.ceo-g--withimg{grid-template-columns:1fr}.ceo-left{order:2}.ceo-right{order:1}}

/* ===== ニュース + FAQ 横並び ===== */
.news-faq-grid{display:grid;grid-template-columns:1fr 1fr;gap:2.5rem}
.news-col,.faq-col{min-width:0}
@media(max-width:767px){.news-faq-grid{grid-template-columns:1fr}}

/* ===== 問い合わせ 2カラム ===== */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:2.5rem;align-items:start}
.contact-benefits{position:sticky;top:calc(var(--nav-h) + 2rem)}
@media(max-width:767px){.contact-grid{grid-template-columns:1fr}.contact-benefits{position:static}}

/* ===== ROI表 tfoot ===== */
.roi-t tfoot td{border-top:2px solid var(--accent);padding-top:.8rem;font-size:.95rem}

/* ===== サービスCTAリンク強化 ===== */
.srv-tile-link--cta{display:flex;flex-direction:column;gap:.25rem;padding:.8rem 1rem;margin:0 -1rem -1rem;background:linear-gradient(135deg,rgba(0,102,255,.08),rgba(0,212,255,.04));border-radius:0 0 var(--radius) var(--radius);border-top:1px solid var(--border);transition:all .35s}
.srv-tile:hover .srv-tile-link--cta{background:linear-gradient(135deg,rgba(0,102,255,.15),rgba(0,212,255,.08))}
.srv-tile-link-main{font-size:.82rem;font-weight:900;color:var(--accent);display:flex;align-items:center;gap:.4rem}
.srv-tile-link-sub{font-size:.68rem;color:var(--text-dim);line-height:1.4;display:block}
.srv-tile--premium .srv-tile-link--cta{background:linear-gradient(135deg,rgba(255,215,0,.08),rgba(255,215,0,.03))}
.srv-tile--premium:hover .srv-tile-link--cta{background:linear-gradient(135deg,rgba(255,215,0,.15),rgba(255,215,0,.06))}
.srv-tile--premium .srv-tile-link-main{color:var(--gold)}

/* ===== レスポンシブ改行クラス ===== */
.sp-br{display:none}
.pc-br{display:inline}
@media(max-width:767px){
.sp-br{display:inline}
.pc-br{display:none}
}

/* ===== CEO 写真付きレイアウト ===== */
.ceo-g--withphoto{display:grid;grid-template-columns:280px 1fr;gap:clamp(2rem,4vw,3.5rem);align-items:start}
.ceo-photo-col{text-align:center}
.ceo-nm .nm-en{font-family:var(--font-en);font-size:.72rem;color:var(--text-dim);letter-spacing:.08em;margin-top:.15rem}
@media(max-width:767px){
.ceo-g--withphoto{grid-template-columns:1fr}
.ceo-photo-col{order:0;margin-bottom:1rem}
.ceo-ph{max-width:200px;margin:0 auto}
.ceo-right{order:1}
}
