:root{
  --bg:#FFFFFF;
  --bg-2:#FAF9F6;
  --bg-3:#F2F0EB;
  --line:#E2E0DA;
  --line-soft:#EDEBE5;
  --text:#1A1A1A;
  --text-2:#3A3A3A;
  --text-mute:#7A7A78;
  --text-dim:#A8A8A4;
  --accent:#1A1A1A;
  --accent-2:#B8543C;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:"Inter","Noto Sans JP","Hiragino Kaku Gothic ProN",sans-serif;
  background:var(--bg);color:var(--text);
  line-height:1.9;letter-spacing:.005em;font-size:17px;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.container{max-width:1380px;margin:0 auto;padding:0 48px}
.eyebrow{font-family:"Inter",sans-serif;font-size:12px;letter-spacing:.32em;text-transform:uppercase;color:var(--text-mute);font-weight:500}
.eyebrow-num{font-family:"Playfair Display",serif;font-style:italic;color:var(--text);margin-right:14px}
.rule{display:inline-block;width:40px;height:1px;background:var(--text);vertical-align:middle;margin-right:14px}
.serif{font-family:"Playfair Display","Noto Serif JP",serif}

/* Strong gothic for main JP display headings */
.jp-strong{
  font-family:"HG創英角ｺﾞｼｯｸUB","HGSoeiKakugothicUB","創英角ゴシック","Zen Kaku Gothic New","Noto Sans JP","Hiragino Kaku Gothic ProN",sans-serif;
  font-weight:900;
  letter-spacing:.01em;
  line-height:1.45;
  word-break:keep-all;
  overflow-wrap:break-word;
}
.jp-strong em{font-style:normal;color:var(--accent-2)}
.nobr{display:inline-block}

/* ===== Header ===== */
.header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  background:rgba(255,255,255,.94);backdrop-filter:blur(20px) saturate(180%);
  border-bottom:1px solid var(--line-soft);
}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:10px 48px;max-width:1500px;margin:0 auto;gap:30px}
.logo{display:flex;align-items:center;flex-shrink:0}
.logo img{display:block;height:120px;width:auto}
.logo small{display:block;font-family:"Inter",sans-serif;font-size:10px;color:var(--text-mute);letter-spacing:.24em;text-transform:uppercase;margin-top:2px;font-weight:400}
.nav{display:flex;align-items:center;gap:24px;flex-wrap:wrap;justify-content:flex-end}
.nav-link{display:flex;flex-direction:column;align-items:center;line-height:1.2;transition:color .25s;color:var(--text-2)}
.nav-link:hover{color:var(--text)}
.nav-link .en{font-size:13px;font-weight:500;letter-spacing:.08em;text-transform:uppercase}
.nav-link .ja{font-size:10.5px;font-weight:500;color:var(--text-mute);margin-top:4px;letter-spacing:.04em;font-family:"Zen Kaku Gothic New","Noto Sans JP",sans-serif}
.nav-cta{
  padding:14px 28px;background:var(--text);color:#fff;
  font-size:12px;letter-spacing:.18em;font-weight:500;text-transform:uppercase;
  transition:all .25s;text-align:center;line-height:1.3;
}
.nav-cta .ja{display:block;font-size:10px;margin-top:4px;letter-spacing:.06em;opacity:.8;font-family:"Zen Kaku Gothic New","Noto Sans JP",sans-serif}
.nav-cta:hover{background:var(--accent-2);color:#fff}
.nav-pilot{
  display:flex;flex-direction:column;align-items:center;line-height:1.25;
  padding:13px 22px;background:#fff;border:1.5px solid var(--accent-2);color:var(--accent-2);
  font-family:"Zen Kaku Gothic New","Noto Sans JP",sans-serif;font-weight:700;
  transition:all .25s;text-align:center;
}
.nav-pilot .en{font-size:10px;letter-spacing:.18em;font-weight:600;text-transform:uppercase;opacity:.7;margin-bottom:4px;font-family:"Inter",sans-serif}
.nav-pilot .ja{font-size:12.5px;letter-spacing:.04em}
.nav-pilot:hover{background:var(--accent-2);color:#fff}

/* ===== Service Dropdown ===== */
.nav-has-sub{position:relative}
.nav-has-sub > .nav-link{cursor:pointer}
.nav-submenu{
  position:absolute;top:calc(100% + 10px);left:50%;
  transform:translateX(-50%) translateY(8px);
  background:#fff;border:1px solid var(--line);
  min-width:240px;padding:6px 0;
  box-shadow:0 16px 40px rgba(0,0,0,.10);
  opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity .25s ease, transform .25s ease, visibility .25s;
  z-index:200;
}
.nav-has-sub:hover .nav-submenu,
.nav-has-sub:focus-within .nav-submenu{
  opacity:1;visibility:visible;pointer-events:auto;
  transform:translateX(-50%) translateY(0);
}
.nav-submenu a{
  display:block;padding:12px 22px;color:var(--text);
  border-bottom:1px solid var(--line-soft);
  transition:background .2s ease, color .2s ease;
  text-decoration:none;
}
.nav-submenu a:last-child{border-bottom:0}
.nav-submenu a:hover{background:var(--bg-3);color:var(--accent-2)}
.nav-submenu a .en{
  display:block;font-family:"Inter",sans-serif;font-size:9.5px;
  letter-spacing:.18em;color:var(--text-mute);text-transform:uppercase;
  margin-bottom:4px;font-weight:500;
}
.nav-submenu a .ja{
  display:block;font-size:14px;font-weight:500;line-height:1.3;
  font-family:"Zen Kaku Gothic New","Noto Sans JP",sans-serif;
}

/* Service rows as anchor links — outer anchor is plain block, inner <article> is the grid */
.service-row-link{
  display:block;color:inherit;text-decoration:none;
  -webkit-tap-highlight-color:rgba(184,84,60,.08);
}
.service-row-link:hover .ttl{color:var(--accent-2)}
.service-row-link:hover{background:var(--bg-2)}


/* ===== Hamburger toggle (hidden on desktop) ===== */
.nav-toggle{
  display:none;
  width:44px;height:44px;
  background:transparent;border:0;padding:0;cursor:pointer;
  position:relative;z-index:120;
  -webkit-tap-highlight-color:transparent;
}
.nav-toggle span{
  display:block;position:absolute;left:10px;right:10px;height:2px;
  background:var(--text);border-radius:2px;
  transition:transform .3s ease,opacity .2s ease,top .3s ease;
}
.nav-toggle span:nth-child(1){top:14px}
.nav-toggle span:nth-child(2){top:21px}
.nav-toggle span:nth-child(3){top:28px}
body.nav-open .nav-toggle span:nth-child(1){top:21px;transform:rotate(45deg)}
body.nav-open .nav-toggle span:nth-child(2){opacity:0}
body.nav-open .nav-toggle span:nth-child(3){top:21px;transform:rotate(-45deg)}
.nav-backdrop{
  display:none;position:fixed;inset:0;
  background:rgba(20,20,20,.45);backdrop-filter:blur(4px);
  z-index:90;opacity:0;pointer-events:none;transition:opacity .3s ease;
}
body.nav-open .nav-backdrop{opacity:1;pointer-events:auto}


/* ===== Hero ===== */
.hero{position:relative;padding:0;border-bottom:1px solid var(--line);overflow:hidden}
.hero-bg{
  position:relative;min-height:720px;
  background-color:#FAF9F6;
  background-image:url('hero.png');
  background-size:auto 78%;background-position:center center;background-repeat:no-repeat;
}
.hero-bg::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(90deg,rgba(255,255,255,.96) 0%,rgba(255,255,255,.86) 30%,rgba(255,255,255,.55) 50%,rgba(255,255,255,.35) 70%,rgba(255,255,255,.55) 100%);
  pointer-events:none;
}
/* Pilot page hero — full-bleed photograph */
.hero-bg.hero-bg-pilot{
  background-image:url('hero-pilot.png');
  background-size:cover;
  background-position:center top;
  background-repeat:no-repeat;
}
.hero-bg.hero-bg-pilot::before{
  background:linear-gradient(90deg,rgba(255,255,255,.94) 0%,rgba(255,255,255,.80) 28%,rgba(255,255,255,.42) 55%,rgba(255,255,255,.18) 78%,rgba(255,255,255,.32) 100%);
}
.hero-bg .container{position:relative;z-index:1;padding-top:170px;padding-bottom:80px}
.hero-top{padding:0 0 36px;display:grid;grid-template-columns:1fr auto;align-items:end;gap:60px;border-bottom:1px solid rgba(0,0,0,.18)}
.hero-top-meta{display:flex;align-items:center;gap:20px;font-size:12px;letter-spacing:.24em;color:var(--text-2);text-transform:uppercase;flex-wrap:wrap;font-weight:500}
.hero-top-meta .dot{width:6px;height:6px;border-radius:50%;background:var(--text)}
.hero-top-issue{font-family:"Playfair Display",serif;font-style:italic;font-size:16px;color:var(--text-2)}
.hero-body{padding:60px 0 24px;max-width:680px}
.hero-headline{
  font-size:88px;line-height:1.25;
  color:var(--text);
  font-family:"HG創英角ｺﾞｼｯｸUB","HGSoeiKakugothicUB","創英角ゴシック","Zen Kaku Gothic New","Noto Sans JP",sans-serif;
  font-weight:900;letter-spacing:.005em;word-break:keep-all;overflow-wrap:break-word;
}
.hero-headline em{font-style:normal;color:var(--accent-2)}
.hero-sub{font-family:"Playfair Display",serif;font-size:30px;font-style:italic;color:var(--text-2);margin-top:24px;font-weight:400;letter-spacing:.005em}
.hero-lead{font-size:17px;line-height:2.05;color:var(--text);max-width:560px;margin-top:36px;font-weight:500}
.hero-ctas{margin-top:44px;display:flex;gap:14px;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:12px;padding:20px 36px;font-size:14px;letter-spacing:.16em;font-weight:600;text-transform:uppercase;transition:all .3s;border:0;cursor:pointer;font-family:"Inter","Zen Kaku Gothic New","Noto Sans JP",sans-serif}
.btn-dark{background:var(--text);color:#fff}
.btn-dark:hover{background:var(--accent-2)}
.btn-outline{background:transparent;color:var(--text);border:1.5px solid var(--text)}
.btn-outline:hover{background:var(--text);color:#fff}

/* Stat strip */
.stat-strip{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.stat-item{padding:40px 36px;border-right:1px solid var(--line-soft)}
.stat-item:last-child{border-right:0}
.stat-num{font-family:"Playfair Display",serif;font-size:52px;font-weight:400;line-height:1;letter-spacing:-.01em}
.stat-num small{font-size:24px;color:var(--text-mute);margin-left:4px}
.stat-label{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--text-mute);margin-top:16px;font-weight:500}
.stat-label .ja{display:block;font-size:13px;letter-spacing:.04em;text-transform:none;color:var(--text-2);margin-top:6px;font-family:"Zen Kaku Gothic New","Noto Sans JP",sans-serif;font-weight:500}

/* ===== Sections shared ===== */
section{padding:140px 0;position:relative}
.sec-meta{display:flex;align-items:center;gap:20px;margin-bottom:36px}
.sec-meta .num{font-family:"Playfair Display",serif;font-style:italic;font-size:30px;color:var(--text)}
.sec-head{margin-bottom:80px;max-width:980px}
.sec-head h2{
  font-size:58px;line-height:1.45;letter-spacing:.005em;
  font-family:"HG創英角ｺﾞｼｯｸUB","HGSoeiKakugothicUB","創英角ゴシック","Zen Kaku Gothic New","Noto Sans JP",sans-serif;
  font-weight:900;word-break:keep-all;overflow-wrap:break-word;
}
.sec-head h2 em{font-style:normal;color:var(--accent-2)}
.sec-head p{margin-top:28px;font-size:17px;color:var(--text-2);line-height:2.05;max-width:680px}

/* ===== Services ===== */
.services{background:var(--bg);border-top:1px solid var(--line)}
.service-list{display:flex;flex-direction:column;border-top:1px solid var(--line)}
.service-row{display:grid;grid-template-columns:80px 1fr 1.1fr 300px;gap:54px;align-items:center;padding:40px 0;border-bottom:1px solid var(--line);transition:background .3s;cursor:pointer;position:relative}
.service-row:hover{background:var(--bg-2)}
.service-row .num{font-family:"Playfair Display",serif;font-size:34px;font-style:italic;color:var(--text)}
.service-row .ttl{
  font-size:30px;line-height:1.4;font-weight:900;
  font-family:"HG創英角ｺﾞｼｯｸUB","HGSoeiKakugothicUB","Zen Kaku Gothic New","Noto Sans JP",sans-serif;
}
.service-row .ttl small{display:block;font-family:"Playfair Display",serif;font-style:italic;font-size:15px;color:var(--text-mute);font-weight:400;margin-top:8px;letter-spacing:.02em}
.service-row .desc{font-size:16px;color:var(--text-2);line-height:1.95}
.service-row .img{aspect-ratio:5/4;overflow:hidden;background:var(--bg-3)}
.service-row .img img{width:100%;height:100%;object-fit:cover;transition:transform 1s}
.service-row:hover .img img{transform:scale(1.05)}
.service-row .img-gallery{display:grid;grid-template-columns:1.5fr 1fr;grid-template-rows:1fr 1fr;gap:4px;aspect-ratio:5/4;background:var(--bg-3)}
.service-row .img-gallery > div{overflow:hidden;position:relative}
.service-row .img-gallery .main{grid-row:span 2}
.service-row .img-gallery-2{grid-template-columns:1.5fr 1fr;grid-template-rows:1fr}
.service-row .img-gallery-2 .main{grid-row:span 1}
.service-row .img-gallery img{width:100%;height:100%;object-fit:cover;transition:transform 1s}
.service-row:hover .img-gallery img{transform:scale(1.05)}
.service-row::after{content:"→";position:absolute;right:-44px;top:50%;transform:translateY(-50%);font-size:16px;opacity:0;transition:all .3s}
.service-row:hover::after{opacity:1;right:-32px}

/* ===== Why ===== */
.why{background:var(--bg-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);margin-top:30px}
.why-card{background:var(--bg-2);padding:60px 44px;display:flex;flex-direction:column;gap:26px;position:relative;transition:background .3s}
.why-card:hover{background:var(--bg)}
.why-card-num{font-family:"Playfair Display",serif;font-size:120px;font-weight:400;line-height:1;letter-spacing:-.02em;color:var(--text);font-style:italic}
.why-card-num small{font-size:34px;color:var(--text-mute);margin-left:6px;font-style:normal;letter-spacing:.04em;font-family:"Zen Kaku Gothic New","Noto Sans JP",sans-serif;font-weight:500}
.why-card h3{
  font-size:24px;line-height:1.55;font-weight:900;
  font-family:"HG創英角ｺﾞｼｯｸUB","HGSoeiKakugothicUB","Zen Kaku Gothic New","Noto Sans JP",sans-serif;
  word-break:keep-all;
}
.why-card p{font-size:16px;color:var(--text-2);line-height:2.05}
.why-card .stat-label{font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--text-mute);padding-top:24px;border-top:1px solid var(--line);margin-top:auto}

/* Quote band */
.quote-band{padding:120px 0;background:var(--bg);border-bottom:1px solid var(--line)}
.quote-band .container{max-width:1080px}
.quote-band blockquote{
  font-family:"Noto Serif JP",serif;font-size:44px;line-height:1.7;font-weight:500;letter-spacing:.005em;
  text-align:center;color:var(--text);word-break:keep-all;overflow-wrap:break-word;
}
.quote-band blockquote em{font-family:"Playfair Display",serif;font-style:italic;color:var(--accent-2);font-weight:400}
.quote-band cite{display:block;margin-top:36px;font-style:normal;font-size:13px;letter-spacing:.24em;text-transform:uppercase;color:var(--text-mute);text-align:center}

/* ===== Flow ===== */
.flow{background:var(--bg-2);border-bottom:1px solid var(--line)}
.flow-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin-top:60px;border-top:1px solid var(--line)}
.flow-cell{padding:44px 32px;border-right:1px solid var(--line);border-bottom:1px solid var(--line);position:relative}
.flow-cell:last-child{border-right:0}
.flow-num{font-family:"Playfair Display",serif;font-style:italic;font-size:34px;color:var(--text);margin-bottom:20px}
.flow-cell h4{
  font-size:20px;font-weight:900;margin-bottom:14px;line-height:1.55;
  font-family:"HG創英角ｺﾞｼｯｸUB","HGSoeiKakugothicUB","Zen Kaku Gothic New","Noto Sans JP",sans-serif;
  word-break:keep-all;
}
.flow-cell p{font-size:15px;color:var(--text-2);line-height:1.95}

/* ===== CTA (お問合せフォーム banner) ===== */
.cta-banner{padding:160px 0;background:var(--bg-3);position:relative;overflow:hidden}
.cta-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:80px;align-items:center}
.cta-banner h2{
  font-size:64px;line-height:1.45;letter-spacing:.005em;
  font-family:"HG創英角ｺﾞｼｯｸUB","HGSoeiKakugothicUB","創英角ゴシック","Zen Kaku Gothic New","Noto Sans JP",sans-serif;
  font-weight:900;word-break:keep-all;overflow-wrap:break-word;
}
.cta-banner h2 em{font-style:normal;color:var(--accent-2)}
.cta-banner p{margin-top:28px;font-size:17px;color:var(--text-2);line-height:2.05;max-width:520px}

