/* =========================================================
   HOPYARD — Yamanashi Craft Brewery
   eathungrytiger UI を踏襲 / 配色はビールのアイデンティティへ
   ========================================================= */

/* ---------- TOKENS ---------- */
:root{
  --cream:      #f5efe2;
  --cream-deep: #ece1cd;
  --paper:      #faf6ec;
  --ink:        #241a12;
  --ink-soft:   #5c4a38;
  --ink-mute:   #8a755e;
  --amber:      #bf7d2c;
  --amber-deep: #a5641a;
  --amber-soft: #e8c98f;
  --bottle:     #34503a;
  --bottle-deep:#263c2b;
  --line:       rgba(36,26,18,.14);
  --line-soft:  rgba(36,26,18,.08);

  --f-display: "Fraunces", "Noto Serif JP", Georgia, serif;
  --f-sans:    "Noto Sans JP", system-ui, sans-serif;
  --f-mono:    "JetBrains Mono", ui-monospace, monospace;

  --ease-spring: cubic-bezier(.34,1.56,.64,1);
  --ease-smooth: cubic-bezier(.16,1,.3,1);

  --maxw: 1240px;
  --pad: clamp(20px, 5vw, 64px);
  --sec-y: clamp(84px, 13vh, 168px);
}

/* ---------- RESET ---------- */
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ -webkit-text-size-adjust:100%; }
body{
  font-family:var(--f-sans);
  font-weight:400;
  color:var(--ink);
  background:var(--cream);
  line-height:1.75;
  letter-spacing:.01em;
  overflow-x:hidden;
  text-rendering:optimizeLegibility;
  -webkit-font-smoothing:antialiased;
  font-feature-settings:"palt" 1;
}
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; border:none; background:none; color:inherit; }
ul{ list-style:none; }
::selection{ background:var(--amber); color:var(--paper); }

body::before{
  content:""; position:fixed; inset:0; z-index:9998; pointer-events:none;
  opacity:.035; mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ---------- UTILITIES ---------- */
.container{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--pad); }

.eyebrow{
  font-family:var(--f-mono);
  font-size:12px; font-weight:500;
  letter-spacing:.28em; text-transform:uppercase;
  color:var(--amber-deep);
}

.section-title{
  font-family:var(--f-sans); font-weight:900;
  font-size:clamp(30px, 5.4vw, 68px);
  line-height:1.1; letter-spacing:.01em; color:var(--ink);
  text-wrap:balance;
}
.br-sp{ display:none; }

/* ---------- BUTTONS ---------- */
.btn{ display:inline-flex; align-items:center; gap:.6em; font-weight:700; font-size:15px; line-height:1; transition:all .35s var(--ease-smooth); }

.btn-fill{
  background:var(--ink); color:var(--paper);
  padding:17px 30px; border-radius:2px;
}
.btn-fill:hover{ background:var(--amber-deep); transform:translateY(-2px); }

.btn-line{
  position:relative; color:var(--ink); padding:8px 2px;
  background-image:linear-gradient(var(--amber),var(--amber));
  background-size:100% 2px; background-position:0 100%; background-repeat:no-repeat;
}
.btn-line::after{ content:"→"; font-family:var(--f-mono); transition:transform .35s var(--ease-smooth); }
.btn-line:hover{ color:var(--amber-deep); }
.btn-line:hover::after{ transform:translateX(5px); }

.btn-ghost{
  color:var(--ink-soft); padding:8px 2px;
  background-image:linear-gradient(var(--line),var(--line));
  background-size:100% 1px; background-position:0 100%; background-repeat:no-repeat;
}
.btn-ghost:hover{ color:var(--ink); background-image:linear-gradient(var(--ink),var(--ink)); }

/* ---------- SPLASH ---------- */
.splash{
  position:fixed; inset:0; z-index:9999;
  background:linear-gradient(180deg, rgba(26,18,11,.42), rgba(26,18,11,.62)), #241a12 url('../images/splash-pc.jpg') center/cover no-repeat;
  display:flex; align-items:center; justify-content:center;
  transition:opacity .9s var(--ease-smooth), visibility 0s linear .9s;
}
.splash-inner{ display:flex; flex-direction:column; align-items:center; gap:10px; }
.splash-kabu{ font-family:var(--f-sans); font-size:13px; font-weight:500; letter-spacing:.3em; color:rgba(245,239,226,.82);
  opacity:0; transform:translateY(8px); animation:splashUp .7s var(--ease-smooth) .1s forwards; }
