:root{--c-primary:#2b7de9;--c-primary-light:#5a9cf0;--c-primary-pale:#e8f1fd;--c-primary-50:#f0f6ff;--c-accent:#f08c28;--c-accent-hover:#e07a15;--c-accent-pale:#fff4e6;--c-green:#22b573;--c-green-pale:#e6f9f0;--c-navy:#1a3353;--c-text:#2d3748;--c-text-light:#6b7c93;--c-text-muted:#94a3b8;--c-white:#fff;--c-bg-warm:#faf8f5;--c-bg-blue:#f4f8ff;--c-bg-cream:#fffcf7;--c-gray-100:#f1f5f9;--c-gray-200:#e2e8f0;--c-gray-300:#cbd5e1;--ff-sans:'Noto Sans JP','Hiragino Kaku Gothic ProN',sans-serif;--ff-serif:'Noto Serif JP','Hiragino Mincho ProN',serif;--ff-display:'DM Sans',var(--ff-sans);--section-py:clamp(40px,6vw,80px);--container-max:1200px;--container-px:clamp(16px,4vw,40px);--r-lg:20px;--r-md:14px;--r-sm:8px;--shadow-sm:0 2px 8px rgba(43,125,233,.06);--shadow-md:0 8px 30px rgba(43,125,233,.08);--shadow-lg:0 16px 50px rgba(43,125,233,.1);--shadow-card:0 4px 20px rgba(0,0,0,.04);--ease-out:cubic-bezier(.16,1,.3,1);--dur:.6s}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}body{font-family:var(--ff-sans);color:var(--c-text);background:var(--c-white);line-height:1.8;overflow-x:hidden;-webkit-font-smoothing:antialiased}img{max-width:100%;height:auto;display:block}a{text-decoration:none;color:inherit}ul{list-style:none}.container{max-width:var(--container-max);margin:0 auto;padding:0 var(--container-px)}
.reveal{opacity:0;transform:translateY(30px);transition:opacity var(--dur) var(--ease-out),transform var(--dur) var(--ease-out)}.reveal.visible{opacity:1;transform:translateY(0)}.reveal-delay-1{transition-delay:.1s}.reveal-delay-2{transition-delay:.2s}.reveal-delay-3{transition-delay:.3s}.reveal-delay-4{transition-delay:.4s}
.site-header{position:fixed;top:0;left:0;right:0;z-index:1000;background:rgba(255,255,255,.96);backdrop-filter:blur(12px);transition:all .3s}.site-header.scrolled{box-shadow:0 2px 24px rgba(43,125,233,.08)}.header-inner{max-width:1400px;margin:0 auto;padding:0 var(--container-px);display:flex;align-items:center;justify-content:space-between;height:72px}.logo-link{display:flex;align-items:center;gap:10px}.logo-img{height:42px;width:auto}
.main-nav{display:flex;align-items:center;gap:0}.main-nav a{padding:8px 13px;font-size:.82rem;font-weight:500;color:var(--c-text);position:relative;transition:color .2s}.main-nav a:hover{color:var(--c-primary)}.main-nav a::after{content:'';position:absolute;bottom:0;left:13px;right:13px;height:2.5px;background:var(--c-primary);border-radius:2px;transform:scaleX(0);transition:transform .3s var(--ease-out)}.main-nav a:hover::after{transform:scaleX(1)}
.header-cta{display:flex;align-items:center;gap:14px}.header-tel{font-family:var(--ff-display);font-weight:700;font-size:.95rem;color:var(--c-navy)}.header-tel small{font-size:.68rem;font-weight:400;color:var(--c-text-light);display:block;font-family:var(--ff-sans)}.btn-contact{display:inline-flex;align-items:center;gap:6px;padding:10px 24px;background:var(--c-primary);color:#fff;font-size:.82rem;font-weight:700;border-radius:50px;transition:all .25s}.btn-contact:hover{background:var(--c-primary-light);transform:translateY(-1px);box-shadow:0 6px 20px rgba(43,125,233,.25)}
.menu-toggle{display:none;background:none;border:none;cursor:pointer;width:32px;height:32px;position:relative}.menu-toggle span{display:block;width:22px;height:2px;background:var(--c-navy);position:absolute;left:5px;transition:all .3s}.menu-toggle span:nth-child(1){top:8px}.menu-toggle span:nth-child(2){top:15px}.menu-toggle span:nth-child(3){top:22px}
.hero{position:relative;min-height:100vh;display:flex;flex-direction:column;justify-content:center;overflow:hidden;background:linear-gradient(160deg,var(--c-bg-blue) 0%,var(--c-white) 40%,var(--c-bg-cream) 100%)}.hero::before{content:'';position:absolute;top:-120px;right:-120px;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(43,125,233,.07) 0%,transparent 70%);pointer-events:none;animation:deco-drift 18s ease-in-out infinite}.hero::after{content:'';position:absolute;bottom:-80px;left:-80px;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(240,140,40,.06) 0%,transparent 70%);pointer-events:none;animation:deco-drift 14s ease-in-out infinite reverse}
.hero-video-wrap{position:absolute;top:0;left:0;width:100%;height:100%;z-index:0}.hero-video-wrap video{width:100%;height:100%;object-fit:cover;opacity:.65}.hero-video-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(160deg,rgba(244,248,255,0.45) 0%,rgba(255,255,255,0.35) 40%,rgba(255,252,247,0.40) 100%);z-index:1}
.hero-content{position:relative;z-index:2;max-width:1400px;margin:0 auto;padding:90px var(--container-px) 20px;display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:var(--c-accent-pale);border:1.5px solid var(--c-accent);padding:7px 18px;border-radius:50px;font-size:.8rem;font-weight:700;color:var(--c-accent-hover);margin-bottom:14px;animation:pulse-badge 2.5s ease infinite}@keyframes pulse-badge{0%,100%{box-shadow:0 0 0 0 rgba(240,140,40,.2)}50%{box-shadow:0 0 0 10px rgba(240,140,40,0)}}.hero-badge-dot{width:8px;height:8px;border-radius:50%;background:var(--c-accent);animation:blink 1.4s infinite}@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}
.hero-logo-area{margin-bottom:10px}.hero-logo-area img{height:44px;width:auto;filter:brightness(0.32)}
.hero-catch{font-family:var(--ff-serif);font-size:clamp(1.8rem,3.8vw,2.8rem);font-weight:700;color:var(--c-navy);line-height:1.55;margin-bottom:16px}.hero-catch em{font-style:normal;color:var(--c-primary);position:relative;display:inline-block}.hero-catch em::after{content:'';position:absolute;bottom:4px;left:0;right:0;height:8px;background:rgba(43,125,233,.12);border-radius:4px;z-index:-1}
.hero-sub{font-size:.95rem;color:var(--c-text-light);line-height:1.95;margin-bottom:24px;max-width:520px}.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.btn-primary{display:inline-flex;align-items:center;gap:8px;padding:15px 34px;background:var(--c-accent);color:#fff;font-size:.95rem;font-weight:700;border-radius:50px;transition:all .25s;box-shadow:0 4px 16px rgba(240,140,40,.25)}.btn-primary:hover{background:var(--c-accent-hover);transform:translateY(-2px);box-shadow:0 8px 28px rgba(240,140,40,.3)}
.btn-secondary{display:inline-flex;align-items:center;gap:8px;padding:15px 34px;border:2px solid var(--c-primary);color:var(--c-primary);font-size:.95rem;font-weight:700;border-radius:50px;transition:all .25s;background:#fff}.btn-secondary:hover{background:var(--c-primary-pale);transform:translateY(-2px)}
.hero-right{position:relative;padding-top:110px;padding-bottom:0}.hero-img-main{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-lg);border:4px solid #fff}.hero-img-main img{width:100%;display:block}
.hero-float-card{position:absolute;top:-30px;left:10%;background:#fff;border-radius:var(--r-md);padding:14px 20px;box-shadow:var(--shadow-md);display:flex;align-items:center;gap:12px;animation:float 4s ease-in-out infinite;border:1px solid var(--c-gray-200);white-space:nowrap;z-index:3}@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}.hero-float-icon{width:42px;height:42px;border-radius:12px;background:var(--c-primary-pale);display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0}.hero-float-label{font-size:.7rem;color:var(--c-text-muted)}.hero-float-value{font-family:var(--ff-display);font-size:.95rem;font-weight:800;color:var(--c-primary)}
.hero-float-card-2{position:absolute;top:-30px;right:10%;background:#fff;border-radius:var(--r-md);padding:14px 20px;box-shadow:var(--shadow-md);display:flex;align-items:center;gap:12px;animation:float2 4s ease-in-out infinite;border:1px solid var(--c-gray-200);white-space:nowrap;z-index:3}@keyframes float2{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}.hero-float-icon-2{width:38px;height:38px;border-radius:10px;background:var(--c-green-pale);display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0}
.hero-stats{position:relative;z-index:2;max-width:1400px;margin:0 auto;padding:16px var(--container-px) 32px}.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.stat-item{background:#fff;border-radius:var(--r-md);padding:22px 20px;text-align:center;box-shadow:var(--shadow-card);border:1px solid var(--c-gray-200);transition:all .3s var(--ease-out)}.stat-item:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--c-primary-pale)}.stat-icon{font-size:1.5rem;margin-bottom:6px}.stat-num{font-family:var(--ff-display);font-size:clamp(1.2rem,2.2vw,1.6rem);font-weight:800;color:var(--c-primary);line-height:1.3}.stat-label{font-size:.75rem;color:var(--c-text-light);margin-top:4px}
.section{position:relative;z-index:1}.section-header{text-align:center;margin-bottom:36px}.section-label{font-family:var(--ff-display);font-size:.78rem;font-weight:700;color:var(--c-primary);letter-spacing:.14em;text-transform:uppercase;margin-bottom:10px}.section-title{font-family:var(--ff-serif);font-size:clamp(1.5rem,3.2vw,2.1rem);font-weight:700;color:var(--c-navy);line-height:1.55}.section-title em{font-style:normal;color:var(--c-primary)}.section-desc{max-width:600px;margin:14px auto 0;font-size:.9rem;color:var(--c-text-light);line-height:1.9}
.s-usp{padding:var(--section-py) 0;background:linear-gradient(170deg,#f0f6ff 0%,#e8f4fd 40%,#f5f0ff 100%);position:relative;overflow:hidden}.s-usp::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:url('../images/bg/bg-blue-lines.jpg') center/cover no-repeat;opacity:.12;pointer-events:none}.s-usp::after{content:'';position:absolute;top:-60px;right:-40px;width:280px;height:280px;border-radius:50%;background:radial-gradient(circle,rgba(43,125,233,.06),transparent 70%);animation:deco-drift 12s ease-in-out infinite;pointer-events:none}@keyframes deco-drift{0%,100%{transform:translate(0,0)}50%{transform:translate(-20px,15px)}}.usp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}.usp-card{background:#fff;border-radius:var(--r-lg);padding:28px 24px;position:relative;overflow:hidden;transition:all .35s var(--ease-out);border:1px solid var(--c-gray-200)}.usp-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);border-color:var(--c-primary-pale)}.usp-card-icon{width:56px;height:56px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;margin-bottom:18px}.usp-card:nth-child(1) .usp-card-icon{background:var(--c-primary-pale)}.usp-card:nth-child(2) .usp-card-icon{background:var(--c-accent-pale)}.usp-card:nth-child(3) .usp-card-icon{background:var(--c-green-pale)}.usp-num{font-family:var(--ff-display);font-size:.7rem;font-weight:700;color:var(--c-primary);letter-spacing:.1em;margin-bottom:8px}.usp-card h3{font-size:1.1rem;font-weight:700;color:var(--c-navy);margin-bottom:12px;line-height:1.5}.usp-card p{font-size:.88rem;color:var(--c-text-light);line-height:1.9}
.s-target{padding:var(--section-py) 0;background:linear-gradient(180deg,#fff 0%,#fafcff 50%,#f8faf5 100%);position:relative;overflow:hidden}.s-target::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:url('../images/bg/bg-wave-white.jpg') center/cover no-repeat;opacity:.15;pointer-events:none}.s-target::after{content:'';position:absolute;bottom:-40px;left:10%;width:220px;height:220px;border-radius:50%;background:radial-gradient(circle,rgba(34,181,115,.05),transparent 70%);animation:deco-drift 14s ease-in-out infinite;pointer-events:none}.target-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}.target-card{border-radius:var(--r-lg);overflow:hidden;background:#fff;border:1px solid var(--c-gray-200);transition:all .35s var(--ease-out)}.target-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}.target-card-img{position:relative;height:220px;overflow:hidden}.target-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease-out)}.target-card:hover .target-card-img img{transform:scale(1.04)}.target-card-num{position:absolute;top:14px;left:14px;background:var(--c-primary);color:#fff;width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-family:var(--ff-display);font-weight:800;font-size:.85rem}.target-card-body{padding:24px}.target-card-body h3{font-size:1.05rem;font-weight:700;color:var(--c-navy);margin-bottom:10px}.target-card-body p{font-size:.85rem;color:var(--c-text-light);line-height:1.85}
.s-jwcad{padding:var(--section-py) 0;background:linear-gradient(160deg,#faf8f5 0%,#f5f0e8 40%,#f0ede6 100%);position:relative;overflow:hidden}.s-jwcad::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:url('../images/bg/bg-diagonal-gray.jpg') center/cover no-repeat;opacity:.18;pointer-events:none}.s-jwcad::after{content:'';position:absolute;top:30%;right:-60px;width:250px;height:250px;border-radius:50%;background:radial-gradient(circle,rgba(240,140,40,.06),transparent 70%);animation:deco-drift 16s ease-in-out infinite;pointer-events:none}.jwcad-layout{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center}.jwcad-images{display:grid;grid-template-columns:1fr 1fr;gap:12px}.jwcad-images img{border-radius:var(--r-md);width:100%;box-shadow:var(--shadow-sm);border:3px solid #fff}.jwcad-images img:first-child{grid-row:span 2;height:100%;object-fit:cover}.jwcad-text h3{font-family:var(--ff-serif);font-size:1.45rem;font-weight:700;color:var(--c-navy);margin-bottom:18px;line-height:1.6}.jwcad-text p{font-size:.9rem;color:var(--c-text-light);line-height:2;margin-bottom:14px}.jwcad-features{display:flex;flex-direction:column;gap:10px;margin-top:20px}.jwcad-feature{display:flex;align-items:center;gap:12px;font-size:.88rem;color:var(--c-text);background:#fff;padding:12px 16px;border-radius:var(--r-sm);border:1px solid var(--c-gray-200)}.jwcad-feature-icon{width:28px;height:28px;border-radius:50%;background:var(--c-green-pale);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--c-green);font-size:.8rem;font-weight:700}
.s-course{padding:var(--section-py) 0;background:linear-gradient(180deg,#fff 0%,#f8fbff 50%,#f4f8ff 100%);position:relative;overflow:hidden}.s-course::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:url('../images/bg/bg-diagonal-blue.jpg') center/cover no-repeat;opacity:.25;pointer-events:none}.s-course::after{content:'';position:absolute;top:-30px;left:-30px;width:200px;height:200px;border-radius:50%;background:radial-gradient(circle,rgba(90,108,240,.05),transparent 70%);animation:deco-drift 10s ease-in-out infinite reverse;pointer-events:none}.course-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}.course-card{background:#fff;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--c-gray-200);transition:all .35s var(--ease-out);display:flex;flex-direction:column}.course-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}.course-card-header{position:relative;height:200px;overflow:hidden}.course-card-header img{width:100%;height:100%;object-fit:cover}.course-tag{position:absolute;top:14px;left:14px;color:#fff;padding:5px 16px;border-radius:50px;font-size:.72rem;font-weight:700}.course-card:nth-child(1) .course-tag{background:var(--c-accent)}.course-card:nth-child(2) .course-tag{background:var(--c-primary)}.course-card:nth-child(3) .course-tag{background:var(--c-green)}.course-card-body{padding:28px 24px;flex:1;display:flex;flex-direction:column;position:relative;background:linear-gradient(160deg,#fff 60%,#f8fbff 100%)}.course-card-body::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background-image:radial-gradient(circle,rgba(43,125,233,.03) 1px,transparent 1px);background-size:20px 20px;pointer-events:none}.course-card-body::after{content:'';position:absolute;bottom:12px;right:12px;width:80px;height:80px;border-radius:50%;opacity:.06;pointer-events:none}
.course-card:nth-child(1) .course-card-body::after{background:var(--c-accent)}
.course-card:nth-child(2) .course-card-body::after{background:var(--c-primary)}
.course-card:nth-child(3) .course-card-body::after{background:var(--c-green)}
.course-card-body>*{position:relative;z-index:1}
.course-card-illust{position:absolute;top:10px;right:10px;width:90px;height:90px;opacity:.5;z-index:0}
.course-card-illust svg{width:100%;height:100%}
.course-illust-orange{color:var(--c-accent)}
.course-illust-blue{color:var(--c-primary)}
.course-illust-green{color:var(--c-green)}.course-card-body h3{font-size:1.15rem;font-weight:700;color:var(--c-navy);margin-bottom:10px}.course-card-body p{font-size:.85rem;color:var(--c-text-light);line-height:1.85;flex:1}.course-price{margin-top:18px;padding-top:16px;border-top:1px dashed var(--c-gray-200)}.course-price-main{font-family:var(--ff-display);font-size:1.35rem;font-weight:800;color:var(--c-primary)}.course-price-main small{font-size:.72rem;font-weight:400;color:var(--c-text-light);font-family:var(--ff-sans)}.course-price-note{font-size:.75rem;color:var(--c-accent-hover);font-weight:500;margin-top:4px}
.s-diff{padding:var(--section-py) 0;background:linear-gradient(170deg,#edf3ff 0%,#f4f8ff 50%,#f0f4fb 100%);position:relative;overflow:hidden}.s-diff::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:url('../images/bg/bg-city-grid.jpg') center/cover no-repeat;opacity:.08;pointer-events:none}.s-diff::after{content:'';position:absolute;bottom:-50px;right:5%;width:260px;height:260px;border-radius:50%;background:radial-gradient(circle,rgba(43,125,233,.05),transparent 70%);animation:deco-drift 13s ease-in-out infinite;pointer-events:none}.diff-layout{display:grid;grid-template-columns:1fr 1fr;gap:36px;align-items:center}.diff-img{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-md);border:4px solid #fff}.diff-img img{width:100%;display:block}.diff-content h3{font-family:var(--ff-serif);font-size:1.4rem;font-weight:700;color:var(--c-navy);line-height:1.6;margin-bottom:18px}.diff-content p{font-size:.9rem;color:var(--c-text-light);line-height:2;margin-bottom:24px}.diff-list{display:flex;flex-direction:column;gap:12px}.diff-list-item{display:flex;align-items:center;gap:12px;font-size:.88rem;color:var(--c-text);background:#fff;padding:14px 18px;border-radius:var(--r-sm);border:1px solid var(--c-gray-200);transition:all .2s}.diff-list-item:hover{border-color:var(--c-primary-pale);box-shadow:var(--shadow-sm)}.diff-list-check{width:24px;height:24px;border-radius:50%;background:var(--c-primary);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#fff;font-size:.7rem;font-weight:700}
.s-campaign{padding:var(--section-py) 0;background:linear-gradient(135deg,#4a9cf5 0%,var(--c-primary) 50%,#5a6cf0 100%);position:relative;overflow:hidden}.s-campaign::before{content:'';position:absolute;top:-150px;right:-150px;width:500px;height:500px;border-radius:50%;background:rgba(255,255,255,.08);animation:deco-drift 15s ease-in-out infinite}.s-campaign::after{content:'';position:absolute;bottom:-100px;left:-100px;width:350px;height:350px;border-radius:50%;background:rgba(255,255,255,.06);animation:deco-drift 12s ease-in-out infinite reverse}.s-campaign .campaign-inner::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background-image:repeating-linear-gradient(135deg,transparent,transparent 80px,rgba(255,255,255,.03) 80px,rgba(255,255,255,.03) 81px);pointer-events:none}.campaign-inner{position:relative;z-index:1;text-align:center}.campaign-tag{display:inline-block;background:rgba(255,255,255,.2);padding:7px 22px;border-radius:50px;font-size:.82rem;font-weight:700;color:#fff;margin-bottom:18px}.campaign-title{font-family:var(--ff-serif);font-size:clamp(1.5rem,3.5vw,2.3rem);font-weight:700;color:#fff;line-height:1.55;margin-bottom:14px}.campaign-price{font-family:var(--ff-display);font-size:clamp(2rem,5vw,3.2rem);font-weight:800;color:var(--c-accent);line-height:1.3;margin-bottom:8px;text-shadow:0 2px 8px rgba(0,0,0,.1)}.campaign-price del{font-size:.45em;color:rgba(255,255,255,.5);font-weight:400;margin-right:8px;text-decoration-thickness:2px}.campaign-note{font-size:.82rem;color:rgba(255,255,255,.7);margin-bottom:20px}.campaign-actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.btn-white{display:inline-flex;align-items:center;gap:8px;padding:16px 40px;background:#fff;color:var(--c-primary);font-size:.95rem;font-weight:700;border-radius:50px;transition:all .25s;box-shadow:0 4px 16px rgba(0,0,0,.1)}.btn-white:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(0,0,0,.15)}.btn-white-outline{display:inline-flex;align-items:center;gap:8px;padding:16px 40px;border:2px solid rgba(255,255,255,.5);color:#fff;font-size:.95rem;font-weight:600;border-radius:50px;transition:all .25s}.btn-white-outline:hover{border-color:#fff;background:rgba(255,255,255,.1)}
.s-blog{padding:var(--section-py) 0;background:linear-gradient(180deg,#fffcf7 0%,#faf6f0 50%,#f8f4ee 100%);position:relative;overflow:hidden}.s-blog::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:url('../images/bg/bg-diagonal-gray2.jpg') center/cover no-repeat;opacity:.12;pointer-events:none}.s-blog::after{content:'';position:absolute;top:20%;left:-40px;width:200px;height:200px;border-radius:50%;background:radial-gradient(circle,rgba(240,140,40,.05),transparent 70%);animation:deco-drift 11s ease-in-out infinite reverse;pointer-events:none}.blog-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}.blog-card{background:#fff;border-radius:var(--r-md);overflow:hidden;border:1px solid var(--c-gray-200);transition:all .35s var(--ease-out)}.blog-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.blog-card-img{height:150px;overflow:hidden}.blog-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s var(--ease-out)}.blog-card:hover .blog-card-img img{transform:scale(1.05)}.blog-card-body{padding:18px}.blog-card-cat{display:inline-block;font-size:.68rem;font-weight:700;color:var(--c-primary);background:var(--c-primary-pale);padding:3px 10px;border-radius:50px;margin-bottom:6px}.blog-card-date{font-size:.72rem;color:var(--c-text-muted);margin-bottom:8px;font-family:var(--ff-display)}.blog-card-body h3{font-size:.85rem;font-weight:700;color:var(--c-navy);line-height:1.6;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.blog-more{text-align:center;margin-top:24px}.btn-more{display:inline-flex;align-items:center;gap:8px;padding:14px 32px;border:2px solid var(--c-primary);color:var(--c-primary);font-size:.88rem;font-weight:600;border-radius:50px;transition:all .25s;background:#fff}.btn-more:hover{background:var(--c-primary);color:#fff}
.s-access{padding:var(--section-py) 0;background:linear-gradient(180deg,#fff 0%,#f8fafe 50%,#f4f7fc 100%);position:relative;overflow:hidden}.s-access::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background-image:repeating-linear-gradient(0deg,transparent,transparent 48px,rgba(43,125,233,.025) 48px,rgba(43,125,233,.025) 49px);pointer-events:none}.access-layout{display:grid;grid-template-columns:1fr 1fr;gap:36px;align-items:start}.access-info h3{font-family:var(--ff-serif);font-size:1.3rem;font-weight:700;color:var(--c-navy);margin-bottom:24px}.access-table{width:100%;border-collapse:collapse}.access-table tr{border-bottom:1px solid var(--c-gray-200)}.access-table th,.access-table td{padding:14px 0;font-size:.88rem;text-align:left;vertical-align:top}.access-table th{font-weight:700;color:var(--c-navy);width:120px}.access-table td{color:var(--c-text-light)}.access-map{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-md);height:360px;background:var(--c-gray-100);display:flex;align-items:center;justify-content:center;color:var(--c-text-light);font-size:.9rem;border:3px solid #fff}
.site-footer{background:linear-gradient(170deg,#65788a 0%,#708090 50%,#6a7a8a 100%);color:rgba(255,255,255,.75);position:relative;z-index:1;overflow:hidden}.site-footer::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background-image:repeating-linear-gradient(135deg,transparent,transparent 60px,rgba(255,255,255,.03) 60px,rgba(255,255,255,.03) 61px);pointer-events:none}.footer-top{padding:40px 0 28px;display:grid;grid-template-columns:1.3fr 1fr 1fr 1fr;gap:32px}.footer-logo{height:36px;width:auto;filter:brightness(0) invert(1);margin-bottom:14px}.footer-brand p{font-size:.82rem;line-height:1.8;max-width:280px}.footer-brand .footer-tel{margin-top:8px;font-family:var(--ff-display);font-size:1.2rem;font-weight:700;color:#fff}.footer-brand .footer-address{font-size:.78rem;margin-top:10px;color:rgba(255,255,255,.6)}.footer-nav h4{font-size:.75rem;font-weight:700;color:#fff;letter-spacing:.1em;text-transform:uppercase;margin-bottom:14px}.footer-nav ul{display:flex;flex-direction:column;gap:10px}.footer-nav a{font-size:.82rem;transition:color .2s}.footer-nav a:hover{color:#fff}.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding:18px 0;display:flex;justify-content:space-between;align-items:center;font-size:.75rem}
@media(max-width:1024px){.hero-content{grid-template-columns:1fr;gap:36px}.hero-right{display:none}.stats-row{grid-template-columns:repeat(2,1fr)}.usp-grid{grid-template-columns:repeat(2,1fr)}.target-grid{grid-template-columns:repeat(2,1fr)}.course-grid{grid-template-columns:repeat(2,1fr)}.jwcad-layout{grid-template-columns:1fr}.diff-layout{grid-template-columns:1fr}.blog-grid{grid-template-columns:repeat(2,1fr)}.access-layout{grid-template-columns:1fr}.footer-top{grid-template-columns:1fr 1fr}}
@media(max-width:768px){.main-nav{display:none}.header-tel{display:none}.menu-toggle{display:block}.header-inner{height:60px}.hero{min-height:auto;padding-top:0}.hero-content{padding-top:80px;padding-bottom:20px}.hero-catch{font-size:1.6rem}.hero-actions{flex-direction:column}.btn-primary,.btn-secondary{width:100%;justify-content:center}.stats-row{grid-template-columns:repeat(2,1fr);gap:10px}.stat-item{padding:16px 12px}.usp-grid{grid-template-columns:1fr}.target-grid{grid-template-columns:1fr}.course-grid{grid-template-columns:1fr}.blog-grid{grid-template-columns:1fr}.footer-top{grid-template-columns:1fr}.campaign-actions{flex-direction:column;align-items:center}.btn-white,.btn-white-outline{width:280px;justify-content:center}}
.mobile-cta{display:none;position:fixed;bottom:0;left:0;right:0;z-index:999;background:#fff;border-top:1px solid var(--c-gray-200);padding:10px 16px;box-shadow:0 -4px 20px rgba(0,0,0,.06)}.mobile-cta-inner{display:flex;gap:10px}.mobile-cta-inner a{flex:1;text-align:center;padding:12px;border-radius:50px;font-size:.82rem;font-weight:700}.mobile-cta-tel{background:#fff;border:2px solid var(--c-primary);color:var(--c-primary)}.mobile-cta-contact{background:var(--c-accent);color:#fff}@media(max-width:768px){.mobile-cta{display:block}body{padding-bottom:68px}}
.to-top{position:fixed;bottom:24px;right:24px;width:46px;height:46px;border-radius:50%;background:var(--c-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.1rem;z-index:998;opacity:0;transform:translateY(20px);transition:all .3s;cursor:pointer;border:none;box-shadow:0 4px 16px rgba(43,125,233,.25)}.to-top.show{opacity:1;transform:translateY(0)}.to-top:hover{background:var(--c-primary-light)}@media(max-width:768px){.to-top{bottom:80px}}
/* SVG Icon System */
.icon{display:inline-flex;align-items:center;justify-content:center;width:1em;height:1em;flex-shrink:0}
.icon svg{width:100%;height:100%;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.icon-filled svg{fill:currentColor;stroke:none}
.stat-icon .icon{font-size:1.6rem;color:var(--c-primary)}
.usp-card-icon .icon{font-size:1.6rem}
.usp-card:nth-child(1) .usp-card-icon .icon{color:var(--c-primary)}
.usp-card:nth-child(2) .usp-card-icon .icon{color:var(--c-accent)}
.usp-card:nth-child(3) .usp-card-icon .icon{color:var(--c-green)}
.hero-float-icon .icon,.hero-float-icon-2 .icon{font-size:1.3rem}
.hero-float-icon .icon{color:var(--c-primary)}
.hero-float-icon-2 .icon{color:var(--c-green)}
.jwcad-feature-icon .icon{font-size:.8rem;color:#fff}
.jwcad-feature-icon .icon svg{stroke-width:2.5}
.diff-list-check .icon{font-size:.7rem;color:#fff}
.diff-list-check .icon svg{stroke-width:3}
.blog-card-icon{font-size:2.4rem;color:var(--c-primary);opacity:.35}
.btn-icon{font-size:1em;margin-right:2px}
.btn-icon .icon{font-size:1em}
.to-top .icon{font-size:1.2rem}
.mobile-cta .btn-icon .icon{font-size:1.1em}

/* ============================================
   下層ページ共通: ページヒーロー
   ============================================ */
.page-hero{position:relative;padding:120px 0 48px;overflow:hidden;background:linear-gradient(160deg,#e8f1fd 0%,#f0f6ff 40%,#f5f0ff 100%)}
.page-hero::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:url('../images/bg/bg-blue-lines.jpg') center/cover no-repeat;opacity:.1;pointer-events:none}
.page-hero::after{content:'';position:absolute;top:-80px;right:-80px;width:350px;height:350px;border-radius:50%;background:radial-gradient(circle,rgba(43,125,233,.06),transparent 70%);animation:deco-drift 14s ease-in-out infinite;pointer-events:none}
.page-hero-inner{position:relative;z-index:1;text-align:center}
.page-hero-label{font-family:var(--ff-display);font-size:.82rem;font-weight:700;color:var(--c-primary);letter-spacing:.16em;text-transform:uppercase;margin-bottom:10px}
.page-hero-title{font-family:var(--ff-serif);font-size:clamp(1.8rem,4vw,2.6rem);font-weight:700;color:var(--c-navy);line-height:1.4;margin-bottom:14px}
.page-hero-desc{font-size:.92rem;color:var(--c-text-light);line-height:1.9;max-width:560px;margin:0 auto}

/* パンくずリスト */
.breadcrumb{background:var(--c-white);border-bottom:1px solid var(--c-gray-200);padding:12px 0}
.breadcrumb ol{display:flex;align-items:center;gap:6px;font-size:.75rem;color:var(--c-text-muted)}
.breadcrumb a{color:var(--c-primary);transition:opacity .2s}
.breadcrumb a:hover{opacity:.7}
.breadcrumb li:not(:last-child)::after{content:'›';margin-left:6px;color:var(--c-gray-300)}
.breadcrumb li[aria-current]{color:var(--c-text-light)}

/* ============================================
   コースページ: コースナビ
   ============================================ */
.course-nav-section{padding:32px 0;background:var(--c-white)}
.course-nav{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.course-nav-item{display:flex;flex-direction:column;align-items:center;gap:8px;padding:24px 16px;border-radius:var(--r-md);border:2px solid var(--c-gray-200);background:var(--c-white);transition:all .3s var(--ease-out);text-align:center}
.course-nav-item:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.course-nav-orange:hover{border-color:var(--c-accent);background:var(--c-accent-pale)}
.course-nav-blue:hover{border-color:var(--c-primary);background:var(--c-primary-pale)}
.course-nav-green:hover{border-color:var(--c-green);background:var(--c-green-pale)}
.course-nav-icon{font-size:1.8rem;color:var(--c-primary)}
.course-nav-orange .course-nav-icon{color:var(--c-accent)}
.course-nav-green .course-nav-icon{color:var(--c-green)}
.course-nav-name{font-size:.92rem;font-weight:700;color:var(--c-navy)}
.course-nav-price{font-family:var(--ff-display);font-size:.82rem;font-weight:700;color:var(--c-text-light)}

/* ============================================
   コースページ: コース詳細
   ============================================ */
.course-detail{padding:var(--section-py) 0;background:var(--c-white);position:relative;overflow:hidden}
.course-detail::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:url('../images/bg/bg-wave-white.jpg') center/cover no-repeat;opacity:.1;pointer-events:none}
.course-detail-alt{background:linear-gradient(180deg,#f8fbff 0%,#f4f8ff 100%)}
.course-detail-alt::before{background:url('../images/bg/bg-diagonal-blue.jpg') center/cover no-repeat;opacity:.08}
.course-detail-layout{display:grid;grid-template-columns:1fr 1.2fr;gap:40px;align-items:start;position:relative;z-index:1}
.course-detail-reverse{direction:rtl}
.course-detail-reverse>*{direction:ltr}
.course-detail-img{position:relative;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-md);border:3px solid #fff}
.course-detail-img img{width:100%;display:block}
.course-detail-illust{padding:16px 20px;background:linear-gradient(135deg,#f8fbff,#fff);border-top:1px solid var(--c-gray-200)}
.course-detail-illust svg{width:100%;height:60px}
.course-illust-orange{color:var(--c-accent)}
.course-illust-blue{color:var(--c-primary)}
.course-illust-green{color:var(--c-green)}
.course-detail-tag{position:absolute;top:14px;left:14px;color:#fff;padding:5px 16px;border-radius:50px;font-size:.72rem;font-weight:700}
.course-detail-label{font-family:var(--ff-display);font-size:.75rem;font-weight:700;letter-spacing:.12em;margin-bottom:6px}
.course-detail-title{font-family:var(--ff-serif);font-size:1.6rem;font-weight:700;color:var(--c-navy);margin-bottom:8px}
.course-detail-subtitle{font-size:.88rem;color:var(--c-text-light);margin-bottom:16px;font-weight:500}
.course-detail-text{font-size:.88rem;color:var(--c-text-light);line-height:2;margin-bottom:20px}
.course-detail-price-box{background:var(--c-gray-100);border-radius:var(--r-sm);padding:18px 20px;margin-bottom:20px;border-left:4px solid var(--c-primary)}
.course-detail-price{font-family:var(--ff-display);font-size:1.5rem;font-weight:800;color:var(--c-primary)}
.course-detail-price small{font-size:.72rem;font-weight:400;color:var(--c-text-light);font-family:var(--ff-sans)}
.course-detail-campaign{font-size:.85rem;color:var(--c-accent-hover);font-weight:600;margin-top:6px}
.course-detail-note{font-size:.78rem;color:var(--c-text-light);margin-top:4px}
.course-detail-features{display:flex;flex-direction:column;gap:8px;margin-bottom:24px}
.course-feature-item{display:flex;align-items:center;gap:10px;font-size:.86rem;color:var(--c-text)}
.course-feature-item .icon{font-size:1rem;color:var(--c-green);flex-shrink:0}
.course-feature-item .icon svg{stroke-width:2.5}
.course-detail-actions{display:flex;gap:12px;flex-wrap:wrap}

/* ============================================
   コースページ: 比較表
   ============================================ */
.s-compare{padding:var(--section-py) 0;background:linear-gradient(170deg,#faf8f5 0%,#f5f0e8 100%);position:relative;overflow:hidden}
.s-compare::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:url('../images/bg/bg-diagonal-gray2.jpg') center/cover no-repeat;opacity:.12;pointer-events:none}
.compare-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
.compare-table{width:100%;border-collapse:collapse;background:#fff;border-radius:var(--r-md);overflow:hidden;box-shadow:var(--shadow-md)}
.compare-table th,.compare-table td{padding:16px 20px;text-align:center;font-size:.85rem;border-bottom:1px solid var(--c-gray-200)}
.compare-table thead th{font-weight:700;color:#fff;padding:18px 20px;font-size:.88rem}
.compare-head-orange{background:var(--c-accent)}
.compare-head-blue{background:var(--c-primary)}
.compare-head-green{background:var(--c-green)}
.compare-table thead th:first-child{background:var(--c-navy);width:120px}
.compare-table tbody th{font-weight:600;color:var(--c-navy);background:var(--c-gray-100);text-align:left;font-size:.82rem}
.compare-table tbody td{color:var(--c-text-light);line-height:1.6}

/* ============================================
   下層ページ Responsive追加
   ============================================ */
@media(max-width:1024px){
  .course-detail-layout{grid-template-columns:1fr}
  .course-detail-reverse{direction:ltr}
  .course-nav{grid-template-columns:1fr}
}
@media(max-width:768px){
  .page-hero{padding:80px 0 32px}
  .course-nav{gap:10px}
  .course-nav-item{flex-direction:row;padding:16px}
  .compare-table{font-size:.78rem}
  .compare-table th,.compare-table td{padding:12px 10px}
}

/* ============================================
   FAQページ: アコーディオン
   ============================================ */
.s-faq{padding:var(--section-py) 0;background:linear-gradient(180deg,#fff 0%,#f8fbff 50%,#f4f8ff 100%);position:relative;overflow:hidden}
.s-faq::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:url('../images/bg/bg-wave-white.jpg') center/cover no-repeat;opacity:.12;pointer-events:none}
.faq-list{max-width:800px;margin:0 auto;display:flex;flex-direction:column;gap:14px;position:relative;z-index:1}
.faq-item{background:#fff;border-radius:var(--r-md);border:1px solid var(--c-gray-200);overflow:hidden;transition:all .3s var(--ease-out)}
.faq-item:hover{border-color:var(--c-primary-pale);box-shadow:var(--shadow-sm)}
.faq-item.open{border-color:var(--c-primary);box-shadow:var(--shadow-md)}
.faq-question{display:flex;align-items:center;gap:14px;width:100%;padding:20px 24px;background:none;border:none;cursor:pointer;text-align:left;font-family:inherit;font-size:.92rem;font-weight:600;color:var(--c-navy);line-height:1.5;transition:background .2s}
.faq-question:hover{background:var(--c-primary-50)}
.faq-q-badge{width:32px;height:32px;border-radius:8px;background:var(--c-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--ff-display);font-weight:800;font-size:.85rem;flex-shrink:0}
.faq-q-text{flex:1}
.faq-toggle{width:28px;height:28px;border-radius:50%;background:var(--c-gray-100);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .3s;color:var(--c-text-light)}
.faq-toggle .icon{font-size:.85rem;transition:transform .3s}
.faq-item.open .faq-toggle{background:var(--c-primary);color:#fff}
.faq-item.open .faq-toggle .icon{transform:rotate(45deg)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .4s var(--ease-out)}
.faq-item.open .faq-answer{max-height:600px}
.faq-a-inner{display:flex;gap:14px;padding:0 24px 24px;align-items:flex-start}
.faq-a-badge{width:32px;height:32px;border-radius:8px;background:var(--c-accent);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--ff-display);font-weight:800;font-size:.85rem;flex-shrink:0}
.faq-a-text{flex:1;font-size:.88rem;color:var(--c-text-light);line-height:1.9}
.faq-a-text p{margin-bottom:10px}
.faq-a-text p:last-child{margin-bottom:0}
/* FAQ時間チャート */
.faq-time-chart{display:flex;flex-direction:column;gap:10px;margin:14px 0}
.faq-time-item{display:flex;flex-direction:column;gap:4px}
.faq-time-bar{height:6px;border-radius:3px;background:linear-gradient(90deg,var(--c-primary),var(--c-primary-light))}
.faq-time-label{font-size:.82rem;color:var(--c-text)}
/* FAQ CTA */
.s-faq-cta{padding:var(--section-py) 0;background:linear-gradient(170deg,#f0f6ff 0%,#e8f1fd 100%);position:relative;overflow:hidden}
.s-faq-cta::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:url('../images/bg/bg-diagonal-blue.jpg') center/cover no-repeat;opacity:.08;pointer-events:none}
.faq-cta-box{display:flex;align-items:center;justify-content:space-between;gap:32px;background:#fff;border-radius:var(--r-lg);padding:36px 40px;box-shadow:var(--shadow-md);position:relative;z-index:1}
.faq-cta-text h2{font-family:var(--ff-serif);font-size:1.3rem;font-weight:700;color:var(--c-navy);margin-bottom:8px}
.faq-cta-text p{font-size:.88rem;color:var(--c-text-light);line-height:1.8}
.faq-cta-actions{display:flex;gap:12px;flex-shrink:0}
.faq-cta-actions .icon{font-size:1.1em;margin-right:4px}
@media(max-width:768px){
  .faq-cta-box{flex-direction:column;text-align:center;padding:28px 24px}
  .faq-cta-actions{flex-direction:column;width:100%}
  .faq-cta-actions a{width:100%;justify-content:center}
  .faq-question{padding:16px 18px;font-size:.86rem}
  .faq-a-inner{padding:0 18px 18px}
}

/* ============================================
   講師紹介ページ
   ============================================ */
.teacher-intro{padding:var(--section-py) 0;background:var(--c-white);position:relative;overflow:hidden}
.teacher-intro::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:url('../images/bg/bg-diagonal-gray.jpg') center/cover no-repeat;opacity:.08;pointer-events:none}
.teacher-intro-layout{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center;position:relative;z-index:1}
.teacher-intro-img{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-md);border:3px solid #fff}
.teacher-intro-img img{width:100%;display:block}
.teacher-intro-text h2{font-family:var(--ff-serif);font-size:1.4rem;font-weight:700;color:var(--c-navy);line-height:1.6;margin-bottom:16px}
.teacher-intro-text p{font-size:.9rem;color:var(--c-text-light);line-height:2;margin-bottom:12px}
.teacher-list{padding:0 0 var(--section-py);background:linear-gradient(180deg,#fff 0%,#f8fbff 100%);position:relative;overflow:hidden}
.teacher-list::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:url('../images/bg/bg-wave-white.jpg') center/cover no-repeat;opacity:.1;pointer-events:none}
.teacher-card{display:grid;grid-template-columns:.35fr .65fr;gap:36px;align-items:start;background:#fff;border-radius:var(--r-lg);padding:32px;margin-bottom:28px;border:1px solid var(--c-gray-200);box-shadow:var(--shadow-card);position:relative;z-index:1;transition:all .3s var(--ease-out)}
.teacher-card:hover{box-shadow:var(--shadow-md);border-color:var(--c-primary-pale)}
.teacher-card-reverse{grid-template-columns:.65fr .35fr}
.teacher-card-reverse .teacher-card-photo{order:2}
.teacher-card-reverse .teacher-card-body{order:1}
.teacher-card-photo{border-radius:var(--r-md);overflow:hidden;box-shadow:var(--shadow-sm)}
.teacher-card-photo img{width:100%;display:block}
.teacher-card-role{font-size:.75rem;font-weight:700;color:var(--c-primary);letter-spacing:.06em;margin-bottom:4px;display:inline-block;background:var(--c-primary-pale);padding:3px 12px;border-radius:50px}
.teacher-card-name{font-family:var(--ff-serif);font-size:1.4rem;font-weight:700;color:var(--c-navy);margin-bottom:10px}
.teacher-card-profile{font-size:.82rem;color:var(--c-text-light);display:flex;align-items:flex-start;gap:8px;margin-bottom:16px;padding:10px 14px;background:var(--c-gray-100);border-radius:var(--r-sm);line-height:1.6}
.teacher-card-profile .icon{font-size:1rem;color:var(--c-accent);flex-shrink:0;margin-top:2px}
.teacher-card-sections{display:flex;flex-direction:column;gap:14px}
.teacher-card-section h4{font-size:.82rem;font-weight:700;color:var(--c-navy);display:flex;align-items:center;gap:6px;margin-bottom:6px}
.teacher-card-section h4 .icon{font-size:1rem;color:var(--c-primary)}
.teacher-card-section p{font-size:.86rem;color:var(--c-text-light);line-height:1.9}
@media(max-width:1024px){
  .teacher-intro-layout{grid-template-columns:1fr}
  .teacher-card,.teacher-card-reverse{grid-template-columns:1fr}
  .teacher-card-reverse .teacher-card-photo{order:0}
  .teacher-card-reverse .teacher-card-body{order:0}
  .teacher-card-photo{max-width:280px}
}
@media(max-width:768px){
  .teacher-card{padding:20px}
}

/* ============================================
   ブログ一覧ページ
   ============================================ */
.blog-filter-section{padding:24px 0;background:var(--c-white);border-bottom:1px solid var(--c-gray-200)}
.blog-filter{display:flex;gap:8px;flex-wrap:wrap;justify-content:center}
.blog-filter-item{padding:8px 20px;border-radius:50px;font-size:.82rem;font-weight:500;color:var(--c-text-light);border:1.5px solid var(--c-gray-200);background:var(--c-white);transition:all .2s}
.blog-filter-item:hover,.blog-filter-item.active{background:var(--c-primary);color:#fff;border-color:var(--c-primary)}
.s-blog-list{padding:var(--section-py) 0;background:linear-gradient(180deg,#fff 0%,#f8fbff 100%);position:relative;overflow:hidden}
.s-blog-list::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:url('../images/bg/bg-wave-white.jpg') center/cover no-repeat;opacity:.08;pointer-events:none}
.blog-list-cat{margin-bottom:16px;position:relative;z-index:1}
.blog-list-cat-title{font-family:var(--ff-serif);font-size:1.15rem;font-weight:700;color:var(--c-navy);padding-bottom:10px;border-bottom:2px solid var(--c-primary);display:inline-block}
.blog-list-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-bottom:40px;position:relative;z-index:1}
.blog-list-card{display:grid;grid-template-columns:160px 1fr;gap:16px;background:#fff;border-radius:var(--r-md);border:1px solid var(--c-gray-200);padding:16px;transition:all .3s var(--ease-out);align-items:center}
.blog-list-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--c-primary-pale)}
.blog-list-card-img{height:100px;border-radius:var(--r-sm);overflow:hidden}.blog-list-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s var(--ease-out)}.blog-list-card:hover .blog-list-card-img img{transform:scale(1.05)}
.blog-list-card-body{}
.blog-list-card-meta{display:flex;align-items:center;gap:10px;margin-bottom:6px}
.blog-list-card-cat{font-size:.68rem;font-weight:700;color:var(--c-primary);background:var(--c-primary-pale);padding:2px 10px;border-radius:50px}
.blog-list-card-date{font-size:.72rem;color:var(--c-text-muted);font-family:var(--ff-display)}
.blog-list-card-body h3{font-size:.88rem;font-weight:600;color:var(--c-navy);line-height:1.6;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
@media(max-width:768px){.blog-list-grid{grid-template-columns:1fr}.blog-list-card{grid-template-columns:1fr}.blog-list-card-img{height:140px}}

/* ============================================
   ブログ記事ページ
   ============================================ */
.page-hero-sm{padding:100px 0 36px}
.s-article{padding:var(--section-py) 0;background:var(--c-white)}
.article-layout{display:grid;grid-template-columns:1fr 300px;gap:40px;align-items:start}
.article-main{}
.article-meta{display:flex;align-items:center;gap:12px;margin-bottom:20px;flex-wrap:wrap}
.article-cat{font-size:.72rem;font-weight:700;color:var(--c-primary);background:var(--c-primary-pale);padding:4px 14px;border-radius:50px}
.article-date,.article-updated{font-size:.78rem;color:var(--c-text-muted);font-family:var(--ff-display)}
.article-content{font-size:.92rem;color:var(--c-text);line-height:2}
.article-content h2{font-family:var(--ff-serif);font-size:1.3rem;font-weight:700;color:var(--c-navy);margin:32px 0 14px;padding-bottom:10px;border-bottom:2px solid var(--c-primary-pale)}
.article-content h3{font-size:1.1rem;font-weight:700;color:var(--c-navy);margin:24px 0 10px;padding-left:14px;border-left:3px solid var(--c-primary)}
.article-content p{margin-bottom:16px}
.article-content img{border-radius:var(--r-md);margin:20px 0;box-shadow:var(--shadow-sm)}
.article-content ul,.article-content ol{margin:12px 0 16px 20px}
.article-content li{margin-bottom:6px}
.article-cta{margin-top:40px;background:linear-gradient(135deg,var(--c-primary-pale),#f0f6ff);border-radius:var(--r-lg);padding:32px;text-align:center}
.article-cta h3{font-family:var(--ff-serif);font-size:1.15rem;font-weight:700;color:var(--c-navy);margin-bottom:10px}
.article-cta p{font-size:.88rem;color:var(--c-text-light);margin-bottom:20px}
.article-cta-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
/* サイドバー */
.article-sidebar{position:sticky;top:88px}
.sidebar-widget{background:#fff;border:1px solid var(--c-gray-200);border-radius:var(--r-md);padding:20px;margin-bottom:16px}
.sidebar-title{font-size:.85rem;font-weight:700;color:var(--c-navy);margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--c-gray-200)}
.sidebar-cat-list{display:flex;flex-direction:column;gap:8px}
.sidebar-cat-list a{font-size:.84rem;color:var(--c-text-light);transition:color .2s;display:flex;align-items:center;gap:6px}
.sidebar-cat-list a::before{content:'›';color:var(--c-primary);font-weight:700}
.sidebar-cat-list a:hover{color:var(--c-primary)}
.sidebar-campaign{background:linear-gradient(135deg,var(--c-accent-pale),#fff4e6);border-color:var(--c-accent);text-align:center}
.sidebar-campaign-label{font-size:.78rem;font-weight:700;color:var(--c-accent-hover);margin-bottom:6px}
.sidebar-campaign-price{font-family:var(--ff-display);font-size:1.1rem;margin-bottom:12px;color:var(--c-navy)}
.sidebar-campaign-price del{color:var(--c-text-muted);font-size:.85rem}
.sidebar-info{font-size:.82rem;color:var(--c-text-light);line-height:1.7}
@media(max-width:1024px){.article-layout{grid-template-columns:1fr}.article-sidebar{position:static;display:grid;grid-template-columns:repeat(3,1fr);gap:12px}@media(max-width:768px){.article-sidebar{grid-template-columns:1fr}}}

/* ============================================
   お問い合わせページ
   ============================================ */
.contact-tel-section{padding:32px 0;background:var(--c-white)}
.contact-tel-box{display:flex;align-items:center;justify-content:space-between;gap:24px;background:linear-gradient(135deg,var(--c-primary-pale),#f0f6ff);border-radius:var(--r-lg);padding:28px 36px;border:1px solid rgba(43,125,233,.1)}
.contact-tel-text h2{font-family:var(--ff-serif);font-size:1.15rem;font-weight:700;color:var(--c-navy);margin-bottom:4px}
.contact-tel-text p{font-size:.88rem;color:var(--c-text-light)}
.contact-tel-num{font-family:var(--ff-display);font-size:1.6rem;font-weight:800;color:var(--c-primary);display:flex;align-items:center;gap:8px}
.contact-tel-num .icon{font-size:1.3rem}
.contact-tel-hours{font-size:.75rem;color:var(--c-text-muted);display:block;margin-top:4px;text-align:right}
.s-contact-form{padding:var(--section-py) 0;background:linear-gradient(180deg,#fff 0%,#f8fbff 100%);position:relative;overflow:hidden}
.s-contact-form::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:url('../images/bg/bg-diagonal-blue.jpg') center/cover no-repeat;opacity:.06;pointer-events:none}
.contact-form-wrap{max-width:700px;margin:0 auto;background:#fff;border-radius:var(--r-lg);padding:40px;box-shadow:var(--shadow-md);border:1px solid var(--c-gray-200);position:relative;z-index:1}
.contact-form-title{font-family:var(--ff-serif);font-size:1.2rem;font-weight:700;color:var(--c-navy);margin-bottom:8px;text-align:center}
.contact-form-note{font-size:.82rem;color:var(--c-text-muted);text-align:center;margin-bottom:28px}
.contact-error{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:14px 18px;border-radius:var(--r-sm);font-size:.88rem;margin-bottom:20px}
.form-group{margin-bottom:20px}
.form-label{display:block;font-size:.86rem;font-weight:600;color:var(--c-navy);margin-bottom:6px}
.required-mark{color:#dc2626;font-weight:700;margin-left:2px}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px 16px;border:1.5px solid var(--c-gray-200);border-radius:var(--r-sm);font-family:var(--ff-sans);font-size:.9rem;color:var(--c-text);transition:border-color .2s;background:#fff}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--c-primary);box-shadow:0 0 0 3px rgba(43,125,233,.1)}
.form-group textarea{resize:vertical;min-height:120px}
.form-group select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b7c93' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:40px}
.form-privacy{margin-top:24px}
.form-checkbox{display:flex;align-items:center;gap:10px;cursor:pointer;font-size:.86rem;color:var(--c-text)}
.form-checkbox input{width:20px;height:20px;accent-color:var(--c-primary);cursor:pointer}
.form-privacy-link{color:var(--c-primary);font-weight:600;text-decoration:underline}
.form-submit{margin-top:28px;text-align:center}
.btn-submit{padding:16px 60px;font-size:1rem;border:none;cursor:pointer;font-family:var(--ff-sans)}
.btn-submit .icon{font-size:1.1em;margin-right:6px}
/* 送信完了 */
.contact-complete{text-align:center;padding:60px 20px;max-width:500px;margin:0 auto}
.contact-complete-icon{width:64px;height:64px;border-radius:50%;background:var(--c-green-pale);color:var(--c-green);display:flex;align-items:center;justify-content:center;margin:0 auto 20px;font-size:2rem}
.contact-complete h2{font-family:var(--ff-serif);font-size:1.3rem;font-weight:700;color:var(--c-navy);margin-bottom:12px}
.contact-complete p{font-size:.9rem;color:var(--c-text-light);line-height:1.8}
/* 個人情報保護方針 */
.s-privacy{padding:var(--section-py) 0;background:var(--c-gray-100)}
.privacy-box{max-width:800px;margin:0 auto;background:#fff;border-radius:var(--r-lg);padding:36px;border:1px solid var(--c-gray-200)}
.privacy-box h2{font-family:var(--ff-serif);font-size:1.15rem;font-weight:700;color:var(--c-navy);margin-bottom:16px}
.privacy-content{font-size:.84rem;color:var(--c-text-light);line-height:1.9}
.privacy-content h3{font-size:.9rem;font-weight:700;color:var(--c-navy);margin:16px 0 6px}
@media(max-width:768px){
  .contact-tel-box{flex-direction:column;text-align:center;padding:24px 20px}
  .contact-tel-hours{text-align:center}
  .contact-form-wrap{padding:24px 20px}
  .btn-submit{width:100%}
}

/* ============================================
   ブログ一覧ページ
   ============================================ */
.blog-cats{padding:24px 0;background:var(--c-white);border-bottom:1px solid var(--c-gray-200)}
.blog-cat-tabs{display:flex;gap:8px;flex-wrap:wrap}
.blog-cat-tab{padding:8px 20px;border-radius:50px;font-size:.82rem;font-weight:600;color:var(--c-text-light);border:1.5px solid var(--c-gray-200);transition:all .2s;background:var(--c-white)}
.blog-cat-tab:hover,.blog-cat-tab.active{background:var(--c-primary);color:#fff;border-color:var(--c-primary)}
.s-blog-list{padding:var(--section-py) 0;background:linear-gradient(180deg,#fff 0%,#f8fbff 100%);position:relative;overflow:hidden}
.s-blog-list::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:url('../images/bg/bg-wave-white.jpg') center/cover no-repeat;opacity:.08;pointer-events:none}
.blog-list-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;position:relative;z-index:1}
.blog-list-card{display:flex;flex-direction:column;background:#fff;border-radius:var(--r-md);overflow:hidden;border:1px solid var(--c-gray-200);transition:all .35s var(--ease-out)}
.blog-list-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--c-primary-pale)}
.blog-list-card-img{height:180px;overflow:hidden;background:var(--c-gray-100)}
.blog-list-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s var(--ease-out)}
.blog-list-card:hover .blog-list-card-img img{transform:scale(1.04)}
.blog-list-card-placeholder{height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--c-primary-pale),var(--c-bg-cream));color:var(--c-primary);font-size:2.5rem;opacity:.3}
.blog-list-card-body{padding:20px;flex:1;display:flex;flex-direction:column}
.blog-list-cat{display:inline-block;font-size:.68rem;font-weight:700;color:var(--c-primary);background:var(--c-primary-pale);padding:3px 10px;border-radius:50px;margin-bottom:8px;width:fit-content}
.blog-list-date{font-size:.72rem;color:var(--c-text-muted);margin-bottom:8px;font-family:var(--ff-display);display:block}
.blog-list-card-body h2{font-size:.9rem;font-weight:700;color:var(--c-navy);line-height:1.6;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
@media(max-width:1024px){.blog-list-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:768px){.blog-list-grid{grid-template-columns:1fr}.blog-cat-tabs{gap:6px}.blog-cat-tab{padding:6px 14px;font-size:.78rem}}

/* ============================================
   ブログ記事ページ
   ============================================ */
.page-hero-sm{padding:100px 0 36px}
.s-article{padding:var(--section-py) 0;background:var(--c-white)}
.article-layout{display:grid;grid-template-columns:1fr 300px;gap:40px;align-items:start}
.article-meta{display:flex;align-items:center;gap:12px;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid var(--c-gray-200)}
.article-meta time{font-size:.78rem;color:var(--c-text-muted);font-family:var(--ff-display)}
.article-content{font-size:.92rem;color:var(--c-text);line-height:2}
.article-content h2{font-family:var(--ff-serif);font-size:1.3rem;font-weight:700;color:var(--c-navy);margin:32px 0 16px;padding:12px 18px;background:var(--c-primary-pale);border-left:4px solid var(--c-primary);border-radius:0 var(--r-sm) var(--r-sm) 0}
.article-content h3{font-size:1.1rem;font-weight:700;color:var(--c-navy);margin:24px 0 12px;padding-left:14px;border-left:3px solid var(--c-accent)}
.article-content p{margin-bottom:16px}
.article-content blockquote{margin:20px 0;padding:16px 20px;background:var(--c-gray-100);border-left:4px solid var(--c-gray-300);border-radius:0 var(--r-sm) var(--r-sm) 0;color:var(--c-text-light);font-style:italic}
.article-content ul,.article-content ol{margin:16px 0;padding-left:24px}
.article-content li{margin-bottom:8px}
.article-content img{border-radius:var(--r-md);margin:20px 0;box-shadow:var(--shadow-sm)}
.article-cta{margin-top:40px;padding:32px;background:linear-gradient(135deg,var(--c-primary-pale),var(--c-bg-cream));border-radius:var(--r-lg);text-align:center}
.article-cta h3{font-family:var(--ff-serif);font-size:1.2rem;font-weight:700;color:var(--c-navy);margin-bottom:10px;line-height:1.6}
.article-cta p{font-size:.88rem;color:var(--c-text-light);margin-bottom:20px}
.article-cta-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.article-sidebar{position:sticky;top:88px}
.sidebar-widget{background:#fff;border-radius:var(--r-md);border:1px solid var(--c-gray-200);padding:20px;margin-bottom:20px}
.sidebar-widget h4{font-size:.85rem;font-weight:700;color:var(--c-navy);margin-bottom:12px;padding-bottom:8px;border-bottom:2px solid var(--c-primary)}
.sidebar-widget ul{display:flex;flex-direction:column;gap:8px}
.sidebar-widget a{font-size:.84rem;color:var(--c-text-light);transition:color .2s}
.sidebar-widget a:hover{color:var(--c-primary)}
.sidebar-campaign{background:var(--c-accent-pale);border-radius:var(--r-sm);padding:16px;text-align:center}
.sidebar-campaign-price{font-family:var(--ff-display);font-size:1.1rem;font-weight:800;color:var(--c-accent);margin-bottom:4px}
.sidebar-campaign p{font-size:.82rem;color:var(--c-text-light);margin-bottom:10px}
@media(max-width:1024px){.article-layout{grid-template-columns:1fr}.article-sidebar{position:static;display:grid;grid-template-columns:repeat(2,1fr);gap:16px}}
@media(max-width:768px){.article-sidebar{grid-template-columns:1fr}.page-hero-sm{padding:80px 0 24px}}

/* ============================================
   お問い合わせページ
   ============================================ */
.s-contact{padding:var(--section-py) 0;background:linear-gradient(180deg,#fff 0%,#f8fbff 100%);position:relative;overflow:hidden}
.s-contact::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:url('../images/bg/bg-diagonal-blue.jpg') center/cover no-repeat;opacity:.06;pointer-events:none}
.contact-layout{display:grid;grid-template-columns:1fr 320px;gap:40px;align-items:start;position:relative;z-index:1}
.contact-form-card{background:#fff;border-radius:var(--r-lg);border:1px solid var(--c-gray-200);padding:32px;box-shadow:var(--shadow-card)}
.contact-form-note{display:flex;align-items:center;gap:10px;font-size:.85rem;color:var(--c-text-light);background:var(--c-accent-pale);padding:14px 18px;border-radius:var(--r-sm);margin-bottom:24px}
.contact-form-note .icon{font-size:1.3rem;flex-shrink:0}
.form-group{margin-bottom:20px}
.form-label{display:block;font-size:.85rem;font-weight:600;color:var(--c-navy);margin-bottom:6px}
.form-required{font-size:.7rem;color:#fff;background:var(--c-accent);padding:2px 8px;border-radius:3px;margin-left:6px;font-weight:700;vertical-align:middle}
.form-input,.form-select,.form-textarea{width:100%;padding:12px 16px;border:1.5px solid var(--c-gray-200);border-radius:var(--r-sm);font-family:var(--ff-sans);font-size:.9rem;color:var(--c-text);transition:border-color .2s;background:var(--c-white);appearance:none}
.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--c-primary);box-shadow:0 0 0 3px rgba(43,125,233,.1)}
.form-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:40px}
.form-textarea{resize:vertical;min-height:120px}
.form-privacy{margin-top:24px}
.form-checkbox{display:flex;align-items:center;gap:10px;cursor:pointer;font-size:.85rem;color:var(--c-text-light)}
.form-checkbox input{width:18px;height:18px;accent-color:var(--c-primary);cursor:pointer}
.form-submit{margin-top:28px;text-align:center}
.btn-submit{padding:16px 60px;font-size:1rem;gap:10px}
.contact-errors{background:#fef2f2;border:1px solid #fecaca;border-radius:var(--r-sm);padding:16px 20px;margin-bottom:20px}
.contact-errors p{font-size:.85rem;color:#dc2626;margin-bottom:4px}
.contact-errors p:last-child{margin-bottom:0}
.contact-thanks{text-align:center;padding:60px 20px;background:#fff;border-radius:var(--r-lg);border:1px solid var(--c-gray-200);box-shadow:var(--shadow-card)}
.contact-thanks h2{font-family:var(--ff-serif);font-size:1.4rem;font-weight:700;color:var(--c-navy);margin:16px 0 12px}
.contact-thanks p{font-size:.9rem;color:var(--c-text-light);line-height:1.8}
.contact-sidebar{position:sticky;top:88px}
.contact-side-card{background:#fff;border-radius:var(--r-md);border:1px solid var(--c-gray-200);padding:24px;margin-bottom:16px;box-shadow:var(--shadow-card)}
.contact-side-card h3{font-size:.9rem;font-weight:700;color:var(--c-navy);margin-bottom:10px;display:flex;align-items:center;gap:6px}
.contact-side-card h3 .icon{font-size:1.1rem}
.contact-side-tel{display:block;font-family:var(--ff-display);font-size:1.4rem;font-weight:800;color:var(--c-primary);margin-bottom:6px}
.contact-side-card p{font-size:.82rem;color:var(--c-text-light);line-height:1.7}
.contact-side-campaign{background:var(--c-accent-pale);border-color:transparent}
.contact-campaign-price{font-family:var(--ff-display);font-size:1.2rem;font-weight:800;color:var(--c-accent)}
@media(max-width:1024px){.contact-layout{grid-template-columns:1fr}.contact-sidebar{position:static;display:grid;grid-template-columns:repeat(3,1fr);gap:12px}}
@media(max-width:768px){.contact-sidebar{grid-template-columns:1fr}.contact-form-card{padding:20px}.btn-submit{width:100%}}

/* ============================================
   体験キャンペーンページ
   ============================================ */
.s-campaign-detail{padding:var(--section-py) 0;background:var(--c-white);position:relative;overflow:hidden}
.s-campaign-detail::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:url('../images/bg/bg-wave-white.jpg') center/cover no-repeat;opacity:.1;pointer-events:none}
.campaign-detail-box{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center;position:relative;z-index:1}
.campaign-detail-img{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-md);border:3px solid #fff}
.campaign-detail-img img{width:100%;display:block}
.campaign-detail-body{}
.campaign-detail-tag{display:inline-block;background:var(--c-accent-pale);color:var(--c-accent-hover);font-size:.78rem;font-weight:700;padding:6px 16px;border-radius:50px;margin-bottom:12px}
.campaign-detail-body h2{font-family:var(--ff-serif);font-size:1.5rem;font-weight:700;color:var(--c-navy);margin-bottom:12px}
.campaign-detail-price{font-family:var(--ff-display);font-size:1.8rem;margin-bottom:8px;color:var(--c-navy)}
.campaign-detail-price del{font-size:.8em;color:var(--c-text-muted);margin-right:6px}
.campaign-detail-price strong{color:var(--c-accent);font-weight:800}
.campaign-detail-price small{font-size:.45em;font-weight:400;color:var(--c-text-light);font-family:var(--ff-sans)}
.campaign-detail-note{font-size:.82rem;color:var(--c-text-muted);margin-bottom:16px}
.campaign-detail-body p{font-size:.9rem;color:var(--c-text-light);line-height:1.9}
.s-campaign-features{padding:var(--section-py) 0;background:linear-gradient(180deg,#f8fbff 0%,#f4f8ff 100%);position:relative;overflow:hidden}
.s-campaign-features::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:url('../images/bg/bg-diagonal-blue.jpg') center/cover no-repeat;opacity:.08;pointer-events:none}
.campaign-features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;position:relative;z-index:1}
.campaign-feature-card{background:#fff;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--c-gray-200);transition:all .35s var(--ease-out)}
.campaign-feature-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.campaign-feature-img{height:180px;overflow:hidden}
.campaign-feature-img img{width:100%;height:100%;object-fit:cover}
.campaign-feature-body{padding:22px}
.campaign-feature-body h3{font-size:1rem;font-weight:700;color:var(--c-navy);margin-bottom:8px}
.campaign-feature-body p{font-size:.84rem;color:var(--c-text-light);line-height:1.85}
.s-campaign-courses{padding:var(--section-py) 0;background:var(--c-white);position:relative;overflow:hidden}
.s-campaign-courses::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:url('../images/bg/bg-diagonal-gray.jpg') center/cover no-repeat;opacity:.08;pointer-events:none}
@media(max-width:768px){.campaign-detail-box{grid-template-columns:1fr}.campaign-features-grid{grid-template-columns:1fr}}

/* ============================================
   運営会社ページ
   ============================================ */
.s-company-intro{padding:var(--section-py) 0;background:var(--c-white);position:relative;overflow:hidden}
.s-company-intro::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:url('../images/bg/bg-wave-white.jpg') center/cover no-repeat;opacity:.08;pointer-events:none}
.company-intro-layout{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center;position:relative;z-index:1}
.company-intro-img{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-md);border:3px solid #fff}
.company-intro-img img{width:100%;display:block}
.company-intro-text h2{font-family:var(--ff-serif);font-size:1.35rem;font-weight:700;color:var(--c-navy);margin-bottom:16px;line-height:1.6}
.company-intro-text p{font-size:.9rem;color:var(--c-text-light);line-height:2;margin-bottom:12px}
.s-company-info{padding:var(--section-py) 0;background:linear-gradient(180deg,#f8fbff 0%,#f4f8ff 100%);position:relative;overflow:hidden}
.s-company-info::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:url('../images/bg/bg-diagonal-blue.jpg') center/cover no-repeat;opacity:.06;pointer-events:none}
.company-table-wrap{max-width:800px;margin:0 auto;position:relative;z-index:1}
.company-table{width:100%;border-collapse:collapse;background:#fff;border-radius:var(--r-md);overflow:hidden;box-shadow:var(--shadow-sm)}
.company-table tr{border-bottom:1px solid var(--c-gray-200)}
.company-table th,.company-table td{padding:16px 20px;font-size:.88rem;text-align:left;vertical-align:top}
.company-table th{font-weight:600;color:var(--c-navy);background:var(--c-gray-100);width:140px}
.company-table td{color:var(--c-text-light);line-height:1.7}
.s-company-history{padding:var(--section-py) 0;background:var(--c-white);position:relative;overflow:hidden}
.s-company-history::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:url('../images/bg/bg-diagonal-gray.jpg') center/cover no-repeat;opacity:.08;pointer-events:none}
.history-timeline{max-width:700px;margin:0 auto;position:relative;z-index:1;padding-left:32px;border-left:3px solid var(--c-primary-pale)}
.history-item{position:relative;padding:0 0 28px 28px}
.history-item:last-child{padding-bottom:0}
.history-item::before{content:'';position:absolute;left:-39px;top:4px;width:14px;height:14px;border-radius:50%;background:var(--c-primary);border:3px solid var(--c-primary-pale)}
.history-year{font-family:var(--ff-display);font-size:1rem;font-weight:800;color:var(--c-primary);margin-bottom:4px}
.history-text{font-size:.9rem;color:var(--c-text-light);line-height:1.7}
.s-company-access{padding:var(--section-py) 0;background:linear-gradient(170deg,#f0f6ff 0%,#e8f1fd 100%);position:relative;overflow:hidden}
.s-company-access::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:url('../images/bg/bg-blue-lines.jpg') center/cover no-repeat;opacity:.08;pointer-events:none}
.s-company-group{padding:var(--section-py) 0;background:var(--c-white);position:relative;overflow:hidden}
.s-company-group::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:url('../images/bg/bg-diagonal-gray2.jpg') center/cover no-repeat;opacity:.08;pointer-events:none}
.company-group-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;max-width:800px;margin:0 auto;position:relative;z-index:1}
.company-group-card{background:#fff;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--c-gray-200);transition:all .35s var(--ease-out)}
.company-group-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.company-group-card img{width:100%;height:160px;object-fit:cover}
.company-group-body{padding:20px}
.company-group-body h3{font-size:1rem;font-weight:700;color:var(--c-navy);margin-bottom:6px}
.company-group-body p{font-size:.82rem;color:var(--c-text-light)}
@media(max-width:768px){.company-intro-layout{grid-template-columns:1fr}.company-group-grid{grid-template-columns:1fr}}

/* ============================================
   採用情報ページ
   ============================================ */
.s-recruit-summary{padding:var(--section-py) 0;background:var(--c-white);position:relative;overflow:hidden}
.s-recruit-summary::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:url('../images/bg/bg-wave-white.jpg') center/cover no-repeat;opacity:.08;pointer-events:none}
.recruit-summary-box{max-width:800px;margin:0 auto;position:relative;z-index:1}
.recruit-summary-header{text-align:center;margin-bottom:24px}
.recruit-summary-header h2{font-family:var(--ff-serif);font-size:1.3rem;font-weight:700;color:var(--c-navy)}
.s-recruit-message{padding:var(--section-py) 0;background:linear-gradient(180deg,#f8fbff 0%,#f4f8ff 100%);position:relative;overflow:hidden}
.s-recruit-message::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:url('../images/bg/bg-diagonal-blue.jpg') center/cover no-repeat;opacity:.06;pointer-events:none}
.recruit-message-layout{display:grid;grid-template-columns:.4fr .6fr;gap:36px;align-items:center;position:relative;z-index:1}
.recruit-message-img{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-md);border:3px solid #fff}
.recruit-message-img img{width:100%;display:block}
.recruit-message-text h2{font-family:var(--ff-serif);font-size:1.35rem;font-weight:700;color:var(--c-navy);margin-bottom:16px}
.recruit-message-text p{font-size:.9rem;color:var(--c-text-light);line-height:2;margin-bottom:12px}
.s-recruit-photos{padding:var(--section-py) 0;background:var(--c-white)}
.recruit-photos-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.recruit-photos-grid img{border-radius:var(--r-md);width:100%;height:200px;object-fit:cover;box-shadow:var(--shadow-sm)}
.s-recruit-detail{padding:var(--section-py) 0;background:linear-gradient(170deg,#faf8f5 0%,#f5f0e8 100%);position:relative;overflow:hidden}
.s-recruit-detail::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:url('../images/bg/bg-diagonal-gray2.jpg') center/cover no-repeat;opacity:.08;pointer-events:none}
@media(max-width:768px){.recruit-message-layout{grid-template-columns:1fr}.recruit-photos-grid{grid-template-columns:1fr}}

/* ============================================
   図面事例セクション (Works)
   ============================================ */
.s-works{padding:var(--section-py) 0;background:linear-gradient(170deg,#f8fbff 0%,#f0f6ff 100%);position:relative;overflow:hidden}
.s-works::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:url('../images/bg/bg-diagonal-blue.jpg') center/cover no-repeat;opacity:.05;pointer-events:none}
.works-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;position:relative;z-index:1}
.works-card{background:var(--c-white);border-radius:var(--r-lg);padding:36px 28px;box-shadow:var(--shadow-sm);border:1px solid rgba(0,0,0,.06);transition:transform .3s,box-shadow .3s}
.works-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.works-card-icon{width:52px;height:52px;border-radius:12px;background:linear-gradient(135deg,var(--c-cyan),var(--c-primary));display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.works-card-icon .icon{width:26px;height:26px;stroke:white;fill:none;stroke-width:1.5}
.works-card h3{font-size:1.15rem;font-weight:700;color:var(--c-navy);margin-bottom:10px}
.works-card p{font-size:.88rem;color:var(--c-text-light);line-height:1.85}
.works-note{position:relative;z-index:1}
@media(max-width:768px){.works-grid{grid-template-columns:1fr;gap:20px}.works-card{padding:28px 22px}}
