/*
Theme Name: HAMBURG THE BUTLER (Customizer Edition)
Version: 1.2.0
Text Domain: butler
*/
:root{--butler:#f97316}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Noto Sans JP",sans-serif}
a{color:var(--butler);text-decoration:none}a:hover{text-decoration:underline}
img{max-width:100%;height:auto;display:block}
.container{max-width:1120px;margin:0 auto;padding:0 16px}
.header{position:sticky;top:0;z-index:1000;background:#fff;border-bottom:1px solid #fed7aa}
.header-inner{display:grid;grid-template-columns:auto auto auto;gap:12px;align-items:center;padding:12px 0}
@media(min-width:768px){.header-inner{grid-template-columns:auto 1fr auto}}
.menu-toggle{display:inline-flex;flex-direction:column;gap:4px;width:40px;height:36px;align-items:center;justify-content:center;background:#fff;border:1px solid #fed7aa;border-radius:10px}
.menu-toggle .menu-toggle-bar{width:18px;height:2px;background:var(--butler);display:block}
@media(min-width:768px){.menu-toggle{display:none}}
.nav{display:none}.nav--open{display:block}@media(min-width:768px){.nav{display:block}}
.nav-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}@media(min-width:768px){.nav-list{flex-direction:row;gap:20px;justify-content:center}}
.nav-list>li>a{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:40px;padding:6px 10px;color:#374151;font-weight:700;line-height:1.2;position:relative;border-radius:10px;text-align:center;font-size:15px}
.nav-list>li>a .en-label{font-size:11px;color:#6b7280;font-weight:400;margin-top:2px}
.nav-list>li>a:hover{color:#c2410c}.nav-list>li>a::after{content:"";position:absolute;left:12px;right:12px;bottom:2px;height:2px;background:var(--butler);border-radius:2px;transform:scaleX(0);transition:transform .22s}
.nav-list>li>a:hover::after{transform:scaleX(1)}
.header-actions{display:flex;gap:10px}.lang-toggle{font-size:12px;padding:6px 10px;border:1px solid #fed7aa;border-radius:9999px}
.cta{padding:8px 14px;border-radius:9999px;font-weight:800;background:var(--butler);color:#fff;border:0}
.cta--ghost{background:#fff;color:var(--butler);border:1px solid var(--butler)}
.hero{padding:64px 0 48px}.hero-grid{display:grid;grid-template-columns:1fr;gap:32px}@media(min-width:900px){.hero-grid{grid-template-columns:1.1fr .9fr;align-items:center}}
.hero-title{font-size:clamp(28px,5vw,46px);font-weight:900;margin:0 0 20px}.hero-lead{font-size:16px;line-height:1.6;color:#374151}
.hero-image img{border-radius:20px;border:1px solid #fed7aa}
.section{padding:42px 0}.section-title{font-size:clamp(22px,3.5vw,32px);font-weight:900;margin:0 0 16px}
.menu-grid{display:grid;gap:18px;grid-template-columns:1fr}@media(min-width:700px){.menu-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.menu-grid{grid-template-columns:repeat(3,1fr)}}
.card{border:1px solid #fed7aa;border-radius:16px;padding:16px}
.footer{border-top:1px solid #e5e7eb;margin-top:48px}.footer-inner{display:grid;gap:20px;padding:36px 0}@media(min-width:900px){.footer-inner{grid-template-columns:1.3fr 1fr 1fr}}


/* Access page styling */
.access-lead{color:#374151;margin:6px 0 18px;font-size:15px}
.access-grid{display:grid;gap:18px;grid-template-columns:1fr}
@media(min-width:980px){.access-grid{grid-template-columns:1.2fr 1fr}}
.access-map iframe{border-radius:16px;border:1px solid #fed7aa}
.access-info.card{border:1px solid #fed7aa;border-radius:16px;padding:18px;box-shadow:0 4px 12px rgba(249,115,22,.08)}
.access-heading{margin:0 0 12px;font-weight:800}
.access-list{list-style:none;margin:0 0 12px;padding:0;display:grid;gap:10px}
.access-list .label{display:block;font-size:12px;color:#6b7280;margin-bottom:2px}
.access-list .value{font-weight:600}
.access-times{display:flex;flex-wrap:wrap;gap:8px;margin:8px 0 16px}
.chip{border:1px solid #fed7aa;border-radius:9999px;padding:6px 10px;font-size:12px;background:#fff7ed}
.access-actions{display:flex;gap:8px;flex-wrap:wrap}


/* === Menu thumbnails (responsive) === */
.menu-card .thumb{
  width:100%;
  aspect-ratio: 4 / 3;      /* お好みで 16/9 や 1/1 に変更可 */
  overflow:hidden;
  border-radius:12px;
  border:1px solid #fed7aa;
  background:#fff;
}
.menu-card .thumb img{
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;         /* 余白を作らず中央でトリミング */
}

/* 念のための保険（テーマ全体） */
img{max-width:100%;height:auto;display:block}


/* ===== Access page (revamped) ===== */
.access-header { margin-bottom: 12px; }
.access-lead { color:#374151; margin:6px 0 18px; font-size:15px; }

.access-grid {
  display:grid; gap:18px; grid-template-columns:1fr;
}
@media (min-width: 980px){
  .access-grid { grid-template-columns: 1.15fr 0.85fr; }
}

.access-card {
  border:1px solid #fed7aa; border-radius:16px; background:#fff;
  padding:16px; box-shadow:0 6px 18px rgba(249,115,22,.08);
}

.access-map iframe {
  width:100%; height:420px; border:0; border-radius:12px;
  display:block;
}

.access-actions, .cta-actions {
  display:flex; flex-wrap:wrap; gap:10px; margin-top:12px;
}
.btn {
  display:inline-flex; align-items:center; justify-content:center;
  padding:10px 16px; border-radius:9999px; font-weight:800;
  border:0; background:var(--butler,#f97316); color:#fff; text-decoration:none;
}
.btn:hover { filter:brightness(0.95); }
.btn-ghost {
  background:#fff; color:var(--butler,#f97316); border:1px solid var(--butler,#f97316);
}
.btn-ghost:hover { background:#fff7ed; }

.access-info .access-subtitle { margin:0 0 12px; font-weight:800; }
.access-list { list-style:none; margin:0 0 12px; padding:0; display:grid; gap:12px; }
.access-list .label { display:block; font-size:12px; color:#6b7280; margin-bottom:2px; }
.access-list .value { font-weight:600; word-break:break-word; }
.access-list address { font-style:normal; }

.access-times { display:flex; flex-wrap:wrap; gap:8px; margin-top:6px; }
.chip {
  border:1px solid #fed7aa; border-radius:9999px; padding:6px 10px;
  font-size:12px; background:#fff7ed;
}

.access-cta-band {
  margin-top:22px; padding:16px; border:1px dashed #fed7aa;
  border-radius:16px; background:#fffaf5;
  display:flex; flex-wrap:wrap; align-items:center; gap:12px; justify-content:space-between;
}
.access-cta-band .cta-text { margin:0; color:#7c2d12; font-weight:700; }

/* 保険：ボタンが本文に重ならないように */
.access-card .btn, .access-card .btn-ghost { position:static; }

/* モバイル最適化 */
@media (max-width: 640px){
  .access-cta-band { flex-direction:column; align-items:flex-start; }
}