.splash-logo{ font-family:var(--f-display); font-weight:600; font-size:clamp(52px,11vw,128px); letter-spacing:.04em; color:#fdf8ee;
  opacity:0; transform:scale(.94); animation:splashIn .9s var(--ease-spring) .2s forwards; }
.splash-tag{ font-family:var(--f-mono); font-size:11px; letter-spacing:.34em; color:var(--amber-soft);
  opacity:0; transform:translateY(8px); animation:splashUp .7s var(--ease-smooth) .45s forwards; }
@keyframes splashIn{ to{ opacity:1; transform:scale(1); } }
@keyframes splashUp{ to{ opacity:1; transform:translateY(0); } }
body.is-loaded .splash{ opacity:0; visibility:hidden; pointer-events:none; }

/* ---------- SCROLL PROGRESS ---------- */
.scroll-progress{ position:fixed; top:0; left:0; right:0; height:3px; z-index:1000; background:transparent; }
.scroll-progress span{ display:block; height:100%; width:0; background:var(--amber); transition:width .1s linear; }

/* ---------- HEADER ---------- */
.site-header{ position:fixed; top:0; left:0; right:0; z-index:900; transition:all .4s var(--ease-smooth);
  opacity:0; transform:translateY(-14px); }
body.is-loaded .site-header{ opacity:1; transform:translateY(0); transition:opacity .8s ease .3s, transform .8s var(--ease-smooth) .3s, background .4s, padding .4s, box-shadow .4s; }
.header-inner{
  max-width:var(--maxw); margin-inline:auto; padding:22px var(--pad);
  display:grid; grid-template-columns:1fr auto 1fr; align-items:center; gap:20px;
  transition:padding .4s var(--ease-smooth);
}
.site-header.compact{ background:rgba(245,239,226,.86); backdrop-filter:blur(12px); box-shadow:0 1px 0 var(--line-soft); }
.site-header.compact .header-inner{ padding-top:13px; padding-bottom:13px; }

.brand{ display:flex; flex-direction:column; align-items:center; line-height:1; gap:4px; }
.brand-name{ font-family:var(--f-display); font-weight:600; font-size:25px; letter-spacing:.18em; color:var(--ink); transition:font-size .4s; }
.brand-kabu{ font-family:var(--f-mono); font-size:9.5px; letter-spacing:.2em; color:var(--ink-mute); }
.site-header.compact .brand-name{ font-size:21px; }

.nav-cluster{ display:flex; align-items:center; gap:clamp(16px,2.2vw,34px); }
.nav-right{ justify-content:flex-end; }
.nav-link{ font-size:14px; font-weight:500; color:var(--ink-soft); position:relative; padding:4px 0; transition:color .3s; }
.nav-link::after{ content:""; position:absolute; left:0; bottom:0; width:0; height:1.5px; background:var(--amber); transition:width .35s var(--ease-smooth); }
.nav-link:hover{ color:var(--ink); }
.nav-link:hover::after{ width:100%; }
.header-cta{ font-family:var(--f-mono); font-size:12px; font-weight:500; letter-spacing:.04em; color:var(--paper); background:var(--bottle); padding:11px 18px; border-radius:2px; transition:background .3s, transform .3s; }
.header-cta:hover{ background:var(--bottle-deep); transform:translateY(-2px); }

.nav-toggle{ display:none; width:46px; height:46px; flex-direction:column; justify-content:center; align-items:center; gap:6px; }
.nav-toggle span{ display:block; width:24px; height:2px; background:var(--ink); transition:transform .35s var(--ease-spring), opacity .3s; }
body.menu-open .nav-toggle span:first-child{ transform:translateY(4px) rotate(45deg); }
body.menu-open .nav-toggle span:last-child{ transform:translateY(-4px) rotate(-45deg); }

/* ---------- MOBILE MENU ---------- */
.mobile-menu{ position:fixed; inset:0; z-index:850; background:var(--ink); color:var(--cream);
  display:flex; flex-direction:column; justify-content:center; padding:80px var(--pad) 48px;
  opacity:0; visibility:hidden; transform:translateY(-100%); transition:transform .6s var(--ease-smooth), opacity .4s, visibility 0s linear .6s; }
