/* ============================================
   Thai Japanese Gymnastics Academy
   Design System v2.0 (2026-05)
   ============================================ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  /* Colors — neo-sports inspired: 青基調 × ディープネイビー × オレンジCTA */
  --navy:#1a3b8e;          /* ディープブルー（メインカラー） */
  --navy-2:#0f2960;
  --blue:#3aa9e0;          /* 明るい水色（背景・アクセント） */
  --blue-light:#9fd9f0;    /* 薄水色 */
  --blue-pale:#e8f5fc;     /* 極薄水色（ベース背景候補） */
  --red:#f08020;           /* オレンジ（CTA限定） */
  --red-2:#d96a10;
  --gold:#f5b400;          /* ゴールドアクセント（メダル系） */
  --gold-2:#dba000;
  --bg:#ffffff;
  --bg-soft:#f0f2f5;       /* ニュース行用の薄いグレー */
  --paper:#ffffff;
  --ink:#1a1a1a;
  --muted:#666666;
  --line:#e3e6eb;
  --line-2:#cfd5dd;

  /* Type — 力強いゴシック × 太字イタリック英文 */
  --font-jp:"Noto Sans JP","Hiragino Kaku Gothic ProN","Yu Gothic",Meiryo,sans-serif;
  --font-en:"Montserrat","Helvetica Neue",sans-serif;
  --font-script:"Caveat","Sacramento",cursive;

  /* Layout */
  --radius:8px;
  --radius-lg:14px;
  --shadow:0 6px 24px rgba(26,59,142,.08);
  --shadow-hover:0 14px 36px rgba(26,59,142,.14);
  --max:1180px;
}

html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-jp);
  background:var(--bg);
  color:var(--ink);
  line-height:1.85;
  font-feature-settings:"palt";
  -webkit-font-smoothing:antialiased;
  font-weight:400;
}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none;transition:.2s}
ul{list-style:none}
button{font:inherit;border:none;background:none;cursor:pointer;color:inherit}

.container{max-width:var(--max);margin:0 auto;padding:0 24px}

/* ============================================
   HEADER
   ============================================ */
.site-header{
  position:sticky;top:0;z-index:100;
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);
}
.header-inner{
  max-width:var(--max);margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 24px;gap:30px;
}
.logo{display:flex;align-items:center;gap:18px;text-decoration:none}
.logo-img{
  width:100px;height:100px;border-radius:50%;object-fit:cover;
  box-shadow:0 8px 22px rgba(26,59,142,.18);
  border:3px solid #fff;
}
.logo-text{display:flex;flex-direction:column;line-height:1.2;gap:2px}
.logo-jp{
  font-family:var(--font-jp);font-weight:900;font-size:26px;
  color:var(--navy);letter-spacing:.04em;white-space:nowrap;
}
.logo-en{
  font-family:var(--font-en);font-weight:700;font-size:12px;
  color:var(--blue);letter-spacing:.34em;
  text-transform:uppercase;margin-top:8px;font-style:italic;
}
@media(max-width:880px){
  .logo-img{width:54px;height:54px;border-width:2px;flex-shrink:0}
  .logo{gap:12px}
  .logo-jp{font-size:14.5px;letter-spacing:.02em}
  .logo-en{font-size:8.5px;letter-spacing:.16em;margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .logo-text{min-width:0;overflow:hidden}
}
@media(max-width:380px){
  .logo-img{width:48px;height:48px}
  .logo-jp{font-size:13px}
  .logo-en{font-size:8px}
}

.site-nav{display:flex;align-items:center;gap:4px}
.nav-link{
  padding:12px 18px;font-weight:700;font-size:13px;color:var(--navy);
  letter-spacing:.05em;position:relative;
}
.nav-link:hover{color:var(--red)}
.nav-link.active{color:var(--red)}
.nav-link.active::after{content:"";position:absolute;bottom:4px;left:50%;transform:translateX(-50%);width:24px;height:2px;background:var(--red)}
.nav-cta{
  margin-left:12px;padding:14px 28px;font-weight:700;font-size:13px;letter-spacing:.06em;
  background:var(--red);color:#fff!important;border-radius:50px;
  box-shadow:0 4px 14px rgba(240,128,32,.35);
}
.nav-cta:hover{background:var(--red-2);transform:translateY(-2px);box-shadow:0 8px 20px rgba(240,128,32,.45)}

.hamburger{display:none;width:42px;height:42px;flex-direction:column;justify-content:center;align-items:center;gap:5px}
.hamburger span{width:24px;height:2.5px;background:var(--navy);border-radius:2px;transition:.3s}
.hamburger.open span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}

.mobile-menu{
  position:fixed;top:74px;left:0;right:0;background:#fff;
  padding:20px 24px;box-shadow:0 14px 40px rgba(0,0,0,.12);
  display:none;flex-direction:column;gap:6px;z-index:99;
  border-bottom:1px solid var(--line);
}
.mobile-menu.open{display:flex}
.mobile-menu .nav-link{padding:14px 16px;border-radius:10px;background:var(--bg);font-size:15px}
.mobile-menu .nav-cta{margin-top:10px;text-align:center;padding:14px}

@media(max-width:880px){
  .site-nav{display:none}
  .hamburger{display:flex}
}

/* ============================================
   HERO (Full-screen slideshow)
   ============================================ */
.hero{
  position:relative;overflow:hidden;color:#fff;
  min-height:88vh;
  display:flex;align-items:center;
  background:#0a2540;
}

/* Slideshow */
.hero-slideshow{position:absolute;inset:0;z-index:0}
.hero-slide{
  position:absolute;inset:0;
  opacity:0;transition:opacity 1.6s ease-in-out;
  background-size:cover;background-position:center;
  will-change:opacity,transform;
}
.hero-slide.active{opacity:1;animation:kenburns 9s ease-out forwards}
@keyframes kenburns{
  from{transform:scale(1.04)}
  to{transform:scale(1.14)}
}

