/* ============================================================
   SK ruhe salon — styles
   Palette: ivory, mocha, dusty rose, warm gold
   Type: Shippori Mincho (display), Cormorant Garamond (latin italic), Noto Sans JP (body)
   ============================================================ */

:root{
  /* color */
  --bg: #FBF7F2;
  --bg-soft: #F4ECE3;
  --bg-deep: #EFE5D8;
  --paper: #FFFCF8;
  --ink: #2E241D;
  --ink-mid: #5B4A40;
  --ink-soft: #8A7868;
  --line: #E5DAD0;
  --line-soft: #EFE5D8;
  --rose: #C7918C;
  --rose-deep: #A37570;
  --gold: #B19059;
  --gold-soft: #D4BA8E;
  --mocha: #3E2F26;
  --line-app: #06C755;
  --line-app-dark: #04A849;

  /* type */
  --f-disp: "Shippori Mincho", "Noto Serif JP", "Yu Mincho", serif;
  --f-italic: "Cormorant Garamond", "Shippori Mincho", serif;
  --f-body: "Noto Sans JP", -apple-system, BlinkMacSystemFont, "Hiragino Kaku Gothic ProN", sans-serif;

  --maxw: 1240px;
  --gutter: clamp(20px, 4vw, 56px);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--f-body);
  color:var(--ink);
  background:var(--bg);
  font-size:15px;
  line-height:1.85;
  -webkit-font-smoothing:antialiased;
  letter-spacing:0.02em;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
em{font-style:italic;font-family:var(--f-italic);font-weight:500}

.container{
  max-width:var(--maxw);
  margin:0 auto;
  padding:0 var(--gutter);
}

/* ============== HEADER ============== */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:50;
  background:rgba(251,247,242,0.86);
  backdrop-filter:saturate(140%) blur(10px);
  -webkit-backdrop-filter:saturate(140%) blur(10px);
  border-bottom:1px solid transparent;
  transition:border-color .3s, background .3s;
}
.site-header.scrolled{border-bottom-color:var(--line-soft)}
.header-inner{
  max-width:1320px;margin:0 auto;
  padding:14px var(--gutter);
  display:flex;align-items:center;gap:24px;
}
.brand{display:flex;align-items:center;gap:14px}
.brand-mark{
  display:inline-flex;align-items:center;justify-content:center;
  width:38px;height:38px;border-radius:50%;
  border:1px solid var(--mocha);
  font-family:var(--f-italic);font-style:italic;font-size:19px;
  color:var(--mocha);letter-spacing:0.04em;
}
.brand-name{display:flex;flex-direction:column;line-height:1.1}
.brand-en{font-family:var(--f-disp);font-size:18px;color:var(--mocha);letter-spacing:0.08em}
.brand-en-em{font-family:var(--f-italic);font-style:italic;font-weight:500}
.brand-ja{font-size:10px;letter-spacing:0.22em;color:var(--ink-soft);margin-top:3px}

.site-nav{display:flex;gap:24px;margin-left:auto}
.site-nav a{
  font-family:var(--f-italic);font-style:italic;
  font-size:15px;color:var(--ink-mid);
  letter-spacing:0.06em;
  padding:6px 0;
  border-bottom:1px solid transparent;
  transition:color .2s, border-color .2s;
}
.site-nav a:hover{color:var(--mocha);border-bottom-color:var(--mocha)}
.header-cta{
  padding:11px 24px;
  background:var(--mocha);color:var(--bg);
  font-size:13px;letter-spacing:0.18em;
  border-radius:999px;
  transition:background .2s;
}
.header-cta:hover{background:var(--rose-deep)}
.header-line{
  background:var(--line-app);
  color:#fff;
}
.header-line:hover{background:var(--line-app-dark)}

.menu-toggle{
  display:none;
  margin-left:auto;
  background:transparent;border:none;
  width:36px;height:36px;
  flex-direction:column;justify-content:center;align-items:center;gap:5px;
  cursor:pointer;padding:0;
}
.menu-toggle span{display:block;width:22px;height:1px;background:var(--mocha);transition:transform .3s, opacity .2s}
.menu-toggle.open span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.menu-toggle.open span:nth-child(2){opacity:0}
.menu-toggle.open span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

.mobile-nav{
  display:none;
  flex-direction:column;
  padding:8px var(--gutter) 22px;
  background:var(--bg);
  border-top:1px solid var(--line-soft);
}
.mobile-nav a{
  padding:14px 0;
  border-bottom:1px solid var(--line-soft);
  font-size:14px;
  color:var(--ink-mid);
}
.mobile-nav a:last-child{border-bottom:none}

