
:root{
  --bg:#f6f3ee;
  --black:#0f0f0f;
  --gold:#9c7a3c;
  --text:#111;
}
*{box-sizing:border-box}
body{margin:0;font-family:"Hiragino Mincho ProN",serif;background:var(--bg);color:var(--text)}
a{color:inherit}
/* Header */
.site-header{position:sticky;top:0;background:var(--black);color:#fff;z-index:1000}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;gap:12px}
.logo{height:56px;width:auto;display:block}
.header-right{display:flex;align-items:center;gap:14px}
.icon-link img{width:22px;height:22px;display:block;opacity:.95}
.hamburger{background:none;border:none;width:34px;height:26px;display:flex;flex-direction:column;justify-content:space-between;cursor:pointer}
.hamburger span{height:2px;background:#fff;border-radius:2px;opacity:.95}


/* Drawer video background (mobile only) */
.drawer-video{position:absolute;inset:0;z-index:1;overflow:hidden}
.drawer-video-el{width:100%;height:100%;object-fit:cover}
.drawer-video-dim{position:absolute;inset:0;background:rgba(0,0,0,.55)}
/* keep menu above video */
.drawer-close{z-index:5}
.drawer-list{position:relative;z-index:4}
.drawer-footer{z-index:4}

/* Drawer */
.drawer{
  position:fixed;top:0;right:-100%;
  width:min(86vw,420px);height:100%;
  background:transparent;color:#fff;
  transition:.35s ease;
  overflow:hidden;
  padding-top:72px;
}
.site-header.open .drawer{right:0}
.drawer-close{position:absolute;top:14px;right:14px;z-index:5;background:none;border:none;color:#fff;font-size:34px;cursor:pointer}
.drawer-list{position:relative;z-index:4;list-style:none;margin:0;padding:110px 22px 0}
.drawer-list li{margin:0 0 18px}
.drawer-list a{display:block;text-decoration:none;font-size:18px;letter-spacing:2px}
.drawer-footer{position:absolute;left:0;right:0;bottom:18px;z-index:4;padding:0 22px}
.drawer-cta{display:flex;justify-content:center;align-items:center;gap:10px;padding:14px 14px;border:1px solid rgba(255,255,255,.35);border-radius:10px;text-decoration:none}
.drawer-cta span{letter-spacing:2px}

/* PC nav (drawer becomes inline) */
@media (min-width: 900px){
  .hamburger{display:none}
  .drawer{position:static;right:auto;width:auto;height:auto;background:none;padding:0;overflow:visible}
  .fan-layer,.drawer-close,.drawer-footer{display:none}
  .drawer-list{display:flex;gap:24px;padding:0 14px 12px;align-items:center}
  .drawer-list a{font-size:14px}
}

/* Hero */
.hero{position:relative;height:76vh;min-height:520px;background:#000;overflow:hidden}
.hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-video.sp{display:none}
.hero--videoonly{height:82vh;min-height:540px;margin-bottom:14px}
.hero--videoonly .hero-overlay{display:none}
.hero-overlay{
  position:relative;z-index:2;height:100%;
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:28px 18px 24px;
  color:#fff;
  background:linear-gradient(to top, rgba(0,0,0,.72), rgba(0,0,0,0));
}
.kicker{color:var(--gold);letter-spacing:4px;margin:0 0 10px}
.hero-overlay h1{margin:0;font-size:44px;line-height:1.18;letter-spacing:1px}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:18px}

/* HERO CTA (video bottom overlay) */
.hero-cta{
  position:absolute;
  left:0; right:0; bottom:0;
  z-index:2;
  padding:28px 18px calc(22px + env(safe-area-inset-bottom));
  color:#fff;
  background:linear-gradient(to top, rgba(0,0,0,.80), rgba(0,0,0,0));
  pointer-events:none; /* allow swipe/scroll on video */
}
.hero-cta-inner{max-width:980px;margin:0 auto;pointer-events:auto}
.hero-cta-title{margin:0;font-size:40px;line-height:1.2;letter-spacing:.02em;font-weight:600}
.hero-cta-actions{margin-top:14px}

@media (max-width: 768px){
  .hero-cta{padding:20px 16px calc(18px + env(safe-area-inset-bottom))}
  .hero-cta-title{font-size:28px}
}
.btn{display:inline-block;padding:12px 18px;border-radius:999px;text-decoration:none;border:1px solid #fff;backdrop-filter: blur(2px)}
.btn.gold{background:var(--gold);border-color:var(--gold);color:#111}
.btn.outline{background:transparent;color:#fff}
@media (max-width: 768px){
  .hero{height:72vh;min-height:420px}
  .hero--videoonly{height:74vh;min-height:440px;margin-bottom:12px}
  .hero-video.pc{display:none}
  .hero-video.sp{display:block}
  .hero-overlay h1{font-size:34px}
}

/* Sections */
.section{padding:54px 18px;max-width:1200px;margin:0 auto}
.section-head h2{margin:0 0 8px;font-size:26px}
.section-head p{margin:0;color:#333}

/* Frames */
.frame{
  background:#fff;
  padding:12px;
  border:1px solid #000;
  box-shadow:0 12px 34px rgba(0,0,0,.16);
}
.frame img{width:100%;display:block;height:auto}
.card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-top:24px}
.card{margin:0}
.card figcaption{text-align:center;margin-top:12px;letter-spacing:2px}
.card.offset{transform:translateY(22px)}
@media (max-width: 900px){
  .card-grid{grid-template-columns:1fr;gap:18px}
  .card.offset{transform:none}
}

/* Split */
.split{display:grid;grid-template-columns:1.1fr .9fr;gap:26px;align-items:center}
.split-text h2{margin:0 0 10px}
.split-text p{margin:0 0 14px}
.text-link{color:var(--gold);text-decoration:none;letter-spacing:1px}
@media (max-width: 900px){
  .split{grid-template-columns:1fr}
}

/* Page */
.page{max-width:1200px;margin:0 auto;padding:54px 18px}
.page-head h1{margin:0 0 10px;font-size:32px}
.page-head p{margin:0;color:#333}

/* Menu grid */
.menu-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-top:28px}
.menu-item{margin:0}
.menu-item figcaption{text-align:center;margin-top:12px;letter-spacing:2px}
@media (max-width: 900px){
  .menu-grid{grid-template-columns:1fr}
}
.cta-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:28px}

/* Concept */
.concept-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:28px}
.concept-card{background:#fff;border:1px solid #000;box-shadow:0 10px 28px rgba(0,0,0,.12);padding:14px}
.concept-card h3{margin:12px 0 6px}
.concept-card p{margin:0;color:#333}
@media (max-width: 900px){
  .concept-grid{grid-template-columns:1fr}
}

/* Access */
.access-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;margin-top:28px}
.access-card{background:#fff;border:1px solid #000;box-shadow:0 10px 28px rgba(0,0,0,.12);padding:14px}
.access-card h3{margin:12px 0 6px}
.access-card p{margin:0 0 12px;color:#333}
@media (max-width: 900px){
  .access-grid{grid-template-columns:1fr}
}

/* Footer */
.site-footer{background:#111;color:#fff;margin-top:60px}
.footer-inner{max-width:1200px;margin:0 auto;padding:18px 18px;display:flex;gap:14px;align-items:center;flex-wrap:wrap}
.footer-title{margin:0;letter-spacing:2px}
.footer-link{color:#fff;text-decoration:none;opacity:.9}
.footer-link:hover{opacity:1}

/* Anim */
.fade{opacity:0;transform:translateY(18px);transition:.9s ease}
.fade.show{opacity:1;transform:none}

@media (min-width: 900px){
  .drawer-video{display:none}
}

/* Event modal (created by JS after scroll) */
.event-modal{
  position: fixed;
  inset: 0;
  z-index: 2500;
  display: flex;
  align-items: center;
  justify-content: center;
}
.event-modal-backdrop{
  position:absolute; inset:0;
  background: rgba(0,0,0,.58);
}
.event-modal-card{
  position:relative;
  max-width: min(92vw, 760px);
  border-radius: 18px;
  overflow: hidden;
  box-shadow: 0 20px 60px rgba(0,0,0,.45);
  transform: scale(.96);
  opacity: 0;
  animation: modalIn .35s ease forwards;
}
.event-modal-card img{width:100%;display:block}
.event-modal-hint{
  position:absolute;right:12px;bottom:12px;
  font-size:12px;letter-spacing:2px;
  background:rgba(0,0,0,.6);color:#fff;
  padding:8px 10px;border-radius:999px;
}
@keyframes modalIn{to{transform:scale(1);opacity:1}}


/* ===== Header contact (address / phone) ===== */
.header-inner{gap:14px}
.header-contact{
  display:flex;
  flex-direction:column;
  gap:4px;
  margin-left:14px;
  padding-left:14px;
  border-left:1px solid rgba(255,255,255,.18);
  max-width:520px;
}
.contact-item{
  display:flex;
  gap:10px;
  align-items:baseline;
  text-decoration:none;
  color:inherit;
  opacity:.92;
}
.contact-item:hover{opacity:1}
.contact-label{
  font-size:12px;
  letter-spacing:.12em;
  opacity:.75;
  white-space:nowrap;
}
.contact-value{
  font-size:13px;
  line-height:1.4;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

/* On small screens, keep header clean */
@media (max-width: 920px){
  .header-contact{display:none}
}

/* ===== TOP: Event section ===== */
.event-section .event-wrap{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap:18px;
  max-width:1100px;
  margin:0 auto;
  padding:0 18px;
  align-items:start;
}
.event-section .event-text{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  border-radius:18px;
  padding:16px 16px 18px;
}
.event-section .event-copy{
  margin:0;
  line-height:1.9;
  opacity:.92;
}
.event-section .event-sub{
  font-weight:700;
}
@media (max-width: 920px){
  .event-section .event-wrap{grid-template-columns:1fr}
}

/* ===== TOP: Concept banner ===== */
.concept-banner{padding-top:10px}
.concept-banner-link{
  display:block;
  max-width:1100px;
  margin:0 auto;
  padding:0 18px;
}
.concept-banner-link img{
  width:100%;
  height:auto;
  display:block;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.08);
}


/* ===== TOP: Concept banner full width ===== */
.concept-banner-full{padding-top:12px}
.concept-banner-full .concept-banner-link{
  max-width:none;
  margin:0;
  padding:0;
}
.concept-banner-full .concept-banner-link img{
  border-radius:0;
  border-left:0;
  border-right:0;
}

/* ===== TOP: Event section redesign ===== */
.event-shell{
  max-width:1100px;
  margin:0 auto;
  padding:0 18px;
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  gap:18px;
  align-items:stretch;
}
.event-media{position:relative;overflow:hidden;border-radius:18px}
.event-media img{width:100%;height:100%;object-fit:cover;display:block;min-height:320px}
.event-media::after{
  content:"";
  position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,.15),rgba(0,0,0,.70));
}
.event-media-badge{
  position:absolute;left:14px;top:14px;z-index:2;
  padding:8px 12px;border-radius:999px;
  background:rgba(0,0,0,.55);
  border:1px solid rgba(255,255,255,.18);
  letter-spacing:.12em;
  font-size:12px;
}
.event-card{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  border-radius:18px;
  padding:18px 18px 16px;
}
.event-title{margin:0 0 8px;font-size:24px}
.event-catch{margin:0 0 14px;opacity:.92;line-height:1.7}
.event-body p{margin:0 0 10px;opacity:.92;line-height:1.9}
.event-dates{
  margin-top:12px;
  border-radius:14px;
  background:rgba(0,0,0,.35);
  border:1px solid rgba(255,255,255,.10);
  padding:12px 12px 10px;
}
.event-dates-head{font-size:12px;letter-spacing:.14em;opacity:.8;margin:0 0 6px}
.event-dates-body{font-weight:700;line-height:1.7}

@media (max-width: 920px){
  .event-shell{grid-template-columns:1fr}
  .event-media img{min-height:220px}
}


/* ===== Fix: Event banner visibility ===== */
.event-media::after{display:none !important}
.event-media img{filter:none !important}

/* ===== Mobile footer contact ===== */
@media (max-width: 920px){
  .site-footer .footer-inner{
    display:flex;
    flex-direction:column;
    gap:10px;
  }
  .footer-contact{
    display:block;
    margin-top:6px;
    padding-top:10px;
    border-top:1px solid rgba(255,255,255,.15);
  }
  .footer-contact a{
    display:block;
    color:inherit;
    text-decoration:none;
    margin-bottom:6px;
    line-height:1.6;
  }
}


/* ===== FIX: Event visibility (remove gray backgrounds) ===== */
.event-card,
.event-text,
.event-dates {
  background: transparent !important;
  border: none !important;
}

.event-dates-body {
  background: transparent !important;
  color: inherit !important;
}

.event-media::after {
  display: none !important;
}



/* Event dates – clean text only */
.event-dates {
  padding: 0;
  margin-top: 12px;
}
.event-dates-head {
  font-weight: bold;
}


/* ===== FIX: Event "gray" badge/overlay completely off ===== */
.event-media-badge{display:none !important}

/* ===== FIX: Event image should look natural (no dim/filter/background) ===== */
.event-media, .event-image{background:transparent !important}
.event-media img, .event-image img{filter:none !important; opacity:1 !important}

/* ===== FIX: Concept banner should NOT crop on mobile ===== */
.concept-banner-full .concept-banner-link img{
  width:100% !important;
  height:auto !important;
  object-fit:contain !important;
}


/* ===== FINAL FIX: remove any gray layer around event image ===== */
.event-media.frame,
.event-image.frame{
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  padding: 0 !important;
}
.event-media.frame img,
.event-image.frame img{
  display:block;
  width:100%;
  height:auto;
  border-radius:18px;
}

/* Some themes add frames via .frame > img; force clean */
.event-section .frame{background:transparent !important;border:none !important;box-shadow:none !important}

/* ===== FINAL FIX: concept banner must never crop ===== */
.concept-banner.concept-banner-full .concept-banner-link img{
  width:100% !important;
  height:auto !important;
  max-width:none !important;
  object-fit:contain !important;
}

/* If any rule sets cover, override */
.concept-banner.concept-banner-full img{object-fit:contain !important}

/* ===== Optional: keep event image large on mobile ===== */
@media (max-width: 920px){
  .event-shell{padding:0 18px}
  .event-media img{min-height:unset !important}
}


/* ===== FORCE REFRESH BUILD 20260106-165305 ===== */

/* Concept banner: full-width but never cropped; reasonable height on mobile */
.concept-banner-full .concept-banner-link img{
  width:100% !important;
  height:auto !important;
  object-fit:contain !important;
  display:block;
}
@media (max-width: 920px){
  .concept-banner-full .concept-banner-link img{
    max-height: 220px;
  }
}
/* If any global rule applies cover to all images, override */
.concept-banner-full img{object-fit:contain !important;}

/* Event image: absolutely no frame/overlay/gray */
.event-section .frame{background:transparent !important;border:none !important;box-shadow:none !important;padding:0 !important;}
.event-section img{filter:none !important; opacity:1 !important;}


/* ===== PATCH 20260106-170127: kill any gray overlays/pseudo-elements ===== */
.event-section .event-media::before,
.event-section .event-media::after,
.event-section .event-media.frame::before,
.event-section .event-media.frame::after,
.event-section .frame::before,
.event-section .frame::after {
  content: none !important;
  display: none !important;
  background: transparent !important;
  opacity: 0 !important;
}

/* Ensure event image container has no overlay/background at all */
.event-section .event-media,
.event-section .event-media.frame,
.event-section .frame {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  padding: 0 !important;
}

/* Concept banner: full width, never cropped */
.concept-banner-full .concept-banner-link {
  display:block;
  width:100%;
}
.concept-banner-full .concept-banner-link img {
  width:100% !important;
  height:auto !important;
  object-fit:contain !important;
  display:block;
}
@media (max-width: 920px) {
  .concept-banner-full .concept-banner-link img {
    max-height: 220px;
  }
}


/* ===== MENU PAGE (rebuild) BUILD 20260106-171126 ===== */
.menu-page{padding-top:0}
.menu-hero{padding: 46px 0 20px}
.menu-hero-inner{max-width:1100px;margin:0 auto;padding:0 22px}
.menu-hero h1{margin:10px 0 10px;letter-spacing:.04em}
.menu-hero-lead{opacity:.85;max-width:46em}
.menu-nav{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}
.chip{display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border-radius:999px;border:1px solid rgba(0,0,0,.12);background:rgba(255,255,255,.6);text-decoration:none;color:inherit}
.chip:hover{background:#fff}
.menu-section .section-head{max-width:1100px;margin:0 auto 18px;padding:0 22px}
.menu-card{max-width:1100px;margin:0 auto;padding:0 22px;display:grid;grid-template-columns:1.1fr .9fr;gap:22px;align-items:center}
.menu-card-media img{width:100%;height:auto;display:block;border-radius:18px}
.menu-card-body h3{margin:0 0 6px}
.menu-note{opacity:.7;margin:0}

.menu-grid{max-width:1100px;margin:0 auto;padding:0 22px;display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.menu-item{border:1px solid rgba(0,0,0,.10);border-radius:18px;overflow:hidden;background:rgba(255,255,255,.65)}
.menu-item-media img{width:100%;height:auto;display:block}
.menu-item-body{padding:16px 16px 18px}
.menu-item-body h3{margin:0 0 8px;font-size:20px;line-height:1.35}
.menu-item-body .price{font-size:18px;opacity:.9;margin-left:8px;white-space:nowrap}
.menu-item-body .set{margin:0;opacity:.85}
.menu-item-wide{max-width:1100px;margin:0 auto;padding:0 22px;display:grid;grid-template-columns:1.1fr .9fr;gap:18px;border:none;background:transparent}
.menu-item-wide .menu-item-media img{border-radius:18px}
.menu-item-wide .menu-item-body{border:1px solid rgba(0,0,0,.10);border-radius:18px;background:rgba(255,255,255,.65);padding:16px 16px 18px}

@media (max-width: 920px){
  .menu-card{grid-template-columns:1fr}
  .menu-grid{grid-template-columns:1fr}
  .menu-item-wide{grid-template-columns:1fr}
  .menu-hero{padding-top:26px}
}



/* ===== CONCEPT PAGE: banners no frame, keep transparency ===== */
.concept-hero{
  width: 100%;
  margin: 0;
  padding: 0;
  background: transparent;
}
.concept-hero-img{
  width: 100%;
  height: auto;
  display: block;
  border: 0;
  border-radius: 0;
  background: transparent;
}
.concept-hero--second{ margin-top: 10px; }

.concept-copy .prose{
  max-width: 980px;
  margin: 0 auto;
}
.concept-copy .prose h1,
.concept-copy .prose h2{
  letter-spacing: .06em;
}
.concept-copy .prose p{
  line-height: 2.0;
}

/* remove any frame/border around concept banners used elsewhere (TOPなど) */
.concept-banner{
  padding: 0 !important;
}
.concept-banner-link{
  max-width: none !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
}
.concept-banner-link img{
  border: 0 !important;
  border-radius: 0 !important;
}

/* ====== TOP: link banners (Menu / Shop) ====== */
.link-banners{padding-top:10px}
.link-banner-grid{max-width:1100px;margin:0 auto;padding:0 24px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:22px}
.link-banner{display:block;border-radius:18px;overflow:hidden;position:relative;text-decoration:none;box-shadow:0 14px 40px rgba(0,0,0,.18);transform:translateZ(0)}
.link-banner::before{content:"";position:absolute;inset:0;border:1px solid rgba(212,175,55,.42);border-radius:18px;pointer-events:none}
.link-banner-media{aspect-ratio:16/9;background:#0b0b0b}
.link-banner-media img{width:100%;height:100%;object-fit:cover;display:block;transform:scale(1.02)}
.link-banner-label{position:absolute;left:16px;bottom:14px;padding:10px 14px;border-radius:14px;background:linear-gradient(90deg,rgba(12,12,12,.78),rgba(12,12,12,.35));backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);border:1px solid rgba(212,175,55,.35)}
.link-banner-label .jp{display:block;font-size:18px;letter-spacing:.18em;color:#f4e7bf;font-weight:600}
.link-banner-label .en{display:block;margin-top:4px;font-size:13px;letter-spacing:.22em;color:rgba(255,255,255,.78)}
.link-banner:hover{transform:translateY(-2px)}
@media (max-width: 820px){
  .link-banner-grid{grid-template-columns:1fr;padding:0 16px;gap:16px}
  .link-banner-label{left:12px;bottom:12px}
  .link-banner-label .jp{font-size:16px}
}


/* ===== BUILD 20260107-1100: shop map button visibility + gold borders ===== */
.shop-page .map-frame{
  background:#fff;
  border:2px solid rgba(182,140,56,.95);
  box-shadow:0 10px 30px rgba(0,0,0,.10);
}
.shop-page .map-actions .btn{
  border-width:1px;
  border-style:solid;
  border-color:rgba(182,140,56,.95);
}
.shop-page .map-actions .btn.outline{
  color:#111;
  background:rgba(255,255,255,.78);
}
.shop-page .map-actions .btn.ghost{
  color:#111;
  background:rgba(255,255,255,.55);
}
.shop-page .map-actions .btn.ghost:active,
.shop-page .map-actions .btn.outline:active{
  transform:translateY(1px);
}

/* ===== Recruit page premium layout ===== */
.recruit-hero{
  position:relative;
  overflow:hidden;
  border-radius:18px;
  border:2px solid rgba(182,140,56,.85);
  box-shadow:0 18px 50px rgba(0,0,0,.14);
  background:#111;
}
.recruit-hero img{
  width:100%;
  height:clamp(260px, 44vw, 420px);
  object-fit:cover;
  display:block;
  filter:saturate(1.05) contrast(1.02);
}
.recruit-hero .overlay{
  position:absolute; inset:0;
  background:linear-gradient(90deg, rgba(0,0,0,.70) 0%, rgba(0,0,0,.35) 52%, rgba(0,0,0,.08) 100%);
  display:flex;
  align-items:flex-end;
  padding:22px;
}
.recruit-hero .title{
  color:#fff;
  font-size:clamp(26px, 3.6vw, 42px);
  letter-spacing:.06em;
  text-shadow:0 10px 24px rgba(0,0,0,.45);
  margin:0 0 6px 0;
}
.recruit-hero .sub{
  color:rgba(255,255,255,.85);
  margin:0;
  font-size:clamp(14px, 1.8vw, 16px);
  line-height:1.7;
}

.recruit-wrap{
  margin-top:26px;
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap:22px;
  align-items:start;
}
@media (max-width: 980px){
  .recruit-wrap{ grid-template-columns:1fr; }
}
.recruit-card{
  background:rgba(255,255,255,.78);
  border:1px solid rgba(182,140,56,.55);
  border-radius:18px;
  box-shadow:0 14px 40px rgba(0,0,0,.08);
  padding:18px 18px;
}
.recruit-card h2{
  margin:0 0 10px 0;
  font-size:20px;
  letter-spacing:.04em;
}
.recruit-lead{
  margin:0 0 14px 0;
  color:#2a2a2a;
  line-height:1.9;
}
.recruit-dl{
  display:grid;
  gap:10px;
}
.recruit-row{
  display:flex;
  gap:12px;
  padding:10px 12px;
  background:rgba(255,255,255,.55);
  border:1px solid rgba(0,0,0,.06);
  border-left:4px solid rgba(182,140,56,.85);
  border-radius:14px;
}
.recruit-row .k{
  min-width:92px;
  color:#333;
  font-weight:700;
}
.recruit-row .v{
  color:#111;
  line-height:1.7;
}
@media (max-width: 520px){
  .recruit-row{ flex-direction:column; gap:6px; }
  .recruit-row .k{ min-width:auto; }
}

.recruit-badges{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:12px;
}
.recruit-badge{
  padding:8px 12px;
  border-radius:999px;
  background:rgba(182,140,56,.10);
  border:1px solid rgba(182,140,56,.55);
  color:#2a2a2a;
  font-weight:700;
  font-size:13px;
}

.recruit-cta{
  margin-top:14px;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
.recruit-cta a{ text-decoration:none; }
.recruit-cta .btn{ border-color:rgba(182,140,56,.95); }
.recruit-cta .btn.gold{
  background:linear-gradient(180deg, rgba(203,164,84,1) 0%, rgba(156,115,38,1) 100%);
  color:#fff;
}

.recruit-note{
  margin-top:10px;
  font-size:13px;
  color:#555;
  line-height:1.8;
}



/* === SNS page (2026-01-07) === */
.sns-page{background:var(--paper,#f4f1ea)}
.sns-hero{padding:64px 20px 46px;background:
  radial-gradient(800px 260px at 50% 0%, rgba(215,170,85,.18), transparent 60%),
  linear-gradient(180deg, #111 0%, #111 55%, transparent 55%);
}
.sns-hero-inner{max-width:980px;margin:0 auto;padding:34px 22px;border-radius:22px;
  background:linear-gradient(180deg, rgba(17,17,17,.92), rgba(17,17,17,.78));
  box-shadow:0 20px 60px rgba(0,0,0,.28);
  border:1px solid rgba(215,170,85,.25);
}
.sns-kicker{letter-spacing:.22em;font-size:12px;color:rgba(255,255,255,.72);margin:0 0 8px}
.sns-title{margin:0 0 10px;font-size:42px;letter-spacing:.08em;color:#d9b45a;text-shadow:0 10px 26px rgba(0,0,0,.35)}
.sns-lead{margin:0 0 18px;color:rgba(255,255,255,.82);line-height:1.8}
.sns-cta{display:flex;gap:12px;flex-wrap:wrap}
.sns-btn{display:inline-flex;align-items:center;gap:10px;padding:12px 16px;border-radius:999px;
  font-weight:700;letter-spacing:.03em;text-decoration:none;transition:.18s transform,.18s opacity;
}
.sns-btn:hover{transform:translateY(-1px);opacity:.95}
.sns-btn-ic{width:18px;height:18px;display:inline-flex}
.sns-btn-ic img{width:18px;height:18px;filter:invert(1)}
.sns-btn.gold{background:linear-gradient(180deg,#d9b45a,#b58a35);color:#111}
.sns-btn.outline{border:1px solid rgba(255,255,255,.35);color:#fff;background:transparent}

.sns-section{padding:36px 20px 24px}
.sns-grid{max-width:980px;margin:0 auto;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.sns-card{background:rgba(255,255,255,.7);border-radius:22px;padding:18px 18px 16px;
  border:1px solid rgba(0,0,0,.06);
  box-shadow:0 18px 50px rgba(0,0,0,.08);
}
.sns-card.wide{grid-column:1 / -1}
.sns-card-head{display:flex;align-items:center;gap:12px;margin-bottom:10px}
.sns-ic{width:44px;height:44px;border-radius:14px;display:grid;place-items:center;
  background:linear-gradient(180deg,#111,#1b1b1b);
  border:1px solid rgba(215,170,85,.35);
  box-shadow:0 10px 22px rgba(0,0,0,.18);
  color:#d9b45a;font-size:18px
}
.sns-ic img{width:20px;height:20px;filter:invert(1)}
.sns-card-txt h2{margin:0;font-size:18px;letter-spacing:.08em}
.sns-card-txt p{margin:2px 0 0;color:rgba(0,0,0,.6);font-size:13px}
.sns-desc{margin:10px 0 12px;line-height:1.9;color:rgba(0,0,0,.72)}
.sns-row{display:flex;gap:14px;flex-wrap:wrap}
.sns-link{display:inline-flex;align-items:center;gap:8px;color:#7a5a1f;font-weight:700;text-decoration:none}
.sns-link:hover{text-decoration:underline}

.sns-note{padding:10px 20px 56px}
.sns-note-inner{max-width:980px;margin:0 auto;padding:18px 18px;border-radius:22px;
  background:linear-gradient(180deg, rgba(215,170,85,.16), rgba(255,255,255,.55));
  border:1px solid rgba(215,170,85,.28);
}
.sns-note-inner h2{margin:0 0 6px;font-size:16px;letter-spacing:.08em}
.sns-note-inner p{margin:0;color:rgba(0,0,0,.7);line-height:1.9}

@media (max-width:720px){
  .sns-hero{padding:54px 14px 34px}
  .sns-hero-inner{padding:26px 16px}
  .sns-title{font-size:34px}
  .sns-grid{grid-template-columns:1fr}
}


/* ===== Language switcher ===== */
.lang-switch{
  display:flex;
  gap:8px;
  align-items:center;
  margin-right:10px;
}
.lang-btn{
  border:1px solid rgba(255,255,255,.35);
  background:rgba(0,0,0,.25);
  color:#fff;
  padding:6px 10px;
  border-radius:999px;
  font-size:12px;
  letter-spacing:.02em;
  cursor:pointer;
  transition:all .2s ease;
  line-height:1;
}
.lang-btn:hover{ background:rgba(255,255,255,.08); }
.lang-btn.is-active{
  background:rgba(212,175,55,.22);
  border-color:rgba(212,175,55,.55);
}
@media(max-width:768px){
  .lang-switch{ gap:6px; margin-right:6px; }
  .lang-btn{ padding:6px 8px; font-size:11px; }
}

/* TOP: philosophy + stacked banners */
.philosophy{padding-top:34px;padding-bottom:22px}
.philo-title-strong{font-weight:700}
.philo-list{margin:18px 0 0;padding:0;list-style:none;font-size:18px;line-height:1.9;letter-spacing:.04em}
.philo-list li{margin:0;padding:2px 0}

.top-origin{padding-top:10px;padding-bottom:28px}
.top-origin-link{display:block;border-radius:18px;overflow:hidden;box-shadow:0 14px 40px rgba(0,0,0,.14)}
.top-origin-link img{width:100%;height:auto;display:block}

.top-blocks{padding-top:18px}
.top-block{margin:0 0 28px}
.block-title{margin:0 0 12px;font-size:22px;letter-spacing:.06em}
.link-banner--stack{max-width:1100px;margin:0 auto}

/* Event page */
.event-hero{max-width:1200px;margin:0 auto;padding:34px 18px 10px}
.event-hero img{width:100%;height:auto;display:block;border-radius:18px;box-shadow:0 14px 40px rgba(0,0,0,.18)}
.event-content .prose h1{margin-top:0}
.event-dates{margin-top:18px;padding:14px 16px;border:1px solid #000;background:#fff;box-shadow:0 10px 28px rgba(0,0,0,.10)}
.event-dates-title{font-weight:700;letter-spacing:.08em;margin:0 0 6px}

@media (max-width: 768px){
  .philo-list{font-size:17px}
  .block-title{font-size:20px}
}


/* 【秀吉のこだわり】タイトル */
.section-bracket-title {
  text-align: center;
  font-size: 20px;
  letter-spacing: 0.12em;
  margin: 32px 0 18px;
  font-weight: 600;
}
.section-bracket-title::before { content: "【"; }
.section-bracket-title::after { content: "】"; }

/* バナー画像 横100% */
.top-kodawari img {
  width: 100%;
  height: auto;
  display: block;
}


/* =========================
   Full width images (content)
   ========================= */
.section img{
  max-width:100%;
  height:auto;
}

/* 画像を“横100%（セクションの左右余白を無視して全面）”に見せる */
.full-bleed{
  width: calc(100% + 36px);
  max-width: none;
  margin-left: -18px;
  margin-right: -18px;
  display:block;
  height:auto;
}

/* バナー系は左右パディングを外す（画像が欠けないように） */
.top-origin, .top-kodawari{
  padding-left: 18px; /* textは維持 */
  padding-right: 18px;
}


/* =========================
   Banner images: always 100% and not shifted
   ========================= */
.link-banner-media{
  padding: 0;
  margin: 0;
  overflow: hidden; /* rounded corners keep */
}
.link-banner-media img{
  width: 100%;
  height: auto;
  display: block;
  margin: 0;
}
/* In case full-bleed remains somewhere in a banner, neutralize it */
.link-banner-media img.full-bleed{
  width: 100%;
  max-width: 100%;
  margin-left: 0;
  margin-right: 0;
}


/* =========================
   Link banner: no-crop variant (for posters etc.)
   ========================= */
.link-banner-media.contain{
  aspect-ratio: auto;
  background: #0b0b0b;
}
.link-banner-media.contain img{
  width: 100%;
  height: auto;
  object-fit: contain;
  transform: none;
}


/* =========================
   FINAL FIX: Banner no crop
   ========================= */
.link-banner-media,
.link-banner-media.nocrop{
  padding: 0;
  margin: 0;
  height: auto !important;
  max-height: none !important;
  overflow: visible !important;
  background: transparent;
}

.link-banner-media img,
.link-banner-media.nocrop img{
  display: block;
  width: 100%;
  height: auto !important;
  max-height: none !important;
  object-fit: unset !important;
  object-position: center center;
}

/* hide Origin EN */
.link-banner-label .en{display:none !important;}


/* remove white space under banners */
.link-banner,
.link-banner-media,
.section .link-banner{
  margin-bottom: 0 !important;
  padding-bottom: 0 !important;
}


/* =========================
   ORIGIN banner: remove blank area under image
   ========================= */
.top-block--origin a.link-banner{
  display:block;
  padding:0 !important;
  margin:0 !important;
  height:auto !important;
  min-height:0 !important;
}
.top-block--origin .link-banner-media{
  padding:0 !important;
  margin:0 !important;
  height:auto !important;
  min-height:0 !important;
  overflow:hidden;
}
.top-block--origin .link-banner-media img{
  display:block;
  width:100%;
  height:auto !important;
  object-fit:unset !important;
}
/* if any label/text exists, hide */
.top-block--origin .link-banner-label,
.top-block--origin .link-banner-text{
  display:none !important;
}
/* remove extra bottom spacing if it was coming from the block itself */
.top-block--origin{
  margin-bottom:0 !important;
  padding-bottom:0 !important;
}


/* =========================
   FIX: Origin banner bottom blank space
   cause: .link-banner-media has aspect-ratio:16/9 but img became height:auto
   ========================= */
.top-block--origin .link-banner-media{
  aspect-ratio: auto !important;
  height: auto !important;
  background: transparent !important;
}
.top-block--origin .link-banner-media img{
  width: 100% !important;
  height: auto !important;
  object-fit: unset !important;
  transform: none !important;
}


/* --- menu text blocks (added 20260205) --- */
.menu-list{margin:10px 0 0 0;padding-left:1.2em}
.menu-list li{margin:4px 0;line-height:1.6}
.menu-cols{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:12px}
@media (max-width:720px){.menu-cols{grid-template-columns:1fr}}
.price-line{margin:10px 0 0 0;font-weight:700}
.menu-sub{margin:12px 0 6px 0;font-weight:700}
.tax{opacity:.8;font-size:.9em;margin-left:4px}
