/* ============================================================
   10 Fields Brewing — Global Stylesheet
   ============================================================ */

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

/* ── Design Tokens ──────────────────────────────────────────── */
:root {
  --bg:          #faf8f4;
  --bg-1:        #f2ebe0;
  --bg-2:        #e8ddd0;
  --card:        #ffffff;
  --card-h:      #fdf9f5;
  --accent:      #c8843a;
  --accent-2:    #a86820;
  --glow:        rgba(200,132,58,.10);
  --text:        #1c1410;
  --text-2:      #5c4838;
  --text-3:      #9c8c7c;
  --border:      #e0d5c4;
  --border-h:    rgba(200,132,58,.6);
  --r:           6px;
  --r-lg:        12px;
  --max-w:       1100px;
  --nav-h:       68px;
}

/* ── Reset ──────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);font-family:'Inter','Noto Sans JP',system-ui,sans-serif;line-height:1.7;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
button{cursor:pointer}
[id]{scroll-margin-top:calc(var(--nav-h) + 1rem)}

/* ── Typography ─────────────────────────────────────────────── */
h1,h2,h3,h4,h5{font-family:'Cormorant Garamond','Noto Serif JP',Georgia,serif;font-weight:400;line-height:1.15}

/* ── Layout ─────────────────────────────────────────────────── */
.container{max-width:var(--max-w);margin:0 auto;padding:0 clamp(1rem,4vw,2.5rem)}
.section{padding:clamp(4rem,10vw,8rem) 0}
.section--alt{background:var(--bg-1)}
.section--dark{background:#1c1410}
.text-center{text-align:center}

/* Grid */
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
@media(max-width:900px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:580px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}

/* Two-col */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,6vw,5rem);align-items:center}
.two-col--rev{direction:rtl}.two-col--rev>*{direction:ltr}
.two-col__img{border-radius:var(--r-lg);overflow:hidden;aspect-ratio:4/3;background:var(--bg-2)}
.two-col__img img{width:100%;height:100%;object-fit:cover}
@media(max-width:768px){.two-col{grid-template-columns:1fr}.two-col--rev{direction:ltr}}

/* ── Section header ─────────────────────────────────────────── */
.sh{margin-bottom:clamp(2rem,5vw,4rem)}
.sh--c{text-align:center}.sh--c .sh__lead{margin:0 auto}
.sh__eyebrow{font-size:.75rem;letter-spacing:.3em;text-transform:uppercase;color:var(--accent);font-weight:500;margin-bottom:.75rem;font-family:'Inter',sans-serif}
.sh__title{font-size:clamp(2rem,5vw,3.25rem);color:var(--text);margin-bottom:1rem}
.sh__lead{font-size:1rem;color:var(--text-2);max-width:560px;line-height:1.85;font-family:'Noto Sans JP',sans-serif}
.divider{width:40px;height:2px;background:var(--accent);margin:1.25rem 0}
.divider--c{margin:1.25rem auto}

