/* ============================================================
   WHISKEY TIDE PARTNERS — DESIGN SYSTEM
   Editorial. Dark navy anchors. Warm parchment content.
   ============================================================ */

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

/* ── Variables ─────────────────────────────────────────── */
:root {
  /* Parchment — content sections */
  --bg-primary:     #F6F1E9;
  --bg-secondary:   #EDE7DA;
  --bg-card:        #FFFFFF;
  --bg-card-hover:  #FAF7F2;

  /* Deep navy — heroes, CTA sections, footer */
  --bg-dark:        #112030;

  /* Text */
  --text-primary:   #1C1712;
  --text-secondary: #6B6054;
  --text-muted:     #A09080;
  --text-on-dark:   #EDE7DA;

  /* Copper accent — single consistent value */
  --accent:         #B07535;
  --accent-light:   #B07535;
  --accent-dim:     rgba(176,117,53,0.08);

  /* Borders */
  --border-subtle:  rgba(90,68,48,0.14);
  --border-accent:  rgba(176,117,53,0.32);
  --border-dark:    rgba(237,231,218,0.10);

  --font-display: 'Cormorant Garamond', Georgia, serif;
  --font-body:    'Inter', system-ui, sans-serif;

  --nav-height:   80px;
  --max-width:    1200px;
  --pad-x:        48px;
  --section-y:    104px;
}

/* ── Reset ──────────────────────────────────────────────── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; font-size:16px; }
body {
  background-color: var(--bg-primary);
  color: var(--text-primary);
  font-family: var(--font-body);
  font-weight: 300;
  line-height: 1.7;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
img { display:block; max-width:100%; }
a  { color: inherit; }

/* ── Dark section utility ───────────────────────────────── */
.section--dark {
  background-color: var(--bg-dark);
  color: var(--text-on-dark);
}
.section--dark .section-title  { color: var(--text-on-dark); }
.section--dark .section-body   { color: rgba(237,231,218,0.65); }
.section--dark .eyebrow        { color: var(--accent-light); }
.section--dark .divider        { background: linear-gradient(90deg, transparent, var(--border-dark), transparent); }

/* Dark section: contact form overrides */
.section--dark .form-label     { color: rgba(237,231,218,0.50); }
.section--dark .form-note      { color: rgba(237,231,218,0.40); }
.section--dark .contact-detail         { border-bottom-color: var(--border-dark); }
.section--dark .contact-detail__label  { color: var(--accent-light); }
.section--dark .contact-detail__value  { color: rgba(237,231,218,0.72); }
.section--dark .contact-detail__value a { color: var(--text-on-dark); }
.section--dark .contact-detail__value a:hover { color: var(--accent-light); }

/* Dark section: services split */
.section--dark .services-split {
  background: transparent;
}
.section--dark .services-split__item {
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--border-dark);
}
.section--dark .services-split__item:hover { background: rgba(255,255,255,0.07); }
.section--dark .services-split__title { color: var(--text-on-dark); }
.section--dark .services-split__body  { color: rgba(237,231,218,0.60); }

/* Dark section: subscribe strip */
.section--dark .subscribe-strip {
  background: rgba(255,255,255,0.04);
  border-color: var(--border-dark);
}
.section--dark .subscribe-strip__title { color: var(--text-on-dark); }
.section--dark .subscribe-strip__body  { color: rgba(237,231,218,0.60); }
.section--dark .subscribe-input {
  background: rgba(255,255,255,0.06);
  border-color: rgba(237,231,218,0.18);
  color: var(--text-on-dark);
}
.section--dark .subscribe-input::placeholder { color: rgba(237,231,218,0.35); }
.section--dark .subscribe-input:focus { border-color: var(--accent-light); }

/* Dark section: barrel table */
.section--dark .barrels-table-wrap { border-color: var(--border-dark); }
.section--dark .barrels-table thead tr { background: rgba(255,255,255,0.06); }
.section--dark .barrels-table thead th { color: rgba(237,231,218,0.55); border-right-color: rgba(255,255,255,0.06); }
.section--dark .barrels-table tbody tr { background: rgba(255,255,255,0.03); border-bottom-color: var(--border-dark); }
.section--dark .barrels-table tbody tr:nth-child(even) { background: rgba(255,255,255,0.05); }
.section--dark .barrels-table tbody tr:hover { background: rgba(255,255,255,0.09); }
.section--dark .barrels-table tbody td { color: var(--text-on-dark); border-right-color: var(--border-dark); }
.section--dark .barrels-table .col-ref   { color: rgba(237,231,218,0.40); }
.section--dark .barrels-table .col-type  { color: var(--text-on-dark); }
.section--dark .barrels-table .col-age,
.section--dark .barrels-table .col-proof,
.section--dark .barrels-table .col-vol   { color: rgba(237,231,218,0.60); }
.section--dark .barrels-table .col-price { color: var(--text-on-dark); }
.section--dark .barrels-note    { color: rgba(237,231,218,0.40); }
.section--dark .barrels-disclaimer { color: rgba(237,231,218,0.35); }
.section--dark .barrels-header .section-title { margin-bottom: 0; }

