:root{
  --navy:#061429;
  --navy2:#0b1f3d;
  --gold:#d9b76f;
  --gold2:#f1d58c;
  --white:#ffffff;
  --soft:#f6f3ed;
  --ink:#152033;
  --muted:#697386;
  --line:rgba(255,255,255,.18);
  --shadow:0 24px 70px rgba(0,0,0,.26);
  --radius:24px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:-apple-system,BlinkMacSystemFont,"Hiragino Sans","Yu Gothic","Yu Gothic UI",Meiryo,sans-serif;
  color:var(--ink);
  background:#fff;
  line-height:1.75;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.skip-link{position:absolute;left:-999px;top:auto}
.skip-link:focus{left:16px;top:16px;z-index:9999;background:#fff;padding:12px}
.container{width:min(1120px,calc(100% - 40px));margin-inline:auto}
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:50;
  background:rgba(6,20,41,.82);
  backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(255,255,255,.1);
}
.header-inner{height:72px;width:min(1180px,calc(100% - 32px));margin:auto;display:flex;align-items:center;justify-content:space-between;gap:24px}
.brand{display:flex;align-items:center;gap:12px;color:#fff;font-weight:800;letter-spacing:.06em}
.brand-mark{display:grid;place-items:center;width:36px;height:36px;border:1px solid var(--gold);border-radius:10px;color:var(--gold)}
.global-nav{display:flex;gap:24px;color:rgba(255,255,255,.82);font-size:14px}
.header-cta{background:linear-gradient(135deg,var(--gold),var(--gold2));color:#111;padding:10px 18px;border-radius:999px;font-weight:800}
.section{padding:96px 0}
.section-dark{background:var(--navy);color:#fff}
.soft-bg{background:var(--soft)}
.hero{
  position:relative;
  min-height:860px;
  display:grid;
  align-items:center;
  overflow:hidden;
  padding:130px 0 86px;
}
.hero-bg,.final-bg{
  position:absolute;inset:0;
  background-image:url("../img/tokyo-dance-recital-video-shooting-hero.jpg");
  background-size:cover;
  background-position:center right;
  transform:scale(1.01);
}
.hero-overlay{
  position:absolute;inset:0;
  background:
    linear-gradient(90deg,rgba(4,13,27,.97) 0%,rgba(4,13,27,.78) 40%,rgba(4,13,27,.20) 72%,rgba(4,13,27,.52) 100%),
    radial-gradient(circle at 78% 24%,rgba(217,183,111,.18),transparent 28%);
}
.hero-grid{position:relative;z-index:2;display:grid;grid-template-columns:minmax(0,1.12fr) 360px;gap:48px;align-items:end}
.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:10px;
  color:var(--gold);
  font-size:17px;
  letter-spacing:.24em;
  font-weight:900;
  margin:0 0 18px;
  text-transform:uppercase;
  line-height:1;
}
.eyebrow::before{
  content:"";
  width:18px;
  height:18px;
  background:linear-gradient(135deg,var(--gold),var(--gold2));
  clip-path:polygon(50% 0,100% 50%,50% 100%,0 50%);
  box-shadow:0 6px 16px rgba(217,183,111,.3);
}
.section-title .eyebrow,
.two-col .eyebrow,
.area-grid .eyebrow,
.voice-grid .eyebrow,
.final-inner .eyebrow,
.contact-card .eyebrow{
  padding:12px 18px;
  border-radius:999px;
  background:rgba(6,20,41,.06);
  border:1px solid rgba(217,183,111,.26);
}
.section-dark .eyebrow,
.hero .eyebrow{
  padding:12px 18px;
  border-radius:999px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(217,183,111,.28);
}
.hero h1{font-size:clamp(36px,5.8vw,72px);line-height:1.08;margin:0 0 22px;letter-spacing:.02em}
.lead{font-size:clamp(17px,2vw,22px);max-width:720px;margin:0 0 28px;color:rgba(255,255,255,.92)}
.hero-points{display:flex;flex-wrap:wrap;gap:10px;margin:0 0 30px}
.hero-points span,.area-tags span{
  border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.08);
  color:#fff;
  padding:8px 12px;
  border-radius:999px;
  font-size:13px;
}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:16px}
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  min-height:52px;padding:14px 24px;border-radius:999px;
  font-weight:900;letter-spacing:.03em;border:1px solid transparent;
}
.btn-primary{background:linear-gradient(135deg,var(--gold),var(--gold2));color:#101010;box-shadow:0 14px 36px rgba(217,183,111,.34)}
.btn-ghost{border-color:rgba(255,255,255,.28);color:#fff;background:rgba(255,255,255,.06)}
.microcopy{font-size:13px;color:rgba(255,255,255,.78);margin:0}
.hero-card{
  border:1px solid rgba(255,255,255,.2);
  background:rgba(8,24,48,.72);
  box-shadow:var(--shadow);
  border-radius:var(--radius);
  padding:28px;
}
.card-label{font-size:13px;color:var(--gold);font-weight:900;margin:0 0 14px}
.hero-card ul{margin:0 0 16px;padding-left:1.2em}
.hero-card li{margin:.3em 0}
.hero-card p:last-child{margin-bottom:0;color:rgba(255,255,255,.8);font-size:14px}
.scroll-hint{position:absolute;z-index:3;left:50%;bottom:24px;transform:translateX(-50%);color:rgba(255,255,255,.62);font-size:11px;letter-spacing:.2em;text-transform:uppercase}
.summary{padding:42px 0;background:#071832;color:#fff}
.section-title{max-width:780px;margin:0 auto 42px;text-align:center}
.section-title.compact{margin-bottom:28px}
.section-title h2,.voice-grid h2,.two-col h2,.area-grid h2,.final-inner h2,.contact-card h2{font-size:clamp(28px,4vw,48px);line-height:1.25;margin:0 0 16px}
.section-title p:not(.eyebrow){color:var(--muted);margin:0}
.summary-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.summary-grid article{
  position:relative;
  border:1px solid rgba(217,183,111,.26);
  background:
    linear-gradient(180deg,rgba(255,255,255,.12),rgba(255,255,255,.04)),
    linear-gradient(135deg,rgba(217,183,111,.08),transparent 42%);
  border-radius:28px;
  padding:28px 26px 24px;
  overflow:hidden;
  box-shadow:0 18px 46px rgba(0,0,0,.18);
  transition:transform .28s ease, box-shadow .28s ease, border-color .28s ease;
}
.summary-grid article::before{
  content:"";
  position:absolute;
  left:0; right:0; top:0;
  height:4px;
  background:linear-gradient(90deg,var(--gold),rgba(241,213,140,.2));
}
.summary-grid article::after{
  content:"";
  position:absolute;
  right:-10px;
  bottom:-10px;
  width:92px;
  height:92px;
  background:linear-gradient(135deg,rgba(217,183,111,.16),rgba(217,183,111,0));
  clip-path:polygon(100% 0,0 100%,100% 100%);
}
.summary-grid article:hover{
  transform:translateY(-6px);
  box-shadow:0 28px 60px rgba(0,0,0,.24);
  border-color:rgba(241,213,140,.52);
}
.summary-grid span{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:72px;
  min-height:54px;
  padding:0 16px;
  margin-bottom:16px;
  border-radius:16px;
  border:1px solid rgba(217,183,111,.42);
  background:linear-gradient(180deg,rgba(10,31,61,.82),rgba(10,31,61,.56));
  color:var(--gold2);
  font-weight:900;
  font-size:30px;
  line-height:1;
  letter-spacing:.06em;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08), 0 10px 28px rgba(0,0,0,.18);
}
.summary-grid h3{
  margin:2px 0 10px;
  font-size:22px;
  letter-spacing:.02em;
}
.summary-grid p{
  margin:0;
  color:rgba(255,255,255,.82);
  font-size:15px;
  line-height:1.72;
}
.voice-strip{padding:60px 0;background:linear-gradient(135deg,#061429,#10264b)}
.voice-grid{display:grid;grid-template-columns:.78fr 1fr;gap:40px;align-items:center}
.voice-grid p:last-child{font-size:18px;color:rgba(255,255,255,.86);margin:0}
.two-col,.area-grid{display:grid;grid-template-columns:1fr 1fr;gap:58px;align-items:center}
.two-col.reverse{grid-template-columns:1fr 1fr}
.image-frame{
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:var(--shadow);
  background:#111;
}
.image-frame img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/3}
.feature-list{display:grid;gap:14px;margin-top:26px}
.feature-list div{
  border-left:4px solid var(--gold);
  padding:16px 18px;
  background:#fff;
  border-radius:0 18px 18px 0;
  box-shadow:0 10px 28px rgba(8,24,48,.08);
}
.feature-list h3{margin:0 0 6px}
.feature-list p{margin:0;color:var(--muted)}
.image-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
figure{margin:0;background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:0 16px 42px rgba(8,24,48,.12)}
figure img{aspect-ratio:4/3;width:100%;object-fit:cover}
figcaption{padding:14px 18px;color:var(--muted);font-size:14px}
.check-list{display:grid;gap:8px;padding:0;margin:22px 0;list-style:none}
.check-list li{position:relative;padding-left:28px}
.check-list li:before{content:"";position:absolute;left:0;top:.7em;width:11px;height:11px;background:var(--gold);clip-path:polygon(50% 0,100% 50%,50% 100%,0 50%)}
.note{font-size:13px;color:rgba(255,255,255,.72);border-top:1px solid rgba(255,255,255,.16);padding-top:16px}
.area-tags{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px}
.area-tags span{background:#10264b}
.price-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.price-cards article{
  background:#fff;border-radius:22px;padding:28px;
  box-shadow:0 16px 42px rgba(8,24,48,.1);
}
.price-cards h3{margin:0 0 8px}
.price-cards p{color:var(--muted)}
.price-cards strong{display:block;font-size:25px;color:var(--navy);margin:12px 0 4px}
.price-cards small{color:var(--muted)}
.flow-list{
  list-style:none;padding:0;margin:0;
  display:grid;grid-template-columns:repeat(3,1fr);gap:18px;
}
.flow-list li{
  border:1px solid #e7e0d4;border-radius:22px;padding:24px;background:#fff;
}
.flow-list span{color:var(--gold);font-weight:900}
.flow-list h3{margin:8px 0}
.flow-list p{margin:0;color:var(--muted)}
.final-cta{position:relative;overflow:hidden;padding:116px 0}
.final-bg{background-image:url("../img/tokyo-dance-recital-final-cta-stage.jpg");background-position:center}
.final-cta:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(6,20,41,.92),rgba(6,20,41,.62),rgba(6,20,41,.88))}
.final-inner{position:relative;z-index:1;max-width:760px;margin-left:auto;margin-right:auto;text-align:center}
.final-inner p:not(.eyebrow){font-size:18px;color:rgba(255,255,255,.84)}
.faq-list{max-width:900px;margin:auto;display:grid;gap:12px}
details{background:#fff;border-radius:18px;padding:18px 22px;box-shadow:0 10px 26px rgba(8,24,48,.08)}
summary{cursor:pointer;font-weight:900}
details p{color:var(--muted);margin:12px 0 0}
.contact-section{background:linear-gradient(135deg,#061429,#10264b);color:#fff}
.contact-card{display:grid;grid-template-columns:.86fr 1.14fr;gap:42px;align-items:start;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);border-radius:var(--radius);padding:42px;box-shadow:var(--shadow)}
.contact-card p{color:rgba(255,255,255,.82)}
.contact-form{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.contact-form label{display:grid;gap:6px;font-weight:800;font-size:14px}
.contact-form input{min-height:48px;border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.1);color:#fff;border-radius:12px;padding:0 14px}
.contact-form input::placeholder{color:rgba(255,255,255,.46)}
.contact-form .btn,.form-note{grid-column:1/-1}
.form-note{font-size:12px;color:rgba(255,255,255,.62)!important;margin:0}
.site-footer{background:#030914;color:rgba(255,255,255,.78);padding:44px 0}
.footer-grid{display:grid;grid-template-columns:1fr 1fr;gap:32px}
.brand-footer{font-size:22px;font-weight:900;color:#fff;margin:0 0 6px}
.footer-grid nav{display:grid;gap:8px;justify-items:end}
.floating-cta{display:none}

@media (max-width: 900px){
  .global-nav{display:none}
  .header-inner{height:64px}
  .hero{min-height:760px;padding-top:110px}
  .hero-bg{background-position:center}
  .hero-overlay{background:linear-gradient(180deg,rgba(4,13,27,.92),rgba(4,13,27,.76) 54%,rgba(4,13,27,.92))}
  .hero-grid,.two-col,.two-col.reverse,.area-grid,.voice-grid,.contact-card{grid-template-columns:1fr}
  .hero-card{display:none}
  .summary-grid,.price-cards,.flow-list{grid-template-columns:1fr}
  .image-grid{grid-template-columns:1fr}
  .section{padding:72px 0}
  .contact-form{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .footer-grid nav{justify-items:start}
  .floating-cta{display:block;position:fixed;z-index:60;left:14px;right:14px;bottom:14px}
  .floating-cta a{display:flex;justify-content:center;background:linear-gradient(135deg,var(--gold),var(--gold2));color:#111;font-weight:900;padding:14px;border-radius:999px;box-shadow:0 10px 30px rgba(0,0,0,.3)}
  body{padding-bottom:70px}
}

.reveal{opacity:0;transform:translateY(18px);transition:opacity .65s ease,transform .65s ease}
.reveal.is-visible{opacity:1;transform:none}

.price-message{
  display:grid;
  grid-template-columns:.78fr 1fr;
  gap:24px;
  align-items:center;
  background:linear-gradient(135deg,#061429,#10264b);
  color:#fff;
  border-radius:var(--radius);
  padding:30px;
  margin:0 0 24px;
  box-shadow:0 16px 42px rgba(8,24,48,.16);
}
.price-message-label{
  display:inline-flex;
  color:var(--gold);
  font-size:12px;
  letter-spacing:.16em;
  font-weight:900;
  margin-bottom:8px;
}
.price-message h3{font-size:clamp(22px,3vw,34px);line-height:1.35;margin:0}
.price-message p{margin:0;color:rgba(255,255,255,.82)}
.price-note{
  margin:18px 0 0;
  color:var(--muted);
  font-size:13px;
}
@media (max-width: 900px){
  .price-message{grid-template-columns:1fr;padding:24px}
}

.header-top{
  min-height:30px;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:18px;
  padding:5px 16px;
  color:rgba(255,255,255,.82);
  font-size:12px;
  background:rgba(3,9,20,.78);
  border-bottom:1px solid rgba(255,255,255,.08);
}
.header-phone{color:var(--gold2);font-weight:800}
.header-note{color:rgba(255,255,255,.62)}
.brand-text{display:grid;line-height:1.2}
.brand-text strong{font-size:14px;letter-spacing:.08em}
.brand-text small{font-size:11px;color:rgba(255,255,255,.72);font-weight:600;letter-spacing:.02em}
.footer-seo{display:grid;gap:34px}
.footer-main{max-width:820px}
.footer-contact{color:var(--gold2)!important;font-weight:800}
.footer-link-groups{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:24px;
  border-top:1px solid rgba(255,255,255,.12);
  padding-top:28px;
}
.footer-link-groups h2{
  font-size:14px;
  color:#fff;
  margin:0 0 12px;
}
.footer-link-groups a{
  display:block;
  color:rgba(255,255,255,.72);
  font-size:13px;
  margin:0 0 8px;
}
.footer-link-groups a:hover{color:var(--gold2)}
@media (max-width:900px){
  .header-top{display:none}
  .brand-text strong{font-size:12px}
  .brand-text small{display:none}
  .footer-link-groups{grid-template-columns:1fr}
}

.price-main{
  display:grid;
  grid-template-columns:.78fr 1fr;
  gap:24px;
  align-items:center;
  margin:0 0 24px;
}
.price-main-card{
  background:linear-gradient(135deg,#061429,#10264b);
  color:#fff;
  border-radius:var(--radius);
  padding:34px;
  box-shadow:0 16px 42px rgba(8,24,48,.16);
}
.price-main-label{
  color:var(--gold);
  font-size:12px;
  letter-spacing:.16em;
  font-weight:900;
  margin:0 0 10px;
}
.price-main-value{
  margin:0;
  font-size:30px;
  font-weight:900;
  line-height:1.2;
}
.price-main-value span{
  font-size:64px;
  color:var(--gold2);
  letter-spacing:.02em;
}
.price-main-sub{
  margin:10px 0 0;
  color:rgba(255,255,255,.78);
}
.price-main-text{
  background:#fff;
  border-radius:var(--radius);
  padding:30px;
  box-shadow:0 16px 42px rgba(8,24,48,.1);
}
.price-main-text h3{
  margin:0 0 10px;
  font-size:clamp(22px,3vw,32px);
  line-height:1.35;
}
.price-main-text p{margin:0;color:var(--muted)}
@media (max-width:900px){
  .price-main{grid-template-columns:1fr}
  .price-main-value span{font-size:52px}
}

.hero h1 span{
  color:var(--gold2);
  white-space:nowrap;
}
.hero .lead br,
.hero .microcopy br{
  display:block;
}
@media (max-width: 560px){
  .hero h1{
    font-size:clamp(31px,9vw,42px);
    line-height:1.16;
  }
  .hero h1 span{
    white-space:normal;
  }
  .lead{
    font-size:16px;
  }
}


.price-cards article,
.flow-list li,
.feature-list div,
figure,
details{
  position:relative;
}
.price-cards article::before,
.flow-list li::before,
.feature-list div::before,
figure::before{
  content:"";
  position:absolute;
  top:0;
  left:0;
  right:0;
  height:4px;
  background:linear-gradient(90deg,var(--gold),rgba(241,213,140,.22));
}
.price-cards article,
.flow-list li{
  border:1px solid rgba(217,183,111,.18);
}
.price-cards article:hover,
.flow-list li:hover{
  transform:translateY(-4px);
  box-shadow:0 24px 52px rgba(8,24,48,.14);
}



@media (max-width: 900px){
  .summary-grid span{
    min-width:64px;
    min-height:48px;
    font-size:26px;
  }
  .summary-grid h3{font-size:20px}
  .eyebrow{
    font-size:15px;
    letter-spacing:.18em;
  }
}



.double-show-section{
  background:#fff;
}
.double-show-cards{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
  margin:24px 0 18px;
}
.double-show-cards article{
  position:relative;
  overflow:hidden;
  border:1px solid rgba(217,183,111,.22);
  border-radius:20px;
  padding:20px 18px;
  background:
    linear-gradient(180deg,#fff,#fbf8f0),
    linear-gradient(135deg,rgba(217,183,111,.12),transparent);
  box-shadow:0 14px 34px rgba(8,24,48,.08);
}
.double-show-cards article::before{
  content:"";
  position:absolute;
  top:0;left:0;right:0;
  height:4px;
  background:linear-gradient(90deg,var(--gold),rgba(241,213,140,.22));
}
.double-show-cards span{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:48px;
  height:38px;
  border-radius:12px;
  background:var(--navy);
  color:var(--gold2);
  font-weight:900;
  font-size:20px;
  margin-bottom:10px;
}
.double-show-cards h3{
  margin:0 0 6px;
  font-size:18px;
}
.double-show-cards p{
  margin:0;
  color:var(--muted);
  font-size:14px;
  line-height:1.65;
}
.note-light{
  font-size:13px;
  color:var(--muted);
  border-top:1px solid rgba(8,24,48,.12);
  padding-top:14px;
}
@media (max-width:900px){
  .double-show-cards{
    grid-template-columns:1fr;
  }
}


.toc-section{
  background:linear-gradient(180deg,#fff,#f6f3ed);
  padding:34px 0 72px;
}
.toc-card{
  margin-top:-58px;
  position:relative;
  z-index:5;
  background:rgba(255,255,255,.94);
  border:1px solid rgba(217,183,111,.22);
  border-radius:28px;
  box-shadow:0 26px 72px rgba(8,24,48,.18);
  padding:30px;
  backdrop-filter:blur(12px);
}
.toc-head{
  display:grid;
  grid-template-columns:.42fr 1fr 1.1fr;
  gap:24px;
  align-items:center;
  border-bottom:1px solid rgba(8,24,48,.1);
  padding-bottom:22px;
  margin-bottom:22px;
}
.toc-head h2{margin:0;font-size:clamp(24px,3vw,34px);line-height:1.25}
.toc-head p:not(.eyebrow){margin:0;color:var(--muted);font-size:14px}
.toc-grid{
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:12px;
}
.toc-grid a{
  position:relative;
  display:grid;
  gap:7px;
  min-height:92px;
  padding:16px;
  border-radius:18px;
  background:linear-gradient(180deg,#fff,#fbf8f0);
  border:1px solid rgba(217,183,111,.18);
  box-shadow:0 12px 30px rgba(8,24,48,.06);
  font-weight:900;
  line-height:1.35;
  overflow:hidden;
}
.toc-grid a::after{
  content:"";
  position:absolute;
  right:-1px;bottom:-1px;
  width:46px;height:46px;
  background:linear-gradient(135deg,rgba(217,183,111,0),rgba(217,183,111,.26));
  clip-path:polygon(100% 0,0 100%,100% 100%);
}
.toc-grid span{
  color:var(--gold);
  font-size:20px;
  line-height:1;
  letter-spacing:.08em;
}
.seo-definition{
  background:#fff;
}
.checkpoint-grid,
.voice-cards,
.area-detail-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
}
.checkpoint-grid article,
.voice-cards article,
.area-detail-grid article{
  position:relative;
  overflow:hidden;
  background:#fff;
  border:1px solid rgba(217,183,111,.2);
  border-radius:24px;
  padding:26px;
  box-shadow:0 16px 42px rgba(8,24,48,.08);
}
.checkpoint-grid article::before,
.voice-cards article::before,
.area-detail-grid article::before{
  content:"";
  position:absolute;left:0;right:0;top:0;height:4px;
  background:linear-gradient(90deg,var(--gold),rgba(241,213,140,.22));
}
.checkpoint-grid span{
  display:inline-flex;
  min-width:58px;
  height:44px;
  align-items:center;
  justify-content:center;
  background:var(--navy);
  color:var(--gold2);
  border-radius:14px;
  font-size:24px;
  font-weight:900;
  margin-bottom:14px;
}
.checkpoint-grid h3,
.voice-cards h3,
.area-detail-grid h3{margin:0 0 10px;font-size:20px;line-height:1.45}
.checkpoint-grid p,
.voice-cards p,
.area-detail-grid p{margin:0;color:var(--muted);font-size:15px}
.voice-meta{color:var(--gold)!important;font-weight:900;margin:0 0 10px!important}
.image-band-section{
  padding:74px 0;
  background:linear-gradient(180deg,#061429,#10264b);
}
.image-band-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
}
.image-band-grid figure{
  background:rgba(255,255,255,.06);
  color:#fff;
  border:1px solid rgba(217,183,111,.18);
}
.image-band-grid figcaption{color:rgba(255,255,255,.82)}
.image-band-grid img{aspect-ratio:4/3;object-fit:cover;width:100%}
.area-detail-section{
  background:#fff;
}
@media (max-width: 900px){
  .toc-card{margin-top:-30px;padding:22px}
  .toc-head{grid-template-columns:1fr;gap:10px}
  .toc-grid{grid-template-columns:1fr 1fr}
  .checkpoint-grid,
  .voice-cards,
  .area-detail-grid,
  .image-band-grid{grid-template-columns:1fr}
}
@media (max-width: 520px){
  .toc-grid{grid-template-columns:1fr}
}


/* v9.2 spacing + shape psychology adjustments */
.section{
  padding:76px 0;
}
.summary{
  padding:38px 0 56px;
}
.toc-section{
  padding:24px 0 54px;
}
.voice-strip{
  padding:48px 0;
}
.image-band-section{
  padding:58px 0;
}
.final-cta{
  padding:92px 0;
}
.section-title{
  margin-bottom:34px;
}
.two-col,
.area-grid{
  gap:44px;
}
.toc-card{
  margin-top:-44px;
}
@media (max-width:900px){
  .section{
    padding:58px 0;
  }
  .toc-section{
    padding:18px 0 44px;
  }
  .summary{
    padding:34px 0 46px;
  }
  .voice-strip{
    padding:42px 0;
  }
  .image-band-section{
    padding:48px 0;
  }
  .final-cta{
    padding:76px 0;
  }
  .section-title{
    margin-bottom:26px;
  }
}

/* Triangle direction markers: used sparingly to guide the eye downward */
.section,
.summary,
.voice-strip,
.toc-section,
.image-band-section{
  position:relative;
}
.toc-section::after,
.summary::after,
.seo-definition::after,
.checkpoints-section::after,
.voices-section::after,
.area-detail-section::after,
.double-show-section::after{
  content:"";
  position:absolute;
  left:50%;
  bottom:-13px;
  transform:translateX(-50%);
  width:0;
  height:0;
  border-left:15px solid transparent;
  border-right:15px solid transparent;
  border-top:16px solid var(--gold);
  filter:drop-shadow(0 6px 10px rgba(217,183,111,.28));
  z-index:3;
}
.summary::after,
.image-band-section::after{
  border-top-color:var(--gold2);
}

/* Small triangle bullets for CTA and important cards */
.btn::after{
  content:"";
  width:0;
  height:0;
  border-top:5px solid transparent;
  border-bottom:5px solid transparent;
  border-left:7px solid currentColor;
  margin-left:10px;
  opacity:.72;
}
.header-cta::after,
.floating-cta a::after{
  content:"";
  display:inline-block;
  width:0;
  height:0;
  border-top:4px solid transparent;
  border-bottom:4px solid transparent;
  border-left:6px solid currentColor;
  margin-left:8px;
}

/* Gold corner triangles: visual hierarchy without adding noise */
.summary-grid article,
.checkpoint-grid article,
.voice-cards article,
.area-detail-grid article,
.price-cards article,
.flow-list li,
.double-show-cards article{
  isolation:isolate;
}
.summary-grid article::after,
.checkpoint-grid article::after,
.voice-cards article::after,
.area-detail-grid article::after,
.price-cards article::after,
.flow-list li::after,
.double-show-cards article::after{
  content:"";
  position:absolute;
  right:0;
  bottom:0;
  width:54px;
  height:54px;
  background:linear-gradient(135deg,rgba(217,183,111,0),rgba(217,183,111,.28));
  clip-path:polygon(100% 0,0 100%,100% 100%);
  z-index:-1;
}

/* Section heading triangle accent: direction + motion */
.section-title h2,
.two-col h2,
.area-grid h2,
.final-inner h2,
.contact-card h2{
  position:relative;
}
.section-title h2::before,
.two-col h2::before,
.area-grid h2::before,
.final-inner h2::before,
.contact-card h2::before{
  content:"";
  display:inline-block;
  width:0;
  height:0;
  border-top:9px solid transparent;
  border-bottom:9px solid transparent;
  border-left:13px solid var(--gold);
  margin-right:12px;
  transform:translateY(2px);
  filter:drop-shadow(0 4px 8px rgba(217,183,111,.25));
}
.final-inner h2::before,
.section-dark h2::before{
  border-left-color:var(--gold2);
}

/* Prevent double/overly large gaps where sections follow image band or toc */
.toc-section + .summary,
.image-band-section + .double-show-section,
.area-detail-section + #price{
  margin-top:0;
}


/* v9.3 menu compact + contact form update */
.header-inner{
  height:60px;
}
.global-nav{
  gap:16px;
  font-size:12px;
}
.header-cta{
  padding:8px 14px;
  font-size:12px;
}
.brand-mark{
  width:32px;
  height:32px;
  border-radius:9px;
  font-size:13px;
}
.brand-text strong{
  font-size:12px;
}
.brand-text small{
  font-size:10px;
}
.header-top{
  min-height:26px;
  font-size:11px;
}
.contact-form textarea{
  width:100%;
  min-height:160px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.1);
  color:#fff;
  border-radius:12px;
  padding:12px 14px;
  font:inherit;
  font-size:15px;
  line-height:1.7;
  resize:vertical;
}
.contact-form textarea::placeholder{
  color:rgba(255,255,255,.46);
}
.full-field{
  grid-column:1/-1;
}
.field-help{
  display:inline-block;
  margin-left:8px;
  color:var(--gold2);
  font-size:12px;
  font-weight:800;
}
@media (max-width:900px){
  .header-inner{
    height:58px;
  }
  .header-cta{
    padding:8px 12px;
    font-size:12px;
  }
}


.header-phone-sub{
  color:rgba(255,255,255,.78);
  font-weight:800;
}
.contact-phone-box{
  grid-column:1/-1;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(217,183,111,.24);
  border-radius:18px;
  padding:18px 20px;
  margin-bottom:18px;
}
.contact-phone-box p{
  margin:0 0 6px;
  color:rgba(255,255,255,.9);
}
.contact-phone-box p:last-child{
  margin-bottom:0;
}
.contact-phone-box strong{
  color:var(--gold2);
}
.contact-phone-note{
  font-size:13px;
  color:rgba(255,255,255,.7)!important;
}
@media (max-width:900px){
  .header-phone-sub{
    display:none;
  }
}


.line-contact-box{
  grid-column:1/-1;
  background:rgba(6,199,85,.10);
  border:1px solid rgba(6,199,85,.36);
  border-radius:18px;
  padding:18px 20px;
  margin-bottom:18px;
}
.line-contact-box p{
  margin:0 0 8px;
  color:rgba(255,255,255,.9);
}
.line-contact-box strong{
  color:#9cffbd;
}
.line-add-button{
  display:inline-flex;
  align-items:center;
  margin-top:4px;
}
.line-add-button img{
  display:block;
  width:auto;
  height:36px;
}


.footer-trust-links{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  padding:18px 0 4px;
  border-top:1px solid rgba(255,255,255,.12);
}
.footer-trust-links a{
  display:inline-flex;
  align-items:center;
  min-height:36px;
  padding:8px 13px;
  border:1px solid rgba(217,183,111,.24);
  border-radius:999px;
  color:rgba(255,255,255,.82);
  font-size:13px;
  background:rgba(255,255,255,.04);
}
.footer-trust-links a::after{
  content:"";
  width:0;
  height:0;
  border-top:4px solid transparent;
  border-bottom:4px solid transparent;
  border-left:6px solid currentColor;
  margin-left:8px;
  opacity:.66;
}
.trust-link-section{
  padding:58px 0;
  background:#f6f3ed;
}
.trust-link-card{
  display:grid;
  grid-template-columns:1.2fr .8fr;
  gap:28px;
  align-items:center;
  background:#fff;
  border:1px solid rgba(217,183,111,.24);
  border-radius:28px;
  padding:34px;
  box-shadow:0 18px 48px rgba(8,24,48,.10);
}
.trust-link-card h2{
  font-size:clamp(24px,3vw,36px);
  line-height:1.3;
  margin:0 0 12px;
}
.trust-link-card p:not(.eyebrow){
  margin:0;
  color:var(--muted);
}
.trust-link-buttons{
  display:grid;
  gap:12px;
}
.trust-link-buttons a{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  padding:16px 18px;
  border-radius:16px;
  background:linear-gradient(135deg,#061429,#10264b);
  color:#fff;
  font-weight:900;
}
.trust-link-buttons a::after{
  content:"";
  width:0;
  height:0;
  border-top:6px solid transparent;
  border-bottom:6px solid transparent;
  border-left:8px solid var(--gold2);
}
@media (max-width:900px){
  .trust-link-card{
    grid-template-columns:1fr;
    padding:24px;
  }
}


/* v10.2 footer-only legal links */
.footer-trust-links{
  margin-top:6px;
  padding:14px 0 0;
  border-top:1px solid rgba(255,255,255,.10);
  gap:14px;
}
.footer-trust-links a{
  min-height:auto;
  padding:0;
  border:none;
  border-radius:0;
  background:transparent;
  color:rgba(255,255,255,.58);
  font-size:12px;
  font-weight:500;
  text-decoration:underline;
  text-underline-offset:3px;
  text-decoration-color:rgba(255,255,255,.22);
}
.footer-trust-links a::after{
  display:none;
}
.footer-trust-links a:hover{
  color:var(--gold2);
}


/* v10.3 contact area balance + LINE color harmony */
.contact-card{
  grid-template-columns:1fr;
  max-width:1040px;
  padding:42px 48px;
}
.contact-card > div:first-child{
  max-width:820px;
  margin-inline:auto;
  text-align:center;
}
.contact-form{
  max-width:860px;
  width:100%;
  margin-inline:auto;
  grid-template-columns:1fr 1fr;
  gap:18px 22px;
}
.contact-phone-box,
.line-contact-box{
  max-width:860px;
  width:100%;
  margin-left:auto;
  margin-right:auto;
}
.line-contact-box{
  background:linear-gradient(135deg,rgba(255,255,255,.08),rgba(217,183,111,.08));
  border:1px solid rgba(217,183,111,.30);
  box-shadow:0 16px 38px rgba(0,0,0,.12);
}
.line-contact-box strong{
  color:var(--gold2);
}
.line-contact-box p{
  color:rgba(255,255,255,.86);
}
.line-add-button{
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  border-radius:12px;
  padding:8px 10px;
}
.contact-form label{
  text-align:left;
}
.contact-form input,
.contact-form textarea{
  width:100%;
}
.contact-form .btn{
  width:min(520px,100%);
  margin-inline:auto;
}
@media (max-width:900px){
  .contact-card{
    padding:28px 22px;
  }
  .contact-card > div:first-child{
    text-align:left;
  }
  .contact-form{
    grid-template-columns:1fr;
  }
  .contact-form .btn{
    width:100%;
  }
}


.optional-label{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  margin-left:8px;
  padding:2px 8px;
  border:1px solid rgba(217,183,111,.38);
  border-radius:999px;
  color:var(--gold2);
  font-size:11px;
  font-weight:900;
  letter-spacing:.08em;
}


/* v10.6 header nav readability + fallback phone size */
.global-nav{
  font-size:14px;
  gap:18px;
}
.global-nav a{
  font-weight:800;
  letter-spacing:.04em;
}
.header-phone{
  font-size:14px;
  font-weight:900;
}
.header-phone-sub{
  font-size:7px;
  font-weight:700;
  opacity:.82;
  margin-left:-6px;
  transform:translateY(1px);
}
.header-top{
  gap:12px;
}
@media (max-width:900px){
  .global-nav{
    display:none;
  }
  .header-phone-sub{
    display:none;
  }
}


/* v10.7 final polish */
.header-phone{
  font-size:14px;
}
.header-phone-sub{
  font-size:8px;
  line-height:1;
  opacity:.78;
}
.hero h1{
  word-break:keep-all;
  overflow-wrap:normal;
}
.hero h1 span{
  white-space:nowrap;
}
@media (max-width:560px){
  .hero h1{
    word-break:normal;
    overflow-wrap:anywhere;
  }
  .hero h1 span{
    white-space:normal;
  }
}


/* v10.9 optional label tone-down */
.optional-label{
  display:inline;
  margin-left:6px;
  padding:0;
  border:none;
  border-radius:0;
  background:transparent;
  color:rgba(255,255,255,.72);
  font-size:12px;
  font-weight:500;
  letter-spacing:0;
}


/* v11.0 phone hierarchy */
.header-phone{
  font-size:13px;
  font-weight:700;
  color:rgba(255,255,255,.92);
}
.header-phone .main-phone-number{
  display:inline-block;
  margin-left:4px;
  font-size:18px;
  line-height:1;
  font-weight:900;
  letter-spacing:.02em;
  color:var(--gold2);
}
.header-phone-sub{
  font-size:8px;
  font-weight:500;
  color:rgba(255,255,255,.72);
  white-space:nowrap;
}
.header-phone-sub .sub-phone-number{
  font-size:9px;
  font-weight:700;
  color:rgba(255,255,255,.82);
}

.footer-contact{
  line-height:1.8;
}
.footer-main-phone{
  display:inline-block;
  font-size:22px;
  line-height:1;
  font-weight:900;
  letter-spacing:.02em;
  color:var(--gold2);
  vertical-align:middle;
}
.footer-subline{
  font-size:12px;
  color:rgba(255,255,255,.72);
  white-space:nowrap;
}
.footer-sub-phone{
  font-size:14px;
  font-weight:700;
  color:rgba(255,255,255,.86);
}

.contact-main-phone{
  display:inline-block;
  font-size:24px;
  line-height:1;
  font-weight:900;
  color:var(--gold2);
  vertical-align:middle;
}
.contact-subline{
  font-size:13px;
  color:rgba(255,255,255,.74);
}
.contact-sub-phone{
  font-size:15px;
  font-weight:700;
  color:rgba(255,255,255,.86);
}

@media (max-width:900px){
  .footer-main-phone{
    font-size:18px;
  }
  .footer-subline{
    font-size:11px;
    white-space:normal;
  }
  .footer-sub-phone{
    font-size:12px;
  }
  .contact-main-phone{
    font-size:20px;
  }
}


/* v11.1 phone label smaller like sample */
.header-phone{
  font-size:11px;
  font-weight:600;
  color:rgba(255,255,255,.90);
}
.header-phone .main-phone-number{
  font-size:18px;
  font-weight:900;
}
.header-phone-sub{
  font-size:8px;
}

.contact-phone-box p:first-child{
  margin-bottom:8px;
}
.contact-phone-box p:first-child strong{
  display:block;
  margin-bottom:4px;
  font-size:12px;
  font-weight:700;
  color:rgba(255,255,255,.92);
  letter-spacing:.02em;
}
.contact-main-phone{
  display:block;
  font-size:30px;
  line-height:1;
  font-weight:900;
  color:var(--gold2);
  letter-spacing:.02em;
}
.contact-subline{
  font-size:12px;
  color:rgba(255,255,255,.72);
}
.contact-sub-phone{
  font-size:14px;
  font-weight:700;
  color:rgba(255,255,255,.84);
}

.footer-contact{
  font-size:12px;
}
.footer-main-phone{
  font-size:20px;
  font-weight:900;
}
.footer-subline{
  font-size:11px;
}
.footer-sub-phone{
  font-size:13px;
  font-weight:700;
}

@media (max-width:900px){
  .contact-phone-box p:first-child strong{
    font-size:11px;
  }
  .contact-main-phone{
    font-size:24px;
  }
}


/* v11.2 brand mark unified with Osaka sample */
.brand{
  gap:14px;
}
.brand-mark{
  display:grid;
  grid-template-columns:repeat(2,6px);
  grid-template-rows:repeat(2,20px);
  gap:6px 8px;
  width:20px;
  min-width:20px;
  height:46px;
  padding:0;
  border:none;
  border-radius:0;
  background:transparent;
}
.brand-mark .mark-bar{
  display:block;
  width:6px;
  height:20px;
  border-radius:999px;
}
.brand-mark .bar-1,
.brand-mark .bar-3,
.brand-mark .bar-4{
  background:#111822;
}
.brand-mark .bar-2{
  background:linear-gradient(180deg,var(--gold),var(--gold2));
}
.brand-text strong{
  font-size:16px;
  letter-spacing:.07em;
}
.brand-text small{
  font-size:11px;
  letter-spacing:.02em;
}
@media (max-width:900px){
  .brand{
    gap:10px;
  }
  .brand-mark{
    grid-template-columns:repeat(2,5px);
    grid-template-rows:repeat(2,16px);
    gap:5px 7px;
    width:17px;
    min-width:17px;
    height:37px;
  }
  .brand-mark .mark-bar{
    width:5px;
    height:16px;
  }
}


/* v11.3 brand mark closer to Osaka sample, gold-only for navy background */
.brand{
  gap:12px;
}

.brand-mark{
  display:grid;
  grid-template-columns:repeat(2,4px);
  grid-template-rows:repeat(2,18px);
  gap:6px 8px;
  width:16px;
  min-width:16px;
  height:42px;
  padding:0;
  border:none;
  border-radius:0;
  background:transparent;
  align-content:center;
  justify-content:center;
}

.brand-mark .mark-bar{
  display:block;
  width:4px;
  height:18px;
  border-radius:999px;
  background:linear-gradient(180deg,var(--gold),var(--gold2));
  box-shadow:0 0 0 1px rgba(217,183,111,.04);
}

.brand-text{
  display:grid;
  line-height:1.12;
}

.brand-text strong{
  font-size:15px;
  letter-spacing:.06em;
}

.brand-text small{
  font-size:10px;
  color:rgba(255,255,255,.82);
  font-weight:500;
  letter-spacing:.01em;
}

@media (max-width:900px){
  .brand{
    gap:10px;
  }
  .brand-mark{
    grid-template-columns:repeat(2,3px);
    grid-template-rows:repeat(2,14px);
    gap:5px 7px;
    width:13px;
    min-width:13px;
    height:33px;
  }
  .brand-mark .mark-bar{
    width:3px;
    height:14px;
  }
  .brand-text strong{
    font-size:13px;
  }
  .brand-text small{
    font-size:9px;
  }
}


/* =====================================================
   v11.7 contact form: validation + spam protection UI
   ===================================================== */

/* ハニーポット：人間からは完全に見えなくする */
.hp-field{
  position:absolute !important;
  left:-9999px !important;
  top:auto !important;
  width:1px !important;
  height:1px !important;
  overflow:hidden !important;
  opacity:0 !important;
  pointer-events:none !important;
}

/* 必須バッジ */
.required-mark{
  display:inline-block;
  margin-left:8px;
  padding:2px 8px;
  background:#d9b76f;
  color:#061429;
  border-radius:6px;
  font-size:10px;
  font-weight:900;
  letter-spacing:.08em;
  vertical-align:1px;
}

/* エラーサマリー（フォーム最上部） */
.form-error-summary{
  grid-column:1/-1;
  background:rgba(239,68,68,.16);
  border:1px solid rgba(239,68,68,.55);
  color:#ffd7d7;
  padding:14px 16px;
  border-radius:12px;
  font-size:14px;
  line-height:1.7;
  font-weight:700;
}

/* 個別フィールドのエラー表示 */
.contact-form label.has-error input,
.contact-form label.has-error textarea{
  border-color:#ef4444 !important;
  background:rgba(239,68,68,.08) !important;
}
.contact-form .field-error{
  display:block;
  margin-top:4px;
  font-size:12px;
  font-weight:700;
  color:#ffb4b4;
  letter-spacing:.02em;
}

/* フォーカス時のスタイル（アクセシビリティ向上） */
.contact-form input:focus,
.contact-form textarea:focus{
  outline:none;
  border-color:#d9b76f !important;
  background:rgba(255,255,255,.16) !important;
  box-shadow:0 0 0 3px rgba(217,183,111,.25);
}

/* 送信中ボタンの状態 */
.contact-form .btn[disabled],
.contact-form .btn.is-sending{
  opacity:.65;
  cursor:wait;
  pointer-events:none;
}
.contact-form .btn.is-sending::before{
  content:"";
  display:inline-block;
  width:14px;
  height:14px;
  margin-right:10px;
  border:2px solid rgba(6,20,41,.3);
  border-top-color:#061429;
  border-radius:50%;
  animation:spin 0.8s linear infinite;
  vertical-align:-2px;
}
@keyframes spin{
  to{transform:rotate(360deg)}
}


/* =====================================================
   v11.8 contact form: type=date 用の見た目調整
   ===================================================== */
.contact-form input[type="date"]{
  min-height:48px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.1);
  color:#fff;
  border-radius:12px;
  padding:0 14px;
  font-size:15px;
  font-family:inherit;
  font-weight:600;
  letter-spacing:.02em;
  -webkit-appearance:none;
  appearance:none;
  cursor:pointer;
}
.contact-form input[type="date"]::-webkit-calendar-picker-indicator{
  /* 暗い背景でも見えるよう、白いカレンダーアイコンに */
  filter:invert(85%) sepia(35%) saturate(380%) hue-rotate(2deg) brightness(102%);
  cursor:pointer;
  opacity:.85;
}
.contact-form input[type="date"]::-webkit-calendar-picker-indicator:hover{
  opacity:1;
}
.contact-form input[type="date"]:invalid{
  color:rgba(255,255,255,.5);
}
.contact-form input[type="date"]::-webkit-datetime-edit{
  color:rgba(255,255,255,.92);
}
.contact-form input[type="date"]::-webkit-datetime-edit-text,
.contact-form input[type="date"]::-webkit-datetime-edit-month-field,
.contact-form input[type="date"]::-webkit-datetime-edit-day-field,
.contact-form input[type="date"]::-webkit-datetime-edit-year-field{
  color:rgba(255,255,255,.92);
}


/* =====================================================
   v11.9 contact form: select の見た目調整
   ===================================================== */
.contact-form select{
  min-height:48px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.1);
  color:#fff;
  border-radius:12px;
  padding:0 38px 0 14px;
  font-size:15px;
  font-family:inherit;
  font-weight:600;
  letter-spacing:.02em;
  -webkit-appearance:none;
  -moz-appearance:none;
  appearance:none;
  cursor:pointer;
  /* 右端のドロップダウン矢印（SVG埋め込み） */
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path fill='%23ffd9a8' d='M0 0l6 8 6-8z'/></svg>");
  background-repeat:no-repeat;
  background-position:right 14px center;
  background-size:11px 7px;
}
.contact-form select option{
  background:#0b1f3d;
  color:#fff;
  font-weight:600;
}
.contact-form label.has-error select{
  border-color:#ef4444 !important;
  background-color:rgba(239,68,68,.08) !important;
}
.contact-form select:focus{
  outline:none;
  border-color:#d9b76f !important;
  background-color:rgba(255,255,255,.16) !important;
  box-shadow:0 0 0 3px rgba(217,183,111,.25);
}


/* =====================================================
   v11.11 フォームレイアウトの隙間を整理
   ===================================================== */
/* textareaは6行分の高さを確保（他フィールドと同じ余白・サイズ感） */
.contact-form textarea[name="message"]{
  min-height:160px;
  resize:vertical;
}
/* full-fieldは2列スパン */
.contact-form label.full-field{
  grid-column:1 / -1;
}
/* select / date input が他と同じ高さ・余白に揃うように統一 */
.contact-form input,
.contact-form select,
.contact-form input[type="date"]{
  min-height:48px;
}
/* ラベル内の余白統一 */
.contact-form label{
  gap:6px;
}
/* required-mark / optional-label / field-help のフォーム内位置を整える */
.contact-form .required-mark,
.contact-form .optional-label{
  vertical-align:1px;
}
.contact-form .field-help{
  display:block;
  margin:0 0 -2px 0;
  font-size:11px;
  letter-spacing:0;
}


/* =====================================================
   v11.12 電話番号BOXとLINEのBOXの間隔を詰める
   ===================================================== */
.contact-phone-box{
  margin-bottom:0 !important;
}
.line-contact-box{
  margin-top:14px !important;
  margin-bottom:0 !important;
}
/* contact-card内の各子要素の縦方向ギャップを抑える */
.contact-card{
  row-gap:18px !important;
}


/* =====================================================
   v11.13 電話番号BOXとLINE BOXの間隔を強力に詰める
   （前のv11.12 row-gap:18px が効いていなかったので強化）
   ===================================================== */
.contact-section .contact-card{
  gap:14px !important;
  row-gap:14px !important;
  column-gap:14px !important;
}
.contact-section .contact-phone-box,
.contact-section .line-contact-box{
  margin:0 !important;
}
/* 電話BOX内の最後のpの下マージンを詰める */
.contact-phone-box p:last-child,
.contact-phone-box .contact-phone-note{
  margin-bottom:0 !important;
}


/* =====================================================
   v11.14 中央揃えを維持しつつ余白だけ縮める修正
   （v11.13 の margin:0 !important が左寄せを起こした不具合の修正）
   ===================================================== */
.contact-section .contact-phone-box,
.contact-section .line-contact-box{
  margin-top:0 !important;
  margin-bottom:0 !important;
  margin-left:auto !important;
  margin-right:auto !important;
}