/* ── Navigation ─────────────────────────────────────────────── */
.nav{position:fixed;top:0;left:0;right:0;z-index:200;height:var(--nav-h);background:rgba(250,248,244,.95);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--border)}
.nav__inner{max-width:var(--max-w);margin:0 auto;padding:0 clamp(1rem,4vw,2.5rem);height:100%;display:flex;align-items:center;justify-content:space-between}
.nav__logo{display:flex;align-items:center;gap:.625rem;transition:opacity .2s}
.nav__logo:hover{opacity:.7}
.nav__logo img{height:34px;width:auto;filter:brightness(0)}
.nav__menu{display:flex;align-items:center;gap:.125rem}
.nav__item{position:relative}
.nav__link{display:flex;align-items:center;gap:3px;padding:.5rem .75rem;font-size:.8125rem;letter-spacing:.04em;color:var(--text-2);transition:color .2s;white-space:nowrap;font-family:'Noto Sans JP',sans-serif}
.nav__link:hover,.nav__link.active{color:var(--accent)}
.nav__link svg{width:9px;height:9px;opacity:.4;transition:transform .2s}
.nav__item:hover .nav__link svg{transform:rotate(180deg)}
.nav__drop{position:absolute;top:calc(100% + 6px);left:0;min-width:190px;background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:.375rem 0;opacity:0;visibility:hidden;transform:translateY(-6px);transition:all .2s;z-index:300;box-shadow:0 8px 32px rgba(28,20,16,.08)}
.nav__item:hover .nav__drop{opacity:1;visibility:visible;transform:translateY(0)}
.nav__drop a{display:block;padding:.5rem 1rem;font-size:.8125rem;color:var(--text-2);font-family:'Noto Sans JP',sans-serif;transition:all .15s}
.nav__drop a:hover{color:var(--accent);background:var(--glow);padding-left:1.25rem}
.nav__toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;padding:4px}
.nav__toggle span{display:block;width:22px;height:1.5px;background:var(--text);transition:all .3s}
.nav__toggle.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.nav__toggle.open span:nth-child(2){opacity:0}
.nav__toggle.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
.nav__mobile{display:none;flex-direction:column;position:fixed;top:var(--nav-h);left:0;right:0;bottom:0;background:var(--card);padding:1.5rem 1.5rem 3rem;overflow-y:auto;z-index:199}
.nav__mobile.open{display:flex}
.nav__mobile a{padding:.875rem 0;border-bottom:1px solid var(--border);color:var(--text-2);font-family:'Noto Sans JP',sans-serif;font-size:.9375rem;transition:color .2s}
.nav__mobile a:hover{color:var(--accent)}
.nav__mobile a.sub{padding-left:1.25rem;font-size:.875rem;color:var(--text-3)}
.nav__mobile-label{font-size:.6875rem;letter-spacing:.2em;color:var(--text-3);padding:.75rem 0 .25rem;font-family:'Inter',sans-serif}
@media(max-width:900px){.nav__menu{display:none}.nav__toggle{display:flex}}

/* ── Hero (full screen) ─────────────────────────────────────── */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;overflow:hidden;padding-top:var(--nav-h)}
.hero__bg{position:absolute;inset:0;background:var(--bg);z-index:0}
.hero__bg img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;opacity:.75}
.hero__bg::after{content:'';position:absolute;inset:0;z-index:1;background:linear-gradient(105deg,var(--bg) 38%,rgba(250,248,244,.82) 56%,rgba(250,248,244,.08) 82%)}
.hero__content{position:relative;z-index:2;padding:5rem 0 4rem}
.hero__eyebrow{font-size:.75rem;letter-spacing:.35em;text-transform:uppercase;color:var(--accent);margin-bottom:1.25rem;font-weight:500;font-family:'Inter',sans-serif}
.hero__line{width:50px;height:1.5px;background:var(--accent);margin-bottom:1.75rem}
.hero__title{font-size:clamp(2.75rem,8vw,5.5rem);font-weight:300;line-height:1.08;margin-bottom:1.5rem;color:var(--text)}
.hero__title em{font-style:italic;color:var(--accent)}
.hero__lead{font-size:clamp(.9375rem,2vw,1.125rem);color:var(--text-2);max-width:520px;line-height:1.85;margin-bottom:2.5rem;font-family:'Noto Sans JP',sans-serif}
.hero__actions{display:flex;gap:1rem;flex-wrap:wrap}
.hero__scroll{position:absolute;bottom:2.5rem;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:.5rem;font-size:.6875rem;letter-spacing:.25em;text-transform:uppercase;color:var(--text-3);z-index:1}
.hero__scroll::after{content:'';display:block;width:1px;height:40px;background:linear-gradient(to bottom,var(--text-3),transparent);animation:scrollLine 1.8s ease-in-out infinite}
@keyframes scrollLine{0%,100%{opacity:.5}50%{opacity:1}}

