/* ====== ベース ====== */
:root{
  --yt-red:#FF0000;
  --yt-red-d:#cc0000;
  --orange:#F17A32;
  --yellow:#FFD123;
  --ink:#2b2b2b;
  --gray:#666;
  --bg:#fffdf8;
  --bg-soft:#fff6ec;
  --radius:22px;
  --shadow:0 10px 30px rgba(0,0,0,.08);
  --shadow-strong:0 14px 40px rgba(241,122,50,.25);
}
*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;scroll-padding-top:80px;overflow-x:hidden;}
body{
  font-family:"M PLUS Rounded 1c","Hiragino Maru Gothic ProN",sans-serif;
  color:var(--ink);
  background:var(--bg);
  line-height:1.85;
  font-size:16px;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  width:100%;
  max-width:100vw;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
.container{max-width:1080px;margin:0 auto;padding:0 20px;width:100%;}
.pc-only{display:inline;}
.sp-only{display:none;}

/* ====== ヘッダー ====== */
.site-header{
  position:fixed;top:0;left:0;width:100%;z-index:1000;
  background:rgba(255,255,255,.96);
  backdrop-filter:blur(8px);
  box-shadow:0 2px 14px rgba(0,0,0,.06);
  transition:.3s;
  overflow-x:hidden;
}
.header-inner{
  max-width:1180px;margin:0 auto;padding:10px 20px;
  display:flex;align-items:center;gap:20px;
  width:100%;
}
.header-logo img{height:46px;width:auto;}
.header-nav{margin-left:auto;display:flex;gap:22px;}
.header-nav a{font-weight:700;font-size:.95rem;position:relative;transition:.2s;}
.header-nav a:hover{color:var(--orange);}
.header-nav a::after{content:"";position:absolute;left:0;bottom:-4px;width:0;height:3px;background:var(--orange);border-radius:3px;transition:.25s;}
.header-nav a:hover::after{width:100%;}
.header-cta{
  background:var(--yt-red);color:#fff;font-weight:800;
  padding:11px 22px;border-radius:999px;font-size:.95rem;
  box-shadow:0 6px 16px rgba(255,0,0,.3);transition:.2s;white-space:nowrap;
}
.header-cta:hover{transform:translateY(-2px);background:var(--yt-red-d);}
.header-line{
  background:#06C755;color:#fff;font-weight:800;
  padding:11px 20px;border-radius:999px;font-size:.95rem;
  box-shadow:0 6px 16px rgba(6,199,85,.3);transition:.2s;white-space:nowrap;
}
.header-line i{margin-right:4px;}
.header-line:hover{transform:translateY(-2px);background:#05a948;}
.nav-toggle{display:none;background:none;border:0;font-size:1.6rem;color:var(--ink);cursor:pointer;}
.mobile-nav{display:none;flex-direction:column;background:#fff;border-top:1px solid #f0e9df;}
.mobile-nav a{padding:14px 24px;font-weight:700;border-bottom:1px solid #f5efe6;}
.mobile-nav .mobile-cta{background:var(--yt-red);color:#fff;text-align:center;border:0;}
.mobile-nav .mobile-cta-line{background:#06C755;}
.mobile-nav.open{display:flex;}

/* ====== ヒーロー ====== */
.hero{
  position:relative;overflow:hidden;
  padding:130px 20px 70px;
  width:100%;
  background:
    radial-gradient(circle at 15% 20%, rgba(255,209,35,.25), transparent 45%),
    radial-gradient(circle at 85% 80%, rgba(241,122,50,.22), transparent 45%),
    linear-gradient(135deg,#fff7ed 0%,#fff1f1 100%);
}
.hero-inner{
  max-width:1080px;margin:0 auto;
  display:grid;grid-template-columns:1.05fr .95fr;gap:46px;align-items:center;
  position:relative;z-index:2;
  width:100%;
}
.hero-badges{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:18px;}
.badge{
  background:#fff;border:2px solid var(--orange);color:var(--orange);
  font-weight:800;font-size:.82rem;padding:6px 14px;border-radius:999px;
  display:inline-flex;align-items:center;gap:6px;box-shadow:0 4px 10px rgba(241,122,50,.12);
}
.badge i{color:var(--orange);}
.hero-pre{
  display:inline-block;background:var(--yellow);color:#7a4b00;font-weight:800;
  padding:7px 18px;border-radius:999px;font-size:1rem;margin-bottom:16px;
  transform:rotate(-1.5deg);box-shadow:0 5px 0 rgba(0,0,0,.06);
}
.hero-title{
  font-family:"Mochiy Pop One",sans-serif;
  font-size:clamp(2rem,4.4vw,3.1rem);line-height:1.35;font-weight:400;
  letter-spacing:.01em;color:var(--ink);margin-bottom:18px;
}
.hero-title .hl{
  color:var(--yt-red);
  background:linear-gradient(transparent 62%, rgba(255,209,35,.6) 62%);
  padding:0 .1em;
}
.hero-sub{font-size:1rem;color:#444;margin-bottom:28px;font-weight:500;}
.hero-cta-wrap{display:flex;flex-wrap:wrap;gap:14px;align-items:center;}
.btn-line{
  display:inline-flex;align-items:center;gap:8px;
  background:#06C755;color:#fff;font-family:"Mochiy Pop One",sans-serif;font-size:1.05rem;
  padding:16px 28px;border-radius:999px;
  box-shadow:0 8px 0 #04923f,0 14px 24px rgba(6,199,85,.3);transition:.15s;
}
.btn-line:hover{transform:translateY(4px);box-shadow:0 4px 0 #04923f,0 8px 16px rgba(6,199,85,.3);}
.btn-line:active{transform:translateY(8px);box-shadow:0 0 0 #04923f;}
.hero-visual{position:relative;}
.play-card{
  position:relative;border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow-strong);border:6px solid #fff;
}
.play-card img{width:100%;aspect-ratio:4/3;object-fit:cover;}
.play-btn{
  position:absolute;inset:0;margin:auto;width:78px;height:78px;
  background:var(--yt-red);border-radius:18px;display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:1.9rem;box-shadow:0 8px 24px rgba(255,0,0,.45);
  animation:pulse 2.2s infinite;
}
@keyframes pulse{0%,100%{transform:scale(1);}50%{transform:scale(1.08);}}

/* 浮遊アイコン */
.hero-bg-deco,.cv-bg-deco{position:absolute;inset:0;z-index:1;pointer-events:none;overflow:hidden;}
.float-icon{position:absolute;opacity:.18;color:var(--orange);}
.float-icon.f1{top:12%;left:6%;font-size:3rem;color:var(--yt-red);animation:float 6s ease-in-out infinite;}
.float-icon.f2{top:70%;left:10%;font-size:2.2rem;color:var(--yellow);opacity:.5;animation:float 5s ease-in-out infinite .5s;}
.float-icon.f3{top:24%;right:8%;font-size:2.4rem;animation:float 7s ease-in-out infinite 1s;}
.float-icon.f4{bottom:14%;right:14%;font-size:2rem;color:var(--yellow);opacity:.5;animation:float 5.5s ease-in-out infinite;}
.float-icon.f5{top:50%;left:48%;font-size:2.6rem;animation:float 8s ease-in-out infinite;}
@keyframes float{0%,100%{transform:translateY(0) rotate(0);}50%{transform:translateY(-18px) rotate(8deg);}}

/* ====== ボタン ====== */
.btn-main{
  display:inline-flex;flex-direction:column;align-items:center;
  background:var(--yt-red);color:#fff;font-family:"Mochiy Pop One",sans-serif;
  font-size:1.25rem;padding:18px 38px;border-radius:999px;
  box-shadow:0 8px 0 var(--yt-red-d),0 14px 24px rgba(255,0,0,.3);
  transition:.15s;line-height:1.4;text-align:center;
}
.btn-main i{margin-right:6px;}
.btn-main .btn-sub{font-family:"M PLUS Rounded 1c",sans-serif;font-size:.8rem;font-weight:700;opacity:.95;margin-top:2px;}
.btn-main:hover{transform:translateY(4px);box-shadow:0 4px 0 var(--yt-red-d),0 8px 16px rgba(255,0,0,.3);}
.btn-main:active{transform:translateY(8px);box-shadow:0 0 0 var(--yt-red-d);}

/* ====== セクション共通 ====== */
.section{padding:78px 0;width:100%;overflow-x:hidden;}
.section-head{text-align:center;margin-bottom:46px;}
.sec-label{
  display:inline-block;font-family:"Mochiy Pop One",sans-serif;
  color:var(--orange);letter-spacing:.18em;font-size:.85rem;margin-bottom:8px;
}
.sec-title{
  font-family:"Mochiy Pop One",sans-serif;font-weight:400;
  font-size:clamp(1.6rem,3.4vw,2.4rem);line-height:1.4;
}
.sec-title .u-orange{color:var(--orange);}
.u-orange{color:var(--orange);}
.sec-lead{margin-top:14px;color:var(--gray);font-weight:500;}

/* ====== お悩み ====== */
.worries{background:var(--bg-soft);}
.worry-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;}
.worry-col{background:#fff;border-radius:var(--radius);padding:30px;box-shadow:var(--shadow);border-top:6px solid var(--orange);}
.worry-col.kids{border-top-color:var(--yellow);}
.worry-head{font-size:1.2rem;color:var(--orange);margin-bottom:16px;display:flex;align-items:center;gap:10px;}
.worry-col.kids .worry-head{color:#d9a200;}
.worry-list{list-style:none;}
.worry-list li{position:relative;padding-left:30px;margin-bottom:14px;font-weight:500;}
.worry-list li::before{content:"\f4ad";font-family:"Font Awesome 6 Free";font-weight:900;position:absolute;left:0;top:2px;color:var(--orange);}
.worry-col.kids .worry-list li::before{color:var(--yellow);}
.worry-answer{
  margin-top:34px;text-align:center;background:#fff;border-radius:var(--radius);
  padding:32px;box-shadow:var(--shadow);border:3px dashed var(--orange);
}
.worry-answer .big{font-family:"Mochiy Pop One",sans-serif;color:var(--yt-red);font-size:1.4rem;margin-bottom:8px;}
.worry-answer b{color:var(--orange);}

/* ====== ソフト ====== */
.soft-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.soft-card{
  background:#fff;border-radius:var(--radius);padding:34px 26px;text-align:center;
  box-shadow:var(--shadow);transition:.25s;border:1px solid #f3ebe0;
}
.soft-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-strong);}
.soft-icon{
  display:inline-flex;align-items:center;justify-content:center;
  width:74px;height:74px;border-radius:20px;font-size:2rem;color:#fff;margin-bottom:16px;
  background:linear-gradient(135deg,var(--orange),var(--yellow));
}
.soft-card h3{font-size:1.15rem;line-height:1.5;margin-bottom:12px;}
.soft-card p{font-size:.95rem;color:#555;font-weight:500;}
.soft-note{text-align:center;margin-top:26px;color:var(--gray);font-size:.92rem;}
.soft-note i{color:var(--orange);}

/* ====== 作品例 ====== */
.works{background:#1f1f1f;color:#fff;}
.works .sec-title,.works .sec-lead{color:#fff;}
.works .sec-label{color:var(--yellow);}
.works-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.work-card{background:#2b2b2b;border-radius:16px;overflow:hidden;transition:.25s;box-shadow:0 10px 30px rgba(0,0,0,.4);}
.work-card:hover{transform:translateY(-6px);}
.thumb{position:relative;aspect-ratio:16/9;overflow:hidden;}
.thumb img{width:100%;height:100%;object-fit:cover;transition:.4s;}
.work-card:hover .thumb img{transform:scale(1.06);}
.thumb-play{
  position:absolute;inset:0;margin:auto;width:58px;height:42px;background:var(--yt-red);
  border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.3rem;
  opacity:.92;box-shadow:0 6px 16px rgba(0,0,0,.4);
}
.thumb-no{position:absolute;left:10px;top:10px;background:var(--yellow);color:#3a2400;font-weight:800;font-size:.78rem;padding:3px 10px;border-radius:6px;}
.work-body{padding:20px;}
.work-body h3{font-size:1.08rem;margin-bottom:8px;display:flex;align-items:center;gap:8px;}
.work-body h3 i{color:var(--yellow);}
.work-body p{font-size:.92rem;color:#cfcfcf;font-weight:500;}

/* ====== 特徴 ====== */
.feature-list{max-width:880px;margin:0 auto;display:flex;flex-direction:column;gap:22px;}
.feature-row{
  display:flex;gap:22px;align-items:flex-start;background:#fff;border-radius:var(--radius);
  padding:28px 30px;box-shadow:var(--shadow);border-left:8px solid var(--orange);
}
.feature-num{
  font-family:"Mochiy Pop One",sans-serif;font-size:2rem;color:var(--orange);
  background:var(--bg-soft);width:64px;height:64px;border-radius:16px;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.feature-text h3{font-size:1.15rem;margin-bottom:8px;color:var(--ink);}
.feature-text p{font-weight:500;color:#555;}
.feature-text b{color:var(--yt-red);background:linear-gradient(transparent 60%,rgba(255,209,35,.5) 60%);}

/* ====== 準備 ====== */
.prepare{background:var(--bg-soft);}
.prepare-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.prepare-card{background:#fff;border-radius:var(--radius);padding:30px 24px;box-shadow:var(--shadow);text-align:center;}
.prepare-icon{
  display:inline-flex;align-items:center;justify-content:center;width:66px;height:66px;
  border-radius:50%;background:var(--yt-red);color:#fff;font-size:1.6rem;margin-bottom:14px;
}
.prepare-card h3{font-size:1.1rem;margin-bottom:10px;}
.prepare-card p{font-size:.92rem;color:#555;font-weight:500;}
.prepare-tip{margin-top:10px;background:var(--bg-soft);border-radius:12px;padding:10px 12px;color:#a86a1e!important;font-size:.86rem;}
.prepare-tip i{color:var(--yellow);}

/* ====== カリキュラム ====== */
.flow-steps{max-width:760px;margin:0 auto;list-style:none;position:relative;}
.flow-steps::before{content:"";position:absolute;left:32px;top:20px;bottom:20px;width:4px;background:repeating-linear-gradient(var(--orange) 0 8px,transparent 8px 16px);}
.flow-steps li{display:flex;gap:22px;align-items:flex-start;margin-bottom:24px;position:relative;}
.flow-step-no{
  flex-shrink:0;width:68px;height:68px;border-radius:50%;background:#fff;border:4px solid var(--orange);
  color:var(--orange);font-family:"Mochiy Pop One",sans-serif;font-size:.78rem;
  display:flex;align-items:center;justify-content:center;z-index:2;box-shadow:var(--shadow);
}
.flow-steps li>div{background:#fff;border-radius:var(--radius);padding:18px 24px;box-shadow:var(--shadow);flex:1;}
.flow-steps h3{font-size:1.1rem;margin-bottom:4px;color:var(--orange);}
.flow-steps p{font-weight:500;color:#555;}

/* ====== インストラクター ====== */
.instructor-card{
  display:grid;grid-template-columns:300px 1fr;gap:36px;align-items:center;
  background:#fff;border-radius:var(--radius);padding:36px;box-shadow:var(--shadow);
  border:1px solid #f3ebe0;
}
.instructor-photo img{border-radius:18px;width:100%;box-shadow:var(--shadow);}
.instructor-name{text-align:center;margin-top:14px;font-size:1.05rem;}
.instructor-name b{color:var(--orange);}
.instructor-msg p{margin-bottom:14px;font-weight:500;color:#444;}
.instructor-msg b{color:var(--yt-red);}

/* ====== 料金 ====== */
.price-block{background:#fff;border-radius:var(--radius);padding:30px;box-shadow:var(--shadow);margin-bottom:24px;}
.price-h{font-size:1.25rem;color:var(--orange);margin-bottom:14px;display:flex;align-items:center;gap:10px;}
.price-note-top{color:#555;font-weight:500;margin-bottom:18px;}
.time-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
.time-card{
  background:var(--bg-soft);border-radius:16px;padding:18px;text-align:center;border:2px solid #ffe2c2;
}
.time-label{display:inline-block;background:var(--orange);color:#fff;font-weight:800;font-size:.8rem;padding:3px 14px;border-radius:999px;margin-bottom:8px;}
.time-val{display:block;font-family:"Mochiy Pop One",sans-serif;font-size:1.25rem;color:var(--ink);}
.time-min{font-size:.85rem;color:var(--gray);}
.price-mini{margin-top:14px;color:var(--gray);font-size:.88rem;text-align:right;}
.price-cols{display:grid;grid-template-columns:1fr 1.4fr;gap:24px;}
.price-cols .price-block{margin-bottom:0;}
.grade-big{font-family:"Mochiy Pop One",sans-serif;font-size:1.5rem;color:var(--yt-red);text-align:center;padding:18px 0;}
.fee-table{width:100%;border-collapse:collapse;}
.fee-table th,.fee-table td{padding:14px 12px;border-bottom:1px dashed #eadfce;text-align:left;}
.fee-table th{width:38%;color:var(--orange);font-size:.98rem;}
.fee-table td{font-family:"Mochiy Pop One",sans-serif;font-size:1.05rem;}
.fee-table small{font-family:"M PLUS Rounded 1c";font-size:.78rem;color:var(--gray);font-weight:600;}
.fee-note{font-family:"M PLUS Rounded 1c";font-size:.78rem;color:var(--gray);font-weight:600;}

/* ====== FAQ ====== */
.faq{background:var(--bg-soft);}
.faq-list{max-width:820px;margin:0 auto;}
.faq-item{background:#fff;border-radius:16px;margin-bottom:14px;overflow:hidden;box-shadow:var(--shadow);}
.faq-q{
  width:100%;text-align:left;border:0;background:none;cursor:pointer;
  font-family:"M PLUS Rounded 1c";font-weight:700;font-size:1.02rem;color:var(--ink);
  padding:20px 56px 20px 56px;position:relative;line-height:1.6;
}
.faq-q::before{content:"Q";position:absolute;left:18px;top:18px;background:var(--yt-red);color:#fff;width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-family:"Mochiy Pop One";font-size:.9rem;}
.faq-q i{position:absolute;right:20px;top:22px;color:var(--orange);transition:.3s;}
.faq-item.open .faq-q i{transform:rotate(180deg);}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease;}
.faq-a p{padding:0 22px 22px 56px;position:relative;color:#555;font-weight:500;}
.faq-a p::before{content:"A";position:absolute;left:18px;top:0;background:var(--yellow);color:#7a4b00;width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-family:"Mochiy Pop One";font-size:.9rem;}
.faq-a b{color:var(--yt-red);}

/* ====== アクセス ====== */
.access-grid{display:grid;grid-template-columns:1fr 1fr;gap:30px;align-items:stretch;}
.access-info{background:#fff;border-radius:var(--radius);padding:30px;box-shadow:var(--shadow);}
.access-info dl{display:grid;grid-template-columns:auto 1fr;gap:14px 18px;}
.access-info dt{font-weight:800;color:var(--orange);white-space:nowrap;}
.access-info dd{font-weight:500;}
.access-info dd a{color:var(--yt-red);font-weight:800;}
.access-info dd small{color:var(--gray);}
.access-caution{margin-top:18px;background:var(--bg-soft);border-radius:12px;padding:14px;font-size:.88rem;color:#a86a1e;}
.access-caution i{color:var(--yt-red);}
.access-map{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);min-height:340px;}
.access-map iframe{width:100%;height:100%;min-height:340px;border:0;}

/* ====== 入会の流れ ====== */
.join-steps{display:flex;align-items:stretch;justify-content:center;gap:14px;flex-wrap:wrap;}
.join-card{flex:1;min-width:230px;max-width:300px;background:#fff;border-radius:var(--radius);padding:30px 24px;text-align:center;box-shadow:var(--shadow);border-top:6px solid var(--orange);}
.join-no{display:inline-flex;align-items:center;justify-content:center;width:54px;height:54px;border-radius:50%;background:var(--yt-red);color:#fff;font-family:"Mochiy Pop One";font-size:1.5rem;margin-bottom:14px;}
.join-card h3{font-size:1.1rem;margin-bottom:10px;}
.join-card p{font-weight:500;color:#555;font-size:.93rem;}
.join-arrow{display:flex;align-items:center;color:var(--orange);font-size:1.6rem;}

/* ====== 最終CV ====== */
.cv{position:relative;overflow:hidden;text-align:center;color:#fff;
  background:linear-gradient(135deg,var(--orange) 0%,var(--yt-red) 100%);
  padding:80px 20px;
}
.cv .container{position:relative;z-index:2;}
.cv-bg-deco .float-icon{opacity:.16;color:#fff;}
.cv-bg-deco .c1{top:18%;left:10%;font-size:3rem;}
.cv-bg-deco .c2{bottom:18%;right:14%;font-size:2.4rem;}
.cv-bg-deco .c3{top:30%;right:8%;font-size:2.2rem;}
.cv-pre{display:inline-block;background:var(--yellow);color:#7a4b00;font-weight:800;padding:6px 20px;border-radius:999px;margin-bottom:16px;}
.cv-title{font-family:"Mochiy Pop One";font-weight:400;font-size:clamp(1.7rem,4vw,2.6rem);line-height:1.4;margin-bottom:18px;}
.cv-note{font-weight:700;margin-bottom:30px;}
.cv-note i{color:var(--yellow);}
.cv-btns{display:flex;gap:20px;justify-content:center;flex-wrap:wrap;}
.btn-white{background:#fff;color:var(--yt-red);box-shadow:0 8px 0 #d6d6d6,0 14px 24px rgba(0,0,0,.2);}
.btn-white:hover{transform:translateY(4px);box-shadow:0 4px 0 #d6d6d6,0 8px 16px rgba(0,0,0,.2);}
.btn-white .btn-sub{color:#cc0000;opacity:.9;}
.btn-tel{background:#1f1f1f;box-shadow:0 8px 0 #000,0 14px 24px rgba(0,0,0,.3);}
.btn-tel:hover{transform:translateY(4px);box-shadow:0 4px 0 #000,0 8px 16px rgba(0,0,0,.3);}
.btn-line-cv{background:#06C755;box-shadow:0 8px 0 #04923f,0 14px 24px rgba(6,199,85,.3);}
.btn-line-cv:hover{transform:translateY(4px);box-shadow:0 4px 0 #04923f,0 8px 16px rgba(6,199,85,.3);}
.btn-line-cv:active{transform:translateY(8px);box-shadow:0 0 0 #04923f;}

/* ====== フッター ====== */
.site-footer{background:#1f1f1f;color:#ddd;padding:50px 0 30px;text-align:center;}
.footer-logo{height:50px;margin:0 auto 18px;background:#fff;padding:10px 16px;border-radius:14px;}
.footer-addr{font-size:.9rem;line-height:1.9;margin-bottom:20px;}
.footer-nav{display:flex;gap:20px;justify-content:center;flex-wrap:wrap;margin-bottom:24px;}
.footer-nav a{font-size:.9rem;font-weight:700;transition:.2s;}
.footer-nav a:hover{color:var(--yellow);}
.copyright{font-size:.8rem;color:#888;}

/* ====== 追従CTA ====== */
.floating-cta-wrap{
  display:none;position:fixed;bottom:0;left:0;width:100%;z-index:900;
  box-shadow:0 -4px 16px rgba(0,0,0,.2);
}
.floating-cta{
  flex:1;text-align:center;font-family:"Mochiy Pop One";
  font-size:1rem;padding:15px 6px;color:#fff;background:var(--yt-red);
}
.floating-cta i{margin-right:4px;}
.floating-line{background:#06C755;}

/* ====== レスポンシブ ====== */
@media(max-width:920px){
  .header-nav{display:none;}
  .nav-toggle{display:block;margin-left:auto;}
  .hero-inner{grid-template-columns:1fr;text-align:center;}
  .hero-badges,.hero-cta-wrap{justify-content:center;}
  .hero-visual{order:-1;max-width:100%;margin:0 auto;}
  .pc-only{display:none;}
  .sp-only{display:inline;}
  .hero{padding:110px 16px 56px;}
  .hero-cta-wrap{flex-direction:column;align-items:center;}
  .btn-line{width:100%;max-width:340px;justify-content:center;}
}
@media(max-width:780px){
  .worry-grid,.soft-grid,.works-grid,.prepare-grid,.price-cols{grid-template-columns:1fr;}
  .access-grid{grid-template-columns:1fr;}
  .instructor-card{grid-template-columns:1fr;text-align:center;}
  .instructor-photo{max-width:280px;margin:0 auto;}
  .join-arrow{transform:rotate(90deg);}
  .header-cta,.header-line{display:none;}
  .floating-cta-wrap{display:flex;}
  body{padding-bottom:60px;}
  .section{padding:56px 0;}
  .feature-row{flex-direction:column;align-items:center;text-align:center;}
  .feature-num{margin:0 auto;}
  .cv-btns{flex-direction:column;align-items:center;}
  .btn-main{width:100%;max-width:340px;}
  .container{padding:0 16px;}
  .flow-steps::before{left:28px;}
  .flow-step-no{width:58px;height:58px;font-size:.72rem;}
  .hero-pre{font-size:.9rem;padding:6px 14px;}
  .hero-title{font-size:clamp(1.7rem,7vw,2.2rem);}
}
@media(max-width:480px){
  .hero{padding:100px 14px 50px;}
  .time-grid{grid-template-columns:1fr;}
  .header-logo img{height:36px;}
  .header-inner{padding:10px 14px;gap:12px;}
  .section{padding:46px 0;}
  .badge{font-size:.76rem;padding:5px 10px;}
  .faq-q{font-size:.95rem;padding:18px 46px 18px 50px;}
  .feature-row{padding:20px 18px;}
  .worry-col,.prepare-card,.soft-card{padding:22px 18px;}
  .price-block{padding:22px 16px;}
  .instructor-card{padding:22px 18px;}
  .join-card{padding:22px 16px;}
  .flow-steps li>div{padding:14px 16px;}
}
