/* Direction A — "Cellar": dark editorial luxury */
.dirA {
  --bg: #0b0907;
  --bg-2: #13100c;
  --ink: #e8dcc4;
  --ink-2: rgba(232,220,196,0.62);
  --ink-3: rgba(232,220,196,0.32);
  --gold: #b8945a;
  --gold-2: #d4b078;
  --rule: rgba(232,220,196,0.14);
  font-family: 'Inter', -apple-system, system-ui, sans-serif;
  background: var(--bg);
  color: var(--ink);
  line-height: 1.5;
}
.dirA *, .dirA *::before, .dirA *::after { box-sizing: border-box; }
.dirA .serif { font-family: 'Cormorant Garamond', Georgia, serif; }
.dirA h1, .dirA h2, .dirA h3 { font-family: 'Cormorant Garamond', Georgia, serif; font-weight: 300; margin: 0; letter-spacing: -0.015em; }
.dirA h1 { font-size: clamp(72px, 11vw, 168px); line-height: 0.95; }
.dirA h2 { font-size: clamp(44px, 5vw, 76px); line-height: 1; }
.dirA h3 { font-size: 26px; line-height: 1.15; }
.dirA em { font-style: italic; color: var(--gold); }
.dirA p { margin: 0; }
.dirA a { color: inherit; text-decoration: none; }
.dirA .eyebrow { font-size: 11px; letter-spacing: 0.3em; text-transform: uppercase; color: var(--gold); }

/* Nav */
.dirA .nav { position: sticky; top: 0; z-index: 50; display: flex; align-items: center; justify-content: space-between; padding: 22px 56px; background: rgba(11,9,7,0); backdrop-filter: blur(0px); -webkit-backdrop-filter: blur(0px); border-bottom: 1px solid transparent; transition: background-color .25s ease, padding .25s ease, border-color .25s ease; will-change: background-color, padding; }
.dirA .nav.scrolled { background: rgba(11,9,7,0.88); backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px); border-bottom-color: var(--rule); padding: 14px 56px; }
.dirA .nav-logo { display: flex; align-items: center; gap: 14px; }
.dirA .nav-logo img { height: 32px; opacity: 0.95; }
.dirA .nav-logo .wm { font-family: 'Cormorant Garamond', serif; font-size: 18px; letter-spacing: 0.32em; color: var(--ink); }
.dirA .nav-links { display: flex; gap: 38px; align-items: center; font-size: 11.5px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--ink-2); }
.dirA .nav-links a { transition: color .2s; }
.dirA .nav-links a:hover { color: var(--ink); }
.dirA .lang { display: flex; gap: 8px; }
.dirA .lang button { background: none; border: 0; cursor: pointer; padding: 2px 0; color: var(--ink-3); font: inherit; font-size: 10.5px; letter-spacing: 0.18em; }
.dirA .lang button.on { color: var(--gold); }
.dirA .cta-pill { background: var(--gold); color: var(--bg) !important; padding: 22px 52px; border-radius: 999px; font-size: 13px; letter-spacing: 0.22em; font-weight: 500; text-transform: uppercase; line-height: 1.2; white-space: nowrap; display: inline-block; box-sizing: border-box; }
.dirA .cta-ghost { border: 1px solid var(--rule); padding: 14px 32px; border-radius: 999px; font-size: 11.5px; letter-spacing: 0.24em; text-transform: uppercase; }
.dirA .cta-solid { background: var(--gold); color: var(--bg) !important; padding: 14px 32px; border-radius: 999px; font-size: 11.5px; letter-spacing: 0.24em; text-transform: uppercase; font-weight: 500; }

/* Hero */
.dirA .hero { position: relative; height: 110vh; min-height: 760px; margin-top: -82px; overflow: hidden; }
.dirA .hero-bg { position: absolute; inset: 0; background: url(/images/hero-bg.jpg) center/cover; transform: scale(1.08); }
.dirA .hero-bg::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(11,9,7,0.55) 0%, rgba(11,9,7,0.25) 35%, rgba(11,9,7,0.7) 75%, var(--bg) 100%); }
.dirA .hero-vig { position: absolute; inset: 0; background: radial-gradient(ellipse at 50% 60%, transparent 35%, rgba(11,9,7,0.55) 100%); }
.dirA .hero-inner { position: relative; height: 100%; display: flex; flex-direction: column; justify-content: center; align-items: center; padding: 0 56px; text-align: center; }
.dirA .hero-eyebrow { display: flex; align-items: center; gap: 18px; margin-bottom: 36px; }
.dirA .hero-eyebrow .line { width: 32px; height: 1px; background: var(--gold); opacity: 0.6; }
.dirA .hero h1 { color: var(--ink); }
.dirA .hero p.lede { font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 22px; color: var(--ink-2); margin-top: 32px; max-width: 540px; line-height: 1.5; }
.dirA .hero-actions { display: flex; gap: 16px; margin-top: 48px; }
.dirA .scroll-cue { position: absolute; bottom: 36px; left: 50%; transform: translateX(-50%); display: flex; flex-direction: column; align-items: center; gap: 12px; font-size: 10px; letter-spacing: 0.32em; color: var(--ink-3); text-transform: uppercase; }
.dirA .scroll-cue .ln { width: 1px; height: 56px; background: linear-gradient(180deg, var(--gold) 0%, transparent 100%); }

/* Intro */
.dirA .intro { padding: 160px 56px 120px; }
.dirA .intro-grid { max-width: 1240px; margin: 0 auto; display: grid; grid-template-columns: 1fr 1fr; gap: 100px; align-items: center; }
.dirA .intro p { font-size: 16px; line-height: 1.75; color: var(--ink-2); font-weight: 300; }
.dirA .intro p strong { color: var(--ink); font-weight: 400; }
.dirA .stats { margin-top: 48px; display: grid; grid-template-columns: repeat(2,1fr); gap: 28px; }
.dirA .stat { border-top: 1px solid var(--rule); padding-top: 18px; }
.dirA .stat .n { font-family: 'Cormorant Garamond', serif; font-size: 38px; color: var(--gold); line-height: 1; }
.dirA .stat .l { font-size: 12px; color: var(--ink-2); margin-top: 8px; line-height: 1.45; }

/* Pillars */
.dirA .pillars { background: var(--bg-2); padding: 140px 0 160px; }
.dirA .pillars-wrap { max-width: 1320px; margin: 0 auto; padding: 0 56px; }
.dirA .pillars-head { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 80px; }
.dirA .pillars-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 0; border-top: 1px solid var(--rule); }
.dirA .pillar { padding: 48px 40px; border-right: 1px solid var(--rule); transition: background .3s; }
.dirA .pillar:last-child { border-right: 0; }
.dirA .pillar:hover { background: rgba(184,148,90,0.04); }
.dirA .pillar-img { aspect-ratio: 4/3; overflow: hidden; margin-bottom: 28px; }
.dirA .pillar-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .8s; filter: brightness(0.92); }
.dirA .pillar:hover .pillar-img img { transform: scale(1.04); }
.dirA .pillar .num { font-size: 11px; letter-spacing: 0.28em; color: var(--gold); margin-bottom: 12px; }
.dirA .pillar h3 { color: var(--ink); margin-bottom: 14px; }
.dirA .pillar p { font-size: 14px; line-height: 1.65; color: var(--ink-2); margin-bottom: 24px; }
.dirA .pillar .more { font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--gold-2); display: inline-flex; gap: 10px; align-items: center; }
.dirA .pillar .more::after { content: "→"; transition: transform .25s; }
.dirA .pillar:hover .more::after { transform: translateX(6px); }

/* Panama */
.dirA .panama { padding: 160px 56px; position: relative; overflow: hidden; }
.dirA .panama-bg { position: absolute; inset: 0; background: url(/images/panama-landscape.jpg) center/cover; opacity: 0.18; }
.dirA .panama-bg::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, var(--bg) 0%, transparent 25%, transparent 75%, var(--bg) 100%); }
.dirA .panama-inner { position: relative; max-width: 1100px; margin: 0 auto; text-align: center; }
.dirA .panama h2 { margin: 28px 0 36px; font-style: italic; }
.dirA .panama .lede { font-size: 22px; line-height: 1.6; color: var(--ink); max-width: 720px; margin: 0 auto 80px; font-family: 'Cormorant Garamond', serif; }
.dirA .timeline { display: grid; grid-template-columns: repeat(3,1fr); gap: 0; text-align: left; border-top: 1px solid var(--rule); }
.dirA .tl { padding: 40px 32px; border-right: 1px solid var(--rule); }
.dirA .tl:last-child { border-right: 0; }
.dirA .tl .yr { display: flex; align-items: center; gap: 12px; font-size: 12px; letter-spacing: 0.24em; color: var(--gold); margin-bottom: 16px; }
.dirA .tl .dot { width: 6px; height: 6px; background: var(--gold); border-radius: 50%; }
.dirA .tl h3 { font-size: 22px; margin-bottom: 14px; line-height: 1.2; color: var(--ink); }
.dirA .tl p { font-size: 13px; line-height: 1.6; color: var(--ink-2); }

/* Market */
.dirA .market { background: var(--bg-2); padding: 140px 56px; }
.dirA .market-grid { max-width: 1320px; margin: 0 auto; display: grid; grid-template-columns: 380px 1fr; gap: 96px; align-items: end; }
.dirA .market p { font-size: 14px; line-height: 1.7; color: var(--ink-2); margin-bottom: 24px; }
.dirA .cagr { display: inline-flex; gap: 12px; align-items: baseline; padding: 14px 18px; border: 1px solid var(--rule); }
.dirA .cagr .n { font-family: 'Cormorant Garamond', serif; font-size: 28px; color: var(--gold-2); }
.dirA .cagr .l { font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink-2); }
.dirA .chart { display: flex; align-items: flex-end; gap: 14px; height: 360px; padding-bottom: 40px; border-bottom: 1px solid var(--rule); }
.dirA .bar-wrap { flex: 1; height: 100%; display: flex; flex-direction: column; justify-content: flex-end; gap: 8px; }
.dirA .bar-val { font-size: 12px; color: var(--ink); text-align: center; flex-shrink: 0; }
.dirA .bar { background: linear-gradient(180deg, var(--gold-2), var(--gold)); border-radius: 1px 1px 0 0; flex-shrink: 0; }
.dirA .bar.future { background: linear-gradient(180deg, rgba(212,176,120,0.4), rgba(184,148,90,0.18)); border: 1px solid var(--rule); border-bottom: 0; }
.dirA .bar-yr { font-size: 11px; color: var(--ink-2); text-align: center; padding-top: 12px; flex-shrink: 0; }
.dirA .bar-yr.proj::after { content: "*"; color: var(--gold); }
.dirA .chart-foot { font-size: 11px; color: var(--ink-3); margin-top: 16px; }

