/*
Theme Name: Ottawa Whiskey
Theme URI: https://ottawawhiskey.ca
Author: Ottawa Whiskey
Description: Custom theme for Ottawa Whiskey Tasting & Consulting.
Version: 1.0
Text Domain: ottawa-whiskey
*/

:root{
  --cream:        #FAF5EA;
  --cream-alt:    #F1EADA;
  --forest:       #1E3328;
  --forest-soft:  #2E4838;
  --copper:       #B6692E;
  --copper-soft:  #D9A857;
  --sage:         #93A382;
  --sage-soft:    #DCE3D4;
  --ink:          #2A2620;
  --ink-soft:     #6B6256;

  --display: 'Fraunces', serif;
  --body: 'Work Sans', sans-serif;
  --script: 'Caveat', cursive;

  --maxw: 1180px;
}

*{ box-sizing: border-box; margin:0; padding:0; }
html{ scroll-behavior: smooth; }
body{
  font-family: var(--body);
  background: var(--cream);
  color: var(--ink);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}
img{ max-width:100%; display:block; }
a{ color: inherit; text-decoration:none; }
.wrap{ max-width: var(--maxw); margin: 0 auto; padding: 0 32px; }

h1,h2,h3{ font-family: var(--display); font-weight: 600; color: var(--forest); line-height: 1.1; }

.eyebrow{
  font-family: var(--body); font-weight: 600; font-size: 0.78rem;
  letter-spacing: 0.14em; text-transform: uppercase; color: var(--copper);
}