/* Dark overlay for text readability */
.hero-overlay{
  position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    radial-gradient(1200px 700px at 75% 30%,rgba(58,169,224,.18),transparent 60%),
    linear-gradient(120deg,rgba(15,41,96,.78) 0%,rgba(26,59,142,.5) 60%,rgba(58,169,224,.3) 100%),
    linear-gradient(180deg,rgba(15,41,96,.2) 0%,transparent 30%,rgba(15,41,96,.55) 100%);
}

/* Slide indicators */
.hero-indicators{
  position:absolute;bottom:28px;left:50%;transform:translateX(-50%);
  z-index:3;display:flex;gap:10px;
}
.hero-indicator{
  width:36px;height:3px;background:rgba(255,255,255,.3);
  border-radius:2px;cursor:pointer;transition:.3s;border:none;padding:0;
}
.hero-indicator.active{background:var(--gold);width:60px}
.hero-indicator:hover{background:rgba(255,255,255,.6)}

.hero-inner{
  position:relative;z-index:2;
  max-width:var(--max);margin:0 auto;
  padding:90px 24px 110px;width:100%;
}

.hero-content{max-width:880px}
.hero-eyebrow{
  font-family:var(--font-en);font-weight:900;font-style:italic;
  font-size:clamp(32px,5.5vw,68px);
  letter-spacing:.01em;line-height:1;text-transform:uppercase;
  color:#fff;margin-bottom:8px;
  text-shadow:0 4px 24px rgba(0,0,0,.5);
  animation:fadeUp .8s ease-out .2s both;
}
.hero-eyebrow .script{
  display:block;font-family:var(--font-script);font-style:normal;
  font-size:.55em;font-weight:700;color:var(--blue-light);
  text-transform:none;letter-spacing:.02em;margin-top:4px;
}

.hero-title{
  font-family:var(--font-jp);
  font-size:clamp(28px,4.4vw,52px);
  font-weight:900;line-height:1.4;letter-spacing:.02em;
  margin:24px 0 32px;
  text-shadow:0 4px 24px rgba(0,0,0,.5);
  animation:fadeUp .9s ease-out .35s both;
}
.hero-title .accent{color:var(--red)}
.hero-title .red{color:var(--red)}

.hero-body{
  font-size:clamp(15px,1.5vw,18px);line-height:1.95;opacity:.95;
  max-width:580px;margin-bottom:40px;
  text-shadow:0 2px 12px rgba(0,0,0,.3);
  animation:fadeUp .9s ease-out .5s both;
}

.hero-btns{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:48px;animation:fadeUp .9s ease-out .65s both}

.hero-stats-inline{
  display:flex;gap:36px;flex-wrap:wrap;
  padding-top:32px;border-top:1px solid rgba(255,255,255,.18);
  animation:fadeUp .9s ease-out .8s both;
}
.hero-stats-inline .item{display:flex;flex-direction:column;line-height:1.2}
.hero-stats-inline .item .num{font-family:var(--font-en);font-size:32px;font-weight:600;font-style:italic;color:var(--blue-light);text-shadow:0 2px 12px rgba(0,0,0,.4);letter-spacing:.01em}
.hero-stats-inline .item .lbl{font-size:12px;opacity:.88;letter-spacing:.05em;margin-top:4px}

@keyframes fadeUp{
  from{opacity:0;transform:translateY(28px)}
  to{opacity:1;transform:none}
}

@media(max-width:760px){
  /* スマホでは「写真→文字」の縦並びに切替（neo-sports.jp 流） */
  .hero{
    min-height:auto;
    display:block;
    background:#fff;
    color:var(--ink);
  }
  .hero-slideshow{
    position:relative;
    height:42vh;
    min-height:320px;
    max-height:380px;
    inset:auto;
  }
  /* スマホでは縦長専用写真を1枚固定表示・上部をカット */
  .hero-slide{display:none}
  .hero-slide.active{
    display:block;opacity:1!important;animation:none!important;
    background-image:url('../images/hero-mobile.png')!important;
    background-position:center 40%!important;
    background-size:cover!important;
  }
  /* 写真下に斜めの白ウェッジ：テキストと自然に繋ぐ */
  .hero-slideshow::after{
    content:"";position:absolute;left:0;right:0;bottom:-1px;height:50px;
    background:#fff;
    clip-path:polygon(0 100%,100% 0,100% 100%);
    z-index:2;
  }
  .hero-overlay{display:none}
  .hero-indicators{display:none}
  .hero-inner{
    padding:0 22px 24px;
    background:#fff;
    margin-top:-30px;     /* 写真下の白ウェッジに重ねる */
    position:relative;z-index:3;
  }
  /* テキスト色を反転：白→濃紺 */
  .hero-eyebrow{
    color:var(--navy);
    font-size:28px;
    line-height:1;
    text-shadow:none;
    margin-bottom:6px;
  }
  .hero-eyebrow .script{
    color:var(--blue);
    font-size:.55em;
    margin-top:6px;
  }
  .hero-title{
    color:var(--ink);
    font-size:20px;
    font-weight:900;
    line-height:1.5;
    text-shadow:none;
    margin:14px 0 12px;
  }
  .hero-title .accent{color:var(--red)}
  .hero-body{
    color:var(--muted);
    font-size:13px;
    line-height:1.8;
    text-shadow:none;
    margin-bottom:18px;
  }
  .hero-btns{
    flex-direction:column;
    align-items:stretch;
    margin-bottom:0;
    gap:10px;
  }
  .hero-btns .btn{padding:14px 20px;font-size:14px}
  .hero-btns .btn{width:100%}
  .hero-btns .btn-outline{
    color:var(--navy);
    border-color:var(--navy);
  }
  .hero-stats-inline{
    gap:0;
    padding-top:24px;
    border-top:1px solid var(--line);
    display:grid;
    grid-template-columns:1fr 1fr;
    column-gap:16px;
    row-gap:18px;
  }
  .hero-stats-inline .item{align-items:flex-start}
  .hero-stats-inline .item .num{
    color:var(--navy);
    font-size:26px;
    text-shadow:none;
  }
  .hero-stats-inline .item .lbl{color:var(--muted);opacity:1}
  .hero-flag::before,.hero-flag::after{display:none}
}