/* CTA / contact */
.dirA .cta { padding: 160px 56px; position: relative; overflow: hidden; border-top: 1px solid var(--rule); }
.dirA .cta-bg { position: absolute; inset: 0; background: url(/images/tasting-glasses.jpg) center/cover; opacity: 0.16; }
.dirA .cta-bg::after { content: ""; position: absolute; inset: 0; background: radial-gradient(ellipse at center, transparent 0%, var(--bg) 80%); }
.dirA .cta-inner { position: relative; max-width: 1100px; margin: 0 auto; display: grid; grid-template-columns: 1fr 1fr; gap: 80px; }
.dirA .cta h2 { font-style: italic; margin-bottom: 24px; }
.dirA .cta p.copy { font-size: 15px; line-height: 1.7; color: var(--ink-2); margin-bottom: 32px; }
.dirA form { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.dirA form .full { grid-column: 1 / -1; }
.dirA .field { position: relative; }
.dirA .field input, .dirA .field textarea { width: 100%; background: transparent; border: 0; border-bottom: 1px solid var(--rule); padding: 18px 0 12px; color: var(--ink); font-family: inherit; font-size: 14px; outline: none; transition: border-color .25s; resize: none; }
.dirA .field input:focus, .dirA .field textarea:focus { border-bottom-color: var(--gold); }
.dirA .field input::placeholder, .dirA .field textarea::placeholder { color: var(--ink-3); font-size: 12px; letter-spacing: 0.18em; text-transform: uppercase; }
.dirA .submit { grid-column: 1 / -1; margin-top: 12px; padding: 18px; background: var(--gold); color: var(--bg); border: 0; font-family: inherit; font-size: 12px; letter-spacing: 0.28em; text-transform: uppercase; cursor: pointer; font-weight: 500; }

/* Reveal animations */
.dirA .reveal { opacity: 0; transform: translateY(28px); transition: opacity 1.05s cubic-bezier(.2,.7,.3,1), transform 1.05s cubic-bezier(.2,.7,.3,1); }
.dirA .reveal.in { opacity: 1; transform: translateY(0); }
.dirA .reveal.d1 { transition-delay: .08s; }
.dirA .reveal.d2 { transition-delay: .16s; }
.dirA .reveal.d3 { transition-delay: .24s; }
.dirA .reveal.d4 { transition-delay: .32s; }
.dirA .reveal-x { opacity: 0; transform: translateX(-32px); transition: opacity 1.1s cubic-bezier(.2,.7,.3,1), transform 1.1s cubic-bezier(.2,.7,.3,1); }
.dirA .reveal-x.in { opacity: 1; transform: translateX(0); }
.dirA .reveal-line { transform: scaleX(0); transform-origin: left; transition: transform 1.2s cubic-bezier(.2,.7,.3,1); }
.dirA .reveal-line.in { transform: scaleX(1); }

/* Bar grow */
.dirA .bar { transform-origin: bottom; transform: scaleY(0); transition: transform 1.1s cubic-bezier(.2,.7,.3,1); }
.dirA .bar.in { transform: scaleY(1); }
.dirA .bar.b1 { transition-delay: .05s; }
.dirA .bar.b2 { transition-delay: .12s; }
.dirA .bar.b3 { transition-delay: .19s; }
.dirA .bar.b4 { transition-delay: .26s; }
.dirA .bar.b5 { transition-delay: .33s; }
.dirA .bar.b6 { transition-delay: .40s; }

/* Nav microinteractions */
.dirA .nav-links a { position: relative; padding: 4px 0; }
.dirA .nav-links a::after { content: ""; position: absolute; left: 0; right: 0; bottom: -2px; height: 1px; background: var(--gold); transform: scaleX(0); transform-origin: left; transition: transform .35s cubic-bezier(.2,.7,.3,1); }
.dirA .nav-links a:hover::after { transform: scaleX(1); }
.dirA .nav-links a.active { color: var(--ink); }
.dirA .nav-links a.active::after { transform: scaleX(1); background: var(--gold); }
.dirA .lang button { position: relative; transition: color .25s; }
.dirA .lang button.on::after { content: ""; position: absolute; left: 0; right: 0; bottom: -3px; height: 1px; background: var(--gold); }
.dirA .cta-pill { transition: transform .25s, box-shadow .25s, background .25s; }
.dirA .cta-pill:hover { transform: translateY(-2px); box-shadow: 0 8px 24px rgba(184,148,90,0.35); background: var(--gold-2); }
.dirA .cta-solid { transition: transform .25s, box-shadow .25s, background .25s; }
.dirA .cta-solid:hover { transform: translateY(-2px); box-shadow: 0 12px 36px rgba(184,148,90,0.4); background: var(--gold-2); }
.dirA .cta-ghost { transition: border-color .25s, color .25s, background .25s; }
.dirA .cta-ghost:hover { border-color: var(--gold); color: var(--gold-2); }
.dirA .submit { transition: background .25s, transform .15s; }
.dirA .submit:hover { background: var(--gold-2); }
.dirA .submit:active { transform: scale(0.98); }
.dirA .pillar .more { transition: color .25s; }
.dirA .pillar:hover .more { color: var(--ink); }

/* Footer */
.dirA .footer { padding: 60px 56px; border-top: 1px solid var(--rule); display: flex; justify-content: space-between; align-items: center; font-size: 11px; letter-spacing: 0.18em; color: var(--ink-3); text-transform: uppercase; }

/* ── Heritage strip (compact, epigraph style) ── */
.dirA .heritage-strip { position: relative; padding: 110px 56px; overflow: hidden; }
.dirA .heritage-strip-bg { position: absolute; inset: 0; background: url(/images/rum-glasses.jpg) center/cover; opacity: 0.32; }
.dirA .heritage-strip-bg::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, var(--bg) 0%, rgba(11,9,7,0.55) 35%, rgba(11,9,7,0.55) 65%, var(--bg) 100%); }
.dirA .heritage-strip-inner { position: relative; max-width: 760px; margin: 0 auto; text-align: center; display: flex; flex-direction: column; align-items: center; gap: 22px; }
.dirA .heritage-strip-rule { width: 48px; height: 1px; background: var(--gold); opacity: 0.7; }
.dirA .heritage-strip-quote { font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: clamp(24px, 3vw, 36px); line-height: 1.35; color: var(--ink); margin: 0; max-width: 640px; font-weight: 300; }
.dirA .heritage-strip-quote em { color: var(--gold); font-style: italic; }
.dirA .heritage-strip-body { font-family: 'Inter', sans-serif; font-size: 14px; line-height: 1.75; color: var(--ink-2); max-width: 520px; margin: 0; }
.dirA .heritage-strip .note { font-family: 'Inter', sans-serif; font-size: 11px; letter-spacing: 0.32em; text-transform: uppercase; color: var(--gold); margin-top: 4px; }

/* ── Brand loader ── */
.brand-loader { position: fixed; inset: 0; z-index: 99999; background: #0b0906; display: flex; align-items: center; justify-content: center; transition: opacity .8s cubic-bezier(.65,0,.35,1), transform .8s cubic-bezier(.65,0,.35,1); }
.brand-loader__inner { display: flex; flex-direction: column; align-items: center; }
.brand-loader__logo { width: 64px; height: 64px; opacity: 0; transform: scale(.92); animation: bl-logo .9s cubic-bezier(.16,1,.3,1) .05s forwards; }
.brand-loader__line { display: block; width: 0; height: 1px; background: #b08548; margin: 22px 0; animation: bl-line .9s cubic-bezier(.65,0,.35,1) .55s forwards; }
.brand-loader__name { font-family: 'Libre Baskerville', 'Cormorant Garamond', Georgia, serif; font-size: 14px; color: #e8dcc8; letter-spacing: 4px; opacity: 0; transform: translateY(6px); animation: bl-name .9s cubic-bezier(.16,1,.3,1) .4s forwards; white-space: nowrap; }
.brand-loader--done { opacity: 0; transform: translateY(-12px); pointer-events: none; }
@keyframes bl-logo { to { opacity: 1; transform: scale(1); } }
@keyframes bl-line { to { width: 70px; } }
@keyframes bl-name { to { opacity: 1; transform: translateY(0); letter-spacing: 8px; } }
html.bl-loading, html.bl-loading body { overflow: hidden; }
html.bl-skip .brand-loader { display: none !important; }

/* ── Form status + cookie banner ── */
.dirA .form-status { grid-column: 1 / -1; font-size: 12px; letter-spacing: 0.18em; text-transform: uppercase; padding: 12px 0; min-height: 18px; transition: color .3s; }
.dirA .form-status.success { color: var(--gold-2); }
.dirA .form-status.error { color: #d4806a; }
.dirA .submit:disabled { opacity: 0.5; cursor: not-allowed; }
.dirA .cookie-banner { position: fixed; bottom: 24px; left: 24px; right: 24px; max-width: 540px; margin: 0 auto; background: var(--bg-2); border: 1px solid var(--rule); padding: 22px 28px; z-index: 1000; transform: translateY(120%); opacity: 0; transition: transform .6s cubic-bezier(.2,.7,.3,1), opacity .6s; }
.dirA .cookie-banner.active { transform: translateY(0); opacity: 1; }
.dirA .cookie-banner.hidden { display: none; }
.dirA .cookie-banner__text { font-size: 13px; line-height: 1.6; color: var(--ink-2); margin-bottom: 14px; }
.dirA .cookie-banner__text a { color: var(--gold); border-bottom: 1px solid var(--gold); }
.dirA .cookie-banner__actions { display: flex; gap: 12px; }
.dirA .cookie-banner__btn { background: none; border: 1px solid var(--rule); color: var(--ink); padding: 10px 22px; font-family: inherit; font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; cursor: pointer; transition: all .25s; }
.dirA .cookie-banner__btn:hover { border-color: var(--gold); color: var(--gold-2); }
.dirA .cookie-banner__btn--accept { background: var(--gold); color: var(--bg); border-color: var(--gold); }
.dirA .cookie-banner__btn--accept:hover { background: var(--gold-2); color: var(--bg); }

/* ── Mobile (≤900px) ── */
@media (max-width: 900px) {
  .dirA .nav { padding: 16px 24px; flex-wrap: wrap; gap: 16px; }
  .dirA .nav-links { display: none; }
  .dirA .nav.menu-open .nav-links { display: flex; flex-direction: column; gap: 18px; width: 100%; padding: 16px 0 8px; align-items: flex-start; }
  .dirA .nav-toggle { display: inline-flex; flex-direction: column; gap: 5px; background: none; border: 0; cursor: pointer; padding: 6px; }
  .dirA .nav-toggle span { width: 22px; height: 1px; background: var(--ink); display: block; transition: transform .3s; }
  .dirA .nav.menu-open .nav-toggle span:nth-child(1) { transform: translateY(6px) rotate(45deg); }
  .dirA .nav.menu-open .nav-toggle span:nth-child(2) { opacity: 0; }
  .dirA .nav.menu-open .nav-toggle span:nth-child(3) { transform: translateY(-6px) rotate(-45deg); }
  .dirA .hero { height: 100vh; min-height: 600px; }
  .dirA .hero-inner { padding: 0 24px; }
  .dirA .hero-actions { flex-direction: column; width: 100%; max-width: 320px; }
  .dirA .cta-solid, .dirA .cta-ghost { text-align: center; }
  .dirA .intro { padding: 100px 24px 80px; }
  .dirA .intro-grid { grid-template-columns: 1fr; gap: 40px; }
  .dirA .stats { grid-template-columns: 1fr 1fr; }
  .dirA .pillars { padding: 100px 0 110px; }
  .dirA .pillars-wrap { padding: 0 24px; }
  .dirA .pillars-head { flex-direction: column; gap: 24px; margin-bottom: 56px; }
  .dirA .pillars-grid { grid-template-columns: 1fr; }
  .dirA .pillar { border-right: 0; border-bottom: 1px solid var(--rule); padding: 40px 24px; }
  .dirA .pillar:last-child { border-bottom: 0; }
  .dirA .heritage-strip { padding: 100px 24px; }
  .dirA .panama { padding: 110px 24px; }
  .dirA .timeline { grid-template-columns: 1fr; }
  .dirA .tl { border-right: 0; border-bottom: 1px solid var(--rule); padding: 32px 0; }
  .dirA .tl:last-child { border-bottom: 0; }
  .dirA .market { padding: 100px 24px; }
  .dirA .market-grid { grid-template-columns: 1fr; gap: 56px; }
  .dirA .chart { height: 280px; }
  .dirA .cta { padding: 110px 24px; }
  .dirA .cta-inner { grid-template-columns: 1fr; gap: 56px; }
  .dirA form { grid-template-columns: 1fr; }
  .dirA form .full { grid-column: 1; }
  .dirA .footer { padding: 40px 24px; flex-direction: column; gap: 16px; text-align: center; }
}

/* nav-toggle hidden by default on desktop */
.dirA .nav-toggle { display: none; }

/* prefers-reduced-motion */
@media (prefers-reduced-motion: reduce) {
  .dirA .reveal, .dirA .bar, .dirA .hero-bg { transition: none !important; transform: none !important; opacity: 1 !important; }
}

/* ═════════════════════════════════════════════════════════
   ABOUT PAGE
   ═════════════════════════════════════════════════════════ */

/* About hero — split (text left, photo right) */
.dirA .ab-hero { position: relative; min-height: 88vh; display: grid; grid-template-columns: 1fr 1fr; align-items: center; overflow: hidden; margin-top: -82px; padding-top: 82px; background: var(--bg); }
.dirA .ab-hero-text { padding: 100px 56px; max-width: 640px; margin-left: auto; }
.dirA .ab-hero-overline { display: flex; align-items: center; gap: 14px; margin-bottom: 28px; font-size: 11px; letter-spacing: 0.32em; text-transform: uppercase; color: var(--gold); }
.dirA .ab-hero-overline .line { width: 32px; height: 1px; background: var(--gold); opacity: 0.6; flex-shrink: 0; }
.dirA .ab-hero-text h1 { font-size: clamp(48px, 6vw, 88px); line-height: 1; margin-bottom: 28px; }
.dirA .ab-hero-text .lede { font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 22px; line-height: 1.55; color: var(--ink-2); max-width: 540px; }
.dirA .ab-hero-img { position: relative; height: 100%; min-height: 88vh; overflow: hidden; }
.dirA .ab-hero-img img { width: 100%; height: 100%; object-fit: cover; filter: brightness(0.78); }
.dirA .ab-hero-img::after { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, var(--bg) 0%, rgba(11,9,7,0.55) 18%, transparent 45%); }

/* Story split */
.dirA .story { padding: 140px 56px; }
.dirA .story-grid { max-width: 1240px; margin: 0 auto; display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center; }
.dirA .story-img { aspect-ratio: 4/5; overflow: hidden; }
.dirA .story-img img { width: 100%; height: 100%; object-fit: cover; transition: transform 1.2s; }
.dirA .story:hover .story-img img { transform: scale(1.04); }
.dirA .story-text h2 { margin: 24px 0 32px; }
.dirA .story-text p { font-size: 16px; line-height: 1.85; color: var(--ink-2); margin-bottom: 22px; font-weight: 300; }
.dirA .story-text p:last-child { margin-bottom: 0; }

/* Difference accordion (numbered rows) */
.dirA .diff { background: var(--bg-2); padding: 140px 56px; }
.dirA .diff-wrap { max-width: 1100px; margin: 0 auto; }
.dirA .diff-head { text-align: center; margin-bottom: 80px; max-width: 640px; margin-left: auto; margin-right: auto; }
.dirA .diff-head .eyebrow { display: inline-block; margin-bottom: 18px; }
.dirA .diff-head h2 { font-style: italic; }
.dirA .diff-list { border-top: 1px solid var(--rule); }
.dirA .diff-item { border-bottom: 1px solid var(--rule); }
.dirA .diff-head-btn { width: 100%; background: transparent; border: 0; padding: 32px 0; display: grid; grid-template-columns: 80px 1fr 32px; gap: 32px; align-items: center; cursor: pointer; text-align: left; font: inherit; color: inherit; transition: padding .35s ease; }
.dirA .diff-head-btn:hover .diff-title { color: var(--ink); }
.dirA .diff-head-btn:hover .diff-icon::before, .dirA .diff-head-btn:hover .diff-icon::after { background: var(--gold-2); }
.dirA .diff-num { font-family: 'Cormorant Garamond', serif; font-size: 26px; font-style: italic; color: var(--gold); }
.dirA .diff-title { font-family: 'Cormorant Garamond', serif; font-size: 26px; font-weight: 300; color: rgba(232,220,196,0.78); transition: color .3s; }
.dirA .diff-icon { position: relative; width: 18px; height: 18px; }
.dirA .diff-icon::before, .dirA .diff-icon::after { content: ""; position: absolute; left: 50%; top: 50%; background: var(--gold); transition: transform .5s cubic-bezier(.65,0,.35,1); }
.dirA .diff-icon::before { width: 14px; height: 1px; transform: translate(-50%, -50%); }
.dirA .diff-icon::after { width: 1px; height: 14px; transform: translate(-50%, -50%); }
.dirA .diff-item.is-open .diff-icon::after { transform: translate(-50%, -50%) rotate(90deg); }
.dirA .diff-body { max-height: 0; overflow: hidden; opacity: 0; transition: max-height .65s cubic-bezier(.2,.8,.2,1), opacity .4s ease; }
.dirA .diff-item.is-open .diff-body { max-height: 400px; opacity: 1; }
.dirA .diff-body-inner { padding: 0 0 36px 112px; max-width: 720px; }
.dirA .diff-body-inner p { font-size: 15px; line-height: 1.75; color: var(--ink-2); font-weight: 300; }

/* Network / partners */
.dirA .network { padding: 140px 56px; }
.dirA .network-wrap { max-width: 1100px; margin: 0 auto; }
.dirA .network-head { max-width: 640px; margin-bottom: 80px; }
.dirA .network-head h2 { margin-top: 18px; font-style: italic; }
.dirA .network-head .lede { font-size: 16px; line-height: 1.7; color: var(--ink-2); margin-top: 24px; max-width: 520px; }
.dirA .partner { padding: 56px 0; border-top: 1px solid var(--rule); display: grid; grid-template-columns: 180px 1fr auto; gap: 48px; align-items: center; }
.dirA .partner:last-child { border-bottom: 1px solid var(--rule); }
.dirA .partner-region { font-size: 11px; letter-spacing: 0.32em; text-transform: uppercase; color: var(--gold); }
.dirA .partner-name { font-family: 'Cormorant Garamond', serif; font-size: 32px; font-weight: 300; color: var(--ink); margin-bottom: 12px; line-height: 1.1; }
.dirA .partner-desc { font-size: 14px; line-height: 1.7; color: var(--ink-2); max-width: 520px; }
.dirA .partner-link { font-size: 11px; letter-spacing: 0.24em; text-transform: uppercase; color: var(--gold-2); display: inline-flex; gap: 10px; align-items: center; transition: gap .25s, color .25s; white-space: nowrap; }
.dirA .partner-link::after { content: "\2192"; transition: transform .25s; }
.dirA .partner-link:hover { color: var(--ink); gap: 14px; }

/* Values flowing prose */
.dirA .values { background: var(--bg-2); padding: 140px 56px; }
.dirA .values-wrap { max-width: 880px; margin: 0 auto; }
.dirA .values-head { text-align: center; margin-bottom: 88px; }
.dirA .values-head h2 { margin-top: 18px; font-style: italic; }
.dirA .values-block { margin-bottom: 88px; max-width: 620px; }
.dirA .values-block:last-child { margin-bottom: 0; }
.dirA .values-block--right { margin-left: auto; text-align: right; }
.dirA .values-block--center { margin: 0 auto 88px; text-align: center; }
.dirA .values-block h3 { font-size: 28px; line-height: 1.25; margin-bottom: 20px; font-style: italic; color: var(--ink); }
.dirA .values-block h3 em { font-style: italic; color: var(--gold); }
.dirA .values-block p { font-size: 16px; line-height: 1.85; color: var(--ink-2); font-weight: 300; }
.dirA .values-block .rule { width: 32px; height: 1px; background: var(--gold); opacity: 0.55; margin-top: 36px; display: block; }
.dirA .values-block--right .rule { margin-left: auto; }
.dirA .values-block--center .rule { margin: 36px auto 0; }

/* Stats strip */
.dirA .stats-strip { padding: 80px 56px; border-top: 1px solid var(--rule); border-bottom: 1px solid var(--rule); }
.dirA .stats-strip-grid { max-width: 1100px; margin: 0 auto; display: grid; grid-template-columns: repeat(3, 1fr); gap: 48px; text-align: center; }
.dirA .stats-strip .n { font-family: 'Cormorant Garamond', serif; font-size: clamp(48px, 5.5vw, 72px); color: var(--gold); line-height: 1; margin-bottom: 16px; font-weight: 300; }
.dirA .stats-strip .l { font-size: 11px; letter-spacing: 0.3em; text-transform: uppercase; color: var(--ink-2); }

/* About mobile (≤900px) */
@media (max-width: 900px) {
  .dirA .ab-hero { grid-template-columns: 1fr; min-height: auto; margin-top: 0; padding-top: 0; }
  .dirA .ab-hero-text { padding: 100px 24px 60px; max-width: none; }
  .dirA .ab-hero-img { min-height: 360px; }
  .dirA .ab-hero-img::after { background: linear-gradient(180deg, transparent 0%, rgba(11,9,7,0.55) 70%, var(--bg) 100%); }
  .dirA .story { padding: 100px 24px; }
  .dirA .story-grid { grid-template-columns: 1fr; gap: 40px; }
  .dirA .diff { padding: 100px 24px; }
  .dirA .diff-head-btn { grid-template-columns: 50px 1fr 24px; gap: 16px; padding: 26px 0; }
  .dirA .diff-num { font-size: 20px; }
  .dirA .diff-title { font-size: 20px; }
  .dirA .diff-body-inner { padding: 0 0 28px 66px; }
  .dirA .network { padding: 100px 24px; }
  .dirA .partner { grid-template-columns: 1fr; gap: 16px; padding: 40px 0; }
  .dirA .values { padding: 100px 24px; }
  .dirA .values-block, .dirA .values-block--right, .dirA .values-block--center { text-align: left; margin-left: 0; margin-right: 0; }
  .dirA .values-block--right .rule { margin-left: 0; }
  .dirA .values-block--center .rule { margin: 36px 0 0; }
  .dirA .stats-strip { padding: 56px 24px; }
  .dirA .stats-strip-grid { grid-template-columns: 1fr; gap: 36px; }
}

/* ═════════════════════════════════════════════════════════
   CASK OWNERSHIP PAGE
   ═════════════════════════════════════════════════════════ */

/* CO hero — centered, image fade behind */
.dirA .co-hero { position: relative; min-height: 78vh; display: flex; align-items: center; justify-content: center; overflow: hidden; margin-top: -82px; padding: 140px 56px 100px; text-align: center; }
.dirA .co-hero-bg { position: absolute; inset: 0; background: url(/images/invest-1.jpg) center/cover; opacity: 0.32; filter: brightness(0.65); }
.dirA .co-hero-bg::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, var(--bg) 0%, rgba(11,9,7,0.5) 30%, rgba(11,9,7,0.5) 70%, var(--bg) 100%); }
.dirA .co-hero-inner { position: relative; max-width: 880px; }
.dirA .co-hero-overline { display: flex; align-items: center; justify-content: center; gap: 16px; margin-bottom: 32px; font-size: 11px; letter-spacing: 0.32em; text-transform: uppercase; color: var(--gold); }
.dirA .co-hero-overline .line { width: 32px; height: 1px; background: var(--gold); opacity: 0.6; }
.dirA .co-hero h1 { font-size: clamp(48px, 7vw, 96px); line-height: 1; margin-bottom: 32px; }
.dirA .co-hero .lede { font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 22px; line-height: 1.6; color: var(--ink-2); max-width: 640px; margin: 0 auto; }

/* CO quote strip */
.dirA .co-quote { position: relative; padding: 80px 56px; overflow: hidden; }
.dirA .co-quote-bg { position: absolute; inset: 0; background: url(/images/barrel-glass.jpg) center/cover; opacity: 0.25; }
.dirA .co-quote-bg::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, var(--bg) 0%, rgba(11,9,7,0.5) 50%, var(--bg) 100%); }
.dirA .co-quote-inner { position: relative; max-width: 760px; margin: 0 auto; text-align: center; }
.dirA .co-quote-text { font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: clamp(22px, 2.6vw, 32px); line-height: 1.45; color: var(--ink); }
.dirA .co-quote-text em { color: var(--gold); }

