/* ============================================================
   凪 nagi — 築130年の古民家宿 / coastal kominka inn
   Design system
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Shippori+Mincho:wght@400;500;600;700&family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;1,400&family=Jost:wght@300;400;500&display=swap');

:root {
  /* palette — warm paper, sumi ink, a muted sea + earth accent */
  --paper:      oklch(0.962 0.009 84);
  --paper-2:    oklch(0.935 0.012 78);
  --paper-3:    oklch(0.905 0.014 74);
  --ink:        oklch(0.255 0.012 62);
  --ink-soft:   oklch(0.430 0.012 62);
  --ink-faint:  oklch(0.560 0.010 64);
  --line:       oklch(0.840 0.012 74);
  --line-soft:  oklch(0.885 0.010 76);
  --sea:        oklch(0.470 0.046 218);
  --sea-deep:   oklch(0.360 0.040 220);
  --wood:       oklch(0.540 0.052 58);

  /* type */
  --jp:    "Shippori Mincho", "Hiragino Mincho ProN", "Yu Mincho", serif;
  --en:    "Cormorant Garamond", "Shippori Mincho", serif;
  --label: "Jost", "Shippori Mincho", sans-serif;

  /* rhythm */
  --gut: clamp(20px, 5vw, 96px);   /* horizontal page margin */
  --sp:  clamp(72px, 11vw, 180px); /* vertical section spacing */
  --maxw: 1320px;

  --ease: cubic-bezier(0.22, 1, 0.36, 1);
}

/* ---------- reset ---------- */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--paper);
  color: var(--ink);
  font-family: var(--jp);
  font-weight: 400;
  line-height: 1.95;
  letter-spacing: 0.04em;
  font-feature-settings: "palt" 1;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font: inherit; color: inherit; cursor: pointer; border: 0; background: none; }
h1,h2,h3,h4,p { margin: 0; }

/* ---------- language toggle ---------- */
body.lang-ja .en-only { display: none !important; }
body.lang-en .ja-only { display: none !important; }

/* ---------- helpers ---------- */
.wrap { max-width: var(--maxw); margin-inline: auto; padding-inline: var(--gut); }
.label {
  font-family: var(--label);
  font-weight: 400;
  font-size: clamp(10px, 0.78vw, 12px);
  letter-spacing: 0.42em;
  text-transform: uppercase;
  color: var(--ink-faint);
}
.en-serif { font-family: var(--en); font-style: italic; letter-spacing: 0.01em; }

/* striped image placeholders ------------------------------------ */
.ph {
  position: relative;
  background-color: var(--paper-2);
  background-image: repeating-linear-gradient(
    -45deg,
    transparent 0, transparent 11px,
    oklch(0.89 0.013 76) 11px, oklch(0.89 0.013 76) 12px
  );
  overflow: hidden;
}
.ph::after {
  content: attr(data-label);
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 1.2em;
  font-family: "SFMono-Regular", ui-monospace, Menlo, monospace;
  font-size: clamp(9px, 0.8vw, 11px);
  letter-spacing: 0.16em;
  line-height: 1.7;
  color: var(--ink-faint);
  text-transform: uppercase;
}
.ph.dark { background-color: var(--sea-deep); background-image: repeating-linear-gradient(-45deg, transparent 0, transparent 11px, oklch(0.32 0.04 220) 11px, oklch(0.32 0.04 220) 12px); }
.ph.dark::after { color: oklch(0.78 0.03 220); }

/* filled with a real image (stock or final) */
.ph.has-img { background-image: none; background-size: cover; background-position: center; }
.ph.has-img::after { display: none; }
.ph.has-img.loading { background-color: var(--paper-3); }

/* reveal-on-scroll ---------------------------------------------- */
.rv { opacity: 0; transform: translateY(26px); transition: opacity 1.1s var(--ease), transform 1.1s var(--ease); }
.rv.in { opacity: 1; transform: none; }
.rv.d1 { transition-delay: 0.08s; }
.rv.d2 { transition-delay: 0.16s; }
.rv.d3 { transition-delay: 0.24s; }
@media (prefers-reduced-motion: reduce){ .rv{opacity:1;transform:none;transition:none;} }

/* =====================================================================
   ANIMATION LAYER
   ===================================================================== */