.hero-visual{position:relative;display:flex;flex-direction:column;align-items:center;gap:24px}
.hero-photo{
  position:relative;width:100%;aspect-ratio:4/5;border-radius:var(--radius-lg);
  overflow:hidden;box-shadow:0 30px 60px rgba(0,0,0,.4);
  border:3px solid rgba(255,255,255,.15);
}
.hero-photo img{width:100%;height:100%;object-fit:cover;object-position:center}
.hero-photo-badge{
  position:absolute;bottom:18px;left:18px;right:18px;
  background:rgba(10,37,64,.85);backdrop-filter:blur(10px);
  padding:14px 18px;border-radius:14px;
  display:flex;align-items:center;gap:12px;
  border:1px solid rgba(245,185,0,.3);
}
.hero-photo-badge img{width:38px;height:38px;border-radius:8px;flex-shrink:0}
.hero-photo-badge .txt{flex:1;line-height:1.3}
.hero-photo-badge .txt strong{display:block;font-size:13px;color:#fff;font-weight:800}
.hero-photo-badge .txt small{display:block;font-size:10px;color:var(--gold);letter-spacing:.1em;margin-top:2px}
.hero-card-title{font-weight:800;font-size:18px;margin-bottom:6px}
.hero-card-sub{font-family:var(--font-en);font-size:11px;letter-spacing:.15em;color:var(--gold);text-transform:uppercase}
.hero-card-divider{width:40px;height:2px;background:var(--gold);margin:18px auto}
.hero-card-meta{font-size:13px;opacity:.85;line-height:1.8}

.hero-stat-row{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;width:100%}
.hero-stat{
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);
  border-radius:14px;padding:18px;text-align:center;
}
.hero-stat .num{display:block;font-family:var(--font-en);font-size:30px;font-weight:900;color:var(--gold);line-height:1}
.hero-stat .lbl{display:block;font-size:11px;opacity:.8;margin-top:6px;letter-spacing:.05em}

@media(max-width:900px){
  .hero{padding:60px 24px 80px}
  .hero-inner{grid-template-columns:1fr;gap:40px;text-align:center}
  .hero-flag::before,.hero-flag::after{display:none}
  .hero-body{margin-left:auto;margin-right:auto}
  .hero-btns{justify-content:center}
}

/* ============================================
   BUTTONS
   ============================================ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:14px;
  padding:18px 44px;border-radius:50px;font-weight:700;font-size:15px;
  letter-spacing:.08em;
  transition:all .3s ease;cursor:pointer;border:2px solid transparent;
  white-space:nowrap;font-family:var(--font-jp);
  position:relative;
}
.btn-primary{background:var(--red);color:#fff;box-shadow:0 6px 20px rgba(240,128,32,.35)}
.btn-primary:hover{background:var(--red-2);transform:translateY(-3px);box-shadow:0 10px 28px rgba(240,128,32,.45)}
.btn-navy{background:var(--navy);color:#fff;box-shadow:0 6px 20px rgba(26,59,142,.3)}
.btn-navy:hover{background:var(--navy-2);transform:translateY(-3px);box-shadow:0 10px 28px rgba(26,59,142,.4)}
.btn-outline{background:transparent;color:#fff;border-color:rgba(255,255,255,.7)}
.btn-outline:hover{background:#fff;color:var(--navy);border-color:#fff}
.btn-outline-blue{background:transparent;color:var(--navy);border-color:var(--navy);padding:14px 32px;font-size:14px}
.btn-outline-blue:hover{background:var(--navy);color:#fff}
.btn-gold{background:var(--gold);color:#fff;box-shadow:0 6px 20px rgba(245,180,0,.35)}
.btn-gold:hover{background:var(--gold-2);transform:translateY(-3px)}

/* ============================================
   SECTIONS
   ============================================ */