/* ============== HERO ============== */
.hero{
  position:relative;
  min-height:100svh;
  padding:120px var(--gutter) 80px;
  overflow:hidden;
}
.hero-image{
  position:absolute;inset:0;
}
.hero-image::before{
  content:""; position:absolute; inset:0;
  background:
    linear-gradient(135deg, #cdb89f 0%, #b89e85 30%, #8d7563 60%, #5e463b 100%);
}
.hero-image::after{
  content:"";position:absolute;inset:0;
  background-image:
    repeating-linear-gradient(45deg, transparent 0 28px, rgba(255,255,255,0.05) 28px 29px);
  mix-blend-mode:overlay;
}
.hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(46,36,29,0.05) 0%, rgba(46,36,29,0.55) 100%);
}
.ph-label{
  position:absolute;left:50%;top:50%;
  transform:translate(-50%,-50%);
  font-family:"SFMono-Regular", ui-monospace, monospace;
  font-size:11px;letter-spacing:0.06em;
  color:rgba(255,252,248,0.9);
  background:rgba(46,36,29,0.55);
  padding:6px 14px;border-radius:999px;
  text-align:center;
  border:1px solid rgba(255,252,248,0.18);
  pointer-events:none;
  white-space:nowrap;
}
[data-img].has-local-image{
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
}
[data-img].has-local-image::before,
[data-img].has-local-image::after{
  opacity:0;
  pointer-events:none;
}
[data-img].has-local-image .ph-label{
  display:none;
}
.hero-content{
  position:relative;z-index:2;
  max-width:var(--maxw);margin:0 auto;
  padding-top:8vh;
  color:var(--bg);
}
.hero-eyebrow{
  display:flex;align-items:center;gap:14px;
  margin:0 0 24px;
  font-family:var(--f-italic);font-style:italic;
  font-size:16px;letter-spacing:0.1em;
  color:rgba(255,252,248,0.9);
}
.hero-eyebrow .rule{display:inline-block;width:48px;height:1px;background:rgba(255,252,248,0.6)}
.hero-title{
  font-family:var(--f-disp);font-weight:500;
  font-size:clamp(40px, 7vw, 88px);
  line-height:1.2;letter-spacing:0.02em;
  margin:0 0 28px;
  color:var(--bg);
  text-shadow:0 2px 20px rgba(0,0,0,0.18);
}
.hero-title em{
  font-family:var(--f-italic);font-style:italic;
  font-weight:400;
  color:#f7d9bd;
}
.hero-sub{
  max-width:560px;
  font-size:15px;line-height:2;
  color:rgba(255,252,248,0.94);
  margin:0 0 40px;
  overflow-wrap:anywhere;
}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;align-items:center}

.mobile-only{display:none}
.desktop-break{display:block}

.hero-meta{
  position:absolute;right:var(--gutter);bottom:60px;
  z-index:2;
  display:flex;flex-direction:column;gap:10px;
  background:rgba(46,36,29,0.4);
  backdrop-filter:blur(6px);
  border:1px solid rgba(255,252,248,0.15);
  padding:18px 24px;
  border-radius:4px;
  color:var(--bg);
  font-size:12px;letter-spacing:0.12em;
}
.meta-row{display:flex;gap:24px;justify-content:space-between}
.meta-row span:first-child{font-family:var(--f-italic);font-style:italic;color:#f0d9bd}

/* ============== BUTTONS ============== */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:14px 28px;
  font-size:13px;letter-spacing:0.16em;
  border-radius:999px;
  border:1px solid transparent;
  cursor:pointer;
  font-family:var(--f-body);font-weight:500;
  transition:all .25s;
  text-align:center;
  background:transparent;
}
.btn-primary{background:var(--mocha);color:var(--bg)}
.btn-primary:hover{background:var(--rose-deep);transform:translateY(-1px)}
.btn-primary:disabled{background:var(--ink-soft);color:rgba(255,255,255,0.6);cursor:not-allowed;transform:none}
.btn-line{
  background:var(--line-app);
  color:#fff;
  border-color:var(--line-app);
  box-shadow:0 14px 30px -18px rgba(6,199,85,0.9);
}
.btn-line:hover{
  background:var(--line-app-dark);
  border-color:var(--line-app-dark);
  transform:translateY(-1px);
}
.btn-ghost{
  border-color:var(--mocha);color:var(--mocha);background:transparent;
}
.btn-ghost:hover{background:var(--mocha);color:var(--bg)}
.btn-ghost.light{border-color:rgba(255,252,248,0.5);color:var(--bg)}
.btn-ghost.light:hover{background:var(--bg);color:var(--mocha)}
.btn-text{
  padding:10px 0;
  font-size:13px;letter-spacing:0.16em;
  color:var(--bg);
  border-bottom:1px solid currentColor;
  border-radius:0;
}
.btn-text.light{color:var(--bg)}

