/* ================================================================
   77th Avenue — Main Stylesheet
   Editorial design system for premium organic food brand
   ================================================================ */

:root{
  --black:#0C0C0C;
  --white:#FFFFFF;
  --off:#F6F6F4;
  --gray-1:#EFEFED;
  --gray-2:#DDDDD9;
  --gray-3:#AAAAAA;
  --gray-4:#666664;
  --chilli:#B83220;
  --chilli-dk:#8C2218;
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'DM Sans',system-ui,sans-serif;
  --pad:clamp(1.5rem,5vw,4rem);
  --max:1280px;
  --nav-h:72px;
  --ease:.25s ease;
}

/* RESET */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth}
body{
  font-family:var(--sans);
  font-weight:300;
  line-height:1.7;
  color:var(--black);
  background:var(--white);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img,svg{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none;transition:color var(--ease)}
ul,ol{list-style:none}
h1,h2,h3,h4,h5,h6{font-family:var(--serif);font-weight:300;line-height:1.1;color:var(--black)}
h1{font-size:clamp(2.8rem,6vw,6rem)}
h2{font-size:clamp(2rem,4vw,3.8rem)}
h3{font-size:clamp(1.3rem,2vw,1.8rem)}
h4{font-size:1.2rem}
em,i{font-style:italic}
p{margin-bottom:1rem}
p:last-child{margin-bottom:0}
button,input,textarea,select{font:inherit}

/* UTILITIES */
.container{max-width:var(--max);margin:0 auto;padding:0 var(--pad)}
.eye{
  display:block;
  font-size:.7rem;
  font-weight:500;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--chilli);
  margin-bottom:.85rem;
  font-family:var(--sans);
}

/* BUTTONS */
.btn{
  display:inline-block;
  font-family:var(--sans);
  font-size:.72rem;
  font-weight:500;
  letter-spacing:.13em;
  text-transform:uppercase;
  padding:.875rem 2rem;
  border:1px solid transparent;
  cursor:pointer;
  transition:all var(--ease);
  white-space:nowrap;
}
.btn-black{background:var(--black);color:var(--white);border-color:var(--black)}
.btn-black:hover{background:var(--chilli);border-color:var(--chilli);color:var(--white)}
.btn-outline{background:transparent;color:var(--black);border-color:var(--black)}
.btn-outline:hover{background:var(--black);color:var(--white)}
.btn-outline-w{background:transparent;color:var(--white);border-color:rgba(255,255,255,.4)}
.btn-outline-w:hover{background:var(--white);color:var(--black)}
.btn-chilli{background:var(--chilli);color:var(--white);border-color:var(--chilli)}
.btn-chilli:hover{background:var(--chilli-dk);border-color:var(--chilli-dk)}

/* ANIMATIONS */
@keyframes fadeUp{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}
.f{opacity:0;animation:fadeUp .7s ease forwards}
.f1{animation-delay:.1s}.f2{animation-delay:.25s}.f3{animation-delay:.42s}.f4{animation-delay:.6s}

/* =========================================================
   NAV
   ========================================================= */
nav.site-nav{
  position:fixed;top:0;left:0;right:0;z-index:200;
  height:var(--nav-h);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 var(--pad);
  background:rgba(255,255,255,.96);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid var(--gray-1);
  transition:box-shadow var(--ease);
}
nav.site-nav.scrolled{box-shadow:0 2px 24px rgba(0,0,0,.07)}
.logo{
  font-family:var(--serif);
  font-size:1.35rem;
  font-weight:600;
  letter-spacing:.04em;
  color:var(--black);
}
.logo span{color:var(--chilli)}
.logo img{max-height:40px;width:auto}
.nav-links{display:flex;gap:2.5rem;align-items:center}
.nav-links a{
  font-size:.72rem;
  font-weight:400;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--gray-4);
  position:relative;
}
.nav-links a::after{
  content:'';position:absolute;bottom:-2px;left:0;
  width:0;height:1px;background:var(--chilli);
  transition:width var(--ease);
}
.nav-links a:hover,
.nav-links a.active,
.nav-links li.current-menu-item > a,
.nav-links li.current_page_item > a{color:var(--black)}
.nav-links a:hover::after,
.nav-links a.active::after,
.nav-links li.current-menu-item > a::after,
.nav-links li.current_page_item > a::after{width:100%}
.nav-actions{display:flex;align-items:center;gap:1rem}
.hamburger{
  display:none;background:none;border:none;cursor:pointer;
  flex-direction:column;gap:5px;padding:.2rem;
}
.hamburger span{
  display:block;width:22px;height:1.5px;
  background:var(--black);transition:all var(--ease);
}

