:root{--bg: #fcf8f6;--surface: rgba(255, 255, 255, .78);--surface-strong: #fffdfc;--line: rgba(98, 76, 78, .16);--text: #3e3a39;--muted: #6f6664;--primary: #e0a7b4;--primary-deep: #c78395;--accent: #8a6a63;--soft: #f4e2e7;--shadow: 0 24px 60px rgba(115, 84, 92, .12);--radius-xl: 32px;--radius-lg: 24px;--radius-md: 18px;--shell: min(1120px, calc(100vw - 32px) )}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:Hiragino Sans,Noto Sans JP,Yu Gothic,sans-serif;color:var(--text);background:radial-gradient(circle at top left,rgba(224,167,180,.24),transparent 32%),linear-gradient(180deg,#fffaf8 0%,var(--bg) 45%,#f8f0ed 100%);line-height:1.7}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}.shell{width:var(--shell);margin:0 auto}.site-header{position:sticky;top:0;z-index:10;backdrop-filter:blur(18px);background:#fcf8f6c2;border-bottom:1px solid rgba(98,76,78,.08)}.header-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;min-height:78px;padding:12px 0}.brand{display:grid;gap:2px}.brand-mark,h1,h2,h3{font-family:A1明朝,Yu Mincho,Hiragino Mincho ProN,serif;letter-spacing:.04em}.brand-mark{font-size:.82rem;color:var(--primary-deep);text-transform:uppercase}.brand-name{font-size:.96rem;font-weight:600}.main-nav{display:flex;flex-wrap:nowrap;justify-content:center;gap:8px;flex:1;min-width:0}.nav-link{padding:8px 12px;color:var(--muted);border-radius:999px;font-size:.92rem;white-space:nowrap}.nav-link.is-active,.nav-link:hover{color:var(--text);background:#e0a7b424}.mobile-menu-toggle,.mobile-menu-close{font:inherit;border:0;appearance:none;-webkit-appearance:none}.mobile-menu-toggle,.mobile-menu-panel,.mobile-menu-backdrop{display:none}.header-cta,.button-primary,.button-secondary{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:48px;padding:0 20px;border-radius:999px;transition:transform .2s ease,box-shadow .2s ease,background .2s ease}.header-cta,.button-primary{color:#fff;background:linear-gradient(135deg,#cf8fa0,var(--primary));box-shadow:0 12px 24px #c783952e}.button-secondary{color:var(--accent);background:#ffffff8f;border:1px solid rgba(98,76,78,.12)}.header-cta:hover,.button-primary:hover,.button-secondary:hover{transform:translateY(-1px)}section{padding:48px 0}#about-section{scroll-margin-top:108px}.eyebrow{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;color:var(--primary-deep);background:#e0a7b41f;font-size:.85rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase}.section-heading{display:grid;gap:12px;max-width:680px;margin-bottom:28px}.section-heading h2,.section-heading h1{margin:0;font-size:clamp(2rem,4vw,3.5rem);line-height:1.2}.section-heading p{margin:0;color:var(--muted);font-size:1rem}.section-title-line{display:block;white-space:nowrap}.section-title-mobile{display:none}.why-heading h2{max-width:15em;font-size:clamp(1.9rem,3.4vw,3rem);line-height:1.28;text-wrap:balance}.why-title-line{display:block}.card-grid{display:grid;gap:20px}.card-grid.cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.card-grid.cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.card,.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow)}.card{padding:24px;min-width:0}.panel{padding:32px;min-width:0}.kicker{color:var(--primary-deep);font-size:.9rem;font-weight:700}.hero{padding:56px 0 44px}.hero-grid{display:grid;grid-template-columns:minmax(0,1.28fr) minmax(320px,.72fr);grid-template-areas:"copy visual" "note visual";gap:18px;align-items:stretch}.hero-copy{grid-area:copy;padding:40px 34px 26px;background:linear-gradient(180deg,#ffffffd9,#fffaf8d1),linear-gradient(135deg,rgba(224,167,180,.15),transparent);border:1px solid var(--line);border-radius:var(--radius-xl);box-shadow:var(--shadow)}.hero-copy h1{margin:18px 0;font-size:clamp(2rem,3.1vw,3rem);line-height:1.28;letter-spacing:0;text-wrap:balance;max-width:none}.hero-copy p{color:var(--muted);margin:0;max-width:29rem;font-size:.98rem;text-wrap:pretty}.hero-lead{display:grid;gap:4px}.hero-lead span{display:block}.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:26px}.hero-note{grid-area:note;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.hero-note .card{background:#ffffff42;box-shadow:var(--shadow);border-radius:18px;padding:14px 14px 12px;border-color:#624c4e14}.hero-actions .button-secondary{min-width:220px;border-color:#c7839533;background:#ffffffd1;box-shadow:0 10px 24px #73545c14}.visual-placeholder{display:grid;align-content:end;min-height:100%;padding:28px;color:var(--text);background:linear-gradient(160deg,#e0a7b429,#ffffffc2),linear-gradient(180deg,#fff8f54d,#8a6a631f);border:1px solid var(--line);border-radius:var(--radius-xl);box-shadow:var(--shadow);overflow:hidden;position:relative;min-height:520px;min-width:0}.visual-placeholder:before,.visual-placeholder:after{content:"";position:absolute;border-radius:999px;background:#ffffff57}.visual-placeholder:before{width:240px;height:240px;top:-60px;right:-40px}.visual-placeholder:after{width:180px;height:180px;bottom:-40px;left:-20px}.visual-placeholder strong{font-size:1.2rem}.visual-placeholder p{color:var(--muted);margin:10px 0 0}.feature-image{border:1px solid var(--line);border-radius:var(--radius-xl);box-shadow:var(--shadow);overflow:hidden;background:#ffffffb8}.feature-image img{width:100%;height:100%;object-fit:cover;aspect-ratio:4 / 5}.hero-visual{grid-area:visual;position:relative}.hero-visual img{aspect-ratio:1 / 1;object-position:48% center}.hero-title-line{display:block;white-space:nowrap}.hero-title-line.tight{white-space:normal}.hero-title-line.balance{white-space:normal;max-width:11em}.pill-list,.plain-list{display:flex;flex-wrap:wrap;gap:10px;padding:0;margin:0;list-style:none}.pill-list li{padding:10px 14px;border-radius:999px;background:#e0a7b424;color:var(--accent);font-weight:600}.plain-list{display:grid;gap:12px}.stat{display:grid;gap:4px}.stat strong{font-size:1.08rem;color:var(--primary-deep)}.stat .kicker{font-size:.75rem;letter-spacing:.02em}.stat .muted{font-size:.9rem}.cta-band{padding:28px 32px;display:flex;flex-wrap:wrap;gap:16px;align-items:center;justify-content:space-between}.cta-actions{display:grid;gap:16px;justify-items:end}.cta-social{display:grid;gap:10px;justify-items:end}.cta-social-copy{margin:0;color:var(--muted);font-size:.94rem}.cta-social-links{display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-end}.social-button{min-height:42px;padding:0 16px}.social-button img,.footer-social-list img{width:18px;height:18px;flex:0 0 auto}.access-card strong{display:block;margin-bottom:10px;font-size:1.24rem;line-height:1.45;color:var(--primary-deep)}.access-card-image{margin:-2px 0 14px;border-radius:16px;overflow:hidden;border:1px solid rgba(98,76,78,.08);background:#fff9}.access-card-image img{width:100%;height:auto;aspect-ratio:16 / 9;object-fit:cover;display:block}.post-card h3,.faq-item h3,.course-card h3,.recruit-card h3{margin-top:10px;margin-bottom:10px;font-size:1.25rem}.voice-quote{position:relative;margin-top:0;margin-bottom:12px;padding-left:18px}.voice-quote:before{content:"“";position:absolute;left:4px;top:-.08em;font-size:1.05em;color:var(--text)}.voice-quote:after{content:"”";margin-left:.12em;color:var(--text)}.voice-signature{display:inline-block;font-size:.89rem;color:#624c4e9e;letter-spacing:.02em}.recruit-lead{max-width:860px;margin:0 0 22px}.recruit-grid{align-items:stretch}.recruit-card{min-height:auto;max-width:920px}.recruit-card .muted{line-height:1.78}.recruit-points{display:grid;gap:12px;margin:14px 0 0;padding:0;list-style:none}.recruit-points li{position:relative;padding-left:18px;color:var(--muted);line-height:1.82}.recruit-points li:before{content:"";position:absolute;left:0;top:.78em;width:7px;height:7px;border-radius:50%;background:#c78395cc;transform:translateY(-50%)}.recruit-more{display:flex;justify-content:flex-start}.post-card .kicker{font-size:.98rem;font-weight:700}.blog-section-head{max-width:860px}.blog-section-head h2{font-size:clamp(1.9rem,3.4vw,3rem);line-height:1.24}.blog-more{display:flex;justify-content:flex-end}.course-card{scroll-snap-align:start}.course-card-button{margin-top:18px;align-self:flex-start}.course-carousel-area{display:grid}.course-carousel-controls{display:none}.course-carousel-dots{display:flex;align-items:center;justify-content:center;gap:8px}.course-carousel-dot{width:8px;height:8px;border-radius:999px;background:#c7839538;transition:background .2s ease,transform .2s ease}.course-carousel-dot.is-active{background:var(--primary-deep);transform:scale(1.1)}.course-carousel-arrow{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:999px;border:1px solid rgba(98,76,78,.12);background:#ffffffdb;box-shadow:0 10px 20px #73545c14;cursor:pointer;color:var(--accent);transition:opacity .2s ease,transform .2s ease,background .2s ease}.course-carousel-arrow:hover{transform:translateY(-1px)}.course-carousel-arrow:disabled{opacity:.42;cursor:default;transform:none}.course-carousel-arrow span{display:inline-block;width:10px;height:10px;border-top:1.7px solid currentColor;border-right:1.7px solid currentColor}.course-carousel-arrow.is-prev span{transform:rotate(-135deg);margin-left:4px}.course-carousel-arrow.is-next span{transform:rotate(45deg);margin-right:4px}.teacher-panel{max-width:920px;padding-bottom:28px}.teacher-section-head{margin-bottom:28px}.teacher-intro{display:flex;align-items:center;gap:24px;margin-bottom:18px}.teacher-intro h2{margin:0;font-size:clamp(2rem,3.5vw,3rem);line-height:1.24}.teacher-title-line{display:block}.teacher-avatar{width:152px;height:152px;flex:0 0 152px;border-radius:50%;object-fit:cover;object-position:center 28%;border:6px solid rgba(255,255,255,.86);box-shadow:0 16px 34px #73545c24}.teacher-name{margin-top:10px;font-size:.95rem}.teacher-lead{margin:0 0 18px;max-width:42rem}.teacher-highlights{grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.teacher-highlight{padding:20px 20px 18px;min-height:198px;box-shadow:0 16px 34px #73545c14;background:#ffffff8f;border-color:#c783951f}.teacher-highlight-kicker{display:inline-block;margin-bottom:4px}.teacher-highlight h3{margin:10px 0;font-size:1.16rem;line-height:1.52}.teacher-highlight .muted{font-size:.96rem;line-height:1.78}.teacher-cta-row{display:flex;justify-content:flex-start}.teacher-cta-row .button-secondary{min-width:220px;border-color:#c7839533;background:#ffffffe6;box-shadow:0 12px 26px #73545c14;font-weight:700}.flow-grid{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(256px,1fr);gap:18px;overflow-x:auto;padding:4px 18px 8px 4px;scroll-snap-type:x proximity;-webkit-overflow-scrolling:touch;scrollbar-width:thin;align-items:stretch}.flow-section-head{display:grid;gap:10px;max-width:760px;margin-bottom:22px}.flow-section-head h2{margin:0;font-size:clamp(1.9rem,3.4vw,3rem);line-height:1.22}.flow-section-head p{margin:0}.flow-card{position:relative;min-height:100%;scroll-snap-align:start}.flow-card:not(:last-child):after{content:"";position:absolute;right:-12px;top:50%;width:22px;height:22px;border-top:1.5px solid rgba(199,131,149,.5);border-right:1.5px solid rgba(199,131,149,.5);transform:translateY(-50%) rotate(45deg);border-radius:2px;pointer-events:none}.faq-more{display:flex;justify-content:flex-end}.why-card{padding:18px 24px;min-height:148px}.why-card-image{margin:-2px 0 14px;border-radius:16px;overflow:hidden;border:1px solid rgba(98,76,78,.08);background:#fff9}.why-card-image img{width:100%;height:auto;aspect-ratio:16 / 9;object-fit:cover;display:block}.why-card h3{margin:0 0 10px;font-size:1.05rem;line-height:1.55}.why-card .muted{font-size:.94rem;line-height:1.7}.muted{color:var(--muted)}.split{display:grid;grid-template-columns:1fr 1fr;gap:24px}.button-row{display:flex;gap:12px;flex-wrap:wrap}[data-reveal]{opacity:0;transform:translateY(24px);transition:opacity .8s cubic-bezier(.22,1,.36,1),transform .8s cubic-bezier(.22,1,.36,1);transition-delay:var(--reveal-delay, 0ms);will-change:opacity,transform}[data-reveal].is-visible{opacity:1;transform:translateY(0)}@media(prefers-reduced-motion:reduce){[data-reveal]{opacity:1;transform:none;transition:none}}.site-footer{margin-top:48px;padding:40px 0 56px;border-top:1px solid rgba(98,76,78,.08);background:#ffffff7a}.mobile-fixed-cta-wrap{display:none}.mobile-fixed-cta-wrap[hidden]{display:none!important}.mobile-fixed-cta{display:none}.footer-grid{display:grid;grid-template-columns:1.2fr 1fr .8fr .9fr;gap:24px}.footer-title,.footer-heading{margin:0 0 10px;font-weight:700}.footer-copy{margin:0;color:var(--muted)}.footer-list{margin:0;padding:0;list-style:none;display:grid;gap:12px;color:var(--muted)}.footer-social-list a{display:inline-flex;align-items:center;gap:8px;min-height:36px;padding:0 12px;border-radius:999px;background:#e0a7b41f;color:var(--accent);font-weight:600}@media(min-width:961px){.header-inner{gap:18px}.brand{flex:0 0 224px}.header-cta{flex:0 0 auto;min-width:136px}}@media(max-width:960px){#about-section{scroll-margin-top:132px}.mobile-fixed-cta-wrap{display:block!important;position:fixed;left:0;right:0;bottom:0;z-index:1010;padding:10px 12px calc(10px + env(safe-area-inset-bottom));pointer-events:none}.mobile-fixed-cta{display:flex!important;align-items:center;justify-content:center;min-height:54px;width:auto;margin:0;padding:0 20px;border-radius:999px;color:#fff;background:linear-gradient(135deg,#cf8fa0,var(--primary));box-shadow:0 14px 30px #c783953d;font-weight:700;letter-spacing:.01em;pointer-events:auto}.hero-grid,.split,.footer-grid,.card-grid.cols-2,.card-grid.cols-3{grid-template-columns:1fr}.header-inner{flex-direction:column;align-items:stretch;min-height:auto}.desktop-nav{flex-wrap:wrap;justify-content:flex-start;width:100%}.hero-copy,.panel,.card{padding:24px}.hero-note{grid-template-columns:1fr}.teacher-intro{align-items:flex-start}.teacher-highlights{grid-template-columns:1fr}.flow-card:not(:last-child):after{right:50%;top:auto;bottom:-12px;transform:translate(50%) rotate(135deg)}.flow-grid{grid-auto-flow:row;grid-auto-columns:unset;overflow-x:visible;padding:0;scroll-snap-type:none}.faq-more{justify-content:flex-start}main{padding-bottom:calc(86px + env(safe-area-inset-bottom))}.site-footer{padding-bottom:calc(112px + env(safe-area-inset-bottom))}}@media(max-width:640px){:root{--shell: min(100vw - 20px, 1120px);--radius-xl: 24px;--radius-lg: 20px}.site-header{z-index:1000}section{padding:32px 0}.header-inner{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;padding:12px 0 16px;align-items:start}.brand{grid-column:1 / 2;grid-row:1 / 2}.brand-name{font-size:.95rem}.desktop-nav,.desktop-cta{display:none}.mobile-menu-toggle{display:flex;align-items:center;justify-content:space-between;width:128px;min-height:52px;padding:0 18px;border-radius:999px;background:#ffffff8f;border:1px solid rgba(98,76,78,.12);color:var(--text);font-weight:600;cursor:pointer;grid-column:2 / 3;grid-row:1 / 2;justify-self:end}.mobile-menu-icon{position:relative;width:18px;height:12px;display:inline-block;border-top:1.5px solid currentColor;border-bottom:1.5px solid currentColor}.mobile-menu-icon:before{content:"";position:absolute;left:0;top:50%;width:18px;border-top:1.5px solid currentColor;transform:translateY(-50%)}body.is-mobile-menu-open .mobile-menu-backdrop{display:block;position:fixed;inset:0;background:#3e3a3929;backdrop-filter:blur(3px);z-index:999}.mobile-menu-panel{position:fixed;top:0;right:0;bottom:0;width:min(82vw,340px);padding:22px 18px 24px;background:linear-gradient(180deg,#fffcfbfa,#fcf6f4f5);box-shadow:-18px 0 40px #3e3a391f;border-left:1px solid rgba(98,76,78,.08);transform:translate(100%);transition:transform .34s cubic-bezier(.22,1,.36,1);z-index:1000;overflow-y:auto;display:block}body.is-mobile-menu-open .mobile-menu-panel{transform:translate(0)}.mobile-menu-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:18px}.mobile-menu-title{margin:0;color:var(--primary-deep);font-weight:700}.mobile-menu-close{min-height:40px;padding:0 14px;border-radius:999px;background:#ffffffc7;border:1px solid rgba(98,76,78,.12);color:var(--text);cursor:pointer}.mobile-nav{display:grid;grid-template-columns:1fr;gap:8px}.nav-link{text-align:left;padding:12px 14px;font-size:.88rem;white-space:normal;background:#ffffff75;border:1px solid rgba(98,76,78,.08)}.hero{padding-top:28px}.hero-copy{padding:24px 18px}.hero-grid{grid-template-areas:"copy" "visual" "note"}.hero-copy h1{margin:8px 0 20px;font-size:clamp(1.72rem,7.6vw,2.2rem);line-height:1.18}.hero-title-line,.hero-title-line.tight{white-space:nowrap}.hero-title-line.balance{white-space:nowrap;max-width:none}.hero-actions,.button-row{display:grid;grid-template-columns:1fr}.button-primary,.button-secondary{width:100%;min-height:52px;padding:0 16px;text-align:center}.hero-actions{margin-top:22px}.hero-actions .button-secondary{border-width:1.5px;border-color:#c7839542;background:#fffffff0;box-shadow:0 12px 26px #73545c1a;color:#7e5f59;font-weight:700}.hero-note{gap:8px}.hero-note .card{padding:12px 14px 10px;border-radius:16px;box-shadow:0 14px 30px #73545c14}.hero-note .kicker{font-size:.74rem}.hero-note .stat strong{font-size:1.16rem}.hero-note .stat .muted{font-size:.84rem;line-height:1.55}.card-grid.cols-3.course-carousel{display:grid;grid-template-columns:unset;grid-auto-flow:column;grid-auto-columns:minmax(88%,88%);overflow-x:auto;gap:14px;padding-bottom:6px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:thin;align-items:stretch}.card-grid.cols-3.course-carousel>*{width:100%;min-width:0}.course-carousel .course-card[data-reveal]{opacity:1;transform:none;transition:none;will-change:auto}.course-carousel-controls{display:flex;align-items:center;justify-content:center;gap:14px;margin-top:16px}.visual-placeholder{min-height:280px;padding:20px}.teacher-intro{flex-direction:column;gap:14px}.teacher-avatar{width:108px;height:108px;flex-basis:108px}.feature-image img{aspect-ratio:4 / 4.6}.hero-visual img{aspect-ratio:4 / 4.4;object-position:center top}.visual-placeholder:before{width:180px;height:180px;top:-50px;right:-50px}.visual-placeholder:after{width:120px;height:120px;left:-20px;bottom:-20px}.eyebrow{font-size:.75rem;padding:7px 10px}.section-heading{gap:10px;margin-bottom:20px}.section-heading h1,.section-heading h2{font-size:clamp(1.8rem,8vw,2.4rem);line-height:1.25}.section-title-line{display:inline;white-space:normal}.section-title-course .section-title-desktop{display:none}.section-title-course .section-title-mobile,.section-title-fixed-mobile .section-title-line{display:block;white-space:nowrap}.card,.panel{padding:20px 16px}.pill-list{display:grid;grid-template-columns:1fr}.pill-list li{border-radius:16px;text-align:center}.stat strong{font-size:1.3rem}.cta-band{padding:20px 16px;align-items:stretch}.cta-band>div:last-child{width:100%;display:grid;gap:12px}.cta-actions,.cta-social{justify-items:stretch}.cta-social-links{justify-content:flex-start}.footer-grid{grid-template-columns:1fr;gap:20px}}