/* ============== STRIP ============== */
.strip{
  background:var(--mocha);
  color:var(--bg);
  padding:14px 0;
  overflow:hidden;
  border-top:1px solid rgba(255,252,248,0.1);
}
.strip-track{
  display:flex;gap:0;
  white-space:nowrap;
  animation: scroll 60s linear infinite;
  font-family:var(--f-italic);font-style:italic;
  font-size:13px;letter-spacing:0.16em;
  color:#e6d6c1;
}
.strip-track span{padding:0 24px}
@keyframes scroll{
  to{ transform:translateX(-50%) }
}

/* ============== SECTION COMMON ============== */
.section{padding:clamp(80px, 12vh, 140px) 0;position:relative}
.section-head{margin-bottom:60px}
.section-head.center{text-align:center}
.eyebrow{
  display:inline-flex;align-items:center;gap:12px;
  font-family:var(--f-italic);font-style:italic;
  font-size:14px;letter-spacing:0.18em;
  color:var(--ink-soft);
  margin:0 0 24px;
}
.eyebrow.light{color:rgba(255,252,248,0.7)}
.eyebrow .num{
  font-family:var(--f-italic);font-style:italic;
  font-size:14px;color:var(--rose-deep);
  letter-spacing:0.1em;
}
.h-display{
  font-family:var(--f-disp);font-weight:500;
  font-size:clamp(32px, 4.6vw, 60px);
  line-height:1.3;letter-spacing:0.04em;
  margin:0;
  color:var(--mocha);
}
.h-display em{
  font-family:var(--f-italic);font-style:italic;
  color:var(--rose-deep);font-weight:500;
}
.h-display.light{color:var(--bg)}
.h-display.light em{color:var(--gold-soft)}
.section-desc{
  margin-top:22px;
  font-size:15px;color:var(--ink-mid);
  max-width:560px;
}

/* ============== CONCEPT ============== */
.concept{background:var(--bg)}
.concept-grid{
  display:grid;
  grid-template-columns:1fr 0.9fr;
  gap:clamp(40px, 8vw, 100px);
  align-items:center;
}
.concept-text .lead{
  font-family:var(--f-disp);
  font-size:20px;line-height:2;
  color:var(--mocha);margin:32px 0 24px;
}
.concept-text .body{
  font-size:15px;color:var(--ink-mid);max-width:520px;
}
.concept-text .signature{
  margin-top:40px;
  font-family:var(--f-italic);font-style:italic;
  font-size:18px;color:var(--rose-deep);
}
.concept-text .signature span{
  display:block;
  font-family:var(--f-body);font-style:normal;
  font-size:11px;letter-spacing:0.2em;
  color:var(--ink-soft);
  margin-top:6px;
}

