:root{
  --green:#06c755;
  --green-dark:#04963f;
  --green-soft:#eafaf0;
  --black:#101820;
  --text:#1f2933;
  --muted:#65758b;
  --line:#dfe8ef;
  --bg:#f5f8fb;
  --white:#fff;
  --shadow:0 24px 70px rgba(20,39,57,.14);
  --radius:26px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:'Noto Sans JP',system-ui,-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;color:var(--text);background:var(--bg);line-height:1.75;letter-spacing:.02em;overflow-x:hidden}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}
.container{width:min(1120px,calc(100% - 40px));margin:0 auto}.narrow{width:min(900px,calc(100% - 40px))}.center{text-align:center}.sp{display:none}
.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.92);backdrop-filter:blur(14px);border-bottom:1px solid rgba(223,232,239,.8)}
.header-inner{height:76px;display:flex;align-items:center;justify-content:space-between;gap:20px}.brand{display:flex;align-items:center;gap:11px;font-weight:900;font-size:18px}.brand-logo{width:40px;height:40px;border-radius:12px;object-fit:cover;box-shadow:0 8px 22px rgba(6,199,85,.2)}.nav{display:flex;gap:28px;font-size:14px;font-weight:800;color:#405168}.nav a:hover{color:var(--green-dark)}.header-cta{display:inline-flex;align-items:center;justify-content:center;padding:12px 20px;border-radius:999px;background:linear-gradient(135deg,var(--green),#2eea84);color:#fff;font-weight:900;font-size:14px;box-shadow:0 10px 26px rgba(6,199,85,.24)}.menu-button{display:none;border:0;background:var(--black);color:#fff;border-radius:999px;padding:10px 14px;font-weight:900}
.btn{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;font-weight:900;line-height:1.25;transition:.18s ease}.btn:hover{transform:translateY(-2px)}.btn-primary{background:linear-gradient(135deg,var(--green),#2eea84);color:#fff;box-shadow:0 16px 38px rgba(6,199,85,.32)}.btn-sub{background:#fff;color:var(--black);border:1px solid rgba(16,24,32,.12);box-shadow:0 14px 36px rgba(20,39,57,.09)}.btn-lg{padding:18px 28px;font-size:16px}.btn-xl{padding:22px 34px;font-size:18px}
.hero{position:relative;overflow:hidden;padding:78px 0 88px;background:linear-gradient(180deg,#ffffff 0%,#edf8f1 100%)}.hero:before{content:"";position:absolute;inset:auto -10% -40% -10%;height:58%;background:linear-gradient(135deg,rgba(6,199,85,.14),rgba(255,255,255,0));border-radius:50% 50% 0 0;pointer-events:none}.hero-grid{position:relative;z-index:1;display:block}.hero-copy{max-width:none}.hero-label,.label{display:inline-flex;align-items:center;gap:10px;margin:0;color:var(--green-dark);font-size:13px;font-weight:900;letter-spacing:.12em;text-transform:uppercase}.hero-label:before,.label:before{content:"";width:32px;height:3px;border-radius:99px;background:var(--green)}.hero h1{margin:18px 0 22px;font-size:clamp(44px,5.7vw,76px);line-height:1.08;letter-spacing:-.055em;font-weight:900;color:#0b1720}.hero h1 span{color:var(--green);text-shadow:0 12px 34px rgba(6,199,85,.18)}.hero-lead{margin:0 0 28px;font-size:18px;color:#4f5f72;max-width:860px}.hero-actions{display:flex;gap:14px;flex-wrap:wrap}.hero-note{margin:18px 0 0;color:#748297;font-size:13px}
.hero-mini-points{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}.hero-mini-points span{display:inline-flex;align-items:center;padding:9px 13px;border-radius:999px;background:#fff;border:1px solid #d6eee0;color:#1f6a3d;font-size:13px;font-weight:900;box-shadow:0 8px 20px rgba(20,39,57,.06)}
.hero-screen{position:relative}.browser-frame{width:100%;border-radius:26px;overflow:hidden;background:#fff;border:1px solid rgba(150,170,188,.35);box-shadow:var(--shadow)}.browser-bar{height:48px;display:flex;align-items:center;gap:8px;padding:0 16px;border-bottom:1px solid var(--line);background:#f7fafc}.browser-bar span{width:11px;height:11px;border-radius:999px;background:#ccd7e1}.browser-bar span:nth-child(1){background:#ff7b7b}.browser-bar span:nth-child(2){background:#ffc857}.browser-bar span:nth-child(3){background:#06c755}.browser-bar p{margin:0 0 0 8px;color:#7a8797;font-size:12px;font-weight:800}.dashboard-mock{display:grid;grid-template-columns:150px 1fr;min-height:410px}.dashboard-mock aside{padding:20px 16px;background:#101820;color:#fff}.mock-logo{display:flex;align-items:center;gap:9px;margin-bottom:26px}.mock-logo img{width:30px;height:30px;border-radius:9px}.mock-logo b{font-size:13px}.dashboard-mock aside i{display:block;height:14px;border-radius:99px;background:rgba(255,255,255,.16);margin:16px 0}.dashboard-mock aside i:nth-child(3){width:76%}.dashboard-mock aside i:nth-child(4){width:88%}.dashboard-mock aside i:nth-child(5){width:64%}.dashboard-mock section{padding:24px;background:#f5f8fb}.mock-top{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:18px}.mock-top small{display:block;color:#7a8797;font-weight:800}.mock-top strong{font-size:22px;color:#101820}.mock-top em{font-style:normal;background:#e3f9ed;color:var(--green-dark);font-size:12px;font-weight:900;padding:7px 12px;border-radius:999px}.mock-alert{padding:20px;border-radius:20px;background:linear-gradient(135deg,#08c85a,#0fa56a);color:#fff;margin-bottom:18px;box-shadow:0 14px 34px rgba(6,199,85,.24)}.mock-alert b{display:block;font-size:18px;margin-bottom:4px}.mock-alert span{font-size:13px;opacity:.92}.mock-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:18px}.mock-cards div{background:#fff;border:1px solid var(--line);border-radius:16px;padding:15px}.mock-cards b{display:block;color:var(--green-dark);font-size:13px}.mock-cards span{font-weight:900;font-size:12px}.mock-chart{height:100px;border-radius:18px;background:#fff;border:1px solid var(--line);display:flex;align-items:end;gap:12px;padding:18px}.mock-chart span{flex:1;border-radius:8px 8px 0 0;background:linear-gradient(180deg,#06c755,#bcf4d4)}.mock-chart span:nth-child(1){height:42%}.mock-chart span:nth-child(2){height:66%}.mock-chart span:nth-child(3){height:50%}.mock-chart span:nth-child(4){height:78%}.mock-chart span:nth-child(5){height:61%}
.section{padding:94px 0}.section-title{max-width:790px}.section-title.center{margin:0 auto 44px}.section-title h2{margin:12px 0 14px;font-size:clamp(32px,4vw,52px);line-height:1.24;letter-spacing:-.04em}.section-title p:not(.label){margin:0;color:var(--muted);font-size:17px}.problem-section{background:#fff}.problem-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}.problem-grid article{padding:34px;border-radius:var(--radius);background:#fff;border:1px solid var(--line);box-shadow:0 16px 42px rgba(20,39,57,.06)}.problem-grid span{display:grid;place-items:center;width:48px;height:48px;border-radius:15px;background:var(--green-soft);color:var(--green-dark);font-weight:900}.problem-grid h3{font-size:21px;line-height:1.45;margin:20px 0 10px}.problem-grid p{margin:0;color:var(--muted)}
.solution-section{background:linear-gradient(180deg,#f5f8fb,#eafaf0)}.solution-card{display:grid;grid-template-columns:1fr .82fr;gap:42px;align-items:center;background:#fff;border:1px solid var(--line);border-radius:34px;padding:54px;box-shadow:var(--shadow)}.solution-copy h2{margin:12px 0 20px;font-size:clamp(36px,5vw,60px);line-height:1.15;letter-spacing:-.045em}.solution-copy h2 span{color:var(--green)}.solution-copy p{color:var(--muted);font-size:17px}.callout{margin:22px 0;padding:18px 20px;border-radius:18px;background:var(--green-soft);border:1px solid #c4f1d6;color:#075d2a;font-weight:900}.solution-list{display:grid;gap:14px}.solution-list div{display:flex;align-items:center;gap:16px;padding:20px;border-radius:18px;background:#f7fafc;border:1px solid var(--line);font-weight:900}.solution-list b{display:grid;place-items:center;width:42px;height:42px;border-radius:13px;background:var(--green);color:#fff}.solution-list span{font-size:16px}
.features-section{background:#fff}.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}.feature-card{position:relative;padding:32px;border-radius:var(--radius);background:#fff;border:1px solid var(--line);box-shadow:0 16px 44px rgba(19,32,51,.06);overflow:hidden}.feature-card:after{content:"";position:absolute;right:-40px;top:-40px;width:120px;height:120px;border-radius:999px;background:rgba(21,200,139,.08)}.feature-card .icon{width:48px;height:48px;border-radius:16px;display:grid;place-items:center;background:linear-gradient(135deg,var(--green),#1e9df2);color:#fff;font-weight:900}.feature-card h3{margin:18px 0 8px;font-size:21px}.feature-card p{margin:0;color:var(--muted)}
.reason-section{background:#f5f8fb}.reason-grid{display:grid;grid-template-columns:1fr .9fr;gap:52px;align-items:center}.reason-grid h2{margin:12px 0 16px;font-size:clamp(32px,4vw,52px);line-height:1.24;letter-spacing:-.04em}.reason-grid p{color:var(--muted);font-size:17px}.check-panel{display:grid;gap:13px}.check-panel p{margin:0;padding:20px 22px;border-radius:18px;background:#fff;border:1px solid var(--line);box-shadow:0 12px 30px rgba(20,39,57,.06);font-weight:900;color:var(--text)}.check-panel span{color:var(--green);font-weight:900;margin-right:8px}.target-section{background:#101820;color:#fff}.light h2,.light p{color:#fff}.target-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.target-grid div{padding:20px;border-radius:18px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);font-weight:900}.target-grid div:before{content:"✓";color:#70f2a7;margin-right:8px}.seminar-section{background:#fff}.seminar-card{display:grid;grid-template-columns:1fr .45fr;gap:32px;align-items:center;padding:54px;border-radius:34px;background:linear-gradient(135deg,#effcf4,#f4f8fb);border:1px solid #d6eee0;box-shadow:var(--shadow)}.seminar-card h2{margin:12px 0 16px;font-size:clamp(32px,4vw,52px);line-height:1.24;letter-spacing:-.04em}.seminar-card p{color:var(--muted);font-size:17px}.seminar-tags{display:flex;gap:10px;flex-wrap:wrap;margin-top:20px}.seminar-tags span{padding:10px 14px;border-radius:999px;background:#fff;border:1px solid #d6eee0;color:#1f6a3d;font-weight:900}.seminar-action{background:#fff;border:1px solid var(--line);border-radius:26px;padding:30px;text-align:center;box-shadow:0 16px 42px rgba(20,39,57,.08)}.seminar-action p{margin:14px 0 0;font-size:14px}.faq-section{background:#f5f8fb}.faq-list{display:grid;gap:14px}.faq-list details{background:#fff;border:1px solid var(--line);border-radius:18px;padding:0 24px;box-shadow:0 12px 28px rgba(20,39,57,.05)}.faq-list summary{cursor:pointer;font-weight:900;list-style:none;padding:22px 0;display:flex;justify-content:space-between;gap:18px}.faq-list summary:after{content:"＋";color:var(--green);font-weight:900}.faq-list details[open] summary:after{content:"−"}.faq-list p{margin:0 0 22px;color:var(--muted)}.final-cta{padding:98px 0;background:linear-gradient(135deg,#101820,#0d3b2a);color:#fff}.final-cta .label{color:#72f4a8}.final-cta h2{margin:12px 0 18px;font-size:clamp(34px,4.5vw,56px);line-height:1.26;letter-spacing:-.04em}.final-cta p:not(.label){max-width:760px;margin:0 auto 30px;color:#dbe6ef;font-size:17px}.site-footer{background:#0c131a;color:#dbe6ef;padding:28px 0}.footer-inner{display:flex;align-items:center;justify-content:space-between;gap:18px}.footer-inner p{margin:0;color:#9dafbf;font-size:13px}.footer-simple{justify-content:center;text-align:center}
@media(max-width:920px){.hero-grid,.solution-card,.reason-grid,.seminar-card{grid-template-columns:1fr}.problem-grid,.feature-grid,.target-grid{grid-template-columns:1fr 1fr}.solution-card,.seminar-card{padding:34px}.hero{padding-top:54px}.dashboard-mock{grid-template-columns:128px 1fr}.hero-copy{max-width:none}}
@media(max-width:620px){.container,.narrow{width:min(100% - 28px,1120px)}.sp{display:block}.section{padding:70px 0}.hero h1{font-size:42px}.hero-lead{font-size:16px}.hero-actions{display:grid}.btn-lg,.btn-xl{width:100%;padding:18px 22px}.browser-frame{border-radius:20px}.dashboard-mock{grid-template-columns:1fr;min-height:auto}.dashboard-mock aside{display:none}.mock-top{align-items:flex-start}.mock-cards,.problem-grid,.feature-grid,.target-grid{grid-template-columns:1fr}.solution-card,.seminar-card{padding:24px;border-radius:24px}.section-title h2,.reason-grid h2,.seminar-card h2,.final-cta h2{font-size:32px}.footer-inner{display:grid;justify-items:center;text-align:center}.brand-logo{width:38px;height:38px}.header-cta{padding:10px 14px;font-size:13px}.brand span{font-size:16px}}

/* v10: hero button is one CTA only */
.hero-actions.single-action {
  justify-content: flex-start;
}
@media (max-width: 767px) {
  .hero-actions.single-action {
    justify-content: center;
  }
}


/* v14: center hero text */
.hero-copy{display:flex;flex-direction:column;align-items:center;text-align:center;}
.hero-lead{margin-left:auto;margin-right:auto;}
.hero-actions.single-action{justify-content:center;}
.hero-note{text-align:center;}


/* v15: make reason CTA visually a button block */
.reason-cta {
  margin-top: 28px;
}
.reason-cta .btn {
  display: inline-flex;
  min-width: 300px;
  justify-content: center;
}
@media (max-width: 620px) {
  .reason-cta .btn {
    width: 100%;
    min-width: 0;
  }
}


/* v16: solution CTA button block */
.solution-cta{margin-top:22px;}
.solution-cta .btn{display:inline-flex;min-width:260px;justify-content:center;}

/* solution mock visual */
.solution-mock-visual{margin:24px 0 28px;display:flex;justify-content:center;}
.solution-mock-visual img{display:block;width:100%;max-width:1120px;height:auto;border-radius:20px;box-shadow:0 24px 60px rgba(19,32,51,.12);}
@media (max-width: 768px){.solution-mock-visual{margin:20px 0 24px}.solution-mock-visual img{border-radius:16px;box-shadow:0 18px 40px rgba(19,32,51,.10);}}

@media (max-width:620px){.solution-cta .btn{width:100%;min-width:0;}}


/* v17: remove decorative labels and adjust spacing */
.hero h1 {
  margin-top: 0;
}
.section-title h2,
.solution-copy h2,
.reason-grid h2,
.seminar-card h2,
.final-cta h2 {
  margin-top: 0;
}
.final-cta .center > h2:first-child {
  margin-top: 0;
}


/* reason block single column fix */
.reason-grid.reason-grid-single {
  grid-template-columns: 1fr;
  max-width: 920px;
}
.reason-grid.reason-grid-single p {
  max-width: 820px;
}
.reason-grid.reason-grid-single .reason-cta {
  margin-top: 28px;
}
.reason-grid.reason-grid-single .reason-cta .btn {
  display: inline-flex;
  justify-content: center;
}
@media (max-width: 620px) {
  .reason-grid.reason-grid-single .reason-cta .btn {
    width: 100%;
  }
}


/* recommend section background fix */
.target-section {
  background: #f5f8fb !important;
  color: var(--text) !important;
}
.target-section .section-title.light h2,
.target-section .section-title.light p {
  color: var(--text) !important;
}
.target-section .target-grid div {
  background: #fff !important;
  border: 1px solid var(--line) !important;
  color: var(--text) !important;
  box-shadow: 0 12px 30px rgba(20,39,57,.06);
}
.target-section .target-grid div:before {
  color: var(--green) !important;
}


/* guideline warning section - checked against adjacent blocks */
.guideline-section{
  background: #fff7ec;
  padding-top: 84px;
  padding-bottom: 84px;
  border-top: 1px solid #f1dcc0;
  border-bottom: 1px solid #f1dcc0;
}
.guideline-card{
  background: #ffffff;
  border: 1px solid #f2dcc4;
  border-radius: 34px;
  padding: 52px 52px 48px;
  box-shadow: 0 18px 48px rgba(119,75,23,.08);
}
.guideline-title{
  max-width: 900px;
  margin: 0 auto 30px;
}
.guideline-title h2{
  margin: 0;
  font-size: clamp(34px,4.4vw,56px);
  line-height: 1.2;
  letter-spacing: -.04em;
}
.guideline-copy{
  max-width: 920px;
  margin: 0 auto;
}
.guideline-copy p{
  margin: 0 0 16px;
  color: var(--muted);
  font-size: 17px;
  line-height: 1.9;
  text-align: center;
}
.guideline-copy p:first-child{
  padding: 16px 20px;
  border-radius: 18px;
  background: #fffaf3;
  border: 1px solid #f0dfcd;
  color: #7a4b12;
  font-weight: 900;
}
.guideline-copy strong{
  color: #7a4b12;
}
.guideline-image-wrap{
  max-width: 980px;
  margin: 34px auto 34px;
  padding: 14px;
  border-radius: 26px;
  background: #fff;
  border: 1px solid #eadfce;
  box-shadow: 0 16px 36px rgba(20,39,57,.06);
}
.guideline-image{
  display: block;
  width: 100%;
  height: auto;
  border-radius: 18px;
}
.guideline-highlight{
  max-width: 920px;
  margin: 18px auto 0;
  padding: 20px 24px;
  border-radius: 20px;
  background: linear-gradient(135deg,#effcf4,#f7fbff);
  border: 1px solid #d6eee0;
  color: var(--green-dark);
  font-size: 20px;
  font-weight: 900;
  line-height: 1.7;
  text-align: center;
}
@media (max-width: 920px){
  .guideline-card{
    padding: 38px 30px 34px;
  }
}
@media (max-width: 620px){
  .guideline-section{
    padding-top: 68px;
    padding-bottom: 68px;
  }
  .guideline-card{
    padding: 26px 20px 24px;
    border-radius: 24px;
  }
  .guideline-title h2{
    font-size: 32px;
  }
  .guideline-copy p{
    font-size: 16px;
    text-align: left;
  }
  .guideline-highlight{
    font-size: 18px;
    padding: 18px 16px;
  }
}


/* reason section center alignment fix */
.reason-grid.reason-grid-centered {
  grid-template-columns: 1fr;
  text-align: center;
  justify-items: center;
}
.reason-grid.reason-grid-centered > div {
  width: 100%;
}
.reason-grid.reason-grid-centered h2,
.reason-grid.reason-grid-centered p {
  margin-left: auto;
  margin-right: auto;
}
.reason-grid.reason-grid-centered p {
  max-width: 820px;
}
.reason-grid.reason-grid-centered .reason-cta {
  display: flex;
  justify-content: center;
  margin-top: 28px;
}
@media (max-width: 620px) {
  .reason-grid.reason-grid-centered .reason-cta .btn {
    width: 100%;
  }
}


/* booking modal */
body.booking-open{overflow:hidden}
.booking-modal{position:fixed;inset:0;z-index:9999;display:none}
.booking-modal.is-open{display:block}
.booking-modal__overlay{position:absolute;inset:0;background:rgba(8,18,28,.62);backdrop-filter:blur(5px)}
.booking-modal__panel{position:relative;width:min(92vw,560px);max-height:calc(100vh - 48px);overflow:auto;margin:24px auto;padding:34px;border-radius:28px;background:#fff;box-shadow:0 30px 80px rgba(0,0,0,.28)}
.booking-modal__close{position:absolute;top:14px;right:16px;width:38px;height:38px;border:0;border-radius:999px;background:#f0f4f7;color:#223;font-size:26px;line-height:1;cursor:pointer}
.booking-modal__head{text-align:center;margin-bottom:24px}
.booking-modal__head p{display:inline-flex;margin:0 0 12px;padding:7px 13px;border-radius:999px;background:#e9f9ef;color:var(--green-dark);font-weight:900;font-size:13px}
.booking-modal__head h2{margin:0 0 10px;font-size:clamp(26px,4vw,36px);letter-spacing:-.04em}
.booking-modal__head span{color:var(--muted);font-size:14px}
.booking-form{display:grid;gap:16px}
.booking-form label{display:grid;gap:8px;font-weight:900;color:var(--text)}
.booking-form input,.booking-form select{width:100%;border:1px solid var(--line);border-radius:14px;padding:14px 15px;font:inherit;background:#fff;color:var(--text);outline:none}
.booking-form input:focus,.booking-form select:focus{border-color:var(--green);box-shadow:0 0 0 4px rgba(6,199,85,.12)}
.booking-submit{width:100%;justify-content:center;margin-top:6px}
.booking-note{margin:0;color:var(--muted);font-size:13px;text-align:center}
.booking-message{padding:13px 14px;border-radius:14px;font-weight:900;line-height:1.6}
.booking-message.is-success{background:#e9f9ef;border:1px solid #c8efd6;color:var(--green-dark)}
.booking-message.is-error{background:#fff1f1;border:1px solid #ffd2d2;color:#a72727}
.booking-message.is-info{background:#f5f8fb;border:1px solid var(--line);color:var(--text)}
@media(max-width:620px){.booking-modal__panel{width:min(94vw,560px);padding:26px 20px;border-radius:22px}}


/* booking modal visibility reliability fix */
.booking-modal.is-open {
  display: flex !important;
  align-items: center;
  justify-content: center;
  padding: 24px 0;
}
.booking-modal.is-open .booking-modal__panel {
  margin: 0 auto;
}


/* booking calendar UI fix */
.booking-modal.is-open{
  display:flex!important;
  align-items:center;
  justify-content:center;
  padding:24px 0;
}
.booking-modal.is-open .booking-modal__panel{
  margin:0 auto;
}
.booking-modal__panel{
  width:min(94vw,900px);
}
.booking-form{
  gap:18px;
}
.booking-note{
  display:none!important;
}
.booking-calendar-area{
  margin-top:8px;
  border:1px solid var(--line);
  border-radius:18px;
  overflow:hidden;
  background:#fff;
}
.booking-calendar-head{
  display:grid;
  grid-template-columns:120px 1fr 120px;
  align-items:center;
  gap:12px;
  padding:14px 16px;
  border-bottom:1px solid var(--line);
  background:#fff;
}
.booking-calendar-head strong{
  text-align:center;
  font-size:26px;
  line-height:1.2;
}
.booking-month-btn{
  border:1px solid #7f8b96;
  background:#fff;
  color:#344150;
  border-radius:6px;
  padding:8px 10px;
  font:inherit;
  cursor:pointer;
}
.booking-calendar-week{
  display:grid;
  grid-template-columns:repeat(7,1fr);
  background:#6f7a83;
  color:#fff;
  font-weight:900;
  text-align:center;
}
.booking-calendar-week span{
  padding:7px 4px;
  border-right:1px solid rgba(255,255,255,.35);
}
.booking-calendar-grid{
  display:grid;
  grid-template-columns:repeat(7,1fr);
  background:#d9dee3;
  gap:1px;
}
.booking-calendar-loading{
  grid-column:1/-1;
  padding:28px;
  background:#fff;
  text-align:center;
  font-weight:900;
}
.booking-day{
  min-height:64px;
  border:0;
  background:#fff;
  color:#111;
  cursor:pointer;
  display:grid;
  place-items:center;
  gap:2px;
  padding:7px 2px;
  font:inherit;
}
.booking-day-num{
  font-size:18px;
  font-weight:900;
  line-height:1;
}
.booking-day-mark{
  font-size:20px;
  line-height:1;
}
.booking-day.is-sunday .booking-day-num{
  color:red;
}
.booking-day.is-other{
  background:#f1f1f1;
  color:#111;
}
.booking-day.is-disabled{
  cursor:default;
  background:#f3f3f3;
  color:#999;
}
.booking-day.is-disabled .booking-day-mark{
  display:none;
}
.booking-day.is-selected{
  outline:2px solid #0075ff;
  outline-offset:-2px;
  background:#fffdf5;
}
.booking-time-area{
  margin-top:4px;
}
.booking-time-title{
  margin:0 0 10px;
  font-size:17px;
  font-weight:900;
}
.booking-time-list{
  display:grid;
  gap:8px;
}
.booking-time-btn{
  width:100%;
  padding:14px 18px;
  border:1px solid var(--line);
  border-radius:8px;
  background:#fff;
  color:#344150;
  font:inherit;
  font-size:17px;
  cursor:pointer;
  text-align:center;
}
.booking-time-btn.is-selected{
  border-color:var(--green);
  background:#e9f9ef;
  color:var(--green-dark);
  font-weight:900;
}
.booking-time-empty{
  margin:0;
  padding:14px;
  border:1px solid var(--line);
  border-radius:8px;
  color:var(--muted);
  text-align:center;
}
@media(max-width:720px){
  .booking-calendar-head{
    grid-template-columns:90px 1fr 90px;
    gap:8px;
    padding:12px 10px;
  }
  .booking-calendar-head strong{
    font-size:22px;
  }
  .booking-month-btn{
    padding:7px 5px;
    font-size:13px;
  }
  .booking-day{
    min-height:54px;
  }
  .booking-day-num{
    font-size:16px;
  }
}


/* stable booking modal and calendar */
body.booking-open{overflow:hidden}
.booking-modal{position:fixed;inset:0;z-index:99999;display:none}
.booking-modal.is-open{display:flex!important;align-items:center;justify-content:center;padding:24px 0}
.booking-modal__overlay{position:absolute;inset:0;background:rgba(8,18,28,.62);backdrop-filter:blur(5px)}
.booking-modal__panel{position:relative;width:min(94vw,900px);max-height:calc(100vh - 48px);overflow:auto;margin:0 auto;padding:34px;border-radius:28px;background:#fff;box-shadow:0 30px 80px rgba(0,0,0,.28)}
.booking-modal__close{position:absolute;top:14px;right:16px;width:38px;height:38px;border:0;border-radius:999px;background:#f0f4f7;color:#223;font-size:26px;line-height:1;cursor:pointer}
.booking-modal__head{text-align:center;margin-bottom:24px}
.booking-modal__head p{display:inline-flex;margin:0 0 12px;padding:7px 13px;border-radius:999px;background:#e9f9ef;color:var(--green-dark);font-weight:900;font-size:13px}
.booking-modal__head h2{margin:0 0 10px;font-size:clamp(26px,4vw,44px);letter-spacing:-.04em}
.booking-modal__head span{color:var(--muted);font-size:14px}
.booking-form{display:grid;gap:18px}
.booking-form label{display:grid;gap:8px;font-weight:900;color:var(--text)}
.booking-form input{width:100%;border:1px solid var(--line);border-radius:14px;padding:14px 15px;font:inherit;background:#fff;color:var(--text);outline:none}
.booking-form input:focus{border-color:var(--green);box-shadow:0 0 0 4px rgba(6,199,85,.12)}
.booking-note{display:none!important}
.booking-submit{width:100%;justify-content:center;margin-top:6px}
.booking-message{padding:13px 14px;border-radius:14px;font-weight:900;line-height:1.6}
.booking-message.is-success{background:#e9f9ef;border:1px solid #c8efd6;color:var(--green-dark)}
.booking-message.is-error{background:#fff1f1;border:1px solid #ffd2d2;color:#a72727}
.booking-message.is-info{background:#f5f8fb;border:1px solid var(--line);color:var(--text)}
.booking-calendar-area{margin-top:8px;border:1px solid var(--line);border-radius:18px;overflow:hidden;background:#fff}
.booking-calendar-head{display:grid;grid-template-columns:120px 1fr 120px;align-items:center;gap:12px;padding:14px 16px;border-bottom:1px solid var(--line);background:#fff}
.booking-calendar-head strong{text-align:center;font-size:30px;line-height:1.2}
.booking-month-btn{border:1px solid #7f8b96;background:#fff;color:#344150;border-radius:6px;padding:8px 10px;font:inherit;cursor:pointer}
.booking-calendar-week{display:grid;grid-template-columns:repeat(7,1fr);background:#6f7a83;color:#fff;font-weight:900;text-align:center}
.booking-calendar-week span{padding:7px 4px;border-right:1px solid rgba(255,255,255,.35)}
.booking-calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);background:#d9dee3;gap:1px}
.booking-calendar-loading{grid-column:1/-1;padding:28px;background:#fff;text-align:center;font-weight:900}
.booking-day{min-height:66px;border:0;background:#fff;color:#111;cursor:pointer;display:grid;place-items:center;gap:2px;padding:7px 2px;font:inherit}
.booking-day-num{font-size:20px;font-weight:900;line-height:1}
.booking-day-mark{font-size:20px;line-height:1}
.booking-day.is-sunday .booking-day-num{color:red}
.booking-day.is-other{background:#f1f1f1;color:#111}
.booking-day.is-disabled{cursor:default;background:#f3f3f3;color:#999}
.booking-day.is-disabled .booking-day-mark{display:none}
.booking-day.is-selected{outline:2px solid #0075ff;outline-offset:-2px;background:#fffdf5}
.booking-time-title{margin:0 0 10px;font-size:17px;font-weight:900}
.booking-time-list{display:grid;gap:8px}
.booking-time-btn{width:100%;padding:14px 18px;border:1px solid var(--line);border-radius:8px;background:#fff;color:#344150;font:inherit;font-size:17px;cursor:pointer;text-align:center}
.booking-time-btn.is-selected{border-color:var(--green);background:#e9f9ef;color:var(--green-dark);font-weight:900}
.booking-time-empty{margin:0;padding:14px;border:1px solid var(--line);border-radius:8px;color:var(--muted);text-align:center}
@media(max-width:720px){
  .booking-modal__panel{padding:26px 18px;border-radius:22px}
  .booking-calendar-head{grid-template-columns:88px 1fr 88px;gap:8px;padding:12px 10px}
  .booking-calendar-head strong{font-size:22px}
  .booking-month-btn{padding:7px 5px;font-size:13px}
  .booking-day{min-height:54px}
  .booking-day-num{font-size:16px}
}


/* booking confirm screen */
.booking-step[hidden]{display:none!important}
.booking-confirm-box{border:1px solid var(--line);background:#fafcff;border-radius:20px;padding:24px}
.booking-confirm-box h3{margin:0 0 18px;font-size:24px;text-align:center}
.booking-confirm-box dl{display:grid;grid-template-columns:150px 1fr;gap:12px 16px;margin:0}
.booking-confirm-box dt{font-weight:900;color:var(--muted)}
.booking-confirm-box dd{margin:0;font-weight:900;color:var(--text)}
.booking-confirm-actions{display:grid;grid-template-columns:1fr 2fr;gap:12px;margin-top:18px}
.btn-secondary{background:#f0f4f7!important;color:#223!important;box-shadow:none!important}
@media(max-width:620px){
  .booking-confirm-box dl{grid-template-columns:1fr;gap:6px}
  .booking-confirm-actions{grid-template-columns:1fr}
}

.solution-card-single{display:block}
.solution-card-single .solution-copy{max-width:860px;margin:0 auto;text-align:center}
.solution-card-single .solution-copy h2{max-width:820px;margin-left:auto;margin-right:auto}
.solution-card-single .solution-copy p{max-width:820px;margin-left:auto;margin-right:auto}
.solution-card-single .callout{max-width:760px;margin-left:auto;margin-right:auto}
.solution-card-single .solution-cta{justify-content:center}
@media (max-width: 768px){
  .solution-card-single .solution-copy{text-align:left}
  .solution-card-single .solution-cta{justify-content:flex-start}
}

/* ▼TOP見出しと画像の間に入るPC＋スマホ画像の表示位置・余白 */
.hero-device-image{
  margin: 36px auto 26px;
  display: flex;
  justify-content: center;
  align-items: center;
}
/* ▼TOP画像そのものの横幅指定 */
.hero-device-image img{
  display: block;
  width: min(100%, 980px);
  height: auto;
}
/* ▼スマホ表示時のTOP画像まわりの余白・横幅 */
@media (max-width: 768px){
  .hero-device-image{
    margin: 28px auto 22px;
  }
  .hero-device-image img{
    width: min(100%, 720px);
  }
}

/* hero lead copy */
/* ▼追加コピー全体の余白。下側の値が画像との間隔に効く */
.hero-system-lead{
  margin: 18px auto 5px;
  text-align: center;
  line-height: 1.18;
}
/* ▼追加コピー1行目・2行目の文字サイズ */
.hero-system-lead-small,
/* ▼追加コピー2行目の上余白 */
.hero-system-lead-mid{
  color: #0f172a;
  font-weight: 800;
  font-size: clamp(17px, 1.85vw, 24px);
  letter-spacing: .04em;
}
.hero-system-lead-mid{
  margin-top: 2px;
}
/* ▼追加コピー3行目 Safety-LINE の文字サイズ・上余白 */
.hero-system-lead-brand{
  color: var(--green, #06c755);
  font-weight: 900;
  font-size: clamp(34px, 4.1vw, 54px);
  line-height: 1.02;
  letter-spacing: .01em;
  margin-top: 4px;
}

/* ▼TOP見出し上の余白。数値を小さくすると見出しが上に詰まる */
/* hero top spacing adjustment */
.hero{
  padding-top: 25px;
}
.hero .hero-inner,
.hero-inner,
.hero-content{
  padding-top: 0 !important;
}
/* ▼TOP見出し自体の上余白を消す指定 */
.hero h1,
.hero-title,
.hero-headline{
  margin-top: 0 !important;
}
/* ▼追加コピーとTOP画像の間隔。小さくすると画像が上に近づく */
.hero-device-image{
  margin-top: 1px !important;
}

/* ▼スマホ表示時：TOP見出し上の余白 */
@media (max-width: 768px){
  .hero{
    padding-top: 15px;
  }
/* ▼スマホ表示時：追加コピー全体の余白 */
  .hero-system-lead{
    margin: 14px auto 16px;
  }
/* ▼スマホ表示時：追加コピー1行目・2行目の文字サイズ */
  .hero-system-lead-small,
  .hero-system-lead-mid{
    font-size: 16px;
  }
/* ▼スマホ表示時：Safety-LINE の文字サイズ */
  .hero-system-lead-brand{
    font-size: 34px;
  }
/* ▼スマホ表示時：追加コピーとTOP画像の間隔 */
  .hero-device-image{
    margin-top: 1px !important;
  }
}

/* ▼TOP見出しと追加コピーの間の横線 */
.hero-lead-divider{
  width: min(440px, 72%);
  height: 1px;
  margin: 9px auto 7px;
  background: #d9e2ea;
}
/* ▼スマホ表示時：横線の横幅・上下余白 */
@media (max-width: 768px){
  .hero-lead-divider{
    width: 72%;
    margin: 7px auto 7px;
  }
}

/* ▼スマホ表示の時だけ改行を入れるためのクラス
   HTML側で <br class="sp-br"> を入れると、
   PCでは改行されず、スマホだけ改行されます。 */
.sp-br{
  display: none;
}
@media (max-width: 768px){
  .sp-br{
    display: inline;
  }
}