.btn{
  display:inline-flex; align-items:center; gap:8px;
  font-family: var(--body); font-weight:600; font-size:0.95rem;
  padding: 14px 26px; border-radius: 999px; border:2px solid transparent;
  cursor:pointer; transition: transform .2s ease, background .2s ease, color .2s ease, border-color .2s ease;
}
.btn-primary{ background: var(--copper); color: var(--cream); }
.btn-primary:hover{ background: #9c5824; transform: translateY(-2px); }
.btn-outline{ border-color: var(--forest); color: var(--forest); }
.btn-outline:hover{ background: var(--forest); color: var(--cream); transform: translateY(-2px); }

/* ---------- Reveal on scroll ---------- */
.reveal{ opacity:0; transform: translateY(18px); transition: opacity .7s ease, transform .7s ease; }
.reveal.is-visible{ opacity:1; transform: translateY(0); }
@media (prefers-reduced-motion: reduce){
  .reveal{ opacity:1; transform:none; transition:none; }
  html{ scroll-behavior:auto; }
}

/* ---------- Header ---------- */
header.site-header{
  position: sticky; top:0; z-index: 50;
  background: rgba(250,245,234,0.92); backdrop-filter: blur(8px);
  border-bottom: 1px solid rgba(30,51,40,0.08);
}
.navbar{
  max-width: var(--maxw); margin:0 auto; padding: 14px 32px;
  display:flex; align-items:center; justify-content:space-between; gap: 24px;
}
.brand{ display:flex; align-items:center; gap:12px; }
.brand img{ border-radius: 7px; }
.brand-name{ font-family: var(--display); font-weight:600; font-size:1.25rem; color: var(--forest); }
nav ul{ list-style:none; display:flex; gap: 26px; flex-wrap:wrap; }
nav a{ font-size:0.92rem; font-weight:500; color: var(--ink); position:relative; padding-bottom:3px; }
nav a::after{
  content:''; position:absolute; left:0; bottom:0; width:0; height:2px; background: var(--copper);
  transition: width .25s ease;
}
nav a:hover::after{ width:100%; }
nav a.current::after{ width:100%; }
.nav-cta{ flex-shrink:0; }
.navbar .btn-primary{ padding:10px 20px; font-size:0.88rem; }
.menu-toggle{ display:none; background:none; border:none; cursor:pointer; padding:6px; }
.menu-toggle svg{ width:26px; height:26px; color:var(--forest); }

/* ---------- Hero ---------- */
.hero{ padding: 76px 0 64px; overflow:hidden; }
.hero .wrap{
  display:flex; flex-direction:column; align-items:center; text-align:center; gap: 22px;
  max-width: 740px;
}
.hero-mark{ position:relative; width: 220px; height:220px; margin-bottom: 6px; }
.hero-ring{
  position:absolute; inset:-34px; border-radius:50%;
  border: 1.5px solid var(--copper-soft); opacity:0.55;
}
.hero-ring::before{
  content:''; position:absolute; inset:18px; border-radius:50%;
  border: 1px solid var(--sage); opacity:0.5;
}
.hero-mark svg, .hero-mark img{ position:relative; width:100%; height:100%; object-fit: cover; border-radius: 18px; filter: drop-shadow(0 16px 26px rgba(30,51,40,0.28)); }
.hero h1{ font-size: clamp(2.2rem, 4vw, 3.1rem); }
.hero p.lead{ font-size: 1.1rem; color: var(--ink-soft); max-width: 50ch; }
.hero-ctas{ display:flex; gap:16px; flex-wrap:wrap; justify-content:center; margin-top:8px; }

/* ---------- Page hero (inner pages) ---------- */
.page-hero{ padding: 64px 0 36px; text-align:center; }
.page-hero h1{ font-size: clamp(2rem, 3.6vw, 2.8rem); margin-top:8px; }
.page-hero p.lead{ font-size: 1.05rem; color: var(--ink-soft); max-width: 60ch; margin: 14px auto 0; }

/* ---------- Pour divider ---------- */
.pour-divider{ width:100%; height:46px; display:block; }
.pour-divider path{ fill:none; stroke: var(--copper-soft); stroke-width:2.5; stroke-linecap:round; }

/* ---------- Story / Meet Your Guide ---------- */
.story{ background: var(--cream-alt); padding: 76px 0; }
.story .story-head{ margin-bottom: 40px; }
.story .story-head h2{ font-size: clamp(1.8rem, 3vw, 2.3rem); margin-top:8px; }
.story-main{ display:grid; grid-template-columns: 0.85fr 1.15fr; gap: 56px; align-items:start; }
.story blockquote{
  font-family: var(--display); font-style:italic; font-weight:500;
  font-size: clamp(1.5rem, 2.4vw, 2rem); color: var(--forest); line-height:1.35;
  border-left: 3px solid var(--copper); padding-left: 22px;
}
.story .story-body p{ margin-bottom: 16px; color: var(--ink); }
.story-photo{ border-radius: 16px; overflow:hidden; margin-bottom:24px; box-shadow: 0 20px 40px -28px rgba(30,51,40,0.4); }
.story-photo img{ width:100%; object-fit:cover; }

.credentials-detail{
  margin-top: 56px; padding-top: 48px; border-top: 1px solid rgba(30,51,40,0.12);
  display:grid; grid-template-columns: repeat(3, 1fr); gap: 28px;
}
.credentials-detail .cred-head{ grid-column: 1/-1; max-width: 56ch; margin-bottom: 6px; }
.credentials-detail .cred-head h3{ font-size: 1.3rem; }
.credentials-detail .cred-head p{ color: var(--ink-soft); font-size:0.95rem; }
.cred-card{
  background: var(--cream); border: 1px solid var(--sage-soft); border-radius: 14px;
  padding: 24px 22px; display:flex; flex-direction:column; gap:12px;
}
.cred-card svg, .cred-card img{ height: 56px; width:auto; align-self:flex-start; }
.cred-card h4{ font-family: var(--display); font-weight:600; color: var(--forest); font-size:1.05rem; }
.cred-card p{ color: var(--ink-soft); font-size:0.9rem; }

/* ---------- Explore grid ---------- */
.explore{ padding: 84px 0; }
.section-head{ margin-bottom: 44px; max-width: 60ch; }
.section-head h2{ font-size: clamp(1.8rem, 3vw, 2.3rem); margin-bottom: 10px; }
.section-head p{ color: var(--ink-soft); }

.grid12{ display:grid; grid-template-columns: repeat(auto-fit, minmax(210px, 1fr)); gap: 22px; }
.card{
  border-radius: 16px; background: var(--cream-alt);
  border: 1px solid rgba(30,51,40,0.08); padding: 28px 24px;
  display:flex; flex-direction:column; gap:12px;
  transition: transform .2s ease, border-color .2s ease;
}
.card:hover{ transform: translateY(-3px); border-color: var(--copper-soft); }
.card-icon{ width:32px; height:32px; }
.card h3{ font-size:1.12rem; }
.card p{ color: var(--ink-soft); font-size:0.92rem; flex:1; }
.card .card-link{ font-weight:600; font-size:0.86rem; color: var(--copper); display:inline-flex; align-items:center; gap:6px; }
.card .card-link svg{ width:14px; height:14px; }

/* ---------- Generic content page ---------- */
.content-page{ padding: 0 0 84px; }
.content-page .wrap{ max-width: 820px; }
.content-block{ margin-bottom: 28px; }
.content-block h2{ font-size: 1.5rem; margin-bottom: 12px; }
.content-block h3{ font-size: 1.15rem; margin: 18px 0 8px; color: var(--forest-soft); }
.content-block p{ margin-bottom: 14px; color: var(--ink); }
.content-block p:last-child{ margin-bottom:0; }
.content-block ol, .content-block ul{ margin: 0 0 14px 22px; color: var(--ink); }
.content-block li{ margin-bottom: 6px; }
.content-photo{ border-radius: 14px; overflow:hidden; margin: 24px 0; }
.divider-rule{ border:none; border-top:1px solid var(--sage-soft); margin: 36px 0; }

/* ---------- Credentials band (sitewide) ---------- */
.credentials{ background: var(--forest); color: var(--cream); padding: 70px 0; position:relative; overflow:hidden; }
.credentials .wrap{ display:grid; grid-template-columns: 1fr auto; gap: 48px; align-items:center; }
.credentials h2{ color: var(--cream); font-size: clamp(1.7rem, 2.8vw, 2.1rem); margin-bottom:14px; }
.credentials p{ color: #D9DECF; max-width: 52ch; }
.badge-row{ display:flex; gap: 20px; flex-shrink:0; align-items:center; }
.badge-row svg, .badge-row img{ height: 96px; width:auto; filter: drop-shadow(0 8px 14px rgba(0,0,0,0.25)); }

/* ---------- Contact ---------- */
.contact-wrap{ padding: 84px 0; background: var(--cream-alt); }
.contact-wrap .wrap{ display:grid; grid-template-columns: 1fr 0.85fr; gap: 56px; align-items:start; }
.contact-form{
  background: var(--cream); border-radius: 20px; padding: 34px;
  border: 1px solid rgba(30,51,40,0.08); box-shadow: 0 24px 50px -34px rgba(30,51,40,0.4);
}
.field{ margin-bottom: 18px; }
.field label{ display:block; font-size:0.85rem; font-weight:600; margin-bottom:6px; color: var(--forest-soft); }
.field input, .field textarea{
  width:100%; padding: 12px 14px; border-radius:10px; border: 1.5px solid var(--sage-soft);
  background: var(--cream-alt); font-family: var(--body); font-size:0.95rem; color: var(--ink);
}
.field input:focus, .field textarea:focus{ outline: 2px solid var(--copper); outline-offset:1px; border-color: var(--copper); }
.contact-info h2{ font-size: clamp(1.7rem, 2.8vw, 2.1rem); margin-bottom: 14px; }
.contact-info p{ color: var(--ink-soft); margin-bottom: 18px; }
.contact-info .contact-detail{ font-weight:600; color: var(--forest); margin-bottom:6px; }
.contact-tag{ font-family: var(--script); font-size: 1.8rem; color: var(--copper); }
.form-notice{ padding: 14px 16px; border-radius: 10px; margin-bottom: 20px; font-size:0.92rem; font-weight:500; }
.form-notice.success{ background:#E5EEDF; color: var(--forest-soft); border:1px solid var(--sage); }
.form-notice.error{ background:#F6E6DC; color:#8C4A1F; border:1px solid var(--copper-soft); }

/* ---------- Tools / shop ---------- */
.tools-grid{ display:grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 28px; }
.tool-card{
  background: var(--cream-alt); border: 1px solid rgba(30,51,40,0.08); border-radius: 18px;
  padding: 30px; display:flex; flex-direction:column; gap: 14px;
}
.tool-card .tool-tag{ font-size:0.78rem; font-weight:600; letter-spacing:0.1em; text-transform:uppercase; color: var(--copper); }
.tool-card h3{ font-size: 1.4rem; }
.tool-card p{ color: var(--ink-soft); font-size:0.95rem; flex:1; }

/* ---------- Blog ---------- */
.blog-list{ display:grid; gap: 28px; }
.blog-post-card{
  background: var(--cream-alt); border: 1px solid rgba(30,51,40,0.08); border-radius: 16px;
  padding: 26px 28px;
}
.blog-post-card h2{ font-size: 1.3rem; margin-bottom: 8px; }
.blog-post-card h2 a:hover{ color: var(--copper); }
.blog-post-card .post-meta{ font-size:0.82rem; color: var(--ink-soft); margin-bottom: 10px; }
.blog-post-card .post-excerpt{ color: var(--ink); font-size:0.95rem; }
.blog-post-card .read-more{ display:inline-block; margin-top:10px; color: var(--copper); font-weight:600; font-size:0.88rem; }
.single-post .wrap{ max-width: 760px; }
.single-post .post-meta{ color: var(--ink-soft); font-size:0.88rem; margin-bottom: 24px; }
.single-post .post-content p{ margin-bottom: 16px; }
.single-post .post-content img{ border-radius: 14px; margin: 20px 0; }

/* ---------- Footer ---------- */
footer.site-footer{ background: var(--forest); border-top: 3px solid var(--copper); padding: 38px 0; }
footer.site-footer .wrap{ display:flex; align-items:center; justify-content:space-between; gap:20px; flex-wrap:wrap; }
footer.site-footer .brand-name{ color: var(--cream); }
footer.site-footer nav ul{ gap: 22px; }
footer.site-footer nav a{ color: #D9DECF; font-size:0.85rem; }
footer.site-footer nav a::after{ background: var(--copper-soft); }
.copyright{ color: #9FB0A2; font-size:0.8rem; }

/* ---------- Responsive ---------- */
@media (max-width: 920px){
  .hero .wrap, .story-main, .credentials .wrap, .contact-wrap .wrap{ grid-template-columns: 1fr; }
  .credentials-detail{ grid-template-columns: 1fr 1fr; }
  .badge-row{ justify-content:flex-start; flex-wrap:wrap; }
  .menu-toggle{ display:inline-flex; }
  nav{ display:none; width:100%; }
  nav.is-open{ display:block; }
  .navbar{ flex-wrap:wrap; }
  nav ul{ flex-direction:column; gap:14px; padding: 18px 0; width:100%; }
}
@media (max-width: 560px){
  .wrap{ padding: 0 20px; }
  .hero{ padding: 56px 0 40px; }
  .credentials-detail{ grid-template-columns: 1fr; }
  .contact-wrap .wrap{ gap: 32px; }
}