.form-banner{
  margin-top:54px;display:block;
  background:var(--text);color:#fff;
  padding:56px 64px;
  transition:all .35s;
  position:relative;overflow:hidden;
}
.form-banner:hover{background:var(--accent-2);transform:translateY(-2px)}
.form-banner-inner{display:flex;align-items:center;justify-content:space-between;gap:34px;position:relative;z-index:1}
.form-banner-text .sm{font-size:15px;letter-spacing:.28em;text-transform:uppercase;color:rgba(255,255,255,.78);font-weight:600}
.form-banner-text .lg{
  font-size:42px;margin-top:14px;line-height:1.35;
  font-family:"HG創英角ｺﾞｼｯｸUB","HGSoeiKakugothicUB","Zen Kaku Gothic New","Noto Sans JP",sans-serif;
  font-weight:900;letter-spacing:.01em;
}
.form-banner-arrow{
  width:76px;height:76px;border-radius:50%;border:1px solid rgba(255,255,255,.5);
  display:grid;place-items:center;font-size:28px;flex-shrink:0;transition:all .3s;
}
.form-banner:hover .form-banner-arrow{background:#fff;color:var(--accent-2);border-color:#fff;transform:rotate(-45deg) scale(1.05)}

.cta-img{aspect-ratio:4/5;overflow:hidden}
.cta-img img{width:100%;height:100%;object-fit:cover}

/* ===== Footer ===== */
.footer{background:var(--bg);padding:80px 0 40px;border-top:1px solid var(--line)}
.footer-top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.3fr;gap:60px;margin-bottom:60px}
.footer-logo{font-family:"Playfair Display",serif;font-size:28px;letter-spacing:.005em;font-weight:500;margin-bottom:18px}
.footer-logo small{display:block;font-family:"Zen Kaku Gothic New","Noto Sans JP",sans-serif;font-size:11px;color:var(--text-mute);letter-spacing:.18em;text-transform:uppercase;margin-top:4px;font-weight:500}
.footer-desc{font-size:15px;line-height:2;color:var(--text-2);max-width:340px}
.footer h4{font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--text);font-weight:600;margin-bottom:22px}
.footer h4 .ja{display:block;font-size:13px;letter-spacing:.04em;text-transform:none;color:var(--text-mute);margin-top:6px;font-weight:500;font-family:"Zen Kaku Gothic New","Noto Sans JP",sans-serif}
.footer ul{list-style:none;display:grid;gap:14px}
.footer ul a{
  font-size:15px;color:var(--text-2);
  transition:color .2s ease, padding-left .2s ease;
  display:inline-flex;align-items:center;gap:8px;
  position:relative;
}
.footer ul a::before{
  content:"›";display:inline-block;color:var(--text-mute);
  font-family:"Inter",sans-serif;font-weight:400;font-size:14px;
  transition:transform .2s ease, color .2s ease;
}
.footer ul a:hover{color:var(--accent-2);text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1px}
.footer ul a:hover::before{color:var(--accent-2);transform:translateX(3px)}
.footer-form-btn{display:inline-flex;align-items:center;gap:12px;padding:18px 26px;background:var(--text);color:#fff;font-size:13px;letter-spacing:.14em;font-weight:600;text-transform:uppercase;transition:all .25s;margin-top:6px}
.footer-form-btn:hover{background:var(--accent-2);color:#fff}
.footer-bottom{padding-top:30px;border-top:1px solid var(--line-soft);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:18px;font-size:12px;color:var(--text-dim);letter-spacing:.04em}
.footer-bottom a{color:var(--text-mute);margin-left:24px;transition:color .2s}
.footer-bottom a:hover{color:var(--text)}

@media (max-width:1080px){
  .container{padding:0 28px}
  .hero-body{max-width:none;padding:40px 0 12px}
  .hero-bg{min-height:auto}
  .hero-bg::before{background:linear-gradient(180deg,rgba(255,255,255,.96) 0%,rgba(255,255,255,.88) 55%,rgba(255,255,255,.5) 100%)}
  .hero-bg .container{padding-top:150px;padding-bottom:60px}
  .hero-headline{font-size:54px}
  .hero-sub{font-size:22px}
  .stat-strip{grid-template-columns:1fr}
  .stat-item{border-right:0;border-bottom:1px solid var(--line-soft)}
  .stat-item:last-child{border-bottom:0}
  .service-row{grid-template-columns:50px 1fr 1.4fr;gap:30px}
  .service-row .img{display:none}
  .why-grid{grid-template-columns:1fr}
  .quote-band blockquote{font-size:30px}
  .flow-grid{grid-template-columns:1fr 1fr}
  .cta-grid{grid-template-columns:1fr;gap:50px}
  .cta-banner h2{font-size:40px}
  .form-banner{padding:42px 44px}
  .form-banner-text .lg{font-size:30px}
  .form-banner-text .sm{font-size:13px}
  .form-banner-arrow{width:60px;height:60px;font-size:22px}
  .footer-top{grid-template-columns:1fr 1fr;gap:40px}
  .sec-head h2{font-size:40px}
  section{padding:90px 0}
}
@media (max-width:820px){
  .container{padding:0 24px}
  .header-inner{padding:8px 20px;gap:18px}
  .logo img{height:64px}

  /* Hamburger button visible */
  .nav-toggle{display:block}
  .nav-backdrop{display:block}

  /* Nav becomes a drawer that slides in from the right */
  .nav{
    position:fixed;top:0;right:0;
    width:min(86vw,360px);height:100vh;height:100dvh;
    background:#fff;
    flex-direction:column;align-items:stretch;justify-content:flex-start;
    gap:0;
    padding:96px 28px 32px;
    box-shadow:-8px 0 32px rgba(0,0,0,.18);
    transform:translateX(100%);
    transition:transform .35s cubic-bezier(.4,0,.2,1);
    z-index:110;
    overflow-y:auto;
    flex-wrap:nowrap;
  }
  body.nav-open .nav{transform:translateX(0)}

  .nav-link{
    flex-direction:row;align-items:baseline;justify-content:space-between;
    padding:18px 4px;border-bottom:1px solid var(--line);
    gap:12px;
  }
  .nav-link .en{font-size:14px}
  .nav-link .ja{margin-top:0;font-size:13px;color:var(--text-2)}
  .nav-cta{
    margin-top:24px;padding:18px 24px;justify-content:center;text-align:center;
    font-size:13px;
  }
  .nav-cta .ja{display:block;margin-top:6px;font-size:11px}
  .nav-pilot{
    margin-top:14px;padding:16px 22px;flex-direction:column;align-items:center;
  }
  .nav-pilot .en{font-size:10px;margin-bottom:6px}
  .nav-pilot .ja{font-size:13px}

  /* Hero & other layout adjustments */
  .hero{padding:96px 0 0}
  .hero-headline{font-size:38px}
  .hero-sub{font-size:20px}
  .service-row{grid-template-columns:1fr;gap:18px;padding:30px 0}
  .flow-grid{grid-template-columns:1fr}
  .cta-banner h2{font-size:30px}
  .form-banner-inner{flex-direction:column;align-items:flex-start;gap:20px}
  .footer-top{grid-template-columns:1fr;gap:40px}


  /* Service submenu inline in mobile drawer */
  .nav-has-sub{position:static;display:block;width:100%}
  .nav-has-sub > .nav-link{display:flex;justify-content:space-between;width:100%}
  .nav-submenu{
    position:static;transform:none;
    opacity:1;visibility:visible;pointer-events:auto;
    background:var(--bg-3);
    border:0;box-shadow:none;
    margin:0 -28px 8px;padding:6px 0;
    min-width:0;
  }
  .nav-submenu a{padding:14px 28px}
  .nav-submenu a .en{font-size:9px;margin-bottom:3px}
  .nav-submenu a .ja{font-size:13.5px}

}

/* ============================================
   DETAIL PAGE EXTENSIONS
   ============================================ */
.detail-hero{
  position:relative;min-height:560px;overflow:hidden;
  background-size:cover;background-position:center;background-repeat:no-repeat;
  display:flex;align-items:flex-end;
}
.detail-hero::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,.15) 0%,rgba(0,0,0,.4) 60%,rgba(0,0,0,.78) 100%);
  pointer-events:none;
}
.detail-hero .container{position:relative;z-index:1;padding-top:200px;padding-bottom:80px;width:100%}
.detail-hero-meta{display:flex;align-items:center;gap:16px;color:rgba(255,255,255,.85);font-size:12px;letter-spacing:.24em;text-transform:uppercase;margin-bottom:30px;font-weight:500}
.detail-hero-meta .num{font-family:"Playfair Display",serif;font-style:italic;font-size:22px;color:#fff;letter-spacing:0;text-transform:none}
.detail-hero-meta .rule{display:inline-block;width:40px;height:1px;background:rgba(255,255,255,.6)}
.detail-hero h1{
  font-size:84px;line-height:1.2;color:#fff;
  font-family:"HG創英角ｺﾞｼｯｸUB","HGSoeiKakugothicUB","創英角ゴシック","Zen Kaku Gothic New","Noto Sans JP",sans-serif;
  font-weight:900;letter-spacing:.005em;word-break:keep-all;overflow-wrap:break-word;
}
.detail-hero h1 em{font-style:normal;color:#FFD6CB}
.detail-hero .sub{font-family:"Playfair Display",serif;font-style:italic;font-size:28px;color:rgba(255,255,255,.85);margin-top:22px;font-weight:400}
.detail-hero .lead{font-size:17px;line-height:2;color:rgba(255,255,255,.92);margin-top:30px;max-width:640px;font-weight:500}

/* Breadcrumb */
.breadcrumb{padding:30px 0 0;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--text-mute);font-weight:500}
.breadcrumb a{color:var(--text-2);transition:color .2s}
.breadcrumb a:hover{color:var(--accent-2)}
.breadcrumb .sep{margin:0 12px;color:var(--text-dim)}
.breadcrumb .cur{color:var(--text)}

/* Overview band */
.overview{padding:140px 0 120px;border-bottom:1px solid var(--line)}
.overview-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:90px;align-items:start}
.overview-text h2{
  font-size:54px;line-height:1.45;letter-spacing:.005em;
  font-family:"HG創英角ｺﾞｼｯｸUB","HGSoeiKakugothicUB","創英角ゴシック","Zen Kaku Gothic New","Noto Sans JP",sans-serif;
  font-weight:900;word-break:keep-all;overflow-wrap:break-word;
}
.overview-text h2 em{font-style:normal;color:var(--accent-2)}
.overview-text p{margin-top:30px;font-size:17px;color:var(--text-2);line-height:2.1}
.overview-img{aspect-ratio:4/3;overflow:hidden;background:var(--bg-3)}
.overview-img img{width:100%;height:100%;object-fit:cover}