/* Sub-menus (basic) */
.nav-links li.menu-item-has-children{position:relative}
.nav-links .sub-menu{
  position:absolute;top:100%;left:0;
  background:var(--white);
  border:1px solid var(--gray-1);
  min-width:200px;
  padding:.75rem 0;
  opacity:0;visibility:hidden;
  transform:translateY(8px);
  transition:all var(--ease);
  box-shadow:0 8px 24px rgba(0,0,0,.06);
  z-index:201;
}
.nav-links li.menu-item-has-children:hover > .sub-menu{
  opacity:1;visibility:visible;transform:translateY(0);
}
.nav-links .sub-menu li{display:block}
.nav-links .sub-menu a{
  display:block;padding:.6rem 1.25rem;font-size:.7rem;
}
.nav-links .sub-menu a::after{display:none}

/* =========================================================
   HERO — generic page hero
   ========================================================= */
.hero{
  padding-top:var(--nav-h);
  min-height:46vh;
  background:var(--off);
  display:flex;flex-direction:column;justify-content:flex-end;
  padding-bottom:clamp(3rem,6vw,5rem);
  border-bottom:1px solid var(--gray-2);
}
.hero-inner{padding:0 var(--pad);max-width:var(--max);margin:0 auto;width:100%}
.hero-inner h1{max-width:800px}

/* Dark hero variant (used on About) */
.hero-dark{
  background:var(--black);
  position:relative;overflow:hidden;
  min-height:60vh;
  border-bottom:none;
}
.hero-dark::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(0,0,0,.85) 55%,rgba(30,30,30,.4));
  pointer-events:none;
}
.hero-bg{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  opacity:.35;
}
.hero-dark .hero-inner{position:relative;z-index:2}
.hero-dark .hero-inner h1{color:var(--white)}
.hero-dark .hero-inner p{
  font-size:1.1rem;
  color:rgba(255,255,255,.5);
  max-width:480px;
  margin-top:1.25rem;
  font-weight:300;
  line-height:1.85;
}
.hero-dark .eye{color:rgba(184,50,32,.75)}

/* =========================================================
   ABOUT BODY
   ========================================================= */
.about-body{padding:clamp(4rem,8vw,8rem) var(--pad);background:var(--white)}
.about-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:5rem;
  max-width:var(--max);margin:0 auto;
}
.body-text{font-size:1.05rem;color:var(--gray-4);line-height:1.9;font-weight:300}
.body-text p{margin-bottom:1.5rem}
.pull-quote{
  margin-top:2rem;background:var(--off);
  border-left:3px solid var(--chilli);
  padding:1.75rem 2rem;
}
.pull-quote blockquote{
  font-family:var(--serif);font-size:1.5rem;font-style:italic;
  font-weight:300;color:var(--black);line-height:1.4;
  border:none;padding:0;margin:0;
}
.brand-statement{
  font-family:var(--serif);font-size:clamp(1.8rem,3vw,2.5rem);
  font-weight:300;line-height:1.25;margin-bottom:2rem;color:var(--black);
}
.body-right p{
  font-size:1rem;color:var(--gray-4);line-height:1.9;
  font-weight:300;margin-bottom:1.25rem;
}

/* =========================================================
   VALUES
   ========================================================= */
.values{padding:clamp(4rem,7vw,6rem) var(--pad);background:var(--off)}
.values-inner{max-width:var(--max);margin:0 auto}
.values-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:1.25rem;margin-top:3rem;
}
.value-card{
  padding:2rem 1.75rem;background:var(--white);
  border-top:2px solid var(--black);
}
.value-card h3{
  font-family:var(--serif);font-size:1.4rem;
  font-weight:400;margin-bottom:.75rem;
}
.value-card p{
  font-size:.9rem;color:var(--gray-4);line-height:1.75;font-weight:300;
}

/* =========================================================
   PIPELINE / VALUE CHAIN (Our Work)
   ========================================================= */
