/* ==========================================================
   PILLARS COFFEE V2 — SHARED STYLESHEET
   Design system: editorial minimalism
   Fonts: Space Grotesk (display) + Inter (body)
========================================================== */

@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Inter:wght@400;500;600&display=swap');

:root{
  --paper: #FBFAF8;
  --ink:   #171411;
  --stone: #6F6A63;
  --line:  #E7E2D9;
  --clay:  #A2754F;
  --white: #FFFFFF;
}

/* ---------- reset ---------- */

*{ margin:0; padding:0; box-sizing:border-box; }
html{ scroll-behavior:smooth; }
img{ display:block; max-width:100%; }
a{ text-decoration:none; color:inherit; }

body{
  font-family:'Inter', ui-sans-serif, sans-serif;
  background:var(--paper);
  color:var(--ink);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}

h1,h2,h3,h4{
  font-family:'Space Grotesk', sans-serif;
  font-weight:600;
  letter-spacing:-0.01em;
  line-height:1.1;
}

/* ---------- layout ---------- */

.container{
  width:min(88%, 1180px);
  margin:auto;
}

.section{ padding:130px 0; }
.section-sm{ padding:80px 0; }

/* ---------- eyebrow ---------- */

.eyebrow{
  display:flex; align-items:center; gap:10px;
  text-transform:uppercase;
  letter-spacing:0.14em;
  font-size:11.5px;
  font-weight:600;
  color:var(--stone);
  margin-bottom:18px;
}
.eyebrow .bar{ width:1px; height:16px; background:var(--clay); flex-shrink:0; }

.eyebrow-light{
  display:flex; align-items:center; gap:10px;
  text-transform:uppercase;
  letter-spacing:0.14em;
  font-size:11.5px;
  font-weight:600;
  color:rgba(251,250,248,0.85);
  margin-bottom:20px;
}
.eyebrow-light .bar{ width:1px; height:16px; background:rgba(251,250,248,0.7); flex-shrink:0; }

/* ---------- nav ---------- */

header{
  position:fixed;
  top:0; left:0; width:100%;
  z-index:1000;
  background:rgba(251,250,248,0.88);
  backdrop-filter:blur(12px);
  border-bottom:1px solid transparent;
  transition:border-color .3s;
}
header.scrolled{ border-bottom-color:var(--line); }

.nav{
  height:76px;
  display:flex;
  align-items:center;
  justify-content:space-between;
}

.nav-logo{
  display:flex;
  align-items:center;
}
.nav-logo .logo-img{ height:42px; width:auto; display:block; }

.nav-links{
  display:flex;
  align-items:center;
  gap:38px;
  font-size:14px;
  font-weight:500;
}

.nav-links a:not(.btn-nav){
  position:relative;
  padding-bottom:3px;
  color:var(--stone);
  transition:color .2s;
}
.nav-links a:not(.btn-nav):hover{ color:var(--ink); }
.nav-links a:not(.btn-nav)::after{
  content:'';
  position:absolute; left:0; bottom:0;
  width:0; height:1px;
  background:var(--ink);
  transition:width .25s ease;
}
.nav-links a:not(.btn-nav):hover::after{ width:100%; }

.btn-nav{
  padding:11px 22px;
  background:var(--ink);
  color:var(--paper) !important;
  font-size:14px;
  font-weight:600;
  border-radius:2px;
  transition:background .2s;
}
.btn-nav:hover{ background:var(--clay) !important; }

/* ---------- mobile nav ---------- */

.menu-toggle{
  display:none;
  background:none; border:none;
  font-size:24px; cursor:pointer;
  color:var(--ink);
}

.mobile-overlay{
  display:none;
  position:fixed; inset:0;
  background:rgba(0,0,0,0.3);
  z-index:1400;
}
.mobile-overlay.active{ display:block; }

.mobile-menu{
  position:fixed;
  top:0; right:-100%;
  width:78%; max-width:310px; height:100vh;
  background:var(--paper);
  padding:100px 36px 40px;
  border-left:1px solid var(--line);
  z-index:1500;
  transition:right .3s ease;
}
.mobile-menu.active{ right:0; }

.mobile-menu a{
  display:block;
  font-size:18px;
  font-weight:500;
  margin-bottom:28px;
}

.mobile-menu .btn-nav-mobile{
  display:inline-block;
  margin-top:8px;
  padding:13px 24px;
  background:var(--ink);
  color:var(--paper);
  font-weight:600;
  border-radius:2px;
}