/* Use cases */
.usecases{padding:140px 0;background:var(--bg-2);border-bottom:1px solid var(--line)}
.usecase-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:40px;margin-top:30px}
.usecase-card{background:var(--bg);border:1px solid var(--line);display:flex;flex-direction:column;transition:transform .35s, box-shadow .35s}
.usecase-card:hover{transform:translateY(-4px);box-shadow:0 18px 40px rgba(0,0,0,.06)}
.usecase-card .ph{aspect-ratio:5/4;overflow:hidden;background:var(--bg-3)}
.usecase-card .ph img{width:100%;height:100%;object-fit:cover;transition:transform 1s}
.usecase-card:hover .ph img{transform:scale(1.05)}
.usecase-card .body{padding:32px 28px;display:flex;flex-direction:column;gap:16px;flex:1}
.usecase-card .num{font-family:"Playfair Display",serif;font-style:italic;font-size:22px;color:var(--text)}
.usecase-card h3{
  font-size:22px;line-height:1.5;font-weight:900;
  font-family:"HG創英角ｺﾞｼｯｸUB","HGSoeiKakugothicUB","Zen Kaku Gothic New","Noto Sans JP",sans-serif;
  word-break:keep-all;
}
.usecase-card p{font-size:15px;color:var(--text-2);line-height:1.95}

