
:root{
  --bg:#0f0b08;
  --surface:#17120e;
  --surface-2:#211812;
  --line:rgba(255,255,255,.08);
  --line-soft:rgba(255,255,255,.04);
  --text:#f9f3ec;
  --muted:#c9beb0;
  --orange:#f46d0c;
  --orange-deep:#c84700;
  --gold:#f1c36c;
  --gold-soft:#ffe0a6;
  --card:#1b150f;
  --max:1180px;
  --radius:24px;
  --shadow:0 20px 60px rgba(0,0,0,.35);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:"Hiragino Sans","Yu Gothic",system-ui,sans-serif;background:radial-gradient(circle at top,rgba(244,109,12,.08),transparent 28%),linear-gradient(180deg,#0d0907,#120d09 25%,#0f0b08 100%);color:var(--text);line-height:1.7}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%;height:auto}
.container{max-width:var(--max);margin:0 auto;padding:0 20px}
.section{padding:84px 0}
.section-head{display:flex;justify-content:space-between;align-items:end;gap:24px;margin-bottom:34px}
.section-head h2{font-size:clamp(2rem,4vw,3.25rem);line-height:1.15;margin:6px 0 0}
.section-head p{max-width:530px;color:var(--muted);margin:0}
.eyebrow{display:inline-block;letter-spacing:.18em;text-transform:uppercase;font-size:.78rem;color:var(--gold);font-weight:800}
.kbd{padding:.25rem .5rem;border:1px solid var(--line);border-radius:999px;background:rgba(255,255,255,.03);font-size:.8rem;color:var(--gold-soft)}
.skip-link{position:absolute;left:-9999px;top:auto}
.skip-link:focus{left:16px;top:16px;z-index:1000;background:#fff;color:#000;padding:8px 12px;border-radius:8px}
.site-header{position:sticky;top:0;z-index:50;background:rgba(8,6,5,.82);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.site-header .inner{max-width:var(--max);margin:0 auto;padding:12px 20px;display:flex;align-items:center;gap:18px}
.brand{display:flex;align-items:center;gap:14px;min-width:0}
.brand-mark{width:52px;height:52px;border-radius:14px;overflow:hidden;box-shadow:0 10px 24px rgba(0,0,0,.2);border:1px solid rgba(255,255,255,.08)}
.brand-mark img{width:100%;height:100%;object-fit:cover}
.brand-text{display:flex;flex-direction:column;line-height:1.1}
.brand-text strong{font-size:1.15rem;font-weight:900}
.brand-text small{color:var(--muted)}
.brand-sub{color:var(--gold-soft);font-size:.78rem;font-weight:800;letter-spacing:.08em}
.global-nav{display:flex;gap:20px;margin-left:auto;align-items:center}
.global-nav a{font-weight:700;color:#ece0d0;font-size:.95rem}
.global-nav a:hover{color:var(--gold-soft)}
.nav-actions{display:flex;gap:10px;align-items:center}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:48px;padding:0 18px;border-radius:999px;border:1px solid var(--line);font-weight:800;transition:.2s ease;cursor:pointer}
.btn:hover{transform:translateY(-1px)}
.btn.primary{background:linear-gradient(135deg,var(--orange),#ff8b2b);color:#fff;border-color:transparent;box-shadow:0 16px 30px rgba(244,109,12,.24)}
.btn.secondary{background:linear-gradient(135deg,var(--gold),#f6dda5);color:#2a1703;border-color:transparent}
.btn.ghost{background:rgba(255,255,255,.03)}
.menu-toggle{display:none;background:none;border:0;color:#fff;font-size:1.5rem}
.hero{padding:34px 0 0}
.hero-grid{max-width:var(--max);margin:0 auto;padding:0 20px;display:grid;grid-template-columns:1.15fr .85fr;gap:26px;align-items:stretch}
.hero-main{position:relative;min-height:640px;border:1px solid var(--line);border-radius:32px;overflow:hidden;box-shadow:var(--shadow);background:#1a110c}
.hero-main::after{content:"";position:absolute;inset:0;background:linear-gradient(115deg,rgba(10,7,5,.80),rgba(10,7,5,.44) 42%,rgba(10,7,5,.68) 100%)}
.hero-main img.bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-copy{position:relative;z-index:1;display:flex;flex-direction:column;justify-content:space-between;height:100%;padding:54px}
.hero-copy h1{font-size:clamp(2.7rem,6vw,5.2rem);line-height:1.02;margin:10px 0 18px;max-width:8.5em}
.hero-copy h1 span{color:var(--gold-soft)}
.hero-copy .lead{max-width:620px;color:#f3e7db;font-size:1.02rem}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:28px}
.hero-badges{display:flex;gap:10px;flex-wrap:wrap;margin-top:26px}
.hero-badges span{padding:9px 13px;border-radius:999px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.1);font-weight:700;color:#fff}
.hero-side{display:grid;gap:22px}
.logo-panel,.info-panel{background:linear-gradient(180deg,var(--surface),var(--surface-2));border:1px solid var(--line);border-radius:28px;padding:28px;box-shadow:var(--shadow)}
.logo-stack{display:grid;grid-template-columns:110px 1fr;gap:18px;align-items:center}
.logo-stack .mark{background:#fff;border-radius:20px;padding:12px;display:grid;place-items:center;min-height:110px}
.logo-stack .mark img{max-width:100%;max-height:86px;object-fit:contain}
.logo-panel .mascot{width:124px;max-width:38%;margin:20px 0 0 auto}
.logo-stack h2{font-size:1.8rem;line-height:1.15;margin:0 0 6px}
.logo-stack p{color:var(--muted);margin:0}
.notice-list{display:grid;gap:14px;margin-top:18px}
.notice-item{display:grid;grid-template-columns:auto 1fr;gap:12px;align-items:start;padding:14px 16px;border-radius:18px;background:rgba(255,255,255,.03);border:1px solid var(--line-soft)}
.notice-item b{color:var(--gold-soft)}
.notice-item span{color:var(--muted);font-size:.95rem}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.store-card{background:linear-gradient(180deg,var(--surface),rgba(33,24,18,.92));border:1px solid var(--line);border-radius:24px;overflow:hidden;box-shadow:var(--shadow)}
.store-card .thumb{aspect-ratio:4/3;overflow:hidden}
.store-card .thumb img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.store-card:hover .thumb img{transform:scale(1.04)}
.store-card .body{padding:20px 22px 24px}
.store-card h3{margin:0 0 8px;font-size:1.4rem}
.store-card p{margin:0;color:var(--muted)}
.gallery{display:grid;grid-template-columns:1.15fr 1fr 1fr;gap:18px}
.gallery .large{grid-row:span 2}
.tile{position:relative;border-radius:22px;overflow:hidden;border:1px solid var(--line);min-height:260px;box-shadow:var(--shadow);background:#22160e}
.tile img{width:100%;height:100%;object-fit:cover}
.tile .cap{position:absolute;left:16px;right:16px;bottom:16px;padding:12px 14px;border-radius:16px;background:linear-gradient(180deg,rgba(10,7,5,.05),rgba(10,7,5,.8));backdrop-filter:blur(8px)}
.tile .cap strong{display:block;font-size:1rem}.tile .cap span{color:#eadfce;font-size:.88rem}
.split{display:grid;grid-template-columns:1.08fr .92fr;gap:26px;align-items:center}
.service-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.service-card{display:block;padding:24px;border-radius:22px;border:1px solid var(--line);background:linear-gradient(180deg,var(--surface),rgba(27,21,15,.95));box-shadow:var(--shadow);position:relative;overflow:hidden;min-height:250px}
.service-card::before{content:"";position:absolute;right:-35px;bottom:-40px;width:150px;height:150px;border-radius:50%;background:rgba(244,109,12,.13)}
.service-card .num{display:inline-flex;width:36px;height:36px;border-radius:12px;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--orange),#ff9f4f);font-weight:900;margin-bottom:18px}
.service-card h3{margin:0 0 8px;font-size:1.3rem;line-height:1.25}
.service-card p{margin:0 0 18px;color:var(--muted)}
.service-card b{color:var(--gold-soft)}
.service-card.feature{background:linear-gradient(180deg,rgba(244,109,12,.25),rgba(27,21,15,.95))}
.service-card:hover{transform:translateY(-4px)}
.info-columns{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.info-box{padding:24px;border-radius:24px;border:1px solid var(--line);background:linear-gradient(180deg,var(--surface),rgba(25,18,13,.92));box-shadow:var(--shadow)}
.info-box h3{margin:0 0 14px;font-size:1.3rem}
.info-list{display:grid;gap:12px}
.info-list div{padding-bottom:12px;border-bottom:1px dashed rgba(255,255,255,.08)}
.info-list dt{font-size:.8rem;color:var(--gold);font-weight:800;letter-spacing:.08em}
.info-list dd{margin:4px 0 0;color:var(--muted)}
.mini-gallery{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.mini-gallery .tile{min-height:230px}
.cta-band{padding:28px 30px;border-radius:26px;background:linear-gradient(135deg,rgba(244,109,12,.18),rgba(255,255,255,.03));border:1px solid rgba(244,109,12,.25);display:flex;justify-content:space-between;gap:24px;align-items:center;box-shadow:var(--shadow)}
.cta-band p{margin:0;color:#f4e8dc;max-width:650px}
.map-wrap{border-radius:24px;overflow:hidden;border:1px solid var(--line);background:linear-gradient(180deg,var(--surface),rgba(25,18,13,.92));box-shadow:var(--shadow)}
.map-image-link{display:block}
.map-image{display:block;width:100%;height:auto;min-height:420px;object-fit:cover}
.footer{padding:34px 0 48px;border-top:1px solid var(--line);margin-top:40px}
.footer .inner{max-width:var(--max);margin:0 auto;padding:0 20px;display:flex;justify-content:space-between;gap:24px;align-items:flex-start}
.footer p{margin:6px 0 0;color:var(--muted);font-size:.92rem}
.footer .small{color:#aa9d8e;font-size:.82rem;max-width:720px}
.subhero{padding:24px 0 0}
.subhero-wrap{max-width:var(--max);margin:0 auto;padding:0 20px}
.subhero-box{display:grid;grid-template-columns:1.05fr .95fr;gap:24px;align-items:stretch}
.subhero-copy,.subhero-image{border-radius:30px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow)}
.subhero-copy{padding:42px;background:linear-gradient(180deg,var(--surface),var(--surface-2))}
.subhero-copy h1{font-size:clamp(2.4rem,5vw,4.6rem);line-height:1.05;margin:12px 0}
.subhero-copy h1 span{color:var(--gold-soft)}
.subhero-copy p{color:var(--muted)}
.subhero-image img{width:100%;height:100%;object-fit:cover;min-height:320px}
.service-index{position:sticky;top:74px;z-index:20;background:rgba(10,7,5,.84);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);margin-top:24px}
.service-index .inner{max-width:var(--max);margin:0 auto;padding:12px 20px;display:flex;gap:10px;overflow:auto}
.service-index a{padding:10px 14px;border-radius:999px;border:1px solid var(--line);white-space:nowrap;background:rgba(255,255,255,.03);font-weight:700;color:#efe3d1}
.service-index a:hover{background:rgba(244,109,12,.15);border-color:rgba(244,109,12,.22)}
.service-section{padding:72px 0;scroll-margin-top:140px}
.service-layout{display:grid;grid-template-columns:1.08fr .92fr;gap:26px;align-items:start}
.service-copy-box{padding:28px;border-radius:26px;border:1px solid var(--line);background:linear-gradient(180deg,var(--surface),var(--surface-2));box-shadow:var(--shadow)}
.service-copy-box h2{font-size:2rem;line-height:1.18;margin:10px 0 14px}
.service-copy-box p{color:var(--muted)}
.points{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:22px}
.points .point{padding:14px 16px;border-radius:18px;border:1px solid var(--line-soft);background:rgba(255,255,255,.03)}
.points .point b{display:block;color:var(--gold-soft);margin-bottom:2px;font-size:.9rem}
.points .point span{color:var(--muted);font-size:.92rem}
.service-photo-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.service-photo-grid .tile{min-height:230px}
.service-photo-grid .tile.wide{grid-column:1 / -1;min-height:280px}
.note-box{margin-top:18px;padding:16px 18px;border-left:4px solid var(--orange);background:rgba(244,109,12,.08);border-radius:16px;color:#f1e5d8}
@media (max-width:1080px){
  .hero-grid,.section-head,.split,.subhero-box,.service-layout,.grid-2,.info-columns{grid-template-columns:1fr}
  .service-grid{grid-template-columns:repeat(2,1fr)}
  .gallery{grid-template-columns:1fr 1fr}
  .gallery .large{grid-row:auto}
}
@media (max-width:780px){
  .menu-toggle{display:block;margin-left:auto}
  .global-nav{display:none;position:absolute;left:0;right:0;top:77px;padding:14px 20px 20px;background:rgba(8,6,5,.96);border-bottom:1px solid var(--line);flex-direction:column;align-items:flex-start}
  body.nav-open .global-nav{display:flex}
  .nav-actions{display:none}
  .hero-copy{padding:30px}
  .hero-main{min-height:560px}
  .service-grid,.gallery,.mini-gallery,.service-photo-grid,.points{grid-template-columns:1fr}
  .gallery .large,.service-photo-grid .tile.wide{grid-column:auto}
  .footer .inner{display:block}
  .logo-stack{grid-template-columns:1fr}
}
@media (max-width:560px){
  .container,.site-header .inner,.hero-grid,.subhero-wrap,.service-index .inner{padding-left:16px;padding-right:16px}
  .hero-copy h1{font-size:2.8rem}
  .hero-actions .btn,.cta-band .btn,.nav-actions .btn{width:100%}
  .hero-actions,.cta-band{display:block}
  .hero-actions .btn + .btn,.cta-band .btn + .btn{margin-top:10px}
  .service-grid{grid-template-columns:1fr}
  .brand-text strong{font-size:1rem}
  .brand-text small{display:none}
}


.brand-sub{color:var(--gold-soft);font-size:.78rem;font-weight:800;letter-spacing:.08em}
.logo-note{margin-top:16px;padding:16px 18px;border-radius:18px;background:rgba(255,255,255,.035);border:1px solid var(--line-soft)}
.logo-note p{margin:0 0 8px;color:#efe2d3}
.mini-link{display:inline-flex;align-items:center;gap:6px;color:var(--gold-soft);font-weight:800;font-size:.92rem}
.kelly-box{position:relative}
.kelly-head{display:grid;grid-template-columns:120px 1fr;gap:16px;align-items:center;margin-bottom:14px}
.kelly-head img{width:120px;height:120px;object-fit:cover;border-radius:24px;border:1px solid var(--line);box-shadow:var(--shadow)}
.kelly-quote{margin:4px 0 0;color:#f7ebdc;font-weight:700;line-height:1.7}
.service-title{font-size:clamp(1.9rem,5.5vw,4.2rem)!important;line-height:1.1;white-space:nowrap;letter-spacing:.01em}
.service-kelly{padding-top:34px;padding-bottom:10px}
.kelly-banner{display:grid;grid-template-columns:140px 1fr;gap:20px;align-items:center;padding:20px 24px;border-radius:24px;border:1px solid var(--line);background:linear-gradient(135deg,rgba(255,255,255,.04),rgba(244,109,12,.08));box-shadow:var(--shadow)}
.kelly-banner img{width:140px;height:140px;object-fit:cover;border-radius:26px;border:1px solid var(--line)}
.kelly-banner h2{margin:6px 0 8px;font-size:1.8rem}
.kelly-banner p{margin:0;color:#f3e5d7}
.service-photo-grid .tile{min-height:0;background:linear-gradient(180deg,var(--surface),rgba(28,22,16,.96));}
.service-photo-grid .tile img{width:100%;height:290px;object-fit:cover;transform:scale(1.08);transform-origin:center;display:block}
.service-photo-grid .tile.wide img{height:360px}
.service-photo-grid .tile .cap{position:static;left:auto;right:auto;bottom:auto;margin:0;padding:14px 16px 16px;border-radius:0;background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.02));backdrop-filter:none}
.service-photo-grid .tile .cap strong{font-size:1.08rem;margin-bottom:4px}
.service-photo-grid .tile .cap span{display:block;font-size:.92rem;line-height:1.6;color:#eadfce}
.notice-item a,.info-list a{color:var(--gold-soft);font-weight:800}

@media (max-width:780px){
  .kelly-banner{grid-template-columns:1fr;text-align:left}
  .kelly-banner img{width:112px;height:112px}
  .kelly-head{grid-template-columns:96px 1fr}
  .kelly-head img{width:96px;height:96px}
  .service-title{white-space:normal;font-size:clamp(2rem,9vw,3rem)!important}
  .service-photo-grid .tile img{height:250px}
  .service-photo-grid .tile.wide img{height:280px}
}
@media (max-width:560px){
  .service-title{font-size:clamp(2rem,8vw,2.8rem)!important;line-height:1.18}
  .kelly-head{grid-template-columns:1fr}
}


/* v8: izakaya-friendly + Kelly forward */
.kelly-hero-panel{display:grid;grid-template-columns:132px 1fr;gap:18px;align-items:center;background:linear-gradient(135deg,rgba(255,224,166,.12),rgba(244,109,12,.16));border:1px solid rgba(255,224,166,.18);border-radius:28px;padding:22px;box-shadow:var(--shadow);position:relative;overflow:hidden}
.kelly-hero-panel::after{content:"ワン！";position:absolute;right:18px;top:12px;font-weight:900;color:rgba(255,224,166,.13);font-size:3.5rem;transform:rotate(-8deg)}
.kelly-hero-panel img{width:132px;height:132px;object-fit:cover;border-radius:28px;border:2px solid rgba(255,224,166,.35);box-shadow:0 18px 42px rgba(0,0,0,.28)}
.kelly-hero-panel h2{margin:4px 0 6px;font-size:1.55rem;line-height:1.25}
.kelly-hero-panel p{margin:0 0 8px;color:#f6eadc;font-weight:700;position:relative;z-index:1}
.kelly-feature{margin-top:26px;display:grid;grid-template-columns:180px 1fr;gap:22px;align-items:center;padding:22px 26px;border-radius:28px;border:1px solid rgba(255,224,166,.18);background:linear-gradient(135deg,rgba(244,109,12,.18),rgba(255,255,255,.04));box-shadow:var(--shadow)}
.kelly-feature-image img{width:180px;height:180px;object-fit:cover;border-radius:34px;border:2px solid rgba(255,224,166,.35)}
.kelly-feature-copy h3{font-size:1.85rem;margin:4px 0 8px}
.kelly-feature-copy p{margin:0;color:#f3e5d7;font-weight:700;line-height:1.8}
.kelly-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
.kelly-tags span{background:rgba(255,224,166,.12);border:1px solid rgba(255,224,166,.2);border-radius:999px;padding:7px 12px;color:var(--gold-soft);font-weight:800;font-size:.88rem}
.service-card{transition:.2s ease}
.kelly-box{background:linear-gradient(180deg,rgba(244,109,12,.13),rgba(25,18,13,.92))}
.kelly-head img{transform:scale(1.04)}
@media (max-width:780px){
  .kelly-hero-panel,.kelly-feature{grid-template-columns:1fr;text-align:left}
  .kelly-hero-panel img,.kelly-feature-image img{width:124px;height:124px}
  .kelly-hero-panel::after{font-size:2.7rem;top:auto;bottom:8px}
}


/* v9 refinements: calmer Kelly, better balance, fuller layout */
.site-header .inner{gap:14px}
.brand{min-width:220px;max-width:220px}
.brand-text strong{font-size:1.02rem}
.brand-text small{font-size:.8rem;line-height:1.25}
.global-nav{gap:14px;flex:1;justify-content:center}
.global-nav a,.btn{white-space:nowrap}
.global-nav a{font-size:.88rem;letter-spacing:.01em}
.nav-actions{gap:8px}
.btn{min-height:44px;padding:0 15px;font-size:.94rem}
.hero-grid{grid-template-columns:1.05fr .95fr;gap:22px}
.hero-main{min-height:600px}
.hero-copy{padding:42px}
.hero-copy h1{font-size:clamp(2.6rem,5vw,4.55rem);line-height:1.06;max-width:7.8em;margin-bottom:16px}
.hero-copy .lead{font-size:1rem;max-width:34rem}
.kbd{font-size:.82rem;padding:.45rem .8rem}
.section-head h2{font-size:clamp(1.9rem,3.6vw,2.9rem);line-height:1.18}
.kelly-hero-panel{grid-template-columns:92px 1fr;padding:18px 20px;background:linear-gradient(135deg,rgba(255,224,166,.08),rgba(244,109,12,.08));border-color:rgba(255,224,166,.12)}
.kelly-hero-panel::after{content:none}
.kelly-hero-panel img{width:92px;height:92px;border-radius:22px;border-width:1px}
.kelly-hero-panel h2{font-size:1.18rem;margin-bottom:4px}
.kelly-hero-panel p{font-size:.96rem;font-weight:600;line-height:1.65;margin-bottom:10px}
.hero-reco-list{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:10px}
.hero-reco-list span{padding:6px 10px;border-radius:999px;border:1px solid rgba(255,224,166,.18);background:rgba(255,255,255,.04);color:var(--gold-soft);font-size:.82rem;font-weight:700}
.logo-panel,.info-panel,.kelly-hero-panel{padding:24px}
.logo-stack{grid-template-columns:88px 1fr;gap:16px}
.logo-stack .mark{min-height:88px;padding:10px;border-radius:18px}
.logo-stack .mark img{max-height:68px}
.logo-stack h2{font-size:1.55rem;line-height:1.2}
.logo-note{padding:14px 16px;margin-top:14px}
.logo-highlights{display:grid;gap:10px;margin-top:14px}
.logo-highlights div{display:grid;grid-template-columns:64px 1fr;gap:12px;padding:12px 14px;border-radius:16px;background:rgba(255,255,255,.03);border:1px solid var(--line-soft)}
.logo-highlights b{color:var(--gold-soft);font-size:.86rem;letter-spacing:.04em}
.logo-highlights span{color:var(--muted);font-size:.92rem}
.notice-item{padding:12px 14px;border-radius:16px}
.notice-item b{font-size:.92rem}
.gallery .tile .cap,.mini-gallery .tile .cap{padding:14px 14px 13px}
.gallery .tile .cap strong,.mini-gallery .tile .cap strong{font-size:1rem}
.service-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}
.service-card{min-height:220px;padding:22px}
.service-card h3{font-size:1.18rem;line-height:1.34}
.service-card p{font-size:.95rem;line-height:1.65}
.kelly-feature{grid-template-columns:96px 1fr;gap:18px;padding:18px 20px;background:linear-gradient(135deg,rgba(255,255,255,.035),rgba(244,109,12,.08));border-color:rgba(255,255,255,.08)}
.kelly-feature-image img{width:96px;height:96px;border-width:1px;border-radius:24px}
.kelly-feature-copy h3{font-size:1.35rem;margin-bottom:6px}
.kelly-feature-copy p{font-size:.96rem;font-weight:600;line-height:1.7}
.kelly-tags span{font-size:.82rem;padding:6px 10px}
.first-guide-box h3{font-size:1.35rem}
.guide-lead{margin:0 0 14px;color:#efe2d3}
.mini-kelly-inline{display:grid;grid-template-columns:70px 1fr;gap:12px;align-items:center;margin-top:16px;padding:12px 14px;border-radius:16px;background:rgba(255,255,255,.03);border:1px solid var(--line-soft)}
.mini-kelly-inline img{width:70px;height:70px;object-fit:cover;border-radius:18px}
.mini-kelly-inline p{margin:0;color:#f0e1d1;font-size:.95rem;font-weight:600;line-height:1.6}
.subhero-copy{padding:38px}
.subhero-copy p{font-size:1rem;line-height:1.75}
.service-title{font-size:clamp(2.2rem,4.2vw,3.4rem)!important;line-height:1.15;white-space:normal;max-width:12em}
.service-kelly{padding-top:26px;padding-bottom:0}
.kelly-banner{grid-template-columns:88px 1fr;padding:16px 18px;gap:16px;background:linear-gradient(135deg,rgba(255,255,255,.03),rgba(244,109,12,.06))}
.kelly-banner.soft img,.kelly-banner img{width:88px;height:88px;border-radius:20px}
.kelly-banner h2{font-size:1.2rem;margin-bottom:4px}
.kelly-banner p{font-size:.95rem;line-height:1.65}
.service-summary-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin-top:18px}
.service-summary-grid div{padding:14px 16px;border-radius:18px;background:rgba(255,255,255,.03);border:1px solid var(--line-soft)}
.service-summary-grid b{display:block;color:var(--gold-soft);margin-bottom:4px;font-size:.94rem}
.service-summary-grid span{color:var(--muted);font-size:.92rem;line-height:1.6}
.service-copy-box{padding:24px 26px}
.service-copy-box h2{font-size:1.72rem;line-height:1.25}
.service-copy-box p{font-size:.98rem;line-height:1.8}
.points .point{padding:13px 14px}
.points .point span{line-height:1.58}
.service-photo-grid{gap:14px}
.service-photo-grid .tile img{height:260px;transform:scale(1.04)}
.service-photo-grid .tile.wide img{height:320px}
.service-photo-grid .tile .cap strong{font-size:1rem}
.service-photo-grid .tile .cap span{font-size:.9rem;line-height:1.55}
.cta-band h3{font-size:1.45rem !important;line-height:1.3}
@media (max-width:1220px){
  .brand{min-width:190px;max-width:190px}
  .global-nav{gap:10px}
  .global-nav a{font-size:.84rem}
  .btn{padding:0 12px;font-size:.9rem}
}
@media (max-width:1080px){
  .brand{min-width:0;max-width:none}
  .hero-grid,.section-head,.split,.subhero-box,.service-layout,.grid-2,.info-columns{grid-template-columns:1fr}
  .service-summary-grid{grid-template-columns:1fr 1fr 1fr}
}
@media (max-width:780px){
  .kelly-hero-panel,.kelly-feature,.kelly-banner,.mini-kelly-inline{grid-template-columns:1fr}
  .kelly-hero-panel img,.kelly-feature-image img,.kelly-banner img,.mini-kelly-inline img{width:96px;height:96px}
  .service-grid,.service-summary-grid{grid-template-columns:1fr}
  .hero-main{min-height:540px}
  .hero-copy{padding:28px}
  .hero-copy h1{font-size:clamp(2.25rem,8vw,3.2rem)}
  .site-header .inner{gap:10px}
}
@media (max-width:560px){
  .brand-text strong{font-size:.96rem}
  .hero-badges span{font-size:.85rem}
  .logo-highlights div{grid-template-columns:1fr}
  .service-title{font-size:clamp(1.95rem,7vw,2.5rem)!important}
}


/* v13: honma draft beer feature */
.beer-section{padding-top:0}
.beer-feature{display:grid;grid-template-columns:.96fr 1.04fr;gap:24px;align-items:stretch;border:1px solid rgba(255,224,166,.18);border-radius:30px;background:linear-gradient(135deg,rgba(244,109,12,.15),rgba(255,255,255,.035));box-shadow:var(--shadow);overflow:hidden}
.beer-photo{min-height:360px;background:#1c120c}
.beer-photo img{width:100%;height:100%;object-fit:cover}
.beer-copy{padding:34px;display:flex;flex-direction:column;justify-content:center}
.beer-copy h3{font-size:clamp(1.55rem,3vw,2.4rem);line-height:1.22;margin:8px 0 12px}
.beer-copy p{margin:0 0 12px;color:#f2e5d7;line-height:1.85}
.beer-points{display:flex;flex-wrap:wrap;gap:8px;margin:12px 0 16px}
.beer-points span{padding:8px 12px;border-radius:999px;background:rgba(255,224,166,.12);border:1px solid rgba(255,224,166,.22);color:var(--gold-soft);font-weight:800;font-size:.9rem}
.beer-kelly{margin-top:4px;background:rgba(0,0,0,.18);border-color:rgba(255,224,166,.16)}
@media (max-width:900px){.beer-feature{grid-template-columns:1fr}.beer-photo{min-height:280px}.beer-copy{padding:24px}}
@media (max-width:560px){.beer-section{padding-top:20px}.beer-copy{padding:20px}.beer-photo{min-height:240px}.beer-points span{font-size:.82rem}}

/* v10: casual izakaya + stronger first view + mobile first + captions not covering images */
body{font-size:15.5px;background:radial-gradient(circle at top,rgba(244,109,12,.10),transparent 26%),linear-gradient(180deg,#0d0907,#120d09 22%,#120c08 100%)}
.site-header{background:rgba(10,7,5,.92)}
.site-header .inner{padding:10px 14px;gap:10px;flex-wrap:wrap}
.brand{max-width:none;min-width:0;flex:1 1 auto}
.brand-mark{width:46px;height:46px;border-radius:12px}
.brand-text{min-width:0}
.brand-text strong{font-size:1rem;letter-spacing:.01em}
.brand-text small{display:block;font-size:.75rem;line-height:1.2}
.global-nav{order:3;flex:1 1 100%;justify-content:flex-start;gap:10px;overflow:auto;padding-bottom:2px}
.global-nav a{font-size:.82rem;padding:7px 10px;border-radius:999px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06)}
.nav-actions{gap:8px;margin-left:auto}
.nav-actions .btn{min-height:40px;padding:0 13px;font-size:.88rem}
.hero{padding:16px 0 0}
.hero-grid{display:grid;grid-template-columns:1fr;gap:18px;padding:0 14px}
.hero-main{min-height:560px;border-radius:26px}
.hero-main::after{background:linear-gradient(180deg,rgba(11,8,6,.28),rgba(11,8,6,.54) 35%,rgba(11,8,6,.78) 68%,rgba(11,8,6,.92) 100%)}
.hero-copy{padding:24px 22px 22px;justify-content:flex-end;gap:16px}
.hero-copy h1{font-size:clamp(2.2rem,9vw,3.8rem);line-height:1.08;max-width:8.2em;margin:4px 0 8px;text-shadow:0 4px 20px rgba(0,0,0,.35)}
.hero-copy .lead{font-size:.97rem;line-height:1.75;max-width:none}
.hero-actions{margin-top:18px;display:grid;grid-template-columns:1fr 1fr;gap:10px}
.hero-actions .btn{width:100%;min-height:46px}
.hero-badges{margin-top:14px;gap:8px}
.hero-badges span{font-size:.83rem;padding:8px 12px;background:rgba(0,0,0,.28)}
.hero-quick-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-top:16px}
.hero-quick-grid div{padding:12px 10px;border-radius:16px;background:rgba(255,255,255,.06);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.08)}
.hero-quick-grid b{display:block;color:var(--gold-soft);font-size:.78rem;margin-bottom:3px}
.hero-quick-grid span{display:block;font-size:.88rem;color:#fff;line-height:1.4}
.kbd{display:inline-flex;padding:.5rem .8rem;font-size:.78rem;background:rgba(255,255,255,.05)}
.hero-side{display:grid;gap:18px}
.kelly-hero-panel{grid-template-columns:72px 1fr;padding:16px 16px 15px;border-radius:22px}
.kelly-hero-panel img{width:72px;height:72px;border-radius:18px}
.kelly-hero-panel h2{font-size:1.05rem}
.kelly-hero-panel p{font-size:.9rem;line-height:1.65}
.hero-reco-list span{font-size:.78rem;padding:5px 9px}
.logo-panel,.info-panel,.store-card,.info-box{border-radius:22px}
.logo-panel,.info-panel{padding:18px}
.logo-stack{grid-template-columns:72px 1fr;gap:14px}
.logo-stack .mark{min-height:72px;border-radius:16px}
.logo-stack .mark img{max-height:52px}
.logo-stack h2{font-size:1.34rem}
.logo-stack p,.logo-note p,.section-head p,.service-card p,.store-card p,.guide-lead{font-size:.94rem;line-height:1.7}
.logo-note,.notice-item,.logo-highlights div,.mini-kelly-inline{border-radius:14px}
.logo-highlights{grid-template-columns:1fr;gap:8px}
.logo-highlights div{grid-template-columns:56px 1fr;padding:10px 12px}
.notice-list{gap:10px}
.notice-item{padding:10px 12px;grid-template-columns:70px 1fr}
.section{padding:60px 0}
.container{padding:0 14px}
.section-head{display:grid;gap:10px;align-items:start;margin-bottom:24px}
.section-head h2{font-size:clamp(1.65rem,6vw,2.35rem);line-height:1.26}
.grid-2,.info-columns,.split,.service-layout,.subhero-box{grid-template-columns:1fr !important;gap:18px}
.store-card .thumb,.mini-gallery .tile,.gallery .tile{border-bottom-left-radius:0;border-bottom-right-radius:0}
.store-card .body{padding:16px 16px 18px}
.store-card h3{font-size:1.18rem}
.gallery,.mini-gallery{grid-template-columns:1fr 1fr;gap:14px}
.gallery .large{grid-column:1 / -1}
.tile{min-height:unset;border-radius:20px;overflow:hidden;background:linear-gradient(180deg,var(--surface),rgba(25,18,13,.98))}
.tile img{width:100%;height:220px;object-fit:cover}
.gallery .large img{height:270px}
/* fix comments hiding images: captions now below images, not overlay */
.tile .cap{position:static !important;left:auto !important;right:auto !important;bottom:auto !important;margin:0;padding:12px 14px 14px;border-radius:0;background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.015));backdrop-filter:none}
.tile .cap strong{font-size:1rem;display:block;margin-bottom:4px}
.tile .cap span{font-size:.88rem;line-height:1.55;color:#e2d7c9}
.service-grid{grid-template-columns:1fr;gap:14px}
.service-card{min-height:unset;padding:18px;border-radius:18px}
.service-card .num{width:32px;height:32px;font-size:.86rem;margin-bottom:14px}
.service-card h3{font-size:1.08rem}
.kelly-feature{grid-template-columns:68px 1fr;padding:16px;border-radius:20px;margin-top:18px}
.kelly-feature-image img{width:68px;height:68px;border-radius:18px}
.kelly-feature-copy h3{font-size:1.14rem}
.kelly-feature-copy p{font-size:.92rem;line-height:1.7}
.kelly-tags{margin-top:10px}
.kelly-tags span{font-size:.76rem;padding:5px 8px}
.first-guide-box h3{font-size:1.18rem}
.mini-kelly-inline{grid-template-columns:54px 1fr;padding:10px 12px}
.mini-kelly-inline img{width:54px;height:54px;border-radius:14px}
.mini-kelly-inline p{font-size:.88rem}
.subhero{padding:14px 0 0}
.subhero-wrap{padding:0 14px}
.subhero-copy,.subhero-image{border-radius:24px}
.subhero-copy{padding:24px 20px}
.subhero-image img{min-height:260px}
.service-title{font-size:clamp(1.85rem,7vw,2.7rem)!important;max-width:none;line-height:1.26}
.service-index{top:112px;margin-top:16px}
.service-index .inner{padding:10px 14px;gap:8px}
.service-index a{font-size:.83rem;padding:9px 12px}
.kelly-banner{grid-template-columns:64px 1fr;padding:14px;border-radius:18px}
.kelly-banner img{width:64px;height:64px;border-radius:16px}
.kelly-banner h2{font-size:1.05rem}
.kelly-banner p{font-size:.9rem}
.service-summary-grid{grid-template-columns:1fr;gap:10px}
.service-summary-grid div{padding:12px 14px;border-radius:14px}
.service-section{padding:48px 0;scroll-margin-top:154px}
.service-copy-box{padding:18px;border-radius:20px}
.service-copy-box h2{font-size:1.4rem}
.service-copy-box p{font-size:.94rem}
.points{grid-template-columns:1fr;gap:10px}
.service-photo-grid{grid-template-columns:1fr;gap:14px}
.service-photo-grid .tile,.service-photo-grid .tile.wide{grid-column:auto;min-height:unset}
.service-photo-grid .tile img,.service-photo-grid .tile.wide img{height:240px;transform:none}
.cta-band{padding:18px;border-radius:22px;display:grid;gap:14px}
.cta-band h3{font-size:1.18rem !important}
.footer{padding:28px 0 38px}
.footer .inner{display:grid;gap:12px;padding:0 14px}
@media (min-width:640px){
  .hero-grid{grid-template-columns:1.06fr .94fr}
  .global-nav{order:0;flex:1;justify-content:center;overflow:visible;padding-bottom:0}
  .site-header .inner{flex-wrap:nowrap;padding:10px 18px}
  .brand{flex:0 0 auto}
  .nav-actions{margin-left:0}
  .hero-main{min-height:610px}
  .hero-copy{padding:34px}
  .gallery,.mini-gallery{grid-template-columns:repeat(2,1fr)}
  .service-grid{grid-template-columns:repeat(2,1fr)}
  .service-summary-grid{grid-template-columns:repeat(3,1fr)}
}
@media (min-width:900px){
  .hero{padding-top:22px}
  .hero-grid{grid-template-columns:1.08fr .92fr;gap:22px;padding:0 20px}
  .container{padding:0 20px}
  .hero-main{min-height:640px}
  .hero-copy{padding:42px}
  .hero-copy h1{font-size:clamp(2.8rem,4.8vw,4.45rem)}
  .hero-actions{grid-template-columns:auto auto;justify-content:flex-start}
  .hero-quick-grid{max-width:540px}
  .section-head{grid-template-columns:1fr auto;align-items:end}
  .gallery{grid-template-columns:1.15fr 1fr 1fr}
  .gallery .large{grid-column:auto;grid-row:span 2}
  .tile img{height:240px}
  .gallery .large img{height:100%}
  .service-grid{grid-template-columns:repeat(3,1fr)}
  .split,.info-columns,.grid-2,.service-layout,.subhero-box{grid-template-columns:1.05fr .95fr !important}
  .service-photo-grid{grid-template-columns:1fr 1fr}
  .service-photo-grid .tile.wide{grid-column:1 / -1}
  .service-photo-grid .tile img{height:260px}
  .service-photo-grid .tile.wide img{height:310px}
  .kelly-feature{grid-template-columns:88px 1fr}
  .kelly-feature-image img{width:88px;height:88px}
}


/* v11: prevent awkward line break in hero title */
.hero-copy h1 .keep-phrase{white-space:nowrap;display:inline-block}

/* v13 final override: honma draft beer section */
.beer-section{padding-top:0 !important}
.beer-feature{display:grid;grid-template-columns:.96fr 1.04fr;gap:24px;align-items:stretch;border:1px solid rgba(255,224,166,.18);border-radius:30px;background:linear-gradient(135deg,rgba(244,109,12,.15),rgba(255,255,255,.035));box-shadow:var(--shadow);overflow:hidden}
.beer-photo{min-height:360px;background:#1c120c}
.beer-photo img{width:100%;height:100%;object-fit:cover}
.beer-copy{padding:34px;display:flex;flex-direction:column;justify-content:center}
.beer-copy h3{font-size:clamp(1.55rem,3vw,2.4rem);line-height:1.22;margin:8px 0 12px}
.beer-copy p{margin:0 0 12px;color:#f2e5d7;line-height:1.85}
.beer-points{display:flex;flex-wrap:wrap;gap:8px;margin:12px 0 16px}
.beer-points span{padding:8px 12px;border-radius:999px;background:rgba(255,224,166,.12);border:1px solid rgba(255,224,166,.22);color:var(--gold-soft);font-weight:800;font-size:.9rem}
.beer-kelly{margin-top:4px;background:rgba(0,0,0,.18);border-color:rgba(255,224,166,.16)}
@media (max-width:900px){.beer-feature{grid-template-columns:1fr}.beer-photo{min-height:280px}.beer-copy{padding:24px}}
@media (max-width:560px){.beer-section{padding-top:20px !important}.beer-copy{padding:20px}.beer-photo{min-height:240px}.beer-points span{font-size:.82rem}}

/* v14: mobile optimization + full-image display */
html, body{max-width:100%;overflow-x:hidden}
.btn{max-width:100%;min-width:0;text-align:center;line-height:1.35}
.subhero-copy .hero-actions{grid-template-columns:1fr;gap:10px;max-width:100%}
.subhero-copy .hero-actions .btn{width:100%;white-space:normal;padding:10px 14px;min-height:48px}

/* Keep important photos fully visible instead of cutting them off */
.store-card .thumb,
.tile,
.service-photo-grid .tile,
.subhero-image,
.beer-photo{background:#160f0b}
.store-card .thumb img,
.tile img,
.gallery .large img,
.mini-gallery .tile img,
.service-photo-grid .tile img,
.service-photo-grid .tile.wide img,
.subhero-image img,
.beer-photo img{object-fit:contain !important;object-position:center center;transform:none !important;background:#160f0b}
.logo-stack .mark img,
.brand-mark img{object-fit:contain !important;background:#fff}
.hero-main img.bg{object-fit:cover !important}

@media (max-width:640px){
  .site-header .inner{padding:8px 12px;gap:8px}
  .brand-mark{width:44px;height:44px;flex:0 0 44px}
  .brand-text strong{font-size:.96rem;line-height:1.15}
  .menu-toggle{font-size:1.45rem;padding:4px 8px}
  .subhero-copy{padding:20px 16px}
  .subhero-copy p{font-size:.93rem;line-height:1.75}
  .subhero-copy .hero-actions{display:grid !important;grid-template-columns:1fr !important;margin-top:16px}
  .hero-actions{gap:9px}
  .hero-actions .btn{white-space:normal}
  .subhero-image img{height:230px;min-height:0;padding:6px}
  .tile img{height:200px;padding:6px}
  .gallery .large img{height:230px;padding:6px}
  .service-photo-grid .tile img,
  .service-photo-grid .tile.wide img{height:220px;padding:6px}
  .store-card .thumb img{padding:6px}
  .beer-photo img{padding:6px}
  .service-index{top:62px}
  .service-index .inner{padding:8px 12px}
}

@media (min-width:641px) and (max-width:899px){
  .subhero-copy .hero-actions{grid-template-columns:1fr 1fr}
  .subhero-copy .hero-actions .btn{white-space:normal}
  .subhero-image img{height:300px;min-height:0;padding:8px}
  .tile img{padding:6px}
  .service-photo-grid .tile img,
  .service-photo-grid .tile.wide img{padding:8px}
}

/* =========================================================
   v15: professional smartphone-first cleanup
   - Force single-column layout on phones
   - Keep photos fully visible instead of cropped
   - Make header/menu/buttons safe for narrow screens
   ========================================================= */
@media (max-width: 767px){
  html,body{width:100%;max-width:100%;overflow-x:hidden}
  body{font-size:15px;line-height:1.75}
  .container,.hero-grid,.subhero-wrap,.service-index .inner,.site-header .inner{padding-left:14px!important;padding-right:14px!important}

  /* Header / hamburger menu */
  .site-header .inner{min-height:60px;padding-top:8px!important;padding-bottom:8px!important;gap:8px;position:relative}
  .brand{min-width:0!important;max-width:calc(100% - 52px)!important;flex:1 1 auto;gap:10px}
  .brand-mark{width:44px!important;height:44px!important;flex:0 0 44px;border-radius:12px}
  .brand-text{min-width:0}
  .brand-text strong{font-size:.96rem!important;line-height:1.15;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
  .brand-text small{display:none!important}
  .menu-toggle{display:block!important;margin-left:auto!important;line-height:1;padding:6px 8px;border-radius:10px;background:rgba(255,255,255,.04)}
  .nav-actions{display:none!important}
  .global-nav{display:none!important;position:absolute!important;left:0!important;right:0!important;top:60px!important;z-index:100;background:rgba(8,6,5,.98)!important;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:8px 14px!important;flex-direction:column!important;align-items:stretch!important;gap:0!important;max-height:calc(100dvh - 60px);overflow-y:auto;box-shadow:0 22px 44px rgba(0,0,0,.38)}
  body.nav-open .global-nav{display:flex!important}
  .global-nav a{display:block;width:100%;padding:13px 4px;border-bottom:1px solid rgba(255,255,255,.07);font-size:.95rem!important;white-space:normal!important}
  .global-nav a:last-child{border-bottom:0}

  /* Hero and button safety */
  .hero{padding-top:14px!important}
  .hero-grid{display:grid!important;grid-template-columns:1fr!important;gap:14px!important}
  .hero-main{min-height:0!important;border-radius:24px!important}
  .hero-copy{min-height:520px;padding:24px 18px!important;justify-content:space-between}
  .hero-copy h1{font-size:clamp(2rem,10.5vw,3.05rem)!important;line-height:1.12!important;max-width:9em!important;margin:8px 0 14px!important}
  .hero-copy .lead{font-size:.94rem!important;line-height:1.8!important;max-width:100%!important}
  .hero-actions{display:grid!important;grid-template-columns:1fr!important;gap:10px!important;margin-top:18px!important}
  .hero-actions .btn,.cta-band .btn,.btn{width:100%;max-width:100%;min-width:0;white-space:normal!important;overflow-wrap:anywhere;text-align:center;padding:10px 14px;min-height:46px}
  .hero-badges{display:grid!important;grid-template-columns:1fr!important;gap:8px!important;margin-top:16px!important}
  .hero-badges span{font-size:.84rem;padding:8px 10px;text-align:center}
  .kbd{border-radius:16px;line-height:1.55;white-space:normal}

  /* Compact side panels */
  .kelly-hero-panel{display:grid!important;grid-template-columns:70px 1fr!important;gap:12px!important;padding:14px!important;border-radius:20px!important;text-align:left!important}
  .kelly-hero-panel img{width:70px!important;height:70px!important;border-radius:17px!important}
  .kelly-hero-panel h2{font-size:1.04rem!important;line-height:1.3!important;margin:3px 0 4px!important}
  .kelly-hero-panel p{font-size:.88rem!important;line-height:1.6!important;margin-bottom:8px!important}
  .hero-reco-list{gap:6px!important;margin-bottom:6px!important}
  .hero-reco-list span,.kelly-tags span{font-size:.74rem!important;padding:4px 7px!important}
  .logo-panel,.info-panel,.info-box,.store-card{border-radius:20px!important}
  .logo-panel,.info-panel{padding:16px!important}
  .logo-stack{display:grid!important;grid-template-columns:64px 1fr!important;gap:12px!important;align-items:center!important}
  .logo-stack .mark{min-height:64px!important;border-radius:14px!important;padding:8px!important}
  .logo-stack .mark img{max-height:48px!important}
  .logo-stack h2{font-size:1.2rem!important;line-height:1.3!important}
  .logo-stack p,.logo-note p,.notice-item span{font-size:.9rem!important;line-height:1.7!important}
  .logo-note{padding:12px!important;border-radius:14px!important}
  .logo-highlights{display:grid!important;grid-template-columns:1fr!important;gap:8px!important}
  .logo-highlights div{display:grid!important;grid-template-columns:4.5em 1fr!important;gap:8px!important;padding:10px 12px!important}
  .notice-item{display:grid!important;grid-template-columns:4.8em 1fr!important;gap:8px!important;padding:10px 12px!important;border-radius:14px!important}

  /* Sections */
  .section{padding:48px 0!important}
  .section-head{display:grid!important;grid-template-columns:1fr!important;gap:10px!important;margin-bottom:22px!important;align-items:start!important}
  .section-head h2{font-size:clamp(1.55rem,7.8vw,2.2rem)!important;line-height:1.28!important}
  .section-head p{font-size:.93rem!important;line-height:1.8!important;max-width:100%!important}

  /* The important fix: no two-column cards on smartphone */
  .gallery,
  .mini-gallery,
  .service-photo-grid,
  .service-grid,
  .grid-2,
  .info-columns,
  .split,
  .service-layout,
  .subhero-box,
  .points,
  .service-summary-grid{
    display:grid!important;
    grid-template-columns:1fr!important;
    gap:14px!important;
  }
  .gallery .large,
  .service-photo-grid .tile.wide{
    grid-column:auto!important;
    grid-row:auto!important;
  }

  /* Photos: show the whole image, no crop, captions below */
  .tile,
  .service-photo-grid .tile,
  .mini-gallery .tile,
  .gallery .tile{
    width:100%;min-height:0!important;border-radius:18px!important;overflow:hidden!important;background:linear-gradient(180deg,var(--surface),rgba(25,18,13,.98))!important;
  }
  .tile img,
  .gallery .large img,
  .mini-gallery .tile img,
  .service-photo-grid .tile img,
  .service-photo-grid .tile.wide img,
  .store-card .thumb img,
  .beer-photo img,
  .subhero-image img{
    width:100%!important;
    height:auto!important;
    max-height:none!important;
    aspect-ratio:auto!important;
    object-fit:contain!important;
    object-position:center center!important;
    transform:none!important;
    padding:0!important;
    background:#160f0b!important;
  }
  .store-card .thumb,.beer-photo,.subhero-image{height:auto!important;min-height:0!important;aspect-ratio:auto!important;background:#160f0b!important}
  .tile .cap,
  .service-photo-grid .tile .cap,
  .mini-gallery .tile .cap,
  .gallery .tile .cap{
    position:static!important;left:auto!important;right:auto!important;bottom:auto!important;
    margin:0!important;padding:12px 14px 14px!important;border-radius:0!important;
    background:linear-gradient(180deg,rgba(255,255,255,.045),rgba(255,255,255,.015))!important;
    backdrop-filter:none!important;
  }
  .tile .cap strong{display:block!important;font-size:1rem!important;line-height:1.45!important;margin-bottom:3px!important;word-break:keep-all;overflow-wrap:break-word}
  .tile .cap span{display:block!important;font-size:.88rem!important;line-height:1.65!important;color:#e9dece!important;word-break:normal;overflow-wrap:break-word}

  /* Service page */
  .subhero{padding-top:14px!important}
  .subhero-copy{padding:22px 16px!important;border-radius:22px!important}
  .service-title{font-size:clamp(1.8rem,9vw,2.45rem)!important;line-height:1.25!important;white-space:normal!important;max-width:none!important}
  .service-index{top:60px!important;margin-top:14px!important}
  .service-index .inner{display:flex!important;gap:8px!important;overflow-x:auto!important;scroll-snap-type:x proximity;padding-top:8px!important;padding-bottom:8px!important}
  .service-index a{flex:0 0 auto;scroll-snap-align:start;font-size:.82rem!important;padding:8px 12px!important}
  .service-section{padding:46px 0!important;scroll-margin-top:128px!important}
  .service-copy-box{padding:18px!important;border-radius:20px!important}
  .service-copy-box h2{font-size:1.35rem!important;line-height:1.35!important}
  .points .point{padding:12px 14px!important;border-radius:15px!important}
  .kelly-banner,.mini-kelly-inline,.kelly-feature{display:grid!important;grid-template-columns:62px 1fr!important;gap:12px!important;text-align:left!important;padding:14px!important;border-radius:18px!important}
  .kelly-banner img,.mini-kelly-inline img,.kelly-feature-image img{width:62px!important;height:62px!important;border-radius:15px!important}
  .kelly-banner h2,.kelly-feature-copy h3{font-size:1.05rem!important;line-height:1.35!important;margin:0 0 4px!important}
  .kelly-banner p,.mini-kelly-inline p,.kelly-feature-copy p{font-size:.88rem!important;line-height:1.65!important;margin:0!important}
  .service-card{padding:17px!important;border-radius:18px!important;min-height:0!important}
  .service-card h3{font-size:1.08rem!important;line-height:1.35!important}
  .service-card p{font-size:.9rem!important;line-height:1.7!important}

  /* Beer feature */
  .beer-section{padding-top:20px!important}
  .beer-feature{display:grid!important;grid-template-columns:1fr!important;border-radius:22px!important;gap:0!important}
  .beer-copy{padding:20px 16px!important}
  .beer-copy h3{font-size:1.35rem!important;line-height:1.3!important}
  .beer-points{gap:7px!important}
  .beer-points span{font-size:.78rem!important;padding:6px 9px!important}

  /* CTA / Footer */
  .cta-band{display:grid!important;grid-template-columns:1fr!important;padding:18px!important;border-radius:20px!important;gap:12px!important}
  .footer .inner{display:grid!important;grid-template-columns:1fr!important;gap:12px!important;padding-left:14px!important;padding-right:14px!important}
}

@media (min-width:768px) and (max-width:1023px){
  html,body{overflow-x:hidden}
  .hero-grid,.subhero-box,.service-layout,.grid-2,.info-columns,.split{grid-template-columns:1fr!important}
  .gallery,.mini-gallery,.service-photo-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important}
  .gallery .large,.service-photo-grid .tile.wide{grid-column:1 / -1!important;grid-row:auto!important}
  .tile img,.service-photo-grid .tile img,.store-card .thumb img{object-fit:contain!important;transform:none!important;background:#160f0b!important}
  .hero-actions .btn,.subhero-copy .hero-actions .btn{white-space:normal!important;overflow-wrap:anywhere}
}


/* =========================================================
   v16 smartphone fit patch
   - スマホでは写真カードを必ず1カラム化
   - 料理写真は cover ではなく contain で全体表示
   - 画像は一定の枠内に縮小して、見切れを防ぐ
   - キャプションは必ず画像下へ配置
   ========================================================= */
html,body{max-width:100%;overflow-x:hidden}

@media (max-width: 900px){
  .container,
  .site-header .inner,
  .hero-grid,
  .subhero-wrap,
  .service-index .inner{
    width:100%;
    max-width:100%;
  }

  .gallery,
  .mini-gallery,
  .service-photo-grid,
  .grid-2,
  .service-grid,
  .info-columns,
  .split,
  .service-layout,
  .subhero-box,
  .points,
  .service-summary-grid{
    display:grid!important;
    grid-template-columns:1fr!important;
    gap:16px!important;
  }

  .gallery .large,
  .service-photo-grid .tile.wide{
    grid-column:auto!important;
    grid-row:auto!important;
  }

  .tile,
  .gallery .tile,
  .mini-gallery .tile,
  .service-photo-grid .tile{
    display:flex!important;
    flex-direction:column!important;
    width:100%!important;
    min-height:0!important;
    height:auto!important;
    overflow:hidden!important;
    border-radius:18px!important;
    background:linear-gradient(180deg,#17120e,#120d09)!important;
  }

  .tile img,
  .gallery .large img,
  .mini-gallery .tile img,
  .service-photo-grid .tile img,
  .service-photo-grid .tile.wide img{
    display:block!important;
    width:100%!important;
    height:clamp(220px,68vw,340px)!important;
    max-height:340px!important;
    object-fit:contain!important;
    object-position:center center!important;
    transform:none!important;
    padding:0!important;
    background:#120d09!important;
    border-radius:0!important;
  }

  .store-card .thumb{
    aspect-ratio:auto!important;
    height:auto!important;
    min-height:0!important;
    background:#120d09!important;
  }

  .store-card .thumb img{
    width:100%!important;
    height:clamp(220px,68vw,330px)!important;
    object-fit:contain!important;
    object-position:center center!important;
    transform:none!important;
    background:#120d09!important;
  }

  .beer-photo{
    height:auto!important;
    min-height:0!important;
    background:#120d09!important;
  }

  .beer-photo img{
    width:100%!important;
    height:clamp(220px,68vw,330px)!important;
    object-fit:contain!important;
    object-position:center center!important;
    transform:none!important;
    background:#120d09!important;
  }

  .subhero-image{
    height:auto!important;
    min-height:0!important;
    background:#120d09!important;
  }

  .subhero-image img{
    width:100%!important;
    height:clamp(220px,64vw,330px)!important;
    min-height:0!important;
    object-fit:contain!important;
    object-position:center center!important;
    transform:none!important;
    background:#120d09!important;
  }

  .tile .cap,
  .gallery .tile .cap,
  .mini-gallery .tile .cap,
  .service-photo-grid .tile .cap{
    position:static!important;
    left:auto!important;
    right:auto!important;
    bottom:auto!important;
    margin:0!important;
    width:100%!important;
    padding:13px 15px 15px!important;
    border-radius:0!important;
    background:linear-gradient(180deg,rgba(255,255,255,.055),rgba(255,255,255,.018))!important;
    backdrop-filter:none!important;
  }

  .tile .cap strong,
  .gallery .tile .cap strong,
  .mini-gallery .tile .cap strong,
  .service-photo-grid .tile .cap strong{
    display:block!important;
    font-size:1rem!important;
    line-height:1.45!important;
    margin:0 0 4px!important;
    word-break:keep-all!important;
    overflow-wrap:break-word!important;
  }

  .tile .cap span,
  .gallery .tile .cap span,
  .mini-gallery .tile .cap span,
  .service-photo-grid .tile .cap span{
    display:block!important;
    font-size:.88rem!important;
    line-height:1.65!important;
    color:#eadfce!important;
    word-break:normal!important;
    overflow-wrap:break-word!important;
  }
}

@media (max-width: 560px){
  body{background:#0f0b08!important;}
  .container,
  .site-header .inner,
  .hero-grid,
  .subhero-wrap,
  .service-index .inner{
    padding-left:14px!important;
    padding-right:14px!important;
  }

  .section{padding:42px 0!important;}

  .tile img,
  .gallery .large img,
  .mini-gallery .tile img,
  .service-photo-grid .tile img,
  .service-photo-grid .tile.wide img,
  .store-card .thumb img,
  .beer-photo img,
  .subhero-image img{
    height:clamp(210px,70vw,285px)!important;
    max-height:285px!important;
  }

  .hero-main img.bg{
    object-fit:cover!important;
  }

  .service-index .inner{
    scrollbar-width:thin;
  }
}

/* =========================================================
   v17 image centering patch
   - スマホで画像要素そのものを中央寄せ
   - 右寄りに見える原因になりやすい width:100% 固定を解除
   - 画像は見切らず、最大幅・最大高の中で等比縮小
   ========================================================= */
@media (max-width: 900px){
  .gallery .tile,
  .mini-gallery .tile,
  .service-photo-grid .tile{
    align-items:center!important;
    justify-content:flex-start!important;
    text-align:left!important;
  }

  .tile img,
  .gallery .large img,
  .mini-gallery .tile img,
  .service-photo-grid .tile img,
  .service-photo-grid .tile.wide img,
  .store-card .thumb img,
  .beer-photo img,
  .subhero-image img{
    display:block!important;
    width:auto!important;
    max-width:100%!important;
    height:auto!important;
    max-height:340px!important;
    margin-left:auto!important;
    margin-right:auto!important;
    object-fit:contain!important;
    object-position:center center!important;
    transform:none!important;
    align-self:center!important;
  }

  .store-card .thumb,
  .beer-photo,
  .subhero-image{
    display:flex!important;
    align-items:center!important;
    justify-content:center!important;
    overflow:hidden!important;
  }

  .tile .cap,
  .gallery .tile .cap,
  .mini-gallery .tile .cap,
  .service-photo-grid .tile .cap{
    align-self:stretch!important;
    width:100%!important;
    box-sizing:border-box!important;
    text-align:left!important;
  }
}

@media (max-width: 560px){
  .tile img,
  .gallery .large img,
  .mini-gallery .tile img,
  .service-photo-grid .tile img,
  .service-photo-grid .tile.wide img,
  .store-card .thumb img,
  .beer-photo img,
  .subhero-image img{
    max-height:285px!important;
  }

  .subhero-image img{
    max-height:300px!important;
  }
}

/* =========================================================
   v18 index/service final mobile media centering patch
   - TOPページもサービスページと同じ中央寄せルールに統一
   - スマホではカード画像を見切らず、中央で等比縮小
   - 横スクロール・右寄りの原因になりやすい幅指定を抑制
   ========================================================= */
html, body{
  width:100%;
  max-width:100%;
  overflow-x:hidden;
}

figure{
  margin:0;
}

@media (max-width: 900px){
  .container,
  .site-header .inner,
  .hero-grid,
  .subhero-wrap,
  .service-index .inner,
  .footer .inner{
    max-width:100%;
    margin-left:auto!important;
    margin-right:auto!important;
  }

  .gallery,
  .mini-gallery,
  .service-photo-grid,
  .grid-2,
  .split,
  .service-layout,
  .info-columns,
  .service-grid{
    width:100%!important;
    max-width:100%!important;
    margin-left:auto!important;
    margin-right:auto!important;
  }

  .tile,
  .gallery .tile,
  .mini-gallery .tile,
  .service-photo-grid .tile,
  .store-card,
  .beer-feature,
  .subhero-image{
    width:100%!important;
    max-width:100%!important;
    margin-left:auto!important;
    margin-right:auto!important;
    overflow:hidden!important;
  }

  .tile,
  .gallery .tile,
  .mini-gallery .tile,
  .service-photo-grid .tile{
    display:flex!important;
    flex-direction:column!important;
    align-items:stretch!important;
    justify-content:flex-start!important;
    background:#120d09!important;
  }

  .tile > img,
  .gallery .tile > img,
  .gallery .large > img,
  .mini-gallery .tile > img,
  .service-photo-grid .tile > img,
  .service-photo-grid .tile.wide > img{
    display:block!important;
    width:100%!important;
    max-width:100%!important;
    height:auto!important;
    max-height:none!important;
    aspect-ratio:auto!important;
    object-fit:contain!important;
    object-position:center center!important;
    margin:0 auto!important;
    padding:0!important;
    transform:none!important;
    transform-origin:center center!important;
    align-self:center!important;
    background:#120d09!important;
    border-radius:0!important;
  }

  .store-card .thumb,
  .beer-photo,
  .subhero-image,
  .logo-stack .mark,
  .kelly-feature-image,
  .kelly-head,
  .mini-kelly-inline,
  .kelly-banner{
    display:grid!important;
    place-items:center!important;
  }

  .store-card .thumb img,
  .beer-photo img,
  .subhero-image img,
  .kelly-feature-image img,
  .kelly-head img,
  .mini-kelly-inline img,
  .kelly-banner img,
  .logo-stack .mark img,
  .brand-mark img{
    display:block!important;
    margin-left:auto!important;
    margin-right:auto!important;
    object-position:center center!important;
    transform:none!important;
  }

  .store-card .thumb img,
  .beer-photo img,
  .subhero-image img{
    width:100%!important;
    max-width:100%!important;
    height:auto!important;
    max-height:none!important;
    object-fit:contain!important;
    background:#120d09!important;
  }

  .hero-main img.bg{
    width:100%!important;
    height:100%!important;
    object-fit:cover!important;
    object-position:center center!important;
    margin:0!important;
  }

  .tile .cap,
  .gallery .tile .cap,
  .mini-gallery .tile .cap,
  .service-photo-grid .tile .cap{
    width:100%!important;
    max-width:100%!important;
    align-self:stretch!important;
    margin:0!important;
    box-sizing:border-box!important;
  }
}

@media (max-width: 560px){
  .container,
  .site-header .inner,
  .hero-grid,
  .subhero-wrap,
  .service-index .inner,
  .footer .inner{
    padding-left:14px!important;
    padding-right:14px!important;
  }

  .section-head,
  .cta-band{
    gap:16px!important;
  }

  .hero-actions{
    grid-template-columns:1fr!important;
  }

  .hero-quick-grid{
    grid-template-columns:1fr!important;
  }

  .service-index .inner{
    justify-content:flex-start!important;
  }
}

/* v20: top page YouTube official song + Yokoyama community support */
.media-section,
.community-section{
  padding-top:20px;
}
.youtube-card,
.community-card{
  display:grid;
  grid-template-columns:1.25fr .75fr;
  gap:24px;
  align-items:stretch;
  padding:24px;
  border-radius:28px;
  border:1px solid var(--line);
  background:linear-gradient(180deg,var(--surface),rgba(33,24,18,.92));
  box-shadow:var(--shadow);
  overflow:hidden;
}
.youtube-embed{
  position:relative;
  width:100%;
  aspect-ratio:16/9;
  border-radius:22px;
  overflow:hidden;
  background:#000;
  border:1px solid rgba(255,255,255,.08);
}
.youtube-embed iframe{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  border:0;
}
.youtube-copy,
.community-copy{
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap:14px;
  min-width:0;
}
.youtube-copy h3,
.community-copy h2{
  margin:0;
  line-height:1.18;
}
.youtube-copy h3{font-size:clamp(1.6rem,3vw,2.25rem)}
.community-copy h2{font-size:clamp(1.8rem,3.2vw,2.65rem)}
.youtube-copy p,
.community-copy p{
  margin:0;
  color:var(--muted);
}
.youtube-copy .btn,
.community-copy .btn{
  align-self:flex-start;
}
.community-card{
  grid-template-columns:.42fr 1fr;
  background:
    radial-gradient(circle at 14% 18%,rgba(241,195,108,.18),transparent 34%),
    linear-gradient(180deg,var(--surface),rgba(27,21,15,.96));
}
.community-logo{
  display:grid;
  place-items:center;
  min-height:240px;
  border-radius:24px;
  background:rgba(255,255,255,.95);
  border:1px solid rgba(255,255,255,.14);
  padding:22px;
}
.community-logo img{
  display:block;
  width:min(100%,260px);
  max-height:190px;
  object-fit:contain;
  margin:auto;
}
.community-tags{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin:4px 0 2px;
}
.community-tags span{
  padding:8px 12px;
  border-radius:999px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.04);
  color:var(--gold-soft);
  font-size:.9rem;
  font-weight:800;
}
@media (max-width:900px){
  .youtube-card,
  .community-card{
    grid-template-columns:1fr!important;
    padding:18px!important;
    gap:18px!important;
  }
  .community-logo{
    min-height:170px!important;
  }
  .community-logo img{
    width:min(100%,220px)!important;
    max-height:140px!important;
  }
}
@media (max-width:560px){
  .media-section,
  .community-section{
    padding-top:6px!important;
  }
  .youtube-card,
  .community-card{
    border-radius:22px!important;
    padding:14px!important;
  }
  .youtube-embed{
    border-radius:16px!important;
  }
  .youtube-copy .btn,
  .community-copy .btn{
    width:100%!important;
  }
  .community-tags span{
    font-size:.82rem!important;
  }
}

.tile-link{display:block;color:inherit;text-decoration:none}
.tile-link .tile{height:100%}
.tile-link:hover .tile{transform:translateY(-3px)}