.close-toggle{
  position:absolute;
  top:24px; right:26px;
  background:none; border:none;
  font-size:28px; cursor:pointer;
  color:var(--ink);
}

/* ---------- buttons ---------- */

.btn{
  display:inline-block;
  padding:14px 28px;
  font-size:14px;
  font-weight:600;
  border-radius:2px;
  border:1.5px solid var(--ink);
  transition:background .2s, color .2s, border-color .2s;
  cursor:pointer;
}

.btn-solid{ background:var(--ink); color:var(--paper); }
.btn-solid:hover{ background:var(--clay); border-color:var(--clay); }

.btn-line{ background:transparent; color:var(--ink); }
.btn-line:hover{ background:var(--ink); color:var(--paper); }

.btn-light{ background:var(--paper); color:var(--ink); border-color:var(--paper); }
.btn-light:hover{ background:var(--clay); color:var(--paper); border-color:var(--clay); }

.btn-outline-light{ background:transparent; color:var(--paper); border-color:rgba(251,250,248,0.65); }
.btn-outline-light:hover{ background:var(--paper); color:var(--ink); border-color:var(--paper); }

/* ---------- hero (full-bleed photo) ---------- */

.hero-full{
  min-height:100vh;
  position:relative;
  display:flex;
  align-items:flex-end;
  padding:0 0 90px;
  color:var(--paper);
}

.hero-bg{
  position:absolute; inset:0; z-index:0;
  background-size:cover;
  background-position:center;
}
.hero-bg::after{
  content:'';
  position:absolute; inset:0;
  background:linear-gradient(0deg, rgba(10,9,8,0.62) 0%, rgba(10,9,8,0.12) 50%, rgba(10,9,8,0.28) 100%);
}

.hero-full .container{ position:relative; z-index:1; }

.hero-full h1{ font-size:clamp(2.5rem,5.5vw,4.2rem); margin-bottom:18px; }
.hero-full p{ font-size:1.05rem; opacity:0.9; max-width:460px; margin-bottom:36px; }
.hero-buttons{ display:flex; gap:14px; flex-wrap:wrap; }

/* ---------- page header (inner pages, no photo) ---------- */

.page-header{
  padding:160px 0 80px;
  border-bottom:1px solid var(--line);
}
.page-header h1{ font-size:clamp(2.2rem,5vw,3.4rem); margin-bottom:14px; }
.page-header p{ color:var(--stone); font-size:1.05rem; max-width:500px; }

/* ---------- two-col grid ---------- */

.two-col{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:90px;
  align-items:center;
}

.section h2{ font-size:clamp(1.6rem,3vw,2.3rem); margin-bottom:22px; }
.section p{ color:var(--stone); font-size:1rem; max-width:480px; }
.section p + p{ margin-top:14px; }

.photo-full{ width:100%; height:580px; object-fit:cover; }
.photo-half{ width:100%; height:480px; object-fit:cover; }

/* ---------- coffee list (beans page & homepage) ---------- */

.coffee-list{ border-top:1px solid var(--line); }

.coffee-row{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:30px;
  padding:32px 0;
  border-bottom:1px solid var(--line);
}

.coffee-row .c-name{
  font-family:'Space Grotesk', sans-serif;
  font-weight:600;
  font-size:1.1rem;
  margin-bottom:5px;
}
.coffee-row .c-origin{ color:var(--stone); font-size:0.9rem; margin-bottom:8px; }
.coffee-row .c-notes{ font-size:0.9rem; opacity:0.7; }

.coffee-row .c-right{ text-align:right; flex-shrink:0; }
.coffee-row .c-price{ font-weight:600; font-size:0.95rem; margin-bottom:10px; }
.coffee-row .c-link{
  font-size:13px; font-weight:600;
  border-bottom:1px solid var(--ink); padding-bottom:2px;
}

/* ---------- beans page section label ---------- */

.list-section{ padding:80px 0 0; }
.list-section:last-of-type{ padding-bottom:130px; }
.list-label{
  font-family:'Space Grotesk', sans-serif;
  font-size:0.9rem;
  text-transform:uppercase;
  letter-spacing:0.12em;
  color:var(--stone);
  margin-bottom:0;
}

/* ---------- contact cards ---------- */

.contact-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(300px, 1fr));
  gap:1px;
  background:var(--line);
  border:1px solid var(--line);
}

.contact-card{
  background:var(--paper);
  padding:50px 44px;
}
.contact-card h3{ font-size:1.2rem; margin-bottom:12px; }
.contact-card p{ color:var(--stone); font-size:0.95rem; max-width:280px; margin-bottom:22px; }
.contact-card a.email{
  font-weight:600;
  font-size:0.95rem;
  border-bottom:1px solid var(--ink);
  padding-bottom:2px;
}

