:root{--green-900: #0b5a49;--green-600: #167a64;--green-100: #e6f3ef;--yellow-500: #f4c842;--yellow-300: #ffe082;--text-900: #222;--text-600: #4b5563;--bg: #ffffff;--border: #e5e7eb}*{box-sizing:border-box}html,body,#app{min-height:100%}html{scroll-behavior:smooth}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,PingFang SC,Noto Sans SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;color:var(--text-900);background:var(--bg)}img{max-width:100%}.container{width:min(1100px,92vw);margin:0 auto}.site-header{position:sticky;top:0;z-index:20;background:#fffffff5;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:0 2px 8px #0000000f}.header-inner{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 0}.logo{font-weight:700;color:var(--green-900);letter-spacing:.5px}.nav{display:flex;flex-wrap:wrap;justify-content:flex-end}.nav a{margin-left:12px;text-decoration:none;color:var(--text-600);padding:8px 10px;border-radius:8px;transition:background-color .2s ease,color .2s ease}.nav a:hover{background:var(--green-100);color:var(--green-900)}.hero{padding:72px 0 36px;background:radial-gradient(1200px 380px at 50% -80px,var(--yellow-300),transparent 70%)}.hero-inner{text-align:center}.hero h1{font-size:clamp(24px,5vw,44px);margin:0}.hero .accent{color:#ef6c00;margin-right:6px}.hero .sub{color:var(--text-600);margin:12px 0 26px}.brands-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:22px}.brand-card{background:#fff;border:1px solid #eee;border-radius:16px;padding:18px 12px;text-align:center;box-shadow:0 6px 14px #0000000f;transition:transform .2s ease,box-shadow .2s ease}.brand-card:hover{transform:translateY(-4px);box-shadow:0 10px 18px #00000014}.brand-icon{font-size:0;line-height:1}.icon-img{width:56px;height:56px;object-fit:contain;display:inline-block}.brand-name{margin-top:8px;font-weight:600;color:var(--green-900)}.section{padding:64px 0}.section-title{position:relative;display:inline-block;margin:0 0 16px;font-size:28px;color:var(--green-900)}.section-title:after{content:"";display:block;width:48px;height:4px;background:var(--yellow-500);border-radius:4px;margin-top:8px}.section-striped{background:linear-gradient(180deg,var(--green-100) 0,#fff 100%)}.center{text-align:center;color:var(--text-600)}.two-col{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}.icon-box{width:48px;height:48px;border-radius:12px;background:var(--yellow-300);display:inline-flex;align-items:center;justify-content:center;font-size:24px;margin-bottom:8px}.two-col p,.growth-text p,.art-right p,.stepbook-text p,.contact p,.site-footer>div p{color:var(--text-600);line-height:1.8}.contact{display:flex;flex-direction:column;gap:0}.contact p{margin:0}.section-green{background:linear-gradient(180deg,#edf8f4 0,#f8fcfa)}.growth-wrap{display:grid;grid-template-columns:340px 1fr;gap:32px;align-items:center}.growth-card,.module-visual{display:flex;align-items:center;justify-content:center;min-height:240px;width:100%;max-width:320px;margin:0 auto}.module-logo{width:100%;max-width:280px;height:auto;max-height:180px;object-fit:contain;display:block}.module-logo-growth,.module-logo-art,.module-logo-mym,.module-logo-stepbook,.module-logo-snail{max-width:300px}.growth-text strong,.legal-strong{color:var(--green-900);font-weight:600}.section-art{background:#fff}.art-wrap{display:grid;grid-template-columns:1fr 360px;gap:24px;align-items:center}.art-left{display:flex;align-items:center;justify-content:center;min-height:320px;order:2}.art-right{order:1}.mym-wrap,.snail-wrap{display:grid;grid-template-columns:280px 1fr;gap:24px;align-items:start}.section-stepbook{position:relative;background:#f5fffb;overflow:hidden}.stepbook-wrap{position:relative;min-height:360px;display:grid;grid-template-columns:1fr 280px;gap:24px;align-items:center}.stepbook-wrap .module-visual{order:2}.stepbook-text{order:1}.section-snail{background:#fff7e6}.highlight,.legal-highlight{color:#2563eb;font-weight:500}.btn{display:inline-block;margin-top:16px;background:var(--green-600);color:#fff;text-decoration:none;padding:10px 16px;border-radius:10px;box-shadow:0 4px 10px #0000001f}.btn:hover{background:var(--green-900)}.campus-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:20px;margin-top:16px}.campus{border:1px solid #eee;border-radius:12px;padding:16px;box-shadow:0 6px 14px #0000000a}.campus h3{margin:0 0 10px;color:var(--green-600)}.campus ul{padding-left:18px;margin:0;color:var(--text-600);line-height:1.8}.site-footer{background:#f8fafc;padding:28px 0;border-top:1px solid #eee}.footer-inner{display:flex;align-items:center;justify-content:space-between;gap:24px}.footer-brand{display:flex;flex-direction:column;gap:0}.footer-brand p{margin:0}.contact a{color:var(--green-900);text-decoration:none}.footer-divider{display:inline-block;margin:0 8px;color:#94a3b8}.legal-page{padding:24px 16px 32px;background-color:#fff;min-height:100vh}.legal-container{max-width:960px;margin:0 auto;padding:0 0 8px}.legal-title{font-size:26px;font-weight:700;text-align:center;margin-bottom:8px;color:#111827}.legal-meta{text-align:left;font-size:13px;color:#6b7280;margin-bottom:24px}.legal-meta-line{margin-bottom:2px}.legal-section-title{margin-top:24px;margin-bottom:8px;font-size:18px;font-weight:600;color:#111827}.legal-section-subtitle{margin-top:16px;margin-bottom:8px;font-size:15px;font-weight:500;color:#111827}.legal-text{font-size:14px;line-height:1.8;color:#374151;margin-bottom:4px;text-align:justify}.legal-list{margin:4px 0 8px 1.2em;padding-left:.6em}.legal-list li{font-size:14px;line-height:1.8;color:#374151;margin-bottom:2px}.legal-footer{margin-top:32px;padding-top:16px;border-top:1px dashed var(--border);font-size:13px;color:#6b7280}.legal-table-wrapper{margin-top:8px;margin-bottom:8px;overflow-x:auto}.legal-table{width:100%;border-collapse:collapse;font-size:13px}.legal-table th,.legal-table td{border:1px solid var(--border);padding:6px 8px;text-align:left;vertical-align:top}.legal-table th{background-color:#f3f4f6;font-weight:600;color:#111827}@media(max-width:900px){.header-inner,.footer-inner{flex-direction:column;align-items:flex-start}.nav{justify-content:flex-start}.nav a{margin-left:0;margin-right:8px}.brands-grid{grid-template-columns:repeat(2,1fr)}.growth-wrap,.two-col,.campus-grid,.art-wrap,.stepbook-wrap,.mym-wrap,.snail-wrap{grid-template-columns:1fr}.art-left,.stepbook-wrap .module-visual{order:initial}.growth-card,.module-visual{max-width:240px}.module-logo{width:100%;max-width:240px;max-height:140px}}@media(min-width:768px){.legal-container{padding:40px 48px 48px}.legal-title{font-size:28px}}