.section{padding:110px 24px;background:#fff;position:relative}
.section--off{background:var(--blue-pale);position:relative}
.section--navy{background:linear-gradient(160deg,#1a3b8e 0%,#0f2960 100%);color:#fff;position:relative}
.section--cream{background:linear-gradient(180deg,#e8f5fc 0%,#9fd9f0 100%);position:relative}

/* === neo-sports流ダイアゴナル装飾 === */
/* HEAD COACHセクションを斜めに切る */
.section--cream{
  padding-top:140px;padding-bottom:140px;
  margin-top:-40px;margin-bottom:-40px;
  z-index:1;
  clip-path:polygon(0 40px,100% 0,100% calc(100% - 40px),0 100%);
}
/* CTA navyセクションも斜めに */
.section--navy.cta-banner{
  padding-top:140px;padding-bottom:140px;
  margin-top:-40px;
  clip-path:polygon(0 40px,100% 0,100% 100%,0 100%);
}
/* 装飾的な斜めシェイプ（背景アクセント） */
.section--off::before{
  content:"";position:absolute;top:-1px;left:0;right:0;height:60px;
  background:linear-gradient(180deg,#fff 50%,transparent 50%);
  clip-path:polygon(0 0,100% 0,100% 50%,0 100%);
  z-index:1;
}

@media(max-width:760px){
  .section{padding:70px 22px}
  .section--cream{
    padding-top:90px;padding-bottom:90px;
    margin-top:-30px;margin-bottom:-30px;
    clip-path:polygon(0 30px,100% 0,100% calc(100% - 30px),0 100%);
  }
  .section--navy.cta-banner{
    padding-top:90px;padding-bottom:80px;
    margin-top:-30px;
    clip-path:polygon(0 30px,100% 0,100% 100%,0 100%);
  }
}

.section-header{margin-bottom:60px;text-align:center}
.section-header.center{text-align:center}
.section-header.left{text-align:left;display:flex;align-items:baseline;gap:24px;flex-wrap:wrap}

/* neo-sports風: 巨大な英文（Montserrat Black Italic） + 横並び日本語サブタイトル */
.label{
  display:inline-block;font-family:var(--font-en);font-weight:900;
  font-size:clamp(36px,5vw,60px);letter-spacing:.02em;
  color:var(--navy);font-style:italic;
  line-height:1;
  text-transform:uppercase;
  margin-bottom:0;
}
.label--gold{color:var(--gold)}
.label--white{color:#fff}
.label--orange{color:var(--red)}

.section-title{
  font-family:var(--font-jp);
  font-size:clamp(15px,1.6vw,18px);font-weight:700;
  line-height:1.6;letter-spacing:.05em;
  color:var(--navy);
  display:inline-block;margin-bottom:0;
}
.section-header.center .label{display:block;margin-bottom:14px}
.section-header.center .section-title{display:block;margin-bottom:20px}
.section-title--white{color:#fff}
.section-lead{
  font-size:15px;color:var(--ink);max-width:720px;line-height:2;
  font-family:var(--font-jp);font-weight:400;
  margin-top:24px;
}
.section-header.center .section-lead{margin-inline:auto}
.section-lead--white{color:rgba(255,255,255,.92)}

/* MORE link (右側) */
.section-more{
  font-family:var(--font-en);font-weight:700;font-size:14px;
  color:var(--navy);letter-spacing:.15em;
  display:inline-flex;align-items:center;gap:14px;
  border-bottom:1px solid var(--navy);padding:6px 0;
  transition:.2s;
}
.section-more:hover{color:var(--red);border-bottom-color:var(--red);gap:18px}

/* ============================================
   STATS BAR
   ============================================ */
.stats-bar{
  background:#fff;
  border:1px solid var(--line);border-radius:4px;
  display:grid;grid-template-columns:repeat(4,1fr);
  margin-top:-60px;position:relative;z-index:5;
  box-shadow:0 20px 50px rgba(26,40,66,.08);
}
.stat-item{padding:40px 20px;text-align:center;border-right:1px solid var(--line)}
.stat-item:last-child{border-right:none}
.stat-num{font-family:var(--font-en);font-size:42px;font-weight:600;color:var(--navy);line-height:1;display:flex;align-items:baseline;justify-content:center;gap:4px;font-style:italic;letter-spacing:.01em}
.stat-num .unit{font-family:var(--font-jp);font-size:15px;color:var(--navy);font-weight:500;font-style:normal}
.stat-label{font-size:12px;color:var(--muted);margin-top:14px;font-weight:700;letter-spacing:.08em}

@media(max-width:760px){
  .stats-bar{grid-template-columns:repeat(2,1fr);margin-top:-40px}
  .stat-item:nth-child(2){border-right:none}
  .stat-item:nth-child(-n+2){border-bottom:1px solid var(--line)}
  .stat-num{font-size:36px}
}

/* ============================================
   ABOUT
   ============================================ */
.about-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:70px;align-items:center}
.about-visual{position:relative;aspect-ratio:4/5;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-hover)}
.about-visual img{width:100%;height:100%;object-fit:cover;object-position:center;display:block}
.about-visual::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 60%,rgba(10,37,64,.25));pointer-events:none}
.about-badge{position:absolute;bottom:24px;right:24px;background:var(--gold);color:var(--navy);padding:18px 24px;border-radius:14px;font-weight:900;text-align:center;line-height:1.1;box-shadow:0 10px 30px rgba(0,0,0,.2)}
.about-badge strong{display:block;font-size:38px;font-family:var(--font-en);font-weight:600;font-style:italic;line-height:1;letter-spacing:.01em}
.about-badge small{font-size:11px;letter-spacing:.05em}

.about-body p{margin-bottom:22px;color:var(--ink);font-size:15px;line-height:2.1}
.feat-list{margin:36px 0 40px;display:grid;gap:14px}
.feat-item{display:flex;align-items:flex-start;gap:16px;font-weight:500;font-size:14.5px;color:var(--ink);padding-bottom:14px;border-bottom:1px solid var(--line)}
.feat-icon{flex-shrink:0;width:24px;height:24px;background:var(--red);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:11px;margin-top:2px}

@media(max-width:880px){.about-grid{grid-template-columns:1fr;gap:40px}}

/* ============================================
   CARDS GRID (Classes)
   ============================================ */
.classes-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.class-card{
  background:#fff;border-radius:4px;overflow:hidden;
  box-shadow:var(--shadow);transition:.3s;
  border:1px solid var(--line);position:relative;
}
.class-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-hover)}
.card-band{height:3px;background:var(--red)}
.card-thumb{
  height:220px;position:relative;overflow:hidden;background:#fffaed;
}
.card-thumb img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s ease}
.class-card:hover .card-thumb img{transform:scale(1.06)}
.card-thumb::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(0,0,0,.15));pointer-events:none}
.card-tag-wrap{position:absolute;top:14px;left:14px}
.card-tag{
  background:var(--navy);color:#fff;
  padding:7px 16px;border-radius:2px;font-size:11px;font-weight:500;
  letter-spacing:.1em;
}
.card-body{padding:30px 28px}
.card-body h3{font-family:var(--font-jp);font-size:22px;font-weight:900;color:var(--navy);margin-bottom:14px;letter-spacing:.02em}
.card-body p{font-size:14px;color:var(--muted);line-height:1.95;margin-bottom:22px}
.card-meta{display:flex;gap:8px;flex-wrap:wrap}
.meta-pill{background:var(--bg-soft);color:var(--navy);padding:6px 14px;border-radius:2px;font-size:11px;font-weight:500;border:1px solid var(--line);letter-spacing:.05em}

@media(max-width:880px){.classes-grid{grid-template-columns:1fr}}