/* Page hero (smaller) */
.page-hero{padding:calc(var(--nav-h) + 5rem) 0 4rem;text-align:center;background:linear-gradient(180deg,var(--bg-1) 0%,var(--bg) 100%);position:relative;overflow:hidden}
.page-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 60% 100% at 50% 0%,var(--glow),transparent)}
.page-hero .container{position:relative;z-index:1}
.page-hero__eyebrow{font-size:.75rem;letter-spacing:.3em;text-transform:uppercase;color:var(--accent);font-weight:500;margin-bottom:1rem;font-family:'Inter',sans-serif}
.page-hero__title{font-size:clamp(2rem,6vw,3.5rem);margin-bottom:1rem;color:var(--text)}
.page-hero__lead{font-size:1rem;color:var(--text-2);max-width:560px;margin:0 auto;line-height:1.85;font-family:'Noto Sans JP',sans-serif}
.page-hero__line{width:50px;height:1.5px;background:var(--accent);margin:1.5rem auto 0}

/* ── Buttons ─────────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.875rem 2rem;font-size:.875rem;letter-spacing:.06em;font-weight:500;border-radius:var(--r);transition:all .25s;border:none;font-family:'Noto Sans JP',sans-serif}
.btn--primary{background:var(--accent);color:#fff}
.btn--primary:hover{background:var(--accent-2);transform:translateY(-2px);box-shadow:0 8px 28px rgba(200,132,58,.28)}
.btn--outline{background:transparent;color:var(--accent);border:1.5px solid var(--accent)}
.btn--outline:hover{background:var(--glow);transform:translateY(-2px)}
.btn--ghost{background:transparent;color:var(--text-2);border:1px solid var(--border)}
.btn--ghost:hover{color:var(--text);border-color:var(--text-3)}

/* ── Cards ───────────────────────────────────────────────────── */
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;transition:all .3s;display:flex;flex-direction:column;box-shadow:0 2px 12px rgba(28,20,16,.05)}
.card:hover{border-color:var(--border-h);transform:translateY(-4px);box-shadow:0 16px 48px rgba(28,20,16,.12)}
.card__img{aspect-ratio:16/9;overflow:hidden;background:var(--bg-2)}
.card__img img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.card:hover .card__img img{transform:scale(1.04)}
.card__body{padding:1.5rem;flex:1;display:flex;flex-direction:column}
.card__label{font-size:.6875rem;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);margin-bottom:.625rem;font-weight:500}
.card__title{font-family:'Noto Sans JP',sans-serif;font-size:.9375rem;font-weight:500;color:var(--text);margin-bottom:.625rem;line-height:1.55}
.card__excerpt{font-size:.875rem;color:var(--text-2);line-height:1.75;flex:1;font-family:'Noto Sans JP',sans-serif}
.card__date{font-size:.8125rem;color:var(--text-3);margin-top:1rem}
.card__arrow{margin-top:1.25rem;font-size:.8125rem;color:var(--accent);display:flex;align-items:center;gap:.375rem;transition:gap .2s}
.card:hover .card__arrow{gap:.625rem}