.concept-images{
  position:relative;
  display:grid;
  grid-template-columns:1fr 1fr;
  grid-template-rows:auto auto;
  gap:18px;
}
.ci-tall{
  grid-column:1 / span 1;
  grid-row: 1 / span 2;
  aspect-ratio: 3/4.4;
  position:relative;
  background:linear-gradient(135deg, #d6c4ad, #a98a72);
  overflow:hidden;
  border-radius:2px;
}
.ci-short{
  grid-column:2 / span 1;
  grid-row: 2 / span 1;
  aspect-ratio: 4/3;
  position:relative;
  background:linear-gradient(135deg, #c8b9a4, #8d7965);
  overflow:hidden;
  border-radius:2px;
  margin-top:30%;
}
.ci-tall::after,.ci-short::after{
  content:"";position:absolute;inset:0;
  background-image:repeating-linear-gradient(45deg, transparent 0 24px, rgba(255,255,255,0.06) 24px 25px);
}

/* ============== REASONS ============== */
.reasons{background:var(--bg-soft)}
.reason-list{
  list-style:none;margin:0;padding:0;
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(280px,1fr));
  gap:0;
  border-top:1px solid var(--line);
}
.reason-list li{
  padding:36px 32px 36px 28px;
  border-bottom:1px solid var(--line);
  border-right:1px solid var(--line);
  position:relative;
  background:var(--bg-soft);
  transition:background .25s;
}
.reason-list li:hover{background:var(--paper)}
.reason-list li:nth-child(3n){border-right:none}
.r-num{
  font-family:var(--f-italic);font-style:italic;
  font-size:13px;letter-spacing:0.18em;
  color:var(--rose-deep);
  display:block;margin-bottom:14px;
}
.reason-list h3{
  font-family:var(--f-disp);
  font-size:21px;line-height:1.5;
  margin:0 0 12px;color:var(--mocha);
  font-weight:500;
}
.reason-list p{margin:0;font-size:14px;color:var(--ink-mid);line-height:1.9}

/* ============== SERVICE ============== */
.service{background:var(--bg)}
.service-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(260px, 1fr));
  gap:32px;
}
.service-card{
  background:var(--paper);
  border:1px solid var(--line-soft);
  border-radius:2px;
  overflow:hidden;
  transition:transform .3s, box-shadow .3s;
}
.service-card:hover{transform:translateY(-4px);box-shadow:0 20px 40px -28px rgba(46,36,29,0.3)}
.sc-image{
  aspect-ratio:4/3;
  position:relative;
  background:linear-gradient(135deg, #d6c2a8, #997e66);
}
.sc-image::after{
  content:"";position:absolute;inset:0;
  background-image:repeating-linear-gradient(45deg, transparent 0 22px, rgba(255,255,255,0.07) 22px 23px);
}
.sc-body{padding:28px 24px 32px}
.sc-num{
  font-family:var(--f-italic);font-style:italic;
  font-size:13px;color:var(--rose-deep);
  margin:0 0 10px;letter-spacing:0.12em;
}
.service-card h3{
  font-family:var(--f-disp);font-weight:500;
  font-size:24px;margin:0 0 6px;
  color:var(--mocha);
}
.sc-jp{font-size:12px;letter-spacing:0.16em;color:var(--ink-soft);margin:0 0 16px}
.sc-desc{font-size:13.5px;color:var(--ink-mid);margin:0 0 16px;line-height:1.9}
.sc-price{
  font-family:var(--f-italic);font-style:italic;
  font-size:18px;color:var(--mocha);
  border-top:1px solid var(--line-soft);
  padding-top:14px;margin:0;
}

/* ============== MENU ============== */
.menu{background:var(--bg-soft)}
.menu-tabs{
  display:flex;flex-wrap:wrap;gap:0;
  border-bottom:1px solid var(--line);
  margin-bottom:40px;
}
.tab{
  padding:14px 28px;
  background:transparent;border:none;cursor:pointer;
  font-family:var(--f-italic);font-style:italic;
  font-size:15px;letter-spacing:0.06em;
  color:var(--ink-soft);
  border-bottom:2px solid transparent;
  margin-bottom:-1px;
  transition:color .2s, border-color .2s;
}
.tab:hover{color:var(--mocha)}
.tab.active{color:var(--mocha);border-bottom-color:var(--mocha)}

.menu-panel{display:none}
.menu-panel.active{display:block}
.menu-list{list-style:none;padding:0;margin:0}
.menu-list li{
  display:grid;
  grid-template-columns: 1fr auto auto;
  align-items:baseline;
  gap:16px;
  padding:18px 0;
  border-bottom:1px dashed var(--line);
  font-size:15px;
}
.m-name{color:var(--ink);font-weight:500}
.m-dot{
  border-bottom:1px dotted var(--ink-soft);
  align-self:flex-end;
  height:1px;
  min-width:24px;
  position:relative;top:-3px;
}
.m-price{
  font-family:var(--f-italic);font-style:italic;
  font-size:18px;color:var(--rose-deep);
}
.menu-note{
  margin-top:24px;
  font-size:12.5px;color:var(--ink-soft);
  font-family:var(--f-italic);font-style:italic;
}

/* ============== GALLERY ============== */
.gallery{background:var(--bg)}
.gallery-grid{
  display:grid;
  grid-template-columns:repeat(6, 1fr);
  grid-auto-rows: 140px;
  gap:14px;
}
.g-cell{
  position:relative;
  background:linear-gradient(135deg, #c9b59d, #8e7561);
  overflow:hidden;border-radius:2px;
}
.g-cell::after{
  content:"";position:absolute;inset:0;
  background-image:repeating-linear-gradient(45deg, transparent 0 18px, rgba(255,255,255,0.06) 18px 19px);
}
.g-1{grid-column:span 3; grid-row:span 2}
.g-2{grid-column:span 3; grid-row:span 2}
.g-3{grid-column:span 2; grid-row:span 2}
.g-4{grid-column:span 2; grid-row:span 2}
.g-5{grid-column:span 2; grid-row:span 2}
.g-6{grid-column:span 6; grid-row:span 2}
.ig-link{
  text-align:right;
  margin-top:24px;
  font-family:var(--f-italic);font-style:italic;
  font-size:14px;
}
.ig-link a{color:var(--rose-deep);border-bottom:1px solid currentColor;padding-bottom:2px}

/* ============== VOICE ============== */
.voice{background:var(--bg-soft)}
.rating-row{
  display:flex;align-items:baseline;gap:14px;flex-wrap:wrap;
  margin-top:18px;
}
.stars{color:var(--gold);font-size:22px;letter-spacing:0.1em}
.rate-num{
  font-family:var(--f-italic);font-style:italic;
  font-size:32px;color:var(--mocha);
}
.rate-meta{font-size:12.5px;color:var(--ink-soft);letter-spacing:0.06em}

.voice-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(280px,1fr));
  gap:24px;
}
.voice-card{
  background:var(--paper);
  border:1px solid var(--line-soft);
  padding:32px 28px;
  margin:0;
  border-radius:2px;
  position:relative;
}
.voice-card::before{
  content:"“";
  position:absolute;top:8px;left:18px;
  font-family:var(--f-disp);
  font-size:60px;color:var(--rose);opacity:0.4;
  line-height:1;
}
.voice-card blockquote{
  margin:0;padding:0;
  font-size:14.5px;color:var(--ink-mid);
  line-height:2;
}
.voice-card figcaption{
  margin-top:18px;
  padding-top:14px;
  border-top:1px solid var(--line-soft);
  font-size:12px;letter-spacing:0.1em;
  color:var(--ink-soft);
  font-family:var(--f-italic);font-style:italic;
}
.voice-note{
  margin-top:24px;
  font-size:11.5px;color:var(--ink-soft);text-align:right;
}