/* Spec / pricing */
.spec{padding:140px 0;border-bottom:1px solid var(--line)}
.spec-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:80px;margin-top:30px;align-items:start}
.spec-list{display:flex;flex-direction:column;border-top:1px solid var(--line)}
.spec-row{display:grid;grid-template-columns:200px 1fr;gap:30px;padding:24px 0;border-bottom:1px solid var(--line)}
.spec-row dt{font-size:13px;letter-spacing:.18em;text-transform:uppercase;color:var(--text-mute);font-weight:500;padding-top:6px}
.spec-row dt .ja{display:block;text-transform:none;letter-spacing:.04em;color:var(--text);margin-top:6px;font-weight:700;font-size:15px;font-family:"Zen Kaku Gothic New","Noto Sans JP",sans-serif}
.spec-row dd{font-size:17px;line-height:1.95;color:var(--text)}
.spec-row dd .note{display:block;color:var(--text-mute);font-size:14px;margin-top:6px}
.spec-img{aspect-ratio:3/4;overflow:hidden;background:var(--bg-3)}
.spec-img img{width:100%;height:100%;object-fit:cover}

/* Gallery strip */
.gallery{padding:140px 0;background:var(--bg-2);border-bottom:1px solid var(--line)}
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:30px}
.gallery-grid > div{aspect-ratio:4/3;overflow:hidden;background:var(--bg-3)}
.gallery-grid img{width:100%;height:100%;object-fit:cover;transition:transform 1s}
.gallery-grid > div:hover img{transform:scale(1.05)}
.gallery-grid.single{grid-template-columns:1fr;max-width:900px;margin-left:auto;margin-right:auto}

@media (max-width:1080px){
  .detail-hero h1{font-size:52px}
  .detail-hero .sub{font-size:22px}
  .overview-grid{grid-template-columns:1fr;gap:50px}
  .usecase-grid{grid-template-columns:1fr;gap:24px}
  .spec-grid{grid-template-columns:1fr;gap:50px}
  .spec-row{grid-template-columns:1fr;gap:8px}
  .gallery-grid{grid-template-columns:1fr;gap:14px}
}
@media (max-width:640px){
  .detail-hero h1{font-size:36px}
  .detail-hero .container{padding-top:160px;padding-bottom:50px}
  .overview-text h2{font-size:32px}
}