.pipeline{background:var(--white);padding:clamp(4rem,8vw,8rem) 0}
.pipeline-label{padding:0 var(--pad);max-width:var(--max);margin:0 auto 3rem;display:block}
.pipeline-steps{
  display:grid;grid-template-columns:repeat(4,1fr);
  border-top:1px solid var(--gray-1);border-bottom:1px solid var(--gray-1);
  max-width:var(--max);margin:0 auto;
}
.step{
  padding:3rem 2rem;border-right:1px solid var(--gray-1);
  position:relative;
}
.step:last-child{border-right:none}
.step-num{
  font-family:var(--serif);font-size:4.5rem;font-weight:300;
  color:var(--gray-1);line-height:1;margin-bottom:1.5rem;
}
.step-dot{
  width:9px;height:9px;background:var(--chilli);
  border-radius:50%;margin-bottom:.85rem;
}
.step h3{font-family:var(--serif);font-size:1.5rem;font-weight:400;margin-bottom:.75rem}
.step p{font-size:.9rem;color:var(--gray-4);line-height:1.8;font-weight:300}

/* Pipeline alt — 2-column expanded steps */
.process-detailed{padding:clamp(4rem,8vw,7rem) var(--pad);background:var(--off)}
.process-inner{max-width:var(--max);margin:0 auto}
.process-row{
  display:grid;grid-template-columns:140px 1fr 1fr;
  gap:3rem;padding:3rem 0;
  border-bottom:1px solid var(--gray-2);
  align-items:start;
}
.process-row:last-child{border-bottom:none}
.process-num{
  font-family:var(--serif);font-size:5rem;font-weight:300;
  color:var(--chilli);line-height:1;
}
.process-title{font-family:var(--serif);font-size:2rem;font-weight:400;margin-bottom:.5rem}
.process-tag{
  display:inline-block;font-size:.65rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--gray-4);font-weight:500;
  margin-bottom:1rem;padding:.3rem .7rem;background:var(--white);
  border:1px solid var(--gray-2);
}
.process-body p{font-size:1rem;color:var(--gray-4);line-height:1.9;font-weight:300}

/* =========================================================
   CONTENT AREA
   ========================================================= */
.content-area{padding:clamp(3rem,6vw,5rem) var(--pad);background:var(--off)}
.content-inner{max-width:820px;margin:0 auto}
.content-inner p{
  font-size:1.05rem;color:var(--gray-4);line-height:1.9;
  margin-bottom:1.5rem;font-weight:300;
}

/* =========================================================
   CLOSING BAND
   ========================================================= */
.closing{
  background:var(--black);
  padding:clamp(3.5rem,7vw,6rem) var(--pad);
  display:flex;align-items:center;justify-content:space-between;
  gap:2.5rem;flex-wrap:wrap;
}
.closing-text{
  font-family:var(--serif);font-size:clamp(1.5rem,3vw,2.8rem);
  font-style:italic;font-weight:300;color:var(--white);
  max-width:620px;line-height:1.4;
}
.closing-center{text-align:center;justify-content:center}
.closing-center .closing-text{margin:0 auto;color:rgba(255,255,255,.55)}

/* =========================================================
   CONTACT
   ========================================================= */
.contact-body{padding:clamp(4rem,8vw,7rem) var(--pad);background:var(--white)}
.contact-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:5rem;
  max-width:var(--max);margin:0 auto;
}
.contact-intro{
  font-size:1rem;color:var(--gray-4);line-height:1.9;
  font-weight:300;margin-bottom:2.5rem;
}
.detail-row{
  display:flex;gap:1.25rem;align-items:baseline;
  margin-bottom:1rem;
}
.detail-label{
  font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--chilli);font-weight:500;min-width:80px;
  padding-top:2px;flex-shrink:0;
}
.detail-value{font-size:.95rem;color:var(--black);font-weight:400}
.detail-value a{transition:color var(--ease)}
.detail-value a:hover{color:var(--chilli)}
.contact-pull{
  margin-top:2.5rem;background:var(--off);
  border-left:3px solid var(--black);padding:1.5rem 1.75rem;
}
.contact-pull p{
  font-family:var(--serif);font-size:1.15rem;font-style:italic;
  color:var(--black);line-height:1.5;font-weight:300;
}
.form-title{
  font-family:var(--serif);font-size:1.8rem;font-weight:300;
  color:var(--black);margin-bottom:2rem;
}
.field{margin-bottom:1.1rem}
.field label{
  display:block;font-size:.68rem;letter-spacing:.15em;
  text-transform:uppercase;color:var(--gray-4);font-weight:500;
  margin-bottom:.4rem;
}
.field input,.field textarea,.field select,
.contact-form input[type="text"],
.contact-form input[type="email"],
.contact-form input[type="tel"],
.contact-form input[type="url"],
.contact-form textarea,
.contact-form select{
  width:100%;padding:.875rem 1rem;background:var(--off);
  border:1px solid var(--gray-2);font-family:var(--sans);
  font-size:.9rem;color:var(--black);outline:none;
  transition:border-color var(--ease);
  -webkit-appearance:none;border-radius:0;
}
.field input:focus,.field textarea:focus,.field select:focus,
.contact-form input:focus,.contact-form textarea:focus,.contact-form select:focus{
  border-color:var(--black);background:var(--white);
}
.field textarea,.contact-form textarea{resize:vertical;min-height:120px}