/* スマホでは横スワイプ */
@media(max-width:760px){
  .classes-grid{
    display:flex;
    flex-wrap:nowrap;
    overflow-x:auto;
    scroll-snap-type:x mandatory;
    gap:14px;
    padding:8px 22px 24px;
    margin:0 -22px;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;
  }
  .classes-grid::-webkit-scrollbar{display:none}
  .class-card{
    flex:0 0 82%;
    scroll-snap-align:center;
    min-width:280px;
  }
  /* スワイプヒント（右端のフェード） */
  .classes-grid-wrap{position:relative}
  .classes-grid-wrap::after{
    content:"";position:absolute;top:0;right:0;bottom:24px;width:30px;
    background:linear-gradient(90deg,transparent,rgba(255,255,255,.9));
    pointer-events:none;
  }
}

/* ============================================
   COACH FEATURE
   ============================================ */
.coach-feature{
  display:grid;grid-template-columns:1fr 1.3fr;gap:70px;align-items:center;
  background:#fff;border-radius:6px;padding:70px;
  box-shadow:var(--shadow);position:relative;overflow:hidden;
  border:1px solid var(--line);
}
.coach-feature::before{
  content:"";position:absolute;top:-100px;right:-100px;
  width:300px;height:300px;border-radius:50%;
  background:radial-gradient(circle,rgba(245,185,0,.12),transparent 70%);
}
.coach-portrait{
  position:relative;aspect-ratio:1;
  border-radius:50%;overflow:hidden;
  max-width:320px;margin:0 auto;
  box-shadow:0 20px 50px rgba(10,37,64,.3);
  border:6px solid #fff;
}
.coach-portrait img{width:100%;height:100%;object-fit:cover;object-position:center top;display:block}
.coach-portrait .medal{display:none}
.coach-info .role{
  font-family:var(--font-en);font-size:13px;font-weight:700;font-style:italic;
  color:var(--red);letter-spacing:.15em;margin-bottom:8px;text-transform:uppercase;
}
.coach-info h3{font-family:var(--font-jp);font-size:36px;font-weight:900;color:var(--navy);margin-bottom:24px;letter-spacing:.02em}
.coach-info .quote{font-family:var(--font-jp);font-size:16px;color:var(--ink);line-height:2.1;margin-bottom:32px;padding-left:22px;border-left:3px solid var(--red);font-weight:400}
.coach-creds{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.cred{background:var(--bg);padding:16px 18px;border-radius:12px;border-left:4px solid var(--red)}
.cred .num{font-family:var(--font-en);font-size:24px;font-weight:600;color:var(--navy);line-height:1;font-style:italic;letter-spacing:.01em}
.cred .txt{font-size:12px;color:var(--muted);font-weight:700;margin-top:4px}

@media(max-width:880px){
  .coach-feature{grid-template-columns:1fr;padding:36px;gap:36px}
  .coach-creds{grid-template-columns:1fr 1fr}
}

/* ============================================
   NEWS
   ============================================ */
.news-items{display:flex;flex-direction:column;gap:0;border-top:1px solid var(--line)}
.news-row{
  display:grid;grid-template-columns:130px 100px 1fr auto;gap:24px;
  padding:24px 28px;background:var(--bg-soft);margin-bottom:6px;
  border-radius:4px;align-items:center;
  transition:.25s;cursor:pointer;
}
.news-row:hover{background:#e6eaf0;transform:translateX(6px)}
.news-date-block{font-family:var(--font-en);font-size:16px;font-weight:700;color:var(--navy);letter-spacing:.05em}
.news-date-block .day{display:none}
.news-date-block .month{display:none}
.news-content{flex:1;min-width:0}
.badge{display:inline-block;padding:7px 18px;border-radius:4px;font-size:12px;font-weight:700;letter-spacing:.08em;width:fit-content;text-align:center}
.badge-event{background:var(--navy);color:#fff}
.badge-notice{background:var(--blue);color:#fff}
.badge-info{background:#16a34a;color:#fff}
.badge-comp{background:var(--red);color:#fff}
.news-title{font-family:var(--font-jp);font-weight:700;font-size:15px;color:var(--ink);margin-bottom:0;line-height:1.6}
.news-lead{display:none}
.news-arrow{color:var(--navy);font-size:20px;font-weight:700}
.news-arrow{color:var(--muted);font-size:20px}

@media(max-width:760px){
  .news-row{grid-template-columns:80px 1fr;gap:16px}
  .news-arrow{display:none}
  .news-date-block .day{font-size:28px}
}

/* ============================================
   VOICE / TESTIMONIAL
   ============================================ */
.voice-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.voice-card{
  background:#fff;padding:36px 30px;border-radius:8px;
  position:relative;border:1px solid var(--line);
  box-shadow:var(--shadow);
}
.voice-card::before{
  content:"\201C";position:absolute;top:-18px;left:24px;
  font-family:var(--font-en);font-size:90px;color:var(--red);line-height:1;font-weight:900;
}
.voice-text{font-family:var(--font-jp);font-size:14px;line-height:2;margin:24px 0;color:var(--ink);font-weight:400}
.voice-author{display:flex;align-items:center;gap:14px;padding-top:18px;border-top:1px solid var(--line)}
.voice-avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--navy),var(--red));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:900;font-family:var(--font-en);font-size:18px}
.voice-name{font-weight:800;font-size:14px;color:var(--navy)}
.voice-role{font-size:12px;color:var(--muted)}

@media(max-width:880px){.voice-grid{grid-template-columns:1fr}}

/* スマホで保護者の声も横スワイプ */
@media(max-width:760px){
  .voice-grid{
    display:flex;
    flex-wrap:nowrap;
    overflow-x:auto;
    scroll-snap-type:x mandatory;
    gap:14px;
    padding:24px 22px 24px;
    margin:0 -22px;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;
  }
  .voice-grid::-webkit-scrollbar{display:none}
  .voice-card{
    flex:0 0 82%;
    scroll-snap-align:center;
    min-width:260px;
  }
}

/* スワイプヒント（スマホのみ表示） */
.swipe-hint{display:none}
@media(max-width:760px){
  .swipe-hint{
    display:flex;align-items:center;justify-content:center;gap:10px;
    margin-top:18px;color:var(--muted);font-size:12px;
    font-family:var(--font-en);letter-spacing:.15em;
    animation:swipePulse 2s ease-in-out infinite;
  }
  .swipe-hint i{font-size:14px;color:var(--red)}
  @keyframes swipePulse{
    0%,100%{opacity:.6;transform:translateX(0)}
    50%{opacity:1;transform:translateX(6px)}
  }
}

/* ============================================
   CTA BANNER
   ============================================ */
.cta-banner{text-align:center;position:relative;overflow:hidden}
.cta-banner::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(circle at 20% 30%,rgba(245,185,0,.15),transparent 50%),
    radial-gradient(circle at 80% 70%,rgba(232,52,78,.2),transparent 50%);
}
.cta-banner .container{position:relative}

/* ============================================
   PAGE HEADER (sub pages)
   ============================================ */
.page-header{
  position:relative;overflow:hidden;
  color:#fff;padding:80px 24px 70px;text-align:center;
  background:linear-gradient(160deg,#0a2540 0%,#143a5e 100%);
}
.page-header.has-bg::after{
  content:"";position:absolute;inset:0;z-index:0;
  background-image:var(--bg-img);background-size:cover;background-position:center;
  opacity:.22;filter:saturate(1.1);
}
.page-header::before{
  content:"";position:absolute;inset:0;z-index:1;
  background:
    radial-gradient(circle at 80% 20%,rgba(245,185,0,.25),transparent 50%),
    radial-gradient(circle at 20% 80%,rgba(232,52,78,.22),transparent 50%),
    linear-gradient(180deg,rgba(10,37,64,.3),rgba(10,37,64,.6));
}
.page-header-inner{position:relative;z-index:2}
.page-header-inner{position:relative;max-width:var(--max);margin:0 auto}
.page-header .label{color:var(--gold)}
.page-header h1{font-size:clamp(30px,4vw,46px);font-weight:900;line-height:1.3;margin-bottom:16px}
.page-header .lead{font-size:16px;opacity:.9;max-width:640px;margin:0 auto;line-height:1.9}
.breadcrumbs{font-size:12px;font-family:var(--font-en);letter-spacing:.1em;opacity:.7;margin-top:24px}
.breadcrumbs a{color:var(--gold);text-decoration:none}
.breadcrumbs span{margin:0 10px}

/* ============================================
   CONTACT
   ============================================ */
.contact-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:50px}
.contact-info-card{
  background:linear-gradient(160deg,var(--navy) 0%,var(--navy-2) 100%);
  color:#fff;padding:50px 40px;border-radius:var(--radius-lg);
  box-shadow:var(--shadow);position:relative;overflow:hidden;
}
.contact-info-card::before{
  content:"";position:absolute;top:-80px;right:-80px;width:200px;height:200px;
  border-radius:50%;background:radial-gradient(circle,rgba(245,185,0,.2),transparent 70%);
}
.contact-info-card h3{font-size:22px;font-weight:900;margin-bottom:8px;position:relative}
.contact-info-card .sub{font-family:var(--font-en);font-size:11px;color:var(--gold);letter-spacing:.15em;text-transform:uppercase;margin-bottom:30px;position:relative}
.contact-list{display:flex;flex-direction:column;gap:24px;position:relative}
.contact-list-item{display:flex;gap:18px;align-items:flex-start}
.contact-list-icon{flex-shrink:0;width:42px;height:42px;border-radius:12px;background:rgba(255,255,255,.12);display:flex;align-items:center;justify-content:center;font-size:20px}
.contact-list-content{flex:1}
.contact-list-content .key{font-size:11px;color:var(--gold);font-weight:700;letter-spacing:.1em;text-transform:uppercase;margin-bottom:4px}
.contact-list-content .val{font-size:15px;font-weight:600;line-height:1.6}
.contact-list-content .val a{color:#fff;border-bottom:1px solid rgba(245,185,0,.4)}
.contact-list-content .val a:hover{border-bottom-color:var(--gold)}

.contact-form{background:#fff;padding:50px 40px;border-radius:var(--radius-lg);box-shadow:var(--shadow);border:1px solid var(--line)}
.contact-form h3{font-size:22px;font-weight:900;color:var(--navy);margin-bottom:8px}
.contact-form .sub{font-family:var(--font-en);font-size:11px;color:var(--red);letter-spacing:.15em;text-transform:uppercase;margin-bottom:30px}
.form-row{margin-bottom:20px}
.form-row label{display:block;font-size:13px;font-weight:700;color:var(--navy);margin-bottom:8px}
.form-row label .req{color:var(--red);margin-left:4px}
.form-row input,.form-row select,.form-row textarea{
  width:100%;padding:14px 16px;border:1.5px solid var(--line);
  border-radius:10px;font-size:15px;font-family:inherit;
  background:var(--bg);transition:.2s;
}
.form-row input:focus,.form-row select:focus,.form-row textarea:focus{
  outline:none;border-color:var(--navy);background:#fff;
  box-shadow:0 0 0 3px rgba(10,37,64,.08);
}
.form-row textarea{resize:vertical;min-height:120px}
.form-submit{margin-top:30px;text-align:center}
.form-submit button{width:100%;padding:18px;font-size:16px}
.form-note{font-size:12px;color:var(--muted);margin-top:14px;text-align:center;line-height:1.7}

@media(max-width:880px){
  .contact-grid{grid-template-columns:1fr}
  .contact-info-card,.contact-form{padding:36px 28px}
}

/* ============================================
   ACCESS / MAP
   ============================================ */
.access-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center}
.access-map{
  aspect-ratio:4/3;border-radius:var(--radius-lg);overflow:hidden;
  background:linear-gradient(135deg,#cfd8e3,#e8eef4);
  display:flex;align-items:center;justify-content:center;
  position:relative;border:1px solid var(--line);
}
.access-map iframe{width:100%;height:100%;border:0}
.access-info h3{font-size:24px;font-weight:900;color:var(--navy);margin-bottom:20px}
.access-info dl{display:grid;gap:14px}
.access-info .row{display:grid;grid-template-columns:100px 1fr;gap:16px;padding:14px 0;border-bottom:1px solid var(--line);font-size:14.5px}
.access-info .row dt{font-weight:800;color:var(--red);font-size:13px}
@media(max-width:880px){.access-grid{grid-template-columns:1fr}}

/* ============================================
   PRICING (Classes page)
   ============================================ */
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.price-card{
  background:#fff;padding:40px 32px;border-radius:var(--radius);
  border:2px solid var(--line);text-align:center;transition:.3s;
  position:relative;
}
.price-card.featured{border-color:var(--red);box-shadow:0 20px 50px rgba(232,52,78,.15);transform:scale(1.03)}
.price-card.featured::before{
  content:"人気";position:absolute;top:-14px;left:50%;transform:translateX(-50%);
  background:var(--red);color:#fff;padding:6px 18px;border-radius:30px;
  font-size:12px;font-weight:800;letter-spacing:.05em;
}
.price-card h3{font-size:20px;font-weight:900;color:var(--navy);margin-bottom:8px}
.price-card .age-badge{display:inline-block;background:var(--bg);padding:4px 14px;border-radius:20px;font-size:12px;color:var(--muted);font-weight:700;margin-bottom:24px}
.price-card .price-note{font-size:14px;color:var(--muted);margin:24px 0;font-weight:600;padding:14px;background:var(--bg);border-radius:10px}
.price-card ul{text-align:left;display:flex;flex-direction:column;gap:10px;margin-bottom:30px}
.price-card ul li{padding-left:26px;position:relative;font-size:14px;color:var(--ink)}
.price-card ul li::before{content:"✓";position:absolute;left:0;top:0;color:var(--red);font-weight:900}
@media(max-width:880px){.pricing-grid{grid-template-columns:1fr}.price-card.featured{transform:none}}

/* ============================================
   COACHES PAGE
   ============================================ */
.coaches-list{display:grid;grid-template-columns:repeat(2,1fr);gap:30px}
.coach-card{
  background:#fff;border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow);display:grid;grid-template-columns:200px 1fr;
  border:1px solid var(--line);transition:.3s;
}
.coach-card:hover{box-shadow:var(--shadow-hover);transform:translateY(-4px)}
.coach-card-img{
  position:relative;overflow:hidden;
  background:linear-gradient(135deg,var(--navy),var(--red));
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-family:var(--font-en);font-weight:900;font-size:50px;
}
.coach-card-img img{width:100%;height:100%;object-fit:cover;display:block}
.coach-card-img.gold{background:linear-gradient(135deg,var(--gold),var(--red))}
.coach-card-img.navy{background:linear-gradient(135deg,var(--navy-2),var(--navy))}
.coach-card-body{padding:28px}
.coach-card-body .role{font-family:var(--font-en);font-size:11px;color:var(--red);letter-spacing:.15em;font-weight:700;text-transform:uppercase;margin-bottom:6px}
.coach-card-body h3{font-size:22px;font-weight:900;color:var(--navy);margin-bottom:10px}
.coach-card-body p{font-size:14px;color:var(--muted);line-height:1.85;margin-bottom:14px}
.coach-card-body .tags{display:flex;flex-wrap:wrap;gap:6px}
.coach-card-body .tag{background:var(--bg);color:var(--navy);font-size:11px;padding:4px 10px;border-radius:20px;font-weight:700;border:1px solid var(--line)}
@media(max-width:880px){.coaches-list{grid-template-columns:1fr}.coach-card{grid-template-columns:1fr}.coach-card-img{height:180px;font-size:60px}}

/* ============================================
   NEWS PAGE / FILTER
   ============================================ */
.news-filter{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin-bottom:50px}
.filter-btn{
  padding:10px 22px;border-radius:30px;background:#fff;
  border:1.5px solid var(--line);font-weight:700;font-size:13px;
  color:var(--ink);transition:.2s;
}
.filter-btn:hover{border-color:var(--navy);color:var(--navy)}
.filter-btn.active{background:var(--navy);color:#fff;border-color:var(--navy)}

/* ============================================
   FOOTER
   ============================================ */
.site-footer{background:#1a2842;color:#a8b2c0;padding:80px 24px 30px}
.footer-grid{
  max-width:var(--max);margin:0 auto;
  display:grid;grid-template-columns:1.6fr 1fr 1fr 1.3fr;gap:50px;
  padding-bottom:50px;border-bottom:1px solid rgba(255,255,255,.08);
}
.footer-brand .logo{margin-bottom:18px}
.footer-brand .logo-jp{color:#fff}
.footer-brand .logo-en{color:var(--gold)}
.footer-desc{font-size:13.5px;line-height:1.85;margin-bottom:20px}
.footer-social{display:flex;gap:10px}
.footer-social a{
  width:40px;height:40px;border-radius:10px;background:rgba(255,255,255,.06);
  display:flex;align-items:center;justify-content:center;font-size:18px;
  transition:.2s;border:1px solid rgba(255,255,255,.08);
}
.footer-social a:hover{background:var(--red);color:#fff;transform:translateY(-3px)}

.footer-col h4{
  color:#fff;font-size:12px;font-weight:500;margin-bottom:20px;
  letter-spacing:.15em;padding-bottom:14px;border-bottom:1px solid var(--gold);display:inline-block;
  font-family:var(--font-en);font-style:italic;text-transform:uppercase;
}
.footer-col a{display:block;color:#9ba9b8;font-size:13.5px;padding:6px 0;transition:.2s}
.footer-col a:hover{color:var(--gold);padding-left:6px}
.footer-col a i{color:var(--gold);margin-right:8px;width:1em;text-align:center}
.section--navy .icon-inline,
.contact-info-card .icon-inline{color:var(--gold)}

.footer-bottom{
  max-width:var(--max);margin:0 auto;padding-top:24px;
  display:flex;justify-content:space-between;align-items:center;
  font-size:12px;flex-wrap:wrap;gap:14px;
}

@media(max-width:880px){
  .footer-grid{grid-template-columns:1fr 1fr;gap:36px}
  .footer-bottom{flex-direction:column;text-align:center}
}
@media(max-width:560px){.footer-grid{grid-template-columns:1fr}}

/* ============================================
   REVEAL ANIMATION
   ============================================ */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s ease,transform .8s ease}
.reveal.visible{opacity:1;transform:none}

/* ============================================
   FEATURES (4つの特徴) - neo-sports風 円形アイコン
   ============================================ */
.features-section{
  background:linear-gradient(180deg,#fff 0%,#e8f5fc 100%);
  padding:100px 24px 110px;
}
.features-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:30px;
  max-width:1080px;margin:0 auto;
}
.feature-circle{text-align:center;position:relative}
.circle-wrap{
  position:relative;width:160px;height:160px;margin:0 auto 24px;
}
.circle-wrap::before,.circle-wrap::after{
  content:"";position:absolute;top:50%;width:32px;height:60px;
  background-image:radial-gradient(circle at 50% 100%,var(--gold) 0,var(--gold) 1.5px,transparent 1.8px);
  background-size:6px 6px;background-position:center bottom;
  background-repeat:repeat-x;
  transform:translateY(-50%);
  display:none;
}
.circle-num{
  position:absolute;top:50%;left:50%;
  transform:translate(-50%,-58%);
  font-family:var(--font-en);font-style:italic;font-weight:700;
  font-size:90px;color:rgba(26,59,142,.08);line-height:1;z-index:0;
  letter-spacing:.02em;
}
.circle-inner{
  position:absolute;inset:18px;border-radius:50%;
  background:#fff;
  box-shadow:0 8px 24px rgba(26,59,142,.12);
  display:flex;align-items:center;justify-content:center;
  z-index:1;border:1px solid var(--blue-light);
  transition:.3s;
}
.circle-inner i{font-size:46px;color:var(--red)}
.feature-circle:hover .circle-inner{
  transform:translateY(-6px);
  box-shadow:0 14px 32px rgba(26,59,142,.18);
}
.feature-circle h3{
  font-family:var(--font-jp);font-weight:900;font-size:17px;
  color:var(--navy);margin-bottom:12px;line-height:1.5;
}
.feature-circle p{
  font-size:13px;color:var(--muted);line-height:1.85;
  max-width:240px;margin:0 auto;
}
@media(max-width:880px){
  .features-grid{grid-template-columns:repeat(2,1fr);gap:36px 20px}
  .circle-wrap{width:140px;height:140px}
  .circle-num{font-size:78px}
  .circle-inner i{font-size:40px}
}
@media(max-width:480px){
  .features-section{padding:60px 22px 70px}
  .features-grid{gap:32px 14px}
  .circle-wrap{width:120px;height:120px;margin-bottom:18px}
  .circle-num{font-size:66px}
  .circle-inner i{font-size:34px}
  .feature-circle h3{font-size:15px}
  .feature-circle p{font-size:12.5px}
}

/* ============================================
   ICONS (Font Awesome 整え)
   ============================================ */
.fa-solid,.fa-regular,.fa-brands{vertical-align:-0.05em}
.icon-inline{color:var(--navy);margin-right:8px;width:1.1em;text-align:center}
.icon-accent{color:var(--red)}
.icon-fb{color:#1877f2}
.icon-ig{
  background:linear-gradient(45deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
/* ボタン内ではブランド色を上書きして白に */
.btn .icon-fb,.btn .icon-ig{color:#fff;background:none;-webkit-background-clip:initial;background-clip:initial}
/* ダーク背景でブランドアイコン白に */
.section--navy .icon-fb,.section--navy .icon-ig,
.contact-info-card .icon-fb,.contact-info-card .icon-ig{color:#fff;background:none;-webkit-background-clip:initial;background-clip:initial}
/* フッターのSNSは色味維持OK */
.footer-social a i{color:#a8b2c0;margin:0;width:auto;font-size:18px}
.footer-social a:hover i{color:#fff}
.icon-line{color:#06c755}

/* contact list内のアイコン: ゴールドに統一 + 完全中央揃え */
.contact-list-icon i{
  font-size:18px!important;
  color:var(--gold)!important;
  line-height:1!important;
  margin:0!important;
  width:auto!important;
  background:none!important;
  -webkit-background-clip:initial!important;
  background-clip:initial!important;
  -webkit-text-fill-color:var(--gold)!important;
}

/* coach-creds の数値部に置くアイコン */
.cred .num i{font-size:20px;color:var(--red)}

/* meta-pill 内のアイコン */
.meta-pill i{margin-right:6px;color:var(--red);font-size:11px}

/* news-title 内のアイコン */
.news-title i{margin-right:8px;color:var(--navy);font-size:14px}

/* feat-item チェックを Font Awesome に */
.feat-item .feat-icon i{font-size:11px}

/* ============================================
   FIXED SIDE CTA (neo-sports style)
   ============================================ */
.side-cta{
  position:fixed;right:0;top:50%;transform:translateY(-50%);
  z-index:90;display:flex;flex-direction:column;gap:6px;
}
.side-cta a{
  display:flex;flex-direction:column;align-items:center;gap:8px;
  padding:24px 14px;background:var(--red);color:#fff;
  font-family:var(--font-jp);font-weight:700;font-size:13px;
  writing-mode:vertical-rl;text-orientation:upright;
  letter-spacing:.2em;
  border-radius:6px 0 0 6px;
  box-shadow:-4px 4px 14px rgba(0,0,0,.15);
  transition:.25s;
}
.side-cta a:hover{background:var(--red-2);padding-right:18px}
.side-cta a .ico{
  writing-mode:horizontal-tb;font-size:16px;
  width:32px;height:32px;display:flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.2);border-radius:50%;
}
.side-cta a .ico i{color:#fff!important;margin:0;width:auto}
.side-cta a.alt{background:var(--navy)}
.side-cta a.alt:hover{background:var(--navy-2)}
@media(max-width:880px){.side-cta{display:none}}

/* ============================================
   UTILITIES
   ============================================ */
.text-center{text-align:center}
.mt-40{margin-top:40px}