/* ---------- address block ---------- */

.address-block{ margin-top:30px; }
.address-block dt{
  text-transform:uppercase;
  letter-spacing:0.1em;
  font-size:11px;
  color:var(--stone);
  font-weight:600;
  margin-top:22px;
  margin-bottom:5px;
}
.address-block dd{ font-size:1rem; }

/* ---------- preorder ---------- */

.preorder-wrap{
  min-height:100vh;
  display:flex;
  align-items:center;
  padding:120px 0 80px;
}

.preorder-card{
  max-width:640px;
  margin:auto;
  text-align:center;
}

.preorder-card h1{
  font-size:clamp(2.2rem,5vw,3.2rem);
  margin-bottom:14px;
}

.preorder-card .sub{
  color:var(--stone);
  margin-bottom:40px;
  font-size:1.05rem;
}

.pickup-info{
  border:1px solid var(--line);
  padding:36px;
  margin-bottom:36px;
  text-align:left;
}

.pickup-info dt{
  text-transform:uppercase;
  letter-spacing:0.1em;
  font-size:11px;
  color:var(--stone);
  font-weight:600;
  margin-top:20px;
  margin-bottom:5px;
}
.pickup-info dt:first-child{ margin-top:0; }
.pickup-info dd{ font-size:0.97rem; }

.preorder-note{
  margin-top:20px;
  font-size:0.88rem;
  color:var(--stone);
}

/* ---------- pull quote ---------- */

.pull-quote{
  text-align:center;
  padding:130px 0;
  border-top:1px solid var(--line);
}
.pull-quote blockquote{
  font-family:'Space Grotesk', sans-serif;
  font-size:clamp(1.8rem,4vw,2.8rem);
  font-weight:600;
  letter-spacing:-0.01em;
  max-width:700px;
  margin:auto;
  line-height:1.2;
}

/* ---------- footer ---------- */

footer{
  border-top:1px solid var(--line);
  padding:64px 0 36px;
}

.footer-top{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  flex-wrap:wrap;
  gap:36px;
  padding-bottom:48px;
}

.footer-links{
  display:flex;
  gap:32px;
  flex-wrap:wrap;
  font-size:14px;
  font-weight:500;
}
.footer-links a{ position:relative; padding-bottom:3px; }
.footer-links a::after{
  content:''; position:absolute; left:0; bottom:0;
  width:0; height:1px; background:var(--ink);
  transition:width .25s ease;
}
.footer-links a:hover::after{ width:100%; }

.footer-bottom{
  display:flex;
  justify-content:space-between;
  flex-wrap:wrap;
  gap:12px;
  padding-top:24px;
  border-top:1px solid var(--line);
  font-size:12px;
  color:var(--stone);
}

/* ---------- divider ---------- */
.divider{ border:none; border-top:1px solid var(--line); }

/* ---------- utility ---------- */
.mt-8{ margin-top:8px; }
.mt-16{ margin-top:16px; }
.mt-24{ margin-top:24px; }
.mt-32{ margin-top:32px; }
.mt-40{ margin-top:40px; }

/* ==========================================================
   RESPONSIVE
========================================================== */

@media(max-width:900px){

  .nav-links{ display:none; }
  .menu-toggle{ display:block; }

  .two-col{ grid-template-columns:1fr; gap:40px; }

  .photo-full,
  .photo-half{ height:300px; }

  .section{ padding:90px 0; }
  .section-sm{ padding:60px 0; }

  .page-header{ padding:120px 0 60px; }

  .hero-full{ align-items:center; padding:100px 0 60px; }

  .coffee-row{ flex-direction:column; gap:14px; }
  .coffee-row .c-right{ text-align:left; }

  .contact-grid{ grid-template-columns:1fr; }
  .contact-card{ padding:36px 28px; }

  .footer-top{ flex-direction:column; gap:28px; }
  .footer-links{ flex-direction:column; gap:18px; }

  .preorder-card{ padding:0 4px; }

  .pull-quote{ padding:90px 0; }
  .pull-quote blockquote{ font-size:1.8rem; }

  .list-section{ padding:60px 0 0; }
  .list-section:last-of-type{ padding-bottom:90px; }

}

@media(max-width:560px){

  .hero-full h1{ font-size:2.3rem; }
  .hero-buttons{ flex-direction:column; }
  .btn{ width:100%; text-align:center; }

  .pickup-info{ padding:24px 20px; }

}