/* CF7 inheritance */
.wpcf7 .wpcf7-form-control-wrap{display:block}
.wpcf7 label{
  display:block;font-size:.68rem;letter-spacing:.15em;
  text-transform:uppercase;color:var(--gray-4);font-weight:500;
  margin-bottom:1.1rem;
}
.wpcf7 .wpcf7-submit{
  background:var(--black);color:var(--white);border-color:var(--black);
  font-family:var(--sans);font-size:.78rem;font-weight:500;
  letter-spacing:.13em;text-transform:uppercase;
  padding:1rem 2rem;width:100%;border:1px solid var(--black);
  cursor:pointer;transition:all var(--ease);
}
.wpcf7 .wpcf7-submit:hover{background:var(--chilli);border-color:var(--chilli)}
.wpcf7-response-output{
  margin:1rem 0 0!important;padding:1rem!important;
  font-size:.85rem;border-radius:0!important;
}

/* =========================================================
   FOOTER
   ========================================================= */
footer.site-footer{
  background:var(--black);
  padding:clamp(3rem,6vw,5rem) var(--pad) 2rem;
  border-top:1px solid rgba(255,255,255,.06);
}
.footer-top{
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;
  gap:3rem;padding-bottom:3rem;
  border-bottom:1px solid rgba(255,255,255,.08);
  margin-bottom:2rem;
  max-width:var(--max);margin-left:auto;margin-right:auto;
}
.footer-logo{
  font-family:var(--serif);font-size:1.5rem;font-weight:300;
  color:var(--white);margin-bottom:.75rem;
}
.footer-logo span{color:var(--chilli)}
.footer-tagline{
  font-size:.85rem;color:rgba(255,255,255,.3);
  line-height:1.8;max-width:240px;font-weight:300;
}
.footer-col h4{
  font-size:.65rem;letter-spacing:.2em;text-transform:uppercase;
  color:rgba(255,255,255,.22);font-weight:500;
  font-family:var(--sans);margin-bottom:1.25rem;
}
.footer-col ul li{margin-bottom:.6rem}
.footer-col ul li a{
  font-size:.85rem;color:rgba(255,255,255,.45);
  font-weight:300;transition:color var(--ease);
}
.footer-col ul li a:hover{color:var(--white)}
.footer-bottom{
  display:flex;justify-content:space-between;align-items:center;
  flex-wrap:wrap;gap:1rem;
  max-width:var(--max);margin:0 auto;
}
.footer-copy{font-size:.72rem;color:rgba(255,255,255,.18);font-weight:300}
.social-links{display:flex;gap:.75rem}
.social-links a{
  width:32px;height:32px;
  border:1px solid rgba(255,255,255,.1);
  display:flex;align-items:center;justify-content:center;
  font-size:.6rem;color:rgba(255,255,255,.3);
  transition:all var(--ease);
}
.social-links a:hover{border-color:rgba(255,255,255,.4);color:var(--white)}

/* =========================================================
   BLOG / SINGLE / ARCHIVE
   ========================================================= */
.archive-wrap,.single-wrap{
  padding:clamp(4rem,8vw,7rem) var(--pad);
  background:var(--white);
}
.archive-inner,.single-inner{max-width:var(--max);margin:0 auto}
.post-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:2rem;margin-top:3rem;
}
.post-card{background:var(--white);border-bottom:1px solid var(--gray-2);padding-bottom:1.5rem}
.post-card .thumb{aspect-ratio:4/3;overflow:hidden;background:var(--off);margin-bottom:1.25rem}
.post-card .thumb img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.post-card:hover .thumb img{transform:scale(1.04)}
.post-card .meta{
  font-size:.65rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--chilli);font-weight:500;margin-bottom:.6rem;
}
.post-card h2,.post-card h3{
  font-size:1.4rem;font-weight:400;margin-bottom:.6rem;
  font-family:var(--serif);
}
.post-card .excerpt{font-size:.9rem;color:var(--gray-4);line-height:1.7}