/* CO journey — 4 alternating steps */
.dirA .co-journey { padding: 140px 56px 80px; }
.dirA .co-journey-head { text-align: center; max-width: 720px; margin: 0 auto 100px; }
.dirA .co-journey-head h2 { margin-top: 18px; font-style: italic; }
.dirA .co-journey-head .lede { font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 20px; color: var(--ink-2); margin-top: 24px; }
.dirA .co-step { max-width: 1240px; margin: 0 auto 120px; display: grid; grid-template-columns: 1fr 1fr; gap: 100px; align-items: center; }
.dirA .co-step:last-child { margin-bottom: 0; }
.dirA .co-step--reverse { direction: rtl; }
.dirA .co-step--reverse > * { direction: ltr; }
.dirA .co-step-img { aspect-ratio: 4/5; overflow: hidden; }
.dirA .co-step-img img { width: 100%; height: 100%; object-fit: cover; transition: transform 1.2s; filter: brightness(0.9); }
.dirA .co-step:hover .co-step-img img { transform: scale(1.04); }
.dirA .co-step-text .co-step-num { font-family: 'Cormorant Garamond', serif; font-size: clamp(64px, 8vw, 110px); font-style: italic; color: var(--gold); line-height: 0.9; opacity: 0.45; margin-bottom: 24px; }
.dirA .co-step-text .co-step-overline { font-size: 11px; letter-spacing: 0.32em; text-transform: uppercase; color: var(--gold); margin-bottom: 14px; }
.dirA .co-step-text h3 { font-size: clamp(36px, 4vw, 56px); line-height: 1.05; margin-bottom: 24px; font-style: italic; color: var(--ink); }
.dirA .co-step-text p { font-size: 16px; line-height: 1.85; color: var(--ink-2); font-weight: 300; margin-bottom: 18px; max-width: 520px; }
.dirA .co-step-text .co-step-detail { font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 16px; color: var(--gold-2); margin-top: 24px; padding-top: 20px; border-top: 1px solid var(--rule); max-width: 520px; }

/* CO included — 6 features */
.dirA .co-included { background: var(--bg-2); padding: 140px 56px; }
.dirA .co-included-wrap { max-width: 1200px; margin: 0 auto; }
.dirA .co-included-head { text-align: center; max-width: 640px; margin: 0 auto 80px; }
.dirA .co-included-head h2 { margin-top: 18px; font-style: italic; }
.dirA .co-features { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; border-top: 1px solid var(--rule); border-left: 1px solid var(--rule); }
.dirA .co-feature { padding: 44px 36px 48px; border-right: 1px solid var(--rule); border-bottom: 1px solid var(--rule); transition: background .3s; }
.dirA .co-feature:hover { background: rgba(184,148,90,0.04); }
.dirA .co-feature-num { font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 22px; color: var(--gold); margin-bottom: 18px; }
.dirA .co-feature h3 { font-family: 'Cormorant Garamond', serif; font-size: 22px; font-weight: 300; margin-bottom: 12px; color: var(--ink); line-height: 1.2; }
.dirA .co-feature p { font-size: 14px; line-height: 1.7; color: var(--ink-2); font-weight: 300; }

/* CO investment timeline (reuse .timeline-3 layout) */
.dirA .co-investment { padding: 140px 56px; position: relative; overflow: hidden; }
.dirA .co-investment-bg { position: absolute; inset: 0; background: url(/images/invest-3.jpg) center/cover; opacity: 0.16; }
.dirA .co-investment-bg::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, var(--bg) 0%, transparent 25%, transparent 75%, var(--bg) 100%); }
.dirA .co-investment-inner { position: relative; max-width: 1100px; margin: 0 auto; text-align: center; }
.dirA .co-investment h2 { font-style: italic; margin: 18px 0 24px; }
.dirA .co-investment .lede { font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 20px; color: var(--ink-2); max-width: 620px; margin: 0 auto 80px; }

/* CO finale */
.dirA .co-finale { padding: 140px 56px; text-align: center; position: relative; overflow: hidden; background: var(--bg); }
.dirA .co-finale-watermark { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); font-family: 'Cormorant Garamond', serif; font-size: clamp(120px, 18vw, 240px); font-weight: 300; color: rgba(184,148,90,0.04); white-space: nowrap; letter-spacing: 0.12em; pointer-events: none; user-select: none; }
.dirA .co-finale-inner { position: relative; max-width: 720px; margin: 0 auto; }
.dirA .co-finale-pre { font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 16px; color: var(--gold); margin-bottom: 28px; letter-spacing: 0.02em; }
.dirA .co-finale-quote { font-family: 'Cormorant Garamond', serif; font-size: clamp(40px, 5vw, 72px); font-weight: 300; line-height: 1.05; color: var(--ink); margin-bottom: 36px; font-style: normal; }
.dirA .co-finale-quote em { color: var(--gold); font-style: italic; }
.dirA .co-finale-sub { font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 17px; line-height: 1.65; color: var(--ink-2); margin-bottom: 48px; }
.dirA .co-finale-rule { display: flex; align-items: center; justify-content: center; gap: 16px; max-width: 320px; margin: 0 auto; }
.dirA .co-finale-rule .ln { flex: 1; height: 1px; background: rgba(184,148,90,0.3); }
.dirA .co-finale-rule .lbl { font-family: 'Cormorant Garamond', serif; font-size: 13px; letter-spacing: 0.4em; text-transform: uppercase; color: rgba(184,148,90,0.55); }