/* — image wipe reveal (applied to every section image) — */
.ph.wipe { clip-path: inset(0 0 102% 0); transition: clip-path 1.25s var(--ease); will-change: clip-path; }
.ph.wipe.shown { clip-path: inset(0 0 0 0); }

/* a slow inner zoom that settles once revealed */
.ph.zoomable { transition: clip-path 1.25s var(--ease), background-size 6s var(--ease); background-size: 118%; }
.ph.zoomable.shown { background-size: 104%; }

/* — staggered word/line reveal for section heads — */
.sec-head .num { display: inline-block; opacity: 0; transform: translateY(14px); transition: opacity .9s var(--ease) .05s, transform .9s var(--ease) .05s; }
.sec-head .sec-title { display: inline-block; opacity: 0; transform: translateY(22px); transition: opacity 1s var(--ease) .12s, transform 1s var(--ease) .12s; }
.sec-head .sec-sub { display: inline-block; opacity: 0; transform: translateY(16px); transition: opacity 1s var(--ease) .22s, transform 1s var(--ease) .22s; }
.sec-head.in .num, .sec-head.in .sec-title, .sec-head.in .sec-sub { opacity: 1; transform: none; }

/* — hero intro on load — */
.hero .eyebrow,
.hero-inner .ja-only,
.hero-inner .en-only,
.scroll-cue { opacity: 0; transform: translateY(34px); transition: opacity 1.1s var(--ease), transform 1.1s var(--ease); }
body.ready .hero .eyebrow { opacity: 1; transform: none; transition-delay: .35s; }
body.ready .hero-inner .ja-only,
body.ready .hero-inner .en-only { opacity: 1; transform: none; transition-delay: .55s; }
body.ready .scroll-cue { opacity: 1; transform: none; transition-delay: 1.1s; }

/* — hero ken burns — */
.hero .ph { animation: kenburns 20s var(--ease) forwards; }
@keyframes kenburns {
  from { transform: scale(1.12); }
  to   { transform: scale(1.0); }
}

/* — language crossfade — */
main { transition: opacity .4s var(--ease), filter .4s var(--ease); }
body.switching main { opacity: 0; filter: blur(2px); }

/* — nav overlay staggered links — */
.nav-list a { opacity: 0; transform: translateY(26px); transition: opacity .7s var(--ease), transform .7s var(--ease), color .3s, padding-left .4s var(--ease); }
.nav-overlay.open .nav-list a { opacity: 1; transform: none; }
.nav-overlay.open .nav-list a:nth-child(1){ transition-delay:.12s } .nav-overlay.open .nav-list a:nth-child(2){ transition-delay:.17s }
.nav-overlay.open .nav-list a:nth-child(3){ transition-delay:.22s } .nav-overlay.open .nav-list a:nth-child(4){ transition-delay:.27s }
.nav-overlay.open .nav-list a:nth-child(5){ transition-delay:.32s } .nav-overlay.open .nav-list a:nth-child(6){ transition-delay:.37s }
.nav-overlay.open .nav-list a:nth-child(7){ transition-delay:.42s } .nav-overlay.open .nav-list a:nth-child(8){ transition-delay:.47s }
.nav-overlay.open .nav-list a:nth-child(9){ transition-delay:.52s }
.nav-overlay .nav-side .ph { clip-path: inset(0 0 0 100%); transition: clip-path 1s var(--ease) .2s; }
.nav-overlay.open .nav-side .ph { clip-path: inset(0 0 0 0); }

/* — reserve button subtle pulse-free hover lift handled inline — */
.reserve-btn, .menu-btn .bars span, .c-btn, .nav-list a { will-change: transform; }

@media (prefers-reduced-motion: reduce){
  .ph.wipe, .ph.zoomable { clip-path: none !important; background-size: cover !important; transition: none !important; }
  .hero .ph { animation: none !important; transform: none !important; }
  .sec-head .num, .sec-head .sec-title, .sec-head .sec-sub,
  .hero .eyebrow, .hero-inner .ja-only, .hero-inner .en-only, .scroll-cue,
  .nav-list a { opacity: 1 !important; transform: none !important; transition: none !important; }
  main { transition: none !important; }
}

/* =====================================================================
   HEADER
   ===================================================================== */