/* ============== STAFF ============== */
.staff{background:var(--bg)}
.staff-grid{
  display:grid;grid-template-columns:0.9fr 1fr;
  gap:clamp(40px, 8vw, 100px);
  align-items:center;
}
.staff-photo{
  aspect-ratio:3/4;
  position:relative;
  background:linear-gradient(135deg, #d2bda0, #846951);
  overflow:hidden;border-radius:2px;
}
.staff-photo::after{
  content:"";position:absolute;inset:0;
  background-image:repeating-linear-gradient(45deg, transparent 0 22px, rgba(255,255,255,0.07) 22px 23px);
}
.staff-meta{margin:24px 0 28px}
.staff-meta div{
  display:grid;
  grid-template-columns:140px 1fr;
  gap:12px;
  padding:14px 0;
  border-bottom:1px solid var(--line-soft);
  margin:0;
}
.staff-meta dt{
  font-size:11px;letter-spacing:0.2em;
  color:var(--ink-soft);
}
.staff-meta dd{margin:0;font-size:14.5px;color:var(--ink)}

/* ============== RESERVE ============== */
.reserve{background:var(--bg-soft)}
.reserve-card{
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:4px;
  padding:clamp(28px, 5vw, 56px);
  max-width:980px;margin:0 auto;
}
.reserve-stepper{
  display:flex;flex-wrap:wrap;gap:8px;
  margin-bottom:36px;
  border-bottom:1px solid var(--line-soft);
  padding-bottom:18px;
}
.step{
  font-size:12px;letter-spacing:0.1em;
  color:var(--ink-soft);
  padding:6px 14px;border-radius:999px;
  background:transparent;
  border:1px solid transparent;
  transition:all .2s;
}
.step.active{color:var(--mocha);background:var(--bg-deep);border-color:var(--line)}
.step.completed{color:var(--rose-deep)}

.step-panel{display:none;animation:fade .35s ease}
.step-panel.active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

.step-title{
  font-family:var(--f-disp);font-weight:500;
  font-size:22px;color:var(--mocha);margin:0 0 24px;
}

.menu-choices{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(280px, 1fr));
  gap:10px;
}
.menu-choices label{
  display:grid;
  grid-template-columns: auto 1fr auto;
  align-items:center;gap:14px;
  padding:14px 18px;
  border:1px solid var(--line);
  border-radius:2px;
  cursor:pointer;
  transition:border-color .2s, background .2s;
  font-size:14px;
}
.menu-choices label:hover{border-color:var(--mocha);background:var(--bg)}
.menu-choices input{accent-color:var(--mocha)}
.menu-choices label:has(input:checked){
  border-color:var(--mocha);background:var(--bg-deep);
}
.menu-choices em{
  font-family:var(--f-italic);font-style:italic;
  color:var(--rose-deep);font-size:14px;
}

