.bp-page {
--bt-sns-unit-width: 1032px;
--bt-serif     : "Shippori Mincho", "Yu Mincho", "YuMincho", "Hiragino Mincho ProN", serif;
--bt-noto-serif: "Noto Serif JP", "Yu Mincho", "YuMincho", serif;
--bt-cormorant : "Cormorant Garamond", "Times New Roman", serif;
--bt-sans      : "Noto Sans JP", -apple-system, "Hiragino Kaku Gothic ProN", "Yu Gothic", sans-serif;
--bt-gold-dk   : #8c7b64;
--bp-ink      : #2a2620;
--bp-soft     : #6d6458;
--bp-gold     : #b99e74;
--bp-gold-dark: #8c7b64;
--bp-line     : #ded6c7;
--bp-paper    : #faf7f2;
--bp-white    : #fff;
--bp-serif    : "Shippori Mincho", "Yu Mincho", "YuMincho", "Hiragino Mincho ProN", serif;
--bp-display  : "Cormorant Garamond", "Times New Roman", serif;
--bp-sans     : "Noto Sans JP", "Hiragino Kaku Gothic ProN", "Yu Gothic", Meiryo, sans-serif;
background: var(--bp-paper);
color: var(--bp-ink);
font-family: var(--bp-sans);
-webkit-font-smoothing: antialiased;
font-feature-settings: "palt";
}
.bp-page *, .bp-page *::before, .bp-page *::after { box-sizing: border-box; }
.bp-container {
width: 90%;
max-width: 1180px;
margin: 0 auto;
} .bp-hero {
position: relative;
margin-top: 0;
min-height: 250px;
display: flex;
align-items: center;
overflow: hidden;
background:
linear-gradient(90deg, rgba(250, 247, 242, .98) 0%, rgba(250, 247, 242, .92) 42%, rgba(250, 247, 242, .72) 100%),
url(//umekitaclinic.org/wp-content/uploads/2026/05/beauty-hero-slide5.jpg);
background-position: center 42%;
background-size: cover;
border-bottom: 1px solid rgba(222, 214, 199, .9);
}
.bp-hero::before {
content: "";
position: absolute;
inset: auto 0 0;
height: 1px;
background: linear-gradient(90deg, transparent, rgba(185, 158, 116, .72), transparent);
}
.bp-hero__content {
width: min(100%, 720px);
padding: 46px 0 18px;
}
.bp-hero__eyebrow {
margin: 0 0 14px;
color: var(--bp-gold-dark);
font-size: 13px;
font-weight: 700;
letter-spacing: .24em;
}
.bp-hero__title {
display: inline-block;
margin: 0;
font-family: var(--bp-serif);
font-size: clamp(34px, 4vw, 52px);
font-weight: 600;
line-height: 1.2;
letter-spacing: .12em;
color: var(--bp-ink);
}
.bp-hero__en {
display: inline-block;
margin: 0 0 0 22px;
color: #9b8d75;
font-family: var(--bp-display);
font-size: clamp(18px, 2vw, 26px);
font-weight: 500;
letter-spacing: .28em;
vertical-align: baseline;
}
.bp-hero .bp-breadcrumb {
margin: 26px 0 30px;
} .bp-tools {
position: relative;
z-index: 2;
margin-top: 0;
background: rgba(250, 247, 242, .98);
border-bottom: 1px solid rgba(222, 214, 199, .8);
padding: 28px 0 24px;
font-family: var(--bp-sans);
}
.bp-tools__inner {
display: flex;
flex-direction: column;
gap: 14px;
}
.bp-breadcrumb {
display: flex;
flex-wrap: wrap;
gap: 9px;
margin: 30px 0 0;
color: #7d746a;
font-size: 11px;
line-height: 1.7;
letter-spacing: 0;
}
.bp-breadcrumb a,
.bp-breadcrumb span {
color: inherit;
text-decoration: none;
}
.bp-breadcrumb a::after {
content: "/";
margin-left: 9px;
color: #b9ad9c;
} .bp-tools__search-row {
display: flex;
align-items: center;
gap: 20px;
flex-wrap: wrap;
}
.bp-tools__note {
margin: 0;
font-size: 14px;
color: var(--bp-soft);
line-height: 1.6;
letter-spacing: .03em;
} .bp-search {
position: relative;
display: flex;
align-items: center;
}
.bp-search__icon {
position: absolute;
left: 13px;
width: 17px;
height: 17px;
color: var(--bp-gold-dark);
pointer-events: none;
flex-shrink: 0;
}
.bp-search input {
width: 100%;
min-width: 340px;
max-width: 520px;
height: 52px;
border: 1px solid var(--bp-line);
border-radius: 3px;
background: var(--bp-white);
color: var(--bp-ink);
padding: 0 16px 0 40px;
font-family: var(--bp-sans);
font-size: 16px;
outline: none;
transition: border-color .2s, box-shadow .2s;
}
.bp-search input:focus {
border-color: var(--bp-gold);
box-shadow: 0 0 0 3px rgba(185, 158, 116, .14);
}
.bp-search input::placeholder {
color: #bfb5a8;
font-size: 15px;
} .bp-category-nav {
position: relative;
display: grid;
grid-template-columns: repeat(12, minmax(0, 1fr));
gap: 26px 34px;
align-items: start;
padding: 30px 34px 32px;
border: 1px solid rgba(185, 158, 116, .22);
border-radius: 8px;
background: linear-gradient(180deg, rgba(255,255,255,.82), rgba(255,255,255,.58));
box-shadow: 0 18px 44px rgba(58, 45, 30, .06);
font-family: var(--bp-sans);
}
.bp-category-nav__group {
min-width: 0;
padding: 0;
border: 0;
background: transparent;
}
.bp-category-nav__group:nth-child(1) {
grid-column: span 5;
}
.bp-category-nav__group:nth-child(2) {
grid-column: span 3;
}
.bp-category-nav__group:nth-child(3) {
grid-column: span 4;
}
.bp-category-nav__group:nth-child(4) {
grid-column: span 3;
}
.bp-category-nav__group:nth-child(5) {
grid-column: span 9;
}
.bp-category-nav__heading {
display: flex;
align-items: baseline;
gap: 10px;
margin: 0 0 12px;
padding: 0;
border: 0;
color: var(--bp-ink);
font-family: var(--bp-sans);
font-size: 15px;
font-weight: 700;
line-height: 1.45;
letter-spacing: .04em;
white-space: normal;
}
.bp-category-nav__heading span {
display: inline-block;
flex: 0 0 auto;
color: var(--bp-gold);
font-family: var(--bp-display);
font-size: 17px;
font-weight: 600;
letter-spacing: .14em;
}
.bp-category-nav__items {
display: flex;
flex-wrap: wrap;
gap: 9px;
}
.bp-category-nav a {
flex: 0 0 auto;
display: inline-flex;
align-items: center;
justify-content: center;
min-height: 38px;
padding: 0 16px;
border: 1px solid rgba(185, 158, 116, .54);
border-radius: 999px;
background: rgba(255, 255, 255, .72);
color: var(--bp-soft);
font-family: var(--bp-sans);
text-decoration: none;
font-size: 14px;
font-weight: 700;
letter-spacing: .04em;
white-space: nowrap;
box-shadow: 0 8px 18px rgba(58, 45, 30, .035);
transition: background .18s ease, border-color .18s ease, color .18s ease, transform .18s ease, box-shadow .18s ease;
}
.bp-category-nav a:hover,
.bp-category-nav a.is-active {
background: var(--bp-gold-dark);
border-color: var(--bp-gold-dark);
color: var(--bp-white);
box-shadow: 0 12px 22px rgba(140, 123, 100, .16);
transform: translateY(-1px);
} .bp-list {
position: relative;
padding: 64px 0 112px;
} .bp-category {
scroll-margin-top: calc(var(--bth-h-pc, 86px) + 24px);
margin: 0 0 18px;
background: var(--bp-white);
border: 1px solid var(--bp-line);
box-shadow: 0 4px 20px rgba(42, 38, 32, .04);
position: relative;
overflow: hidden;
transition: box-shadow .25s ease;
}
.bp-category:hover {
box-shadow: 0 8px 32px rgba(42, 38, 32, .08);
} .bp-category::before {
content: "";
position: absolute;
left: 0; top: 0; bottom: 0;
width: 4px;
background-color: #9b7d4e;
background-image: linear-gradient(180deg, #d4b06a 0, #9b7d4e 92px);
background-repeat: no-repeat;
opacity: .55;
transition: opacity .25s ease;
pointer-events: none;
}
.bp-category[open]:not(.is-animating)::before,
.bp-category.is-expanded::before,
.bp-category:hover::before { opacity: 1; } .bp-category summary {
min-height: 92px;
padding: 24px 28px 24px 36px;
display: flex;
align-items: center;
justify-content: space-between;
gap: 20px;
cursor: pointer;
list-style: none;
transition: background .2s;
}
.bp-category[open]:not(.is-animating) summary,
.bp-category.is-expanded summary {
background: rgba(250, 247, 242, .55);
border-bottom: 1px solid var(--bp-line);
}
.bp-category summary::-webkit-details-marker { display: none; } .bp-category__title {
display: flex;
flex-direction: column;
gap: 2px;
}
.bp-category__en {
font-family: var(--bp-display);
font-size: 13px;
font-weight: 500;
letter-spacing: .26em;
color: var(--bp-gold-dark);
line-height: 1;
}
.bp-category__ja {
font-family: var(--bp-serif);
font-size: clamp(22px, 2vw, 30px);
font-weight: 600;
letter-spacing: .08em;
color: var(--bp-ink);
line-height: 1.3;
} .bp-category__meta {
display: flex;
align-items: center;
gap: 18px;
flex-shrink: 0;
}
.bp-category__count {
color: var(--bp-soft);
font-size: 13px;
font-weight: 700;
letter-spacing: .1em;
white-space: nowrap;
} .bp-category__toggle {
width: 42px;
height: 42px;
border: 1px solid var(--bp-line);
border-radius: 50%;
display: grid;
place-items: center;
color: var(--bp-gold-dark);
flex-shrink: 0;
transition: background .2s, border-color .2s, color .2s;
position: relative;
}
.bp-category__toggle::before,
.bp-category__toggle::after {
content: "";
position: absolute;
background: currentColor;
border-radius: 1px;
transition: transform .25s ease, opacity .25s ease;
}
.bp-category__toggle::before { width: 13px; height: 1.5px; }
.bp-category__toggle::after  { width: 1.5px; height: 13px; }
.bp-category[open]:not(.is-animating) .bp-category__toggle::after,
.bp-category.is-expanded .bp-category__toggle::after {
transform: rotate(90deg);
opacity: 0;
}
.bp-category[open]:not(.is-animating) .bp-category__toggle,
.bp-category.is-expanded .bp-category__toggle {
background: var(--bp-gold-dark);
border-color: var(--bp-gold-dark);
color: var(--bp-white);
} .bp-table-wrap {
overflow-x: auto;
background: var(--bp-white);
}
.bp-category.is-animating .bp-table-wrap {
overflow: hidden;
}
.bp-category.is-animating summary {
pointer-events: none;
}
.bp-table {
width: 100%;
min-width: 760px;
border-collapse: collapse;
font-family: var(--bp-serif);
font-size: 16px;
}
.bp-table th,
.bp-table td {
padding: 18px 24px;
border-bottom: 1px solid #ede7dc;
text-align: left;
vertical-align: middle;
line-height: 1.85;
} .bp-table thead th {
position: static;
z-index: 1;
background: #4a4035; color: rgba(255, 255, 255, .9);
font-size: 14px;
font-weight: 700;
letter-spacing: .18em;
white-space: nowrap;
} .bp-table tbody tr:last-child th,
.bp-table tbody tr:last-child td { border-bottom: none; }
.bp-table tbody th {
width: 28%;
color: var(--bp-ink);
font-weight: 700;
font-size: 17px;
background: #fdfaf7;
vertical-align: top;
}
.bp-table tbody tr:nth-child(even) th { background: #faf8f4; }
.bp-table tbody td {
color: var(--bp-soft);
font-size: 16px;
} .bp-price {
width: 190px;
color: var(--bp-gold-dark);
font-weight: 800;
font-size: 17px;
white-space: nowrap;
}
.bp-muted { color: #c4bbb1; } .bp-note {
margin: 32px 0 0;
padding: 14px 18px;
font-size: 14px;
line-height: 1.9;
color: var(--bp-soft);
background: rgba(255, 255, 255, .7);
border: 1px solid var(--bp-line);
border-left: 3px solid var(--bp-gold);
}
.bp-empty {
text-align: center;
padding: 60px 0;
color: var(--bp-soft);
font-size: 14px;
} .bp-row-hidden,
.bp-category.is-hidden { display: none; } .bp-cta {
background: var(--bp-ink);
padding: 80px 0 88px;
position: relative;
overflow: hidden;
}
.bp-cta::before {
content: "";
position: absolute;
inset: 0;
background: linear-gradient(135deg, rgba(185, 158, 116, .12) 0%, transparent 55%);
pointer-events: none;
}
.bp-cta__head {
text-align: center;
margin-bottom: 48px;
position: relative;
}
.bp-cta__eyebrow {
margin: 0 0 10px;
font-size: 12px;
font-weight: 700;
letter-spacing: .26em;
color: var(--bp-gold);
}
.bp-cta__title {
margin: 0;
font-family: var(--bp-display);
font-size: clamp(36px, 4.5vw, 56px);
font-weight: 400;
letter-spacing: .12em;
color: var(--bp-white);
line-height: 1;
} .bp-cta__grid {
display: grid;
grid-template-columns: repeat(3, minmax(0, 1fr));
gap: 14px;
position: relative;
}
.bp-cta__item {
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
gap: 8px;
min-height: 108px;
padding: 18px 14px;
border: 1px solid rgba(185, 158, 116, .3);
background: rgba(255, 255, 255, .04);
text-decoration: none;
color: rgba(255, 255, 255, .85);
transition: background .24s ease, border-color .24s ease, color .24s ease, transform .24s ease;
}
.bp-cta__item:hover {
background: var(--bp-gold-dark);
border-color: var(--bp-gold-dark);
color: var(--bp-white);
transform: translateY(-3px);
}
.bp-cta__icon {
width: 34px;
height: 34px;
display: flex;
align-items: center;
justify-content: center;
color: var(--bp-gold);
flex-shrink: 0;
transition: color .24s ease;
}
.bp-cta__icon svg {
display: block;
width: auto;
height: auto;
max-width: 100%;
max-height: 100%;
fill: currentColor;
}
.bp-cta__icon svg * {
fill: currentColor;
}
.bp-cta__item:hover .bp-cta__icon {
color: rgba(255, 255, 255, .9);
}
.bp-cta__en {
font-family: var(--bp-display);
font-size: 11px;
letter-spacing: .2em;
color: var(--bp-gold);
transition: color .24s ease;
}
.bp-cta__item:hover .bp-cta__en {
color: rgba(255, 255, 255, .7);
}
.bp-cta__jp {
font-size: 14px;
font-weight: 700;
letter-spacing: .06em;
line-height: 1.4;
text-align: center;
} @media (max-width: 960px) {
.bp-hero {
margin-top: 0;
min-height: 220px;
}
.bp-tools {
margin-top: 0;
}
.bp-cta__grid {
grid-template-columns: repeat(2, minmax(0, 1fr));
}
} @media (max-width: 640px) {
.bp-container { width: calc(100% - 32px); }
.bp-hero {
min-height: 188px;
}
.bp-hero__content {
padding: 36px 0 18px;
}
.bp-hero .bp-breadcrumb {
margin: 22px 0 24px;
}
.bp-hero__title {
font-size: 30px;
}
.bp-hero__en {
display: block;
margin: 8px 0 0;
font-size: 18px;
}
.bp-tools { padding: 20px 0 18px; }
.bp-tools__search-row { flex-direction: column; align-items: flex-start; gap: 8px; }
.bp-search { width: 100%; }
.bp-search input { min-width: 0; max-width: 100%; width: 100%; }
.bp-category-nav {
display: grid;
grid-template-columns: 1fr;
gap: 12px;
overflow: visible;
margin-inline: 0;
padding: 14px;
}
.bp-category-nav__group {
grid-column: auto !important;
width: 100%;
padding: 0;
}
.bp-category-nav__heading {
margin-bottom: 8px;
font-size: 12px;
line-height: 1.25;
}
.bp-category-nav__heading span {
font-size: 13px;
letter-spacing: .12em;
}
.bp-category-nav__items {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(96px, 1fr));
gap: 6px;
}
.bp-category-nav a {
min-height: 32px;
width: 100%;
padding: 4px 8px;
font-size: 11.5px;
white-space: normal;
text-align: center;
line-height: 1.25;
}
.bp-list { padding: 26px 0 72px; }
.bp-category {
margin-bottom: 12px;
scroll-margin-top: 16px;
border-radius: 4px;
}
.bp-category summary {
min-height: 72px;
padding: 16px 14px 16px 20px;
gap: 10px;
}
.bp-category__en {
font-size: 11px;
letter-spacing: .21em;
}
.bp-category__ja {
font-size: 20px;
letter-spacing: .06em;
}
.bp-category__meta { gap: 10px; }
.bp-category__count {
font-size: 12px;
letter-spacing: .06em;
}
.bp-category__toggle {
width: 36px;
height: 36px;
} .bp-table-wrap { background: #f6f1e9; }
.bp-table {
min-width: 0;
display: block;
}
.bp-table thead { display: none; }
.bp-table tbody,
.bp-table th,
.bp-table td {
display: block;
width: 100%;
}
.bp-table tbody {
padding: 10px;
}
.bp-table tr {
display: grid;
grid-template-columns: 1fr;
padding: 14px 14px 12px;
margin-bottom: 8px;
background: var(--bp-white);
border: 1px solid #e7dece;
border-radius: 4px;
box-shadow: 0 1px 3px rgba(42, 38, 32, .035);
}
.bp-table tr:last-child { margin-bottom: 0; }
.bp-table th,
.bp-table td {
border: 0;
padding: 0;
background: transparent !important;
}
.bp-table td::before {
content: attr(data-label);
display: block;
margin: 10px 0 3px;
font-size: 11px;
font-weight: 700;
letter-spacing: .14em;
color: var(--bp-gold-dark);
}
.bp-table tbody th {
font-size: 16px;
line-height: 1.65;
}
.bp-table tbody td {
font-size: 14px;
line-height: 1.7;
}
.bp-table .bp-price {
display: flex;
justify-content: space-between;
align-items: baseline;
gap: 10px;
margin-top: 11px;
padding-top: 10px;
border-top: 1px solid #eee6d8;
color: var(--bp-gold-dark);
font-size: 18px;
line-height: 1.4;
}
.bp-table .bp-price::before {
flex-shrink: 0;
display: inline-block;
margin: 0;
font-size: 11px;
}
.bp-cta { padding: 56px 0 64px; }
.bp-cta__head { margin-bottom: 32px; }
.bp-cta__grid {
grid-template-columns: repeat(2, minmax(0, 1fr));
gap: 10px;
}
.bp-cta__item { min-height: 88px; }
}
#beauty-price .bt-reserve__btn {
display: flex;
align-items: center;
justify-content: center;
gap: 16px;
width: calc((var(--bt-sns-unit-width) - 20px) / 2);
flex-shrink: 0;
padding: 24px 0;
background: #62A87C;
color: #fff;
font-family: var(--bt-sans);
font-size: 19px;
font-weight: 500;
letter-spacing: .08em;
border: none;
border-radius: 12px;
cursor: pointer;
text-decoration: none;
transition: background .3s ease;
}
#beauty-price .bt-reserve__btn:nth-of-type(2) {
background: #6276A8;
}
#beauty-price .bt-reserve__btn:hover {
filter: brightness(.95);
}
#beauty-price .bt-reserve__title .bt-sec-title__sub {
display: block;
font-family: var(--bt-noto-serif);
font-size: 48px;
font-weight: 500;
line-height: 1.2;
letter-spacing: .09em;
color: rgba(255, 255, 255, .9);
margin-bottom: 0;
}
@media (max-width: 1024px) {
#beauty-price .bt-reserve__btn {
width: calc((90vw - 20px) / 2);
max-width: calc((var(--bt-sns-unit-width) - 20px) / 2);
}
}
@media (max-width: 768px) {
#beauty-price .bt-reserve__title .bt-sec-title__sub {
font-size: 34px;
line-height: 1.25;
letter-spacing: .09em;
}
#beauty-price .bt-reserve__btn {
width: 100%;
flex-shrink: 1;
padding: 20px 0;
border-radius: 10px;
}
}