.site-head {
  position: fixed;
  inset: 0 0 auto 0;
  z-index: 60;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: clamp(16px, 2.2vw, 30px) var(--gut);
  color: var(--paper);
  transition: background .6s var(--ease), color .6s var(--ease), padding .6s var(--ease);
  mix-blend-mode: normal;
}
.site-head.solid {
  background: color-mix(in oklch, var(--paper) 92%, transparent);
  color: var(--ink);
  padding-block: clamp(12px, 1.5vw, 18px);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--line-soft);
}
.brand { display: flex; align-items: baseline; gap: 0.55em; line-height: 1; }
.brand .mark { font-family: var(--jp); font-weight: 500; font-size: clamp(22px, 2.4vw, 30px); letter-spacing: 0.18em; }
.brand .rom  { font-family: var(--label); font-weight: 300; font-size: clamp(10px,0.9vw,12px); letter-spacing: 0.42em; text-transform: uppercase; opacity: .82; }

.head-right { display: flex; align-items: center; gap: clamp(14px, 1.8vw, 26px); }
.lang-toggle { display: flex; align-items: center; gap: 0.5em; font-family: var(--label); font-size: 12px; letter-spacing: 0.18em; }
.lang-toggle button { padding: 2px 1px; opacity: .5; transition: opacity .3s; position: relative; }
.lang-toggle button[aria-pressed="true"] { opacity: 1; }
.lang-toggle .sep { opacity: .35; }

.reserve-btn {
  font-family: var(--label);
  font-size: 12px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  padding: 0.85em 1.5em;
  border: 1px solid currentColor;
  border-radius: 999px;
  transition: background .4s var(--ease), color .4s var(--ease);
}
.site-head:not(.solid) .reserve-btn:hover { background: var(--paper); color: var(--ink); }
.site-head.solid .reserve-btn:hover { background: var(--ink); color: var(--paper); border-color: var(--ink); }

.menu-btn { display: flex; align-items: center; gap: 0.7em; font-family: var(--label); font-size: 12px; letter-spacing: 0.24em; text-transform: uppercase; }
.menu-btn .bars { display: inline-flex; flex-direction: column; gap: 4px; width: 22px; }
.menu-btn .bars span { height: 1px; background: currentColor; display: block; transition: transform .4s var(--ease); }

@media (max-width: 720px){
  .reserve-btn { display: none; }
}

/* =====================================================================
   OVERLAY MENU
   ===================================================================== */
.nav-overlay {
  position: fixed; inset: 0; z-index: 80;
  background: var(--paper);
  color: var(--ink);
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  opacity: 0; visibility: hidden;
  transition: opacity .6s var(--ease), visibility .6s var(--ease);
}
.nav-overlay.open { opacity: 1; visibility: visible; }
.nav-close { position: absolute; top: clamp(16px,2.2vw,30px); right: var(--gut); z-index: 2; font-family: var(--label); font-size: 12px; letter-spacing: 0.24em; text-transform: uppercase; display: flex; gap: .7em; align-items: center; }
.nav-close .x { width: 20px; height: 20px; position: relative; display: inline-block; }
.nav-close .x::before, .nav-close .x::after { content: ""; position: absolute; top: 50%; left: 0; width: 100%; height: 1px; background: currentColor; }
.nav-close .x::before { transform: rotate(45deg); }
.nav-close .x::after { transform: rotate(-45deg); }

.nav-list {
  align-self: center;
  padding: clamp(80px,12vh,140px) var(--gut) clamp(40px,8vh,80px);
  display: flex; flex-direction: column; gap: clamp(8px, 1.2vw, 16px);
}
.nav-list a {
  display: flex; align-items: baseline; gap: 1em;
  transition: color .3s, padding-left .4s var(--ease);
}
.nav-list a:hover { padding-left: 12px; color: var(--sea); }
.nav-list .n-jp { font-family: var(--jp); font-size: clamp(26px, 3.4vw, 46px); font-weight: 500; line-height: 1.25; letter-spacing: 0.06em; }
.nav-list .n-en { font-family: var(--en); font-style: italic; font-size: clamp(13px, 1.1vw, 17px); color: var(--ink-faint); }
.nav-side { position: relative; }
.nav-side .ph { position: absolute; inset: 0; }
.nav-foot { position: absolute; bottom: clamp(24px,4vh,48px); left: var(--gut); display: flex; gap: 1.8em; font-family: var(--label); font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--ink-faint); }
.nav-foot a:hover { color: var(--ink); }