/* CO mobile (≤900px) */
@media (max-width: 900px) {
  .dirA .co-hero { padding: 110px 24px 80px; min-height: auto; margin-top: 0; }
  .dirA .co-quote { padding: 56px 24px; }
  .dirA .co-journey { padding: 100px 24px 40px; }
  .dirA .co-journey-head { margin-bottom: 64px; }
  .dirA .co-step { grid-template-columns: 1fr; gap: 32px; margin-bottom: 80px; direction: ltr !important; }
  .dirA .co-step--reverse > * { direction: ltr; }
  .dirA .co-step-text .co-step-num { font-size: 64px; }
  .dirA .co-step-text h3 { font-size: 32px; }
  .dirA .co-included { padding: 100px 24px; }
  .dirA .co-features { grid-template-columns: 1fr; border-left: 0; }
  .dirA .co-feature { border-right: 0; padding: 36px 0; }
  .dirA .co-investment { padding: 100px 24px; }
  .dirA .co-finale { padding: 100px 24px; }
}

/* ═════════════════════════════════════════════════════════
   STORAGE PAGE
   ═════════════════════════════════════════════════════════ */

/* Storage hero (centered atmospheric) */
.dirA .st-hero { position: relative; min-height: 78vh; display: flex; align-items: center; justify-content: center; overflow: hidden; margin-top: -82px; padding: 140px 56px 100px; text-align: center; }
.dirA .st-hero-bg { position: absolute; inset: 0; background: url(/images/warehouse-interior.jpg) center/cover; opacity: 0.38; filter: brightness(0.6); }
.dirA .st-hero-bg::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, var(--bg) 0%, rgba(11,9,7,0.5) 30%, rgba(11,9,7,0.5) 70%, var(--bg) 100%); }
.dirA .st-hero-inner { position: relative; max-width: 880px; }
.dirA .st-hero-overline { display: flex; align-items: center; justify-content: center; gap: 16px; margin-bottom: 32px; font-size: 11px; letter-spacing: 0.32em; text-transform: uppercase; color: var(--gold); }
.dirA .st-hero-overline .line { width: 32px; height: 1px; background: var(--gold); opacity: 0.6; }
.dirA .st-hero h1 { font-size: clamp(48px, 7vw, 96px); line-height: 1; margin-bottom: 32px; }
.dirA .st-hero .lede { font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 22px; line-height: 1.6; color: var(--ink-2); max-width: 640px; margin: 0 auto; }

/* Bonded warehouse explainer */
.dirA .st-bonded { background: var(--bg-2); padding: 140px 56px; }
.dirA .st-bonded-wrap { max-width: 1200px; margin: 0 auto; }
.dirA .st-bonded-head { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: end; margin-bottom: 80px; }
.dirA .st-bonded-head h2 { font-style: italic; }
.dirA .st-bonded-head .intro { font-size: 15px; line-height: 1.85; color: var(--ink-2); font-weight: 300; }
.dirA .st-bonded-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; border-top: 1px solid var(--rule); border-left: 1px solid var(--rule); }
.dirA .st-bonded-card { padding: 48px 40px 56px; border-right: 1px solid var(--rule); border-bottom: 1px solid var(--rule); transition: background .3s; }
.dirA .st-bonded-card:hover { background: rgba(184,148,90,0.04); }
.dirA .st-bonded-num { font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 28px; color: var(--gold); margin-bottom: 18px; line-height: 1; }
.dirA .st-bonded-card h3 { font-family: 'Cormorant Garamond', serif; font-size: 26px; font-weight: 300; margin-bottom: 16px; color: var(--ink); line-height: 1.2; }
.dirA .st-bonded-card p { font-size: 14px; line-height: 1.75; color: var(--ink-2); font-weight: 300; }

/* Facility split (image + prose) */
.dirA .st-facility { padding: 140px 56px; }
.dirA .st-facility-grid { max-width: 1240px; margin: 0 auto; display: grid; grid-template-columns: 1fr 1fr; gap: 100px; align-items: center; }
.dirA .st-facility-img { aspect-ratio: 4/5; overflow: hidden; }
.dirA .st-facility-img img { width: 100%; height: 100%; object-fit: cover; transition: transform 1.2s; filter: brightness(0.92); }
.dirA .st-facility:hover .st-facility-img img { transform: scale(1.04); }
.dirA .st-facility-text h2 { margin: 18px 0 32px; font-style: italic; }
.dirA .st-facility-text p { font-family: 'Cormorant Garamond', serif; font-size: 19px; line-height: 1.7; color: var(--ink-2); margin-bottom: 22px; font-weight: 300; }
.dirA .st-facility-text p:last-child { margin-bottom: 0; }

/* Pull quote (atmospheric strip) */
.dirA .st-pull { position: relative; padding: 100px 56px; overflow: hidden; }
.dirA .st-pull-bg { position: absolute; inset: 0; background: url(/images/storage-barrels.jpg) center/cover; opacity: 0.3; }
.dirA .st-pull-bg::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, var(--bg) 0%, rgba(11,9,7,0.55) 50%, var(--bg) 100%); }
.dirA .st-pull-inner { position: relative; max-width: 880px; margin: 0 auto; text-align: center; }
.dirA .st-pull-text { font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: clamp(24px, 3vw, 38px); line-height: 1.4; color: var(--ink); }
.dirA .st-pull-text em { color: var(--gold); font-style: italic; }

/* Maturation timeline (Y1/Y3/Y8/Y15+) */
.dirA .st-mat { padding: 140px 56px; background: var(--bg-2); }
.dirA .st-mat-wrap { max-width: 1100px; margin: 0 auto; }
.dirA .st-mat-head { text-align: center; max-width: 720px; margin: 0 auto 80px; }
.dirA .st-mat-head h2 { margin-top: 18px; font-style: italic; }
.dirA .st-mat-head .lede { font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 19px; color: var(--ink-2); margin-top: 24px; }
.dirA .st-mat-list { position: relative; padding-left: 0; }
.dirA .st-mat-row { display: grid; grid-template-columns: 200px 1fr; gap: 56px; padding: 48px 0; border-top: 1px solid var(--rule); }
.dirA .st-mat-row:last-child { border-bottom: 1px solid var(--rule); }
.dirA .st-mat-year { font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: clamp(38px, 4.5vw, 56px); color: var(--gold); line-height: 1; padding-top: 4px; }
.dirA .st-mat-content h3 { font-family: 'Cormorant Garamond', serif; font-size: 26px; font-weight: 300; color: var(--ink); margin-bottom: 14px; line-height: 1.25; }
.dirA .st-mat-content p { font-size: 15px; line-height: 1.85; color: var(--ink-2); font-weight: 300; max-width: 720px; }

/* Storage stat grid (4 cards) */
.dirA .st-grid { padding: 140px 56px; }
.dirA .st-grid-wrap { max-width: 1200px; margin: 0 auto; }
.dirA .st-grid-head { text-align: center; max-width: 720px; margin: 0 auto 72px; }
.dirA .st-grid-head h2 { margin-top: 18px; font-style: italic; }
.dirA .st-grid-cards { display: grid; grid-template-columns: repeat(3, 1fr); grid-template-rows: repeat(4, 220px); gap: 1px; background: rgba(184,148,90,0.18); }
.dirA .st-grid-card { background: #0f0c08; padding: 38px 34px; position: relative; overflow: hidden; display: flex; flex-direction: column; transition: background .35s ease; }
.dirA .st-grid-card:hover { background: #15110a; }
.dirA .st-grid-card .n { font-family: 'Cormorant Garamond', serif; font-size: clamp(32px, 3.4vw, 44px); color: var(--gold); line-height: 1; margin-bottom: 10px; font-weight: 300; }
.dirA .st-grid-card .lbl { font-size: 11px; letter-spacing: 0.28em; text-transform: uppercase; color: var(--ink); }
.dirA .st-grid-card .desc { font-size: 13px; line-height: 1.7; color: var(--ink-2); font-weight: 300; max-height: 0; overflow: hidden; opacity: 0; margin-top: 0; transition: max-height .45s ease, opacity .4s ease, margin-top .35s ease; }
.dirA .st-grid-card:hover .desc { max-height: 160px; opacity: 1; margin-top: 14px; }
.dirA .st-grid-card--feature { grid-column: 1 / 3; grid-row: 1 / 3; z-index: 1; }
.dirA .st-grid-card--feature::before { content: ""; position: absolute; inset: 0; background: url(/images/panama-nature.jpg) center/cover; z-index: 0; transition: transform 1.5s; }
.dirA .st-grid-card--feature:hover::before { transform: scale(1.04); }
.dirA .st-grid-card--feature::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(11,9,7,0.45) 0%, rgba(11,9,7,0.85) 100%); z-index: 1; }
.dirA .st-grid-card--feature > * { position: relative; z-index: 2; }
.dirA .st-grid-card--feature .n { font-size: clamp(56px, 6vw, 88px); color: var(--gold-2); }
.dirA .st-grid-card--feature .lbl { color: var(--ink); }
.dirA .st-grid-card--feature .desc { color: var(--ink); max-width: 360px; }
.dirA .st-grid-card--wide { grid-column: 2 / 4; grid-row: 4; }
.dirA .st-grid-card--wide .desc { max-width: 540px; }

/* Mobile (≤900px) */
@media (max-width: 900px) {
  .dirA .st-hero { padding: 110px 24px 80px; min-height: auto; margin-top: 0; }
  .dirA .st-bonded { padding: 100px 24px; }
  .dirA .st-bonded-head { grid-template-columns: 1fr; gap: 24px; margin-bottom: 56px; }
  .dirA .st-bonded-cards { grid-template-columns: 1fr; border-left: 0; }
  .dirA .st-bonded-card { border-right: 0; padding: 36px 0; }
  .dirA .st-facility { padding: 100px 24px; }
  .dirA .st-facility-grid { grid-template-columns: 1fr; gap: 36px; }
  .dirA .st-pull { padding: 72px 24px; }
  .dirA .st-mat { padding: 100px 24px; }
  .dirA .st-mat-row { grid-template-columns: 1fr; gap: 16px; padding: 36px 0; }
  .dirA .st-mat-year { font-size: 32px; }
  .dirA .st-grid { padding: 100px 24px; }
  .dirA .st-grid-cards { grid-template-columns: 1fr 1fr; grid-template-rows: auto; gap: 1px; }
  .dirA .st-grid-card { padding: 32px 24px; min-height: 200px; }
  .dirA .st-grid-card--feature { grid-column: 1 / 3 !important; grid-row: auto !important; min-height: 280px; }
  .dirA .st-grid-card--wide { grid-column: 1 / 3 !important; grid-row: auto !important; }
  .dirA .st-grid-card .desc { max-height: none; opacity: 1; margin-top: 12px; }
}

/* Subtle texture for maturation section to break flat dark band */
.dirA .st-mat { position: relative; overflow: hidden; }
.dirA .st-mat::before { content: ""; position: absolute; inset: 0; background: url(/images/panama-landscape.jpg) center/cover; opacity: 0.06; pointer-events: none; }
.dirA .st-mat::after { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 1px; background: linear-gradient(90deg, transparent, var(--gold), transparent); opacity: 0.4; }
.dirA .st-mat-wrap { position: relative; z-index: 1; }

/* ═════════════════════════════════════════════════════════
   MARKET PAGE
   ═════════════════════════════════════════════════════════ */

/* Hero */
.dirA .mk-hero { position: relative; min-height: 78vh; display: flex; align-items: center; justify-content: center; overflow: hidden; margin-top: -82px; padding: 140px 56px 100px; text-align: center; }
.dirA .mk-hero-bg { position: absolute; inset: 0; background: url(/images/rum-glasses.jpg) center/cover; opacity: 0.32; filter: brightness(0.6); }
.dirA .mk-hero-bg::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, var(--bg) 0%, rgba(11,9,7,0.5) 30%, rgba(11,9,7,0.55) 70%, var(--bg) 100%); }
.dirA .mk-hero-inner { position: relative; max-width: 920px; }
.dirA .mk-hero-overline { display: flex; align-items: center; justify-content: center; gap: 16px; margin-bottom: 32px; font-size: 11px; letter-spacing: 0.32em; text-transform: uppercase; color: var(--gold); }
.dirA .mk-hero-overline .line { width: 32px; height: 1px; background: var(--gold); opacity: 0.6; }
.dirA .mk-hero h1 { font-size: clamp(48px, 7vw, 96px); line-height: 1; margin-bottom: 32px; }
.dirA .mk-hero .lede { font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 22px; line-height: 1.6; color: var(--ink-2); max-width: 740px; margin: 0 auto; }

/* Key stats strip (3 big numbers) */
.dirA .mk-keystats { padding: 100px 56px; border-bottom: 1px solid var(--rule); }
.dirA .mk-keystats-grid { max-width: 1200px; margin: 0 auto; display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: rgba(184,148,90,0.18); }
.dirA .mk-keystat { background: var(--bg); padding: 56px 40px; text-align: center; }
.dirA .mk-keystat .n { font-family: 'Cormorant Garamond', serif; font-size: clamp(48px, 5.5vw, 76px); color: var(--gold); line-height: 1; margin-bottom: 18px; font-weight: 300; }
.dirA .mk-keystat .lbl { font-size: 11px; letter-spacing: 0.3em; text-transform: uppercase; color: var(--ink-2); max-width: 280px; margin: 0 auto; line-height: 1.6; }

