@charset "UTF-8";
/* ============ Top utility bar ============ */
.util-bar{
  background:var(--green-800);
  color:#fff;
  font-size:11px;
  display:flex;justify-content:space-between;align-items:center;
  padding:6px 24px;
  letter-spacing:0.04em;
}
.util-bar .left a{margin-right:18px;opacity:0.9}
.util-bar .left a:hover{opacity:1}
.util-bar .right{display:flex;gap:14px;align-items:center;font-size:10.5px}
.util-bar .sns a{margin-left:8px;opacity:0.85}

/* ============ Header ============ */
header.site-head{
  background:#fff;
  border-bottom:1px solid var(--ink-100);
  padding:18px 40px 0;
  position:sticky;top:0;z-index:50;
}
.head-row{
  display:flex;align-items:center;justify-content:space-between;
  gap:24px;max-width:1080px;margin:0 auto;
}
.logo{
  display:flex;align-items:center;gap:14px;
}
.logo-mark{
  width:32px;height:32px;border-radius:50%;
  background:var(--green-700);color:#fff;
  display:grid;place-items:center;
  font-size:18px;font-family:"Noto Serif JP",serif;
}
.logo .name{
  font-family:"Noto Serif JP",serif;
  font-size:22px;font-weight:600;letter-spacing:0.04em;
  color:var(--ink-900);
}
.head-info{
  display:flex;align-items:stretch;gap:14px;
}
.station-badge{
  display:flex;flex-direction:column;justify-content:center;
  padding:4px 10px;border-left:1px solid var(--ink-200);
  font-size:11px;color:var(--ink-600);line-height:1.4;
}
.station-badge strong{color:var(--ink-900);font-weight:600;font-size:12px;display:block}
.payment-badge{
  border:1px solid var(--ink-200);
  padding:6px 12px;border-radius:2px;
  font-size:10.5px;color:var(--ink-700);line-height:1.5;
  display:flex;flex-direction:column;justify-content:center;
}
.payment-badge strong{font-weight:600;font-size:11px;color:var(--ink-900)}
.head-cta{
  background:var(--green-800);color:#fff;
  padding:10px 18px 10px 20px;
  display:flex;flex-direction:column;align-items:stretch;gap:2px;
  border-radius:2px;min-width:200px;
}
.head-cta .sub{font-size:10.5px;letter-spacing:0.08em;opacity:0.9;text-align:center}
.head-cta .tel{
  font-family:"Noto Serif JP",serif;
  font-size:22px;font-weight:500;letter-spacing:0.02em;
  display:flex;align-items:center;gap:6px;justify-content:center;
}
.head-cta .tel svg{width:14px;height:14px}
.reserve-btn{
  background:var(--green-700);color:#fff;
  padding:8px 16px;border-radius:2px;
  font-size:12px;letter-spacing:0.06em;
  display:flex;align-items:center;gap:8px;
}
.reserve-btn::before{content:"▶";font-size:8px;color:#fff}
.reserve-btn:hover{background:var(--green-800)}

/* Global nav */
nav.gnav{
  max-width:1080px;margin:0 auto;
  padding:14px 0 16px;
  display:flex;justify-content:center;gap:38px;
  font-size:13px;letter-spacing:0.08em;
}
nav.gnav a{
  color:var(--ink-800);position:relative;padding:4px 0;
  display:inline-flex;flex-direction:column;align-items:center;line-height:1.2;
}
nav.gnav a .en{font-size:9.5px;color:var(--green-700);letter-spacing:0.18em;margin-top:3px}
nav.gnav a:hover{color:var(--green-700)}
nav.gnav a.active{color:var(--green-700)}
nav.gnav a.active::after{
  content:"";position:absolute;bottom:-4px;left:50%;
  width:18px;height:2px;background:var(--green-700);transform:translateX(-50%);
}

/* Floating side buttons */
.side-float{position:fixed;top:46%;z-index:40;display:flex;flex-direction:column;gap:2px}
.side-float.left{left:0}
.side-float.right{right:0}
.float-btn{
  background:#06c755;color:#fff;
  width:64px;padding:12px 6px;
  display:flex;flex-direction:column;align-items:center;gap:6px;
  font-size:11px;letter-spacing:0.08em;text-align:center;line-height:1.3;
  border-radius:0 3px 3px 0;
}
.float-btn.line .icon{
  width:26px;height:26px;background:#fff;color:#06c755;border-radius:50%;
  display:grid;place-items:center;font-size:12px;font-weight:700;
}
.side-float.right .float-btn{border-radius:3px 0 0 3px}
.float-btn.tel{
  background:var(--green-700);color:#fff;padding:14px 6px 10px;
  line-height:1.3;
}
.float-btn.tel .num{font-family:"Noto Serif JP",serif;font-size:13px;letter-spacing:0;margin-top:4px}
.float-btn.web{
  background:var(--ink-800);color:#fff;padding:14px 6px;
}
.float-btn.web .icon{font-size:18px;margin-bottom:2px}

/* ============ Footer CTA strip ============ */
.footer-cta{
  background:#fff;padding:80px 40px;border-top:1px solid var(--ink-100);text-align:center;
}
.footer-cta .h{
  font-family:"Noto Serif JP",serif;font-size:28px;letter-spacing:0.15em;
  margin-bottom:16px;color:var(--green-800);
}
.footer-cta > .wrapper > p{
  font-size:15px;color:#555;margin-bottom:40px;
}
/* ボタン3点グリッド */
.foot-cta-grid{
  display:flex;justify-content:center;align-items:center;
  gap:20px;flex-wrap:wrap;
}
.btn-reserve-large{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  min-width:220px;padding:16px 28px;
  background:var(--green-800);color:#fff;
  font-family:"Noto Serif JP",serif;font-size:15px;letter-spacing:0.1em;
  border:2px solid var(--green-800);
  border-radius:2px;transition:background 0.25s,color 0.25s;
  text-decoration:none;cursor:pointer;
}
.btn-reserve-large:hover{background:var(--green-700);border-color:var(--green-700);}
.btn-reserve-large svg{flex-shrink:0;}
/* オンライン診療ブロック */
.online-cta-block{
  margin-top:56px;padding-top:40px;border-top:1px solid var(--ink-100);
}
.online-cta-block h3{
  font-family:"Noto Serif JP",serif;font-size:22px;color:var(--green-800);
  margin-bottom:12px;letter-spacing:0.1em;
}
.online-cta-block > p{
  font-size:14px;line-height:1.7;color:#555;margin-bottom:32px;
}
.online-cta-inner{
  display:inline-flex;justify-content:center;align-items:center;
  gap:40px;flex-wrap:wrap;
  background:#f8fafc;padding:40px;border-radius:12px;
  border:1px solid var(--ink-100);max-width:100%;
}
.online-cta-btns{
  display:flex;flex-direction:column;gap:16px;flex-grow:1;min-width:240px;
}
.btn-online{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  width:100%;padding:16px 20px;
  font-family:"Noto Serif JP",serif;font-size:14px;letter-spacing:0.08em;
  font-weight:600;border-radius:2px;text-decoration:none;transition:opacity 0.2s;
}
.btn-online:hover{opacity:0.8;}
.btn-online.internal{
  background:#fff;color:var(--green-800);border:2px solid var(--green-800);
}
.btn-online.private{
  background:#fff;color:#8b7355;border:2px solid #8b7355;
}
/* レスポンシブ */
@media(max-width:860px){
  .footer-cta{padding:60px 24px;}
  .foot-cta-grid{flex-direction:column;align-items:stretch;}
  .btn-reserve-large{width:100%;min-width:unset;}
  .online-cta-inner{flex-direction:column;padding:28px 20px;}
  .online-cta-btns{width:100%;}
}

/* ============ Footer ============ */
footer.site-foot{
  background:#1a1a1a;color:#ddd;padding:56px 40px 24px;font-size:12px;
}
.foot-top{
  max-width:1160px;margin:0 auto;
  display:grid;grid-template-columns:1.2fr 1fr 1fr 1fr;gap:40px;
}
.foot-top .logo-block .name{
  font-family:"Noto Serif JP",serif;font-size:20px;color:#fff;margin-bottom:10px;display:block;
}
.foot-top .logo-block address{font-style:normal;line-height:1.9;color:#aaa;font-size:11.5px}
.foot-col h5{
  font-size:11px;letter-spacing:0.2em;color:#fff;
  margin:0 0 12px;padding-bottom:8px;border-bottom:1px solid #333;
}
.foot-col ul{list-style:none;padding:0;margin:0}
.foot-col li{margin:6px 0}
.foot-col a{color:#bbb;font-size:11.5px;display:flex;align-items:center;gap:6px}
.foot-col a::before{content:"›";color:var(--green-600);font-size:12px}
.foot-col a:hover{color:#fff}
.foot-bottom{
  max-width:1160px;margin:40px auto 0;padding-top:20px;
  border-top:1px solid #333;
  display:flex;justify-content:space-between;align-items:center;
  color:#777;font-size:10.5px;letter-spacing:0.08em;
}

/* ============ Hamburger button ============ */
.menu-toggle{
  display:none;
  flex-direction:column;justify-content:center;gap:5px;
  width:40px;height:40px;
  background:none;border:none;cursor:pointer;padding:6px;
  flex-shrink:0;
}
.menu-toggle span{
  display:block;height:2px;
  background:var(--ink-900);border-radius:1px;
  transition:transform 0.3s ease, opacity 0.3s ease;
}
.menu-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.menu-toggle[aria-expanded="true"] span:nth-child(2){opacity:0;}
.menu-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

/* ============ Nav backdrop ============ */
.gnav-backdrop{
  display:none;
  position:fixed;inset:0;
  background:rgba(0,0,0,0.4);
  z-index:49;
}
.gnav-backdrop.is-open{display:block;}

@media (max-width:860px){
  header.site-head{padding:12px 16px 0;}
  .head-row{flex-direction:row;justify-content:space-between;align-items:center;gap:12px;}
  .logo{justify-content:flex-start;}
  .head-info{display:none;}

  .menu-toggle{display:flex;}

  nav.gnav{
    position:fixed;top:0;right:0;
    width:280px;height:100vh;
    flex-direction:column;justify-content:flex-start;
    gap:0;padding:72px 0 40px;
    background:#fff;
    box-shadow:-4px 0 24px rgba(0,0,0,0.12);
    z-index:50;
    transform:translateX(100%);
    transition:transform 0.3s ease;
    overflow-y:auto;
  }
  nav.gnav.is-open{transform:translateX(0);}
  nav.gnav a{
    font-size:14px;padding:16px 32px;
    border-bottom:1px solid var(--ink-100);
    flex-direction:row;align-items:center;gap:10px;
    justify-content:flex-start;
  }
  nav.gnav a .en{font-size:9px;margin-top:0;}
  nav.gnav a.active::after{display:none;}

  .side-float{display:none;}

  .foot-cta-grid{grid-template-columns:1fr}
  .foot-top{grid-template-columns:1fr;gap:32px}
  .foot-bottom{flex-direction:column;gap:12px;text-align:center;}
}

@media (max-width:480px){
  .head-info{gap:6px;}
  .header-badges{width:100%;justify-content:center;margin-bottom:4px;}
  .head-cta img{max-height:36px;}
  
  nav.gnav{gap:10px 14px;}
  nav.gnav a{font-size:11px;}
  nav.gnav a .en{font-size:8px;}
}

/* ============ Clinic info (Global) ============ */
.clinic-info{padding:60px 40px 72px;background:#fff}
.clinic-info .sec-title .jp{font-size:24px}
.info-grid{
  max-width:1000px;margin:0 auto;
  display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start;
}
.info-table{font-size:13px}
.info-table dl{
  display:grid;grid-template-columns:80px 1fr;gap:8px 16px;
  padding:12px 0;border-bottom:1px solid var(--ink-100);margin:0;
}
.info-table dt{color:var(--green-800);font-weight:600;font-size:12px;letter-spacing:0.1em}
.info-table dd{margin:0;color:var(--ink-800);line-height:1.75}
.info-table dd .small{font-size:11.5px;color:var(--ink-600)}
.info-table .access-list{margin:4px 0 0;padding-left:16px;font-size:12px;color:var(--ink-700)}
.info-table .access-list li{line-height:1.9}

.map-block{display:flex;flex-direction:column;gap:12px}
.map-ph{
  aspect-ratio:4/3;background:url('../img/map.png') no-repeat center/cover;border:1px solid var(--ink-100);
  position:relative;overflow:hidden;
}
.map-btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  border:1px solid var(--green-700);color:var(--green-800);
  padding:10px 18px;font-size:11.5px;letter-spacing:0.16em;
  align-self:flex-start;
}
.map-btn::after{content:"→"}
.map-btn:hover{background:var(--green-700);color:#fff}

.hours{margin:28px auto 0;max-width:640px}
.hours table{width:100%;border-collapse:collapse;font-size:12.5px;background:#fff}
.hours th,.hours td{border:1px solid var(--ink-200);padding:10px 8px;text-align:center}
.hours th{background:var(--paper-warm);color:var(--ink-900);font-weight:500;font-size:11.5px;letter-spacing:0.08em}
.hours td.time{background:var(--paper-warm);font-size:11.5px;color:var(--ink-700);text-align:left;padding-left:14px}
.hours .mark{color:var(--ink-900);font-weight:500}
.hours .off{color:var(--ink-300)}
.hours-notes{font-size:11px;color:var(--red);margin-top:12px;line-height:1.9;text-align:left;max-width:640px;margin-left:auto;margin-right:auto}
.hours-notes .sub{color:var(--ink-600)}

@media (max-width:860px){
  .info-grid{grid-template-columns:1fr;gap:32px}
  .info-table dl{grid-template-columns:1fr;gap:4px;padding:12px 0;}
  .hours{overflow-x:auto;}
  .hours table{min-width:500px;}
}