@media (max-width: 860px){
  .nav-overlay { grid-template-columns: 1fr; }
  .nav-side { display: none; }
}

/* =====================================================================
   HERO
   ===================================================================== */
.hero { position: relative; height: 100svh; min-height: 600px; color: var(--paper); }
.hero .ph { position: absolute; inset: 0; }
.hero::after { content:""; position:absolute; inset:0; background: linear-gradient(180deg, rgba(20,22,20,.32) 0%, rgba(20,22,20,.05) 30%, rgba(20,22,20,.08) 60%, rgba(20,22,20,.5) 100%); }
.hero-inner { position: absolute; inset: 0; z-index: 2; display: flex; flex-direction: column; justify-content: flex-end; padding: 0 var(--gut) clamp(56px, 9vh, 110px); }
.hero .eyebrow { color: color-mix(in oklch, var(--paper) 88%, transparent); margin-bottom: 1.6em; }
.hero h1 { font-family: var(--jp); font-weight: 500; font-size: clamp(34px, 6.4vw, 92px); line-height: 1.28; letter-spacing: 0.08em; text-shadow: 0 2px 40px rgba(0,0,0,.25); }
.hero h1 .small { display:block; font-size: 0.42em; letter-spacing: 0.12em; margin-top: 0.7em; color: color-mix(in oklch, var(--paper) 90%, transparent); }
.hero .en-only h1 { font-family: var(--en); letter-spacing: 0.01em; font-size: clamp(40px,7vw,104px); }
.scroll-cue { position: absolute; left: 50%; bottom: clamp(20px,4vh,34px); transform: translateX(-50%); z-index: 3; display:flex; flex-direction: column; align-items:center; gap: 10px; font-family: var(--label); font-size: 10px; letter-spacing: 0.3em; text-transform: uppercase; color: color-mix(in oklch, var(--paper) 85%, transparent); }
.scroll-cue .ln { width: 1px; height: 46px; background: currentColor; transform-origin: top; animation: cue 2.6s var(--ease) infinite; }
@keyframes cue { 0%{transform:scaleY(0);opacity:0} 30%{opacity:1} 100%{transform:scaleY(1);opacity:0} }

/* =====================================================================
   SECTION SCAFFOLD
   ===================================================================== */
section[id] { scroll-margin-top: 90px; }
.section { padding-block: var(--sp); }
.sec-head { display: flex; align-items: baseline; gap: 1em; margin-bottom: clamp(36px, 5vw, 72px); }
.sec-head .num { font-family: var(--en); font-style: italic; font-size: clamp(14px,1.2vw,18px); color: var(--ink-faint); }
.sec-head .titles { display: flex; flex-direction: column; gap: 0.3em; }
.sec-title { font-family: var(--jp); font-weight: 500; font-size: clamp(28px, 3.4vw, 50px); letter-spacing: 0.1em; line-height: 1.2; }
.sec-title .en-only { font-family: var(--en); letter-spacing: 0.02em; }
.sec-sub { font-family: var(--en); font-style: italic; font-size: clamp(13px,1.1vw,16px); color: var(--ink-faint); letter-spacing: 0.04em; }
.lede { font-size: clamp(15px, 1.35vw, 19px); line-height: 2.3; color: var(--ink-soft); max-width: 40ch; }

/* =====================================================================
   ABOUT
   ===================================================================== */
.about { background: var(--paper); }
.about-top { display: grid; grid-template-columns: 1fr 1.1fr; gap: clamp(32px, 6vw, 110px); align-items: end; }
.about-top .ph { aspect-ratio: 4/5; }
.about-lead { font-family: var(--jp); font-weight: 500; font-size: clamp(22px, 2.6vw, 36px); line-height: 1.9; letter-spacing: 0.08em; margin-bottom: 1.4em; }
.pillars { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(20px, 3vw, 56px); margin-top: clamp(56px, 8vw, 120px); }
.pillar .ph { aspect-ratio: 3/4; margin-bottom: 1.6em; }
.pillar h3 { font-family: var(--jp); font-weight: 500; font-size: clamp(18px,1.6vw,23px); letter-spacing: 0.08em; margin-bottom: 0.7em; }
.pillar .p-en { font-family: var(--en); font-style: italic; color: var(--ink-faint); font-size: 15px; display:block; margin-bottom: 1em; }
.pillar p { font-size: 14.5px; line-height: 2.1; color: var(--ink-soft); }
@media (max-width: 820px){
  .about-top { grid-template-columns: 1fr; gap: 36px; }
  .pillars { grid-template-columns: 1fr; gap: 48px; }
  .pillar .ph { aspect-ratio: 16/10; }
}

