:root {
  --bg: #fffdfb;
  --cream: #fdf8f5;
  --pink: #f5e4e2;
  --pink-deep: #d99d9c;
  --rose: #c88c8d;
  --ink: #514743;
  --muted: #817470;
  --line: #eadbd7;
  --shadow: 0 15px 42px rgba(139,102,92,.08);
  --serif: "Times New Roman", "Hiragino Mincho ProN", "Yu Mincho", serif;
  --sans: "Helvetica Neue", "Hiragino Kaku Gothic ProN", "Yu Gothic", Arial, sans-serif;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; background: var(--bg); color: var(--ink); font-family: var(--serif); letter-spacing: .08em; }
a { color: inherit; text-decoration: none; transition: opacity .25s ease, background .25s ease; }
a:hover { opacity: .65; }
img { max-width: 100%; display: block; }
p { margin: 0; line-height: 2; }
h1,h2,h3 { margin: 0; font-weight: 400; }
.site-header { height: 80px; display: flex; align-items: center; gap: 40px; padding: 0 clamp(22px,4.1vw,54px); position: absolute; z-index: 5; width: 100%; top: 0; }
.brand { display: flex; flex-direction: column; width: 192px; flex-shrink: 0; }
.brand-script,.footer-logo { font-style: italic; letter-spacing: .08em; font-size: clamp(31px,3vw,38px); line-height: .85; color: #544a46; }
.brand-sub { font: 10px var(--sans); letter-spacing: .43em; margin: 9px 0 0 13px; }
.global-nav { flex: 1; display: flex; justify-content: center; gap: clamp(18px,2.8vw,42px); font-size: 13px; letter-spacing: .15em; }
.header-reserve { height: 80px; min-width: 155px; padding: 0 22px; display: flex; gap: 11px; align-items: center; justify-content: center; background: #e4b0b0; color: #fff; font-size: 15px; letter-spacing: .18em; }
.nav-toggle { display: none; }
.hero { min-height: 590px; background: linear-gradient(90deg,#fffdfb 0%,#fffaf8 50%,#f9f3f0 100%); display: grid; grid-template-columns: 47% 53%; position: relative; overflow: hidden; }
.hero-copy { align-self: center; margin: 74px 0 0 clamp(44px,10.5vw,148px); position: relative; z-index: 1; }
.catch { font-size: clamp(29px,2.65vw,40px); letter-spacing: .2em; line-height: 1.7; margin-bottom: 22px; }
.catch span { color: var(--pink-deep); }
.lead { color: #635a56; font-size: 14px; letter-spacing: .14em; margin-bottom: 30px; }
.button { height: 46px; display: inline-flex; align-items: center; justify-content: center; gap: 45px; padding: 0 34px; font-size: 14px; letter-spacing: .14em; }
.button b { font-weight: 400; font-size: 19px; }
.pill { border-radius: 27px; background: #e3a9aa; color: #fff; min-width: 220px; }
.hero-photo { height: 590px; width: 100%; overflow: hidden; }
.hero-photo img { width: 100%; height: 100%; object-fit: cover; object-position: 45% 8%; }
.hero-sign { position: absolute; right: 6.5vw; top: 275px; color: #dcaaaa; font-size: 32px; font-style: italic; transform: rotate(-7deg); letter-spacing: .08em; }
.hero-sign small { display: block; padding-left: 42px; font-size: 25px; }
.scroll { position: absolute; left: 47px; bottom: 55px; font: 10px var(--sans); letter-spacing: .3em; writing-mode: vertical-rl; }
.scroll span { height: 29px; border-left: 1px solid var(--rose); margin-top: 15px; display: inline-block; }
.concept { display: grid; grid-template-columns: 42.5% 1fr; min-height: 335px; position: relative; }
.concept-photo img { height: 335px; width: 100%; object-fit: cover; }
.concept-body { padding: 43px clamp(44px,7vw,96px) 35px; }
.eyebrow { color: var(--rose); font-size: 13px; letter-spacing: .2em; line-height: 1; margin-bottom: 24px; }
.concept-body h2 { font-size: clamp(23px,2vw,31px); letter-spacing: .18em; line-height: 1.7; margin-bottom: 13px; }
.concept-body > p:not(.eyebrow) { max-width: 540px; font-size: 12.5px; letter-spacing: .09em; color: #68605d; line-height: 2.2; margin-bottom: 23px; }
.outline { border: 1px solid #e4c6c1; height: 43px; min-width: 235px; color: #685b57; }
.leaf { position: absolute; right: 6vw; bottom: 18px; font-size: 108px; color: #f1ddd9; opacity: .85; }
.menu { padding: 27px clamp(32px,7vw,88px) 31px; background: linear-gradient(130deg,#fff8f7,#fffdfb 40%,#fdf3f2); }
.section-title { display: flex; justify-content: center; align-items: center; gap: 18px; margin-bottom: 23px; }
.section-title h2 { font-size: 18px; letter-spacing: .18em; }
.section-title span { width: 29px; border-top: 1px solid #e6b7b2; }
.menu-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 19px; max-width: 1170px; margin: auto; }
.menu-card { border: 1px solid #f0dddd; background: #fff; }
.menu-card img { height: 127px; width: 100%; object-fit: cover; }
.menu-card div { padding: 16px 16px 18px; }
.menu-card h3 { font-size: 17px; letter-spacing: .14em; color: #775e59; margin-bottom: 4px; }
.menu-card .jp { font-size: 11px; color: #7d716d; line-height: 1.6; }
.menu-card .price { font-size: 16px; line-height: 1.75; letter-spacing: .07em; }
.menu-card div > p:last-child { font-size: 12px; color: #6e6460; line-height: 1.8; letter-spacing: .06em; }
.menu-button { display: flex; margin: 25px auto 0; width: 300px; }
.reasons { min-height: 164px; display: grid; grid-template-columns: minmax(220px,26%) 1fr; padding: 26px clamp(34px,6.5vw,88px); background: #fffdfd; border-top: 1px solid #f5e9e6; border-bottom: 1px solid #f5e9e6; }
.reasons-heading { padding-right: 38px; }
.reasons-heading h2 { font-size: 20px; letter-spacing: .18em; line-height: 1.9; }
.reasons-heading p { color: #dcacab; font-style: italic; font-size: 18px; line-height: 1; padding-left: 28px; }
.reason-items { display: grid; grid-template-columns: repeat(4,1fr); }
.reason-items article { padding: 0 25px; border-left: 1px solid #ead8d3; text-align: center; }
.icon { color: #ddaaaa; height: 43px; font-size: 34px; line-height: 1; }
.reason-items h3 { font-size: 13px; letter-spacing: .11em; margin: 8px 0; }
.reason-items p { font-size: 11px; line-height: 1.75; color: #766d69; letter-spacing: .05em; }
.discover { padding: 29px clamp(34px,4.5vw,63px) 31px; display: grid; grid-template-columns: 1fr 1.04fr .94fr 1.32fr; gap: 42px; background: #fffaf8; }
.discover-card h2,.news h2 { font-size: 16px; letter-spacing: .14em; margin-bottom: 18px; }
.thumbs { display: grid; grid-template-columns: repeat(3,1fr); gap: 3px; margin-bottom: 10px; }
.thumbs img { width: 100%; height: 102px; object-fit: cover; }
.discover-card p { font-size: 11px; color: #706663; line-height: 1.8; margin: 8px 0 10px; }
.salon-photo { height: 101px; width: 100%; object-fit: cover; margin-bottom: 8px; }
.mini-button { display: flex; justify-content: space-between; align-items: center; border: 1px solid #e8cac7; font-size: 11px; height: 34px; padding: 0 15px; letter-spacing: .14em; }
.news-title { display: flex; justify-content: space-between; align-items: start; margin-bottom: 10px; }
.news-title a { font-size: 11px; }
.news ul { margin: 0; padding: 0; list-style: none; }
.news li { display: flex; gap: 18px; border-bottom: 1px solid #ecdfdb; padding: 12px 0; font-size: 11px; line-height: 1.5; }
.news time { flex-shrink: 0; color: #756d68; }
.contact-band { min-height: 153px; padding: 16px clamp(34px,4.5vw,62px); display: grid; grid-template-columns: 1.65fr .45fr 1.25fr 1.35fr; gap: 30px; align-items: center; border-top: 1px solid #f2e8e5; }
.info { display: grid; grid-template-columns: 1fr 1fr; gap: 2px 25px; font-size: 11px; color: #6a615e; }
.info .logo { grid-column: 1 / -1; font: italic 23px var(--serif); color: #5a4c49; letter-spacing: .1em; }
.info .logo small { font: 9px var(--sans); letter-spacing: .28em; margin-left: 10px; }
.social { grid-column: 1 / -1; font-size: 16px; letter-spacing: .3em; }
.flower { height: 102px; width: 100%; object-fit: cover; object-position: center; }
.booking { text-align: center; min-height: 108px; padding: 13px 18px; background: #fffaf8; }
.booking h2 { font-size: 16px; letter-spacing: .17em; margin-bottom: 6px; }
.booking p { font-size: 10px; color: #6f6763; line-height: 1.7; margin-bottom: 7px; }
.booking .pill { min-width: 180px; height: 31px; font-size: 12px; gap: 34px; }
.phone { background: #fdf7f1; }
.phone > a { display: block; font-size: 28px; letter-spacing: .12em; color: #8b716a; line-height: 1.35; }
.phone small { font-size: 9px; letter-spacing: .1em; }
.site-footer { height: 73px; padding: 0 clamp(29px,4.7vw,62px); background: #dfafae; color: #fff; display: flex; align-items: center; justify-content: space-between; }
.footer-logo { color: #fff; display: flex; flex-direction: column; font-size: 27px; }
.footer-logo small { font: 8px var(--sans); letter-spacing: .35em; text-align: center; margin-top: 6px; }
.site-footer nav { display: flex; gap: clamp(16px,2.7vw,40px); font-size: 11px; letter-spacing: .18em; }
.to-top { display: flex; flex-direction: column; text-align: center; font-size: 15px; }
.to-top small { font: 8px var(--sans); letter-spacing: .15em; }
@media (max-width: 1050px) {
 .global-nav { gap: 16px; font-size: 11px; }
 .brand { width: 150px; }
 .hero-copy { margin-left: 55px; }
 .leaf { display:none; }
 .reason-items article { padding: 0 12px; }
 .discover { grid-template-columns: repeat(2,1fr); }
 .contact-band { grid-template-columns: 1fr 1fr; }
 .flower { display:none; }
}
@media (max-width: 760px) {
 .site-header { position: fixed; height: 70px; background: rgba(255,253,251,.96); padding: 0 20px; box-shadow: 0 1px 8px rgba(90,70,64,.06); }
 .brand { width: auto; }
 .brand-script { font-size: 29px; }
 .brand-sub { font-size: 8px; }
 .header-reserve { height: 70px; min-width: 96px; font-size: 11px; margin-left: auto; padding: 0 10px; }
 .nav-toggle { order: 3; display: block; border: 0; background: transparent; width: 36px; height: 36px; padding: 9px 3px; }
 .nav-toggle span { display:block; height: 1px; background: var(--ink); margin: 7px 0; }
 .global-nav { display:none; position: fixed; top:70px; left:0; right:0; background:#fffdfb; flex-direction: column; padding: 25px 30px; gap: 21px; box-shadow: var(--shadow); }
 .global-nav.is-open { display:flex; }
 .hero { display: flex; flex-direction: column-reverse; padding-top: 70px; min-height: 0; }
 .hero-photo { height: 54vh; min-height: 360px; }
 .hero-copy { margin: 0; padding: 35px 27px 45px; }
 .catch { font-size: 27px; }
 .hero-sign,.scroll { display:none; }
 .concept { display:block; }
 .concept-photo img { height: 250px; }
 .concept-body { padding: 34px 25px 43px; }
 .menu { padding: 30px 20px; }
 .menu-grid { grid-template-columns: repeat(2,1fr); gap: 12px; }
 .menu-card img { height: 100px; }
 .menu-card div { padding: 13px 10px; }
 .menu-card div > p:last-child { display:none; }
 .reasons { display:block; padding: 34px 21px; }
 .reasons-heading { text-align:center; padding:0 0 28px; }
 .reason-items { grid-template-columns: repeat(2,1fr); gap: 28px 0; }
 .discover { display:block; padding: 35px 23px; }
 .discover-card,.news { margin-bottom: 38px; }
 .thumbs img,.salon-photo { height: auto; }
 .contact-band { display:flex; flex-direction:column; padding: 26px 22px; gap: 18px; }
 .info { width:100%; display:block; text-align:center; }
 .booking { width:100%; }
 .site-footer { height: auto; flex-direction: column; gap: 22px; padding: 29px 20px; }
 .site-footer nav { flex-wrap:wrap; justify-content:center; }
}
