/* =========================================================
   Trattoria Celeste — demo site
   Claude Design ハンドオフ（Trattoria Celeste.dc.html）の静的実装
   インライン style をクラス化した共通スタイル
   ※ 配色・タイポ・余白はデザイン値を踏襲（pixel-perfect 優先）
   ========================================================= */

:root{
  --bg:#FFFFFF;--bg2:#FFFFFF;--card:#fff;
  --ink:#2A2521;--ink2:#73695E;--ink3:#A89E91;
  --accent:#BC5A38;--accent2:#9B4526;--accentsoft:#EBD2BC;
  --line:rgba(42,37,33,.12);--line2:rgba(42,37,33,.06);
  --fen:'Schibsted Grotesk',sans-serif;
  --fja:'Zen Kaku Gothic New','Schibsted Grotesk',sans-serif;
}
[data-tone="olive"]{
  --bg:#FFFFFF;--bg2:#FFFFFF;--card:#fff;
  --ink:#272820;--ink2:#5F6150;--ink3:#9B9C89;
  --accent:#6F7A47;--accent2:#525C31;--accentsoft:#D7DBBE;
  --line:rgba(39,40,32,.12);--line2:rgba(39,40,32,.06);
}
/* 地中海カラー案 ----------------------------------------- */
/* A. エーゲ海ブルー（深い青・サントリーニのドーム） */
[data-tone="aegean"]{
  --bg:#FFFFFF;--bg2:#F6FAFC;--card:#fff;
  --ink:#16313D;--ink2:#566F7B;--ink3:#94A8B1;
  --accent:#1A6E96;--accent2:#114E6E;--accentsoft:#C4DEEA;
  --line:rgba(22,49,61,.12);--line2:rgba(22,49,61,.06);
}
/* B. サントリーニ（明るい空色×白）／背景は白で統一（--bg2 も白） */
[data-tone="santorini"]{
  --bg:#FFFFFF;--bg2:#FFFFFF;--card:#fff;
  --ink:#1C3A4B;--ink2:#5E7682;--ink3:#9BB0BB;
  --accent:#2E86C1;--accent2:#1F6699;--accentsoft:#D4E9F4;
  --line:rgba(28,58,75,.12);--line2:rgba(28,58,75,.06);
}
/* C. ターコイズ（浅瀬の青緑・シーグラス） */
[data-tone="teal"]{
  --bg:#FFFFFF;--bg2:#F4FBF9;--card:#fff;
  --ink:#163A38;--ink2:#566E69;--ink3:#93ABA6;
  --accent:#1F9C8E;--accent2:#147268;--accentsoft:#BFE5DE;
  --line:rgba(22,58,56,.12);--line2:rgba(22,58,56,.06);
}
/* D. オリーブ・グローブ（地中海の緑） … olive と同系の調整版 */
[data-tone="olive-med"]{
  --bg:#FFFFFF;--bg2:#F8F9F2;--card:#fff;
  --ink:#272820;--ink2:#5F6150;--ink3:#9B9C89;
  --accent:#6F7A47;--accent2:#4F5A2F;--accentsoft:#D9DFBE;
  --line:rgba(39,40,32,.12);--line2:rgba(39,40,32,.06);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:var(--bg);color:var(--ink);font-family:var(--fja);
  min-height:100vh;overflow-x:hidden;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img{display:block;max-width:100%}
button{font-family:inherit;color:inherit;cursor:pointer;border:none;background:none;padding:0}
a{color:inherit;text-decoration:none}
input,textarea,select{font-family:inherit;font-size:inherit;color:inherit}
::selection{background:var(--accent);color:#fff}

/* ---- layout containers ---- */
.container{max-width:1320px;margin:0 auto;padding:0 clamp(18px,4vw,56px)}
.container--narrow{max-width:1100px;margin:0 auto;padding:0 clamp(18px,4vw,56px)}
.container--form{max-width:980px;margin:0 auto;padding:0 clamp(18px,4vw,56px)}
.section{padding-top:clamp(92px,12vw,180px);padding-bottom:clamp(92px,12vw,180px)}
.section--tight{padding-top:clamp(84px,10vw,156px);padding-bottom:clamp(84px,10vw,156px)}

/* ---- buttons ---- */
.btn{display:inline-flex;align-items:center;gap:10px;border-radius:999px;font-family:var(--fen);font-weight:600;letter-spacing:.05em;line-height:1;transition:.25s}
.btn--xs{padding:12px 24px;font-size:13px;letter-spacing:.06em}
.btn--sm{padding:14px 26px;font-size:13px;letter-spacing:.04em}
.btn--md{padding:15px 30px;font-size:13.5px}
.btn--lg{padding:17px 34px;font-size:14px}
.btn--accent{background:var(--accent);color:#fff}
.btn--accent:hover{background:var(--accent2)}
.btn--dark{background:var(--ink);color:var(--bg)}
.btn--dark:hover{background:var(--accent)}
.btn--outline{background:transparent;color:var(--ink);border:1px solid var(--ink)}
.btn--outline:hover{background:var(--ink);color:var(--bg)}
.btn--white{background:#fff;color:var(--accent)}
.btn--lift:hover{transform:translateY(-2px)}
/* CTAアイコン（シェブロン）— SVG line / currentColor */
.ico{flex:none;width:16px;height:16px;vertical-align:-3px;transition:transform .25s ease}
.btn:hover .ico,.submit:hover .ico,.fab a:hover .ico,.map-lg__link:hover .ico{transform:translateX(2px)}

/* ---- eyebrow / titles ---- */
.eyebrow{font-family:var(--fen);font-weight:600;font-size:12px;letter-spacing:.24em;text-transform:uppercase;color:var(--accent);margin:0 0 18px}
.eyebrow--soft{color:var(--accentsoft)}
.sec-title{margin:0;font-weight:700;font-size:clamp(21px,2.8vw,32px);line-height:1.34}

/* ---- top bar ---- */
.topbar{background:var(--ink);color:rgba(255,255,255,.82);font-size:11.5px;letter-spacing:.04em}
.topbar__inner{max-width:1320px;margin:0 auto;padding:9px clamp(18px,4vw,56px);display:flex;flex-wrap:wrap;gap:8px 26px;align-items:center;justify-content:space-between}
.topbar__loc{font-family:var(--fen);letter-spacing:.16em;text-transform:uppercase;color:var(--accentsoft)}
.topbar__hours{display:flex;flex-wrap:wrap;gap:6px 18px;align-items:center}
.topbar__hours .tel{font-family:var(--fen);letter-spacing:.05em}
.sep{opacity:.4}

/* ---- header / nav ---- */
.header{position:sticky;top:0;z-index:90;background:color-mix(in srgb,var(--bg) 95%,transparent);border-bottom:1px solid var(--line)}
.header__inner{max-width:1320px;margin:0 auto;padding:16px clamp(18px,4vw,56px);display:flex;align-items:center;justify-content:space-between;gap:24px}
.brand{display:flex;flex-direction:column;gap:2px;text-align:left}
.brand__sup{font-family:var(--fen);font-size:10px;letter-spacing:.42em;color:var(--accent);text-transform:uppercase}
.brand__name{font-family:var(--fen);font-size:23px;font-weight:600;letter-spacing:.18em;line-height:.9}
.brand__logo{display:block;height:48px;width:auto}
@media(max-width:600px){.brand__logo{height:38px}}
.nav{display:flex;align-items:center;gap:clamp(14px,2.6vw,40px)}
.nav__link{font-family:var(--fen);font-size:13px;font-weight:500;letter-spacing:.1em;transition:.2s}
.nav__link:hover{color:var(--accent)}
/* ---- mobile nav (hamburger) ---- */
.nav-toggle{display:none;width:44px;height:44px;flex-direction:column;align-items:center;justify-content:center;gap:5px;background:none;border:0;padding:0;cursor:pointer;color:var(--ink)}
.nav-toggle__bar{display:block;width:24px;height:2px;border-radius:2px;background:currentColor;transition:transform .3s ease,opacity .2s ease}
.nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
@media(max-width:820px){
  .nav-toggle{display:inline-flex;position:relative;z-index:120}
  .nav-toggle[aria-expanded="true"]{color:#fff}
  .nav{position:fixed;top:0;left:0;width:100%;height:100vh;height:100dvh;z-index:100;flex-direction:column;align-items:center;justify-content:center;gap:24px;background:var(--ink);padding:84px 24px 48px;transform:scale(1.06);opacity:0;visibility:hidden;pointer-events:none;transition:opacity .32s ease,transform .32s ease,visibility .32s}
  .nav.nav--open{transform:none;opacity:1;visibility:visible;pointer-events:auto}
  .nav__link{color:#fff;font-size:23px;letter-spacing:.12em;padding:6px 0}
  .nav .nav__link:hover{color:var(--accentsoft)}
  .nav .btn{margin-top:12px}
  .nav .btn--accent{background:#fff;color:var(--accent);padding:14px 38px;font-size:15px}
  .nav .btn--accent:hover{background:#fff;color:var(--accent2)}
}
.nav__link[aria-current="page"]{color:var(--accent)}

/* ---- hero (home) ---- */
.hero{display:flex;flex-wrap:wrap;border-bottom:1px solid var(--line)}
.hero__text{flex:1 1 460px;display:flex;flex-direction:column;justify-content:center;padding:clamp(72px,8vw,140px) clamp(28px,5vw,96px);position:relative}
.hero__eyebrow{font-family:var(--fen);font-weight:600;font-size:12px;letter-spacing:.24em;text-transform:uppercase;color:var(--accent);margin-bottom:26px}
.hero h1{margin:0;font-weight:700;font-size:clamp(28px,3.6vw,46px);line-height:1.26;letter-spacing:.02em}
.hero__lead{margin:28px 0 0;color:var(--ink2);font-size:14px;line-height:2.05}
.hero__lead b{color:var(--ink);font-weight:500}
.hero__actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:38px}
.hero__status{display:flex;flex-wrap:wrap;gap:8px 22px;align-items:center;margin-top:42px;padding-top:26px;border-top:1px solid var(--line);font-size:12.5px;color:var(--ink2)}
.hero__open{display:inline-flex;align-items:center;gap:7px;font-weight:500;color:var(--ink)}
.hero__dot{width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 3px var(--accentsoft)}
.hero__media{flex:1 1 520px;position:relative;min-height:clamp(380px,62vh,720px);display:flex;padding:clamp(16px,2.2vw,40px)}
.hero__frame{position:relative;flex:1 1 auto;border-radius:12px;overflow:hidden;background:linear-gradient(135deg,var(--bg2),var(--accentsoft));box-shadow:0 20px 50px rgba(13,28,38,.12)}
.hero__media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero__vtag{position:absolute;top:24px;right:24px;writing-mode:vertical-rl;font-family:var(--fen);font-size:11px;letter-spacing:.34em;color:rgba(255,255,255,.9);text-transform:uppercase;text-shadow:0 1px 8px rgba(0,0,0,.4)}
/* HERO キャッチ：縦書き和文（C）＋写真の装飾筆記体 */
.cpro{display:flex;gap:18px;align-items:stretch;margin:8px 0 30px}
.hero .v-head{writing-mode:vertical-rl;font-family:var(--fja);font-weight:500;font-size:clamp(25px,3.1vw,44px);line-height:2.2;letter-spacing:.2em;margin:0;color:var(--ink)}
.v-head em{color:var(--accent);font-style:normal}
.cpro__rule{width:2px;background:linear-gradient(180deg,var(--accent),color-mix(in srgb,var(--accent) 8%,transparent));border-radius:2px}
.hero__scrim{position:absolute;inset:0;z-index:1;background:linear-gradient(to top,rgba(13,28,38,.30),rgba(13,28,38,0) 50%);pointer-events:none}
.hero__script{position:absolute;left:clamp(16px,2vw,34px);bottom:clamp(14px,2vw,30px);z-index:2;margin:0;font-family:'Great Vibes',cursive;font-weight:400;font-size:clamp(38px,5.4vw,88px);line-height:.9;color:#DCE6F0;pointer-events:none;white-space:nowrap}
@media(max-width:600px){.hero__text{padding-bottom:36px}}

/* ---- section head (title + lead) ---- */
.sec-head{display:flex;flex-wrap:wrap;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:68px}
.sec-head__lead{color:var(--ink2);font-size:14px;line-height:1.95;margin:0}

/* ---- scenes grid ---- */
.scenes{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:clamp(12px,1.6vw,22px)}
.scene{position:relative;border-radius:3px;overflow:hidden;aspect-ratio:3/4;background:var(--bg2)}
.scene img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:.6s}
.scene:hover img{transform:scale(1.05)}
.scene__shade{position:absolute;inset:0;background:linear-gradient(to top,rgba(20,16,12,.82),rgba(20,16,12,.05) 55%)}
.scene__body{position:absolute;left:0;right:0;bottom:0;padding:22px 22px 24px;color:#fff}
.scene__tag{font-family:var(--fen);font-size:10.5px;letter-spacing:.26em;text-transform:uppercase;color:var(--accentsoft);margin-bottom:8px}
.scene__title{font-weight:700;font-size:18px;margin-bottom:8px}
.scene__copy{font-size:12.5px;line-height:1.7;color:rgba(255,255,255,.85)}

/* ---- feature (signature) ---- */
.band{background:var(--bg2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.feature{display:flex;flex-wrap:wrap;gap:clamp(36px,5vw,80px);align-items:center}
.feature__media{flex:1 1 420px;position:relative;border-radius:3px;overflow:hidden;aspect-ratio:5/4;background:var(--accentsoft)}
.feature__media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.feature__body{flex:1 1 380px}
.feature__body h2{margin:0;font-weight:700;font-size:clamp(22px,3vw,34px);line-height:1.3}
.feature__body p{margin:24px 0 0;color:var(--ink2);font-size:13.5px;line-height:2.05}

.sig-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:clamp(14px,1.8vw,26px);margin-top:clamp(40px,5vw,68px)}
.sig-card{background:var(--card);border-radius:3px;overflow:hidden;border:1px solid var(--line)}
.sig-card__media{aspect-ratio:4/3;background:var(--bg2);overflow:hidden}
.sig-card__media img{width:100%;height:100%;object-fit:cover;transition:.6s}
.sig-card:hover .sig-card__media img{transform:scale(1.05)}
.sig-card__body{padding:22px 24px 26px}
.row-baseline{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-bottom:6px}
.sig-card__name{font-weight:700;font-size:17px}
.price{font-family:var(--fen);font-weight:600;font-size:13.5px;color:var(--accent);white-space:nowrap}
.it-label{font-family:var(--fen);font-style:italic;font-size:12.5px;letter-spacing:.04em;color:var(--ink3);margin-bottom:12px}
.sig-card__copy{margin:0;font-size:13px;line-height:1.8;color:var(--ink2)}

/* ---- story / pillars ---- */
.story{display:flex;flex-wrap:wrap;gap:clamp(36px,5vw,84px)}
.story__text{flex:1 1 360px}
.story__text h2{margin:0;font-weight:700;font-size:clamp(22px,3vw,34px);line-height:1.3}
.story__lead{margin:24px 0 36px;color:var(--ink2);font-size:13.5px;line-height:2.05}
.pillars{display:flex;flex-direction:column;border-top:1px solid var(--line)}
.pillar{display:flex;gap:22px;padding:24px 0;border-bottom:1px solid var(--line);align-items:flex-start}
.pillar__no{font-family:var(--fen);font-size:13px;font-weight:600;color:var(--accent);padding-top:3px}
.pillar__title{font-weight:700;font-size:17px;margin-bottom:8px}
.pillar__copy{margin:0;font-size:13.5px;line-height:1.85;color:var(--ink2)}
.story__media{flex:1 1 380px;display:flex;flex-direction:column;gap:clamp(14px,1.8vw,22px)}
.story__media-main{flex:2;position:relative;border-radius:3px;overflow:hidden;min-height:300px;background:var(--bg2)}
.story__media-row{flex:1;display:flex;gap:clamp(14px,1.8vw,22px)}
.story__media-cell{flex:1;position:relative;border-radius:3px;overflow:hidden;min-height:170px;background:var(--bg2)}
.cover{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}

/* ---- atmosphere band ---- */
.atmos{position:relative}
.atmos__media{position:relative;min-height:clamp(360px,52vh,580px);overflow:hidden}
.atmos__shade{position:absolute;inset:0;background:linear-gradient(90deg,rgba(20,15,11,.78),rgba(20,15,11,.18))}
.atmos__inner{position:relative;max-width:1320px;margin:0 auto;padding:clamp(56px,8vw,110px) clamp(18px,4vw,56px);min-height:inherit;display:flex;flex-direction:column;justify-content:center}
.atmos__inner h2{margin:0;color:#fff;font-weight:700;font-size:clamp(22px,3vw,34px);line-height:1.34;max-width:600px}
.atmos__inner p{margin:24px 0 0;color:rgba(255,255,255,.82);font-size:13.5px;line-height:2}

/* ---- news ---- */
.news{border-top:1px solid var(--line)}
.news__row{width:100%;text-align:left;display:flex;flex-wrap:wrap;align-items:center;gap:10px 26px;padding:22px 4px;border-bottom:1px solid var(--line);transition:.2s}
.news__row:hover{background:rgba(0,0,0,.035);padding-left:14px}
.news__date{font-family:var(--fen);font-size:13px;letter-spacing:.06em;color:var(--ink2);min-width:88px}
.news__cat{font-family:var(--fen);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);border:1px solid var(--accent);border-radius:999px;padding:4px 12px}
.news__title{font-size:13.5px;font-weight:500;flex:1}
.news__arrow{color:var(--ink3);font-size:14px}

/* ---- access card (home) + map ---- */
.access-cta{display:flex;flex-wrap:wrap;border:1px solid var(--line);border-radius:4px;overflow:hidden}
.access-cta__body{flex:1 1 360px;padding:clamp(36px,4vw,60px)}
.info-dl{margin:0;display:grid;grid-template-columns:auto 1fr;gap:16px 22px;font-size:14px}
.info-dl dt{color:var(--ink3);font-family:var(--fen);font-size:11px;letter-spacing:.12em;text-transform:uppercase;padding-top:3px}
.info-dl dd{margin:0;line-height:1.8}
.access-cta__actions{display:flex;gap:12px;margin-top:30px;flex-wrap:wrap}
.map{flex:1 1 380px;min-height:320px;position:relative;background:var(--bg2);border-left:1px solid var(--line)}
.map__grid{position:absolute;inset:0;background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);background-size:46px 46px;opacity:.7}
.map__plot{position:absolute;left:30%;top:42%;width:38%;height:30%;background:var(--card);border:1px solid var(--line);transform:rotate(-4deg)}
.map__pin{position:absolute;left:50%;top:50%;transform:translate(-50%,-100%);display:flex;flex-direction:column;align-items:center;gap:6px}
.map__pin-label{background:var(--accent);color:#fff;font-family:var(--fen);font-size:11px;font-weight:600;letter-spacing:.08em;padding:7px 14px;border-radius:999px;box-shadow:0 6px 16px rgba(0,0,0,.18);white-space:nowrap}
.map__pin-stem{width:2px;height:14px;background:var(--accent)}
.map__pin-dot{width:9px;height:9px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 4px color-mix(in srgb,var(--accent) 28%,transparent)}

/* ---- page head (menu/access/reservation) ---- */
.page-head{background:var(--bg2);border-bottom:1px solid var(--line)}
.page-head__inner{padding:clamp(84px,10vw,148px) clamp(18px,4vw,56px) clamp(40px,5vw,64px)}
.page-head h1{margin:0;font-weight:700;font-size:clamp(27px,4vw,44px);letter-spacing:.04em;font-family:var(--fen)}
.page-head__lead{margin:22px 0 0;color:var(--ink2);font-size:13.5px;line-height:2}

/* ---- menu: weekly feature ---- */
.weekly{background:var(--ink);color:var(--bg);border-radius:4px;overflow:hidden;display:flex;flex-wrap:wrap}
.weekly__media{flex:1 1 280px;min-height:240px;position:relative;background:var(--accentsoft)}
.weekly__body{flex:1 1 340px;padding:clamp(30px,3.5vw,52px);display:flex;flex-direction:column;justify-content:center}
.weekly__label{font-family:var(--fen);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--accentsoft);margin-bottom:14px}
.weekly__body h2{margin:0 0 14px;font-weight:700;font-size:clamp(20px,2.4vw,27px);color:#fff}
.weekly__body p{margin:0 0 20px;font-size:13.5px;line-height:1.95;color:rgba(255,255,255,.82)}
.weekly__price{font-family:var(--fen);font-weight:600;font-size:22px;color:var(--accentsoft)}
.weekly__note{margin-top:18px;font-size:11.5px;letter-spacing:.04em;color:rgba(255,255,255,.5)}

/* ---- menu section heads + lunch grid ---- */
.menu-head{display:flex;align-items:baseline;gap:18px;margin-bottom:42px;border-bottom:1px solid var(--ink);padding-bottom:14px}
.menu-head__it{font-family:var(--fen);font-weight:700;font-size:clamp(18px,2.2vw,24px);letter-spacing:.02em}
.menu-head__ja{font-weight:700;font-size:17px}
.menu-head__time{margin-left:auto;font-size:12.5px;color:var(--ink2)}
.lunch-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:clamp(14px,1.8vw,24px)}
.m-card{background:var(--card);border:1px solid var(--line);border-radius:3px;overflow:hidden}
.m-card__media{aspect-ratio:4/3;background:var(--bg2);overflow:hidden}
.m-card__media img{width:100%;height:100%;object-fit:cover;transition:.6s}
.m-card:hover .m-card__media img{transform:scale(1.05)}
.m-card__body{padding:20px 22px 24px}
.m-card__name{font-weight:700;font-size:14px;line-height:1.4}
.m-card__desc{margin:10px 0 0;font-size:12.5px;line-height:1.75;color:var(--ink2)}

/* ---- menu: dinner list + courses + drinks ---- */
.dinner{display:flex;flex-wrap:wrap;gap:clamp(36px,5vw,64px)}
.dinner__col{flex:1 1 300px;display:flex;flex-direction:column;gap:30px}
.dgroup__head{display:flex;align-items:baseline;gap:12px;margin-bottom:14px}
.dgroup__it{font-family:var(--fen);font-style:italic;font-size:13px;letter-spacing:.04em;color:var(--accent)}
.dgroup__ja{font-weight:700;font-size:14px}
.ditem{display:flex;align-items:baseline;gap:12px;padding:13px 0;border-bottom:1px dotted var(--line)}
.ditem__name{font-size:13.5px;font-weight:500}
.ditem__dots{flex:1;border-bottom:1px dotted var(--line);transform:translateY(-4px)}
.ditem__price{font-family:var(--fen);font-weight:600;font-size:14px;color:var(--accent);white-space:nowrap}
.courses-col{flex:1 1 280px}
.courses-col__label{font-family:var(--fen);font-style:italic;font-size:13px;letter-spacing:.04em;color:var(--accent);margin-bottom:16px}
.courses{display:flex;flex-direction:column;gap:16px}
.course{background:var(--bg2);border:1px solid var(--line);border-radius:3px;padding:24px 26px}
.course__row{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-bottom:8px}
.course__name{font-weight:700;font-size:16px}
.course__price{font-family:var(--fen);font-weight:600;font-size:17px;color:var(--accent)}
.course__desc{margin:0;font-size:12.5px;line-height:1.8;color:var(--ink2)}
.note{font-size:11.5px;line-height:1.7;color:var(--ink3)}
.drinks{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px 40px}
.drink{display:flex;align-items:baseline;gap:12px;padding:12px 0;border-bottom:1px dotted var(--line)}
.drink__name{font-size:14px;font-weight:500}
.drink__sp{flex:1}
.drink__price{font-family:var(--fen);font-weight:600;font-size:13.5px;color:var(--accent);white-space:nowrap}

/* ---- promo band (accent) ---- */
.promo{background:var(--accent);color:#fff;border-radius:4px;padding:clamp(36px,4vw,56px);display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:24px}
.promo h2{margin:0 0 8px;font-weight:700;font-size:clamp(18px,2.2vw,24px)}
.promo p{margin:0;font-size:14px;color:rgba(255,255,255,.85)}

/* ---- split (about hero) ---- */
.split{display:flex;flex-wrap:wrap;border-bottom:1px solid var(--line)}
.split__media{flex:1 1 420px;position:relative;min-height:clamp(340px,52vh,560px);background:var(--bg2)}
.split__body{flex:1 1 420px;display:flex;flex-direction:column;justify-content:center;padding:clamp(68px,8vw,132px) clamp(24px,4vw,72px)}
.split__body h1{margin:0;font-weight:700;font-size:clamp(23px,3vw,36px);line-height:1.3}
.split__body p{margin:26px 0 0;color:var(--ink2);font-size:13.5px;line-height:2.05}

/* ---- about: chef ---- */
.chef{display:flex;flex-wrap:wrap;gap:clamp(36px,5vw,72px);align-items:center}
.chef__media{flex:1 1 300px;position:relative;border-radius:3px;overflow:hidden;aspect-ratio:4/5;max-width:380px;background:var(--accentsoft)}
.chef__body{flex:1 1 380px}
.chef__name{margin:0 0 4px;font-weight:700;font-size:clamp(20px,2.4vw,27px)}
.chef__role{font-family:var(--fen);font-style:italic;font-size:14px;color:var(--ink3);margin-bottom:24px}
.chef__body p{margin:0 0 16px;color:var(--ink2);font-size:13.5px;line-height:2.05}
.chef__body p:last-child{margin-bottom:0}

/* ---- about: commitment ---- */
.commit-head{text-align:center;margin-bottom:64px}
.commit-head .eyebrow{margin-bottom:14px}
.commit-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:clamp(16px,2vw,28px)}
.commit-card{background:var(--card);border:1px solid var(--line);border-radius:3px;padding:34px 30px}
.commit-card__no{font-family:var(--fen);font-weight:600;font-size:13px;color:var(--accent);margin-bottom:18px}
.commit-card h3{margin:0 0 12px;font-weight:700;font-size:18px}
.commit-card p{margin:0;font-size:13.5px;line-height:1.95;color:var(--ink2)}

/* ---- gallery ---- */
.gallery{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:clamp(12px,1.6vw,20px)}
.gallery__item{position:relative;aspect-ratio:1;border-radius:3px;overflow:hidden;background:var(--bg2)}

/* ---- access page ---- */
.map-lg{position:relative;border-radius:4px;overflow:hidden;border:1px solid var(--line);height:clamp(280px,38vh,420px);background:var(--bg2)}
.map-lg__grid{position:absolute;inset:0;background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);background-size:54px 54px;opacity:.7}
.map-lg__plot{position:absolute;background:var(--card);border:1px solid var(--line)}
.map-lg__plot--a{left:18%;top:34%;width:30%;height:34%;transform:rotate(-3deg)}
.map-lg__plot--b{right:14%;top:20%;width:26%;height:26%;transform:rotate(2deg)}
.map-lg__road{position:absolute;left:0;right:0;top:60%;height:14px;background:var(--accentsoft);opacity:.6}
.map-lg__pin-label{background:var(--accent);color:#fff;font-family:var(--fen);font-size:12px;font-weight:600;letter-spacing:.08em;padding:8px 16px;border-radius:999px;box-shadow:0 8px 20px rgba(0,0,0,.2);white-space:nowrap}
.map-lg__pin-stem{width:2px;height:16px;background:var(--accent)}
.map-lg__pin-dot{width:11px;height:11px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 5px color-mix(in srgb,var(--accent) 28%,transparent)}
.map-lg__link{position:absolute;right:18px;bottom:18px;display:inline-flex;align-items:center;gap:8px;padding:11px 20px;background:var(--ink);color:var(--bg);border-radius:999px;font-family:var(--fen);font-weight:600;font-size:12.5px;letter-spacing:.04em}
.map__img,.map-lg__img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.map__img{display:block}
.info-cols{display:flex;flex-wrap:wrap;gap:clamp(36px,5vw,72px);margin-top:clamp(40px,5vw,64px)}
.info-cols__main{flex:1 1 320px}
.info-cols__side{flex:1 1 260px}
.block-title{margin:0 0 24px;font-weight:700;font-size:22px}
.info-table{margin:0;display:grid;grid-template-columns:7em 1fr;gap:0;font-size:14px;border-top:1px solid var(--line)}
.info-table dt{padding:16px 0;border-bottom:1px solid var(--line);color:var(--ink2);font-size:13px}
.info-table dd{margin:0;padding:16px 0;border-bottom:1px solid var(--line);line-height:1.7}
.hours-card{background:var(--bg2);border:1px solid var(--line);border-radius:3px;padding:30px 32px}
.hours-row{display:flex;justify-content:space-between;padding:16px 0}
.hours-row--top{padding-bottom:16px;padding-top:0;border-bottom:1px solid var(--line)}
.hours-row .fen{font-family:var(--fen)}
.hours-row .lo{color:var(--ink3);font-size:12px}
.hours-closed{margin-top:8px;padding-top:16px;border-top:1px solid var(--line);font-size:13.5px;color:var(--ink2)}
.tel-btn{display:flex;align-items:center;justify-content:center;gap:10px;margin-top:18px;padding:18px;border:1px solid var(--ink);border-radius:3px;font-family:var(--fen);font-weight:600;font-size:18px;letter-spacing:.04em;transition:.25s}
.tel-btn:hover{background:var(--ink);color:var(--bg)}

/* ---- reservation ---- */
.methods{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px}
.method{background:var(--card);border:1px solid var(--line);border-radius:3px;padding:26px 24px;display:flex;flex-direction:column;gap:8px;transition:.2s}
.method--link:hover{border-color:var(--accent);transform:translateY(-2px)}
.method__label{font-family:var(--fen);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent)}
.method__name{font-weight:700;font-size:16px}
.method__tel{font-family:var(--fen);font-weight:600;font-size:18px;letter-spacing:.02em}
.method__note{font-size:12.5px;color:var(--ink2);line-height:1.7}
.form-card{border:1px solid var(--line);border-radius:4px;padding:clamp(28px,3.5vw,52px)}
.form-card h2{margin:0 0 28px;font-weight:700;font-size:20px;padding-bottom:16px;border-bottom:1px solid var(--line)}
.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:22px 26px}
.field{display:flex;flex-direction:column;gap:9px}
.field--full{margin-top:22px}
.field__label{font-size:12.5px;font-weight:500}
.req{color:var(--accent)}
.inp{padding:13px 14px;border:1px solid var(--line);border-radius:3px;background:var(--bg)}
textarea.inp{resize:vertical}
.agree{display:flex;align-items:flex-start;gap:10px;margin-top:24px;font-size:13px;color:var(--ink2);line-height:1.6}
.agree input{margin-top:3px}
.agree a{color:var(--accent);text-decoration:underline}
.submit{margin-top:30px;width:100%;display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:18px;background:var(--accent);color:#fff;border-radius:999px;font-family:var(--fen);font-weight:600;font-size:13.5px;letter-spacing:.05em;transition:.25s}
.submit:hover{background:var(--accent2)}
.form-notes{display:flex;flex-wrap:wrap;gap:18px 32px;margin-top:36px;padding-top:28px;border-top:1px solid var(--line);font-size:12.5px;color:var(--ink2);line-height:1.8}
.form-note{flex:1 1 240px}
.form-note b{color:var(--ink);font-weight:600}
.success{background:var(--bg2);border:1px solid var(--line);border-radius:4px;padding:clamp(40px,5vw,72px);text-align:center}
.success__check{width:56px;height:56px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:26px;margin:0 auto 22px}
.success h2{margin:0 0 12px;font-weight:700;font-size:24px}
.success p{margin:0 0 26px;color:var(--ink2);font-size:13.5px;line-height:1.95}

/* ---- footer ---- */
/* フッター：ミニマル・センター（レイアウトB）× ライト（配色D） */
.footer{background:#F3F8FC;border-top:1px solid var(--line);color:var(--ink2)}
.footer__inner{max-width:1320px;margin:0 auto;padding:clamp(56px,7vw,88px) clamp(18px,4vw,56px) clamp(40px,5vw,56px);text-align:center}
.foot-sup{font-family:var(--fen);font-size:10px;letter-spacing:.42em;text-transform:uppercase;color:var(--accent);margin-bottom:8px}
.foot-name{font-family:var(--fen);font-size:clamp(28px,4vw,40px);font-weight:600;letter-spacing:.2em;color:var(--ink);margin-bottom:20px}
.foot-logo{display:block;height:54px;width:auto;margin:0 auto 20px}
.foot-info{margin:0 auto 24px;font-size:13px;line-height:1.95;color:var(--ink2);max-width:620px}
.foot-nav{display:flex;flex-wrap:wrap;gap:10px 28px;justify-content:center;margin-bottom:22px;font-size:13.5px}
.foot-nav a{color:var(--ink);transition:.2s}
.foot-nav a:hover{color:var(--accent)}
.foot-soc{display:flex;gap:12px;justify-content:center;align-items:center;margin-bottom:30px}
.foot-soc a{width:38px;height:38px;border:1px solid var(--line);border-radius:50%;display:inline-flex;align-items:center;justify-content:center;color:var(--ink2);transition:.2s}
.foot-soc a:hover{background:var(--accent);border-color:var(--accent);color:#fff}
.foot-soc a svg{width:16px;height:16px;display:block}
.foot-soc a.foot-soc__tabelog{width:auto;height:38px;border-radius:999px;padding:0 15px;font-family:var(--fen);font-size:12px;font-weight:600;letter-spacing:.04em}
.foot-rule{height:1px;background:var(--line);max-width:560px;margin:0 auto 18px}
.foot-copy{display:flex;flex-wrap:wrap;gap:8px 20px;justify-content:center;font-size:11.5px;color:var(--ink3)}
.foot-copy .foot-legal{display:flex;gap:20px}
.foot-copy a{color:var(--ink3);transition:.2s}
.foot-copy a:hover{color:var(--accent)}

/* ---- floating CTA ---- */
.fab{position:fixed;right:clamp(14px,2vw,28px);bottom:clamp(14px,2vw,28px);z-index:70;display:flex;flex-direction:column;gap:10px}
.fab__tel{display:flex;align-items:center;justify-content:center;gap:9px;padding:14px 20px;background:var(--card);color:var(--ink);border:1px solid var(--line);border-radius:999px;font-family:var(--fen);font-weight:600;font-size:13px;letter-spacing:.03em;box-shadow:0 8px 24px rgba(0,0,0,.14);transition:.2s}
.fab__tel:hover{transform:translateY(-2px)}
.fab__net{display:flex;align-items:center;justify-content:center;gap:9px;padding:15px 24px;background:var(--accent);color:#fff;border-radius:999px;font-family:var(--fen);font-weight:600;font-size:13.5px;letter-spacing:.04em;box-shadow:0 8px 24px color-mix(in srgb,var(--accent) 45%,transparent);transition:.2s}
.fab__net:hover{background:var(--accent2);transform:translateY(-2px)}
/* モバイルメニュー展開中はフローティングCTAを隠す（モーダルとの重なり防止） */
body.nav-open .fab{opacity:0;visibility:hidden;pointer-events:none}

/* ---- utilities ---- */
.u-flush-top{padding-top:0}
.section--access-home{padding-top:0;padding-bottom:clamp(64px,9vw,120px)}

/* ---- responsive ---- */
@media (max-width:720px){
  .topbar__inner{justify-content:flex-start}
  .fab{right:12px;bottom:12px}
  .fab__tel,.fab__net{padding:12px 16px;font-size:12.5px}
  .sec-head{margin-bottom:40px}
}