/* ── Typography helpers ─────────────────────────────────── */
.eyebrow {
  font-family: var(--font-body);
  font-size: 0.68rem;
  font-weight: 500;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--accent);
  display: block;
}

.section-title {
  font-family: var(--font-display);
  font-size: clamp(2.4rem, 5vw, 3.8rem);
  font-weight: 300;
  line-height: 1.08;
  letter-spacing: -0.02em;
  color: var(--text-primary);
  margin-top: 14px;
  margin-bottom: 22px;
}
.section-title em { font-style:italic; color: var(--accent); }

.section-body {
  font-size: 1.05rem;
  font-weight: 300;
  color: var(--text-secondary);
  line-height: 1.82;
  max-width: 580px;
}

/* ── Layout ─────────────────────────────────────────────── */
.container {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 var(--pad-x);
}
.section { padding: var(--section-y) 0; }

.divider {
  height: 1px;
  background: linear-gradient(90deg,
    transparent 0%,
    var(--border-subtle) 25%,
    var(--border-subtle) 75%,
    transparent 100%);
}

/* ── Navigation ─────────────────────────────────────────── */
.nav {
  position: fixed; top:0; left:0; right:0; z-index:1000;
  height: var(--nav-height);
  display: flex; align-items: center;
  transition: background 0.35s ease, border-bottom 0.35s ease;
  --nav-text:        rgba(237,231,218,0.82);
  --nav-text-hover:  #EDE7DA;
  --nav-cta-color:   rgba(237,231,218,0.82);
  --nav-cta-border:  rgba(237,231,218,0.28);
  --nav-hamburger:   #EDE7DA;
}
.nav.scrolled {
  background: rgba(17,32,48,0.97);
  border-bottom: 1px solid var(--border-dark);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  --nav-text:        rgba(237,231,218,0.72);
  --nav-text-hover:  #EDE7DA;
  --nav-cta-color:   var(--accent-light);
  --nav-cta-border:  rgba(192,96,40,0.40);
  --nav-hamburger:   #EDE7DA;
}
.nav__inner {
  display: flex; align-items: center; justify-content: space-between;
  width:100%; max-width: var(--max-width);
  margin:0 auto; padding: 0 var(--pad-x);
}

/* ── Logo (image-based) ──────────────────────────────────── */
.nav__logo {
  display: flex; align-items: center;
  text-decoration: none; flex-shrink:0;
}
.nav__logo-img {
  height: 52px; width: auto;
  display: block;
  transition: opacity 0.3s ease;
}
/* Light logo shows by default (nav is over dark hero) */
/* On scroll — nav becomes dark navy, keep light logo */
/* No switching needed — light logo works on both transparent and navy nav */

.nav__links {
  display:flex; align-items:center; gap:36px; list-style:none;
}
.nav__link {
  font-size: 0.72rem; font-weight:400;
  letter-spacing:0.12em; text-transform:uppercase;
  color: var(--nav-text); text-decoration:none;
  transition: color 0.2s ease;
}
.nav__link:hover, .nav__link.active { color: var(--nav-text-hover); }