/* ============================================
   MOBILE (<=560px) — 包括的スマホ対応
   ============================================ */
@media (max-width:560px){
  body{font-size:15px;line-height:1.85}
  .container{padding:0 18px}
  .nobr{display:inline}

  /* Header */
  .header-inner{padding:8px 16px;gap:10px}
  .logo img{height:48px}

  /* Hero */
  .hero{padding:0}
  .hero-bg{
    min-height:auto;
    background-size:135% auto;
    background-position:center 70px;
    background-repeat:no-repeat;
  }
  .hero-bg::before{
    background:linear-gradient(180deg,
      rgba(255,255,255,.08) 0%,
      rgba(255,255,255,.05) 25%,
      rgba(255,255,255,.40) 42%,
      rgba(255,255,255,.92) 56%,
      rgba(255,255,255,1) 70%);
  }
  .hero-bg .container{padding-top:310px;padding-bottom:40px}
  .hero-body{padding:0;max-width:none}
  .hero-headline{font-size:32px;line-height:1.35}
  .hero-sub{font-size:15px;margin-top:14px}
  .hero-lead{font-size:14.5px;margin-top:22px;line-height:1.95;max-width:none}
  .hero-ctas{margin-top:28px;gap:10px;flex-direction:column;align-items:stretch}
  .hero-ctas .btn{width:100%}
  .btn{padding:16px 22px;font-size:12.5px;justify-content:center;letter-spacing:.12em}

  /* Stat strip */
  .stat-item{padding:24px 20px}
  .stat-num{font-size:40px}
  .stat-num small{font-size:18px}
  .stat-label{font-size:11px;letter-spacing:.14em;margin-top:10px}
  .stat-label .ja{font-size:12px}

  /* Sections shared */
  section{padding:64px 0}
  .sec-meta{margin-bottom:22px;gap:14px}
  .sec-meta .num{font-size:22px}
  .sec-head{margin-bottom:38px}
  .sec-head h2{font-size:26px;line-height:1.5}
  .sec-head p{font-size:14.5px;margin-top:18px;line-height:1.9}

  /* Services */
  .service-list{border-top:0}
  .service-row{grid-template-columns:1fr;gap:8px;padding:22px 0}
  .service-row .num{font-size:20px}
  .service-row .ttl{font-size:20px;line-height:1.4}
  .service-row .ttl small{font-size:12.5px;margin-top:4px}
  .service-row .desc{font-size:14.5px;line-height:1.9}
  .service-row::after{display:none}
  .service-row .img,.service-row .img-gallery{display:none}

  /* Why */
  .why-grid{gap:1px}
  .why-card{padding:34px 22px;gap:16px}
  .why-card-num{font-size:72px}
  .why-card-num small{font-size:20px}
  .why-card h3{font-size:18px;line-height:1.5}
  .why-card p{font-size:14.5px;line-height:1.95}
  .why-card .stat-label{font-size:10.5px;padding-top:18px}

  /* Quote band */
  .quote-band{padding:60px 0}
  .quote-band blockquote{font-size:19px;line-height:1.8}
  .quote-band cite{margin-top:22px;font-size:10.5px;letter-spacing:.18em}

  /* Flow */
  .flow-grid{margin-top:32px}
  .flow-cell{padding:28px 20px}
  .flow-num{font-size:24px;margin-bottom:12px}
  .flow-cell h4{font-size:17px;margin-bottom:10px}
  .flow-cell p{font-size:13.5px;line-height:1.85}

  /* CTA */
  .cta-banner{padding:72px 0}
  .cta-grid{gap:36px}
  .cta-banner h2{font-size:24px;line-height:1.55}
  .cta-banner p{font-size:14.5px;margin-top:18px;line-height:1.95}
  .form-banner{padding:26px 22px;margin-top:34px}
  .form-banner-inner{flex-direction:row;gap:14px;align-items:center}
  .form-banner-text .sm{font-size:12px;letter-spacing:.2em}
  .form-banner-text .lg{font-size:21px;margin-top:8px;line-height:1.35}
  .form-banner-arrow{width:48px;height:48px;font-size:19px}
  .cta-img{display:none}

  /* Footer */
  .footer{padding:54px 0 24px}
  .footer-top{grid-template-columns:1fr;gap:32px;margin-bottom:36px}
  .footer-logo{font-size:22px}
  .footer-desc{font-size:14px;line-height:1.9}
  .footer h4{font-size:11px;margin-bottom:14px}
  .footer h4 .ja{font-size:12px;margin-top:4px}
  .footer ul a{font-size:14px}
  .footer-form-btn{padding:14px 20px;font-size:12px;letter-spacing:.1em}
  .footer-bottom{font-size:11px;flex-direction:column;align-items:flex-start;gap:8px}
  .footer-bottom > div:last-child a:first-of-type{margin-left:0}
  .footer-bottom a{margin-left:16px}

  /* Detail pages */
  .detail-hero{min-height:auto}
  .detail-hero .container{padding-top:110px;padding-bottom:48px}
  .detail-hero-meta{font-size:10.5px;letter-spacing:.16em;gap:10px;margin-bottom:18px;flex-wrap:wrap}
  .detail-hero-meta .num{font-size:18px}
  .detail-hero-meta .rule{width:24px}
  .detail-hero h1{font-size:30px;line-height:1.35}
  .detail-hero .sub{font-size:16px;margin-top:14px}
  .detail-hero .lead{font-size:14.5px;margin-top:22px;line-height:1.95}
  .breadcrumb{padding:18px 0 0;font-size:10.5px;letter-spacing:.14em}
  .overview{padding:60px 0 50px}
  .overview-grid{gap:30px}
  .overview-text h2{font-size:24px;line-height:1.55}
  .overview-text p{font-size:14.5px;margin-top:18px;line-height:1.95}
  .usecases,.spec,.gallery{padding:60px 0}
  .usecase-grid{gap:18px;margin-top:22px}
  .usecase-card .body{padding:24px 20px;gap:12px}
  .usecase-card .num{font-size:18px}
  .usecase-card h3{font-size:18px;line-height:1.5}
  .usecase-card p{font-size:14px;line-height:1.85}
  .spec-grid{gap:30px;margin-top:22px}
  .spec-row{padding:18px 0}
  .spec-row dt{font-size:11px;letter-spacing:.14em}
  .spec-row dt .ja{font-size:14px}
  .spec-row dd{font-size:14.5px;line-height:1.85}
  .gallery-grid{gap:12px;margin-top:22px}
}

/* ============================================================
   PILOT PAGE — sibling brand treatment
   ============================================================ */

/* Logo + pilot badge */
.logo-pilot{display:flex;align-items:center;gap:14px}
.logo-pilot img{display:block;height:120px;width:auto}
.brand-pilot{
  display:inline-flex;flex-direction:column;line-height:1.1;
  padding:8px 14px;border-left:1px solid var(--line);
}
.brand-pilot .en{
  font-family:"Inter",sans-serif;font-size:10px;letter-spacing:.28em;
  text-transform:uppercase;color:var(--accent-2);font-weight:600;margin-bottom:4px;
}
.brand-pilot .ja{
  font-family:"Zen Kaku Gothic New","Noto Sans JP",sans-serif;
  font-size:15px;letter-spacing:.04em;color:var(--text);font-weight:700;
}

/* Nav: back-link to main spray site */
.nav-back{
  display:inline-flex;align-items:center;gap:6px;
  font-family:"Inter",sans-serif;font-size:11px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--text-mute);font-weight:500;
  padding:8px 0;transition:color .25s;
}
.nav-back::before{content:"←";font-size:13px;transition:transform .2s ease}
.nav-back:hover{color:var(--accent-2)}
.nav-back:hover::before{transform:translateX(-3px)}
.nav-back .ja{display:block;font-family:"Zen Kaku Gothic New","Noto Sans JP",sans-serif;font-size:11px;letter-spacing:.04em;margin-top:2px;color:var(--text-2)}