/* =====================================================================
   ROOMS
   ===================================================================== */
.rooms { background: var(--paper-2); }
.room { display: grid; grid-template-columns: 1fr 1fr; align-items: center; gap: clamp(28px, 5vw, 96px); padding-block: clamp(44px, 6vw, 88px); border-top: 1px solid var(--line); }
.room:first-of-type { border-top: 0; }
.room .ph { aspect-ratio: 5/4; }
.room.flip .room-media { order: 2; }
.room-no { font-family: var(--en); font-style: italic; font-size: clamp(14px,1.2vw,18px); color: var(--ink-faint); margin-bottom: 1.1em; }
.room h3 { font-family: var(--jp); font-weight: 500; display: flex; align-items: baseline; gap: 0.7em; margin-bottom: 1em; }
.room h3 .kanji { font-size: clamp(34px, 4vw, 60px); letter-spacing: 0.12em; line-height: 1; }
.room h3 .rom { font-family: var(--en); font-style: italic; font-size: clamp(16px,1.4vw,22px); color: var(--ink-faint); }
.room p { font-size: 15px; line-height: 2.2; color: var(--ink-soft); max-width: 38ch; margin-bottom: 1.6em; }
.room .specs { display: flex; gap: 1.6em; flex-wrap: wrap; font-family: var(--label); font-size: 11.5px; letter-spacing: 0.14em; color: var(--ink-faint); text-transform: uppercase; margin-bottom: 1.8em; }
.room .specs span { position: relative; padding-left: 1.1em; }
.room .specs span::before { content:"—"; position:absolute; left:0; }
@media (max-width: 820px){
  .room { grid-template-columns: 1fr; gap: 24px; padding-block: 48px; }
  .room.flip .room-media { order: 0; }
  .room .ph { aspect-ratio: 16/11; }
}

/* =====================================================================
   DINING
   ===================================================================== */
.dining { background: var(--sea-deep); color: var(--paper); }
.dining .sec-head .num, .dining .sec-sub { color: oklch(0.74 0.03 220); }
.dining .label { color: oklch(0.74 0.03 220); }
.dine-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: clamp(20px, 3vw, 48px); }
.dine .ph { aspect-ratio: 4/3; margin-bottom: 1.6em; }
.dine h3 { font-family: var(--jp); font-weight: 500; font-size: clamp(19px,1.8vw,26px); letter-spacing: 0.08em; margin-bottom: 0.4em; }
.dine .d-en { font-family: var(--en); font-style: italic; color: oklch(0.78 0.03 220); font-size: 15px; display:block; margin-bottom: 1em; }
.dine p { font-size: 14.5px; line-height: 2.1; color: oklch(0.86 0.02 220); }
@media (max-width: 820px){ .dine-grid { grid-template-columns: 1fr; gap: 44px; } }

/* =====================================================================
   EXPERIENCE
   ===================================================================== */
.exp { background: var(--paper); }
.exp-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: clamp(28px, 4vw, 64px) clamp(28px, 5vw, 90px); }
.exp-item { display: grid; grid-template-columns: 0.9fr 1.1fr; gap: clamp(18px,2.4vw,34px); align-items: center; }
.exp-item .ph { aspect-ratio: 1/1; }
.exp-item .x-no { font-family: var(--en); font-style: italic; color: var(--ink-faint); font-size: 14px; margin-bottom: .7em; }
.exp-item h3 { font-family: var(--jp); font-weight: 500; font-size: clamp(18px,1.7vw,24px); letter-spacing: 0.06em; margin-bottom: .5em; }
.exp-item .e-en { font-family: var(--en); font-style: italic; color: var(--ink-faint); font-size: 14px; display:block; margin-bottom: .9em; }
.exp-item p { font-size: 14px; line-height: 2; color: var(--ink-soft); }
.exp-item .tag { display:inline-block; margin-top: .8em; font-family: var(--label); font-size: 10.5px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--wood); border:1px solid color-mix(in oklch,var(--wood) 45%, var(--line)); border-radius: 999px; padding: .35em .9em; }
@media (max-width: 900px){ .exp-grid { grid-template-columns: 1fr; } }
@media (max-width: 480px){ .exp-item { grid-template-columns: 1fr; } .exp-item .ph{aspect-ratio:16/10;} }

