:root {
  --ink: #202823;
  --body-text: #384139;
  --muted: #5f6962;
  --paper: #fffdf8;
  --white: #ffffff;
  --wash: #f2f6f2;
  --clinic-blue: #315f8b;
  --clinic-blue-dark: #244762;
  --lamp: #d88b39;
  --wood: #75513f;
  --offer-red: #b3261e;
  --offer-red-dark: #861a22;
  --offer-pink: #fce8ea;
  --line: #d8ddd7;
  --safe: #e5efe7;
  --shadow: 0 14px 40px rgba(32, 40, 35, 0.1);
  --radius: 16px;
  --font-display: "Yu Mincho", "Hiragino Mincho ProN", "Hiragino Mincho Pro", serif;
  --font-body: "BIZ UDPGothic", "Yu Gothic", "Hiragino Kaku Gothic ProN", sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
[id] { scroll-margin-top: 86px; }
body {
  margin: 0;
  color: var(--body-text);
  background: var(--paper);
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.8;
  text-rendering: optimizeLegibility;
}
img { display: block; max-width: 100%; height: auto; }
a { color: inherit; }
button, summary, a { -webkit-tap-highlight-color: transparent; }
a:focus-visible, summary:focus-visible { outline: 3px solid var(--lamp); outline-offset: 4px; }
.text-nowrap { white-space: nowrap; }
.skip-link { position: fixed; z-index: 100; top: 8px; left: 8px; padding: 8px 14px; transform: translateY(-150%); background: var(--ink); color: white; }
.skip-link:focus { transform: translateY(0); }

.container { width: min(1120px, calc(100% - 40px)); margin-inline: auto; }
.narrow { width: min(760px, calc(100% - 40px)); }
.section { padding: 72px 0; }
.section-compact { padding: 28px 0 44px; }
.wash { background: var(--wash); }

.site-header { position: sticky; top: 0; z-index: 50; background: rgba(255, 253, 248, 0.96); border-bottom: 1px solid rgba(216, 221, 215, 0.8); backdrop-filter: blur(10px); }
.header-inner { width: min(1180px, calc(100% - 32px)); min-height: 64px; margin-inline: auto; display: flex; align-items: center; justify-content: space-between; gap: 24px; }
.brand { display: inline-flex; align-items: baseline; gap: 10px; min-width: 0; text-decoration: none; transform: translateY(2px); }
.brand-name { font-family: var(--font-display); font-weight: 700; font-size: 25px; letter-spacing: 0.01em; line-height: 1.1; white-space: nowrap; }
.brand-note { color: var(--muted); font-size: 12px; }
.desktop-nav { display: none; align-items: center; gap: 24px; }
.desktop-nav > a:not(.button) { text-decoration: none; font-size: 14px; font-weight: 700; }
.desktop-nav > a[aria-current="page"] { color: var(--clinic-blue-dark); text-decoration: underline; text-decoration-thickness: 2px; text-underline-offset: 6px; }
.header-phone { color: var(--clinic-blue-dark); font-variant-numeric: tabular-nums; }
.mobile-menu { position: relative; }
.mobile-menu summary { list-style: none; cursor: pointer; min-height: 48px; display: inline-flex; align-items: center; justify-content: center; box-sizing: border-box; color: var(--clinic-blue-dark); font-size: 15px; font-weight: 800; line-height: 1; white-space: nowrap; border: 2px solid rgba(49, 95, 139, 0.34); border-radius: 10px; padding: 10px 13px; background: rgba(255,255,255,.78); box-shadow: 0 3px 10px rgba(32,40,35,.08); }
.mobile-menu summary::-webkit-details-marker { display: none; }
.mobile-menu nav { position: absolute; right: 0; top: calc(100% + 10px); width: min(320px, calc(100vw - 24px)); padding: 12px; background: var(--white); border: 1px solid var(--line); border-radius: 12px; box-shadow: var(--shadow); }
.mobile-menu nav a { display: block; min-height: 48px; padding: 14px 12px; color: var(--ink); font-size: 15px; font-weight: 700; text-decoration: none; border-bottom: 1px solid var(--line); }
.mobile-menu nav a[aria-current="page"] { color: var(--clinic-blue-dark); background: var(--wash); border-radius: 8px; }
.mobile-menu nav a:last-child { border-bottom: 0; }

.hero-grid { display: grid; gap: 28px; }
.hero-cover-section { padding-top: 18px; padding-bottom: 24px; }
.hero-cover-layout { display: grid; gap: 14px; width: min(100% - 16px, 1180px); }
.hero-cover { margin: 0; overflow: hidden; border-radius: 12px; box-shadow: var(--shadow); background: white; }
.hero-cover img { width: 100%; height: auto; }
.hero-cover-copy { display: grid; gap: 8px; padding: 2px 4px 0; text-align: center; }
.hero-cover-copy h1 { margin: 0; color: #1f3429; font-size: 24px; line-height: 1.38; letter-spacing: 0; }
.hero-cover-copy p { max-width: 760px; margin: 0 auto; color: #4a5a51; font-size: 15px; line-height: 1.8; }
.hero-actions { display: grid; gap: 8px; }
.hero-visual { margin: 0; overflow: hidden; border-radius: 22px; box-shadow: var(--shadow); }
.hero-visual img { width: 100%; height: clamp(190px, 56vw, 300px); object-fit: cover; object-position: 64% 48%; }
.eyebrow { margin: 0 0 12px; color: var(--clinic-blue-dark); font-size: 16px; font-weight: 800; letter-spacing: 0.04em; }
h1, h2, h3 { margin-top: 0; color: var(--ink); font-family: var(--font-display); line-height: 1.45; letter-spacing: 0.02em; }
h1 { margin-bottom: 20px; font-size: clamp(31px, 8.2vw, 46px); font-weight: 700; }
.headline-line { display: block; }
.headline-emphasis { color: var(--clinic-blue-dark); }
h2 { margin-bottom: 20px; font-size: clamp(30px, 7.6vw, 42px); }
h3 { font-size: 20px; }
.hero-lead { margin: 0; color: #374039; font-size: 17px; }
.page-title { padding: 58px 0 52px; background: var(--paper); }
.page-title p:last-child { margin: 0; color: var(--muted); font-size: 17px; }
.page-title-photo { margin: 26px 0 0; overflow: hidden; border-radius: 16px; background: var(--white); box-shadow: var(--shadow); }
.page-title-photo img { width: 100%; aspect-ratio: 4 / 3; object-fit: cover; object-position: center; }
.first-visit-intro { padding: 58px 0 34px; }
.first-visit-intro .page-label-title { margin-bottom: 18px; }
.first-visit-intro .first-visit-lead { max-width: 720px; color: var(--body-text); font-size: clamp(16px, 4.2vw, 18px); line-height: 1.9; }
.first-policy-section { padding-top: 50px; }
.profile-hero { padding-bottom: 62px; }
.profile-hero-grid { display: grid; gap: 32px; align-items: center; }
.profile-hero-copy { max-width: 560px; }
.profile-main-title { margin-bottom: 20px; font-size: clamp(42px, 12vw, 58px); }
.profile-hero .profile-main-title { margin-bottom: 18px; }
.profile-hero-lead { max-width: 520px; color: var(--body-text); font-size: clamp(16px, 4.2vw, 18px); line-height: 1.95; }
.profile-hero .profile-hero-name { margin-top: 22px; color: var(--muted); font-size: 14px; line-height: 1.7; }
.profile-hero .profile-hero-name strong { color: var(--clinic-blue-dark); font-size: 20px; letter-spacing: 0.04em; }
.profile-hero figure { margin: 0; max-width: 420px; }
.profile-hero figure img { width: 100%; border-radius: 20px; box-shadow: var(--shadow); object-fit: cover; object-position: center top; }
.profile-hero .profile-greeting-photo { width: min(100%, 520px); max-width: none; justify-self: center; }
.profile-hero .profile-greeting-photo img { width: 100%; height: auto; aspect-ratio: auto; object-fit: contain; object-position: center; }
.access-title h1 { margin-bottom: 0; font-size: clamp(40px, 11vw, 58px); }
.access-section-heading { margin-bottom: 24px; }
.access-section-heading h2 { margin-bottom: 0; font-size: clamp(38px, 10vw, 54px); }
.action-group { margin-top: 26px; display: grid; gap: 8px; }
.button { min-height: 50px; display: inline-flex; align-items: center; justify-content: center; padding: 12px 20px; border: 2px solid var(--clinic-blue); border-radius: 10px; background: var(--clinic-blue); color: white; font-weight: 700; line-height: 1.4; text-align: center; text-decoration: none; transition: background-color .2s ease, border-color .2s ease, transform .2s ease; }
.button:hover { background: var(--clinic-blue-dark); border-color: var(--clinic-blue-dark); transform: translateY(-1px); }
.button-small { min-height: 40px; padding: 8px 15px; font-size: 14px; }
.button-outline { background: transparent; color: var(--clinic-blue-dark); }
.button-outline:hover { color: white; }
.button-light { background: white; border-color: white; color: var(--clinic-blue-dark); }
.button-light:hover { background: var(--paper); border-color: var(--paper); color: var(--clinic-blue-dark); }
.button-ghost { background: transparent; border-color: rgba(255,255,255,.75); color: white; }
.button-ghost:hover { background: rgba(255,255,255,.1); border-color: white; }
.text-link { color: var(--clinic-blue-dark); font-weight: 700; text-underline-offset: 5px; text-decoration-thickness: 1px; }
.text-link::after { content: " →"; }
.action-note, .microcopy { color: var(--muted); font-size: 12px; line-height: 1.6; }
.microcopy { margin: 12px 0 0; }
.anchor-nav { margin-top: 28px; display: flex; flex-wrap: wrap; gap: 10px; }
.anchor-nav a { padding: 8px 12px; border: 1px solid var(--line); border-radius: 999px; background: var(--white); color: var(--clinic-blue-dark); font-size: 14px; font-weight: 700; text-decoration: none; }

.fact-strip { border-block: 1px solid var(--line); background: var(--white); }
.fact-grid { display: grid; grid-template-columns: 1fr 1fr; }
.fact-grid div { min-height: 116px; display: flex; flex-direction: column; justify-content: center; padding: 18px 12px; border-bottom: 1px solid var(--line); }
.fact-grid div:nth-child(odd) { border-right: 1px solid var(--line); }
.fact-grid div:nth-last-child(-n+2) { border-bottom: 0; }
.fact-grid strong { color: var(--clinic-blue-dark); font-size: 16px; }
.fact-grid span { margin-top: 3px; color: var(--muted); font-size: 12px; line-height: 1.5; }

.section-heading { margin-bottom: 36px; }
.section-heading-tight { margin-bottom: 24px; }
.section-heading > p:last-child { max-width: 720px; color: var(--muted); }
.principles .section-heading > p { max-width: 720px; color: var(--body-text); }
.policy-title-block { display: grid; gap: 22px; align-content: start; }
.policy-content { display: grid; gap: 24px; }
.policy-list { display: grid; gap: 18px; }
.policy-list article { padding-bottom: 18px; border-bottom: 1px solid var(--line); }
.policy-list article:last-child { padding-bottom: 0; border-bottom: 0; }
.policy-list h3 { margin-bottom: 6px; }
.policy-list p { margin: 0; color: var(--body-text); }
.policy-support-photo { margin: 0; overflow: hidden; border-radius: 14px; background: var(--white); box-shadow: var(--shadow); }
.policy-support-photo img { width: 100%; aspect-ratio: 16 / 9; object-fit: cover; object-position: center 45%; }
.greeting-copy p,
.story-copy p { color: var(--body-text); }
.greeting-copy p:first-child,
.story-copy p:first-child { margin-top: 0; }
.profile-greeting-section { padding-top: 42px; padding-bottom: 64px; }
.profile-greeting-section .split-heading { grid-template-columns: 1fr; justify-items: center; gap: 0; }
.profile-greeting-copy { width: min(100%, 820px); max-width: 820px; margin-inline: auto; padding: clamp(28px, 6vw, 52px); border: 1px solid rgba(49, 95, 139, 0.16); border-radius: 8px; background: linear-gradient(180deg, rgba(255, 253, 248, 0.98), rgba(255, 250, 241, 0.96)); box-shadow: 0 18px 46px rgba(32, 40, 35, 0.08); }
.profile-greeting-copy p { max-width: 680px; margin-inline: auto; line-height: 2.05; }
.profile-greeting-copy p:last-child { margin-bottom: 0; }
.profile-greeting-copy p:first-child { color: var(--ink); font-family: var(--font-display); font-size: clamp(24px, 6.6vw, 32px); line-height: 1.65; }
.policy-section-title { margin-bottom: 18px; font-size: clamp(31px, 7.8vw, 42px); }
.policy-name-photo { width: 100%; margin: 0; }
.policy-name-photo img { width: 100%; aspect-ratio: 4 / 3; object-fit: cover; object-position: center 58%; border-radius: 14px; box-shadow: var(--shadow); }
.page-label-title { margin-bottom: 18px; font-size: clamp(40px, 11vw, 56px); }
.section-label-title { margin-bottom: 22px; color: var(--ink); font-size: clamp(31px, 7.8vw, 42px); }
.split-heading .section-label-title { margin-bottom: 0; }
.section-lead { margin: -8px 0 0; color: var(--muted); font-size: 16px; line-height: 1.75; }
.profile-block figure { overflow: hidden; border-radius: 18px; box-shadow: var(--shadow); }
.profile-block figure img { width: 100%; aspect-ratio: 4 / 3; object-fit: cover; object-position: center; }
.profile-facts { margin: 24px 0 0; border-top: 1px solid var(--line); }
.profile-facts div { display: grid; gap: 4px; padding: 14px 0; border-bottom: 1px solid var(--line); }
.profile-facts dt { color: var(--muted); font-size: 13px; font-weight: 700; }
.profile-facts dd { margin: 0; }
.message-band { padding: 54px 0; background: var(--clinic-blue-dark); color: white; text-align: center; }
.message-band .eyebrow { color: #dce9f3; }
.message-band p:last-child { margin: 0; font-family: var(--font-display); font-size: clamp(24px, 7vw, 38px); line-height: 1.55; }
.with-lamps { position: relative; padding-top: 32px; }
.lamp-dots { position: absolute; top: -4px; left: 2px; display: flex; align-items: flex-start; gap: 7px; height: 32px; }
.lamp-dots i { display: block; width: 8px; height: 8px; border-radius: 50%; background: var(--lamp); box-shadow: 0 -12px 0 -3px var(--wood); }
.lamp-dots i:nth-child(2) { margin-top: 8px; }
.lamp-dots i:nth-child(3) { margin-top: 16px; }
.principle-grid { display: grid; gap: 24px; }
.principle-grid article { position: relative; padding-top: 22px; border-top: 1px solid var(--line); }
.principle-marker { position: absolute; top: -5px; left: 0; width: 10px; height: 10px; border: 2px solid var(--paper); border-radius: 50%; background: var(--lamp); }
.principle-photo { margin: 0 0 18px; overflow: hidden; border-radius: 14px; box-shadow: 0 10px 28px rgba(32, 40, 35, 0.08); }
.principle-photo img { width: 100%; aspect-ratio: 4 / 3; object-fit: cover; object-position: center; }
.principle-grid p { color: var(--body-text); }
.section-action { margin: 32px 0 0; }

.concern-illustration { margin: -8px auto 22px; overflow: hidden; max-width: 520px; border-radius: 16px; box-shadow: 0 12px 32px rgba(32, 40, 35, 0.08); background: white; }
.concern-illustration img { width: 100%; height: auto; }
.concern-list { overflow: hidden; margin: 0; padding: 0; list-style: none; display: grid; border: 1px solid var(--line); border-radius: 8px; background: var(--white); }
.concern-list li { position: relative; min-height: 38px; padding: 8px 10px 8px 42px; border-bottom: 1px solid rgba(216, 221, 215, 0.9); color: var(--body-text); font-size: 14px; line-height: 1.55; }
.concern-list li:nth-child(odd) { background: var(--white); }
.concern-list li:nth-child(even) { background: #fff9f2; }
.concern-list li:last-child { border-bottom: 0; }
.concern-list li::before { content: ""; position: absolute; left: 12px; top: 50%; width: 15px; height: 15px; box-sizing: border-box; border: 1.5px solid #78927c; border-radius: 3px; background: var(--paper); transform: translateY(-50%); }
.concern-list li::after { content: ""; position: absolute; left: 16px; top: 50%; width: 7px; height: 4px; border-left: 2px solid var(--clinic-blue); border-bottom: 2px solid var(--clinic-blue); transform: translateY(-58%) rotate(-45deg); }
.concern-closing { margin: 20px 0 32px; padding: 20px 22px 22px; border: 1px solid rgba(216, 221, 215, 0.95); border-radius: 8px; background: rgba(255, 255, 255, 0.72); color: var(--body-text); font-family: var(--font-body); font-size: clamp(15px, 1.72vw, 19.5px); font-weight: 500; line-height: 1.76; }
.concern-closing p { margin: 0; }
.concern-closing p + p { margin-top: 12px; }
.concern-closing .mobile-break { display: none; }
.concern-closing .desktop-break { display: inline; }
.concern-closing + .section-action { margin-top: -4px; }
.recommend-grid { display: grid; gap: 32px; align-items: center; }
.recommend-grid figure { margin: 0; overflow: hidden; border-radius: 16px; box-shadow: var(--shadow); }
.recommend-grid figure img { width: 100%; aspect-ratio: 4 / 3; object-fit: cover; object-position: center; }
.recommend-list { margin: 26px 0 0; padding: 0; list-style: none; display: grid; gap: 10px; }
.recommend-list li { position: relative; padding: 13px 12px 13px 42px; border: 1px solid var(--line); border-radius: 10px; background: var(--white); }
.recommend-list li::before { content: ""; position: absolute; left: 16px; top: 21px; width: 12px; height: 7px; border-left: 2px solid var(--clinic-blue); border-bottom: 2px solid var(--clinic-blue); transform: rotate(-45deg); }
.safety-note { margin: 0 0 48px; padding: 20px; border-left: 4px solid #6f8a72; background: var(--safe); }
.safety-note p { margin: 6px 0 0; color: var(--muted); }
.flow-summary { padding: 22px 20px; border: 1px solid var(--line); border-radius: 12px; background: var(--white); }
.flow-summary p { margin: 0; color: var(--body-text); }
.subsection-title { margin: 0 0 24px; font-size: 24px; }
.flow-summary .subsection-title { margin-bottom: 8px; }
.flow-cards { margin: 0; padding: 0; list-style: none; display: grid; gap: 18px; }
.flow-cards li { display: grid; gap: 0; overflow: hidden; border: 1px solid var(--line); border-radius: 14px; background: var(--white); box-shadow: 0 10px 28px rgba(32, 40, 35, 0.06); }
.flow-cards figure { margin: 0; background: var(--wash); }
.flow-cards img { width: 100%; aspect-ratio: 16 / 10; object-fit: cover; object-position: center; }
.flow-cards div { padding: 20px; }
.flow-cards span { width: 38px; height: 38px; margin-bottom: 12px; display: grid; place-items: center; border-radius: 50%; background: var(--clinic-blue); color: white; font-weight: 700; font-variant-numeric: tabular-nums; }
.flow-cards h3 { margin-bottom: 6px; font-size: 21px; }
.flow-cards p { margin: 0; color: var(--body-text); }
.reservation-boxes { display: grid; gap: 16px; }
.reservation-boxes article { padding: 22px; border: 1px solid var(--line); border-radius: 14px; background: var(--white); }
.reservation-boxes h3 { margin-bottom: 6px; }
.reservation-boxes p { color: var(--body-text); }
.reservation-boxes .button { margin-top: 12px; }
.reservation-boxes .text-link { display: inline-block; margin-top: 12px; }
.phone-button { min-width: 190px; font-variant-numeric: tabular-nums; }
.notice-list { margin: 0; padding: 0; list-style: none; display: grid; gap: 10px; counter-reset: notice; }
.notice-list-section .section-heading { margin-bottom: 24px; }
.notice-list-section h2:not(.section-label-title) { color: #374039; font-size: clamp(24px, 6vw, 32px); }
.notice-list li { position: relative; padding: 14px 16px 14px 48px; border-left: 3px solid #b6c8b9; background: rgba(255, 255, 255, 0.68); color: var(--muted); font-size: 15px; line-height: 1.75; box-shadow: none; }
.notice-list li::before { counter-increment: notice; content: counter(notice); position: absolute; left: 16px; top: 16px; width: 22px; height: 22px; display: grid; place-items: center; border-radius: 50%; background: #edf4ee; color: #5d7461; font-size: 12px; font-weight: 700; }
.notice-list + * { margin-top: 0; }

.price-section { padding-block: 56px 48px; }
.price-section + .access { padding-top: 56px; }
.price-panel { display: grid; gap: 24px; padding-block: 30px; border-block: 1px solid var(--line); }
.price-panel h2 { margin-bottom: 6px; }
.price-duration { margin: 0; color: var(--muted); }
.price-block { display: flex; flex-direction: column; align-items: flex-start; gap: 4px; }
.price-label, .table-regular-label { color: var(--muted); font-size: 13px; font-weight: 700; }
.regular-price { color: var(--muted); text-decoration: line-through; }
.regular-price-large { display: inline-flex; align-items: baseline; width: max-content; color: var(--clinic-blue-dark); font-size: clamp(32px, 9vw, 46px); line-height: 1.12; font-weight: 700; text-decoration: none; font-variant-numeric: tabular-nums; white-space: nowrap; }
.regular-number { position: relative; display: inline-block; }
.regular-number::after { content: ""; position: absolute; left: 0; right: 0; top: 54%; height: 3px; border-radius: 999px; background: rgba(179, 38, 30, 0.9); transform: translateY(-50%) rotate(-7deg); transform-origin: center; }
.regular-price-large small { font-size: 15px; }
.price-breakdown { color: var(--muted); font-size: 13px; }
.discount-badge { display: inline-flex; align-items: center; min-height: 30px; margin-top: 8px; padding: 3px 10px; border: 1px solid #f0b9bd; border-radius: 999px; background: var(--offer-pink); color: var(--offer-red-dark); font-size: 14px; font-weight: 800; line-height: 1.4; }
.price-block strong { color: var(--clinic-blue-dark); font-size: clamp(42px, 12vw, 60px); line-height: 1.2; font-variant-numeric: tabular-nums; }
.price-block .sale-price { color: var(--offer-red); font-size: clamp(48px, 14vw, 68px); white-space: nowrap; }
.price-block small { font-size: 16px; }
.price-block > span:last-child:not(.discount-badge) { color: var(--muted); font-size: 13px; }
.price-action { display: grid; gap: 10px; justify-items: start; }
.price-action .button { width: 100%; }
.price-action p { margin: 0; color: var(--muted); font-size: 13px; line-height: 1.7; }
.price-primary-action { width: 100%; display: grid; gap: 8px; justify-items: start; }
.price-phone-action { width: 100%; display: grid; gap: 8px; padding: 14px; border: 1px solid rgba(49, 95, 139, 0.22); border-radius: 12px; background: rgba(255, 255, 255, 0.72); }
.price-phone-action span { color: var(--muted); font-size: 13px; font-weight: 700; }
.price-phone-number { color: var(--clinic-blue-dark); font-size: 24px; font-weight: 800; line-height: 1.1; text-decoration-thickness: 1px; text-underline-offset: 5px; font-variant-numeric: tabular-nums; }
.standard-price-card { margin-bottom: 18px; padding: 18px; border: 1px solid rgba(49, 95, 139, 0.2); border-radius: 14px; background: var(--white); box-shadow: 0 8px 24px rgba(32, 40, 35, 0.05); }
.standard-price-title { margin: 0 0 12px; color: var(--clinic-blue-dark); font-size: 15px; font-weight: 800; }
.standard-price-list { margin: 0; display: grid; gap: 8px; }
.standard-price-list div { display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: 16px; align-items: baseline; padding-top: 8px; border-top: 1px solid var(--line); }
.standard-price-list div:first-child { padding-top: 0; border-top: 0; }
.standard-price-list dt { color: var(--muted); font-size: 14px; font-weight: 700; }
.standard-price-list dd { margin: 0; color: var(--clinic-blue-dark); font-size: 22px; font-weight: 800; line-height: 1.2; font-variant-numeric: tabular-nums; }
.price-table { overflow: hidden; border: 1px solid var(--line); border-radius: 14px; background: var(--white); }
.price-row { display: grid; grid-template-columns: 100px minmax(0, 1fr); gap: 8px 10px; align-items: center; padding: 14px 16px; border-top: 1px solid var(--line); }
.price-row:first-child { border-top: 0; }
.price-row-head { display: none; color: var(--muted); background: var(--wash); font-size: 13px; font-weight: 700; }
.price-row div { display: grid; gap: 4px; }
.price-row div:nth-child(2) { grid-column: 1 / -1; order: 3; }
.price-row div:last-child { justify-items: end; text-align: right; }
.price-row strong { color: var(--clinic-blue-dark); font-size: 18px; }
.price-row .price-plan-cell { align-self: center; gap: 2px; }
.price-row .price-plan-cell span { color: var(--body-text); font-size: 14px; line-height: 1.65; white-space: nowrap; }
.price-row .price-detail-cell span:not(.discount-badge) { color: var(--body-text); font-size: 15px; font-weight: 700; line-height: 1.55; }
.price-row .price-row-spacer { display: none; }
.price-row div:last-child strong { font-size: 30px; line-height: 1.18; font-variant-numeric: tabular-nums; }
.price-row span, .price-row small { color: var(--muted); }
.price-row .coupon-price, .price-row .sale-price-table, .price-row .discount-price { color: var(--offer-red); }
.regular-price-large,
.price-block .sale-price,
.price-block .sale-price small,
.standard-price-list dd,
.price-table .price-cell > strong,
.price-table .sale-price-table,
.price-table .table-regular-price,
.price-table .savings-line strong,
.mobile-offer-price,
.mobile-offer-price strong { font-family: "Helvetica Neue", Arial, sans-serif; }
.price-cell > strong, .sale-price-table { display: inline-flex; align-items: baseline; gap: 1px; }
.price-cell .price-number, .price-cell .price-yen, .sale-price-table .price-number, .sale-price-table .price-yen { color: inherit; }
.price-yen { margin-left: 1px; font-size: 0.72em; line-height: 1; }
.table-regular-price .price-yen { color: inherit; font-size: 0.78em; }
.sale-price-table .price-yen { font-size: 0.68em; }
.price-cell small { color: var(--muted); font-weight: 700; }
.price-cell .savings-line { display: inline-flex; align-items: baseline; justify-content: flex-end; gap: 2px; max-width: 100%; color: var(--body-text); font-size: 13px; line-height: 1.35; white-space: nowrap; }
.price-cell .savings-line span { color: var(--body-text); font-size: 13px; line-height: 1.35; }
.price-row div:last-child .savings-line strong { color: var(--offer-red); font-size: 16px; line-height: 1.2; }
.price-row-coupon small { color: var(--body-text); font-weight: 700; }
.price-row-popular, .price-row-soft { background: #fff9f2; }
.popular-badge { width: max-content; display: inline-flex; align-items: center; min-height: 26px; padding: 3px 9px; border-radius: 999px; background: var(--lamp); color: white !important; font-size: 12px !important; font-weight: 900; line-height: 1.25 !important; box-shadow: 0 3px 8px rgba(216, 139, 57, 0.18); }
.coupon-price-line { display: flex !important; align-items: baseline; justify-content: flex-end; gap: 3px; white-space: nowrap; }
.coupon-regular-price { color: var(--muted); font-size: 13px; font-weight: 700; font-variant-numeric: tabular-nums; }
.coupon-price-line .regular-number::after { height: 1.5px; }
.price-row-coupon .coupon-price { font-size: 24px; }
.price-cell-offer { gap: 5px; align-content: center; }
.table-regular-label { width: 100%; max-width: 100%; justify-self: stretch; color: var(--muted); font-size: 11px; line-height: 1.45; text-align: right; overflow-wrap: anywhere; }
.offer-price-line { display: flex !important; align-items: baseline; justify-content: flex-end; gap: 3px; white-space: nowrap; }
.table-regular-price { display: inline-flex; align-items: baseline; width: max-content; color: var(--clinic-blue-dark); font-size: clamp(16px, 4.4vw, 22px); font-weight: 700; line-height: 1.15; text-decoration: none; font-variant-numeric: tabular-nums; }
.offer-price-line .regular-number::after { height: 2px; }
.offer-price-arrow { color: var(--muted); font-size: 12px; font-weight: 700; }
.price-table-badge { margin-top: 1px; justify-self: end; font-size: 12px; }
.price-row div:last-child .sale-price-table { font-size: clamp(24px, 6.4vw, 32px); }
.price-note { margin-top: 20px; padding: 18px; border-left: 4px solid #6f8a72; background: var(--safe); }
.price-note p { margin: 0 0 16px; color: var(--muted); }
.price-note .inline-actions { grid-template-columns: 1fr; gap: 8px; }
.price-note .microcopy { margin: -2px 0 2px; }
.detail-list { margin-top: 0; }
.info-panel { padding: 24px; border: 1px solid var(--line); border-radius: 14px; background: var(--white); }
.info-panel h3 { margin-bottom: 8px; }
.info-panel p { color: var(--body-text); }

.director-grid, .access-grid { display: grid; gap: 36px; align-items: center; }
.director figure, .access figure { margin: 0; }
.director figure { max-width: 420px; }
.director figure img { width: 100%; border-radius: 22px; object-fit: cover; object-position: center top; box-shadow: var(--shadow); }
.director .eyebrow { margin-bottom: 18px; color: var(--ink); font-family: var(--font-display); font-size: clamp(31px, 7.8vw, 42px); font-weight: 700; line-height: 1.45; letter-spacing: 0.02em; }
.director-name { display: flex; flex-wrap: wrap; align-items: baseline; gap: 8px 16px; }
.director-name strong { font-size: 22px; }
.director-name span { color: var(--muted); font-size: 14px; }
blockquote { max-width: 760px; margin: 28px 0; padding: 18px 0 18px 20px; border-left: 4px solid var(--lamp); color: #5f4638; font-family: var(--font-display); font-size: clamp(22px, 6vw, 30px); line-height: 1.65; }
blockquote span { display: block; }
.split-heading { display: grid; gap: 24px; }
.split-heading .button { margin-top: 12px; }
.access figure img { border-radius: 14px; box-shadow: var(--shadow); }
.access-page figure { margin: 0; }
.access-page .access-grid figure { width: min(100%, 620px); }
.access-overview-grid { display: grid; gap: 28px; align-items: start; }
.access-overview-photo img { width: 100%; aspect-ratio: 4 / 3; object-fit: cover; object-position: center; border-radius: 14px; box-shadow: var(--shadow); }
.access-hours-card h2 { margin-bottom: 18px; }
.access-route-copy h2 { font-size: clamp(30px, 7.6vw, 42px); line-height: 1.35; }
.access-route-copy p { margin-top: 18px; }
.business-list { margin: 24px 0; }
.business-list div { display: grid; grid-template-columns: 84px 1fr; gap: 14px; padding: 12px 0; border-top: 1px solid var(--line); }
.business-list div:last-child { border-bottom: 1px solid var(--line); }
.business-list dt { color: var(--muted); font-size: 14px; }
.business-list dd { margin: 0; }
.inline-actions { display: grid; gap: 14px; align-items: center; }

.faq-list { border-top: 1px solid var(--line); }
.faq-list details { border-bottom: 1px solid var(--line); }
.faq-list summary { position: relative; cursor: pointer; padding: 20px 44px 20px 0; font-weight: 700; list-style: none; }
.faq-list summary::-webkit-details-marker { display: none; }
.faq-list summary::after { content: "+"; position: absolute; right: 8px; top: 16px; color: var(--clinic-blue); font-size: 25px; font-weight: 400; }
.faq-list details[open] summary::after { content: "−"; }
.faq-list details p { margin: -4px 0 22px; color: var(--muted); }

.review-showcase,
.before-after-showcase { display: grid; gap: 24px; }
.review-showcase .section-heading,
.before-after-showcase .section-heading { max-width: 760px; margin-bottom: 0; }
.review-photo { width: 100%; margin: 0; overflow: hidden; border-radius: 16px; background: var(--white); box-shadow: var(--shadow); }
.review-photo img { width: 100%; aspect-ratio: 4 / 3; object-fit: cover; object-position: center; }
.before-after-list { display: grid; gap: 18px; }
.before-after-grid { display: grid; gap: 18px; }
.before-after-card { overflow: hidden; border: 1px solid var(--line); border-radius: 8px; background: var(--white); box-shadow: 0 10px 28px rgba(32, 40, 35, 0.07); }
.before-after-images { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 1px; background: var(--line); }
.before-after-images figure { position: relative; margin: 0; min-width: 0; overflow: hidden; background: var(--wash); }
.before-after-images img { width: 100%; aspect-ratio: 3 / 3.55; object-fit: cover; object-position: center; }
.before-after-images span { position: absolute; top: 8px; left: 8px; z-index: 2; min-height: 26px; display: inline-flex; align-items: center; padding: 3px 9px; border-radius: 999px; background: rgba(255, 253, 248, 0.92); color: var(--clinic-blue-dark); font-size: 12px; font-weight: 900; line-height: 1.2; box-shadow: 0 3px 10px rgba(32, 40, 35, 0.12); }
.before-after-copy { padding: 16px; }
.before-after-copy h3 { margin-bottom: 4px; font-size: 19px; }
.before-after-copy p { margin: 0; color: var(--body-text); font-size: 14px; line-height: 1.75; }
.review-action { max-width: 720px; display: grid; gap: 12px; }
.review-action p { margin: 0; color: var(--muted); }
.review-action .button { justify-self: start; }
.review-action .microcopy { margin-top: 0; }

.final-cta { padding: 76px 0 90px; background: var(--clinic-blue-dark); color: white; text-align: center; }
.final-cta .eyebrow { color: #dce9f3; }
.final-cta p { color: #edf3f7; }
.compact-final-cta { padding-top: 50px; padding-bottom: 78px; }
.compact-final-title { margin-bottom: 16px; color: white; font-size: clamp(29px, 7.4vw, 38px); }
.compact-final-cta p { max-width: 620px; margin: 0 auto; }
.final-cta-mobile-break { display: none; }
.compact-final-cta .final-actions { margin-top: 20px; }
.final-actions { margin-top: 30px; display: grid; gap: 18px; }
.final-actions > div { display: grid; gap: 6px; }
.final-actions span { color: #dce9f3; font-size: 12px; }
.site-footer { padding: 48px 0 220px; background: #17201b; color: #dce2dd; }
.footer-grid { display: grid; gap: 24px; }
.site-footer strong { color: white; font-family: var(--font-display); font-size: 20px; }
.site-footer p { margin: 6px 0 0; color: #aeb9b1; font-size: 13px; }
.footer-phone { color: #f7fbf8; font-size: 14px; font-weight: 700; font-variant-numeric: tabular-nums; text-underline-offset: 4px; }
.site-footer nav { display: flex; flex-wrap: wrap; gap: 12px 22px; }
.site-footer nav a { color: white; font-size: 14px; }
.footer-note { grid-column: 1 / -1; }

.mobile-booking-bar { position: fixed; z-index: 60; right: 0; bottom: 0; left: 0; display: grid; grid-template-columns: 44% 56%; grid-template-rows: auto 1fr; gap: 8px; min-height: calc(116px + env(safe-area-inset-bottom)); padding: 8px 10px calc(8px + env(safe-area-inset-bottom)); background: rgba(255, 253, 248, 0.98); box-shadow: 0 -10px 30px rgba(32,40,35,.18); }
.mobile-booking-offer { grid-column: 1 / -1; min-height: 40px; display: flex; align-items: center; justify-content: center; gap: 8px; padding: 6px 10px; border: 1px solid #f0b9bd; border-radius: 10px; background: #fff5f6; color: var(--ink); font-size: 13px; line-height: 1.3; text-align: center; }
.mobile-offer-badge { flex: 0 0 auto; padding: 3px 9px; border-radius: 999px; background: var(--offer-red); color: white; font-size: 14px; font-weight: 900; line-height: 1.25; box-shadow: 0 3px 8px rgba(179, 38, 30, 0.18); }
.mobile-offer-price { min-width: 0; color: var(--clinic-blue-dark); font-weight: 700; font-variant-numeric: tabular-nums; white-space: nowrap; }
.mobile-offer-price .regular-number { margin-inline: 2px; }
.mobile-offer-price .regular-number::after { height: 1.5px; top: 52%; background: rgba(179, 38, 30, 0.82); }
.mobile-offer-price strong { color: var(--offer-red); font-size: 17px; white-space: nowrap; }
.mobile-booking-bar a { display: grid; place-items: center; min-height: 52px; padding: 12px 8px; border-radius: 10px; color: white; font-size: 15px; font-weight: 800; line-height: 1.2; text-align: center; text-decoration: none; box-shadow: 0 6px 14px rgba(32,40,35,.18); }
.mobile-booking-bar .mobile-call { display: flex !important; align-items: center; justify-content: center; gap: 5px; background: #2f6f5e; font-size: 14px; }
.mobile-call::before { content: "☎"; font-size: 16px; line-height: 1; transform: translateY(-1px); }
.mobile-book { display: flex !important; align-items: center; justify-content: center; gap: 6px; background: #3b82bd; }
.mobile-book::before { content: ""; width: 23px; height: 23px; flex: 0 0 23px; background: center / contain no-repeat url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 28 28' fill='none'%3E%3Crect x='4' y='5.5' width='20' height='18.5' rx='3' stroke='%23fff' stroke-width='2.5'/%3E%3Cpath d='M4 11h20M9 3.8v4M19 3.8v4' stroke='%23fff' stroke-width='2.5' stroke-linecap='round'/%3E%3Cpath d='m10 17 3 3 5-6' stroke='%23fff' stroke-width='2.6' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E"); transform: translateY(-1px); }
.mobile-booking-bar a:active { transform: translateY(1px); box-shadow: 0 3px 8px rgba(32,40,35,.18); }

@media (min-width: 720px) {
  .section { padding: 92px 0; }
  .section-compact { padding: 48px 0 62px; }
  .hero-cover-section { padding-top: 34px; }
  .hero-cover-layout { width: min(1000px, calc(100% - 24px)); gap: 18px; }
  .hero-cover { border-radius: 24px; }
  .hero-cover-copy { padding-top: 2px; }
  .hero-cover-copy h1 { font-size: 36px; line-height: 1.32; }
  .hero-cover-copy p { font-size: 17px; line-height: 1.85; }
  .hero-actions { max-width: 560px; margin-inline: auto; }
  #first-visit { padding-top: 72px; padding-bottom: 76px; }
  #first-visit .narrow { width: min(1040px, calc(100% - 40px)); display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1.05fr); column-gap: 28px; align-items: stretch; }
  #first-visit .section-heading { grid-column: 1 / -1; margin-bottom: 22px; }
  #first-visit .section-label-title { white-space: nowrap; }
  #first-visit .section-label-title br { display: none; }
  #first-visit .concern-illustration { grid-column: 1; align-self: stretch; max-width: none; margin: 0; }
  #first-visit .concern-illustration img { height: 100%; object-fit: cover; object-position: center; }
  #first-visit .concern-list { grid-column: 2; align-self: stretch; }
  #first-visit .concern-list li { display: flex; align-items: center; }
  #first-visit .concern-closing { grid-column: 1 / -1; justify-self: center; width: min(1040px, 100%); margin: 26px 0 0; text-align: left; }
  #first-visit .concern-closing + .section-action { grid-column: 1 / -1; justify-self: center; margin-top: 18px; }
  .hero-grid { grid-template-columns: 1.05fr .95fr; align-items: center; gap: 54px; }
  .hero-visual { order: 2; border-radius: 24px; }
  .hero-copy { order: 1; }
  .hero-visual img { height: 520px; object-position: 62% center; }
  .fact-grid { grid-template-columns: repeat(4, 1fr); }
  .fact-grid div { min-height: 126px; border-right: 1px solid var(--line); border-bottom: 0; padding-inline: 20px; }
  .fact-grid div:last-child { border-right: 0; }
  .first-visit-intro { padding: 70px 0 38px; }
  .first-visit-intro .narrow { max-width: 920px; }
  .first-visit-intro .page-label-title { margin-bottom: 20px; font-size: clamp(52px, 5vw, 64px); }
  .first-visit-intro .first-visit-lead { font-size: 18px; line-height: 1.95; }
  .first-policy-section { padding-top: 56px; }
  .profile-hero { padding-top: 66px; padding-bottom: 58px; }
  .profile-hero-grid { grid-template-columns: minmax(0, .95fr) minmax(300px, .72fr); gap: 44px; }
  .profile-hero-copy { align-self: center; padding-left: clamp(8px, 2vw, 24px); }
  .profile-hero .profile-main-title { font-size: clamp(48px, 4.8vw, 60px); }
  .profile-hero-lead { font-size: 17px; line-height: 1.95; }
  .profile-hero figure { justify-self: end; }
  .profile-hero .profile-greeting-photo { width: min(100%, 360px); }
  .principle-grid { grid-template-columns: repeat(3, 1fr); gap: 36px; }
  .recommend-grid { grid-template-columns: 1fr .86fr; gap: 64px; }
  .flow-cards { grid-template-columns: 1fr; gap: 20px; }
  .flow-cards li { grid-template-columns: minmax(280px, 420px) minmax(0, 1fr); align-items: stretch; }
  .flow-cards figure { height: 240px; min-height: 0; }
  .flow-cards img { height: 100%; aspect-ratio: auto; }
  .price-section { padding-block: 52px 44px; }
  .price-section + .access { padding-top: 52px; }
  .price-panel { grid-template-columns: minmax(220px, .85fr) minmax(330px, 1fr); align-items: center; column-gap: 32px; row-gap: 18px; padding-block: 24px; }
  .price-panel h2 { white-space: nowrap; }
  .price-panel > div:first-child { justify-self: center; text-align: center; }
  .price-panel .price-block { justify-self: center; align-items: center; text-align: center; }
  .price-action { grid-column: 1 / -1; grid-template-columns: minmax(280px, 1fr) minmax(280px, 1fr); align-items: start; gap: 10px 18px; width: min(100%, 920px); justify-self: center; }
  .price-primary-action .button,
  .price-phone-action .button { min-height: 58px; display: inline-flex; align-items: center; justify-content: center; }
  .price-primary-action .text-link { justify-self: center; }
  .price-phone-action { padding: 0; border: 0; background: transparent; border-radius: 0; gap: 8px; justify-items: stretch; }
  .price-phone-action .button { order: -1; }
  .price-phone-action span,
  .price-phone-number { justify-self: center; text-align: center; }
  .price-phone-number { font-size: 22px; }
  .access-price-layout { max-width: 920px; }
  .access-price-layout .section-heading { margin-bottom: 26px; }
  .access-price-layout .standard-price-card { display: grid; grid-template-columns: minmax(140px, .62fr) repeat(2, minmax(0, 1fr)); gap: 0; align-items: stretch; margin-bottom: 16px; padding: 0; }
  .access-price-layout .standard-price-title { display: grid; place-items: center; margin: 0; padding: 22px 20px; border-right: 1px solid var(--line); color: var(--clinic-blue-dark); font-size: 20px; white-space: nowrap; }
  .access-price-layout .standard-price-list { display: contents; }
  .access-price-layout .standard-price-list div { display: grid; grid-template-columns: 1fr; justify-items: center; align-content: center; gap: 8px; min-width: 0; min-height: 104px; padding: 20px 28px; border-top: 0; white-space: nowrap; }
  .access-price-layout .standard-price-list div + div { border-left: 1px solid var(--line); }
  .access-price-layout .standard-price-list dt { font-size: 15px; line-height: 1.35; }
  .access-price-layout .standard-price-list dd { font-size: 30px; line-height: 1.1; letter-spacing: 0; }
  .price-row { grid-template-columns: minmax(140px, .62fr) minmax(0, 1fr) minmax(0, 1fr); align-items: stretch; gap: 0; padding: 0; }
  .price-row-head { display: grid; }
  .price-row > div { min-height: 96px; padding: 18px 20px; align-content: center; justify-items: center; text-align: center; }
  .price-row > div + div { border-left: 1px solid var(--line); }
  .price-row .price-plan-note { display: none; }
  .price-row .price-detail-cell { align-content: center; justify-items: center; }
  .price-row .price-plan-cell span { font-size: 15px; white-space: nowrap; }
  .price-row .price-row-spacer { display: block; }
  .price-row .price-cell { grid-column: 3; }
  .price-row div:nth-child(2) { grid-column: auto; order: 0; }
  .price-row div:last-child { justify-items: center; text-align: center; }
  .price-note { display: grid; grid-template-columns: 1fr auto; gap: 22px; align-items: center; }
  .price-note p { margin: 0; }
  .director-grid { grid-template-columns: minmax(280px, .75fr) 1.25fr; gap: 72px; }
  .split-heading { grid-template-columns: .8fr 1.2fr; gap: 72px; align-items: start; }
  .reservation-layout { max-width: 1040px; grid-template-columns: 1fr; gap: 28px; }
  .reservation-layout .reservation-boxes { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 20px; }
  .reservation-layout .reservation-boxes article { display: flex; min-height: 0; flex-direction: column; align-items: flex-start; padding: 26px; }
  .reservation-layout .reservation-boxes p { margin-bottom: 4px; }
  .reservation-layout .reservation-actions { display: flex; flex-wrap: wrap; gap: 10px 14px; align-items: center; margin-top: 14px; }
  .reservation-layout .reservation-actions .button,
  .reservation-layout .reservation-actions .text-link { margin-top: 0; }
  .reservation-layout .reservation-boxes article:first-child .button-outline { background: var(--clinic-blue-dark); color: white; }
  .reservation-layout .reservation-boxes article:first-child .button-outline:hover { background: var(--clinic-blue); }
  .access-grid { grid-template-columns: 1fr 1fr; gap: 64px; }
  .access-overview-grid { grid-template-columns: minmax(280px, .95fr) minmax(240px, .8fr) minmax(280px, .9fr); gap: 32px; align-items: center; }
  .access-overview-photo img { min-height: 260px; }
  .access-hours-card h2 { margin-bottom: 16px; font-size: clamp(32px, 3.2vw, 42px); }
  .access-hours-card .business-list { margin: 0; }
  .access-hours-card .business-list div { grid-template-columns: 78px 1fr; gap: 10px; padding: 11px 0; }
  .access-hours-card .business-list dt { font-size: 13px; }
  .access-hours-card .business-list dd { font-size: 14px; line-height: 1.6; }
  .access-route-copy h2 { font-size: clamp(28px, 3vw, 36px); line-height: 1.42; }
  .access-route-copy .inline-actions { grid-template-columns: 1fr; justify-items: start; }
  .inline-actions { grid-template-columns: auto 1fr; }
  .before-after-list,
  .before-after-grid { gap: 20px; }
  .before-after-showcase .before-after-grid { grid-template-columns: 1fr; }
  .before-after-card {
    display: grid;
    grid-template-columns: minmax(0, 1.15fr) minmax(280px, .85fr);
    align-items: stretch;
  }
  .before-after-images,
  .before-after-images figure { min-height: 100%; }
  .before-after-images img {
    height: 100%;
    min-height: 280px;
    max-height: 360px;
    aspect-ratio: auto;
    object-fit: cover;
  }
  .before-after-copy { display: grid; align-content: center; padding: 26px 28px; }
  .before-after-copy h3 { font-size: 20px; }
  .before-after-copy p { font-size: 16px; line-height: 1.75; }
  .final-actions { grid-template-columns: 1fr 1fr; }
  .footer-grid { grid-template-columns: 1fr auto; align-items: start; }
}

@media (min-width: 960px) {
  .desktop-nav { display: flex; }
  .mobile-menu { display: none; }
  .brand { transform: none; }
  .brand-name { font-size: 22px; }
  .mobile-booking-bar { display: none; }
  .site-footer { padding-bottom: 48px; }
  #first-visit .concern-list li { padding: 10px 18px 10px 48px; font-size: 16px; line-height: 1.65; }
  #first-visit .concern-list li br { display: none; }
  #first-visit .concern-list li::before { left: 16px; }
  #first-visit .concern-list li::after { left: 20px; }
}

@media (max-width: 719px) {
  body { padding-bottom: calc(116px + env(safe-area-inset-bottom)); }
  .section { padding: 56px 0; }
  .section-heading { margin-bottom: 28px; }
  .annai-page .section-label-title { font-size: clamp(26px, 6.9vw, 29px); }
  .first-visit-intro { padding: 44px 0 14px; }
  .first-visit-intro .page-label-title { margin-bottom: 0; font-size: clamp(38px, 11vw, 48px); }
  .first-visit-intro .first-visit-lead { display: none; }
  .first-policy-section { padding-top: 30px; }
  .profile-hero { padding-bottom: 22px; }
  .profile-hero-lead,
  .profile-hero-name { display: none; }
  .profile-greeting-section { padding-top: 28px; }
  .profile-greeting-copy,
  .profile-greeting-copy p { min-width: 0; max-width: 100%; overflow-wrap: anywhere; }
  .price-row { grid-template-columns: minmax(0, 1fr) auto; gap: 7px 14px; padding: 16px; }
  .price-row .price-plan-cell { grid-column: 1; grid-row: 1; }
  .price-row div:nth-child(2) { grid-column: 1; grid-row: 2; order: 0; }
  .price-row div:last-child { grid-column: 2; grid-row: 1 / span 2; align-self: center; justify-items: end; text-align: right; }
  .price-row .price-row-spacer { display: none; }
  .price-row .price-plan-cell span { white-space: normal; }
  .offer-price-line,
  .coupon-price-line { justify-content: flex-end; flex-wrap: nowrap; white-space: nowrap; }
  .price-table-badge { justify-self: start; }
  .price-row-compact { grid-template-columns: minmax(0, 1fr) auto; align-items: center; }
  .price-row-compact div:first-child { grid-column: 1; grid-row: 1; align-self: end; }
  .price-row-compact div:nth-child(2) { grid-column: 1; grid-row: 2; order: 0; }
  .price-row-compact div:last-child { grid-column: 2; grid-row: 1 / span 2; align-self: center; }
  .principle-grid { gap: 20px; }
  .principle-grid article { padding-top: 18px; }
  .principle-photo { margin-bottom: 14px; }
  .principle-photo img { aspect-ratio: 16 / 9; }
  .concern-list { margin-bottom: 18px; }
  .concern-closing { margin-top: 0; margin-bottom: 28px; padding: 16px 16px 18px; font-size: 14.25px; line-height: 1.9; }
  .concern-closing .mobile-break { display: inline; }
  .concern-closing .desktop-break { display: none; }
  .safety-note { margin-bottom: 26px; padding: 18px; }
  .profile-hero .profile-greeting-photo { width: 100%; max-width: none; justify-self: stretch; }
  .profile-hero .profile-greeting-photo img { aspect-ratio: auto; object-fit: contain; object-position: center; }
  .profile-hero figure { width: min(100%, 320px); }
  .profile-hero figure img { aspect-ratio: 4 / 3; }
  .director figure img { aspect-ratio: 4 / 3; }
  .access figure img { aspect-ratio: 16 / 10; object-fit: cover; }
  .access-page .access-grid { width: calc(100% - 24px); }
  .access-page .access-grid figure { width: 100%; }
  .access-page .access-grid figure img { width: 100%; aspect-ratio: 4 / 3; border-radius: 14px; }
  .before-after-list { gap: 16px; }
  .before-after-grid { gap: 16px; }
  .before-after-copy { padding: 14px; }
  .review-action .button { width: 100%; }
  blockquote { margin: 22px 0; padding-left: 16px; font-size: 20px; line-height: 1.7; }
}

@media (max-width: 430px) {
  .header-inner { gap: 8px; }
  .brand { flex: 1 1 auto; max-width: calc(100% - 104px); }
  .brand-name { display: block; max-width: 100%; overflow: hidden; font-size: 22px; text-overflow: clip; }
  .brand-note { display: none; }
  .mobile-menu { flex: 0 0 auto; }
  .mobile-booking-offer { gap: 4px; padding-inline: 6px; }
  .mobile-offer-badge { padding-inline: 7px; font-size: 13px; }
  .mobile-offer-price { font-size: 11px; }
  .mobile-offer-price strong { font-size: 15px; }
  .compact-final-cta p { max-width: 320px; font-size: 15px; line-height: 1.9; }
  .final-cta-mobile-break { display: block; }
}

@media (max-width: 360px) {
  .container, .narrow { width: min(100% - 32px, 1120px); }
  .header-inner { width: calc(100% - 24px); }
  .brand-name { font-size: 20px; }
  .mobile-menu summary { min-height: 44px; padding: 9px 10px; font-size: 14px; }
  .brand-note { display: none; }
  .mobile-booking-offer { flex-wrap: wrap; gap: 2px 4px; padding-inline: 6px; }
  .mobile-offer-badge { padding-inline: 6px; font-size: 12px; }
  .mobile-offer-price { font-size: 10px; }
  .mobile-offer-price strong { font-size: 14px; }
  .mobile-booking-bar .mobile-call { gap: 3px; font-size: 13px; }
  .mobile-call::before { font-size: 14px; }
  .mobile-book { gap: 4px; font-size: 14px; }
  .mobile-book::before { width: 21px; height: 21px; flex-basis: 21px; }
  h1 { font-size: 27px; }
  .fact-grid strong { font-size: 14px; }
}

@media (max-width: 340px) {
  .hero-cover-copy h1 { font-size: 20px; }
  .mobile-booking-offer { gap: 3px; padding-inline: 5px; }
  .mobile-offer-badge { padding-inline: 6px; font-size: 12px; }
  .mobile-offer-price { font-size: 11px; }
  .mobile-offer-price strong { font-size: 15px; }
}

.price-row-offer { align-items: center; }
.price-row-offer .price-plan-cell { align-self: center; }
.price-row-offer .price-detail-cell { justify-items: start; }
.price-row-offer .price-cell-offer { justify-items: start; text-align: left; }
.price-row-offer .price-table-badge {
  margin: 0 0 2px;
  justify-self: start;
  min-height: 34px;
  padding: 5px 13px;
  border-color: var(--offer-red);
  background: var(--offer-red);
  color: white;
  font-size: 15px;
  box-shadow: 0 5px 14px rgba(179, 38, 30, 0.2);
}
.price-row-offer .table-regular-price { font-size: clamp(18px, 4.8vw, 24px); }
.price-row-offer div:last-child .sale-price-table {
  color: var(--offer-red);
  font-size: clamp(38px, 11vw, 52px);
  line-height: 1.05;
}

@media (min-width: 720px) {
  .price-row-offer .price-plan-cell { grid-column: 1; grid-row: 1; }
  .price-row-offer .price-detail-cell { grid-column: 2; grid-row: 1; }
  .price-row-offer .price-cell { grid-column: 3; grid-row: 1; }
  .price-row-offer .price-table-badge { justify-self: center; }
  .price-row-offer .price-cell-offer { justify-items: center; text-align: center; }
  .price-row-offer .offer-price-line { justify-content: center; }
  .price-row-coupon .price-detail-cell { grid-template-columns: auto auto; align-items: center; justify-content: center; gap: 10px; }
  .price-cell .savings-line { justify-content: center; }
}

@media (max-width: 719px) {
  .price-row.price-row-offer {
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 10px 12px;
  }
  .price-row.price-row-offer > .price-plan-cell {
    grid-column: 1;
    grid-row: 1;
    align-self: center;
  }
  .price-row.price-row-offer > .price-plan-cell strong {
    white-space: nowrap;
  }
  .price-row.price-row-offer > .price-detail-cell {
    grid-column: 2;
    grid-row: 1;
    align-self: center;
    order: 0;
  }
  .price-row.price-row-offer > .price-cell.price-cell-offer {
    grid-column: 1 / -1;
    grid-row: 2;
    justify-self: stretch;
    justify-items: stretch;
    text-align: left;
  }
  .price-row-offer .price-table-badge {
    min-height: 32px;
    padding-inline: 10px;
    font-size: 14px;
    white-space: nowrap;
  }
  .price-row-offer .offer-price-line {
    width: 100%;
    justify-content: flex-end;
    align-items: baseline;
    flex-wrap: nowrap;
    gap: 5px;
    white-space: nowrap;
  }
  .price-row-offer .table-regular-price {
    flex: 0 0 auto;
    font-size: clamp(18px, 5vw, 21px);
  }
  .price-row-offer .offer-price-arrow {
    flex: 0 0 auto;
    font-size: 14px;
  }
  .price-row-offer .sale-price-table {
    flex: 0 1 auto;
    min-width: 0;
    white-space: nowrap;
  }
  .price-row-offer div:last-child .sale-price-table { font-size: clamp(36px, 10.8vw, 42px); }
  .price-table .price-row:not(.price-row-head):not(.price-row-offer) {
    grid-template-columns: minmax(0, 1fr) clamp(146px, 42vw, 160px);
    gap: 8px 12px;
    min-height: 112px;
    padding: 18px 16px;
  }
  .price-table .price-row:not(.price-row-head):not(.price-row-offer) > .price-plan-cell {
    grid-column: 1;
    grid-row: 1;
    align-self: end;
    gap: 2px;
    min-width: 0;
  }
  .price-table .price-row:not(.price-row-head):not(.price-row-offer) > .price-detail-cell {
    grid-column: 1;
    grid-row: 2;
    align-self: start;
    min-width: 0;
    order: 0;
  }
  .price-table .price-row:not(.price-row-head):not(.price-row-offer) > .price-cell {
    grid-column: 2;
    grid-row: 1 / span 2;
    align-self: center;
    justify-self: stretch;
    justify-items: end;
    gap: 3px;
    text-align: right;
  }
  .price-cell .savings-line {
    justify-content: flex-end;
    font-size: clamp(12px, 3.3vw, 13px);
  }
  .price-cell .savings-line span {
    font-size: clamp(12px, 3.3vw, 13px);
  }
  .price-row div:last-child .savings-line strong {
    font-size: clamp(15px, 4.1vw, 16px);
  }
  .price-table .price-row.price-row-popular.price-row-coupon {
    grid-template-columns: minmax(0, 1fr) clamp(146px, 42vw, 160px);
    gap: 8px 14px;
  }
  .price-table .price-row.price-row-popular.price-row-coupon > .price-plan-cell {
    grid-column: 1;
    grid-row: 1 / span 2;
    align-self: center;
  }
  .price-table .price-row.price-row-popular.price-row-coupon > .price-detail-cell {
    grid-column: 2;
    grid-row: 1;
    align-self: center;
    justify-items: end;
    order: 0;
  }
  .price-table .price-row.price-row-popular.price-row-coupon .price-detail-note {
    display: none;
  }
  .price-table .price-row.price-row-popular.price-row-coupon > .price-cell {
    grid-column: 2;
    grid-row: 2;
    align-self: center;
    justify-self: stretch;
    justify-items: end;
    text-align: right;
  }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { transition: none !important; }
}