body.menu-open .mobile-menu{ opacity:1; visibility:visible; transform:translateY(0); transition:transform .6s var(--ease-smooth), opacity .4s; }
.mobile-menu-list{ display:flex; flex-direction:column; gap:6px; }
.mobile-link{ display:flex; align-items:baseline; gap:18px; font-size:clamp(28px,8vw,44px); font-weight:900; color:var(--cream); padding:10px 0; transition:color .3s; }
.mobile-link .mm-num{ font-family:var(--f-mono); font-size:13px; font-weight:400; color:var(--amber-soft); }
.mobile-link:hover{ color:var(--amber-soft); }
.mobile-menu-foot{ margin-top:auto; padding-top:36px; border-top:1px solid rgba(245,239,226,.16); display:flex; justify-content:space-between; align-items:flex-end; flex-wrap:wrap; gap:18px; }
.mobile-cta{ font-family:var(--f-mono); font-size:14px; letter-spacing:.05em; color:var(--ink); background:var(--amber-soft); padding:13px 22px; border-radius:2px; }
.mm-contact{ font-family:var(--f-mono); font-size:12px; line-height:1.8; color:var(--ink-mute); text-align:right; }

/* ---------- HERO ---------- */
.hero{ padding:clamp(120px,17vh,200px) 0 0; position:relative; }
.hero-grid{ max-width:var(--maxw); margin-inline:auto; padding-inline:var(--pad);
  display:grid; grid-template-columns:1.12fr .88fr; gap:clamp(30px,5vw,72px); align-items:center; min-height:62vh; }
.hero-copy .eyebrow{ display:block; margin-bottom:26px; }
.hero-title{ font-family:var(--f-sans); font-weight:900; font-size:clamp(38px,7vw,84px); line-height:1.08; letter-spacing:.005em; color:var(--ink); white-space:nowrap; }
.hero-title-em{ color:var(--amber-deep); position:relative; }
.hero-lead{ margin-top:30px; font-size:clamp(15px,1.7vw,18px); line-height:2; color:var(--ink-soft); max-width:30em; text-wrap:pretty; }
.hero-actions{ margin-top:42px; display:flex; align-items:center; gap:30px; flex-wrap:wrap; }

.hero-visual{ position:relative; display:flex; flex-direction:column; align-items:center; }
.hero-bottle{ width:100%; max-width:380px; aspect-ratio:3/4.4; will-change:transform; }
.bottle-media{ width:100%; height:100%; border-radius:6px;
  background:#a5641a url('../images/hero.jpg') center/cover no-repeat;
  box-shadow:0 30px 70px rgba(36,26,18,.22), inset 0 2px 14px rgba(255,255,255,.18);
  position:relative; overflow:hidden;
}
.bottle-media::after{ content:none; }
.hero-visual-cap{ position:absolute; right:-6px; top:50%; transform:translateY(-50%); display:flex; flex-direction:column; gap:2px; }
.cap-line{ font-family:var(--f-mono); font-size:11px; letter-spacing:.22em; color:var(--ink-mute); writing-mode:vertical-rl; }

.hero-marquee{ margin-top:clamp(54px,8vh,96px); border-top:1px solid var(--line); border-bottom:1px solid var(--line); overflow:hidden; padding:18px 0; }
.hero-marquee-track{ display:flex; align-items:center; gap:28px; width:max-content; animation:marquee 34s linear infinite; }
.hero-marquee-track span{ font-family:var(--f-display); font-weight:500; font-size:clamp(22px,3vw,34px); letter-spacing:.06em; color:var(--ink); white-space:nowrap; }
.hero-marquee-track .dot{ color:var(--amber); }
@keyframes marquee{ to{ transform:translateX(-50%); } }