/* FAQ — details/summary accordion */
.faq{padding:90px 0;background:var(--bg-2)}
.faq-list{margin-top:36px;border-top:1px solid var(--line-soft)}
.faq-item{border-bottom:1px solid var(--line-soft)}
.faq-item summary{
  list-style:none;cursor:pointer;
  display:flex;align-items:flex-start;gap:20px;
  padding:26px 0;
  font-family:"Zen Kaku Gothic New","Noto Sans JP",sans-serif;
  font-size:17px;font-weight:700;color:var(--text);line-height:1.6;
  position:relative;padding-right:50px;
  transition:color .2s;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{
  content:"+";position:absolute;right:6px;top:50%;transform:translateY(-50%);
  font-family:"Inter",sans-serif;font-size:24px;font-weight:300;color:var(--text-mute);
  transition:transform .25s ease, color .2s;
}
.faq-item[open] summary::after{transform:translateY(-50%) rotate(45deg);color:var(--accent-2)}
.faq-item summary:hover{color:var(--accent-2)}
.faq-q-num{
  font-family:"Inter",sans-serif;font-size:13px;font-weight:500;
  letter-spacing:.06em;color:var(--accent-2);
  flex-shrink:0;min-width:34px;padding-top:3px;
}
.faq-a{
  padding:0 0 28px 54px;
  font-size:15px;line-height:2;color:var(--text-2);
}
.faq-a p+p{margin-top:14px}
.faq-a strong{color:var(--text);font-weight:700}

/* Mobile FAQ */
@media (max-width:820px){
  .faq{padding:60px 0}
  .faq-item summary{font-size:15px;gap:12px;padding:20px 0;padding-right:40px}
  .faq-item summary::after{font-size:20px;right:0}
  .faq-q-num{font-size:12px;min-width:26px}
  .faq-a{padding:0 0 22px 38px;font-size:14px;line-height:1.95}
}

/* Mobile adjustments for pilot-brand header */
@media (max-width:820px){
  .logo-pilot{gap:8px}
  .logo-pilot img{height:64px}
  .brand-pilot{padding:6px 0 6px 10px}
  .brand-pilot .en{font-size:8.5px;letter-spacing:.22em;margin-bottom:2px}
  .brand-pilot .ja{font-size:11px}

  /* Pilot mini-site "back to main site" link inside mobile drawer */
  .nav-back{
    flex-direction:column;align-items:flex-start;
    width:100%;padding:18px 4px;border-bottom:1px solid var(--line);
    font-size:11px;gap:2px;
  }
  .nav-back .ja{font-size:13px;color:var(--text-2);margin-top:4px}
}

/* Section "詳しく見る" link button */
.section-more{
  margin-top:44px;display:flex;justify-content:center;
}
.section-more a{
  display:inline-flex;align-items:center;gap:18px;
  padding:22px 42px;background:transparent;color:var(--text);
  border:2px solid var(--text);
  font-family:"Inter","Zen Kaku Gothic New","Noto Sans JP",sans-serif;
  font-size:18px;letter-spacing:.14em;font-weight:700;text-transform:uppercase;
  transition:all .3s;
}
.section-more a::after{content:"→";font-size:22px;transition:transform .25s ease}
.section-more a:hover{background:var(--text);color:#fff}
.section-more a:hover::after{transform:translateX(4px)}
.section-more a .ja{
  font-family:"Zen Kaku Gothic New","Noto Sans JP",sans-serif;
  font-size:18px;letter-spacing:.04em;font-weight:700;text-transform:none;
}

@media (max-width:820px){
  .section-more{margin-top:32px}
  .section-more a{padding:18px 30px;font-size:15px;letter-spacing:.1em;gap:12px}
  .section-more a .ja{font-size:15px}
  .section-more a::after{font-size:18px}
}

/* ============== TIMETABLE (1-Day Training Schedule) ============== */
.tt-banner{
  margin:36px 0 30px;padding:22px 32px;
  background:var(--text);color:#fff;
  display:flex;align-items:center;justify-content:center;
  flex-wrap:wrap;gap:0;
  border-radius:2px;
}
.tt-banner-eyebrow{
  font-family:"Inter",sans-serif;font-size:11px;letter-spacing:.32em;
  text-transform:uppercase;color:var(--accent-2);font-weight:600;
  padding:0 28px 0 0;
  border-right:1px solid rgba(255,255,255,.22);
}
.tt-banner-title{
  font-family:"Playfair Display","Noto Serif JP",serif;
  font-size:30px;font-weight:500;color:#fff;letter-spacing:.04em;
  padding:0 28px;
}
.tt-banner-time{
  font-family:"Inter",sans-serif;font-size:32px;font-weight:300;
  color:#fff;letter-spacing:.04em;white-space:nowrap;
  padding:0 0 0 28px;
  border-left:1px solid rgba(255,255,255,.22);
  display:inline-flex;align-items:baseline;
}
.tt-banner-dash{
  color:var(--accent-2);font-weight:400;
  margin:0 10px;font-size:28px;
  display:inline-block;
}

/* prominent lead under the section heading */
.tt-lead{
  font-family:"Noto Serif JP",serif;
  font-size:19px;font-weight:500;line-height:2;
  color:var(--text);letter-spacing:.02em;
  max-width:780px;margin:24px 0 0;
  text-align:left;
}
.tt-lead strong{
  color:var(--accent-2);font-weight:700;
  font-family:"Noto Sans JP","Zen Kaku Gothic New",sans-serif;
}
.tt-lead .pc-only{display:inline}

@media (max-width:820px){
  .tt-banner{
    flex-direction:column;align-items:stretch;gap:14px;
    padding:22px 22px;margin:24px 0 24px;
  }
  .tt-banner-eyebrow{
    padding:0 0 14px 0;border-right:none;
    border-bottom:1px solid rgba(255,255,255,.22);
    text-align:center;
  }
  .tt-banner-title{
    padding:0 0 14px 0;font-size:24px;text-align:center;
    border-bottom:1px solid rgba(255,255,255,.22);
  }
  .tt-banner-time{
    padding:0;border-left:none;font-size:28px;
    justify-content:center;
  }
  .tt-banner-dash{font-size:24px;margin:0 8px}
  .tt-lead{
    font-size:15.5px;line-height:1.95;margin-top:20px;
    text-align:left;
  }
  .tt-lead .pc-only{display:none}
}

.timetable{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
}

/* Card */
.tt-block{
  background:#fff;border:1px solid var(--line);
  display:flex;flex-direction:column;
  position:relative;overflow:hidden;
  transition:border-color .25s ease, box-shadow .3s ease, transform .25s ease;
}
.tt-block:hover{
  border-color:var(--text);
  box-shadow:0 14px 32px rgba(0,0,0,.08);
  transform:translateY(-3px);
}

/* Image area with step number */
.tt-block-img{
  position:relative;height:200px;
  background:var(--bg-2);overflow:hidden;
}
.tt-block-img img{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform .5s ease;
}
.tt-block:hover .tt-block-img img{transform:scale(1.04)}
.tt-block-no{
  position:absolute;top:0;left:0;
  width:54px;height:54px;
  background:var(--accent-2);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-family:"Playfair Display",serif;font-size:22px;font-weight:500;
  letter-spacing:.02em;
  z-index:2;
}
.tt-block-badge{
  position:absolute;top:16px;right:16px;
  background:var(--text);color:#fff;
  font-family:"Zen Kaku Gothic New","Noto Sans JP",sans-serif;
  font-size:11px;font-weight:700;letter-spacing:.16em;
  padding:8px 14px;z-index:2;
}

/* Body */
.tt-block-body{
  padding:30px 28px 32px;
  display:flex;flex-direction:column;flex:1;
}
.tt-block-time{
  display:flex;align-items:baseline;gap:14px;
  padding-bottom:18px;margin-bottom:22px;
  border-bottom:1px solid var(--line);
}
.tt-block-hours{
  font-family:"Inter",sans-serif;
  font-size:30px;font-weight:300;
  color:var(--text);letter-spacing:.01em;line-height:1;
  white-space:nowrap;
}
.tt-block-hours .tt-dash{
  display:inline-block;margin:0 4px;color:var(--accent-2);font-weight:400;
}
.tt-block-dur{
  font-family:"Zen Kaku Gothic New","Noto Sans JP",sans-serif;
  font-size:13px;font-weight:600;letter-spacing:.04em;
  color:var(--text-mute);
}
.tt-block-tag{
  display:inline-block;align-self:flex-start;
  background:var(--bg-2);color:var(--text);
  font-family:"Zen Kaku Gothic New","Noto Sans JP",sans-serif;
  font-size:13px;font-weight:700;letter-spacing:.18em;
  padding:7px 14px;margin-bottom:18px;
}
.tt-block-heading{
  font-family:"Noto Serif JP",serif;
  font-size:21px;font-weight:700;
  color:var(--text);line-height:1.55;letter-spacing:.02em;
  margin-bottom:16px;
}
.tt-block-desc{
  font-size:14.5px;line-height:1.95;color:var(--text-2);
}
.tt-block-desc strong{color:var(--text);font-weight:700}

/* Break band */
.timetable-break{
  margin-top:24px;padding:16px 24px;
  background:var(--bg-2);border-left:3px solid var(--accent-2);
  display:flex;align-items:center;gap:18px;
  font-size:13px;color:var(--text-2);
}
.timetable-break-time{
  font-family:"Inter",sans-serif;font-weight:600;
  letter-spacing:.18em;color:var(--text);font-size:13px;
}
.timetable-break-label{font-family:"Zen Kaku Gothic New",sans-serif;font-weight:500}

/* Mobile */
@media (max-width:820px){
  .timetable-banner{
    flex-direction:column;align-items:flex-start;gap:12px;
    padding:24px 22px;margin:24px 0 32px;
  }
  .timetable-banner-title{font-size:22px}
  .timetable-banner-time{font-size:28px;gap:4px}
  .timetable-banner-time small{font-size:12px;letter-spacing:.14em}
  .timetable{grid-template-columns:1fr;gap:18px}
  .tt-block-img{height:180px}
  .tt-block-no{width:48px;height:48px;font-size:19px}
  .tt-block-badge{font-size:10px;padding:6px 11px;letter-spacing:.1em}
  .tt-block-body{padding:24px 22px 26px}
  .tt-block-time{padding-bottom:14px;margin-bottom:18px;gap:10px;flex-wrap:wrap}
  .tt-block-hours{font-size:25px}
  .tt-block-dur{font-size:12px}
  .tt-block-tag{font-size:12px;padding:6px 12px;letter-spacing:.14em;margin-bottom:14px}
  .tt-block-heading{font-size:18px;margin-bottom:14px}
  .tt-block-desc{font-size:14px;line-height:1.85}
  .timetable-break{padding:14px 18px;gap:12px;flex-wrap:wrap}
  .timetable-break-time{font-size:12px}
}

/* ============================================
   PILOT CONTACT / APPLY PAGES (v=15)
   ============================================ */

/* Inline accent link */
.inline-link{
  color:var(--accent-2);
  font-weight:700;
  border-bottom:1px solid var(--accent-2);
  transition:opacity .2s;
}
.inline-link:hover{opacity:.7}

/* Note line (small footnote-like text) */
.note-line{
  font-size:14px;color:var(--text-mute);line-height:1.85;
  margin-top:36px;padding-top:24px;border-top:1px dashed var(--line);
  max-width:840px;
}

/* ===== Inquiry Topics Grid ===== */
.topic-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1px;background:var(--line);
  margin-top:30px;
}
.topic-card{
  background:var(--bg);
  padding:48px 36px;
  display:flex;flex-direction:column;gap:18px;
  transition:background .3s;
}
.topic-card:hover{background:var(--bg-2)}
.topic-num{
  font-family:"Playfair Display",serif;font-style:italic;
  font-size:38px;font-weight:400;line-height:1;color:var(--text);
  letter-spacing:-.01em;
}
.topic-card h3{
  font-family:"Zen Kaku Gothic New","Noto Sans JP",sans-serif;
  font-size:19px;font-weight:700;line-height:1.55;
  color:var(--text);
  padding-bottom:14px;border-bottom:1px solid var(--line);
}
.topic-card p{
  font-size:15px;color:var(--text-2);line-height:1.95;
}

/* ===== Form Field Preview ===== */
.field-section{background:var(--bg-2)}
.field-group{margin-top:32px}
.field-group:first-of-type{margin-top:0}
.field-group-title{
  font-family:"Zen Kaku Gothic New","Noto Sans JP",sans-serif;
  font-size:14px;font-weight:700;letter-spacing:.08em;
  color:var(--text);
  padding:14px 18px;
  background:var(--text);color:#fff;
  display:inline-block;
  margin-bottom:18px;
}
.field-list{
  display:flex;flex-direction:column;
  border-top:1px solid var(--line);
  background:var(--bg);
}
.field-row{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 24px;border-bottom:1px solid var(--line);
  gap:20px;
}
.field-label{
  font-family:"Zen Kaku Gothic New","Noto Sans JP",sans-serif;
  font-size:16px;font-weight:500;color:var(--text);
  letter-spacing:.02em;
}
.field-meta{
  font-size:11.5px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--text-mute);font-weight:500;
  padding:6px 12px;border:1px solid var(--line);
  border-radius:2px;flex-shrink:0;
  font-family:"Inter",sans-serif;
}
.field-meta.required{
  color:var(--accent-2);border-color:var(--accent-2);
  background:rgba(184,84,60,.04);
}