/* =====================================================================
   COMMUNITY SPACE
   ===================================================================== */
.community { background: var(--paper-3); }
.comm-top { display: grid; grid-template-columns: 1.15fr 0.85fr; gap: clamp(30px,5vw,90px); align-items: center; margin-bottom: clamp(40px,6vw,80px); }
.comm-top .ph { aspect-ratio: 16/11; }
.comm-cards { display: grid; grid-template-columns: repeat(4,1fr); gap: 1px; background: var(--line); border: 1px solid var(--line); }
.comm-card { background: var(--paper); padding: clamp(24px,2.6vw,38px); display:flex; flex-direction: column; gap: .6em; min-height: 200px; transition: background .4s; }
.comm-card:hover { background: var(--paper-2); }
.comm-card .c-no { font-family: var(--en); font-style: italic; color: var(--ink-faint); font-size: 14px; }
.comm-card h4 { font-family: var(--jp); font-weight: 500; font-size: clamp(17px,1.5vw,21px); letter-spacing: .06em; margin-top: .3em; }
.comm-card .c-en { font-family: var(--en); font-style: italic; color: var(--ink-faint); font-size: 13.5px; }
.comm-card p { font-size: 13.5px; line-height: 1.95; color: var(--ink-soft); margin-top: .5em; }
.comm-card.cta { background: var(--sea); color: var(--paper); }
.comm-card.cta .c-no, .comm-card.cta .c-en { color: oklch(0.85 0.03 220); }
.comm-card.cta:hover { background: var(--sea-deep); }
.comm-card.cta .arrow { margin-top: auto; font-family: var(--label); font-size: 11px; letter-spacing: .2em; text-transform: uppercase; }
@media (max-width: 900px){ .comm-top{grid-template-columns:1fr;} .comm-cards{grid-template-columns:repeat(2,1fr);} }
@media (max-width: 520px){ .comm-cards{grid-template-columns:1fr;} }

/* =====================================================================
   AROUND (周辺のおすすめ)
   ===================================================================== */
.around { background: var(--paper); }
.around-grid { display: grid; grid-template-columns: repeat(12, 1fr); gap: clamp(14px, 1.6vw, 22px); }
.around-cell { position: relative; overflow: hidden; }
.around-cell .ph { position:absolute; inset:0; transition: transform 1.2s var(--ease); }
.around-cell:hover .ph { transform: scale(1.05); }
.around-cell .cap { position: absolute; left: 0; bottom: 0; z-index: 2; padding: clamp(16px,1.6vw,24px); color: var(--paper); }
.around-cell::after { content:""; position:absolute; inset:0; z-index:1; background:linear-gradient(0deg, rgba(20,22,20,.55), rgba(20,22,20,0) 55%); }
.around-cell .cap .a-en { font-family: var(--en); font-style: italic; font-size: 13px; opacity: .85; display:block; }
.around-cell .cap .a-jp { font-family: var(--jp); font-weight: 500; font-size: clamp(17px,1.6vw,22px); letter-spacing: .06em; }
.around-cell.big { grid-column: span 6; aspect-ratio: 16/10; }
.around-cell.tall { grid-column: span 6; aspect-ratio: 16/10; }
.around-cell.third { grid-column: span 4; aspect-ratio: 4/5; }
@media (max-width: 820px){
  .around-cell.big, .around-cell.tall { grid-column: span 12; }
  .around-cell.third { grid-column: span 6; aspect-ratio: 1/1; }
}

/* =====================================================================
   ACCESS
   ===================================================================== */