/* ---------- ABOUT ---------- */
.about{ padding:var(--sec-y) 0; }
.about-head{ margin-bottom:clamp(40px,6vw,72px); }
.about-head .eyebrow{ display:block; margin-bottom:20px; }
.about-body{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(34px,6vw,90px); align-items:start; }
.about-lead p{ font-size:clamp(16px,1.9vw,21px); line-height:2.1; color:var(--ink-soft); text-wrap:pretty; }
.about-lead p + p{ margin-top:1.4em; }
.about-quote{ font-family:var(--f-display); font-weight:500; font-style:italic; font-size:clamp(23px,3.4vw,40px); line-height:1.5; color:var(--ink); position:relative; padding-top:18px; }
.about-quote .quote-mark{ font-size:2em; color:var(--amber); line-height:0; vertical-align:-.3em; margin-right:.1em; }

/* ---------- PAIRING (核 / 横スクロール) ---------- */
.pairing{ padding:var(--sec-y) 0; background:var(--ink); color:var(--cream); position:relative; overflow:hidden; }
.pairing .eyebrow{ color:var(--amber-soft); display:block; margin-bottom:20px; }
.pairing-intro{ margin-bottom:clamp(40px,6vw,70px); }
.pairing .section-title{ color:var(--cream); }
.pairing-sub{ margin-top:20px; font-family:var(--f-mono); font-size:13px; letter-spacing:.06em; color:var(--amber-soft); }