.nav__cta {
  font-size: 0.72rem; font-weight:400;
  letter-spacing:0.12em; text-transform:uppercase;
  color: var(--nav-cta-color); text-decoration:none;
  border: 1px solid var(--nav-cta-border);
  padding: 10px 22px;
  transition: all 0.22s ease;
}
.nav__cta:hover { background: var(--accent); color: #EDE7DA; border-color: var(--accent); }

.nav__hamburger {
  display:none; flex-direction:column; gap:5px;
  background:none; border:none; cursor:pointer; padding:4px;
}
.nav__hamburger span {
  display:block; width:22px; height:1px;
  background: var(--nav-hamburger); transition: all 0.28s ease;
}
.nav__hamburger.open span:nth-child(1) { transform:rotate(45deg) translate(4px,5px); }
.nav__hamburger.open span:nth-child(2) { opacity:0; }
.nav__hamburger.open span:nth-child(3) { transform:rotate(-45deg) translate(4px,-5px); }

.nav__mobile {
  display:none; position:fixed;
  top: var(--nav-height); left:0; right:0;
  background: rgba(17,32,48,0.98);
  border-top: 1px solid var(--border-dark);
  padding: 40px var(--pad-x); z-index:999;
  backdrop-filter: blur(14px);
}
.nav__mobile.open { display:block; }
.nav__mobile-links { list-style:none; display:flex; flex-direction:column; gap:26px; }
.nav__mobile-link {
  font-size: 0.82rem; font-weight:400;
  letter-spacing:0.16em; text-transform:uppercase;
  color: rgba(237,231,218,0.72); text-decoration:none;
  transition: color 0.2s ease;
}
.nav__mobile-link:hover { color: #EDE7DA; }

/* ── Hero (Home) ─────────────────────────────────────────── */
.hero {
  position:relative; min-height:100vh;
  display:flex; align-items:center; overflow:hidden;
  background-color: var(--bg-dark);
}
.hero__img {
  position:absolute; inset:0;
  width:100%; height:100%; object-fit:cover;
  opacity:0.20;
}
.hero__bg {
  position:absolute; inset:0;
  background:
    radial-gradient(ellipse at 70% 50%, rgba(160,98,42,0.08) 0%, transparent 60%);
}
.hero__grain {
  position:absolute; inset:0; pointer-events:none; opacity:0.025;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='400' height='400'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='400' height='400' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size: 180px;
}
.hero__line {
  position:absolute; bottom:0; left:0; right:0; height:1px;
  background: linear-gradient(90deg, transparent, var(--accent), transparent);
  opacity:0.30;
}
.hero__content {
  position:relative; max-width: var(--max-width);
  margin:0 auto; padding: 0 var(--pad-x);
  padding-top: var(--nav-height);
}
.hero__eyebrow { margin-bottom: 28px; display:flex; align-items:center; gap:16px; }
.hero__eyebrow::after {
  content:''; display:block; height:1px; width:56px; background: var(--accent-light);
}
.hero__eyebrow .eyebrow { color: var(--accent-light); }
.hero__headline {
  font-family: var(--font-display);
  font-size: clamp(4.2rem, 9.5vw, 8.5rem);
  font-weight: 300; line-height: 0.98;
  letter-spacing: -0.025em; color: var(--text-on-dark);
  margin-bottom: 34px; max-width: 11ch;
}
.hero__headline em { font-style:italic; color: var(--accent-light); }
.hero__body {
  font-size: 1.1rem; font-weight:300;
  color: rgba(237,231,218,0.72); max-width: 460px;
  line-height: 1.82; margin-bottom: 50px;
}
.hero__scroll {
  position:absolute; bottom:44px; right: var(--pad-x);
  display:flex; flex-direction:column; align-items:center; gap:12px;
}
.hero__scroll-text {
  font-size:0.6rem; letter-spacing:0.22em;
  text-transform:uppercase; color: rgba(237,231,218,0.38);
  writing-mode:vertical-rl;
}
.hero__scroll-line {
  width:1px; height:56px;
  background: linear-gradient(180deg, var(--accent), transparent);
  animation: scrollPulse 2.2s ease-in-out infinite;
}
@keyframes scrollPulse {
  0%,100% { opacity:0.28; transform:scaleY(1); }
  50%      { opacity:0.65;  transform:scaleY(0.65); }
}

/* ── Page Hero (inner pages) ─────────────────────────────── */
.page-hero {
  position:relative;
  padding: calc(var(--nav-height) + 96px) 0 88px;
  overflow:hidden;
  background-color: var(--bg-dark);
}
.page-hero__img {
  position:absolute; inset:0;
  width:100%; height:100%; object-fit:cover;
  opacity:0.16;
}
.page-hero__bg {
  position:absolute; inset:0;
  background:
    radial-gradient(ellipse at 65% 40%, rgba(160,98,42,0.08) 0%, transparent 60%);
}
.page-hero__content {
  position:relative; max-width: var(--max-width);
  margin:0 auto; padding: 0 var(--pad-x);
}
.page-hero__content .eyebrow { color: var(--accent-light); }
.page-hero__headline {
  font-family: var(--font-display);
  font-size: clamp(3rem, 7vw, 6rem);
  font-weight: 300; line-height:1.02;
  letter-spacing:-0.022em; color: var(--text-on-dark);
  margin: 14px 0 26px; max-width: 14ch;
}
.page-hero__headline em { font-style:italic; color: var(--accent-light); }
.page-hero__body {
  font-size:1.05rem; font-weight:300;
  color: rgba(237,231,218,0.68); max-width:520px; line-height:1.82;
}

/* ── Buttons ─────────────────────────────────────────────── */
.btn {
  display:inline-flex; align-items:center; gap:11px;
  text-decoration:none; font-family: var(--font-body);
  font-size:0.72rem; font-weight:400;
  letter-spacing:0.16em; text-transform:uppercase;
  transition: all 0.22s ease; cursor:pointer;
}
.btn--outline {
  color: var(--text-primary);
  border: 1px solid rgba(90,68,48,0.30);
  padding: 14px 30px;
  background: transparent;
}
.btn--outline:hover {
  border-color: var(--text-primary);
  background: rgba(90,68,48,0.06);
}
/* Outline button on dark hero/navy background */
.hero__content .btn--outline,
.section--dark .btn--outline {
  color: var(--text-on-dark);
  border-color: rgba(237,231,218,0.32);
}
.hero__content .btn--outline:hover,
.section--dark .btn--outline:hover {
  border-color: var(--text-on-dark);
  background: rgba(237,231,218,0.06);
}
.btn--accent {
  color: #F5F0E8;
  background: var(--accent); border:none;
  padding: 15px 32px;
}
.btn--accent:hover { background: var(--accent-light); }
.btn--ghost {
  color: var(--accent); padding:4px 0;
  border-bottom: 1px solid transparent;
  background: none; border-top:none; border-left:none; border-right:none;
}
.btn--ghost:hover { border-bottom-color: var(--accent); }
.section--dark .btn--ghost { color: var(--accent-light); }
.section--dark .btn--ghost:hover { border-bottom-color: var(--accent-light); }
.btn .arrow { transition: transform 0.2s ease; display:inline-block; }
.btn:hover .arrow { transform: translateX(4px); }

/* ── Section header ──────────────────────────────────────── */
.section-header { margin-bottom: 56px; }
.section-header--center { text-align:center; }
.section-header--center .section-body { margin:0 auto; }
.section-header--flex {
  display:flex; align-items:flex-end;
  justify-content:space-between; gap:24px;
}

/* ── Who We Serve ────────────────────────────────────────── */
.serve-grid {
  display:grid; grid-template-columns:repeat(3,1fr);
}
.serve-card {
  background: var(--bg-card); padding:52px 40px;
  border-right: 1px solid var(--border-subtle);
  transition: background 0.3s ease;
}
.serve-card:last-child { border-right: none; }
.serve-card:hover { background: var(--bg-card-hover); }
.serve-card__number {
  font-family: var(--font-display);
  font-size: 5rem; font-weight:300; line-height:1;
  color: rgba(90,68,48,0.10); margin-bottom:24px;
  transition: color 0.3s ease;
}
.serve-card:hover .serve-card__number { color: rgba(160,98,42,0.14); }
.serve-card__label {
  font-size:0.68rem; font-weight:500; letter-spacing:0.2em;
  text-transform:uppercase; color: var(--accent);
  margin-bottom:14px; display:block;
}
.serve-card__title {
  font-family: var(--font-display); font-size:1.7rem; font-weight:400;
  color: var(--text-primary); margin-bottom:14px; line-height:1.2;
}
.serve-card__body {
  font-size:0.92rem; font-weight:300;
  color: var(--text-secondary); line-height:1.78;
}

/* ── Services Split ──────────────────────────────────────── */
.services-split {
  display:grid; grid-template-columns:1fr 1fr;
  gap:1px; background: var(--border-subtle);
}
.services-split__item {
  background: var(--bg-secondary); padding:48px 52px;
  text-decoration:none; color:inherit;
  transition: background 0.3s ease;
  display:block; position:relative; overflow:hidden;
}
.services-split__item:hover { background: var(--bg-card-hover); }
.services-split__arrow {
  position:absolute; bottom:48px; right:52px;
  font-size:1.4rem; color: var(--accent);
  opacity:0; transform:translateX(-12px);
  transition: all 0.3s ease;
}
.services-split__item:hover .services-split__arrow { opacity:1; transform:translateX(0); }
.services-split__title {
  font-family: var(--font-display); font-size:1.9rem; font-weight:400;
  color: var(--text-primary); margin:14px 0 16px; line-height:1.15;
}
.services-split__body {
  font-size:0.93rem; font-weight:300;
  color: var(--text-secondary); line-height:1.78; max-width:380px;
}

/* ── Cards Grid ──────────────────────────────────────────── */
.cards-grid {
  display:grid; grid-template-columns:repeat(3,1fr); gap:20px;
}
.card {
  background: var(--bg-card); border:1px solid var(--border-subtle);
  padding:36px; transition: border-color 0.28s, background 0.28s, box-shadow 0.28s;
  text-decoration:none; color:inherit; display:block;
}
.card:hover {
  border-color: var(--border-accent);
  background: var(--bg-card-hover);
  box-shadow: 0 4px 24px rgba(90,68,48,0.08);
}
.card__meta {
  display:flex; align-items:center; gap:12px; margin-bottom:18px;
}
.card__tag {
  font-size:0.62rem; font-weight:500; letter-spacing:0.18em;
  text-transform:uppercase; color: var(--accent);
  border:1px solid var(--border-accent); padding:4px 9px;
}
.card__date {
  font-size:0.68rem; font-weight:300; color: var(--text-muted);
}
.card__title {
  font-family: var(--font-display); font-size:1.38rem; font-weight:400;
  color: var(--text-primary); line-height:1.3; margin-bottom:12px;
}
.card__excerpt {
  font-size:0.88rem; font-weight:300;
  color: var(--text-secondary); line-height:1.72; margin-bottom:24px;
}
.card__readmore {
  font-size:0.68rem; font-weight:400;
  letter-spacing:0.15em; text-transform:uppercase; color: var(--accent);
  transition: gap 0.2s ease; display:inline-flex; align-items:center; gap:8px;
}

/* ── Contact Form ────────────────────────────────────────── */
.contact-section { padding: var(--section-y) 0; }
.contact-inner {
  display:grid; grid-template-columns:1fr 1fr;
  gap:80px; align-items:start;
}
.contact-form { display:flex; flex-direction:column; gap:18px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.form-group { display:flex; flex-direction:column; gap:8px; }
.form-label {
  font-size:0.65rem; font-weight:400; letter-spacing:0.18em;
  text-transform:uppercase; color: var(--text-muted);
}
.form-input, .form-select, .form-textarea {
  background: var(--bg-card); border:1px solid var(--border-subtle);
  color: var(--text-primary); font-family: var(--font-body);
  font-size:0.9rem; font-weight:300; padding:13px 15px;
  outline:none; transition: border-color 0.2s;
  border-radius:0; -webkit-appearance:none; appearance:none;
}
.form-input:focus, .form-select:focus, .form-textarea:focus {
  border-color: var(--border-accent);
}
.form-input::placeholder, .form-textarea::placeholder { color: var(--text-muted); }
.form-select {
  cursor:pointer;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='7' viewBox='0 0 11 7'%3E%3Cpath d='M1 1l4.5 4.5L10 1' stroke='%23A09080' stroke-width='1.4' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 14px center;
}
.form-select option { background: var(--bg-card); color: var(--text-primary); }
.form-textarea { resize:vertical; min-height:110px; }
.form-submit {
  background: var(--accent); color: #F5F0E8;
  border:none; cursor:pointer; width:100%;
  font-family: var(--font-body); font-size:0.72rem;
  font-weight:500; letter-spacing:0.16em; text-transform:uppercase;
  padding:16px; transition: background 0.22s;
}
.form-submit:hover { background: var(--accent-light); }
.form-note {
  font-size:0.72rem; color: var(--text-muted); text-align:center;
}

/* ── Liquid Types ────────────────────────────────────────── */
.liquid-grid {
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:1px; background: var(--border-subtle);
  border:1px solid var(--border-subtle);
}
.liquid-item {
  background: var(--bg-primary); padding:40px;
  transition: background 0.28s;
}
.liquid-item:hover { background: var(--bg-card); }
.liquid-item__name {
  font-family: var(--font-display); font-size:1.55rem; font-weight:400;
  color: var(--text-primary); margin-bottom:10px;
}
.liquid-item__desc {
  font-size:0.85rem; font-weight:300;
  color: var(--text-secondary); line-height:1.72;
}

/* ── Process Steps ───────────────────────────────────────── */
.steps {
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:1px; background: var(--border-subtle);
}
.step { background: var(--bg-primary); padding:52px 44px; }
.step__num {
  font-family: var(--font-display); font-size:3.8rem; font-weight:300;
  color: var(--accent); opacity:0.32; line-height:1; margin-bottom:24px;
}
.step__title {
  font-family: var(--font-display); font-size:1.55rem; font-weight:400;
  color: var(--text-primary); margin-bottom:12px;
}
.step__body {
  font-size:0.9rem; font-weight:300;
  color: var(--text-secondary); line-height:1.78;
}

/* ── Advisory Service Areas ──────────────────────────────── */
.service-areas { display:flex; flex-direction:column; gap:1px; background: var(--border-subtle); }
.service-area {
  background: var(--bg-primary); padding:38px 52px;
  display:grid; grid-template-columns:220px 1fr; gap:40px;
  align-items:start; transition: background 0.28s;
}
.service-area:hover { background: var(--bg-card); }
.service-area__title {
  font-family: var(--font-display); font-size:1.3rem; font-weight:400;
  color: var(--text-primary); line-height:1.3;
}
.service-area__body {
  font-size:0.9rem; font-weight:300;
  color: var(--text-secondary); line-height:1.78;
}

/* ── Approach Block ──────────────────────────────────────── */
.approach-block {
  display:grid; grid-template-columns:1fr 1fr; gap:1px;
  background: var(--border-dark); border:1px solid var(--border-dark);
}
.approach-block__quote {
  background: rgba(255,255,255,0.04); padding:64px 56px;
}
.approach-block__quote blockquote {
  font-family: var(--font-display); font-size:clamp(1.6rem, 3vw, 2.2rem);
  font-weight:300; line-height:1.45; letter-spacing:-0.01em;
  color: var(--text-on-dark); font-style:italic;
}
.approach-block__points { background: rgba(255,255,255,0.02); padding:64px 56px; }
.approach-block__point {
  display:flex; gap:20px; align-items:flex-start;
  padding:20px 0; border-bottom:1px solid var(--border-dark);
}
.approach-block__point:first-child { padding-top:0; }
.approach-block__point:last-child { border-bottom:none; padding-bottom:0; }
.approach-point-label {
  font-size:0.65rem; font-weight:500; letter-spacing:0.18em;
  text-transform:uppercase; color: var(--accent-light);
  white-space:nowrap; padding-top:3px;
}
.approach-point-text {
  font-size:0.92rem; font-weight:300; color: rgba(237,231,218,0.65); line-height:1.72;
}

/* ── Market Intel ────────────────────────────────────────── */
.intel-featured {
  display:grid; grid-template-columns:1fr 1fr;
  gap:1px; background: var(--border-subtle);
  border:1px solid var(--border-subtle); margin-bottom:20px;
}
.intel-featured__content { background: var(--bg-card); padding:56px 52px; }
.intel-featured__side {
  background: var(--bg-secondary); padding:56px 52px;
  display:flex; flex-direction:column; justify-content:space-between;
}
.intel-featured__num {
  font-family: var(--font-display); font-size:7rem; font-weight:300;
  color: var(--border-subtle); line-height:1; margin-bottom:20px;
}
.intel-featured__title {
  font-family: var(--font-display); font-size:clamp(1.8rem,3vw,2.4rem);
  font-weight:400; color: var(--text-primary);
  line-height:1.18; margin:16px 0 20px;
}
.intel-featured__excerpt {
  font-size:1rem; font-weight:300; color: var(--text-secondary);
  line-height:1.8; margin-bottom:32px;
}

.intel-grid { display:grid; grid-template-columns:1fr 1fr; gap:20px; }

/* Industry articles */
.articles-section { margin-top: 72px; }
.articles-header { margin-bottom:32px; }
.articles-grid {
  display:grid; grid-template-columns:1fr 1fr;
  gap:1px; background: var(--border-subtle);
  border:1px solid var(--border-subtle);
}
.article-card {
  background: var(--bg-primary); padding:36px;
  display:flex; flex-direction:column; gap:10px;
  text-decoration:none; color:inherit;
  transition: background 0.28s;
}
.article-card:hover { background: var(--bg-card); }
.article-card__source {
  font-size:0.62rem; font-weight:500; letter-spacing:0.2em;
  text-transform:uppercase; color: var(--text-muted);
}
.article-card__title {
  font-family: var(--font-display); font-size:1.28rem; font-weight:400;
  color: var(--text-primary); line-height:1.32;
}
.article-card__excerpt {
  font-size:0.85rem; font-weight:300; color: var(--text-secondary);
  line-height:1.72; flex:1;
}
.article-card__footer {
  display:flex; align-items:center; justify-content:space-between;
  margin-top:8px;
}
.article-card__date { font-size:0.68rem; color: var(--text-muted); }
.article-card__link {
  font-size:0.65rem; letter-spacing:0.14em;
  text-transform:uppercase; color: var(--accent);
}

/* Subscribe strip */
.subscribe-strip {
  background: var(--bg-card); border:1px solid var(--border-subtle);
  padding:56px; display:grid; grid-template-columns:1fr 1fr;
  gap:60px; align-items:center; margin-top:20px;
}
.subscribe-strip__title {
  font-family: var(--font-display); font-size:2rem; font-weight:300;
  color: var(--text-primary); line-height:1.2; margin-top:12px; margin-bottom:10px;
}
.subscribe-strip__body {
  font-size:0.9rem; font-weight:300; color: var(--text-secondary); line-height:1.72;
}
.subscribe-form { display:flex; }
.subscribe-input {
  flex:1; background:transparent; border:1px solid var(--border-subtle); border-right:none;
  color: var(--text-primary); font-family: var(--font-body);
  font-size:0.9rem; font-weight:300; padding:14px 18px;
  outline:none; transition: border-color 0.2s;
}
.subscribe-input:focus { border-color: var(--border-accent); }
.subscribe-input::placeholder { color: var(--text-muted); }
.subscribe-btn {
  background: var(--accent); color: var(--bg-primary);
  border:1px solid var(--accent); font-family: var(--font-body);
  font-size:0.68rem; font-weight:500; letter-spacing:0.16em;
  text-transform:uppercase; padding:14px 26px; cursor:pointer;
  transition: background 0.22s; white-space:nowrap;
}
.subscribe-btn:hover { background: var(--accent-light); }

/* ── Footer ──────────────────────────────────────────────── */
.footer {
  background: var(--bg-dark);
  border-top:1px solid var(--border-dark);
  padding: 64px 0 40px;
}
.footer__inner { max-width: var(--max-width); margin:0 auto; padding: 0 var(--pad-x); }
.footer__top {
  display:grid; grid-template-columns:1.6fr 1fr 1fr; gap:60px;
  padding-bottom:48px; border-bottom:1px solid var(--border-dark); margin-bottom:32px;
}
.footer__logo { height:44px; width:auto; display:block; margin-bottom:14px; }
.footer__tagline { font-size:0.78rem; font-weight:300; color: rgba(237,231,218,0.42); margin-top:7px; letter-spacing:0.04em; }
.footer__col-title {
  font-size:0.62rem; font-weight:500; letter-spacing:0.22em;
  text-transform:uppercase; color: rgba(237,231,218,0.35); margin-bottom:20px;
}
.footer__links { list-style:none; display:flex; flex-direction:column; gap:12px; }
.footer__link {
  font-size:0.9rem; font-weight:300; color: rgba(237,231,218,0.55);
  text-decoration:none; transition: color 0.2s;
}
.footer__link:hover { color: var(--text-on-dark); }
.footer__bottom {
  display:flex; align-items:center; justify-content:space-between;
}
.footer__copy { font-size:0.72rem; font-weight:300; color: rgba(237,231,218,0.30); }
.footer__legal { display:flex; gap:22px; list-style:none; }
.footer__legal-link {
  font-size:0.72rem; font-weight:300; color: rgba(237,231,218,0.30);
  text-decoration:none; transition: color 0.2s;
}
.footer__legal-link:hover { color: rgba(237,231,218,0.55); }

/* ── Founder Block ───────────────────────────────────────── */
.founder-block {
  display:grid; grid-template-columns:1fr 1fr;
  gap:1px; background: var(--border-subtle);
  border:1px solid var(--border-subtle);
}
.founder-block__img {
  background: var(--bg-card);
  overflow:hidden; min-height:480px; position:relative;
}
.founder-block__img img {
  width:100%; height:100%; object-fit:cover;
  opacity:0.85; transition: opacity 0.4s ease, transform 0.6s ease;
  position:absolute; inset:0;
}
.founder-block:hover .founder-block__img img { opacity:0.95; transform:scale(1.02); }
.founder-block__content {
  background: var(--bg-secondary);
  padding:64px 56px;
  display:flex; flex-direction:column; justify-content:center;
}
.founder-block__role {
  font-size:0.68rem; font-weight:500; letter-spacing:0.2em;
  text-transform:uppercase; color: var(--accent); margin-top:6px; margin-bottom:20px; display:block;
}
.founder-block__name {
  font-family: var(--font-display); font-size:clamp(2rem,4vw,3rem);
  font-weight:400; color: var(--text-primary); line-height:1.1; margin-bottom:4px;
}
.founder-block__bio {
  font-size:0.95rem; font-weight:300; color: var(--text-secondary);
  line-height:1.82; margin-top:20px;
}

/* ── Service Detail Cards ────────────────────────────────── */
.service-detail-grid {
  display:grid; grid-template-columns:1fr 1fr; gap:20px;
}
.service-detail-card {
  background: var(--bg-card); border:1px solid var(--border-subtle);
  padding:40px; transition: border-color 0.28s, background 0.28s;
}
.service-detail-card:hover { border-color: var(--border-accent); background: var(--bg-card-hover); }
.service-detail-card__icon {
  width:44px; height:44px;
  border:1px solid var(--border-subtle); display:flex;
  align-items:center; justify-content:center; margin-bottom:24px;
  color: var(--accent);
}
.service-detail-card__title {
  font-family: var(--font-display); font-size:1.5rem; font-weight:400;
  color: var(--text-primary); margin-bottom:12px; line-height:1.2;
}
.service-detail-card__desc {
  font-size:0.9rem; font-weight:300; color: var(--text-secondary);
  line-height:1.78; margin-bottom:24px;
}
.service-detail-card__list {
  list-style:none; display:flex; flex-direction:column; gap:10px;
  padding-top:20px; border-top:1px solid var(--border-subtle);
}
.service-detail-card__list li {
  display:flex; align-items:flex-start; gap:10px;
  font-size:0.85rem; font-weight:300; color: var(--text-secondary); line-height:1.5;
}
.service-detail-card__list li::before {
  content:'→'; color: var(--accent); font-size:0.75rem; margin-top:1px; flex-shrink:0;
}

/* ── Process Steps (horizontal, numbered circles) ────────── */
.process-steps {
  display:grid; grid-template-columns:repeat(5,1fr); gap:20px; position:relative;
}
.process-steps::before {
  content:''; position:absolute;
  top:22px; left:10%; right:10%; height:1px;
  background: linear-gradient(90deg, transparent, var(--border-accent), transparent);
}
.process-step { text-align:center; position:relative; }
.process-step__num {
  display:inline-flex; align-items:center; justify-content:center;
  width:44px; height:44px; border-radius:50%;
  border:1px solid var(--border-accent);
  font-family: var(--font-body); font-size:0.72rem; font-weight:500;
  color: var(--accent); margin-bottom:16px; position:relative; z-index:1;
  background: var(--bg-primary);
}
.process-step__title {
  font-family: var(--font-display); font-size:1.1rem; font-weight:400;
  color: var(--text-primary); margin-bottom:8px;
}
.process-step__body {
  font-size:0.8rem; font-weight:300; color: var(--text-secondary); line-height:1.7;
}

/* ── Contact Info Details ────────────────────────────────── */
.contact-details { display:flex; flex-direction:column; gap:20px; margin-top:36px; }
.contact-detail {
  padding:18px 0; border-bottom:1px solid var(--border-subtle);
  display:flex; flex-direction:column; gap:5px;
}
.contact-detail:last-child { border-bottom:none; }
.contact-detail__label {
  font-size:0.62rem; font-weight:500; letter-spacing:0.2em;
  text-transform:uppercase; color: var(--accent);
}
.contact-detail__value {
  font-size:0.92rem; font-weight:300; color: var(--text-secondary);
}
.contact-detail__value a {
  color: var(--text-primary); text-decoration:none; transition: color 0.2s;
}
.contact-detail__value a:hover { color: var(--accent); }

/* ── Featured Barrels Table ──────────────────────────────── */
.barrels-header {
  display: flex; align-items: flex-end;
  justify-content: space-between; gap: 24px;
  margin-bottom: 36px;
}
.barrels-note {
  font-size: 0.78rem; font-weight: 300; color: var(--text-muted);
  font-style: italic; padding-bottom: 4px;
}
.barrels-table-wrap {
  overflow-x: auto;
  border: 1px solid var(--border-subtle);
}
.barrels-table {
  width: 100%; border-collapse: collapse;
  font-family: var(--font-body); font-size: 0.85rem;
}
.barrels-table thead tr { background: var(--bg-dark); }
.barrels-table thead th {
  font-size: 0.6rem; font-weight: 500;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: rgba(237,231,218,0.55);
  padding: 14px 18px; text-align: left;
  white-space: nowrap; border-right: 1px solid rgba(255,255,255,0.06);
}
.barrels-table thead th:last-child { border-right: none; }
.barrels-table tbody tr {
  background: var(--bg-card);
  border-bottom: 1px solid var(--border-subtle);
  transition: background 0.22s;
}
.barrels-table tbody tr:nth-child(even) { background: var(--bg-card-hover); }
.barrels-table tbody tr:hover { background: #F0EAE0; }
.barrels-table tbody td {
  padding: 16px 18px; color: var(--text-primary);
  border-right: 1px solid var(--border-subtle);
  white-space: nowrap; vertical-align: middle;
}
.barrels-table tbody td:last-child { border-right: none; }
.barrels-table .col-ref {
  font-size: 0.72rem; font-weight: 500; letter-spacing: 0.1em;
  color: var(--text-muted);
}
.barrels-table .col-type {
  font-family: var(--font-display); font-size: 1rem; font-weight: 400;
  color: var(--text-primary);
}
.barrels-table .col-age,
.barrels-table .col-proof,
.barrels-table .col-vol   { color: var(--text-secondary); font-weight: 300; }
.barrels-table .col-price {
  font-weight: 500; color: var(--text-primary);
  font-variant-numeric: tabular-nums;
}
.barrel-status {
  display: inline-block;
  font-size: 0.58rem; font-weight: 500; letter-spacing: 0.16em;
  text-transform: uppercase; padding: 4px 10px; white-space: nowrap;
}
.barrel-status--available {
  background: rgba(176,117,53,0.10); color: var(--accent);
  border: 1px solid var(--border-accent);
}
.barrel-status--loi {
  background: rgba(90,68,48,0.07); color: var(--text-secondary);
  border: 1px solid var(--border-subtle);
}
.barrel-status--pending {
  background: rgba(28,23,18,0.05); color: var(--text-muted);
  border: 1px solid var(--border-subtle);
}
.barrels-disclaimer {
  margin-top: 16px; font-size: 0.72rem;
  font-weight: 300; color: var(--text-muted);
  font-style: italic; line-height: 1.65;
}

/* ── Fade-in animation ───────────────────────────────────── */
.fade-in {
  opacity:0; transform:translateY(22px);
  transition: opacity 0.72s ease, transform 0.72s ease;
}
.fade-in.visible { opacity:1; transform:translateY(0); }
.fade-in:nth-child(2) { transition-delay:0.1s; }
.fade-in:nth-child(3) { transition-delay:0.18s; }

/* ── Utilities ───────────────────────────────────────────── */
.text-accent { color: var(--accent); }
.text-muted  { color: var(--text-muted); }
.mt-12  { margin-top:12px; }
.mt-20  { margin-top:20px; }
.mt-32  { margin-top:32px; }
.mt-48  { margin-top:48px; }
.mt-64  { margin-top:64px; }
.mb-12  { margin-bottom:12px; }
.mb-20  { margin-bottom:20px; }
.mb-32  { margin-bottom:32px; }
.mb-48  { margin-bottom:48px; }

/* ── Responsive ──────────────────────────────────────────── */
@media (max-width: 1024px) {
  :root { --section-y: 80px; --pad-x: 36px; }
  .serve-grid          { grid-template-columns:1fr 1fr; }
  .cards-grid          { grid-template-columns:1fr 1fr; }
  .services-split      { grid-template-columns:1fr; }
  .intel-featured      { grid-template-columns:1fr; }
  .intel-grid          { grid-template-columns:1fr; }
  .contact-inner       { grid-template-columns:1fr; gap:52px; }
  .approach-block      { grid-template-columns:1fr; }
  .subscribe-strip     { grid-template-columns:1fr; gap:36px; }
  .footer__top         { grid-template-columns:1fr 1fr; gap:40px; }
  .service-area        { grid-template-columns:1fr; gap:10px; }
  .liquid-grid         { grid-template-columns:1fr 1fr; }
  .steps               { grid-template-columns:1fr; }
  .founder-block       { grid-template-columns:1fr; }
  .founder-block__img  { min-height:320px; }
  .service-detail-grid { grid-template-columns:1fr; }
  .process-steps       { grid-template-columns:1fr 1fr; }
  .process-steps::before { display:none; }
}
@media (max-width: 768px) {
  :root { --section-y: 64px; --pad-x: 22px; }
  .nav__links, .nav__cta { display:none; }
  .nav__hamburger { display:flex; }
  .serve-grid, .cards-grid, .liquid-grid, .articles-grid { grid-template-columns:1fr; }
  .services-split__item { padding:48px var(--pad-x); }
  .intel-featured__content, .intel-featured__side { padding:44px 32px; }
  .approach-block__quote, .approach-block__points { padding:44px 32px; }
  .subscribe-strip { padding:44px var(--pad-x); }
  .subscribe-form { flex-direction:column; }
  .subscribe-input { border-right:1px solid var(--border-subtle); }
  .footer__top { grid-template-columns:1fr; gap:28px; }
  .footer__bottom { flex-direction:column; gap:14px; text-align:center; }
  .form-row { grid-template-columns:1fr; }
  .section-header--flex { flex-direction:column; align-items:flex-start; gap:16px; }
  .hero__scroll { display:none; }
  .page-hero { padding: calc(var(--nav-height) + 64px) 0 64px; }
  .founder-block__content { padding:44px var(--pad-x); }
  .process-steps { grid-template-columns:1fr; }
  .service-detail-grid { grid-template-columns:1fr; }
  .barrels-header { flex-direction:column; align-items:flex-start; gap:12px; }
  .section--dark .services-split__item { padding:48px var(--pad-x); }
}