.access { background: var(--paper-2); }
.access-grid { display: grid; grid-template-columns: 1.2fr 0.8fr; gap: clamp(30px,5vw,80px); }
.access-map { aspect-ratio: 16/10; }
.access-info dl { margin: 0; }
.access-info .row { padding-block: clamp(16px,1.6vw,22px); border-top: 1px solid var(--line); }
.access-info .row:first-child { border-top: 0; }
.access-info dt { font-family: var(--label); font-size: 11px; letter-spacing: .24em; text-transform: uppercase; color: var(--ink-faint); margin-bottom: .6em; }
.access-info dd { margin: 0; font-size: 15px; line-height: 2; }
.access-info .row .sub { color: var(--ink-soft); font-size: 14px; }

/* =====================================================================
   BLOG
   ===================================================================== */
.blog { background: var(--paper); }
.blog-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: clamp(22px,3vw,48px); }
.post .ph { aspect-ratio: 3/2; margin-bottom: 1.3em; overflow:hidden; }
.post .ph > .inner { position:absolute; inset:0; transition: transform 1.1s var(--ease); }
.post:hover .ph { }
.post .p-meta { display:flex; gap: 1em; align-items:center; font-family: var(--label); font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: var(--ink-faint); margin-bottom: .8em; }
.post .p-meta .cat { color: var(--sea); }
.post h4 { font-family: var(--jp); font-weight: 500; font-size: clamp(17px,1.5vw,21px); line-height: 1.7; letter-spacing: .04em; }
.post:hover h4 { color: var(--sea); transition: color .3s; }
@media (max-width: 820px){ .blog-grid{grid-template-columns:1fr;} }

/* =====================================================================
   CONTACT / FOOTER
   ===================================================================== */
.contact { background: var(--sea-deep); color: var(--paper); padding-top: var(--sp); }
.contact .label { color: oklch(0.74 0.03 220); }
.contact-head { text-align: center; margin-bottom: clamp(40px,6vw,72px); }
.contact-head h2 { font-family: var(--jp); font-weight: 500; font-size: clamp(28px,4vw,56px); letter-spacing: .1em; margin-top: .4em; }
.contact-head .en-only h2 { font-family: var(--en); letter-spacing: .02em; }
.contact-actions { display:flex; justify-content:center; gap: clamp(14px,2vw,24px); flex-wrap: wrap; }
.c-btn { font-family: var(--label); font-size: 12px; letter-spacing: .2em; text-transform: uppercase; padding: 1.1em 2.4em; border-radius: 999px; transition: transform .4s var(--ease), background .4s, color .4s; }
.c-btn.primary { background: var(--paper); color: var(--ink); }
.c-btn.primary:hover { transform: translateY(-3px); }
.c-btn.ghost { border: 1px solid color-mix(in oklch, var(--paper) 55%, transparent); }
.c-btn.ghost:hover { background: color-mix(in oklch, var(--paper) 14%, transparent); }

.foot { border-top: 1px solid color-mix(in oklch, var(--paper) 18%, transparent); margin-top: var(--sp); padding-block: clamp(40px,5vw,64px); }
.foot-grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr; gap: clamp(28px,4vw,60px); }
.foot .brand .mark, .foot .brand .rom { color: var(--paper); }
.foot .f-addr { color: oklch(0.82 0.02 220); font-size: 14px; line-height: 2; margin-top: 1.4em; }
.foot-col h5 { font-family: var(--label); font-size: 11px; letter-spacing: .24em; text-transform: uppercase; color: oklch(0.72 0.03 220); margin-bottom: 1.3em; }
.foot-col a { display:block; font-size: 14px; line-height: 2.3; color: oklch(0.9 0.015 220); transition: color .3s; }
.foot-col a:hover { color: var(--paper); }
.foot-bottom { display:flex; justify-content: space-between; align-items:center; flex-wrap: wrap; gap: 12px; margin-top: clamp(40px,5vw,64px); padding-top: clamp(24px,3vw,32px); border-top: 1px solid color-mix(in oklch, var(--paper) 14%, transparent); font-family: var(--label); font-size: 11px; letter-spacing: .16em; color: oklch(0.74 0.025 220); text-transform: uppercase; }
.foot-bottom a:hover { color: var(--paper); }
@media (max-width: 820px){ .foot-grid{grid-template-columns:1fr; gap:36px;} }