/* Big chart section */
.dirA .mk-chart-section { padding: 140px 56px; background: var(--bg-2); }
.dirA .mk-chart-wrap { max-width: 1200px; margin: 0 auto; }
.dirA .mk-chart-head { text-align: center; max-width: 760px; margin: 0 auto 72px; }
.dirA .mk-chart-head h2 { font-style: italic; margin-top: 18px; }
.dirA .mk-chart-head .lede { font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 19px; color: var(--ink-2); margin-top: 22px; }
.dirA .mk-chart-frame { background: rgba(11,9,7,0.5); border: 1px solid var(--rule); padding: 56px 40px 36px; }
.dirA .mk-chart { display: flex; align-items: flex-end; gap: 10px; height: 360px; padding-bottom: 36px; border-bottom: 1px solid var(--rule); }
.dirA .mk-chart .bar-wrap { flex: 1; height: 100%; display: flex; flex-direction: column; justify-content: flex-end; gap: 8px; }
.dirA .mk-chart .bar-val { font-size: 11px; color: var(--ink); text-align: center; flex-shrink: 0; }
.dirA .mk-chart .bar { background: linear-gradient(180deg, var(--gold-2), var(--gold)); flex-shrink: 0; transform-origin: bottom; transform: scaleY(0); transition: transform 1.1s cubic-bezier(.2,.7,.3,1); }
.dirA .mk-chart .bar.in { transform: scaleY(1); }
.dirA .mk-chart .bar.future { background: linear-gradient(180deg, rgba(212,176,120,0.4), rgba(184,148,90,0.18)); border: 1px solid var(--rule); border-bottom: 0; }
.dirA .mk-chart .bar-yr { font-size: 10px; color: var(--ink-2); text-align: center; padding-top: 12px; flex-shrink: 0; letter-spacing: 0.05em; }
.dirA .mk-chart .bar-yr.proj::after { content: "*"; color: var(--gold); }
.dirA .mk-chart-foot { font-size: 11px; color: var(--ink-3); margin-top: 18px; letter-spacing: 0.04em; }
/* bar stagger */
.dirA .mk-chart .bar.b1  { transition-delay: .04s; } .dirA .mk-chart .bar.b2  { transition-delay: .08s; }
.dirA .mk-chart .bar.b3  { transition-delay: .12s; } .dirA .mk-chart .bar.b4  { transition-delay: .16s; }
.dirA .mk-chart .bar.b5  { transition-delay: .20s; } .dirA .mk-chart .bar.b6  { transition-delay: .24s; }
.dirA .mk-chart .bar.b7  { transition-delay: .28s; } .dirA .mk-chart .bar.b8  { transition-delay: .32s; }
.dirA .mk-chart .bar.b9  { transition-delay: .36s; } .dirA .mk-chart .bar.b10 { transition-delay: .40s; }
.dirA .mk-chart .bar.b11 { transition-delay: .44s; } .dirA .mk-chart .bar.b12 { transition-delay: .48s; }
.dirA .mk-chart .bar.b13 { transition-delay: .52s; }

/* Insights — "Why premium rum now" */
.dirA .mk-insights { padding: 140px 56px; }
.dirA .mk-insights-wrap { max-width: 1200px; margin: 0 auto; }
.dirA .mk-insights-head { max-width: 720px; margin-bottom: 80px; }
.dirA .mk-insights-head h2 { font-style: italic; margin-top: 18px; }
.dirA .mk-insights-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; border-top: 1px solid var(--rule); }
.dirA .mk-insight { padding: 56px 36px 64px; border-right: 1px solid var(--rule); }
.dirA .mk-insight:last-child { border-right: 0; }
.dirA .mk-insight .num { font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 28px; color: var(--gold); margin-bottom: 24px; line-height: 1; }
.dirA .mk-insight h3 { font-family: 'Cormorant Garamond', serif; font-size: 24px; font-weight: 300; color: var(--ink); margin-bottom: 20px; line-height: 1.25; font-style: italic; }
.dirA .mk-insight p { font-size: 14px; line-height: 1.85; color: var(--ink-2); font-weight: 300; }

/* Country cards */
.dirA .mk-countries { padding: 120px 56px; background: var(--bg-2); }
.dirA .mk-countries-wrap { max-width: 1200px; margin: 0 auto; }
.dirA .mk-countries-head { text-align: center; max-width: 720px; margin: 0 auto 64px; }
.dirA .mk-countries-head h2 { font-style: italic; margin-top: 18px; }
.dirA .mk-country-row { display: grid; grid-template-columns: repeat(5, 1fr); gap: 1px; background: rgba(184,148,90,0.18); border: 1px solid rgba(184,148,90,0.18); }
.dirA .mk-country { background: #0f0c08; padding: 40px 24px; text-align: center; transition: background .35s; }
.dirA .mk-country:hover { background: #15110a; }
.dirA .mk-country .name { font-family: 'Cormorant Garamond', serif; font-size: 22px; color: var(--ink); font-weight: 400; margin-bottom: 14px; line-height: 1.1; }
.dirA .mk-country .cagr { font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 32px; color: var(--gold); line-height: 1; font-weight: 300; }
.dirA .mk-country .lbl { font-size: 10px; letter-spacing: 0.3em; text-transform: uppercase; color: var(--ink-3); margin-top: 8px; }

/* Rarity split (image + text) — reuse story-grid feel */
.dirA .mk-rarity { padding: 140px 56px; }
.dirA .mk-rarity-grid { max-width: 1240px; margin: 0 auto; display: grid; grid-template-columns: 1fr 1fr; gap: 100px; align-items: center; }
.dirA .mk-rarity-img { aspect-ratio: 4/5; overflow: hidden; }
.dirA .mk-rarity-img img { width: 100%; height: 100%; object-fit: cover; transition: transform 1.2s; }
.dirA .mk-rarity:hover .mk-rarity-img img { transform: scale(1.04); }
.dirA .mk-rarity-text h2 { margin: 18px 0 32px; font-style: italic; }
.dirA .mk-rarity-text p { font-size: 16px; line-height: 1.85; color: var(--ink-2); margin-bottom: 22px; font-weight: 300; }
.dirA .mk-rarity-text p:last-child { margin-bottom: 0; }
.dirA .mk-rarity-text .pull { font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 22px; line-height: 1.5; color: var(--gold-2); margin-top: 32px; padding-top: 28px; border-top: 1px solid var(--rule); }

/* Panama atmospheric strip */
.dirA .mk-panama { position: relative; padding: 120px 56px; overflow: hidden; }
.dirA .mk-panama-bg { position: absolute; inset: 0; background: url(/images/panama-landscape.jpg) center/cover; opacity: 0.28; }
.dirA .mk-panama-bg::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, var(--bg) 0%, rgba(11,9,7,0.6) 50%, var(--bg) 100%); }
.dirA .mk-panama-inner { position: relative; max-width: 880px; margin: 0 auto; text-align: center; }
.dirA .mk-panama h2 { font-style: italic; margin: 18px 0 28px; }
.dirA .mk-panama p { font-size: 17px; line-height: 1.75; color: var(--ink); max-width: 720px; margin: 0 auto; font-family: 'Cormorant Garamond', serif; }

/* Mobile */
@media (max-width: 900px) {
  .dirA .mk-hero { padding: 110px 24px 80px; min-height: auto; margin-top: 0; }
  .dirA .mk-keystats { padding: 56px 24px; }
  .dirA .mk-keystats-grid { grid-template-columns: 1fr; }
  .dirA .mk-keystat { padding: 36px 24px; }
  .dirA .mk-chart-section { padding: 100px 24px; }
  .dirA .mk-chart-frame { padding: 32px 16px 24px; }
  .dirA .mk-chart { height: 240px; gap: 4px; }
  .dirA .mk-chart .bar-val { font-size: 9px; }
  .dirA .mk-chart .bar-yr { font-size: 9px; padding-top: 8px; }
  .dirA .mk-insights { padding: 100px 24px; }
  .dirA .mk-insights-grid { grid-template-columns: 1fr; }
  .dirA .mk-insight { border-right: 0; border-bottom: 1px solid var(--rule); padding: 40px 0; }
  .dirA .mk-insight:last-child { border-bottom: 0; }
  .dirA .mk-countries { padding: 100px 24px; }
  .dirA .mk-country-row { grid-template-columns: 1fr 1fr; }
  .dirA .mk-country { padding: 28px 16px; }
  .dirA .mk-country:last-child { grid-column: 1 / 3; }
  .dirA .mk-rarity { padding: 100px 24px; }
  .dirA .mk-rarity-grid { grid-template-columns: 1fr; gap: 36px; }
  .dirA .mk-panama { padding: 100px 24px; }
}

/* ═════════════════════════════════════════════════════════
   MOBILE / RESPONSIVE FIXES
   ═════════════════════════════════════════════════════════ */

/* Lock horizontal overflow site-wide. Use `clip` not `hidden` so position:sticky still works on the nav. */
html, body { overflow-x: clip; max-width: 100%; }
.dirA { overflow-x: clip; }

/* When mobile menu open, prevent body scroll */
html.menu-locked, html.menu-locked body { overflow: hidden; }

/* ── Mobile navbar — full overlay menu ── */
@media (max-width: 900px) {
  .dirA .nav {
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    padding: 14px 20px;
    gap: 0;
  }
  .dirA .nav.scrolled { padding: 12px 20px; }
  .dirA .nav-logo .wm { font-size: 14px; letter-spacing: 0.28em; }
  .dirA .nav-logo img { height: 28px; }

  /* Hamburger always visible on mobile */
  .dirA .nav-toggle {
    display: inline-flex;
    flex-direction: column;
    gap: 5px;
    background: none;
    border: 0;
    cursor: pointer;
    padding: 8px;
    margin-right: -8px;
  }
  .dirA .nav-toggle span {
    width: 22px;
    height: 1px;
    background: var(--ink);
    display: block;
    transition: transform .3s, opacity .3s;
  }
  .dirA .nav.menu-open .nav-toggle span:nth-child(1) { transform: translateY(6px) rotate(45deg); }
  .dirA .nav.menu-open .nav-toggle span:nth-child(2) { opacity: 0; }
  .dirA .nav.menu-open .nav-toggle span:nth-child(3) { transform: translateY(-6px) rotate(-45deg); }

  /* Hide both nav-link blocks by default; show stacked when menu-open */
  .dirA .nav-links { display: none !important; }
  .dirA .nav.menu-open {
    background: rgba(11,9,7,0.96) !important;
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    border-bottom: 1px solid var(--rule);
    padding-bottom: 32px;
  }
  .dirA .nav.menu-open .nav-links {
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start;
    gap: 0;
    width: 100%;
    padding: 16px 0 0 !important;
    font-size: 14px;
    letter-spacing: 0.2em;
  }
  .dirA .nav.menu-open .nav-links a {
    display: block;
    width: 100%;
    padding: 14px 0;
    font-size: 14px;
    border-bottom: 1px solid var(--rule);
  }
  .dirA .nav.menu-open .nav-links a::after { display: none; }

  /* Second .nav-links block (lang + pill) — flow continues below */
  .dirA .nav.menu-open .nav-links + .nav-links {
    flex-direction: row !important;
    flex-wrap: wrap;
    gap: 16px !important;
    padding-top: 24px !important;
    align-items: center;
    justify-content: space-between;
  }
  .dirA .nav.menu-open .lang { gap: 14px; flex-wrap: wrap; }
  .dirA .nav.menu-open .lang button { font-size: 13px; padding: 6px 8px; }
  .dirA .nav.menu-open .cta-pill {
    flex: 1;
    text-align: center;
    padding: 16px 28px;
    margin-left: auto;
    min-width: 160px;
  }
}

/* ── Market chart on mobile — fit cleanly ── */
@media (max-width: 900px) {
  .dirA .mk-chart-section { padding: 80px 16px; }
  .dirA .mk-chart-frame { padding: 24px 12px 20px; }
  .dirA .mk-chart {
    height: 220px;
    gap: 3px;
    overflow: visible;
  }
  .dirA .mk-chart .bar-wrap { min-width: 0; }
  .dirA .mk-chart .bar-val { font-size: 8px; letter-spacing: -0.02em; }
  .dirA .mk-chart .bar-yr { font-size: 8px; letter-spacing: 0; padding-top: 6px; }
  /* Hide every other year label to avoid crush */
  .dirA .mk-chart .bar-wrap:nth-child(even) .bar-val { display: none; }
  .dirA .mk-chart .bar-wrap:nth-child(even) .bar-yr { visibility: hidden; }
}
@media (max-width: 560px) {
  /* Even tighter — show only every third year */
  .dirA .mk-chart .bar-wrap .bar-val { display: none; }
  .dirA .mk-chart .bar-wrap:nth-child(3n+1) .bar-val { display: block; }
  .dirA .mk-chart .bar-wrap .bar-yr { visibility: hidden; }
  .dirA .mk-chart .bar-wrap:nth-child(3n+1) .bar-yr { visibility: visible; }
}

/* Hero overflow safety */
@media (max-width: 900px) {
  .dirA .hero, .dirA .ab-hero, .dirA .co-hero, .dirA .st-hero, .dirA .mk-hero { overflow-x: hidden; }
  .dirA .hero h1, .dirA .ab-hero-text h1, .dirA .co-hero h1, .dirA .st-hero h1, .dirA .mk-hero h1 { word-break: break-word; }
}

/* CTA contact on mobile — keep form readable, no overflow */
@media (max-width: 900px) {
  .dirA .cta { padding: 100px 24px; }
  .dirA .cta-inner { grid-template-columns: 1fr; gap: 56px; }
  .dirA form { grid-template-columns: 1fr; }
  .dirA form .full { grid-column: 1; }
  .dirA .field input, .dirA .field textarea { font-size: 14px; }
}

/* Cookie banner on mobile — narrower, visible */
@media (max-width: 600px) {
  .dirA .cookie-banner { left: 12px; right: 12px; bottom: 12px; padding: 18px 20px; }
  .dirA .cookie-banner__text { font-size: 12px; }
  .dirA .cookie-banner__btn { padding: 8px 16px; font-size: 10px; letter-spacing: 0.18em; }
}

/* ═════════════════════════════════════════════════════════
   BLOG LISTING
   ═════════════════════════════════════════════════════════ */