.single-wrap article{max-width:780px;margin:0 auto}
.single-wrap article h1{margin-bottom:1.5rem}
.single-wrap article .post-meta{
  font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--gray-3);margin-bottom:2rem;font-weight:500;
}
.single-wrap article .post-thumb{margin-bottom:2.5rem}
.single-wrap article p,
.single-wrap article ul,
.single-wrap article ol,
.single-wrap article blockquote{
  font-size:1.05rem;line-height:1.9;color:var(--gray-4);
  font-weight:300;margin-bottom:1.5rem;
}
.single-wrap article ul,.single-wrap article ol{padding-left:1.5rem;list-style:disc}
.single-wrap article ol{list-style:decimal}
.single-wrap article ul li,.single-wrap article ol li{margin-bottom:.5rem}
.single-wrap article a{color:var(--chilli);border-bottom:1px solid var(--chilli)}
.single-wrap article a:hover{color:var(--chilli-dk)}
.single-wrap article h2,.single-wrap article h3{
  margin:2.5rem 0 1rem;font-weight:400;
}
.single-wrap article blockquote{
  background:var(--off);border-left:3px solid var(--chilli);
  padding:1.5rem 1.75rem;font-family:var(--serif);
  font-size:1.4rem;font-style:italic;
}

/* Pagination */
.pagination{
  margin-top:3rem;display:flex;justify-content:center;
  gap:.5rem;flex-wrap:wrap;
}
.pagination a,.pagination span{
  padding:.6rem 1rem;border:1px solid var(--gray-2);
  font-size:.75rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--gray-4);transition:all var(--ease);
}
.pagination a:hover,.pagination .current{
  background:var(--black);color:var(--white);border-color:var(--black);
}

/* Comments */
.comments-area{
  max-width:780px;margin:4rem auto 0;
  padding-top:3rem;border-top:1px solid var(--gray-2);
}
.comments-area h2,.comments-area h3{
  font-size:1.4rem;margin-bottom:1.5rem;font-family:var(--serif);
}
.comment-list{padding:0}
.comment-list .comment{
  margin-bottom:2rem;padding-bottom:1.5rem;
  border-bottom:1px solid var(--gray-1);list-style:none;
}
.comment-author{font-weight:500;font-size:.85rem;margin-bottom:.25rem}
.comment-meta{font-size:.7rem;color:var(--gray-3);margin-bottom:.75rem}
.comment-body p{font-size:.95rem;color:var(--gray-4)}
.comment-respond input[type="text"],
.comment-respond input[type="email"],
.comment-respond input[type="url"],
.comment-respond textarea{
  width:100%;padding:.875rem 1rem;background:var(--off);
  border:1px solid var(--gray-2);font-family:var(--sans);
  font-size:.9rem;margin-bottom:1rem;
}
.comment-respond .submit{
  background:var(--black);color:var(--white);
  padding:.875rem 2rem;font-size:.72rem;letter-spacing:.13em;
  text-transform:uppercase;border:none;cursor:pointer;
}

/* =========================================================
   PARTNERSHIPS BAND
   ========================================================= */
.partnerships{
  padding:clamp(4rem,8vw,7rem) var(--pad);
  background:var(--white);
  border-top:1px solid var(--gray-1);
}
.partnerships-inner{
  max-width:var(--max);margin:0 auto;
  display:grid;grid-template-columns:1fr 2fr;gap:5rem;
  align-items:start;
}
.partnerships-heading h2{
  font-size:clamp(1.8rem,3.5vw,3rem);
  margin-bottom:1rem;
}
.partnerships-heading p{
  font-size:.95rem;color:var(--gray-4);line-height:1.85;
}
.partnership-cards{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}
.p-card{
  padding:2rem 1.75rem;background:var(--off);
  border-top:2px solid var(--chilli);
}
.p-card h3{font-family:var(--serif);font-size:1.3rem;font-weight:400;margin-bottom:.6rem}
.p-card p{font-size:.9rem;color:var(--gray-4);line-height:1.75;font-weight:300}

/* =========================================================
   QA / QUALITY ASSURANCE
   ========================================================= */