/* calendar */
.reserve-grid{
  display:grid;grid-template-columns: 1.1fr 0.9fr;
  gap:36px;
  align-items:start;
}
.cal-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:0 6px 14px;
}
.cal-title{
  font-family:var(--f-disp);font-size:20px;color:var(--mocha);
}
.cal-nav{
  background:transparent;border:1px solid var(--line);
  width:36px;height:36px;border-radius:50%;
  cursor:pointer;color:var(--mocha);font-size:18px;
  transition:background .2s, color .2s;
}
.cal-nav:hover{background:var(--mocha);color:var(--bg)}
.cal-dow{
  display:grid;grid-template-columns:repeat(7,1fr);
  gap:4px;margin-bottom:6px;
  font-size:11px;letter-spacing:0.1em;
  text-align:center;color:var(--ink-soft);
  padding:4px 0;
}
.cal-dow .sun{color:var(--rose-deep)}
.cal-grid{
  display:grid;grid-template-columns:repeat(7,1fr);
  gap:4px;
}
.cell{
  aspect-ratio:1/1;
  display:flex;align-items:center;justify-content:center;
  background:transparent;border:1px solid transparent;
  border-radius:50%;
  font-size:14px;color:var(--ink);
  cursor:pointer;
  transition:all .15s;
  font-family:var(--f-italic);font-style:italic;
}
.cell:hover{background:var(--bg-deep)}
.cell.muted{color:var(--line);cursor:default}
.cell.muted:hover{background:transparent}
.cell.off{color:var(--rose);cursor:not-allowed;text-decoration:line-through;text-decoration-color:var(--line)}
.cell.off:hover{background:transparent}
.cell.disabled{color:var(--line);cursor:not-allowed}
.cell.disabled:hover{background:transparent}
.cell.today{font-weight:600;color:var(--rose-deep)}
.cell.selected{background:var(--mocha);color:var(--bg);font-weight:600}
.cell.selected:hover{background:var(--mocha)}

.cal-legend{
  display:flex;flex-wrap:wrap;gap:14px;
  margin-top:18px;font-size:11px;color:var(--ink-soft);
  align-items:center;
}
.lg{display:inline-block;width:10px;height:10px;border-radius:50%;margin-right:4px;vertical-align:middle}
.lg-off{background:var(--rose)}
.lg-disabled{background:var(--line)}
.lg-selected{background:var(--mocha)}

.time-wrap{padding-top:6px}
.time-label{
  font-size:12px;letter-spacing:0.1em;
  color:var(--ink-soft);margin:0 0 14px;
}
.time-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:8px;
}
.tslot{
  padding:14px 8px;
  background:var(--bg);
  border:1px solid var(--line);border-radius:2px;
  font-family:var(--f-italic);font-style:italic;
  font-size:16px;color:var(--mocha);
  cursor:pointer;
  transition:all .15s;
}
.tslot:hover{border-color:var(--mocha)}
.tslot.selected{background:var(--mocha);color:var(--bg);border-color:var(--mocha)}
.tslot.disabled{color:var(--line);background:transparent;cursor:not-allowed;border-style:dashed}
.tslot.disabled:hover{border-color:var(--line)}
.time-note{
  margin-top:18px;font-size:11.5px;
  color:var(--ink-soft);font-family:var(--f-italic);font-style:italic;
}

/* form */
.customer-form{
  display:grid;grid-template-columns:1fr 1fr;
  gap:20px 28px;
}
.line-reserve-note{
  margin:18px auto 14px;
  color:var(--ink-mid);
  font-size:13.5px;
  line-height:1.8;
}
.reserve-line-btn{margin-top:4px}
.field{display:flex;flex-direction:column;gap:8px;font-size:13px}
.field.full{grid-column:1 / -1}
.f-label{
  font-size:11.5px;letter-spacing:0.14em;color:var(--ink-soft);
  display:flex;align-items:center;gap:8px;
}
.f-label em{
  font-family:var(--f-body);font-style:normal;
  font-size:10px;background:var(--rose);color:var(--bg);
  padding:2px 8px;border-radius:2px;letter-spacing:0.1em;
}
.field input, .field select, .field textarea{
  padding:14px 16px;
  border:1px solid var(--line);
  border-radius:2px;
  background:var(--bg);
  font-family:inherit;font-size:14px;color:var(--ink);
  transition:border-color .2s;
}
.field input:focus, .field select:focus, .field textarea:focus{
  outline:none;border-color:var(--mocha);
}
.field textarea{resize:vertical}