.dirA .bl-hero { position: relative; padding: 180px 56px 80px; overflow: hidden; text-align: center; margin-top: -82px; padding-top: 220px; }
.dirA .bl-hero-bg { position: absolute; inset: 0; background: url(/images/rum-glasses.jpg) center/cover; opacity: 0.18; }
.dirA .bl-hero-bg::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, var(--bg) 0%, rgba(11,9,7,0.6) 50%, var(--bg) 100%); }
.dirA .bl-hero-inner { position: relative; max-width: 760px; margin: 0 auto; }
.dirA .bl-hero h1 { font-size: clamp(56px, 7vw, 100px); margin-bottom: 28px; }
.dirA .bl-hero .lede { font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 20px; line-height: 1.6; color: var(--ink-2); }

.dirA .bl-list { padding: 100px 56px 140px; max-width: 1200px; margin: 0 auto; }
.dirA .bl-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 56px 48px; }
.dirA .bl-card { display: block; background: var(--bg-2); border: 1px solid var(--rule); padding: 40px 40px 44px; transition: background .35s, border-color .35s, transform .4s; position: relative; }
.dirA .bl-card:hover { background: rgba(184,148,90,0.06); border-color: rgba(184,148,90,0.5); transform: translateY(-4px); }
.dirA .bl-card-meta { display: flex; gap: 14px; align-items: center; font-size: 11px; letter-spacing: 0.28em; text-transform: uppercase; color: var(--gold); margin-bottom: 22px; }
.dirA .bl-card-meta .dot { width: 3px; height: 3px; background: var(--gold); border-radius: 50%; opacity: 0.6; }
.dirA .bl-card-title { font-family: 'Cormorant Garamond', serif; font-size: clamp(28px, 3vw, 38px); font-weight: 300; line-height: 1.1; color: var(--ink); margin-bottom: 16px; }
.dirA .bl-card-subtitle { font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 19px; line-height: 1.4; color: var(--gold-2); margin-bottom: 20px; }
.dirA .bl-card-excerpt { font-size: 14px; line-height: 1.75; color: var(--ink-2); font-weight: 300; margin-bottom: 28px; }
.dirA .bl-card-cta { font-size: 11px; letter-spacing: 0.28em; text-transform: uppercase; color: var(--gold); display: inline-flex; gap: 10px; align-items: center; transition: gap .25s, color .25s; }
.dirA .bl-card-cta::after { content: "\2192"; transition: transform .25s; }
.dirA .bl-card:hover .bl-card-cta { color: var(--ink); gap: 14px; }

@media (max-width: 900px) {
  .dirA .bl-hero { padding: 160px 24px 60px; padding-top: 180px; }
  .dirA .bl-list { padding: 80px 24px 100px; }
  .dirA .bl-grid { grid-template-columns: 1fr; gap: 32px; }
  .dirA .bl-card { padding: 32px 28px 36px; }
}

/* ═════════════════════════════════════════════════════════
   BLOG ARTICLE (individual post)
   ═════════════════════════════════════════════════════════ */
.dirA .ba-shell { padding: 140px 56px 100px; max-width: 760px; margin: 0 auto; }
.dirA .ba-back { font-size: 11px; letter-spacing: 0.28em; text-transform: uppercase; color: var(--gold); margin-bottom: 56px; display: inline-block; }
.dirA .ba-back:hover { color: var(--ink); }
.dirA .ba-meta { display: flex; gap: 14px; align-items: center; font-size: 11px; letter-spacing: 0.28em; text-transform: uppercase; color: var(--gold); margin-bottom: 22px; }
.dirA .ba-meta .dot { width: 3px; height: 3px; background: var(--gold); border-radius: 50%; opacity: 0.6; }
.dirA .ba-title { font-family: 'Cormorant Garamond', serif; font-size: clamp(40px, 5vw, 64px); line-height: 1.05; font-weight: 300; color: var(--ink); margin-bottom: 18px; }
.dirA .ba-subtitle { font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 22px; line-height: 1.45; color: var(--gold-2); margin-bottom: 56px; padding-bottom: 56px; border-bottom: 1px solid var(--rule); }
.dirA .ba-content { font-size: 17px; line-height: 1.85; color: var(--ink); font-weight: 300; }
.dirA .ba-content p { margin-bottom: 24px; }
.dirA .ba-content h2 { font-family: 'Cormorant Garamond', serif; font-size: 32px; font-weight: 300; color: var(--ink); margin: 56px 0 20px; line-height: 1.2; font-style: italic; }
.dirA .ba-content h2 em { color: var(--gold); }
.dirA .ba-content h3 { font-family: 'Cormorant Garamond', serif; font-size: 22px; font-weight: 400; color: var(--ink); margin: 36px 0 16px; }
.dirA .ba-content blockquote { border-left: 1px solid var(--gold); padding: 0 0 0 28px; margin: 36px 0; font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 22px; line-height: 1.55; color: var(--gold-2); }
.dirA .ba-content a { color: var(--gold); border-bottom: 1px solid rgba(184,148,90,0.4); }
.dirA .ba-content a:hover { color: var(--gold-2); border-color: var(--gold-2); }

@media (max-width: 900px) {
  .dirA .ba-shell { padding: 110px 24px 80px; }
  .dirA .ba-content { font-size: 16px; }
  .dirA .ba-content h2 { font-size: 26px; margin: 40px 0 16px; }
}

/* ═════════════════════════════════════════════════════════
   MOBILE RHYTHM — break up text-heavy About + CO pages
   ═════════════════════════════════════════════════════════ */

@media (max-width: 900px) {

  /* ── ABOUT ── */
  .dirA .ab-hero-text h1 { font-size: clamp(36px, 9vw, 56px); }
  .dirA .ab-hero-text .lede { font-size: 18px; }

  /* Story split — image becomes a wide banner above text */
  .dirA .story { padding: 80px 24px; }
  .dirA .story-img { aspect-ratio: 16/10; }
  .dirA .story-text h2 { font-size: clamp(32px, 7vw, 44px); }
  .dirA .story-text p { font-size: 15px; line-height: 1.75; }

  /* Difference accordion — tighter, more lively */
  .dirA .diff { padding: 80px 24px; }
  .dirA .diff-head { margin-bottom: 48px; }
  .dirA .diff-head h2 { font-size: clamp(30px, 6.5vw, 42px); }

  /* Partners — gold left accent rule, image-feel even on mobile */
  .dirA .network { padding: 80px 24px; }
  .dirA .network-head { margin-bottom: 48px; }
  .dirA .network-head h2 { font-size: clamp(30px, 6.5vw, 42px); }
  .dirA .partner {
    padding: 36px 0 36px 20px;
    border-left: 2px solid var(--gold);
    border-top: 0;
    margin-bottom: 16px;
    background: linear-gradient(90deg, rgba(184,148,90,0.06) 0%, transparent 60%);
  }
  .dirA .partner:last-child { border-bottom: 0; }
  .dirA .partner-name { font-size: 26px; }
  .dirA .partner-link { margin-top: 8px; }

  /* Values — compress, tighten */
  .dirA .values { padding: 80px 24px; }
  .dirA .values-head { margin-bottom: 56px; }
  .dirA .values-head h2 { font-size: clamp(30px, 6.5vw, 42px); }
  .dirA .values-block { margin-bottom: 56px; }
  .dirA .values-block h3 { font-size: 22px; line-height: 1.3; }
  .dirA .values-block p { font-size: 15px; line-height: 1.75; }
  .dirA .values-block .rule { margin-top: 28px; }

  /* Stats strip on mobile keep tight */
  .dirA .stats-strip { padding: 48px 24px; }

  /* ── CASK OWNERSHIP ── */
  .dirA .co-hero h1 { font-size: clamp(36px, 9vw, 56px); }
  .dirA .co-hero .lede { font-size: 18px; }

  /* Journey — wider, less tall image; tighter step number */
  .dirA .co-journey { padding: 80px 24px 24px; }
  .dirA .co-journey-head { margin-bottom: 56px; }
  .dirA .co-journey-head h2 { font-size: clamp(30px, 6.5vw, 42px); }
  .dirA .co-step { gap: 24px; margin-bottom: 56px; }
  .dirA .co-step-img { aspect-ratio: 16/10; max-height: 280px; }
  .dirA .co-step-text {
    padding-left: 18px;
    border-left: 2px solid var(--gold);
    background: linear-gradient(90deg, rgba(184,148,90,0.06) 0%, transparent 60%);
    padding-top: 8px;
    padding-bottom: 8px;
  }
  .dirA .co-step-text .co-step-num { font-size: 48px; opacity: 0.55; margin-bottom: 12px; }
  .dirA .co-step-text h3 { font-size: 28px; margin-bottom: 14px; }
  .dirA .co-step-text p { font-size: 15px; line-height: 1.75; max-width: 100%; }
  .dirA .co-step-text .co-step-detail { font-size: 14px; padding-top: 14px; margin-top: 16px; }

  /* What's included — accent on cards */
  .dirA .co-included { padding: 80px 24px; }
  .dirA .co-included-head { margin-bottom: 48px; }
  .dirA .co-included-head h2 { font-size: clamp(30px, 6.5vw, 42px); }
  .dirA .co-features { border-left: 0; }
  .dirA .co-feature {
    padding: 28px 0 28px 18px;
    border-right: 0;
    border-bottom: 1px solid var(--rule);
    border-left: 2px solid rgba(184,148,90,0.4);
    margin-bottom: 0;
  }
  .dirA .co-feature:last-child { border-bottom: 0; }
  .dirA .co-feature h3 { font-size: 18px; }

  /* Investment timeline — keep airy */
  .dirA .co-investment { padding: 80px 24px; }
  .dirA .co-investment h2 { font-size: clamp(30px, 6.5vw, 42px); }

  /* Finale — slightly smaller */
  .dirA .co-finale { padding: 80px 24px; }
  .dirA .co-finale-quote { font-size: clamp(34px, 8vw, 52px); }
  .dirA .co-finale-watermark { font-size: clamp(80px, 20vw, 140px); }
}

@media (max-width: 560px) {
  .dirA .co-step-img { aspect-ratio: 16/9; max-height: 220px; }
  .dirA .story-img { aspect-ratio: 16/9; }
  .dirA .co-step-text .co-step-num { font-size: 40px; }
  .dirA .partner-name { font-size: 22px; }
  .dirA .values-block h3 { font-size: 20px; }
}

/* ═════════════════════════════════════════════════════════
   MOBILE RHYTHM (round 2) — Home / Storage / Market / Blog
   ═════════════════════════════════════════════════════════ */