/* ===== Application Flow ===== */
.flow-list{
  display:flex;flex-direction:column;
  margin-top:30px;
}
.flow-item{
  display:grid;
  grid-template-columns:140px 1fr;
  gap:40px;
  padding:36px 0;
  border-top:1px solid var(--line);
  align-items:start;
}
.flow-item:last-child{border-bottom:1px solid var(--line)}
.flow-no{
  font-family:"Playfair Display",serif;font-style:italic;
  font-size:64px;font-weight:400;line-height:1;
  color:var(--text);letter-spacing:-.02em;
  padding-top:6px;
}
.flow-body h3{
  font-family:"Zen Kaku Gothic New","Noto Sans JP",sans-serif;
  font-size:24px;font-weight:700;line-height:1.5;
  color:var(--text);margin-bottom:14px;
}
.flow-body p{
  font-size:16px;color:var(--text-2);line-height:2;
}
.flow-item-final{
  background:linear-gradient(90deg,rgba(184,84,60,.06) 0%,transparent 70%);
}
.flow-item-final .flow-no{color:var(--accent-2)}

/* ===== Payment Cards ===== */
.payment-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:32px;margin-top:30px;
}
.payment-card{
  background:var(--bg-2);
  border:1px solid var(--line);
  padding:48px 40px;
  display:flex;flex-direction:column;gap:18px;
  transition:transform .3s, box-shadow .3s;
}
.payment-card:hover{
  transform:translateY(-3px);
  box-shadow:0 14px 32px rgba(0,0,0,.05);
}
.payment-card-num{
  font-family:"Playfair Display",serif;font-style:italic;
  font-size:56px;font-weight:400;line-height:1;color:var(--accent-2);
  letter-spacing:-.02em;
}
.payment-card-tag{
  font-family:"Inter",sans-serif;
  font-size:11px;letter-spacing:.28em;text-transform:uppercase;
  color:var(--text-mute);font-weight:500;
}
.payment-card h3{
  font-family:"Zen Kaku Gothic New","Noto Sans JP",sans-serif;
  font-size:22px;font-weight:700;line-height:1.5;
  color:var(--text);
  padding-bottom:14px;border-bottom:1px solid var(--line);
}
.payment-card p{
  font-size:15px;color:var(--text-2);line-height:1.95;
}