.qa-section{
  padding:clamp(4rem,8vw,7rem) var(--pad);
  background:var(--off);
}
.qa-inner{max-width:var(--max);margin:0 auto}
.qa-header{
  display:grid;grid-template-columns:1fr 1fr;gap:4rem;
  margin-bottom:4rem;align-items:end;
}
.qa-header h2{font-size:clamp(1.8rem,3.5vw,3rem)}
.qa-header p{font-size:1rem;color:var(--gray-4);line-height:1.85}
.qa-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}
.qa-card{
  background:var(--white);padding:2rem 1.75rem;
  border-left:2px solid var(--black);
}
.qa-card .qa-num{
  font-family:var(--serif);font-size:2.2rem;
  color:var(--chilli);margin-bottom:1rem;line-height:1;
}
.qa-card h3{font-family:var(--serif);font-size:1.3rem;font-weight:400;margin-bottom:.5rem}
.qa-card p{font-size:.9rem;color:var(--gray-4);line-height:1.75;font-weight:300}

/* =========================================================
   404 / SEARCH
   ========================================================= */
.error-404,.search-no-results{
  padding:clamp(5rem,10vw,9rem) var(--pad);
  text-align:center;
}
.error-404 h1{font-size:clamp(4rem,10vw,8rem);margin-bottom:1rem}
.error-404 p{font-size:1.05rem;color:var(--gray-4);margin-bottom:2rem}

/* =========================================================
   PAGE BUILDER COMPATIBILITY
   ========================================================= */
/* Elementor full-width templates */
.elementor-page .site-content{padding-top:var(--nav-h)}
body.elementor-template-canvas nav.site-nav,
body.elementor-template-canvas footer.site-footer{display:none}
body.page-template-page-blank nav.site-nav,
body.page-template-page-blank footer.site-footer{display:none}

/* Block editor / Gutenberg */
.entry-content > *{margin-bottom:1.5rem}
.entry-content .alignfull{
  margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw);
  width:100vw;max-width:100vw;
}
.entry-content .alignwide{
  margin-left:calc(50% - 50vw + var(--pad));
  margin-right:calc(50% - 50vw + var(--pad));
}
.wp-block-quote{
  background:var(--off);border-left:3px solid var(--chilli);
  padding:1.5rem 1.75rem;font-family:var(--serif);
  font-size:1.3rem;font-style:italic;
}

/* WooCommerce light touches */
.woocommerce-page .site-content{padding-top:calc(var(--nav-h) + 2rem)}
.woocommerce ul.products li.product .button{
  background:var(--black);color:var(--white);
  border-radius:0;padding:.75rem 1.25rem;
  font-size:.7rem;letter-spacing:.13em;text-transform:uppercase;
}
.woocommerce ul.products li.product .button:hover{
  background:var(--chilli);color:var(--white);
}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media(max-width:960px){
  .about-grid,.contact-grid,.partnerships-inner,.qa-header{grid-template-columns:1fr;gap:3rem}
  .values-grid{grid-template-columns:1fr}
  .qa-grid{grid-template-columns:1fr}
  .partnership-cards{grid-template-columns:1fr}
  .pipeline-steps{grid-template-columns:1fr 1fr}
  .step{border-right:none;border-bottom:1px solid var(--gray-1)}
  .step:nth-child(odd){border-right:1px solid var(--gray-1)}
  .step:last-child{border-bottom:none}
  .process-row{grid-template-columns:1fr;gap:1rem}
  .process-num{font-size:3rem}
  .post-grid{grid-template-columns:1fr 1fr}
  .footer-top{grid-template-columns:1fr 1fr;gap:2rem}
  .nav-links,.nav-actions .btn-black{display:none}
  .hamburger{display:flex}
  nav.site-nav.nav-open .nav-links{
    display:flex!important;flex-direction:column;
    position:absolute;top:var(--nav-h);left:0;right:0;
    background:var(--white);border-bottom:1px solid var(--gray-1);
    padding:1.5rem var(--pad);gap:1.25rem;
    box-shadow:0 8px 24px rgba(0,0,0,.06);z-index:199;
  }
  nav.site-nav.nav-open .nav-links a{
    font-size:.85rem;padding:.25rem 0;
    border-bottom:1px solid var(--gray-1);display:block;
  }
  nav.site-nav.nav-open .nav-links .sub-menu{
    position:static;opacity:1;visibility:visible;
    transform:none;border:none;box-shadow:none;
    padding:.5rem 0 0 1rem;
  }
}
@media(max-width:600px){
  .pipeline-steps{grid-template-columns:1fr}
  .step{border-right:none!important}
  .closing{flex-direction:column}
  .post-grid{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;text-align:center}
}