@media (max-width: 900px) {

  /* ── HOME ── */
  .dirA .hero h1 { font-size: clamp(56px, 14vw, 84px); }
  .dirA .hero p.lede { font-size: 18px; }
  .dirA .intro { padding: 80px 24px 64px; }
  .dirA .intro-grid { gap: 32px; }
  .dirA .intro p { font-size: 15px; line-height: 1.75; }
  .dirA .intro h2 { font-size: clamp(32px, 7vw, 44px); }
  .dirA .pillars { padding: 80px 0 80px; }
  .dirA .pillars-head { margin-bottom: 40px; }
  .dirA .pillars-head h2 { font-size: clamp(32px, 7vw, 44px); }
  .dirA .pillars-grid { gap: 0; }
  .dirA .pillar { padding: 32px 24px; }
  .dirA .pillar h3 { font-size: 22px; }
  .dirA .pillar p { font-size: 14px; line-height: 1.7; }

  /* Panama timeline on home — gold left rule, tighter */
  .dirA .panama { padding: 90px 24px; }
  .dirA .panama h2 { font-size: clamp(32px, 7vw, 48px); }
  .dirA .panama .lede { font-size: 18px; margin-bottom: 48px; }
  .dirA .timeline { border-top: 0; }
  .dirA .tl {
    padding: 24px 0 24px 18px;
    border-right: 0;
    border-bottom: 0;
    border-left: 2px solid var(--gold);
    background: linear-gradient(90deg, rgba(184,148,90,0.06) 0%, transparent 60%);
    margin-bottom: 14px;
  }
  .dirA .tl h3 { font-size: 20px; }
  .dirA .tl p { font-size: 14px; }

  /* Market section on home */
  .dirA .market { padding: 80px 24px; }
  .dirA .market h2 { font-size: clamp(32px, 7vw, 44px); }
  .dirA .chart { height: 220px; }

  /* CTA / contact on all pages */
  .dirA .cta { padding: 80px 24px; }
  .dirA .cta h2 { font-size: clamp(32px, 7vw, 44px); }
  .dirA .cta p.copy { font-size: 15px; }

  /* ── STORAGE ── */
  .dirA .st-hero h1 { font-size: clamp(36px, 9vw, 56px); }
  .dirA .st-hero .lede { font-size: 18px; }

  .dirA .st-bonded { padding: 80px 24px; }
  .dirA .st-bonded-head h2 { font-size: clamp(30px, 6.5vw, 44px); }
  .dirA .st-bonded-head .intro { font-size: 15px; line-height: 1.75; }
  /* Bonded cards — gold left accent */
  .dirA .st-bonded-cards { border-top: 0; border-left: 0; gap: 0; }
  .dirA .st-bonded-card {
    padding: 28px 0 28px 18px;
    border-right: 0;
    border-bottom: 1px solid var(--rule);
    border-left: 2px solid var(--gold);
    margin-bottom: 0;
    background: linear-gradient(90deg, rgba(184,148,90,0.06) 0%, transparent 60%);
  }
  .dirA .st-bonded-card:last-child { border-bottom: 0; }
  .dirA .st-bonded-card h3 { font-size: 22px; }
  .dirA .st-bonded-card p { font-size: 14px; }

  .dirA .st-facility { padding: 80px 24px; }
  .dirA .st-facility-img { aspect-ratio: 16/10; }
  .dirA .st-facility-text h2 { font-size: clamp(30px, 6.5vw, 42px); }
  .dirA .st-facility-text p { font-size: 17px; line-height: 1.65; }

  .dirA .st-pull { padding: 56px 24px; }

  /* Maturation timeline — vertical with gold dot/rule, more visual */
  .dirA .st-mat { padding: 80px 24px; }
  .dirA .st-mat-head h2 { font-size: clamp(30px, 6.5vw, 42px); }
  .dirA .st-mat-head .lede { font-size: 17px; }
  .dirA .st-mat-list { padding-left: 0; }
  .dirA .st-mat-row {
    grid-template-columns: 1fr;
    gap: 12px;
    padding: 28px 0 28px 20px;
    border-top: 0;
    border-bottom: 0;
    border-left: 2px solid var(--gold);
    margin-bottom: 0;
    background: linear-gradient(90deg, rgba(184,148,90,0.06) 0%, transparent 60%);
  }
  .dirA .st-mat-row:last-child { border-bottom: 0; }
  .dirA .st-mat-year { font-size: 36px; padding-top: 0; }
  .dirA .st-mat-content h3 { font-size: 20px; }
  .dirA .st-mat-content p { font-size: 14px; line-height: 1.75; }

  .dirA .st-grid { padding: 80px 24px; }
  .dirA .st-grid-head h2 { font-size: clamp(30px, 6.5vw, 42px); }

  /* ── MARKET ── */
  .dirA .mk-hero h1 { font-size: clamp(36px, 9vw, 56px); }
  .dirA .mk-hero .lede { font-size: 17px; }

  .dirA .mk-keystats { padding: 56px 16px; }
  .dirA .mk-keystat { padding: 32px 24px; }
  .dirA .mk-keystat .n { font-size: clamp(40px, 9vw, 60px); }

  .dirA .mk-chart-section { padding: 72px 16px; }
  .dirA .mk-chart-head h2 { font-size: clamp(28px, 6.5vw, 40px); }
  .dirA .mk-chart-head .lede { font-size: 15px; }

  /* Insight cards — gold left accent on mobile */
  .dirA .mk-insights { padding: 80px 24px; }
  .dirA .mk-insights-head h2 { font-size: clamp(30px, 6.5vw, 42px); }
  .dirA .mk-insights-grid { border-top: 0; gap: 0; }
  .dirA .mk-insight {
    padding: 28px 0 32px 18px;
    border-right: 0;
    border-bottom: 1px solid var(--rule);
    border-left: 2px solid var(--gold);
    margin-bottom: 0;
    background: linear-gradient(90deg, rgba(184,148,90,0.06) 0%, transparent 60%);
  }
  .dirA .mk-insight:last-child { border-bottom: 0; }
  .dirA .mk-insight h3 { font-size: 20px; }
  .dirA .mk-insight p { font-size: 14px; }

  .dirA .mk-countries { padding: 80px 24px; }
  .dirA .mk-countries-head h2 { font-size: clamp(30px, 6.5vw, 42px); }

  .dirA .mk-rarity { padding: 80px 24px; }
  .dirA .mk-rarity-img { aspect-ratio: 16/10; }
  .dirA .mk-rarity-text h2 { font-size: clamp(30px, 6.5vw, 42px); }
  .dirA .mk-rarity-text p { font-size: 15px; line-height: 1.75; }
  .dirA .mk-rarity-text .pull { font-size: 18px; }

  .dirA .mk-panama { padding: 80px 24px; }
  .dirA .mk-panama h2 { font-size: clamp(30px, 6.5vw, 42px); }
  .dirA .mk-panama p { font-size: 16px; }

  /* ── BLOG ── */
  .dirA .bl-hero h1 { font-size: clamp(44px, 11vw, 72px); }
  .dirA .bl-hero .lede { font-size: 17px; }
  .dirA .bl-card { padding: 28px 24px 32px; border-left: 2px solid var(--gold); background: linear-gradient(90deg, rgba(184,148,90,0.06) 0%, transparent 50%), var(--bg-2); }
  .dirA .bl-card-title { font-size: clamp(24px, 5.5vw, 30px); }
  .dirA .bl-card-subtitle { font-size: 17px; }

  /* Blog article */
  .dirA .ba-shell { padding: 100px 24px 80px; }
  .dirA .ba-title { font-size: clamp(32px, 8vw, 48px); }
  .dirA .ba-subtitle { font-size: 18px; padding-bottom: 40px; margin-bottom: 40px; }
}

/* ═════════════════════════════════════════════════════════
   LEGAL PAGES (privacy / terms / cookies)
   ═════════════════════════════════════════════════════════ */

.dirA .legal-shell { padding: 160px 56px 100px; max-width: 760px; margin: 0 auto; }
.dirA .legal-eyebrow { font-size: 11px; letter-spacing: 0.32em; text-transform: uppercase; color: var(--gold); margin-bottom: 24px; }
.dirA .legal-title { font-family: 'Cormorant Garamond', serif; font-size: clamp(40px, 5vw, 64px); line-height: 1.05; font-weight: 300; color: var(--ink); margin-bottom: 16px; font-style: italic; }
.dirA .legal-title em { color: var(--gold); }
.dirA .legal-updated { font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 16px; color: var(--ink-2); margin-bottom: 56px; padding-bottom: 56px; border-bottom: 1px solid var(--rule); }
.dirA .legal-content { font-size: 15px; line-height: 1.85; color: var(--ink); font-weight: 300; }
.dirA .legal-content p { margin-bottom: 20px; color: var(--ink-2); }
.dirA .legal-content h2 { font-family: 'Cormorant Garamond', serif; font-size: 26px; font-weight: 300; color: var(--ink); margin: 48px 0 18px; line-height: 1.25; font-style: italic; }
.dirA .legal-content h2:first-child { margin-top: 0; }
.dirA .legal-content h3 { font-family: 'Cormorant Garamond', serif; font-size: 19px; font-weight: 400; color: var(--ink); margin: 32px 0 14px; }
.dirA .legal-content ul, .dirA .legal-content ol { margin: 0 0 20px 22px; padding: 0; }
.dirA .legal-content li { margin-bottom: 10px; color: var(--ink-2); line-height: 1.75; }
.dirA .legal-content a { color: var(--gold); border-bottom: 1px solid rgba(184,148,90,0.4); transition: color .25s, border-color .25s; }
.dirA .legal-content a:hover { color: var(--gold-2); border-color: var(--gold-2); }
.dirA .legal-content strong { color: var(--ink); font-weight: 400; }

@media (max-width: 900px) {
  .dirA .legal-shell { padding: 110px 24px 80px; }
  .dirA .legal-title { font-size: clamp(32px, 8vw, 48px); }
  .dirA .legal-updated { padding-bottom: 36px; margin-bottom: 36px; font-size: 15px; }
  .dirA .legal-content { font-size: 14px; }
  .dirA .legal-content h2 { font-size: 22px; margin: 36px 0 14px; }
}
.dirA .legal-content table { width: 100%; border-collapse: collapse; margin: 24px 0; font-size: 13px; }
.dirA .legal-content thead th { font-family: 'Inter', sans-serif; font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--gold); text-align: left; padding: 14px 12px; border-bottom: 1px solid var(--rule); font-weight: 500; }
.dirA .legal-content tbody td { padding: 14px 12px; border-bottom: 1px solid var(--rule); color: var(--ink-2); vertical-align: top; line-height: 1.5; }
.dirA .legal-content tbody tr:last-child td { border-bottom: 0; }
@media (max-width: 600px) { .dirA .legal-content table, .dirA .legal-content tbody, .dirA .legal-content tr, .dirA .legal-content td, .dirA .legal-content th { display: block; } .dirA .legal-content thead { display: none; } .dirA .legal-content tbody tr { padding: 16px 0; border-bottom: 1px solid var(--rule); } .dirA .legal-content tbody td { padding: 4px 0; border-bottom: 0; } }

/* ─── ROUND 3 FIXES ─── */

/* Darker hero overlay for readability */
.dirA .hero-bg::after { background: linear-gradient(180deg, rgba(11,9,7,0.7) 0%, rgba(11,9,7,0.5) 35%, rgba(11,9,7,0.85) 75%, var(--bg) 100%) !important; }
.dirA .hero-vig { background: radial-gradient(ellipse at 50% 60%, rgba(11,9,7,0.15) 35%, rgba(11,9,7,0.7) 100%) !important; }

/* Replace gold-tinted gap colour with neutral rule on airy grids
   (was distracting on reveals — now subtle cream-on-dark) */
.dirA .st-grid-cards,
.dirA .mk-keystats-grid,
.dirA .mk-country-row,
.dirA .st-bonded-cards { background: rgba(232,220,196,0.06) !important; }
.dirA .mk-country-row { border-color: rgba(232,220,196,0.06) !important; }

/* Hide scroll-cue line if some other page kept it */
.dirA .scroll-cue .ln { display: none; }

/* ── Mobile menu — full-screen overlay so it cannot disappear ── */
@media (max-width: 900px) {
  .dirA .nav.menu-open {
    position: fixed !important;
    inset: 0 !important;
    height: 100dvh;
    height: 100vh;
    overflow-y: auto;
    background: rgba(11,9,7,0.97) !important;
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    z-index: 1000;
    align-content: flex-start;
    padding: 16px 24px 32px;
    flex-wrap: wrap;
  }
  .dirA .nav.menu-open .nav-logo,
  .dirA .nav.menu-open .nav-toggle { z-index: 2; }
  .dirA .nav.menu-open .nav-links {
    margin-top: 8px;
    padding-top: 24px !important;
  }
  .dirA .nav.menu-open .nav-links a {
    font-size: 18px !important;
    padding: 18px 0 !important;
    letter-spacing: 0.18em;
  }
  .dirA .nav.menu-open .nav-links + .nav-links {
    flex-direction: column !important;
    align-items: stretch;
    gap: 18px !important;
    padding-top: 24px !important;
    border-top: 1px solid var(--rule);
    margin-top: 8px;
  }
  .dirA .nav.menu-open .lang { justify-content: center; gap: 24px; padding: 8px 0; }
  .dirA .nav.menu-open .lang button { font-size: 14px; padding: 10px 4px; }
  .dirA .nav.menu-open .cta-pill {
    width: 100%;
    text-align: center;
    margin: 8px 0 0 !important;
    padding: 18px 32px !important;
  }
}

/* ─── Mobile nav: fixed positioning (more reliable than sticky at page bottom) ─── */
@media (max-width: 900px) {
  .dirA .nav {
    position: fixed !important;
    top: 0;
    left: 0;
    right: 0;
    z-index: 100;
    background: rgba(11,9,7,0.85);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border-bottom: 1px solid var(--rule);
  }
  /* Push content down by nav height so it isn't hidden under the fixed nav.
     Each page's hero has margin-top: -82px to slide under the nav — that's now mobile-incorrect.
     Reset that on mobile so heroes start below the nav cleanly. */
  .dirA .hero,
  .dirA .ab-hero,
  .dirA .co-hero,
  .dirA .st-hero,
  .dirA .mk-hero,
  .dirA .bl-hero { margin-top: 0 !important; padding-top: max(110px, 24vw) !important; }
  /* Larger tap target for hamburger */
  .dirA .nav-toggle { padding: 12px; margin-right: -12px; min-width: 48px; min-height: 48px; }
}

/* ─── ROUND 4 FIXES ─── */

/* Even darker hero overlay — central area too, so gold title pops */
.dirA .hero-bg::after {
  background: linear-gradient(180deg, rgba(11,9,7,0.78) 0%, rgba(11,9,7,0.65) 35%, rgba(11,9,7,0.88) 75%, var(--bg) 100%) !important;
}
.dirA .hero-vig {
  background: radial-gradient(ellipse at 50% 55%, rgba(11,9,7,0.45) 0%, rgba(11,9,7,0.65) 60%, rgba(11,9,7,0.85) 100%) !important;
}
/* Add a subtle text shadow on the giant h1 for guaranteed legibility */
.dirA .hero h1 { text-shadow: 0 2px 24px rgba(0,0,0,0.6); }
.dirA .hero p.lede { text-shadow: 0 1px 12px rgba(0,0,0,0.6); }

/* Market chart — fit cleanly inside the frame */
.dirA .mk-chart-frame { padding: 64px 32px 28px; overflow: hidden; }
.dirA .mk-chart { padding-bottom: 32px; gap: 8px; min-width: 0; }
.dirA .mk-chart .bar-wrap { min-width: 0; overflow: visible; }
.dirA .mk-chart .bar-val { font-size: 10.5px; white-space: nowrap; padding: 0 2px; }
.dirA .mk-chart .bar-yr { font-size: 10px; padding-top: 10px; }
@media (min-width: 901px) {
  .dirA .mk-chart-frame { padding: 80px 40px 36px; }
  .dirA .mk-chart .bar-val { font-size: 11px; }
}

/* GPU layer for fixed nav on iOS to prevent jitter/disappear */
.dirA .nav { transform: translateZ(0); -webkit-transform: translateZ(0); will-change: transform; }
@media (max-width: 900px) {
  .dirA .nav { -webkit-backface-visibility: hidden; backface-visibility: hidden; }
}