/* summary */
.summary{
  background:var(--bg);
  border:1px solid var(--line);
  padding:24px 28px;
  margin:0 0 24px;
}
.summary div{
  display:grid;grid-template-columns:140px 1fr;
  gap:14px;padding:10px 0;
  border-bottom:1px solid var(--line-soft);
}
.summary div:last-child{border-bottom:none}
.summary dt{font-size:11px;letter-spacing:0.18em;color:var(--ink-soft)}
.summary dd{margin:0;font-size:14.5px;color:var(--ink)}

.disclaimer{
  font-size:12px;color:var(--ink-soft);
  font-family:var(--f-italic);font-style:italic;
  margin-bottom:24px;
}

.step-actions{
  display:flex;justify-content:space-between;align-items:center;
  margin-top:32px;flex-wrap:wrap;gap:12px;
}
.step-actions.center{justify-content:center}

/* DONE */
.step-panel.done{text-align:center;padding:24px 0}
.done-mark{
  width:72px;height:72px;border-radius:50%;
  background:var(--rose-deep);color:var(--bg);
  display:inline-flex;align-items:center;justify-content:center;
  font-size:32px;margin-bottom:24px;
}
.step-panel.done h3{
  font-family:var(--f-disp);font-weight:500;
  font-size:28px;color:var(--mocha);margin:0 0 16px;
}
.step-panel.done > p{
  font-size:14px;color:var(--ink-mid);
  max-width:480px;margin:0 auto 32px;
}
.mail-demo-note{
  font-size:12px !important;
  color:var(--ink-soft) !important;
  margin-top:-8px !important;
  margin-bottom:24px !important;
}

/* ============== ACCESS ============== */
.access{background:var(--bg)}
.access-grid{
  display:grid;grid-template-columns:1fr 1.1fr;
  gap:clamp(36px, 6vw, 80px);
  align-items:start;
}
.access-list{margin:32px 0}
.access-list div{
  display:grid;grid-template-columns:120px 1fr;gap:18px;
  padding:14px 0;border-bottom:1px solid var(--line-soft);
}
.access-list dt{
  font-size:11px;letter-spacing:0.18em;color:var(--ink-soft);
}
.access-list dd{margin:0;font-size:14.5px;color:var(--ink)}
.access-list dd a{color:var(--rose-deep);border-bottom:1px solid currentColor}
.access-list dd span{color:var(--ink-soft);font-size:12px;margin-left:6px}

.access-buttons{display:flex;gap:14px;flex-wrap:wrap;margin-top:24px}

.map-frame{
  position:sticky;top:100px;
  aspect-ratio:4/4.4;
  border:1px solid var(--line);
  border-radius:2px;
  overflow:hidden;
  background:var(--bg-soft);
}
.map-frame iframe{width:100%;height:100%;border:none;filter:grayscale(0.3) contrast(1.02)}

/* ============== FAQ ============== */
.faq{background:var(--bg-soft)}
.faq-list{list-style:none;padding:0;margin:0;border-top:1px solid var(--line)}
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{
  width:100%;
  display:flex;align-items:center;justify-content:space-between;
  padding:24px 6px;
  background:transparent;border:none;cursor:pointer;
  font-family:var(--f-disp);font-weight:500;
  font-size:17px;color:var(--mocha);text-align:left;
  transition:color .2s;
}
.faq-q:hover{color:var(--rose-deep)}
.faq-mark{
  font-size:18px;color:var(--rose-deep);
  transition:transform .3s;
}
.faq-item.open .faq-mark{transform:rotate(45deg)}
.faq-a{
  max-height:0;overflow:hidden;
  transition:max-height .35s ease;
}
.faq-item.open .faq-a{max-height:300px}
.faq-a p{padding:0 6px 24px;margin:0;color:var(--ink-mid);font-size:14.5px;line-height:2;max-width:780px}