/* Beer card */
.beer-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;transition:all .3s;text-align:center;box-shadow:0 2px 12px rgba(28,20,16,.05)}
.beer-card:hover{border-color:var(--border-h);transform:translateY(-4px);box-shadow:0 16px 40px rgba(28,20,16,.12)}
.beer-card__img{aspect-ratio:1;overflow:hidden;background:var(--bg-2)}
.beer-card__img img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.beer-card:hover .beer-card__img img{transform:scale(1.06)}
.beer-card__body{padding:1rem 1.25rem 1.25rem;display:flex;flex-direction:column;align-items:center}
.beer-card__name{font-family:'Noto Sans JP',sans-serif;font-size:.9375rem;font-weight:500;color:var(--text)}
.beer-card__style{font-size:.8125rem;color:var(--text-2);margin-top:.25rem}
.beer-card__abv{font-size:.75rem;color:var(--text-3);margin-top:.2rem;letter-spacing:.04em;flex:1}
.beer-card__more{display:inline-block;margin-top:.875rem;padding:.375rem 1rem;font-size:.75rem;letter-spacing:.08em;border:1.5px solid var(--accent);border-radius:100px;color:var(--accent);font-family:'Inter',sans-serif;transition:all .25s}
.beer-card:hover .beer-card__more{background:var(--accent);color:#fff}

/* ── Brand split ─────────────────────────────────────────────── */
.brand-split{display:grid;grid-template-columns:1fr 1fr}
.brand-panel{position:relative;overflow:hidden;min-height:55vh;display:flex;align-items:flex-end;padding:clamp(1.5rem,4vw,3rem)}
.brand-panel__bg{position:absolute;inset:0;z-index:0}
.brand-panel__bg img{width:100%;height:100%;object-fit:cover;opacity:.28;transition:opacity .4s}
.brand-panel:hover .brand-panel__bg img{opacity:.42}
.brand-panel__overlay{position:absolute;inset:0;z-index:1}
.brand-panel--osa .brand-panel__overlay{background:linear-gradient(to top,rgba(150,30,10,.82) 0%,rgba(0,0,0,.15) 60%)}
.brand-panel--kyo .brand-panel__overlay{background:linear-gradient(to top,rgba(10,30,110,.82) 0%,rgba(0,0,0,.15) 60%)}
.brand-panel__content{position:relative;z-index:2}
.brand-panel__eyebrow{font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;color:rgba(255,255,255,.65);margin-bottom:.625rem}
.brand-panel__title{font-size:clamp(1.75rem,4vw,2.75rem);color:#fff;margin-bottom:.875rem}
.brand-panel__lead{font-size:.875rem;color:rgba(255,255,255,.75);line-height:1.75;margin-bottom:1.5rem;font-family:'Noto Sans JP',sans-serif}
@media(max-width:680px){.brand-split{grid-template-columns:1fr}.brand-panel{min-height:50vw}}

/* ── Stats ───────────────────────────────────────────────────── */
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--border)}
.stat{padding:2.5rem 1.5rem;text-align:center;background:var(--card)}
.stat__num{font-size:clamp(2.5rem,6vw,4rem);font-family:'Cormorant Garamond',serif;color:var(--accent);line-height:1;margin-bottom:.5rem}
.stat__label{font-size:.875rem;color:var(--text-2);font-family:'Noto Sans JP',sans-serif}
@media(max-width:580px){.stats{grid-template-columns:repeat(2,1fr)}}

/* ── Feature list ────────────────────────────────────────────── */
.feat-list{display:flex;flex-direction:column;gap:1.75rem}
.feat-item{display:flex;gap:1.25rem;align-items:flex-start}
.feat-icon{width:48px;height:48px;flex-shrink:0;border-radius:50%;border:1.5px solid rgba(200,132,58,.35);background:var(--glow);display:flex;align-items:center;justify-content:center;font-size:1.25rem}
.feat-text h4{font-family:'Noto Sans JP',sans-serif;font-size:1rem;font-weight:500;margin-bottom:.25rem;color:var(--text)}
.feat-text p{font-size:.875rem;color:var(--text-2);line-height:1.75;font-family:'Noto Sans JP',sans-serif}

/* ── Post list ───────────────────────────────────────────────── */
.posts-list{border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;box-shadow:0 2px 12px rgba(28,20,16,.05)}
.post-row{display:flex;gap:1.5rem;align-items:center;padding:1.125rem 1.5rem;background:var(--card);border-bottom:1px solid var(--border);transition:background .2s}
.post-row:last-child{border-bottom:none}
.post-row:hover{background:var(--card-h)}
.post-row__date{font-size:.8125rem;color:var(--text-3);width:96px;flex-shrink:0}
.post-row__cat{font-size:.6875rem;color:var(--accent);letter-spacing:.15em;width:64px;flex-shrink:0}
.post-row__title{font-size:.9375rem;color:var(--text);font-family:'Noto Sans JP',sans-serif;flex:1;transition:color .2s}
.post-row:hover .post-row__title{color:var(--accent)}
@media(max-width:580px){.post-row{flex-direction:column;gap:.25rem;align-items:flex-start}.post-row__date,.post-row__cat{width:auto}}