/* ===== Form Banner Apply Variant (warmer accent) ===== */
.form-banner-apply{background:var(--accent-2)}
.form-banner-apply:hover{background:var(--text)}

/* ============================================
   Responsive (~820px and ~560px)
   ============================================ */
@media (max-width:980px){
  .topic-grid{grid-template-columns:repeat(2,1fr)}
  .payment-grid{grid-template-columns:1fr;gap:20px}
  .flow-item{grid-template-columns:90px 1fr;gap:24px;padding:28px 0}
  .flow-no{font-size:48px}
}
@media (max-width:820px){
  .topic-grid{grid-template-columns:1fr;gap:1px}
  .topic-card{padding:34px 22px;gap:14px}
  .topic-num{font-size:30px}
  .topic-card h3{font-size:17px;padding-bottom:10px}
  .topic-card p{font-size:14.5px;line-height:1.9}

  .field-row{padding:14px 16px;gap:12px;flex-wrap:wrap}
  .field-label{font-size:14.5px;flex:1 1 auto}
  .field-meta{font-size:10px;letter-spacing:.12em;padding:5px 10px}
  .field-group-title{font-size:12.5px;padding:11px 14px}

  .flow-item{grid-template-columns:1fr;gap:10px;padding:24px 0}
  .flow-no{font-size:40px;padding-top:0}
  .flow-body h3{font-size:19px;margin-bottom:10px;line-height:1.5}
  .flow-body p{font-size:14.5px;line-height:1.9}

  .payment-card{padding:32px 24px;gap:14px}
  .payment-card-num{font-size:44px}
  .payment-card-tag{font-size:10px;letter-spacing:.2em}
  .payment-card h3{font-size:18px;padding-bottom:10px}
  .payment-card p{font-size:14.5px;line-height:1.9}

  .note-line{font-size:13px;line-height:1.85;margin-top:24px;padding-top:18px}
}
@media (max-width:560px){
  .topic-card{padding:28px 20px}
  .topic-num{font-size:26px}
  .topic-card h3{font-size:16px}
  .topic-card p{font-size:13.5px}

  .field-row{padding:12px 14px;gap:10px}
  .field-label{font-size:13.5px}
  .field-meta{font-size:9.5px;padding:4px 8px}

  .flow-no{font-size:34px}
  .flow-body h3{font-size:17px}
  .flow-body p{font-size:13.5px;line-height:1.85}

  .payment-card{padding:26px 20px}
  .payment-card-num{font-size:36px}
  .payment-card h3{font-size:16px}
  .payment-card p{font-size:13.5px}
}

/* === STICKY APPLY CTA (pilot-training & pilot) === */
.sticky-apply{
  position:fixed;
  right:28px;
  bottom:28px;
  z-index:1100;
  display:inline-flex;
  align-items:center;
  gap:24px;
  padding:30px 44px 30px 26px;
  background:var(--accent-2);
  color:#fff;
  text-decoration:none;
  font-family:"Zen Kaku Gothic New","Noto Sans JP",sans-serif;
  border-radius:999px;
  box-shadow:0 18px 40px rgba(0,0,0,.26), 0 6px 14px rgba(0,0,0,.10);
  opacity:0;
  transform:translateY(28px);
  pointer-events:none;
  transition:opacity .35s ease, transform .35s ease, background .2s ease, box-shadow .2s ease;
  letter-spacing:.02em;
}
.sticky-apply.is-visible{
  opacity:1;
  transform:translateY(0);
  pointer-events:auto;
}
.sticky-apply:hover{
  background:#9a4632;
  box-shadow:0 22px 46px rgba(0,0,0,.32), 0 8px 16px rgba(0,0,0,.12);
  transform:translateY(-2px);
}
/* Blue variant for pilot.html → training CTA */
.sticky-apply.sticky-training{
  background:#1e3a8a; /* deep indigo */
}
.sticky-apply.sticky-training:hover{
  background:#152a66;
}
.sticky-apply-icon{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:70px;
  height:70px;
  background:rgba(255,255,255,.18);
  border:1px solid rgba(255,255,255,.4);
  border-radius:50%;
  flex-shrink:0;
}
.sticky-apply-icon svg{
  width:34px;
  height:34px;
}
.sticky-apply-text{
  display:flex;
  flex-direction:column;
  line-height:1.2;
  gap:4px;
}
.sticky-apply-en{
  font-family:"Playfair Display",serif;
  font-style:italic;
  font-size:19px;
  opacity:.9;
  font-weight:500;
  letter-spacing:.05em;
}
.sticky-apply-ja{
  font-size:28px;
  font-weight:900;
  letter-spacing:.06em;
}
.sticky-apply-arrow{
  font-size:30px;
  margin-left:6px;
  transition:transform .25s ease;
  font-weight:400;
}
.sticky-apply:hover .sticky-apply-arrow{
  transform:translateX(6px);
}
@media (max-width:820px){
  .sticky-apply{
    right:14px;
    left:14px;
    bottom:14px;
    padding:22px 28px 22px 22px;
    justify-content:center;
    border-radius:999px;
    gap:14px;
  }
  .sticky-apply-icon{
    width:56px;
    height:56px;
  }
  .sticky-apply-icon svg{
    width:26px;
    height:26px;
  }
  .sticky-apply-en{
    font-size:16px;
  }
  .sticky-apply-ja{
    font-size:22px;
  }
  .sticky-apply-arrow{
    font-size:24px;
  }
}
@media (max-width:560px){
  .sticky-apply{
    padding:20px 26px 20px 20px;
    gap:16px;
  }
  .sticky-apply-en{
    display:none;
  }
  .sticky-apply-ja{
    font-size:20px;
  }
}

/* === Form Modal (iframe popup for /pilot-contact/ and /pilot-apply/) === */
.form-modal{
  position:fixed;inset:0;z-index:9999;
  display:none;
  background:rgba(20,18,16,.72);
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
  opacity:0;
  transition:opacity .25s ease;
}
.form-modal.is-open{display:block;opacity:1}
.form-modal-shell{
  position:absolute;inset:24px;
  max-width:1080px;
  margin:0 auto;
  background:#fff;
  box-shadow:0 28px 70px rgba(0,0,0,.4);
  border-radius:14px;
  overflow:hidden;
  display:flex;
  flex-direction:column;
  transform:translateY(20px);
  transition:transform .3s ease;
}
.form-modal.is-open .form-modal-shell{transform:translateY(0)}
.form-modal-head{
  flex:0 0 auto;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 26px;
  border-bottom:1px solid #eee;
  background:#fafaf9;
}
.form-modal-title{
  font-family:"Zen Kaku Gothic New","Noto Sans JP",sans-serif;
  font-weight:800;font-size:18px;color:#1a1714;letter-spacing:.04em;
}
.form-modal-title small{
  display:block;font-family:"Playfair Display",serif;font-style:italic;
  font-size:12px;color:#7a6e62;font-weight:400;letter-spacing:.04em;margin-bottom:4px;
}
.form-modal-close{
  width:44px;height:44px;border-radius:50%;
  background:#fff;border:1px solid #d9d3cc;
  font-size:22px;line-height:1;color:#1a1714;cursor:pointer;
  display:grid;place-items:center;transition:all .2s;
}
.form-modal-close:hover{background:#1a1714;color:#fff;border-color:#1a1714}
.form-modal-body{
  flex:1 1 auto;
  position:relative;
  overflow:hidden;
  background:#fff;
}
.form-modal-iframe{
  width:100%;height:100%;border:0;display:block;
}
.form-modal-loading{
  position:absolute;inset:0;display:grid;place-items:center;
  color:#a89c8e;font-family:"Zen Kaku Gothic New","Noto Sans JP",sans-serif;
  font-size:14px;letter-spacing:.06em;
  background:#fff;
}
body.form-modal-open{overflow:hidden}
@media (max-width:820px){
  .form-modal-shell{inset:12px;border-radius:10px}
  .form-modal-head{padding:14px 18px}
  .form-modal-title{font-size:16px}
  .form-modal-close{width:38px;height:38px;font-size:20px}
}