/* ============== CTA STRIP ============== */
.cta-strip{
  background:linear-gradient(135deg, #3e2f26 0%, #5b443a 50%, #2e241d 100%);
  color:var(--bg);
  padding:clamp(60px, 10vh, 100px) 0;
  position:relative;
  overflow:hidden;
}
.cta-strip::before{
  content:"";position:absolute;inset:0;
  background-image:repeating-linear-gradient(45deg, transparent 0 40px, rgba(255,255,255,0.025) 40px 41px);
  pointer-events:none;
}
.cta-inner{
  display:flex;justify-content:space-between;align-items:center;
  gap:40px;flex-wrap:wrap;
}
.cta-strip p{color:rgba(255,252,248,0.86);font-size:14px;margin:14px 0 0}
.cta-actions{display:flex;gap:14px;flex-wrap:wrap}

/* ============== FOOTER ============== */
.site-footer{
  background:var(--bg);
  padding:64px 0 32px;
  border-top:1px solid var(--line-soft);
}
.footer-grid{
  display:grid;grid-template-columns:1.2fr 1fr 1fr;
  gap:40px;
  padding-bottom:40px;
  border-bottom:1px solid var(--line-soft);
}
.f-brand{
  font-family:var(--f-disp);font-weight:500;
  font-size:22px;color:var(--mocha);margin:0;
}
.f-sub{font-size:11px;letter-spacing:0.2em;color:var(--ink-soft);margin:6px 0 16px}
.f-meta{font-size:13px;color:var(--ink-mid);line-height:1.8;margin:0}
.f-nav, .f-ext{display:flex;flex-direction:column;gap:10px;font-size:13px}
.f-nav a, .f-ext a{color:var(--ink-mid);transition:color .2s}
.f-nav a:hover, .f-ext a:hover{color:var(--rose-deep)}
.copyright{
  text-align:center;margin:24px 0 0;
  font-size:11px;letter-spacing:0.2em;color:var(--ink-soft);
}

/* ============== STICKY MOBILE ============== */
.sticky-actions{
  display:none;
  position:fixed;left:16px;right:16px;bottom:16px;
  z-index:40;
  gap:8px;
  padding:8px;
  background:rgba(255,252,248,0.88);
  border:1px solid rgba(229,218,208,0.8);
  border-radius:999px;
  box-shadow:0 12px 32px -10px rgba(46,36,29,0.4);
  backdrop-filter:blur(12px);
}
.sticky-actions a{
  flex:1;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  min-height:48px;
  padding:12px 14px;
  border-radius:999px;
  font-size:13px;
  letter-spacing:0.14em;
  white-space:nowrap;
}
.sticky-line{
  background:var(--line-app);
  color:#fff;
}
.sticky-reserve{
  background:var(--mocha);
  color:var(--bg);
}

/* ============== RESPONSIVE ============== */
@media (max-width: 960px){
  .site-nav, .header-cta{display:none}
  .menu-toggle{display:flex}
  .mobile-nav.open{display:flex}

  .hero-meta{display:none}
  .hero{padding-top:96px;min-height:88svh}

  .concept-grid, .staff-grid, .access-grid, .reserve-grid{
    grid-template-columns:1fr;
  }
  .map-frame{position:static;aspect-ratio:4/3}
  .ci-short{margin-top:0}

  .reason-list{grid-template-columns:1fr 1fr}
  .reason-list li{border-right:none}
  .reason-list li:nth-child(2n){border-right:none}

  .gallery-grid{
    grid-template-columns:repeat(4,1fr);
    grid-auto-rows: 100px;
  }
  .g-1{grid-column:span 4;grid-row:span 2}
  .g-2{grid-column:span 2;grid-row:span 2}
  .g-3{grid-column:span 2;grid-row:span 2}
  .g-4{grid-column:span 2;grid-row:span 2}
  .g-5{grid-column:span 2;grid-row:span 2}
  .g-6{grid-column:span 4;grid-row:span 2}

  .customer-form{grid-template-columns:1fr}

  .footer-grid{grid-template-columns:1fr;gap:28px}

  .cta-inner{flex-direction:column;align-items:flex-start;text-align:left}

  .sticky-actions{display:flex}
  body{padding-bottom:96px}
}

@media (max-width: 600px){
  .reason-list{grid-template-columns:1fr}
  .reason-list li{padding:28px 8px}
  .reserve-stepper{font-size:11px}
  .menu-list li{grid-template-columns:1fr auto;gap:10px}
  .m-dot{display:none}
  .access-list div, .staff-meta div, .summary div{grid-template-columns:1fr;gap:4px}
  .hero-content{padding-top:5vh}
  .hero-title{font-size:clamp(34px, 10.4vw, 40px);line-height:1.28}
  .hero-sub{font-size:14px;line-height:1.85;max-width:100%}
  .mobile-only{display:block}
}