/* Storage bonded — accordion variant */
.dirA .st-bonded-cards.is-accordion { display: block; background: none !important; border-top: 1px solid var(--rule); }
.dirA .st-bonded-cards.is-accordion .st-bonded-card {
  display: block;
  padding: 0;
  border-right: 0;
  border-bottom: 1px solid var(--rule);
  border-left: 0;
  background: none !important;
  margin: 0;
}
.dirA .bonded-acc-head {
  width: 100%;
  background: transparent;
  border: 0;
  padding: 28px 16px 28px 0;
  display: grid;
  grid-template-columns: 60px 1fr 32px;
  gap: 24px;
  align-items: center;
  cursor: pointer;
  text-align: left;
  font: inherit;
  color: inherit;
  transition: padding .35s ease;
}
.dirA .bonded-acc-head:hover .bonded-acc-title { color: var(--ink); }
.dirA .bonded-acc-head:hover .bonded-acc-icon::before,
.dirA .bonded-acc-head:hover .bonded-acc-icon::after { background: var(--gold-2); }
.dirA .bonded-acc-num { font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 24px; color: var(--gold); }
.dirA .bonded-acc-title { font-family: 'Cormorant Garamond', serif; font-size: 24px; font-weight: 300; color: rgba(232,220,196,0.78); transition: color .3s; line-height: 1.2; }
.dirA .bonded-acc-icon { position: relative; width: 18px; height: 18px; }
.dirA .bonded-acc-icon::before, .dirA .bonded-acc-icon::after { content: ""; position: absolute; left: 50%; top: 50%; background: var(--gold); transition: transform .5s cubic-bezier(.65,0,.35,1); }
.dirA .bonded-acc-icon::before { width: 14px; height: 1px; transform: translate(-50%, -50%); }
.dirA .bonded-acc-icon::after { width: 1px; height: 14px; transform: translate(-50%, -50%); }
.dirA .st-bonded-card.is-open .bonded-acc-icon::after { transform: translate(-50%, -50%) rotate(90deg); }
.dirA .bonded-acc-body { max-height: 0; overflow: hidden; opacity: 0; transition: max-height .65s cubic-bezier(.2,.8,.2,1), opacity .4s ease; }
.dirA .st-bonded-card.is-open .bonded-acc-body { max-height: 400px; opacity: 1; }
.dirA .bonded-acc-body-inner { padding: 0 0 32px 84px; max-width: 720px; }
.dirA .bonded-acc-body-inner p { font-size: 14px; line-height: 1.75; color: var(--ink-2); font-weight: 300; margin: 0; }
@media (max-width: 900px) {
  .dirA .bonded-acc-head { grid-template-columns: 40px 1fr 24px; gap: 14px; padding: 22px 0; }
  .dirA .bonded-acc-num { font-size: 18px; }
  .dirA .bonded-acc-title { font-size: 18px; }
  .dirA .bonded-acc-body-inner { padding: 0 0 26px 54px; }
}

/* Cask Ownership "What is included" — improved: gold accent + icon line */
.dirA .co-feature {
  position: relative;
  padding: 40px 32px 44px;
  transition: background .35s, transform .35s;
}
.dirA .co-feature::before {
  content: "";
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 0;
  background: var(--gold);
  transition: width .35s ease;
}
.dirA .co-feature:hover::before { width: 3px; }
.dirA .co-feature:hover { background: rgba(184,148,90,0.05); }
.dirA .co-feature-num {
  display: inline-flex; align-items: center; gap: 10px;
  margin-bottom: 16px;
}
.dirA .co-feature-num::after {
  content: "";
  flex: 0 0 32px;
  height: 1px;
  background: var(--gold);
  opacity: 0.5;
}
.dirA .co-feature h3 { font-size: 20px; }
@media (max-width: 900px) {
  .dirA .co-included { padding: 80px 24px; }
  .dirA .co-features {
    display: flex;
    flex-direction: column;
    gap: 0;
    border-left: 0;
    border-top: 0;
  }
  .dirA .co-feature {
    padding: 28px 0 28px 22px;
    border-right: 0;
    border-bottom: 1px solid var(--rule);
    border-left: 2px solid var(--gold);
    background: linear-gradient(90deg, rgba(184,148,90,0.07) 0%, transparent 60%);
  }
  .dirA .co-feature::before { display: none; }
  .dirA .co-feature:last-child { border-bottom: 0; }
  .dirA .co-feature-num { margin-bottom: 12px; font-size: 22px; }
  .dirA .co-feature-num::after { flex-basis: 24px; }
  .dirA .co-feature h3 { font-size: 19px; }
}

/* ─── CO "WHAT IS INCLUDED" — REDESIGN: image + curated list ─── */
.dirA .co-included.is-split { padding: 140px 56px; background: var(--bg-2); }
.dirA .co-incl-grid { max-width: 1280px; margin: 0 auto; display: grid; grid-template-columns: 5fr 6fr; gap: 90px; align-items: stretch; }
.dirA .co-incl-visual { position: relative; overflow: hidden; min-height: 580px; }
.dirA .co-incl-visual img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; filter: brightness(0.78); transition: transform 1.5s; }
.dirA .co-incl-visual:hover img { transform: scale(1.04); }
.dirA .co-incl-visual::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 0%, rgba(11,9,7,0.35) 100%); pointer-events: none; }
.dirA .co-incl-stamp { position: absolute; bottom: 28px; left: 28px; right: 28px; z-index: 2; display: flex; align-items: center; gap: 14px; font-size: 10px; letter-spacing: 0.32em; text-transform: uppercase; color: var(--ink); }
.dirA .co-incl-stamp .ln { flex: 1; height: 1px; background: rgba(232,220,196,0.4); }

.dirA .co-incl-content { display: flex; flex-direction: column; padding: 8px 0; }
.dirA .co-incl-head { margin-bottom: 56px; }
.dirA .co-incl-head h2 { font-style: italic; margin-top: 16px; }
.dirA .co-incl-list { display: flex; flex-direction: column; gap: 28px; }
.dirA .co-incl-item { display: grid; grid-template-columns: 36px 1fr; gap: 20px; align-items: start; padding-bottom: 24px; border-bottom: 1px solid var(--rule); }
.dirA .co-incl-item:last-child { border-bottom: 0; padding-bottom: 0; }
.dirA .co-incl-item-num { font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 22px; color: var(--gold); line-height: 1; padding-top: 6px; }
.dirA .co-incl-item h3 { font-family: 'Cormorant Garamond', serif; font-size: 22px; font-weight: 400; color: var(--ink); margin-bottom: 8px; line-height: 1.2; }
.dirA .co-incl-item p { font-size: 14px; line-height: 1.7; color: var(--ink-2); font-weight: 300; }

@media (max-width: 1100px) {
  .dirA .co-incl-grid { gap: 56px; }
  .dirA .co-incl-visual { min-height: 480px; }
}
@media (max-width: 900px) {
  .dirA .co-included.is-split { padding: 80px 24px; }
  .dirA .co-incl-grid { grid-template-columns: 1fr; gap: 32px; }
  .dirA .co-incl-visual { min-height: 0; aspect-ratio: 16/10; max-height: 320px; }
  .dirA .co-incl-head { margin-bottom: 40px; }
  .dirA .co-incl-head h2 { font-size: clamp(30px, 6.5vw, 42px); }
  .dirA .co-incl-list { gap: 20px; }
  .dirA .co-incl-item { grid-template-columns: 28px 1fr; gap: 14px; padding-bottom: 18px; }
  .dirA .co-incl-item-num { font-size: 18px; padding-top: 4px; }
  .dirA .co-incl-item h3 { font-size: 19px; }
  .dirA .co-incl-item p { font-size: 14px; }
}

/* ─── CO "What is included" — accordion variant ─── */
.dirA .co-included.is-acc { padding: 140px 56px; background: var(--bg-2); }
.dirA .co-incl-acc-wrap { max-width: 920px; margin: 0 auto; }
.dirA .co-incl-acc-head { text-align: center; max-width: 640px; margin: 0 auto 64px; }
.dirA .co-incl-acc-head h2 { font-style: italic; margin-top: 18px; }
.dirA .co-incl-acc-list { border-top: 1px solid var(--rule); }
.dirA .co-incl-acc-item { border-bottom: 1px solid var(--rule); }
.dirA .co-incl-acc-btn {
  width: 100%; background: transparent; border: 0;
  padding: 28px 4px; display: flex; align-items: center;
  justify-content: space-between; gap: 24px; cursor: pointer;
  text-align: left; font: inherit; color: inherit;
  transition: padding .35s ease;
}
.dirA .co-incl-acc-btn:hover .co-incl-acc-title { color: var(--ink); }
.dirA .co-incl-acc-btn:hover .co-incl-acc-icon::before,
.dirA .co-incl-acc-btn:hover .co-incl-acc-icon::after { background: var(--gold-2); }
.dirA .co-incl-acc-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: 24px; font-weight: 300;
  color: rgba(232,220,196,0.78);
  transition: color .3s; line-height: 1.2;
}
.dirA .co-incl-acc-icon { position: relative; width: 18px; height: 18px; flex-shrink: 0; }
.dirA .co-incl-acc-icon::before, .dirA .co-incl-acc-icon::after {
  content: ""; position: absolute; left: 50%; top: 50%;
  background: var(--gold);
  transition: transform .5s cubic-bezier(.65,0,.35,1);
}
.dirA .co-incl-acc-icon::before { width: 14px; height: 1px; transform: translate(-50%, -50%); }
.dirA .co-incl-acc-icon::after { width: 1px; height: 14px; transform: translate(-50%, -50%); }
.dirA .co-incl-acc-item.is-open .co-incl-acc-icon::after { transform: translate(-50%, -50%) rotate(90deg); }
.dirA .co-incl-acc-body { max-height: 0; overflow: hidden; opacity: 0; transition: max-height .55s cubic-bezier(.2,.8,.2,1), opacity .35s ease; }
.dirA .co-incl-acc-item.is-open .co-incl-acc-body { max-height: 300px; opacity: 1; }
.dirA .co-incl-acc-body-inner { padding: 0 0 28px 4px; max-width: 720px; }
.dirA .co-incl-acc-body-inner p { font-size: 15px; line-height: 1.75; color: var(--ink-2); font-weight: 300; margin: 0; }

@media (max-width: 900px) {
  .dirA .co-included.is-acc { padding: 80px 24px; }
  .dirA .co-incl-acc-head { margin-bottom: 40px; }
  .dirA .co-incl-acc-head h2 { font-size: clamp(30px, 6.5vw, 42px); }
  .dirA .co-incl-acc-btn { padding: 22px 0; }
  .dirA .co-incl-acc-title { font-size: 19px; }
  .dirA .co-incl-acc-body-inner { padding: 0 0 22px 0; }
  .dirA .co-incl-acc-body-inner p { font-size: 14px; }
}

/* ─── CO Investment timeline — centered vertical milestone variant ─── */
.dirA .co-investment .timeline.is-milestones {
  display: flex;
  flex-direction: column;
  gap: 0;
  border-top: 0;
  text-align: center;
  max-width: 720px;
  margin: 0 auto;
  position: relative;
  padding: 24px 0;
}
.dirA .co-investment .timeline.is-milestones::before { display: none; }
.dirA .co-investment .timeline.is-milestones .tl {
  padding: 40px 16px;
  border-right: 0;
  position: relative;
  text-align: center;
}
.dirA .co-investment .timeline.is-milestones .tl .yr {
  justify-content: center;
  position: relative;
  z-index: 2;
}
.dirA .co-investment .timeline.is-milestones .tl .yr::before {
  display: none;
  content: "";
  position: absolute;
  left: 50%; top: 50%;
  width: 18px; height: 18px;
  border-radius: 50%;
  background: var(--bg);
  border: 1px solid var(--gold);
  transform: translate(-50%, -50%);
  z-index: -1;
}
.dirA .co-investment .timeline.is-milestones .tl .dot { display: none; }
.dirA .co-investment .timeline.is-milestones .tl h3 { margin-top: 12px; max-width: 440px; margin-left: auto; margin-right: auto; }
.dirA .co-investment .timeline.is-milestones .tl p { max-width: 460px; margin: 0 auto; }

@media (max-width: 900px) {
  .dirA .co-investment .timeline.is-milestones { padding: 16px 0; }
  .dirA .co-investment .timeline.is-milestones .tl { padding: 28px 8px; }
}

/* ─── ROUND 5: pill bigger + lang buttons bigger on desktop ─── */
.dirA .cta-pill { padding: 26px 60px !important; font-size: 14px !important; }
@media (min-width: 901px) {
  .dirA .lang button { font-size: 13px; letter-spacing: 0.22em; padding: 4px 6px; }
  .dirA .lang { gap: 14px; }
}

/* ─── ROUND 6: pill smaller + smoother grid reveals ─── */

/* Pill — smaller (was 26x60 / 14px) */
.dirA .cta-pill { padding: 18px 42px !important; font-size: 13px !important; }

/* Tone down the cream-tint gap so cards don't look like lighter panels behind gaps */
.dirA .st-grid-cards,
.dirA .mk-keystats-grid,
.dirA .mk-country-row,
.dirA .st-bonded-cards { background: rgba(232,220,196,0.025) !important; }
.dirA .mk-country-row { border-color: rgba(232,220,196,0.025) !important; }

/* Make cards match section bg perfectly so gap is just a hairline, not a panel */
.dirA .st-grid-card { background: var(--bg-2); }
.dirA .st-grid-card:hover { background: rgba(184,148,90,0.035); }
.dirA .mk-keystat { background: var(--bg-2); }
.dirA .mk-country { background: var(--bg-2); }
.dirA .mk-country:hover { background: rgba(184,148,90,0.035); }

/* Smoother, longer reveal on cards inside these grids — no staggered pop, fade in together */
.dirA .st-grid-card.reveal,
.dirA .mk-keystat.reveal,
.dirA .mk-country.reveal {
  transition: opacity 1.4s cubic-bezier(.2,.7,.3,1), transform 1.4s cubic-bezier(.2,.7,.3,1) !important;
  transition-delay: 0s !important;
}