.pairing-track-wrap{ position:relative; }
.pairing-track{ display:flex; gap:clamp(20px,2.4vw,34px); padding-inline:var(--pad); width:max-content; will-change:transform; }
.pair-card{ flex:0 0 clamp(280px,30vw,400px); background:var(--paper); color:var(--ink); border-radius:4px; overflow:hidden; display:flex; flex-direction:column; position:relative; box-shadow:0 24px 60px rgba(0,0,0,.28); }
.pair-num{ position:absolute; top:16px; left:18px; z-index:2; font-family:var(--f-mono); font-size:12px; letter-spacing:.1em; color:var(--paper); mix-blend-mode:difference; }
.pair-media{ width:100%; aspect-ratio:4/2.7; }
.media-amber{ background:#bf7d2c url('../images/pair-pale.jpg') center/cover no-repeat; }
.media-gold{ background:#d6ad48 url('../images/pair-pilsner.jpg') center/cover no-repeat; }
.media-copper{ background:#b56a2c url('../images/pair-ipa.jpg') center/cover no-repeat; }
.media-wheat{ background:#e0c97e url('../images/pair-weizen.jpg') center/cover no-repeat; }
.media-stout{ background:#33241a url('../images/pair-stout.jpg') center/cover no-repeat; }
.pair-text{ padding:22px 24px 26px; display:flex; flex-direction:column; gap:7px; flex:1; }
.pair-style{ font-family:var(--f-mono); font-size:11px; letter-spacing:.2em; color:var(--amber-deep); }
.pair-name{ font-family:var(--f-sans); font-weight:900; font-size:25px; line-height:1.2; }
.pair-food{ font-size:14.5px; font-weight:700; color:var(--bottle); }
.pair-desc{ font-size:14px; color:var(--ink-soft); line-height:1.85; flex:1; text-wrap:pretty; }
.pair-spec{ font-family:var(--f-mono); font-size:12px; letter-spacing:.04em; color:var(--ink-mute); padding-top:12px; border-top:1px solid var(--line); }

.pair-card-end{ background:transparent; box-shadow:none; justify-content:center; align-items:flex-start; flex:0 0 clamp(240px,22vw,300px); }
.pair-end{ display:flex; flex-direction:column; gap:22px; }
.pair-end .eyebrow{ color:var(--amber-soft); }
.pair-end-title{ font-family:var(--f-sans); font-weight:900; font-size:clamp(26px,3vw,38px); line-height:1.25; color:var(--cream); }
.pair-card-end .btn-line{ color:var(--cream); }

/* ---------- LINEUP ---------- */
.lineup{ padding:var(--sec-y) 0; }
.lineup-head{ margin-bottom:clamp(40px,6vw,68px); }
.lineup-head .eyebrow{ display:block; margin-bottom:20px; }
.lineup-sub{ margin-top:22px; font-size:clamp(15px,1.7vw,18px); color:var(--ink-soft); max-width:34em; text-wrap:pretty; }

.beer-list{ border-top:1px solid var(--line); }
.beer-row{ display:grid; grid-template-columns:54px 1.4fr 2fr 1.1fr auto; align-items:center; gap:24px;
  padding:30px 8px; border-bottom:1px solid var(--line); transition:background .4s var(--ease-smooth), padding-left .4s var(--ease-smooth); }
.beer-row:hover{ background:var(--paper); padding-left:20px; }
.beer-index{ font-family:var(--f-mono); font-size:13px; color:var(--amber-deep); }
.beer-name-wrap{ display:flex; flex-direction:column; gap:3px; }
.beer-name{ font-family:var(--f-sans); font-weight:900; font-size:clamp(20px,2.4vw,28px); line-height:1.2; }
.beer-en{ font-family:var(--f-display); font-style:italic; font-size:14px; color:var(--ink-mute); }
.beer-note{ font-size:14.5px; color:var(--ink-soft); line-height:1.7; text-wrap:pretty; }
.beer-pair{ font-size:13.5px; font-weight:700; color:var(--bottle); }
.beer-spec{ display:flex; align-items:baseline; gap:6px; font-family:var(--f-mono); white-space:nowrap; }
.beer-spec b{ font-size:18px; font-weight:700; color:var(--ink); }
.beer-spec i{ font-size:10px; font-style:normal; letter-spacing:.1em; color:var(--ink-mute); margin-right:8px; }

.seasonal{ margin-top:48px; background:var(--bottle); color:var(--cream); border-radius:6px; padding:clamp(28px,4vw,44px); }
.seasonal-label{ font-family:var(--f-mono); font-size:12px; letter-spacing:.2em; color:var(--amber-soft); margin-bottom:20px; }
.seasonal-tags{ display:flex; flex-direction:column; }
.seasonal-tags span{ font-size:15px; font-weight:500; padding:15px 0; border-top:1px solid rgba(245,239,226,.2); display:flex; align-items:center; gap:13px; }
.seasonal-tags span::before{ content:""; width:6px; height:6px; border-radius:50%; background:var(--amber-soft); flex:0 0 auto; }

/* ---------- CRAFT ---------- */
.craft{ padding:var(--sec-y) 0; }
.craft-head{ margin-bottom:clamp(40px,6vw,64px); }
.craft-head .eyebrow{ display:block; margin-bottom:20px; }
.craft-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:clamp(24px,3vw,44px); }
.craft-item{ border-top:2px solid var(--ink); padding-top:22px; }
.craft-num{ font-family:var(--f-mono); font-size:12px; color:var(--amber-deep); letter-spacing:.1em; }
.craft-name{ font-family:var(--f-sans); font-weight:900; font-size:clamp(19px,1.6vw,23px); margin:14px 0; }
.craft-desc{ font-size:14.5px; line-height:1.95; color:var(--ink-soft); text-wrap:pretty; word-break:keep-all; }

/* ---------- GARDEN (sticky) ---------- */
.garden{ padding:var(--sec-y) 0; background:var(--paper); }
.garden-inner{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(40px,6vw,90px); align-items:start; }
.garden-sticky{ position:sticky; top:120px; }
.garden-sticky .eyebrow{ display:block; margin-bottom:20px; }
.garden-lead{ margin-top:24px; font-size:clamp(15px,1.7vw,18px); line-height:2; color:var(--ink-soft); text-wrap:pretty; }
.garden-media{ margin-top:32px; width:100%; aspect-ratio:4/3; border-radius:6px;
  background:#34503a url('../images/garden.jpg') center/cover no-repeat;
  box-shadow:0 24px 60px rgba(36,26,18,.18); }
.garden-list{ display:flex; flex-direction:column; }
.garden-feature{ display:flex; gap:22px; padding:28px 0; border-bottom:1px solid var(--line); }
.garden-feature:first-child{ border-top:1px solid var(--line); }
.gf-num{ font-family:var(--f-mono); font-size:12px; color:var(--amber-deep); padding-top:5px; }
.gf-name{ font-family:var(--f-sans); font-weight:900; font-size:clamp(18px,1.7vw,22px); line-height:1.4; }
.gf-desc{ margin-top:10px; font-size:14.5px; line-height:1.8; color:var(--ink-soft); text-wrap:pretty; }
.gf-meta{ margin-top:10px; font-family:var(--f-mono); font-size:12px; letter-spacing:.04em; color:var(--bottle); }
.garden-extra{ margin-top:clamp(40px,5vw,64px); display:grid; grid-template-columns:1.4fr 1fr; gap:clamp(30px,4vw,56px); align-items:start; }
.ge-label{ font-family:var(--f-mono); font-size:12px; letter-spacing:.2em; color:var(--amber-deep); margin-bottom:18px; }
.ge-tags{ display:flex; flex-wrap:wrap; gap:12px 30px; }
.ge-tags span{ font-size:14.5px; padding:7px 0 7px 15px; border-left:2px solid var(--amber); color:var(--ink-soft); }
.garden-info > div{ display:grid; grid-template-columns:96px 1fr; gap:14px; padding:14px 0; border-bottom:1px solid var(--line); }
.garden-info dt{ font-family:var(--f-mono); font-size:11px; letter-spacing:.08em; color:var(--ink-mute); padding-top:3px; }
.garden-info dd{ font-size:14.5px; color:var(--ink); line-height:1.7; }

/* ---------- BREWMASTER ---------- */
.brewmaster{ padding:var(--sec-y) 0; background:var(--ink); color:var(--cream); }
.brewmaster-grid{ display:grid; grid-template-columns:.85fr 1.15fr; gap:clamp(40px,6vw,80px); align-items:center; }
.brewmaster-media{ aspect-ratio:4/5; border-radius:6px;
  background:#241a12 url('../images/brewmaster.jpg') center/cover no-repeat;
  box-shadow:0 30px 70px rgba(0,0,0,.4); }
.brewmaster-text .eyebrow{ color:var(--amber-soft); display:block; margin-bottom:26px; }
.brewmaster-text .section-title{ color:var(--cream); margin-bottom:22px; }
.brewmaster-quote{ font-family:var(--f-display); font-style:italic; font-weight:500; font-size:clamp(21px,2.8vw,32px); line-height:1.55; color:var(--amber-soft); margin-top:4px; }
.brewmaster-quote .quote-mark{ color:var(--amber-soft); font-size:1.4em; line-height:0; vertical-align:-.28em; margin-right:.08em; }
.brewmaster-bio{ margin-top:30px; font-size:15px; line-height:2.1; color:rgba(245,239,226,.78); text-wrap:pretty; }

/* ---------- AWARDS ---------- */
.awards{ padding:var(--sec-y) 0; }
.awards-head{ margin-bottom:clamp(34px,5vw,56px); }
.awards-head .eyebrow{ display:block; margin-bottom:20px; }
.awards-list{ border-top:1px solid var(--line); }
.award-row{ display:grid; grid-template-columns:120px 1fr auto; align-items:center; gap:24px; padding:26px 8px; border-bottom:1px solid var(--line); transition:padding-left .4s var(--ease-smooth), background .4s; }
.award-row:hover{ background:var(--paper); padding-left:18px; }
.award-rank{ font-family:var(--f-sans); font-weight:900; font-size:17px; color:var(--amber-deep); }
.award-name{ font-size:clamp(16px,1.7vw,20px); font-weight:700; color:var(--ink); }
.award-cat{ font-family:var(--f-mono); font-size:12px; letter-spacing:.04em; color:var(--ink-mute); }

/* ---------- CEO ---------- */
.ceo{ padding:var(--sec-y) 0; background:var(--paper); }
.ceo-grid{ display:grid; grid-template-columns:.9fr 1.1fr; gap:clamp(40px,6vw,80px); align-items:center; }
.ceo-media{ aspect-ratio:4/5; border-radius:6px;
  background:#bf7d2c url('../images/ceo.jpg') center/cover no-repeat;
  box-shadow:0 30px 70px rgba(36,26,18,.22); }
.ceo-text .eyebrow{ display:block; margin-bottom:22px; }
.ceo-text .section-title{ margin-bottom:30px; }
.ceo-body p{ font-size:clamp(15px,1.5vw,17px); line-height:2.15; color:var(--ink-soft); text-wrap:pretty; }
.ceo-body p + p{ margin-top:1.3em; }
.ceo-sign{ margin-top:30px; font-family:var(--f-sans); font-weight:700; font-size:16px; color:var(--ink); }

/* ---------- HISTORY ---------- */
.history{ padding:var(--sec-y) 0; }
.history-head{ margin-bottom:clamp(34px,5vw,56px); }
.history-head .eyebrow{ display:block; margin-bottom:20px; }
.timeline{ border-top:1px solid var(--line); }
.tl-row{ display:grid; grid-template-columns:120px 1fr; gap:30px; align-items:baseline; padding:24px 8px; border-bottom:1px solid var(--line); transition:background .4s, padding-left .4s var(--ease-smooth); }
.tl-row:hover{ background:var(--paper); padding-left:16px; }
.tl-year{ font-family:var(--f-display); font-weight:600; font-size:clamp(22px,2.4vw,30px); color:var(--amber-deep); }
.tl-event{ font-size:clamp(15px,1.5vw,17px); color:var(--ink); line-height:1.7; }
.history-next{ margin-top:48px; background:var(--bottle); color:var(--cream); border-radius:8px; padding:clamp(32px,4vw,52px); }
.history-next .eyebrow{ color:var(--amber-soft); display:block; margin-bottom:18px; }
.next-text{ font-size:clamp(16px,1.9vw,21px); line-height:1.9; text-wrap:pretty; }

/* ---------- SHOP ---------- */
.shop{ padding:var(--sec-y) 0; background:var(--ink); color:var(--cream); }
.shop-head{ margin-bottom:clamp(40px,5vw,60px); }
.shop-head .eyebrow{ color:var(--amber-soft); display:block; margin-bottom:20px; }
.shop .section-title{ color:var(--cream); }
.shop-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(34px,5vw,70px); }
.shop-block-label{ font-family:var(--f-mono); font-size:12px; letter-spacing:.2em; color:var(--amber-soft); margin-bottom:8px; }
.shop-items,.shop-where{ display:flex; flex-direction:column; }
.shop-items li{ display:flex; justify-content:space-between; align-items:baseline; gap:16px; padding:18px 0; border-bottom:1px solid rgba(245,239,226,.16); }
.shop-items b{ font-weight:700; font-size:16px; color:var(--cream); }
.shop-items span{ font-family:var(--f-mono); font-size:12px; color:rgba(245,239,226,.55); text-align:right; }
.shop-where li{ padding:18px 0; border-bottom:1px solid rgba(245,239,226,.16); font-size:15px; color:rgba(245,239,226,.85); }
.shop-cta{ margin-top:48px; display:flex; gap:24px; flex-wrap:wrap; align-items:center; }
.shop-cta .btn-fill{ background:var(--amber); color:var(--ink); }
.shop-cta .btn-fill:hover{ background:var(--amber-soft); transform:translateY(-2px); }
.shop-cta .btn-line{ color:var(--cream); }

/* ---------- FOOTER ---------- */
.site-footer{ background:var(--ink); color:var(--cream); padding:clamp(64px,9vw,110px) 0 40px; }
.footer-top{ display:flex; justify-content:space-between; align-items:flex-start; gap:40px; flex-wrap:wrap; padding-bottom:48px; border-bottom:1px solid rgba(245,239,226,.14); }
.footer-brand .brand-name{ font-family:var(--f-display); font-weight:600; font-size:40px; letter-spacing:.14em; color:var(--cream); }
.footer-tag{ margin-top:14px; font-size:14px; color:var(--amber-soft); }
.footer-nav{ display:grid; grid-template-columns:1fr 1fr; gap:14px 48px; }
.footer-nav a{ font-size:14.5px; color:rgba(245,239,226,.78); transition:color .3s; }
.footer-nav a:hover{ color:var(--amber-soft); }
.company{ padding:var(--sec-y) 0; background:var(--paper); }
.company-head{ margin-bottom:clamp(34px,5vw,56px); }
.company-head .eyebrow{ display:block; margin-bottom:20px; }
.company-table{ display:block; max-width:820px; border-top:1px solid var(--line); }
.company-table > div{ display:grid; grid-template-columns:220px 1fr; gap:30px; padding:22px 4px; border-bottom:1px solid var(--line); }
.company-table dt{ font-family:var(--f-mono); font-size:11px; letter-spacing:.14em; color:var(--amber-deep); padding-top:6px; }
.company-table dd{ font-size:15.5px; color:var(--ink); line-height:1.8; }
.footer-bottom{ display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:12px; padding-top:34px; }
.copyright,.credit{ font-family:var(--f-mono); font-size:11px; letter-spacing:.1em; color:var(--ink-mute); }

/* ---------- REVEAL ---------- */
.reveal{ opacity:0; transform:translateY(34px); transition:opacity .9s var(--ease-smooth), transform .9s var(--ease-smooth); }
.reveal.in{ opacity:1; transform:translateY(0); }

/* ---------- RESPONSIVE ---------- */
@media (max-width:980px){
  :root{ --sec-y:clamp(64px,11vh,110px); }
  .nav-cluster{ display:none; }
  .nav-toggle{ display:flex; }
  .header-inner{ grid-template-columns:1fr auto 1fr; }
  .brand{ grid-column:1; align-items:flex-start; }
  .nav-toggle{ grid-column:3; justify-self:end; }

  .hero-grid{ grid-template-columns:1fr; gap:48px; min-height:auto; }
  .hero-visual{ order:-1; }
  .hero-bottle{ max-width:260px; }
  .hero-visual-cap{ display:none; }

  .about-body{ grid-template-columns:1fr; gap:36px; }

  .pairing-track-wrap{ overflow-x:auto; overflow-y:hidden; scroll-snap-type:x mandatory; -webkit-overflow-scrolling:touch; scrollbar-width:none; }
  .pairing-track-wrap::-webkit-scrollbar{ display:none; }
  .pairing-track{ transform:none !important; }
  .pair-card{ scroll-snap-align:start; flex-basis:78vw; }

  .beer-row{ grid-template-columns:40px 1fr auto; gap:10px 16px; padding:24px 6px; }
  .beer-name-wrap{ grid-column:2; }
  .beer-note{ grid-column:2/4; grid-row:2; }
  .beer-pair{ grid-column:2/4; grid-row:3; }
  .beer-spec{ grid-column:3; grid-row:1; }
  .beer-row:hover{ padding-left:6px; }

  .company-table{ grid-template-columns:1fr; }
  .footer-top{ flex-direction:column; gap:30px; }

  .craft-grid{ grid-template-columns:repeat(2,1fr); gap:30px 24px; }
  .garden-inner{ grid-template-columns:1fr; gap:14px; }
  .garden-sticky{ position:static; }
  .garden-media{ aspect-ratio:16/9; }
  .garden-extra{ grid-template-columns:1fr; gap:36px; }
  .garden-info > div{ grid-template-columns:84px 1fr; }
  .brewmaster-grid,.ceo-grid{ grid-template-columns:1fr; gap:34px; }
  .brewmaster-media,.ceo-media{ max-width:360px; }
  .ceo-media{ order:-1; }
  .shop-grid{ grid-template-columns:1fr; gap:34px; }
  .award-row{ grid-template-columns:74px 1fr; gap:6px 14px; padding:22px 6px; }
  .award-name{ grid-column:2; }
  .award-cat{ grid-column:2; }
  .award-row:hover{ padding-left:6px; }
  .tl-row{ grid-template-columns:64px 1fr; gap:18px; }
  .tl-row:hover{ padding-left:6px; }
}

@media (max-width:560px){
  .splash{ background:linear-gradient(180deg, rgba(26,18,11,.4), rgba(26,18,11,.6)), #241a12 url('../images/splash-sp.jpg') center/cover no-repeat; }
  .hero-title{ font-size:clamp(31px,11.4vw,56px); }
  .br-sp{ display:inline; }
  .hero-actions{ gap:20px; }
  .company-table > div{ grid-template-columns:1fr; gap:4px; }
  .seasonal-tags{ flex-direction:column; }
  .seasonal-tags span{ text-align:center; }
  .craft-grid{ grid-template-columns:1fr; }
  .shop-cta{ flex-direction:column; align-items:stretch; }
  .shop-cta .btn{ justify-content:center; }
  .shop-cta .btn-fill{ text-align:center; }
}

/* ---------- A11Y ---------- */
:focus-visible{ outline:2.5px solid var(--amber); outline-offset:3px; }
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{ animation-duration:.01ms !important; animation-iteration-count:1 !important; transition-duration:.01ms !important; scroll-behavior:auto !important; }
  .reveal{ opacity:1; transform:none; }
}