/* ── CTA banner ──────────────────────────────────────────────── */
.cta-wrap{background:linear-gradient(135deg,var(--bg-1) 0%,var(--bg-2) 100%);border:1px solid var(--border);border-radius:var(--r-lg);padding:clamp(2rem,5vw,3.5rem);text-align:center}
.cta-wrap__title{font-family:'Noto Sans JP',sans-serif;font-size:clamp(1.25rem,3vw,1.75rem);font-weight:500;margin-bottom:.75rem;color:var(--text)}
.cta-wrap__lead{font-size:.9375rem;color:var(--text-2);margin-bottom:2rem;font-family:'Noto Sans JP',sans-serif}
.cta-wrap__btns{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* ── Forms ───────────────────────────────────────────────────── */
.form-wrap{background:var(--card);border:1px solid var(--border);border-radius:var(--r-lg);padding:clamp(1.5rem,4vw,2.5rem);box-shadow:0 2px 16px rgba(28,20,16,.06)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-group{margin-bottom:1.25rem}
.form-label{display:block;font-size:.875rem;color:var(--text-2);margin-bottom:.5rem;font-family:'Noto Sans JP',sans-serif}
.form-label .req{color:var(--accent);margin-left:.25rem;font-size:.75rem}
.form-input,.form-textarea,.form-select{width:100%;background:var(--bg);border:1px solid var(--border);border-radius:var(--r);color:var(--text);padding:.875rem 1rem;font-size:.9375rem;font-family:'Noto Sans JP',sans-serif;transition:border-color .2s;-webkit-appearance:none}
.form-input::placeholder,.form-textarea::placeholder{color:var(--text-3)}
.form-input:focus,.form-textarea:focus,.form-select:focus{outline:none;border-color:var(--accent);background:var(--card)}
.form-textarea{min-height:160px;resize:vertical}
.form-select{background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L5 5L9 1' stroke='%239c8c7c' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.5rem}
.form-note{font-size:.8125rem;color:var(--text-3);margin-top:.375rem;font-family:'Noto Sans JP',sans-serif}
@media(max-width:600px){.form-row{grid-template-columns:1fr}}

/* ── Article ─────────────────────────────────────────────────── */
.article{max-width:760px;margin:0 auto}
.article__meta{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}
.article__cat{font-size:.75rem;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);border:1.5px solid rgba(200,132,58,.45);padding:.2rem .75rem;border-radius:100px}
.article__date{font-size:.8125rem;color:var(--text-3)}
.article__title{font-family:'Noto Sans JP',sans-serif;font-size:clamp(1.5rem,4vw,2.25rem);font-weight:500;line-height:1.35;margin-bottom:2rem;color:var(--text)}
.article__hero{border-radius:var(--r-lg);overflow:hidden;margin-bottom:2.5rem}
.article__hero img{width:100%}
.article__body{font-family:'Noto Sans JP',sans-serif}
.article__body h2{font-size:1.375rem;font-weight:500;color:var(--text);margin:2.5rem 0 1rem;padding-bottom:.75rem;border-bottom:1.5px solid var(--border);font-family:'Noto Sans JP',sans-serif}
.article__body h3{font-size:1.0625rem;font-weight:500;color:var(--text);margin:2rem 0 .75rem;padding-left:.875rem;border-left:3px solid var(--accent);font-family:'Noto Sans JP',sans-serif}
.article__body p{margin-bottom:1.25rem;color:var(--text-2);line-height:1.9;font-size:.9375rem}
.article__body ul{list-style:none;padding:0;margin-bottom:1.25rem}
.article__body ul li{display:flex;gap:.625rem;color:var(--text-2);font-size:.9375rem;line-height:1.8;margin-bottom:.375rem}
.article__body ul li::before{content:'—';color:var(--accent);flex-shrink:0}
.article__body table{width:100%;border-collapse:collapse;margin:1.5rem 0;font-size:.875rem}
.article__body th{background:var(--bg-1);color:var(--text);font-weight:500;padding:.75rem 1rem;border:1px solid var(--border);text-align:left}
.article__body td{color:var(--text-2);padding:.75rem 1rem;border:1px solid var(--border)}
.article__body tr:nth-child(even) td{background:var(--bg)}
.note-box{background:var(--glow);border-left:3px solid var(--accent);border-radius:0 var(--r) var(--r) 0;padding:1.25rem 1.5rem;margin:1.75rem 0}
.note-box p{color:var(--text)!important;margin-bottom:0!important}

/* ── Shop card ───────────────────────────────────────────────── */
.shop-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;transition:all .3s;box-shadow:0 2px 12px rgba(28,20,16,.05)}
.shop-card:hover{border-color:var(--border-h);transform:translateY(-3px);box-shadow:0 12px 32px rgba(28,20,16,.10)}
.shop-card__img{aspect-ratio:3/2;overflow:hidden;background:var(--bg-2)}
.shop-card__img img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.shop-card:hover .shop-card__img img{transform:scale(1.04)}
.shop-card__body{padding:1.125rem 1.25rem}
.shop-card__cuisine{font-size:.75rem;color:var(--accent);letter-spacing:.15em;margin-bottom:.375rem}
.shop-card__name{font-family:'Noto Sans JP',sans-serif;font-weight:500;font-size:.9375rem;color:var(--text)}
.shop-card__area{font-size:.8125rem;color:var(--text-3);margin-top:.25rem}

/* Filters */
.filters{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:2rem}
.filter-btn{padding:.375rem .875rem;font-size:.8125rem;border:1px solid var(--border);border-radius:100px;background:var(--card);color:var(--text-2);font-family:'Noto Sans JP',sans-serif;transition:all .2s}
.filter-btn:hover,.filter-btn.on{border-color:var(--accent);color:var(--accent);background:var(--glow)}

/* ── Footer ──────────────────────────────────────────────────── */
.footer{background:#1c1410;border-top:1px solid rgba(255,255,255,.06);padding:4rem 0 2rem}
.footer__grid{display:grid;grid-template-columns:220px 1fr;gap:4rem;margin-bottom:3rem}
.footer__grid>div>img{filter:brightness(0) invert(1);opacity:.55}
.footer__tagline{font-size:.875rem;color:rgba(255,255,255,.4);line-height:1.8;margin-top:1rem;font-family:'Noto Sans JP',sans-serif}
.footer__nav{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
.footer__nav-col h4{font-family:'Noto Sans JP',sans-serif;font-size:.8125rem;font-weight:500;color:rgba(255,255,255,.5);letter-spacing:.08em;margin-bottom:.875rem}
.footer__nav-col ul{display:flex;flex-direction:column;gap:.5rem}
.footer__nav-col a{font-size:.8125rem;color:rgba(255,255,255,.35);font-family:'Noto Sans JP',sans-serif;transition:color .2s}
.footer__nav-col a:hover{color:var(--accent)}
.footer__bottom{border-top:1px solid rgba(255,255,255,.08);padding-top:1.5rem;display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:1rem}
.footer__address{font-size:.8125rem;color:rgba(255,255,255,.3);font-family:'Noto Sans JP',sans-serif;line-height:1.8}
.footer__copy{font-size:.75rem;color:rgba(255,255,255,.25);letter-spacing:.04em}
@media(max-width:768px){.footer__grid{grid-template-columns:1fr;gap:2.5rem}.footer__nav{grid-template-columns:repeat(2,1fr)}.footer__bottom{flex-direction:column}}

/* ── Brand overrides ─────────────────────────────────────────── */
body.osa{--accent:#c03028;--accent-2:#9c2018;--glow:rgba(192,48,40,.09);--border-h:rgba(192,48,40,.55)}
body.kyo{--accent:#3460b8;--accent-2:#244898;--glow:rgba(52,96,184,.09);--border-h:rgba(52,96,184,.55)}

/* Osaka: gothic (sans-serif) typography */
body.osa h1,body.osa h2,body.osa h3,body.osa h4,body.osa h5{font-family:'Noto Sans JP','Inter',sans-serif;font-weight:500;line-height:1.25}
body.osa .hero__title{font-weight:400;line-height:1.4;font-size:clamp(1.625rem,3.5vw,2.5rem)}
body.osa .stat__num{font-family:'Inter','Noto Sans JP',sans-serif}

/* ── Osaka dark header ──────────────────────────────────────── */
body.osa .nav{background:rgba(28,20,16,.97);border-bottom-color:rgba(255,255,255,.08)}
body.osa .nav__logo img{filter:none}
body.osa .nav__link{color:rgba(255,255,255,.65)}
body.osa .nav__link:hover,body.osa .nav__link.active{color:var(--accent)}
body.osa .nav__drop{background:#2a1e18;border-color:rgba(255,255,255,.1)}
body.osa .nav__drop a{color:rgba(255,255,255,.55)}
body.osa .nav__toggle span{background:rgba(255,255,255,.8)}
body.osa .nav__mobile{background:#1c1410}
body.osa .nav__mobile a{color:rgba(255,255,255,.65);border-bottom-color:rgba(255,255,255,.08)}
body.osa .nav__mobile-label{color:rgba(255,255,255,.35)}
body.kyo .nav{background:rgba(10,18,40,.97);border-bottom-color:rgba(255,255,255,.08)}
body.kyo .nav__logo img{filter:brightness(0) invert(1)}
body.kyo .nav__link{color:rgba(255,255,255,.65)}
body.kyo .nav__link:hover,body.kyo .nav__link.active{color:var(--accent)}
body.kyo .nav__drop{background:#0f2040;border-color:rgba(255,255,255,.1)}
body.kyo .nav__drop a{color:rgba(255,255,255,.55)}
body.kyo .nav__toggle span{background:rgba(255,255,255,.8)}
body.kyo .nav__mobile{background:#0a1220}
body.kyo .nav__mobile a{color:rgba(255,255,255,.65);border-bottom-color:rgba(255,255,255,.08)}
body.kyo .nav__mobile-label{color:rgba(255,255,255,.35)}

/* ── Dark section text overrides ────────────────────────────── */
.section--dark .sh__title,
.section--dark .sh__eyebrow,
.section--dark .sh__lead,
.section--dark .feat-text h4,
.section--dark .feat-text p,
.section--dark p,
.section--dark h2,
.section--dark h3{color:inherit}
.section--dark{color:rgba(255,255,255,.85)}
.section--dark .sh__eyebrow{color:var(--accent)}
.section--dark .sh__title{color:#fff}
.section--dark .sh__lead{color:rgba(255,255,255,.6)}
.section--dark .feat-text h4{color:#fff}
.section--dark .feat-text p{color:rgba(255,255,255,.6)}
.section--dark .feat-icon{border-color:rgba(200,132,58,.4);background:rgba(200,132,58,.1)}
.section--dark .stats{background:rgba(255,255,255,.06)}
.section--dark .stat{background:rgba(255,255,255,.04)}
.section--dark .stat__label{color:rgba(255,255,255,.55)}
.section--dark .divider{background:var(--accent)}

/* ── Lineup marquee ──────────────────────────────────────────── */
.lineup-marquee{overflow:hidden;padding:0 0 .5rem;-webkit-mask:linear-gradient(90deg,transparent,#000 100px,#000 calc(100% - 100px),transparent);mask:linear-gradient(90deg,transparent,#000 100px,#000 calc(100% - 100px),transparent)}
.lineup-track{display:flex;gap:1.5rem;width:max-content;animation:lineup-scroll 60s linear infinite}
.lineup-track .beer-card{width:240px;flex-shrink:0}
.lineup-track:hover{animation-play-state:paused}
@keyframes lineup-scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){.lineup-track{animation:none}}

/* ── Scroll reveal ───────────────────────────────────────────── */
.fade-up{opacity:0;transform:translateY(32px);transition:opacity .65s ease,transform .65s ease}
.fade-up.is-visible{opacity:1;transform:translateY(0)}

/* ── Utility ─────────────────────────────────────────────────── */
.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2rem}.mt-6{margin-top:3rem}.mt-8{margin-top:4rem}
.mb-2{margin-bottom:1rem}.mb-4{margin-bottom:2rem}.mb-6{margin-bottom:3rem}
.sep{width:100%;height:1px;background:var(--border)}
.tag{display:inline-block;padding:.2rem .75rem;font-size:.6875rem;letter-spacing:.15em;border:1.5px solid rgba(200,132,58,.45);border-radius:100px;color:var(--accent)}
.breadcrumb{display:flex;gap:.5rem;font-size:.8125rem;color:var(--text-3);margin-bottom:2.5rem;font-family:'Noto Sans JP',sans-serif;flex-wrap:wrap}
.breadcrumb a{color:var(--text-3);transition:color .2s}
.breadcrumb a:hover{color:var(--accent)}
