/** Shopify CDN: Minification failed

Line 1346:121 Expected ":"

**/
:root{--green:#3B6D11;--green-dark:#27500A;--green-light:#639922;--green-pale:#EAF3DE;--green-mid:#C0DD97;--cream:#FAF9F5;--warm-white:#FFFFFF;--text:#2C2C2A;--text-muted:#5F5E5A;--text-light:#888780;--border:#D3D1C7;--border-light:#EDEBE4;--amber:#D97706;--amber-pale:#FEF3C7;--r:12px;--r-lg:20px;--r-xl:32px;--nav-total:104px;}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:'Nunito Sans',sans-serif;background:var(--cream);color:var(--text);font-size:15px;line-height:1.6;}
h1,h2,h3,h4,h5{font-family:'Fraunces',serif;line-height:1.15;}
img{max-width:100%;display:block;}
a{text-decoration:none;}
.wrap{max-width:1100px;margin:0 auto;padding:0 32px;}
.eyebrow{font-size:11px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:var(--green);display:block;margin-bottom:10px;}
.btn{display:inline-flex;align-items:center;gap:7px;padding:10px 22px;border-radius:var(--r);font-family:'Nunito Sans',sans-serif;font-weight:700;font-size:13px;cursor:pointer;transition:all .2s;text-decoration:none;border:none;white-space:nowrap;}
.btn-green{background:var(--green);color:#fff;}.btn-green:hover{background:var(--green-dark);}
.btn-outline{background:transparent;color:var(--green);border:2px solid var(--green);}.btn-outline:hover{background:var(--green-pale);}
.btn-ghost{background:transparent;color:rgba(255,255,255,.82);border:2px solid rgba(255,255,255,.3);}.btn-ghost:hover{background:rgba(255,255,255,.1);color:#fff;}
.btn-white{background:#fff;color:var(--green-dark);}.btn-white:hover{background:var(--green-pale);}
.btn-lg{padding:13px 30px;font-size:15px;border-radius:var(--r-lg);}

/* ══════════════════════════════════════
   TOP UTILITY BAR
══════════════════════════════════════ */
.topbar{background:var(--green-dark);padding:0;height:36px;display:flex;align-items:center;}
.topbar__inner{max-width:1100px;margin:0 auto;padding:0 32px;width:100%;display:flex;align-items:center;justify-content:space-between;gap:24px;}
.topbar__left{display:flex;align-items:center;gap:20px;}
.topbar__msg{font-size:12px;color:rgba(255,255,255,.65);font-weight:600;}
.topbar__msg strong{color:var(--green-mid);}
.topbar__right{display:flex;align-items:center;gap:20px;}
.topbar__link{font-size:12px;color:rgba(255,255,255,.55);font-weight:600;display:flex;align-items:center;gap:5px;transition:color .2s;}
.topbar__link:hover{color:var(--green-mid);}
.topbar__divider{width:1px;height:14px;background:rgba(255,255,255,.18);}

/* ══════════════════════════════════════
   PRIMARY NAV (Logo + Cart)
══════════════════════════════════════ */
.nav{background:var(--warm-white);border-bottom:1px solid var(--border-light);position:sticky;top:0;z-index:200;}
.nav__inner{max-width:1100px;margin:0 auto;padding:0 32px;height:58px;display:flex;align-items:center;justify-content:space-between;gap:20px;}
.nav__logo{font-family:'Fraunces',serif;font-size:19px;font-weight:700;color:var(--green-dark);flex-shrink:0;text-decoration:none;}
.nav__logo sup{color:var(--green-light);font-size:11px;}
.nav__logo:hover{color:var(--green);}
.nav__center{flex:1;display:flex;justify-content:center;}
.nav__phone-wrap{display:flex;align-items:center;gap:7px;color:var(--text-muted);font-size:13px;font-weight:600;text-decoration:none;transition:color .2s;}
.nav__phone-wrap:hover{color:var(--green);}
.nav__phone-wrap svg{color:var(--green);}
.nav__actions{display:flex;align-items:center;gap:8px;flex-shrink:0;}

/* Cart icon button */
.cart-btn{position:relative;width:42px;height:42px;background:none;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:10px;transition:background .2s;color:var(--text-muted);}
.cart-btn:hover{background:var(--green-pale);color:var(--green);}
.cart-btn svg{width:22px;height:22px;}
.cart-badge{position:absolute;top:5px;right:5px;width:17px;height:17px;background:var(--green);color:#fff;font-size:10px;font-weight:700;border-radius:50%;display:flex;align-items:center;justify-content:center;line-height:1;display:none;border:2px solid #fff;}
.cart-badge.show{display:flex;}
.cart-badge.bump{animation:bump .3s ease;}
@keyframes bump{0%{transform:scale(1)}50%{transform:scale(1.4)}100%{transform:scale(1)}}

/* Hamburger */
.nav__hamburger{display:none;background:none;border:none;cursor:pointer;padding:8px;border-radius:8px;color:var(--text-muted);transition:background .2s;}
.nav__hamburger:hover{background:var(--green-pale);}
.nav__hamburger-icon{width:20px;height:14px;display:flex;flex-direction:column;justify-content:space-between;}
.nav__hamburger-icon span{display:block;width:100%;height:2px;background:var(--green-dark);border-radius:2px;transition:all .28s;}

/* ══════════════════════════════════════
   SECONDARY / PAGE NAV BAR
══════════════════════════════════════ */
.subnav{background:var(--warm-white);border-bottom:2px solid var(--green-pale);position:sticky;top:58px;z-index:199;}
.subnav__inner{max-width:1100px;margin:0 auto;padding:0 32px;height:44px;display:flex;align-items:center;justify-content:space-between;gap:8px;}
.subnav__pages{display:flex;align-items:center;gap:2px;}
.subnav__link{display:flex;align-items:center;gap:6px;padding:6px 14px;border-radius:8px;font-size:13px;font-weight:600;color:var(--text-muted);text-decoration:none;transition:all .18s;white-space:nowrap;position:relative;}
.subnav__link:hover{color:var(--green);background:var(--green-pale);}
.subnav__link.active{color:var(--green);background:var(--green-pale);}
.subnav__link.active::after{content:'';position:absolute;bottom:-2px;left:8px;right:8px;height:2px;background:var(--green);border-radius:2px;}
.subnav__badge{font-size:9px;font-weight:700;background:var(--amber-pale);color:var(--amber);border:1px solid #FDE68A;border-radius:100px;padding:1px 6px;letter-spacing:.3px;text-transform:uppercase;}
.subnav__anchors{display:flex;align-items:center;gap:2px;}
.subnav__anchor{padding:5px 11px;border-radius:8px;font-size:12px;font-weight:600;color:var(--text-light);text-decoration:none;transition:all .18s;white-space:nowrap;}
.subnav__anchor:hover{color:var(--green);background:var(--green-pale);}
.subnav__anchor.active{color:var(--green);}
.subnav__sep{width:1px;height:18px;background:var(--border-light);margin:0 4px;}

/* ══════════════════════════════════════
   MOBILE MENU DRAWER
══════════════════════════════════════ */
.mobile-menu-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:300;opacity:0;pointer-events:none;transition:opacity .3s;}
.mobile-menu-overlay.open{opacity:1;pointer-events:all;}
.mobile-menu{position:fixed;top:0;left:0;bottom:0;width:300px;max-width:85vw;background:var(--warm-white);z-index:301;transform:translateX(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;box-shadow:4px 0 24px rgba(0,0,0,.12);}
.mobile-menu.open{transform:translateX(0);}
.mobile-menu__header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border-light);}
.mobile-menu__logo{font-family:'Fraunces',serif;font-size:16px;font-weight:700;color:var(--green-dark);}
.mobile-menu__logo sup{color:var(--green-light);font-size:11px;}
.mobile-menu__close{background:none;border:none;cursor:pointer;padding:6px;color:var(--text-muted);border-radius:8px;font-size:18px;line-height:1;}
.mobile-menu__nav{flex:1;overflow-y:auto;padding:8px 12px;}
.mob-section-label{font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--text-light);padding:12px 14px 4px;}
.mobile-menu__nav a{display:flex;align-items:center;gap:10px;padding:11px 14px;border-radius:var(--r);color:var(--text);font-size:14px;font-weight:600;text-decoration:none;transition:background .18s;margin-bottom:2px;}
.mobile-menu__nav a:hover{background:var(--green-pale);color:var(--green-dark);}
.mobile-menu__nav a svg{flex-shrink:0;opacity:.5;}
.mob-divider{height:1px;background:var(--border-light);margin:8px 14px;}
.mobile-menu__footer{padding:14px;border-top:1px solid var(--border-light);display:flex;flex-direction:column;gap:9px;}
.mob-btn{display:flex;align-items:center;justify-content:center;gap:7px;padding:12px;border-radius:var(--r);font-family:'Nunito Sans',sans-serif;font-weight:700;font-size:14px;text-decoration:none;border:none;cursor:pointer;transition:background .2s;}
.mob-btn-green{background:var(--green);color:#fff;}.mob-btn-green:hover{background:var(--green-dark);}
.mob-btn-outline{background:var(--green-pale);color:var(--green-dark);}.mob-btn-outline:hover{background:var(--green-mid);}

/* ══════════════════════════════════════
   SLIDE-OUT CART DRAWER
══════════════════════════════════════ */
.cart-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:400;opacity:0;pointer-events:none;transition:opacity .3s;}
.cart-overlay.open{opacity:1;pointer-events:all;}
.cart-drawer{position:fixed;top:0;right:0;bottom:0;width:400px;max-width:92vw;background:var(--warm-white);z-index:401;transform:translateX(100%);transition:transform .32s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;box-shadow:-8px 0 32px rgba(0,0,0,.12);}
.cart-drawer.open{transform:translateX(0);}
.cart-drawer__header{display:flex;align-items:center;justify-content:space-between;padding:20px 22px;border-bottom:1px solid var(--border-light);}
.cart-drawer__title{font-family:'Fraunces',serif;font-size:20px;font-weight:700;color:var(--green-dark);}
.cart-drawer__count{font-size:13px;color:var(--text-muted);margin-top:1px;}
.cart-drawer__close{background:none;border:none;cursor:pointer;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--text-muted);transition:background .2s;font-size:18px;}
.cart-drawer__close:hover{background:var(--green-pale);color:var(--green-dark);}
.cart-drawer__body{flex:1;overflow-y:auto;padding:0;}

/* Empty state */
.cart-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;padding:40px 32px;text-align:center;}
.cart-empty__icon{width:72px;height:72px;background:var(--green-pale);border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:20px;}
.cart-empty__icon svg{width:32px;height:32px;color:var(--green);}
.cart-empty h3{font-family:'Fraunces',serif;font-size:22px;font-weight:700;color:var(--green-dark);margin-bottom:8px;}
.cart-empty p{font-size:14px;color:var(--text-muted);line-height:1.6;margin-bottom:24px;}

/* Cart items */
.cart-items{padding:0 22px;}
.cart-item{display:flex;gap:14px;padding:18px 0;border-bottom:1px solid var(--border-light);}
.cart-item:last-child{border-bottom:none;}
.cart-item__img{width:72px;height:72px;background:var(--green-pale);border-radius:var(--r);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:24px;}
.cart-item__info{flex:1;min-width:0;}
.cart-item__name{font-size:14px;font-weight:700;color:var(--green-dark);margin-bottom:3px;line-height:1.3;}
.cart-item__meta{font-size:12px;color:var(--text-muted);margin-bottom:10px;}
.cart-item__row{display:flex;align-items:center;justify-content:space-between;gap:8px;}
.cart-item__qty{display:flex;align-items:center;gap:0;border:1.5px solid var(--border);border-radius:8px;overflow:hidden;}
.cart-item__qty button{width:30px;height:28px;background:none;border:none;cursor:pointer;font-size:16px;color:var(--green-dark);transition:background .15s;display:flex;align-items:center;justify-content:center;}
.cart-item__qty button:hover{background:var(--green-pale);}
.cart-item__qty span{width:28px;text-align:center;font-size:13px;font-weight:700;color:var(--text);}
.cart-item__price{font-family:'Fraunces',serif;font-size:17px;font-weight:600;color:var(--green);}
.cart-item__remove{background:none;border:none;cursor:pointer;color:var(--text-light);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;transition:color .2s;padding:0;margin-top:2px;}
.cart-item__remove:hover{color:#B91C1C;}

/* Cart footer */
.cart-drawer__footer{padding:20px 22px;border-top:1px solid var(--border-light);background:var(--warm-white);}
.cart-subtotal{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px;}
.cart-subtotal__label{font-size:14px;color:var(--text-muted);font-weight:600;}
.cart-subtotal__val{font-family:'Fraunces',serif;font-size:22px;font-weight:700;color:var(--green-dark);}
.cart-subtotal__note{font-size:11px;color:var(--text-light);margin-bottom:16px;text-align:right;}
.cart-drawer__btns{display:flex;flex-direction:column;gap:10px;}
.cart-cta{display:flex;align-items:center;justify-content:center;gap:8px;padding:14px;border-radius:var(--r-lg);font-family:'Nunito Sans',sans-serif;font-weight:700;font-size:15px;cursor:pointer;transition:all .2s;text-decoration:none;border:none;}
.cart-cta--checkout{background:var(--green);color:#fff;}.cart-cta--checkout:hover{background:var(--green-dark);}
.cart-cta--view{background:transparent;color:var(--green);border:2px solid var(--green);}.cart-cta--view:hover{background:var(--green-pale);}
.cart-delivery-note{display:flex;align-items:center;gap:8px;background:var(--green-pale);border-radius:var(--r);padding:10px 14px;margin-top:12px;}
.cart-delivery-note svg{flex-shrink:0;color:var(--green);}
.cart-delivery-note span{font-size:12px;color:var(--green-dark);font-weight:600;}

/* ══════════════════════════════════════
   BACK TO TOP
══════════════════════════════════════ */
.back-to-top{position:fixed;bottom:28px;right:28px;width:44px;height:44px;background:var(--green-dark);color:#fff;border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(0,0,0,.2);z-index:100;opacity:0;pointer-events:none;transition:opacity .3s,transform .3s;transform:translateY(8px);}
.back-to-top.visible{opacity:1;pointer-events:all;transform:translateY(0);}
.back-to-top:hover{background:var(--green);}

/* ══════════════════════════════════════
   FOOTER
══════════════════════════════════════ */
.footer{background:var(--green-dark);color:rgba(255,255,255,.65);padding:56px 0 32px;}
.footer__top{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:44px;margin-bottom:44px;}
.footer__brand{font-family:'Fraunces',serif;font-size:18px;font-weight:700;color:#fff;margin-bottom:12px;}
.footer__tagline{font-size:13px;line-height:1.75;color:rgba(255,255,255,.5);margin-bottom:18px;}
.footer__contact{font-size:13px;display:flex;flex-direction:column;gap:4px;}
.footer__contact a{color:var(--green-mid);font-weight:600;text-decoration:none;}.footer__contact a:hover{opacity:.8;}
.footer__contact span{font-size:12px;color:rgba(255,255,255,.34);}
.footer__col h5{font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,.32);margin-bottom:14px;}
.footer__col ul{list-style:none;display:flex;flex-direction:column;gap:8px;}
.footer__col a{color:rgba(255,255,255,.55);font-size:13px;transition:color .2s;text-decoration:none;}.footer__col a:hover{color:var(--green-mid);}
.footer__bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:24px;display:flex;justify-content:space-between;align-items:center;font-size:12px;flex-wrap:wrap;gap:12px;color:rgba(255,255,255,.3);}
.footer__legal{display:flex;gap:20px;}
.footer__legal a{color:rgba(255,255,255,.3);text-decoration:none;}.footer__legal a:hover{color:rgba(255,255,255,.6);}

/* ══════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════ */
@media(max-width:900px){
  .nav__hamburger{display:flex;}
  .nav__phone-wrap{display:none;}
  .subnav__anchors{display:none;}
  .footer__top{grid-template-columns:1fr 1fr;gap:32px;}
}
@media(max-width:700px){
  .subnav__pages{gap:0;}
  .subnav__link{padding:6px 10px;font-size:12px;}
}
@media(max-width:600px){
  .wrap{padding:0 20px;}
  .topbar{display:none;}
  .nav__inner{padding:0 20px;}
  .subnav__inner{padding:0 20px;}
  .cart-drawer{width:100%;max-width:100%;}
  .footer__top{grid-template-columns:1fr;gap:24px;}
  .back-to-top{bottom:20px;right:16px;}
}

/* ══ SUBNAV DROPDOWNS ═══════════════════════════════════════ */
.snav-item{position:relative;display:flex;align-items:stretch;}
.snav-link{display:flex;align-items:center;gap:5px;padding:0 14px;height:44px;font-size:13px;font-weight:600;color:var(--text-muted);text-decoration:none;transition:color .15s,background .15s;white-space:nowrap;cursor:pointer;border:none;background:none;font-family:'Nunito Sans',sans-serif;}
.snav-link:hover,.snav-item:hover>.snav-link{color:var(--green);background:var(--green-pale);}
.snav-link.active,.snav-item.active>.snav-link{color:var(--green);background:var(--green-pale);position:relative;}
.snav-link.active::after,.snav-item.active>.snav-link::after{content:'';position:absolute;bottom:-2px;left:8px;right:8px;height:2px;background:var(--green);border-radius:2px;}
.snav-chevron{width:12px;height:12px;color:var(--text-light);transition:transform .2s;flex-shrink:0;}
.snav-item:hover .snav-chevron{transform:rotate(180deg);color:var(--green);}
.snav-dropdown{position:absolute;top:calc(100% + 2px);left:0;min-width:220px;background:var(--warm-white);border:1px solid var(--border-light);border-radius:var(--r-lg);box-shadow:0 8px 32px rgba(0,0,0,.12);padding:8px;opacity:0;pointer-events:none;transform:translateY(-6px);transition:opacity .18s,transform .18s;z-index:300;}
.snav-item:hover .snav-dropdown,.snav-item:focus-within .snav-dropdown{opacity:1;pointer-events:all;transform:translateY(0);}
.snav-dropdown a{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--r);font-size:13px;font-weight:600;color:var(--text);text-decoration:none;transition:background .15s,color .15s;}
.snav-dropdown a:hover{background:var(--green-pale);color:var(--green-dark);}
.snav-dropdown a.active{background:var(--green-pale);color:var(--green);}
.snav-dropdown__icon{font-size:16px;width:24px;text-align:center;flex-shrink:0;}
.snav-dropdown__sub{font-size:11px;color:var(--text-light);font-weight:400;display:block;margin-top:1px;}
.snav-dropdown-divider{height:1px;background:var(--border-light);margin:4px 0;}
@media(max-width:900px){.snav-dropdown{display:none !important;}}
@media(max-width:700px){.snav-link{padding:0 9px;font-size:12px;}.snav-chevron{display:none;}}
@media(max-width:500px){.subnav__inner{overflow-x:auto;scrollbar-width:none;}.subnav__inner::-webkit-scrollbar{display:none;}}


/* ══════════════════════════════════════════════════════════════
   MASTERS WEEK SECTION
   Toggle visibility: change data-visible="true" to "false"
   Shopify theme editor: Section Settings > "Show this section"
   ══════════════════════════════════════════════════════════════ */
.masters-moment[data-visible="false"]{ display:none; }
.masters-moment{
  position:relative; overflow:hidden;
  height:520px; display:flex; align-items:stretch;
}
/* Photo side */
.masters-photo{
  flex:0 0 62%; position:relative; overflow:hidden;
}
.masters-photo__img{
  width:100%; height:100%; object-fit:cover; object-position:center;
  transition:transform 8s ease;
}
.masters-moment:hover .masters-photo__img{ transform:scale(1.04); }

/* Placeholder (remove once real photo is in) */
.masters-photo__placeholder{
  width:100%; height:100%;
  background:linear-gradient(160deg, #0d2e0a 0%, #1a4d10 30%, #2d6e1a 55%, #3a7d1f 75%, #4a8f2a 100%);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:14px; padding:40px;
}
.masters-ph-icon{ font-size:52px; opacity:.5; }
.masters-ph-title{
  font-family:'Fraunces',serif; font-size:18px; font-weight:600;
  color:rgba(255,255,255,.6); text-align:center; line-height:1.4;
}
.masters-ph-brief{
  font-size:12px; color:rgba(255,255,255,.35); text-align:center;
  line-height:1.7; max-width:360px;
}
.masters-ph-spec{
  display:flex; gap:8px; flex-wrap:wrap; justify-content:center; margin-top:4px;
}
.masters-ph-spec span{
  background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.15);
  border-radius:100px; padding:3px 10px;
  font-size:10px; font-weight:700; color:rgba(255,255,255,.55); letter-spacing:.5px;
}
/* Fade from photo into text panel */
.masters-photo::after{
  content:''; position:absolute; top:0; right:0; bottom:0; width:160px;
  background:linear-gradient(to right, transparent, var(--green-dark));
  pointer-events:none;
}

/* Text panel */
.masters-text{
  flex:1; background:var(--green-dark); padding:52px 48px 52px 28px;
  display:flex; flex-direction:column; justify-content:center; position:relative;
}
.masters-text::before{
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse 80% 80% at 80% 50%, rgba(99,153,34,.18) 0%, transparent 70%);
  pointer-events:none;
}
.masters-week-badge{
  display:inline-flex; align-items:center; gap:7px;
  background:rgba(192,221,151,.15); color:var(--green-mid);
  border:1px solid rgba(192,221,151,.25); border-radius:100px;
  padding:5px 14px; font-size:11px; font-weight:700;
  letter-spacing:1.5px; text-transform:uppercase;
  margin-bottom:20px; width:fit-content; position:relative; z-index:1;
}
.masters-week-badge::before{
  content:''; width:6px; height:6px; background:var(--green-mid);
  border-radius:50%; animation:pulse-dot 2s infinite;
}
@keyframes pulse-dot{
  0%,100%{ opacity:1; transform:scale(1); }
  50%{ opacity:.4; transform:scale(.7); }
}
.masters-headline{
  font-family:'Fraunces',serif;
  font-size:clamp(26px,3.2vw,42px);
  font-weight:700; color:#fff; line-height:1.1;
  margin-bottom:16px; position:relative; z-index:1;
}
.masters-headline em{
  font-style:italic; color:var(--green-mid);
}
.masters-body{
  font-size:15px; color:rgba(255,255,255,.65);
  line-height:1.8; margin-bottom:28px;
  max-width:360px; position:relative; z-index:1;
}
.masters-origin{
  display:flex; align-items:center; gap:9px;
  margin-bottom:28px; position:relative; z-index:1;
}
.masters-origin__dot{
  width:8px; height:8px; background:var(--green-mid);
  border-radius:50%; flex-shrink:0;
}
.masters-origin__text{
  font-size:12px; font-weight:700; color:rgba(255,255,255,.5);
  letter-spacing:.5px; text-transform:uppercase;
}
.masters-ctas{
  display:flex; gap:12px; flex-wrap:wrap; position:relative; z-index:1;
}
/* Bottom caption strip */
.masters-caption{
  position:absolute; bottom:0; left:0; right:0;
  background:rgba(0,0,0,.5); backdrop-filter:blur(4px);
  padding:10px 24px;
  display:flex; align-items:center; justify-content:space-between;
  gap:16px; z-index:10;
}
.masters-caption__text{
  font-size:11px; color:rgba(255,255,255,.45); font-style:italic;
}
@media(max-width:900px){
  .masters-moment{ flex-direction:column; height:auto; }
  .masters-photo{ flex:none; height:300px; }
  .masters-photo::after{ display:none; }
  .masters-text{ padding:40px 28px; }
  .masters-headline{ font-size:28px; }
}
@media(max-width:600px){
  .masters-photo{ height:240px; }
  .masters-text{ padding:32px 20px; }
}

/* ── PAGE-SPECIFIC STYLES FOR HOMEPAGE ── */

/* ════════════════════════════════════════════
   DESIGN TOKENS
════════════════════════════════════════════ */
:root {
  --green:        #3B6D11;
  --green-dark:   #27500A;
  --green-light:  #639922;
  --green-pale:   #EAF3DE;
  --green-mid:    #C0DD97;
  --cream:        #FAF9F5;
  --warm-white:   #FFFFFF;
  --text:         #2C2C2A;
  --text-muted:   #5F5E5A;
  --text-light:   #888780;
  --border:       #D3D1C7;
  --border-light: #EDEBE4;
  --amber:        #D97706;
  --amber-pale:   #FEF3C7;
  --r:            12px;
  --r-lg:         20px;
  --r-xl:         32px;
  --nav-h:        68px;
}

/* ════════════════════════════════════════════
   RESET & BASE
════════════════════════════════════════════ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body { font-family: 'Nunito Sans', sans-serif; background: var(--cream); color: var(--text); font-size: 16px; line-height: 1.6; -webkit-font-smoothing: antialiased; }
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
h1,h2,h3,h4,h5 { font-family: 'Fraunces', serif; line-height: 1.15; }

/* ════════════════════════════════════════════
   UTILITIES
════════════════════════════════════════════ */
.wrap { max-width: 1200px; margin: 0 auto; padding: 0 48px; }
.eyebrow { font-size: 11px; font-weight: 700; letter-spacing: 2.5px; text-transform: uppercase; color: var(--green); display: block; margin-bottom: 12px; }

.btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; padding: 11px 24px; border-radius: var(--r); font-family: 'Nunito Sans', sans-serif; font-weight: 700; font-size: 14px; cursor: pointer; transition: all 0.2s; text-decoration: none; border: none; letter-spacing: 0.2px; white-space: nowrap; }
.btn-green  { background: var(--green); color: #fff; }
.btn-green:hover  { background: var(--green-dark); }
.btn-outline { background: transparent; color: var(--green); border: 2px solid var(--green); }
.btn-outline:hover { background: var(--green-pale); }
.btn-ghost  { background: transparent; color: rgba(255,255,255,.82); border: 2px solid rgba(255,255,255,.3); }
.btn-ghost:hover  { background: rgba(255,255,255,.1); color: #fff; }
.btn-white  { background: #fff; color: var(--green-dark); }
.btn-white:hover  { background: var(--green-pale); }
.btn-lg     { padding: 15px 36px; font-size: 16px; border-radius: var(--r-lg); }

/* ════════════════════════════════════════════
   LOYALTY BAR
════════════════════════════════════════════ */
.loyalty-bar { background: var(--green-pale); border-bottom: 1px solid var(--green-mid); padding: 9px 48px; display: flex; align-items: center; justify-content: center; gap: 20px; font-size: 13px; color: var(--green-dark); font-weight: 600; flex-wrap: wrap; }
.loyalty-bar a { color: var(--green); font-weight: 700; text-decoration: underline; text-underline-offset: 2px; }

/* ════════════════════════════════════════════
   NAV
════════════════════════════════════════════ */
.nav { background: var(--warm-white); border-bottom: 1px solid var(--border-light); position: sticky; top: 0; z-index: 200; height: var(--nav-h); }
.nav__inner { display: flex; align-items: center; justify-content: space-between; height: 100%; }
.nav__logo { font-family: 'Fraunces', serif; font-size: 20px; font-weight: 700; color: var(--green-dark); }
.nav__logo sup { color: var(--green-light); font-size: 14px; vertical-align: super; }
.nav__links { display: flex; gap: 28px; list-style: none; }
.nav__links a { color: var(--text-muted); font-size: 14px; font-weight: 600; transition: color .2s; }
.nav__links a:hover { color: var(--green); }
.nav__right { display: flex; align-items: center; gap: 14px; }
.nav__phone { font-size: 13px; color: var(--text-muted); font-weight: 600; }
.nav__cart { display: flex; align-items: center; gap: 7px; background: var(--green); color: #fff; padding: 9px 18px; border-radius: var(--r); font-size: 13px; font-weight: 700; border: none; cursor: pointer; font-family: 'Nunito Sans', sans-serif; }

/* ════════════════════════════════════════════
   HERO
════════════════════════════════════════════ */
.hero { background: var(--green-dark); color: #fff; overflow: hidden; position: relative; }
.hero__bg { position: absolute; inset: 0; background: radial-gradient(ellipse 70% 90% at 75% 40%, rgba(99,153,34,.32) 0%, transparent 65%); }
.hero__grain { position: absolute; inset: 0; opacity: .04; background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E"); }
.hero__inner { max-width: 1200px; margin: 0 auto; padding: 96px 48px 100px; display: grid; grid-template-columns: 1fr 1fr; gap: 72px; align-items: center; position: relative; z-index: 1; }
.hero__pill { display: inline-flex; align-items: center; gap: 8px; background: rgba(192,221,151,.15); color: var(--green-mid); font-size: 12px; font-weight: 700; letter-spacing: 1.8px; text-transform: uppercase; padding: 7px 16px; border-radius: 100px; margin-bottom: 24px; border: 1px solid rgba(192,221,151,.25); }
.hero__pill-dot { width: 6px; height: 6px; background: var(--green-mid); border-radius: 50%; }
.hero__title { font-size: clamp(40px, 5.5vw, 66px); font-weight: 700; line-height: 1.05; margin-bottom: 22px; }
.hero__title em { font-style: italic; color: var(--green-mid); }
.hero__body { font-size: 18px; line-height: 1.72; color: rgba(255,255,255,.7); margin-bottom: 36px; max-width: 460px; }
.hero__ctas { display: flex; gap: 14px; flex-wrap: wrap; margin-bottom: 48px; }
.hero__stats { display: flex; gap: 0; padding-top: 40px; border-top: 1px solid rgba(255,255,255,.12); }
.hero__stat { flex: 1; padding-right: 32px; border-right: 1px solid rgba(255,255,255,.12); margin-right: 32px; }
.hero__stat:last-child { border-right: none; margin-right: 0; padding-right: 0; }
.hero__stat-val { font-family: 'Fraunces', serif; font-size: 32px; font-weight: 700; color: var(--green-mid); line-height: 1; }
.hero__stat-lbl { font-size: 13px; color: rgba(255,255,255,.48); margin-top: 4px; }

.hero__visual { position: relative; }
.hero__img-frame { border-radius: var(--r-xl); overflow: hidden; aspect-ratio: 4/5; background: linear-gradient(145deg, #1e3d08 0%, #3B6D11 55%, #639922 100%); display: flex; align-items: center; justify-content: center; }
.hero__img-frame img { width: 100%; height: 100%; object-fit: cover; }
.hero__img-placeholder { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 14px; opacity: .35; }
.hero__badge { position: absolute; bottom: -18px; right: -18px; background: var(--warm-white); border-radius: 50%; width: 110px; height: 110px; display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; padding: 12px; box-shadow: 0 8px 32px rgba(0,0,0,.15); }
.hero__badge-num { font-family: 'Fraunces', serif; font-size: 26px; font-weight: 700; color: var(--green); line-height: 1; }
.hero__badge-txt { font-size: 10px; font-weight: 700; color: var(--green-dark); line-height: 1.3; margin-top: 3px; }

/* ════════════════════════════════════════════
   BENEFITS
════════════════════════════════════════════ */
.benefits { padding: 96px 0; background: var(--cream); }
.benefits__header { text-align: center; margin-bottom: 64px; }
.benefits__title { font-size: clamp(30px, 4vw, 50px); font-weight: 700; color: var(--green-dark); margin-bottom: 14px; }
.benefits__sub { font-size: 18px; color: var(--text-muted); max-width: 580px; margin: 0 auto; line-height: 1.7; }
.benefits__grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; }
.benefit { background: var(--warm-white); border: 1px solid var(--border-light); border-radius: var(--r-lg); padding: 36px 40px; transition: border-color .2s, transform .2s; }
.benefit:hover { border-color: var(--green-mid); transform: translateY(-3px); }
.benefit__tag { display: inline-block; background: var(--green-pale); color: var(--green); font-size: 11px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; padding: 4px 11px; border-radius: 100px; margin-bottom: 18px; }
.benefit h3 { font-size: 23px; font-weight: 600; color: var(--green-dark); margin-bottom: 11px; }
.benefit p { font-size: 15px; color: var(--text-muted); line-height: 1.75; }

/* ════════════════════════════════════════════
   PRODUCT GRID
════════════════════════════════════════════ */
.pgrid { padding: 96px 0; background: var(--warm-white); }
.pgrid__header { text-align: center; margin-bottom: 32px; }
.pgrid__title { font-size: clamp(28px, 4vw, 46px); font-weight: 700; color: var(--green-dark); margin-bottom: 12px; }
.pgrid__sub { font-size: 17px; color: var(--text-muted); max-width: 540px; margin: 0 auto; }

/* Delivery toggle */
.d-toggle { display: flex; justify-content: center; align-items: center; gap: 10px; margin-bottom: 20px; flex-wrap: wrap; }
.d-label { font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; color: var(--text-muted); }
.d-btn { display: flex; align-items: center; gap: 7px; padding: 9px 22px; border-radius: 100px; border: 2px solid var(--border); background: transparent; font-size: 14px; font-weight: 700; color: var(--text-muted); cursor: pointer; font-family: 'Nunito Sans', sans-serif; transition: all .18s; }
.d-btn:hover:not(.active) { border-color: var(--green); color: var(--green); }
.d-btn.active { background: var(--green-dark); border-color: var(--green-dark); color: #fff; }
.d-info { font-size: 12px; background: var(--amber-pale); border: 1px solid #FDE68A; color: #92400E; border-radius: var(--r); padding: 9px 18px; text-align: center; display: none; width: 100%; max-width: 680px; }
.d-info.show { display: block; }

/* Filter tabs */
.tabs { display: flex; gap: 8px; justify-content: center; margin-bottom: 40px; flex-wrap: wrap; }
.tab { padding: 9px 22px; border-radius: 100px; border: 2px solid var(--border); background: transparent; font-size: 13px; font-weight: 700; color: var(--text-muted); cursor: pointer; transition: all .18s; font-family: 'Nunito Sans', sans-serif; }
.tab:hover { border-color: var(--green); color: var(--green); }
.tab.active { background: var(--green-dark); border-color: var(--green-dark); color: #fff; }

/* Product cards */
.cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.card { border: 1px solid var(--border-light); border-radius: var(--r-lg); overflow: hidden; background: var(--cream); transition: box-shadow .2s, transform .2s, border-color .2s; position: relative; }
.card:hover { box-shadow: 0 12px 36px rgba(59,109,17,.1); transform: translateY(-4px); border-color: var(--green-mid); }
.card__img { height: 198px; background: var(--green-pale); display: flex; align-items: center; justify-content: center; overflow: hidden; position: relative; }
.card__img img { width: 100%; height: 100%; object-fit: cover; transition: transform .3s; }
.card:hover .card__img img { transform: scale(1.05); }
.card__img-ph { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 8px; opacity: .45; }
.card__badge { position: absolute; top: 14px; left: 14px; color: #fff; font-size: 11px; font-weight: 700; padding: 5px 12px; border-radius: 100px; letter-spacing: .4px; }
.card__badge--pop  { background: var(--green-dark); }
.card__badge--val  { background: var(--green-light); }
.card__badge--bulk { background: var(--green); }
.card__body { padding: 22px 24px; }
.card__savings { display: inline-block; background: var(--green-pale); border: 1px solid var(--green-mid); color: var(--green); font-size: 11px; font-weight: 700; padding: 3px 10px; border-radius: 100px; margin-bottom: 8px; }
.card__grade { font-size: 11px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; color: var(--green); margin-bottom: 5px; }
.card__name { font-family: 'Fraunces', serif; font-size: 19px; font-weight: 600; color: var(--green-dark); margin-bottom: 7px; }
.card__desc { font-size: 13px; color: var(--text-muted); line-height: 1.65; margin-bottom: 18px; }
.card__foot { display: flex; align-items: flex-end; justify-content: space-between; gap: 10px; padding-top: 16px; border-top: 1px solid var(--border-light); flex-wrap: wrap; }
.card__from { font-size: 11px; color: var(--text-light); text-transform: uppercase; letter-spacing: .5px; }
.card__price { font-family: 'Fraunces', serif; font-size: 26px; font-weight: 600; color: var(--green); line-height: 1.1; }
.card__coverage { font-size: 11px; color: var(--green); font-weight: 600; margin-top: 2px; }
.card__delnote { font-size: 11px; margin-top: 5px; font-style: italic; }
.card__pprice { font-size: 12px; color: var(--text-muted); margin-top: 2px; }
.card__btn { background: var(--green); color: #fff; border: none; padding: 11px 18px; border-radius: var(--r); font-size: 13px; font-weight: 700; cursor: pointer; font-family: 'Nunito Sans', sans-serif; transition: background .18s; white-space: nowrap; }
.card__btn:hover { background: var(--green-dark); }

/* ════════════════════════════════════════════
   HOW IT WORKS
════════════════════════════════════════════ */
.how { background: var(--cream); padding: 96px 0; }
.how__inner { display: grid; grid-template-columns: 1fr 1fr; gap: 96px; align-items: center; }
.how__title { font-size: clamp(28px, 4vw, 46px); font-weight: 700; color: var(--green-dark); margin-bottom: 12px; }
.how__sub { font-size: 17px; color: var(--text-muted); line-height: 1.7; max-width: 440px; }
.how__steps { margin-top: 44px; display: flex; flex-direction: column; gap: 36px; }
.step { display: flex; gap: 22px; }
.step__num { width: 46px; height: 46px; border-radius: 50%; background: var(--green-pale); color: var(--green); font-family: 'Fraunces', serif; font-size: 20px; font-weight: 700; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.step h4 { font-size: 18px; font-weight: 600; color: var(--green-dark); margin-bottom: 6px; }
.step p { font-size: 15px; color: var(--text-muted); line-height: 1.7; }
.how__visual { background: var(--green-pale); border-radius: var(--r-xl); aspect-ratio: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; padding: 48px; gap: 6px; }
.how__visual-num { font-family: 'Fraunces', serif; font-size: 72px; font-weight: 700; color: var(--green-dark); line-height: 1; }
.how__visual-unit { font-size: 20px; color: var(--green); font-weight: 700; }
.how__visual-sub { font-size: 14px; color: var(--text-muted); margin-top: 4px; }

/* ════════════════════════════════════════════
   CALCULATOR
════════════════════════════════════════════ */
.calc { background: var(--warm-white); padding: 96px 0; }
.calc__header { text-align: center; margin-bottom: 36px; }
.calc__title { font-size: clamp(28px, 4vw, 46px); font-weight: 700; color: var(--green-dark); margin-bottom: 12px; }
.calc__sub { font-size: 17px; color: var(--text-muted); max-width: 520px; margin: 0 auto; }

.calc__box { background: var(--green-dark); border-radius: var(--r-xl); padding: 52px; display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: start; position: relative; overflow: hidden; max-width: 1000px; margin: 0 auto; }
.calc__box::before { content: ''; position: absolute; inset: 0; background: repeating-linear-gradient(42deg, rgba(255,255,255,.012) 0, rgba(255,255,255,.012) 1px, transparent 1px, transparent 24px); pointer-events: none; }
.calc__left { position: relative; z-index: 1; }
.calc__eyebrow { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 2px; color: var(--green-mid); margin-bottom: 14px; display: block; }
.calc__left h3 { font-family: 'Fraunces', serif; font-size: 28px; font-weight: 700; color: #fff; margin-bottom: 16px; line-height: 1.2; }
.calc__left p { font-size: 15px; color: rgba(255,255,255,.6); line-height: 1.72; }
.calc__left p strong { color: rgba(255,255,255,.9); }
.calc__specs { margin-top: 28px; display: flex; flex-direction: column; gap: 10px; }
.calc__spec { display: flex; align-items: center; gap: 10px; font-size: 14px; color: rgba(255,255,255,.6); }
.calc__spec-dot { width: 6px; height: 6px; background: var(--green-mid); border-radius: 50%; flex-shrink: 0; }

.calc__right { position: relative; z-index: 1; }
.calc__row2 { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 14px; }
.calc__label { display: block; font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; color: rgba(255,255,255,.5); margin-bottom: 7px; }
.calc__input { width: 100%; background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.18); border-radius: var(--r); padding: 12px 14px; font-size: 15px; color: #fff; font-family: 'Nunito Sans', sans-serif; outline: none; transition: border-color .18s; }
.calc__input::placeholder { color: rgba(255,255,255,.3); }
.calc__input:focus { border-color: var(--green-mid); }
.calc__input option { background: var(--green-dark); }

.calc__result { margin-top: 18px; display: none; }
.calc__banner { font-size: 13px; font-weight: 600; color: var(--green-mid); text-align: center; margin-bottom: 14px; background: rgba(192,221,151,.14); border: 1px solid rgba(192,221,151,.22); border-radius: var(--r); padding: 10px 16px; }
.calc__cols { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.calc__col { background: rgba(0,0,0,.2); border-radius: var(--r); padding: 18px 14px; display: flex; flex-direction: column; align-items: center; text-align: center; }
.calc__col-lbl { font-size: 11px; text-transform: uppercase; letter-spacing: 1px; color: rgba(255,255,255,.42); margin-bottom: 6px; }
.calc__col-qty { font-family: 'Fraunces', serif; font-size: 28px; font-weight: 700; color: var(--green-mid); line-height: 1.1; }
.calc__col-unit { font-size: 11px; color: rgba(255,255,255,.36); margin-top: 4px; }
.calc__col-cost { font-size: 15px; font-weight: 700; color: #fff; margin: 10px 0 4px; }
.calc__cart-btn { display: block; width: 100%; margin-top: 12px; background: var(--green); color: #fff; font-size: 13px; font-weight: 700; padding: 10px 14px; border-radius: var(--r); text-align: center; border: none; cursor: pointer; font-family: 'Nunito Sans', sans-serif; transition: background .18s; }
.calc__cart-btn:hover { background: var(--green-light); }

/* ════════════════════════════════════════════
   WHY US
════════════════════════════════════════════ */
.why { background: var(--cream); padding: 96px 0; }
.why__inner { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center; }
.why__title { font-size: clamp(28px, 4vw, 46px); font-weight: 700; color: var(--green-dark); margin-bottom: 14px; }
.why__lead { font-size: 17px; color: var(--text-muted); line-height: 1.72; max-width: 480px; }
.why__list { margin-top: 40px; display: flex; flex-direction: column; gap: 24px; }
.why-item { display: flex; gap: 18px; }
.why-item__check { width: 26px; height: 26px; border-radius: 50%; background: var(--green-pale); display: flex; align-items: center; justify-content: center; flex-shrink: 0; margin-top: 1px; }
.why-item h4 { font-size: 16px; font-weight: 700; color: var(--green-dark); margin-bottom: 3px; }
.why-item p { font-size: 14px; color: var(--text-muted); line-height: 1.65; }
.testimonial { background: var(--green-pale); border-radius: var(--r-xl); padding: 52px 48px; }
.testimonial__stars { color: #F0A500; font-size: 22px; letter-spacing: 3px; margin-bottom: 20px; }
.testimonial__quote { font-family: 'Fraunces', serif; font-size: 20px; font-style: italic; color: var(--green-dark); line-height: 1.55; margin-bottom: 22px; }
.testimonial__author { font-size: 14px; font-weight: 700; color: var(--green); }
.testimonial__loc { font-size: 13px; color: var(--text-muted); margin-top: 2px; }

/* ════════════════════════════════════════════
   REVIEWS
════════════════════════════════════════════ */
.reviews { background: var(--warm-white); padding: 96px 0; }
.reviews__header { text-align: center; margin-bottom: 52px; }
.reviews__title { font-size: clamp(28px, 4vw, 46px); font-weight: 700; color: var(--green-dark); margin-bottom: 12px; }
.reviews__sub { font-size: 17px; color: var(--text-muted); max-width: 480px; margin: 0 auto; }
.reviews__rating { display: flex; align-items: center; justify-content: center; gap: 16px; margin: 28px 0 52px; flex-wrap: wrap; }
.reviews__stars { color: #F0A500; font-size: 32px; letter-spacing: 4px; }
.reviews__score { font-family: 'Fraunces', serif; font-size: 48px; font-weight: 700; color: var(--green-dark); line-height: 1; }
.reviews__count { font-size: 14px; color: var(--text-muted); margin-top: 4px; }
.reviews__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.review-card { background: var(--cream); border: 1px solid var(--border-light); border-radius: var(--r-lg); padding: 28px; transition: border-color .2s; }
.review-card:hover { border-color: var(--green-mid); }
.review-card__stars { color: #F0A500; font-size: 16px; letter-spacing: 2px; margin-bottom: 14px; }
.review-card__body { font-family: 'Fraunces', serif; font-size: 17px; font-style: italic; color: var(--green-dark); line-height: 1.55; margin-bottom: 18px; }
.review-card__author { font-size: 14px; font-weight: 700; color: var(--green); }
.review-card__loc { font-size: 13px; color: var(--text-muted); margin-top: 2px; }
.reviews__cta { text-align: center; margin-top: 48px; }
.reviews__cta p { font-size: 13px; color: var(--text-muted); margin-top: 14px; }

/* ════════════════════════════════════════════
   GUARANTEE BAR
════════════════════════════════════════════ */
.guarantee{background:var(--warm-white);border-top:1px solid var(--border-light);border-bottom:1px solid var(--border-light);padding:52px 0;}
.guarantee__inner{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:32px;}
.guarantee__badge { width: 112px; height: 112px; border-radius: 50%; background: var(--green-pale); border: 3px solid var(--green-mid); display: flex; flex-direction: column; align-items: center; justify-content: center; flex-shrink: 0; text-align: center; padding: 14px; }
.guarantee__badge-num { font-family: 'Fraunces', serif; font-size: 26px; font-weight: 700; color: var(--green); line-height: 1; }
.guarantee__badge-txt { font-size: 10px; font-weight: 700; color: var(--green-dark); line-height: 1.3; margin-top: 3px; }
.guarantee__content h2 { font-size: 26px; font-weight: 700; color: var(--green-dark); margin-bottom: 8px; }
.guarantee__content p { font-size: 15px; color: var(--text-muted); max-width: 540px; line-height: 1.7; }
.trust-badges{display:flex;gap:28px;flex-wrap:wrap;align-items:center;}
.trust-badge { text-align: center; }
.trust-badge__icon { font-size: 26px; margin-bottom: 6px; }
.trust-badge__lbl { font-size: 11px; font-weight: 700; color: var(--text-light); text-transform: uppercase; letter-spacing: .8px; line-height: 1.4; }

/* ════════════════════════════════════════════
   FOOTER
════════════════════════════════════════════ */
.footer { background: var(--green-dark); color: rgba(255,255,255,.65); padding: 72px 0 40px; }
.footer__top { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 52px; margin-bottom: 56px; }
.footer__brand { font-family: 'Fraunces', serif; font-size: 20px; font-weight: 700; color: #fff; margin-bottom: 14px; }
.footer__tagline { font-size: 14px; line-height: 1.75; color: rgba(255,255,255,.5); margin-bottom: 22px; }
.footer__contact { font-size: 14px; display: flex; flex-direction: column; gap: 5px; }
.footer__contact a { color: var(--green-mid); font-weight: 600; transition: opacity .2s; }
.footer__contact a:hover { opacity: .75; }
.footer__contact span { font-size: 13px; color: rgba(255,255,255,.34); }
.footer__col h5 { font-size: 11px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; color: rgba(255,255,255,.32); margin-bottom: 18px; }
.footer__col ul { list-style: none; display: flex; flex-direction: column; gap: 10px; }
.footer__col a { color: rgba(255,255,255,.58); font-size: 14px; transition: color .2s; }
.footer__col a:hover { color: var(--green-mid); }
.footer__bottom { border-top: 1px solid rgba(255,255,255,.1); padding-top: 28px; display: flex; justify-content: space-between; align-items: center; font-size: 13px; flex-wrap: wrap; gap: 14px; color: rgba(255,255,255,.3); }
.footer__legal { display: flex; gap: 24px; }
.footer__legal a { color: rgba(255,255,255,.3); transition: color .2s; }
.footer__legal a:hover { color: rgba(255,255,255,.6); }

/* ════════════════════════════════════════════
   RESPONSIVE
════════════════════════════════════════════ */
@media(max-width:1024px) {
  .wrap { padding: 0 32px; }
  .cards { grid-template-columns: repeat(2,1fr); }
  .footer__top { grid-template-columns: 1fr 1fr; gap: 36px; }
}
@media(max-width:899px) {
  .hero__inner,.how__inner,.why__inner,.calc__box { grid-template-columns: 1fr; gap: 48px; }
  .hero__inner { padding: 72px 32px; }
  .hero__img-frame { aspect-ratio: 16/9; }
  .hero__badge { right: 12px; bottom: -12px; }
  .reviews__grid { grid-template-columns: 1fr 1fr; }
}
@media(max-width:749px) {
  .wrap { padding: 0 20px; }
  .loyalty-bar,.nav__links,.nav__phone { display: none; }
  .benefits__grid,.cards { grid-template-columns: 1fr; }
  .calc__box { padding: 32px 24px; }
  .calc__row2,.calc__cols { grid-template-columns: 1fr; }
  .reviews__grid { grid-template-columns: 1fr; }
  .benefits,.pgrid,.how,.calc,.why,.reviews { padding: 60px 0; }
  .guarantee__inner{grid-template-columns:1fr;justify-items:start;}.trust-badges{justify-content:flex-start;}
  .footer__top { grid-template-columns: 1fr; gap: 28px; }
}

/* ── HAMBURGER ── */
.nav__hamburger{display:none;background:none;border:none;cursor:pointer;padding:6px;border-radius:8px;color:var(--text);transition:background .2s;}
.nav__hamburger:hover{background:var(--green-pale);}
.nav__hamburger-icon{width:22px;height:16px;display:flex;flex-direction:column;justify-content:space-between;}
.nav__hamburger-icon span{display:block;width:100%;height:2px;background:var(--green-dark);border-radius:2px;transition:all .3s;}
/* ── MOBILE MENU ── */
.mobile-menu-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:300;opacity:0;pointer-events:none;transition:opacity .3s;}
.mobile-menu-overlay.open{opacity:1;pointer-events:all;}
.mobile-menu{position:fixed;top:0;left:0;bottom:0;width:300px;max-width:85vw;background:var(--warm-white);z-index:301;transform:translateX(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;box-shadow:4px 0 24px rgba(0,0,0,.12);}
.mobile-menu.open{transform:translateX(0);}
.mobile-menu__header{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid var(--border-light);}
.mobile-menu__logo{font-family:'Fraunces',serif;font-size:16px;font-weight:700;color:var(--green-dark);text-decoration:none;}
.mobile-menu__logo sup{color:var(--green-light);font-size:11px;}
.mobile-menu__close{background:none;border:none;cursor:pointer;padding:6px;color:var(--text-muted);border-radius:8px;font-size:18px;line-height:1;transition:background .2s;}
.mobile-menu__close:hover{background:var(--green-pale);color:var(--green-dark);}
.mobile-menu__nav{flex:1;overflow-y:auto;padding:12px 12px;}
.mobile-menu__nav a{display:flex;align-items:center;gap:10px;padding:13px 14px;border-radius:var(--r);color:var(--text);font-size:15px;font-weight:600;text-decoration:none;transition:background .18s,color .18s;margin-bottom:2px;}
.mobile-menu__nav a:hover{background:var(--green-pale);color:var(--green-dark);}
.mobile-menu__nav a svg{flex-shrink:0;opacity:.55;}
.mobile-menu__divider{height:1px;background:var(--border-light);margin:8px 14px;}
.mobile-menu__footer{padding:16px 16px;border-top:1px solid var(--border-light);display:flex;flex-direction:column;gap:10px;}
.mobile-menu__footer-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:13px;border-radius:var(--r);font-family:'Nunito Sans',sans-serif;font-weight:700;font-size:14px;text-decoration:none;border:none;cursor:pointer;transition:background .2s;}
.mobile-menu__shop{background:var(--green);color:#fff;}.mobile-menu__shop:hover{background:var(--green-dark);}
.mobile-menu__call{background:var(--green-pale);color:var(--green-dark);}.mobile-menu__call:hover{background:var(--green-mid);}
/* ── BACK TO TOP ── */
.back-to-top{position:fixed;bottom:28px;right:28px;width:44px;height:44px;background:var(--green-dark);color:#fff;border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(0,0,0,.2);z-index:100;opacity:0;pointer-events:none;transition:opacity .3s,transform .3s;transform:translateY(8px);}
.back-to-top.visible{opacity:1;pointer-events:all;transform:translateY(0);}
.back-to-top:hover{background:var(--green);}
/* ── NAV OVERRIDES (new nav structure) ── */
.nav{height:62px;}
.nav__inner{max-width:1100px;margin:0 auto;padding:0 32px;height:62px;display:flex;align-items:center;justify-content:space-between;gap:24px;}
.nav__logo{font-family:'Fraunces',serif;font-size:18px;font-weight:700;color:var(--green-dark);flex-shrink:0;text-decoration:none;}
.nav__logo sup{color:var(--green-light);font-size:12px;}
.nav__links{display:flex;gap:4px;list-style:none;align-items:center;}
.nav__links a{color:var(--text-muted);font-size:13px;font-weight:600;cursor:pointer;transition:color .2s;padding:6px 10px;border-radius:8px;display:block;text-decoration:none;}
.nav__links a:hover,.nav__links a.active{color:var(--green);background:var(--green-pale);}
.nav__phone{font-size:12px;color:var(--text-muted);font-weight:600;text-decoration:none;}.nav__phone:hover{color:var(--green);}
.nav__cart{display:flex;align-items:center;gap:6px;background:var(--green);color:#fff;padding:8px 14px;border-radius:var(--r);font-size:12px;font-weight:700;border:none;cursor:pointer;font-family:'Nunito Sans',sans-serif;transition:background .2s;text-decoration:none;}.nav__cart:hover{background:var(--green-dark);}
/* ── VS SECTION ── */
.vs{background:var(--cream);padding:80px 0;}
.vs__header{text-align:center;margin-bottom:52px;}
.vs__title{font-size:clamp(26px,3.5vw,44px);font-weight:700;color:var(--green-dark);margin-bottom:12px;}
.vs__sub{font-size:16px;color:var(--text-muted);max-width:560px;margin:0 auto;line-height:1.7;}
.vs__fact{background:var(--green-dark);border-radius:var(--r-xl);padding:28px 36px;margin-bottom:48px;display:flex;align-items:center;gap:28px;max-width:860px;margin-left:auto;margin-right:auto;}
.vs__fact-icon{font-size:36px;flex-shrink:0;}
.vs__fact-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:2px;color:var(--green-mid);margin-bottom:6px;}
.vs__fact-headline{font-family:'Fraunces',serif;font-size:20px;font-weight:700;color:#fff;line-height:1.25;margin-bottom:6px;}
.vs__fact-sub{font-size:14px;color:rgba(255,255,255,.6);line-height:1.6;}
.vs__fact-sub strong{color:rgba(255,255,255,.9);}
.vs__compare{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.vs__col{border-radius:var(--r-lg);overflow:hidden;}
.vs__col-head{padding:16px 20px;display:flex;align-items:center;gap:10px;}
.vs__col-head--pine{background:var(--green-dark);}
.vs__col-head--wood{background:#92400E;}
.vs__col-head--rock{background:#4B5563;}
.vs__col-icon{font-size:20px;}
.vs__col-name{font-family:'Fraunces',serif;font-size:16px;font-weight:700;color:#fff;}
.vs__col-sub{font-size:11px;color:rgba(255,255,255,.55);margin-top:1px;}
.vs__col-body{background:var(--warm-white);border:1px solid var(--border-light);border-top:none;}
.vs__row{display:flex;align-items:flex-start;gap:10px;padding:12px 16px;border-bottom:1px solid var(--border-light);}
.vs__row:last-child{border-bottom:none;}
.vs__row-icon{font-size:13px;flex-shrink:0;margin-top:1px;}
.vs__row-text{font-size:12px;color:var(--text-muted);line-height:1.55;}
.vs__row-text strong{color:var(--text);font-weight:700;display:block;font-size:11px;margin-bottom:1px;}
/* ── FAQ ── */
.faq{background:var(--warm-white);padding:80px 0;}
.faq__header{text-align:center;margin-bottom:52px;}
.faq__title{font-size:clamp(26px,3.5vw,44px);font-weight:700;color:var(--green-dark);margin-bottom:12px;}
.faq__sub{font-size:16px;color:var(--text-muted);max-width:500px;margin:0 auto;}
.faq__grid{display:grid;grid-template-columns:1fr 1fr;gap:0 48px;max-width:960px;margin:0 auto;}
.faq__item{border-bottom:1px solid var(--border-light);}
.faq__q{width:100%;background:none;border:none;padding:18px 0;text-align:left;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:16px;font-family:'Nunito Sans',sans-serif;}
.faq__q-text{font-size:14px;font-weight:700;color:var(--green-dark);line-height:1.4;}
.faq__chevron{width:20px;height:20px;border-radius:50%;background:var(--green-pale);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .2s;}
.faq__chevron svg{transition:transform .25s;}
.faq__item.open .faq__chevron{background:var(--green);}
.faq__item.open .faq__chevron svg{transform:rotate(180deg);}
.faq__item.open .faq__chevron path{stroke:#fff;}
.faq__a{max-height:0;overflow:hidden;transition:max-height .3s ease;}
.faq__item.open .faq__a{max-height:300px;}
.faq__a-inner{padding:0 0 18px;font-size:13px;color:var(--text-muted);line-height:1.72;}
.faq__a-inner strong{color:var(--green-dark);font-weight:700;}
.faq__cta{text-align:center;margin-top:48px;}
/* ── RESPONSIVE UPDATES ── */
@media(max-width:900px){
  .nav__links,.nav__phone{display:none;}
  .nav__hamburger{display:flex;}
  .vs__compare{grid-template-columns:1fr;}
}
@media(max-width:600px){
  .faq__grid{grid-template-columns:1fr;}
  .vs__fact{flex-direction:column;gap:16px;padding:24px;}
  .back-to-top{bottom:20px;right:16px;}
}


/* ── OVERRIDE: adjust sticky offset for double nav ── */
.nav{top:0;}
.subnav{top:58px;}
/* ── FIX scroll offset for double navbar ── */

/* ══ BENEFITS PAGE ══ */

:root{--green:#3B6D11;--green-dark:#27500A;--green-light:#639922;--green-pale:#EAF3DE;--green-mid:#C0DD97;--cream:#FAF9F5;--warm-white:#FFFFFF;--text:#2C2C2A;--text-muted:#5F5E5A;--text-light:#888780;--border:#D3D1C7;--border-light:#EDEBE4;--amber:#D97706;--amber-pale:#FEF3C7;--r:12px;--r-lg:20px;--r-xl:32px;}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:'Nunito Sans',sans-serif;background:var(--cream);color:var(--text);font-size:15px;line-height:1.6;}
h1,h2,h3,h4,h5{font-family:'Fraunces',serif;line-height:1.15;}
img{max-width:100%;display:block;}
.wrap{max-width:1100px;margin:0 auto;padding:0 32px;}
.eyebrow{font-size:11px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:var(--green);display:block;margin-bottom:10px;}
.btn{display:inline-flex;align-items:center;gap:7px;padding:10px 22px;border-radius:var(--r);font-family:'Nunito Sans',sans-serif;font-weight:700;font-size:13px;cursor:pointer;transition:all .2s;text-decoration:none;border:none;white-space:nowrap;}
.btn-green{background:var(--green);color:#fff;}.btn-green:hover{background:var(--green-dark);}
.btn-outline{background:transparent;color:var(--green);border:2px solid var(--green);}.btn-outline:hover{background:var(--green-pale);}
.btn-ghost{background:transparent;color:rgba(255,255,255,.82);border:2px solid rgba(255,255,255,.3);}.btn-ghost:hover{background:rgba(255,255,255,.1);color:#fff;}
.btn-white{background:#fff;color:var(--green-dark);}.btn-white:hover{background:var(--green-pale);}
.btn-lg{padding:13px 30px;font-size:15px;border-radius:var(--r-lg);}
/* Loyalty Bar */
.loyalty-bar{background:var(--green-pale);border-bottom:1px solid var(--green-mid);padding:8px 32px;display:flex;align-items:center;justify-content:center;gap:18px;font-size:12px;color:var(--green-dark);font-weight:600;flex-wrap:wrap;}
.loyalty-bar a{color:var(--green);font-weight:700;text-decoration:underline;}
/* Nav */
.nav{background:var(--warm-white);border-bottom:1px solid var(--border-light);padding:0;position:sticky;top:0;z-index:200;}
.nav__inner{max-width:1100px;margin:0 auto;padding:0 32px;height:62px;display:flex;align-items:center;justify-content:space-between;gap:24px;}
.nav__logo{font-family:'Fraunces',serif;font-size:18px;font-weight:700;color:var(--green-dark);flex-shrink:0;text-decoration:none;}
.nav__logo sup{color:var(--green-light);font-size:12px;}
.nav__links{display:flex;gap:4px;list-style:none;align-items:center;}
.nav__links a{color:var(--text-muted);font-size:13px;font-weight:600;cursor:pointer;transition:color .2s;padding:6px 10px;border-radius:8px;display:block;text-decoration:none;}
.nav__links a:hover{color:var(--green);}
.nav__links a.active{color:var(--green);background:var(--green-pale);}
.nav__right{display:flex;align-items:center;gap:10px;flex-shrink:0;}
.nav__phone{font-size:12px;color:var(--text-muted);font-weight:600;text-decoration:none;}
.nav__phone:hover{color:var(--green);}
.nav__cart{display:flex;align-items:center;gap:6px;background:var(--green);color:#fff;padding:8px 14px;border-radius:var(--r);font-size:12px;font-weight:700;border:none;cursor:pointer;font-family:'Nunito Sans',sans-serif;transition:background .2s;text-decoration:none;}
.nav__cart:hover{background:var(--green-dark);}
.nav__hamburger{display:none;background:none;border:none;cursor:pointer;padding:6px;border-radius:8px;color:var(--text);transition:background .2s;}
.nav__hamburger:hover{background:var(--green-pale);}
.nav__hamburger-icon{width:22px;height:16px;display:flex;flex-direction:column;justify-content:space-between;}
.nav__hamburger-icon span{display:block;width:100%;height:2px;background:var(--green-dark);border-radius:2px;transition:all .3s;}
/* Mobile menu */
.mobile-menu-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:300;opacity:0;pointer-events:none;transition:opacity .3s;}
.mobile-menu-overlay.open{opacity:1;pointer-events:all;}
.mobile-menu{position:fixed;top:0;left:0;bottom:0;width:300px;max-width:85vw;background:var(--warm-white);z-index:301;transform:translateX(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;box-shadow:4px 0 24px rgba(0,0,0,.12);}
.mobile-menu.open{transform:translateX(0);}
.mobile-menu__header{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid var(--border-light);}
.mobile-menu__logo{font-family:'Fraunces',serif;font-size:16px;font-weight:700;color:var(--green-dark);text-decoration:none;}
.mobile-menu__logo sup{color:var(--green-light);font-size:11px;}
.mobile-menu__close{background:none;border:none;cursor:pointer;padding:6px;color:var(--text-muted);border-radius:8px;font-size:18px;line-height:1;}
.mobile-menu__nav{flex:1;overflow-y:auto;padding:12px;}
.mobile-menu__nav a{display:flex;align-items:center;gap:10px;padding:13px 14px;border-radius:var(--r);color:var(--text);font-size:15px;font-weight:600;text-decoration:none;transition:background .18s;margin-bottom:2px;}
.mobile-menu__nav a:hover,.mobile-menu__nav a.mob-active{background:var(--green-pale);color:var(--green-dark);}
.mobile-menu__divider{height:1px;background:var(--border-light);margin:8px 14px;}
.mobile-menu__footer{padding:16px;border-top:1px solid var(--border-light);display:flex;flex-direction:column;gap:10px;}
.mobile-menu__footer-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:13px;border-radius:var(--r);font-family:'Nunito Sans',sans-serif;font-weight:700;font-size:14px;text-decoration:none;border:none;cursor:pointer;transition:background .2s;}
.mobile-menu__shop{background:var(--green);color:#fff;}.mobile-menu__shop:hover{background:var(--green-dark);}
.mobile-menu__call{background:var(--green-pale);color:var(--green-dark);}.mobile-menu__call:hover{background:var(--green-mid);}
/* Back to top */
.back-to-top{position:fixed;bottom:28px;right:28px;width:44px;height:44px;background:var(--green-dark);color:#fff;border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(0,0,0,.2);z-index:100;opacity:0;pointer-events:none;transition:opacity .3s,transform .3s;transform:translateY(8px);}
.back-to-top.visible{opacity:1;pointer-events:all;transform:translateY(0);}
.back-to-top:hover{background:var(--green);}
/* Footer */
.footer{background:var(--green-dark);color:rgba(255,255,255,.65);padding:56px 0 32px;}
.footer__top{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:44px;margin-bottom:44px;}
.footer__brand{font-family:'Fraunces',serif;font-size:18px;font-weight:700;color:#fff;margin-bottom:12px;}
.footer__tagline{font-size:13px;line-height:1.75;color:rgba(255,255,255,.5);margin-bottom:18px;}
.footer__contact{font-size:13px;display:flex;flex-direction:column;gap:4px;}
.footer__contact a{color:var(--green-mid);font-weight:600;text-decoration:none;}.footer__contact a:hover{opacity:.8;}
.footer__contact span{font-size:12px;color:rgba(255,255,255,.34);}
.footer__col h5{font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,.32);margin-bottom:14px;}
.footer__col ul{list-style:none;display:flex;flex-direction:column;gap:8px;}
.footer__col a{color:rgba(255,255,255,.55);font-size:13px;transition:color .2s;text-decoration:none;}
.footer__col a:hover{color:var(--green-mid);}
.footer__bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:24px;display:flex;justify-content:space-between;align-items:center;font-size:12px;flex-wrap:wrap;gap:12px;color:rgba(255,255,255,.3);}
.footer__legal{display:flex;gap:20px;}
.footer__legal a{color:rgba(255,255,255,.3);text-decoration:none;}.footer__legal a:hover{color:rgba(255,255,255,.6);}
/* Responsive */
@media(max-width:900px){
  .nav__links{display:none;}
  .nav__phone{display:none;}
  .nav__hamburger{display:flex;}
  .footer__top{grid-template-columns:1fr 1fr;gap:32px;}
}
@media(max-width:600px){
  .wrap{padding:0 20px;}
  .loyalty-bar{padding:8px 20px;font-size:11px;}
  .nav__inner{padding:0 20px;}
  .footer__top{grid-template-columns:1fr;gap:24px;}
  .back-to-top{bottom:20px;right:16px;}
}


.page-hero{background:var(--green-dark);padding:72px 0 80px;position:relative;overflow:hidden;}
.page-hero__bg{position:absolute;inset:0;background:radial-gradient(ellipse 80% 100% at 85% 60%,rgba(99,153,34,.28) 0%,transparent 65%);}
.page-hero__inner{position:relative;z-index:1;max-width:760px;}
.page-hero__breadcrumb{display:flex;align-items:center;gap:8px;font-size:12px;color:rgba(255,255,255,.4);margin-bottom:28px;}
.page-hero__breadcrumb a{color:rgba(255,255,255,.4);text-decoration:none;transition:color .2s;}
.page-hero__breadcrumb a:hover{color:var(--green-mid);}
.page-hero__breadcrumb span{color:rgba(255,255,255,.25);}
.page-hero__pill{display:inline-flex;align-items:center;gap:7px;background:rgba(192,221,151,.15);color:var(--green-mid);font-size:11px;font-weight:700;letter-spacing:1.8px;text-transform:uppercase;padding:6px 14px;border-radius:100px;margin-bottom:20px;border:1px solid rgba(192,221,151,.22);}
.page-hero__title{font-size:clamp(36px,5vw,60px);font-weight:700;color:#fff;line-height:1.06;margin-bottom:20px;}
.page-hero__title em{font-style:italic;color:var(--green-mid);}
.page-hero__body{font-size:17px;color:rgba(255,255,255,.68);line-height:1.75;max-width:620px;margin-bottom:36px;}
.page-hero__ctas{display:flex;gap:12px;flex-wrap:wrap;}
.page-hero__stats{display:flex;gap:40px;margin-top:52px;padding-top:40px;border-top:1px solid rgba(255,255,255,.12);flex-wrap:wrap;}
.page-hero__stat-val{font-family:'Fraunces',serif;font-size:30px;font-weight:700;color:var(--green-mid);line-height:1;}
.page-hero__stat-lbl{font-size:12px;color:rgba(255,255,255,.44);margin-top:3px;}
.intro-strip{background:var(--warm-white);padding:56px 0;border-bottom:1px solid var(--border-light);}
.intro-strip__inner{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;}
.intro-strip__title{font-size:clamp(26px,3.5vw,40px);font-weight:700;color:var(--green-dark);margin-bottom:16px;}
.intro-strip__body{font-size:16px;color:var(--text-muted);line-height:1.8;}
.intro-strip__body p{margin-bottom:16px;}
.intro-strip__visual{background:var(--green-pale);border-radius:var(--r-xl);padding:32px;display:flex;flex-direction:column;gap:14px;}
.intro-stat{display:flex;align-items:center;gap:18px;background:var(--warm-white);border-radius:var(--r-lg);padding:16px 20px;border:1px solid var(--border-light);}
.intro-stat__num{font-family:'Fraunces',serif;font-size:32px;font-weight:700;color:var(--green);line-height:1;flex-shrink:0;}
.intro-stat__text{font-size:13px;color:var(--text-muted);line-height:1.5;}
.intro-stat__text strong{display:block;font-size:14px;color:var(--green-dark);font-weight:700;margin-bottom:2px;}
.benefit-deep{padding:80px 0;}
.benefit-deep:nth-child(even){background:var(--warm-white);}
.benefit-deep:nth-child(odd){background:var(--cream);}
.benefit-deep__inner{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center;}
.benefit-deep__inner--reverse{direction:rtl;}
.benefit-deep__inner--reverse>*{direction:ltr;}
.benefit-deep__tag{display:inline-block;background:var(--green-pale);color:var(--green);font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;padding:4px 12px;border-radius:100px;margin-bottom:14px;}
.benefit-deep__num{font-family:'Fraunces',serif;font-size:80px;font-weight:700;color:var(--green-pale);line-height:1;margin-bottom:-16px;}
.benefit-deep__title{font-size:clamp(24px,3.5vw,38px);font-weight:700;color:var(--green-dark);margin-bottom:16px;line-height:1.15;}
.benefit-deep__body{font-size:15px;color:var(--text-muted);line-height:1.8;}
.benefit-deep__body p{margin-bottom:14px;}
.benefit-deep__callout{background:var(--green-pale);border-left:4px solid var(--green);border-radius:0 var(--r) var(--r) 0;padding:14px 18px;font-size:14px;color:var(--green-dark);font-weight:600;line-height:1.5;margin-top:20px;}
.benefit-deep__visual{border-radius:var(--r-xl);background:var(--green-pale);aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;overflow:hidden;}
.benefit-visual-card{background:var(--green-dark);border-radius:var(--r-xl);padding:40px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;width:100%;height:100%;min-height:280px;gap:8px;}
.benefit-visual-card__icon{font-size:44px;margin-bottom:8px;}
.benefit-visual-card__big{font-family:'Fraunces',serif;font-size:52px;font-weight:700;color:var(--green-mid);line-height:1;}
.benefit-visual-card__label{font-size:14px;color:rgba(255,255,255,.6);margin-top:4px;}
.benefit-visual-card__sub{font-size:12px;color:rgba(255,255,255,.38);}
@media(max-width:900px){.intro-strip__inner,.benefit-deep__inner{grid-template-columns:1fr;gap:36px;}.benefit-deep__inner--reverse{direction:ltr;}.page-hero__stats{gap:24px;}}
@media(max-width:600px){.page-hero{padding:48px 0 56px;}.benefit-deep{padding:60px 0;}}



/* ══ ABOUT PAGE ══ */

:root{--green:#3B6D11;--green-dark:#27500A;--green-light:#639922;--green-pale:#EAF3DE;--green-mid:#C0DD97;--cream:#FAF9F5;--warm-white:#FFFFFF;--text:#2C2C2A;--text-muted:#5F5E5A;--text-light:#888780;--border:#D3D1C7;--border-light:#EDEBE4;--amber:#D97706;--amber-pale:#FEF3C7;--r:12px;--r-lg:20px;--r-xl:32px;}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:'Nunito Sans',sans-serif;background:var(--cream);color:var(--text);font-size:15px;line-height:1.6;}
h1,h2,h3,h4,h5{font-family:'Fraunces',serif;line-height:1.15;}
img{max-width:100%;display:block;}
.wrap{max-width:1100px;margin:0 auto;padding:0 32px;}
.eyebrow{font-size:11px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:var(--green);display:block;margin-bottom:10px;}
.btn{display:inline-flex;align-items:center;gap:7px;padding:10px 22px;border-radius:var(--r);font-family:'Nunito Sans',sans-serif;font-weight:700;font-size:13px;cursor:pointer;transition:all .2s;text-decoration:none;border:none;white-space:nowrap;}
.btn-green{background:var(--green);color:#fff;}.btn-green:hover{background:var(--green-dark);}
.btn-outline{background:transparent;color:var(--green);border:2px solid var(--green);}.btn-outline:hover{background:var(--green-pale);}
.btn-ghost{background:transparent;color:rgba(255,255,255,.82);border:2px solid rgba(255,255,255,.3);}.btn-ghost:hover{background:rgba(255,255,255,.1);color:#fff;}
.btn-white{background:#fff;color:var(--green-dark);}.btn-white:hover{background:var(--green-pale);}
.btn-lg{padding:13px 30px;font-size:15px;border-radius:var(--r-lg);}
/* Loyalty Bar */
.loyalty-bar{background:var(--green-pale);border-bottom:1px solid var(--green-mid);padding:8px 32px;display:flex;align-items:center;justify-content:center;gap:18px;font-size:12px;color:var(--green-dark);font-weight:600;flex-wrap:wrap;}
.loyalty-bar a{color:var(--green);font-weight:700;text-decoration:underline;}
/* Nav */
.nav{background:var(--warm-white);border-bottom:1px solid var(--border-light);padding:0;position:sticky;top:0;z-index:200;}
.nav__inner{max-width:1100px;margin:0 auto;padding:0 32px;height:62px;display:flex;align-items:center;justify-content:space-between;gap:24px;}
.nav__logo{font-family:'Fraunces',serif;font-size:18px;font-weight:700;color:var(--green-dark);flex-shrink:0;text-decoration:none;}
.nav__logo sup{color:var(--green-light);font-size:12px;}
.nav__links{display:flex;gap:4px;list-style:none;align-items:center;}
.nav__links a{color:var(--text-muted);font-size:13px;font-weight:600;cursor:pointer;transition:color .2s;padding:6px 10px;border-radius:8px;display:block;text-decoration:none;}
.nav__links a:hover{color:var(--green);}
.nav__links a.active{color:var(--green);background:var(--green-pale);}
.nav__right{display:flex;align-items:center;gap:10px;flex-shrink:0;}
.nav__phone{font-size:12px;color:var(--text-muted);font-weight:600;text-decoration:none;}
.nav__phone:hover{color:var(--green);}
.nav__cart{display:flex;align-items:center;gap:6px;background:var(--green);color:#fff;padding:8px 14px;border-radius:var(--r);font-size:12px;font-weight:700;border:none;cursor:pointer;font-family:'Nunito Sans',sans-serif;transition:background .2s;text-decoration:none;}
.nav__cart:hover{background:var(--green-dark);}
.nav__hamburger{display:none;background:none;border:none;cursor:pointer;padding:6px;border-radius:8px;color:var(--text);transition:background .2s;}
.nav__hamburger:hover{background:var(--green-pale);}
.nav__hamburger-icon{width:22px;height:16px;display:flex;flex-direction:column;justify-content:space-between;}
.nav__hamburger-icon span{display:block;width:100%;height:2px;background:var(--green-dark);border-radius:2px;transition:all .3s;}
/* Mobile menu */
.mobile-menu-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:300;opacity:0;pointer-events:none;transition:opacity .3s;}
.mobile-menu-overlay.open{opacity:1;pointer-events:all;}
.mobile-menu{position:fixed;top:0;left:0;bottom:0;width:300px;max-width:85vw;background:var(--warm-white);z-index:301;transform:translateX(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;box-shadow:4px 0 24px rgba(0,0,0,.12);}
.mobile-menu.open{transform:translateX(0);}
.mobile-menu__header{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid var(--border-light);}
.mobile-menu__logo{font-family:'Fraunces',serif;font-size:16px;font-weight:700;color:var(--green-dark);text-decoration:none;}
.mobile-menu__logo sup{color:var(--green-light);font-size:11px;}
.mobile-menu__close{background:none;border:none;cursor:pointer;padding:6px;color:var(--text-muted);border-radius:8px;font-size:18px;line-height:1;}
.mobile-menu__nav{flex:1;overflow-y:auto;padding:12px;}
.mobile-menu__nav a{display:flex;align-items:center;gap:10px;padding:13px 14px;border-radius:var(--r);color:var(--text);font-size:15px;font-weight:600;text-decoration:none;transition:background .18s;margin-bottom:2px;}
.mobile-menu__nav a:hover,.mobile-menu__nav a.mob-active{background:var(--green-pale);color:var(--green-dark);}
.mobile-menu__divider{height:1px;background:var(--border-light);margin:8px 14px;}
.mobile-menu__footer{padding:16px;border-top:1px solid var(--border-light);display:flex;flex-direction:column;gap:10px;}
.mobile-menu__footer-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:13px;border-radius:var(--r);font-family:'Nunito Sans',sans-serif;font-weight:700;font-size:14px;text-decoration:none;border:none;cursor:pointer;transition:background .2s;}
.mobile-menu__shop{background:var(--green);color:#fff;}.mobile-menu__shop:hover{background:var(--green-dark);}
.mobile-menu__call{background:var(--green-pale);color:var(--green-dark);}.mobile-menu__call:hover{background:var(--green-mid);}
/* Back to top */
.back-to-top{position:fixed;bottom:28px;right:28px;width:44px;height:44px;background:var(--green-dark);color:#fff;border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(0,0,0,.2);z-index:100;opacity:0;pointer-events:none;transition:opacity .3s,transform .3s;transform:translateY(8px);}
.back-to-top.visible{opacity:1;pointer-events:all;transform:translateY(0);}
.back-to-top:hover{background:var(--green);}
/* Footer */
.footer{background:var(--green-dark);color:rgba(255,255,255,.65);padding:56px 0 32px;}
.footer__top{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:44px;margin-bottom:44px;}
.footer__brand{font-family:'Fraunces',serif;font-size:18px;font-weight:700;color:#fff;margin-bottom:12px;}
.footer__tagline{font-size:13px;line-height:1.75;color:rgba(255,255,255,.5);margin-bottom:18px;}
.footer__contact{font-size:13px;display:flex;flex-direction:column;gap:4px;}
.footer__contact a{color:var(--green-mid);font-weight:600;text-decoration:none;}.footer__contact a:hover{opacity:.8;}
.footer__contact span{font-size:12px;color:rgba(255,255,255,.34);}
.footer__col h5{font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,.32);margin-bottom:14px;}
.footer__col ul{list-style:none;display:flex;flex-direction:column;gap:8px;}
.footer__col a{color:rgba(255,255,255,.55);font-size:13px;transition:color .2s;text-decoration:none;}
.footer__col a:hover{color:var(--green-mid);}
.footer__bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:24px;display:flex;justify-content:space-between;align-items:center;font-size:12px;flex-wrap:wrap;gap:12px;color:rgba(255,255,255,.3);}
.footer__legal{display:flex;gap:20px;}
.footer__legal a{color:rgba(255,255,255,.3);text-decoration:none;}.footer__legal a:hover{color:rgba(255,255,255,.6);}
/* Responsive */
@media(max-width:900px){
  .nav__links{display:none;}
  .nav__phone{display:none;}
  .nav__hamburger{display:flex;}
  .footer__top{grid-template-columns:1fr 1fr;gap:32px;}
}
@media(max-width:600px){
  .wrap{padding:0 20px;}
  .loyalty-bar{padding:8px 20px;font-size:11px;}
  .nav__inner{padding:0 20px;}
  .footer__top{grid-template-columns:1fr;gap:24px;}
  .back-to-top{bottom:20px;right:16px;}
}


.about-hero{background:var(--green-dark);padding:72px 0 0;position:relative;overflow:hidden;}
.about-hero__bg{position:absolute;inset:0;background:radial-gradient(ellipse 80% 100% at 80% 30%,rgba(99,153,34,.25) 0%,transparent 60%);}
.about-hero__inner{position:relative;z-index:1;display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:end;}
.about-hero__content{padding-bottom:72px;}
.about-hero__breadcrumb{display:flex;align-items:center;gap:8px;font-size:12px;color:rgba(255,255,255,.35);margin-bottom:28px;}
.about-hero__breadcrumb a{color:rgba(255,255,255,.35);text-decoration:none;}.about-hero__breadcrumb a:hover{color:var(--green-mid);}
.about-hero__pill{display:inline-flex;align-items:center;gap:7px;background:rgba(192,221,151,.15);color:var(--green-mid);font-size:11px;font-weight:700;letter-spacing:1.8px;text-transform:uppercase;padding:6px 14px;border-radius:100px;margin-bottom:20px;border:1px solid rgba(192,221,151,.22);}
.about-hero__title{font-size:clamp(34px,5vw,56px);font-weight:700;color:#fff;line-height:1.06;margin-bottom:20px;}
.about-hero__title em{font-style:italic;color:var(--green-mid);}
.about-hero__body{font-size:17px;color:rgba(255,255,255,.68);line-height:1.75;max-width:520px;margin-bottom:36px;}
.about-hero__founded{display:inline-flex;align-items:center;gap:16px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);border-radius:var(--r-lg);padding:16px 22px;}
.about-hero__founded-year{font-family:'Fraunces',serif;font-size:36px;font-weight:700;color:var(--green-mid);line-height:1;}
.about-hero__founded-text{font-size:13px;color:rgba(255,255,255,.55);line-height:1.5;}
.about-hero__founded-text strong{display:block;color:rgba(255,255,255,.85);font-size:14px;margin-bottom:2px;}
.about-hero__image-col{align-self:stretch;display:flex;align-items:flex-end;}
.about-hero__image{width:100%;aspect-ratio:3/4;background:linear-gradient(170deg,#1e3d08 0%,#3B6D11 40%,#5a8a2a 80%);border-radius:var(--r-xl) var(--r-xl) 0 0;overflow:hidden;position:relative;}
.about-hero__image img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.about-hero__image-ph{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;opacity:.3;}
.about-hero__stats-bar{background:var(--green-pale);border-top:1px solid var(--green-mid);}
.about-hero__stats{max-width:1100px;margin:0 auto;padding:0 32px;display:grid;grid-template-columns:repeat(4,1fr);border-left:1px solid var(--green-mid);}
.about-hero__stat{padding:22px 24px;border-right:1px solid var(--green-mid);}
.about-hero__stat-val{font-family:'Fraunces',serif;font-size:30px;font-weight:700;color:var(--green-dark);line-height:1;}
.about-hero__stat-lbl{font-size:12px;color:var(--text-muted);margin-top:3px;font-weight:600;}
.origin{background:var(--warm-white);padding:96px 0;}
.origin__inner{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start;}
.origin__title{font-size:clamp(26px,3.5vw,42px);font-weight:700;color:var(--green-dark);margin-bottom:24px;line-height:1.15;}
.origin__body{font-size:16px;color:var(--text-muted);line-height:1.85;}
.origin__body p{margin-bottom:18px;}
.origin__body strong{color:var(--green-dark);}
.origin__pull{font-family:'Fraunces',serif;font-size:21px;font-style:italic;color:var(--green-dark);line-height:1.5;border-left:4px solid var(--green-mid);padding:18px 0 18px 26px;margin:28px 0;}
.origin__timeline{display:flex;flex-direction:column;gap:0;}
.timeline-item{display:flex;gap:0;position:relative;}
.timeline-item::before{content:'';position:absolute;left:19px;top:44px;bottom:-1px;width:2px;background:var(--border-light);}
.timeline-item:last-child::before{display:none;}
.timeline-dot{width:40px;height:40px;border-radius:50%;background:var(--green-dark);border:2px solid var(--green-dark);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-right:20px;margin-top:2px;position:relative;z-index:1;}
.timeline-content{padding-bottom:36px;}
.timeline-year{font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--green);margin-bottom:4px;}
.timeline-title{font-size:16px;font-weight:700;color:var(--green-dark);margin-bottom:5px;}
.timeline-body{font-size:13px;color:var(--text-muted);line-height:1.65;}
.mission{background:var(--green-dark);padding:80px 0;position:relative;overflow:hidden;}
.mission__bg{position:absolute;inset:0;background:radial-gradient(ellipse 70% 90% at 15% 50%,rgba(99,153,34,.22) 0%,transparent 60%);}
.mission__inner{position:relative;z-index:1;display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center;}
.mission__eyebrow{font-size:11px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:var(--green-mid);margin-bottom:14px;display:block;}
.mission__title{font-size:clamp(28px,4vw,44px);font-weight:700;color:#fff;margin-bottom:20px;line-height:1.1;}
.mission__title em{font-style:italic;color:var(--green-mid);}
.mission__body{font-size:15px;color:rgba(255,255,255,.65);line-height:1.82;}
.mission__body p{margin-bottom:16px;}
.mission__body strong{color:rgba(255,255,255,.9);}
.mission__values{display:flex;flex-direction:column;gap:14px;}
.mission-value{display:flex;gap:18px;align-items:flex-start;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:var(--r-lg);padding:20px 22px;transition:background .2s;}
.mission-value:hover{background:rgba(255,255,255,.1);}
.mission-value__icon{font-size:22px;flex-shrink:0;margin-top:2px;}
.mission-value__title{font-size:15px;font-weight:700;color:#fff;margin-bottom:3px;}
.mission-value__body{font-size:13px;color:rgba(255,255,255,.55);line-height:1.6;}
.different{background:var(--cream);padding:80px 0;}
.different__header{text-align:center;margin-bottom:56px;}
.different__title{font-size:clamp(26px,3.5vw,42px);font-weight:700;color:var(--green-dark);margin-bottom:12px;}
.different__sub{font-size:16px;color:var(--text-muted);max-width:540px;margin:0 auto;line-height:1.7;}
.different__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.diff-card{background:var(--warm-white);border:1px solid var(--border-light);border-radius:var(--r-lg);padding:28px;transition:border-color .2s,transform .2s;}
.diff-card:hover{border-color:var(--green-mid);transform:translateY(-3px);}
.diff-card__icon{width:48px;height:48px;background:var(--green-pale);border-radius:var(--r);display:flex;align-items:center;justify-content:center;margin-bottom:18px;font-size:22px;}
.diff-card__title{font-size:17px;font-weight:700;color:var(--green-dark);margin-bottom:9px;}
.diff-card__body{font-size:13px;color:var(--text-muted);line-height:1.75;}
.diff-card__stat{display:inline-block;background:var(--green-pale);color:var(--green);font-size:11px;font-weight:700;padding:3px 10px;border-radius:100px;margin-top:12px;border:1px solid var(--green-mid);}
.promise{background:var(--warm-white);border-top:1px solid var(--border-light);padding:80px 0;}
.promise__inner{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:start;}
.promise__title{font-size:clamp(24px,3.5vw,40px);font-weight:700;color:var(--green-dark);margin-bottom:16px;}
.promise__body{font-size:16px;color:var(--text-muted);line-height:1.82;}
.promise__body p{margin-bottom:16px;}
.promise__body strong{color:var(--green-dark);}
.promise__guarantees{display:flex;flex-direction:column;gap:12px;}
.guarantee-row{display:flex;align-items:flex-start;gap:14px;padding:16px 18px;background:var(--cream);border-radius:var(--r-lg);border:1px solid var(--border-light);}
.guarantee-check{width:26px;height:26px;border-radius:50%;background:var(--green-pale);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px;}
.guarantee-row h4{font-size:14px;font-weight:700;color:var(--green-dark);margin-bottom:2px;}
.guarantee-row p{font-size:13px;color:var(--text-muted);line-height:1.6;}
.community{background:var(--green-pale);padding:80px 0;}
.community__inner{max-width:860px;margin:0 auto;text-align:center;}
.community__title{font-size:clamp(24px,3.5vw,40px);font-weight:700;color:var(--green-dark);margin-bottom:16px;}
.community__body{font-size:16px;color:var(--text-muted);line-height:1.82;}
.community__body p{margin-bottom:14px;}
.community__quote{font-family:'Fraunces',serif;font-size:22px;font-style:italic;color:var(--green-dark);line-height:1.5;margin:28px auto;max-width:700px;padding:24px 32px;background:rgba(255,255,255,.6);border-radius:var(--r-xl);border:1px solid var(--green-mid);}
.reviews-strip{background:var(--warm-white);padding:72px 0;}
.reviews-strip__title{font-size:clamp(22px,3.5vw,36px);font-weight:700;color:var(--green-dark);margin-bottom:10px;text-align:center;}
.reviews-strip__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.rev-card{background:var(--cream);border:1px solid var(--border-light);border-radius:var(--r-lg);padding:24px;}
.rev-card__stars{color:#F0A500;font-size:14px;letter-spacing:2px;margin-bottom:12px;}
.rev-card__body{font-family:'Fraunces',serif;font-size:15px;font-style:italic;color:var(--green-dark);line-height:1.55;margin-bottom:14px;}
.rev-card__author{font-size:13px;font-weight:700;color:var(--green);}
.rev-card__loc{font-size:12px;color:var(--text-muted);margin-top:1px;}
.about-cta{background:var(--green-dark);padding:80px 0;position:relative;overflow:hidden;}
.about-cta__bg{position:absolute;inset:0;background:radial-gradient(ellipse 60% 80% at 80% 50%,rgba(99,153,34,.22) 0%,transparent 60%);}
.about-cta__inner{position:relative;z-index:1;display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;}
.about-cta__title{font-size:clamp(24px,3.5vw,40px);font-weight:700;color:#fff;margin-bottom:12px;line-height:1.15;}
.about-cta__title em{font-style:italic;color:var(--green-mid);}
.about-cta__body{font-size:15px;color:rgba(255,255,255,.65);line-height:1.75;}
.contact-row{display:flex;align-items:center;gap:16px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);border-radius:var(--r-lg);padding:16px 20px;text-decoration:none;transition:background .2s;margin-bottom:12px;}
.contact-row:hover{background:rgba(255,255,255,.12);}
.contact-row:last-child{margin-bottom:0;}
.contact-row__icon{font-size:20px;flex-shrink:0;}
.contact-row__label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:rgba(255,255,255,.4);margin-bottom:2px;}
.contact-row__value{font-size:14px;font-weight:700;color:#fff;}
.contact-row__sub{font-size:12px;color:rgba(255,255,255,.45);}
@media(max-width:900px){.about-hero__inner,.origin__inner,.mission__inner,.promise__inner,.about-cta__inner{grid-template-columns:1fr;gap:40px;}.about-hero__image-col{display:none;}.about-hero__stats{grid-template-columns:repeat(2,1fr);}.different__grid{grid-template-columns:1fr 1fr;}.reviews-strip__grid{grid-template-columns:1fr 1fr;}}
@media(max-width:600px){.about-hero__stats{grid-template-columns:1fr 1fr;padding:0 20px;}.different__grid{grid-template-columns:1fr;}.reviews-strip__grid{grid-template-columns:1fr;}.about-hero{padding:48px 0 0;}}



/* ══ HOW TO APPLY PAGE ══ */
/* ── PAGE HERO ── */
.hta-hero{background:var(--green-dark);padding:68px 0 0;position:relative;overflow:hidden;}
.hta-hero__bg{position:absolute;inset:0;background:radial-gradient(ellipse 80% 100% at 80% 40%,rgba(99,153,34,.28) 0%,transparent 65%);}
.hta-hero__inner{position:relative;z-index:1;display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:end;}
.hta-hero__content{padding-bottom:68px;}
.hta-hero__breadcrumb{display:flex;align-items:center;gap:8px;font-size:12px;color:rgba(255,255,255,.38);margin-bottom:26px;}
.hta-hero__breadcrumb a{color:rgba(255,255,255,.38);transition:color .2s;}.hta-hero__breadcrumb a:hover{color:var(--green-mid);}
.hta-hero__pill{display:inline-flex;align-items:center;gap:7px;background:rgba(192,221,151,.15);color:var(--green-mid);font-size:11px;font-weight:700;letter-spacing:1.8px;text-transform:uppercase;padding:6px 14px;border-radius:100px;margin-bottom:18px;border:1px solid rgba(192,221,151,.22);}
.hta-hero__title{font-size:clamp(34px,5vw,56px);font-weight:700;color:#fff;line-height:1.06;margin-bottom:18px;}
.hta-hero__title em{font-style:italic;color:var(--green-mid);}
.hta-hero__body{font-size:17px;color:rgba(255,255,255,.68);line-height:1.75;max-width:500px;margin-bottom:32px;}
.hta-hero__ctas{display:flex;gap:12px;flex-wrap:wrap;}
.hta-hero__visual-col{align-self:stretch;display:flex;align-items:flex-end;}
.hta-hero__visual{width:100%;background:linear-gradient(160deg,#1e3d08 0%,#3B6D11 45%,#5a8a2a 80%);border-radius:var(--r-xl) var(--r-xl) 0 0;min-height:320px;display:flex;align-items:center;justify-content:center;}
.hta-hero__visual-ph{display:flex;flex-direction:column;align-items:center;gap:10px;opacity:.3;}
.hta-stats-bar{background:var(--green-pale);border-top:1px solid var(--green-mid);}
.hta-stats{max-width:1100px;margin:0 auto;padding:0 32px;display:grid;grid-template-columns:repeat(4,1fr);border-left:1px solid var(--green-mid);}
.hta-stat{padding:20px 24px;border-right:1px solid var(--green-mid);}
.hta-stat-val{font-family:'Fraunces',serif;font-size:28px;font-weight:700;color:var(--green-dark);line-height:1;}
.hta-stat-lbl{font-size:12px;color:var(--text-muted);margin-top:3px;font-weight:600;}

/* ── BEFORE YOU START ── */
.before-start{background:var(--warm-white);padding:80px 0;border-bottom:1px solid var(--border-light);}
.before-start__inner{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:start;}
.before-start__title{font-size:clamp(26px,3.5vw,42px);font-weight:700;color:var(--green-dark);margin-bottom:14px;line-height:1.15;}
.before-start__body{font-size:16px;color:var(--text-muted);line-height:1.82;}
.before-start__body p{margin-bottom:16px;}
.before-start__body p:last-child{margin-bottom:0;}
.before-start__body strong{color:var(--green-dark);}
.checklist{display:flex;flex-direction:column;gap:12px;}
.check-item{display:flex;align-items:flex-start;gap:14px;background:var(--cream);border:1px solid var(--border-light);border-radius:var(--r-lg);padding:16px 18px;transition:border-color .2s;}
.check-item:hover{border-color:var(--green-mid);}
.check-dot{width:28px;height:28px;border-radius:50%;background:var(--green-pale);border:2px solid var(--green-mid);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px;}
.check-item h4{font-size:14px;font-weight:700;color:var(--green-dark);margin-bottom:3px;}
.check-item p{font-size:13px;color:var(--text-muted);line-height:1.6;}

/* ── DEPTH GUIDE ── */
.depth-guide{background:var(--cream);padding:80px 0;}
.depth-guide__header{text-align:center;margin-bottom:56px;}
.depth-guide__title{font-size:clamp(26px,3.5vw,42px);font-weight:700;color:var(--green-dark);margin-bottom:12px;}
.depth-guide__sub{font-size:16px;color:var(--text-muted);max-width:520px;margin:0 auto;}
.depth-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.depth-card{background:var(--warm-white);border:1px solid var(--border-light);border-radius:var(--r-xl);overflow:hidden;transition:transform .2s,border-color .2s;}
.depth-card:hover{transform:translateY(-3px);border-color:var(--green-mid);}
.depth-card__top{padding:32px 24px 24px;text-align:center;}
.depth-card--standard .depth-card__top{background:var(--green-dark);}
.depth-card--topping .depth-card__top{background:var(--green);}
.depth-card--slopes .depth-card__top{background:#1a3a6b;}
.depth-visual{display:flex;flex-direction:column;align-items:center;gap:4px;margin-bottom:20px;}
.depth-bar{border-radius:6px;width:80px;transition:width .3s;}
.depth-bar--soil{height:12px;background:rgba(255,255,255,.15);width:80px;}
.depth-card__inches{font-family:'Fraunces',serif;font-size:48px;font-weight:700;color:var(--green-mid);line-height:1;margin-bottom:4px;}
.depth-card__label{font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.55);}
.depth-card__name{font-family:'Fraunces',serif;font-size:20px;font-weight:700;color:#fff;margin-bottom:6px;}
.depth-card__sub{font-size:13px;color:rgba(255,255,255,.55);}
.depth-card__body{padding:24px;}
.depth-card__body p{font-size:14px;color:var(--text-muted);line-height:1.7;margin-bottom:12px;}
.depth-card__body p:last-child{margin-bottom:0;}
.depth-tag{display:inline-block;font-size:11px;font-weight:700;padding:4px 10px;border-radius:100px;margin-top:2px;}
.depth-tag--rec{background:var(--green-pale);color:var(--green);}
.depth-tag--top{background:#DCFCE7;color:#166534;}
.depth-tag--slope{background:#EFF6FF;color:#1e40af;}

/* ── STEP BY STEP ── */
.steps-section{background:var(--warm-white);padding:80px 0;}
.steps-section__header{text-align:center;margin-bottom:64px;}
.steps-section__title{font-size:clamp(26px,3.5vw,42px);font-weight:700;color:var(--green-dark);margin-bottom:12px;}
.steps-section__sub{font-size:16px;color:var(--text-muted);max-width:520px;margin:0 auto;}
.steps-timeline{max-width:900px;margin:0 auto;display:flex;flex-direction:column;gap:0;}
.step-block{display:grid;grid-template-columns:72px 1fr;gap:0;position:relative;}
.step-block::before{content:'';position:absolute;left:35px;top:72px;bottom:-1px;width:2px;background:var(--border-light);z-index:0;}
.step-block:last-child::before{display:none;}
.step-num-col{display:flex;flex-direction:column;align-items:center;padding-top:4px;}
.step-circle{width:52px;height:52px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Fraunces',serif;font-size:22px;font-weight:700;color:#fff;flex-shrink:0;position:relative;z-index:1;box-shadow:0 0 0 4px var(--warm-white),0 0 0 6px var(--green-pale);}
.step-circle--1{background:var(--green-dark);}
.step-circle--2{background:var(--green);}
.step-circle--3{background:var(--green-dark);}
.step-circle--4{background:var(--green);}
.step-circle--5{background:var(--green-dark);}
.step-circle--6{background:var(--green);}
.step-body{padding:0 0 52px 28px;}
.step-eyebrow{font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--green);margin-bottom:6px;margin-top:12px;}
.step-title{font-size:clamp(20px,2.5vw,28px);font-weight:700;color:var(--green-dark);margin-bottom:12px;line-height:1.2;}
.step-body-text{font-size:15px;color:var(--text-muted);line-height:1.8;}
.step-body-text p{margin-bottom:14px;}
.step-body-text p:last-child{margin-bottom:0;}
.step-body-text strong{color:var(--green-dark);}
.step-tip{background:var(--green-pale);border-left:4px solid var(--green);border-radius:0 var(--r) var(--r) 0;padding:12px 16px;font-size:13px;color:var(--green-dark);font-weight:600;line-height:1.6;margin-top:16px;}
.step-tip span{font-weight:400;color:var(--text-muted);}
.step-visual{background:var(--green-pale);border-radius:var(--r-lg);padding:24px;margin-top:20px;display:grid;grid-template-columns:repeat(3,1fr);gap:12px;}
.step-visual-item{background:var(--warm-white);border-radius:var(--r);padding:14px;text-align:center;border:1px solid var(--border-light);}
.step-visual-item__icon{font-size:24px;margin-bottom:6px;}
.step-visual-item__label{font-size:11px;font-weight:700;color:var(--green-dark);text-transform:uppercase;letter-spacing:.8px;}
.step-visual-item__val{font-family:'Fraunces',serif;font-size:18px;font-weight:700;color:var(--green);margin-top:2px;}

/* ── COVERAGE MINI-CALC ── */
.mini-calc{background:var(--green-dark);padding:72px 0;position:relative;overflow:hidden;}
.mini-calc__bg{position:absolute;inset:0;background:radial-gradient(ellipse 60% 80% at 20% 50%,rgba(99,153,34,.22) 0%,transparent 60%);}
.mini-calc__inner{position:relative;z-index:1;display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;}
.mini-calc__left h2{font-size:clamp(26px,3.5vw,40px);font-weight:700;color:#fff;margin-bottom:12px;line-height:1.15;}
.mini-calc__left p{font-size:15px;color:rgba(255,255,255,.6);line-height:1.75;margin-bottom:24px;}
.mini-calc__btns{display:flex;gap:12px;flex-wrap:wrap;}
.mini-calc__right{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);border-radius:var(--r-xl);padding:32px;}
.calc-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px;}
.calc-lbl{display:block;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:rgba(255,255,255,.5);margin-bottom:6px;}
.calc-input{width:100%;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);border-radius:var(--r);padding:10px 12px;font-size:14px;color:#fff;font-family:'Nunito Sans',sans-serif;outline:none;transition:border-color .18s;}
.calc-input::placeholder{color:rgba(255,255,255,.3);}
.calc-input:focus{border-color:var(--green-mid);}
.calc-input option{background:var(--green-dark);}
.calc-result-box{display:none;margin-top:16px;background:rgba(0,0,0,.25);border-radius:var(--r-lg);padding:18px;}
.calc-result-banner{font-size:12px;font-weight:600;color:var(--green-mid);margin-bottom:14px;text-align:center;}
.calc-result-cols{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.calc-result-col{background:rgba(255,255,255,.07);border-radius:var(--r);padding:14px;text-align:center;}
.calc-result-col__lbl{font-size:10px;text-transform:uppercase;letter-spacing:1px;color:rgba(255,255,255,.4);margin-bottom:4px;}
.calc-result-col__qty{font-family:'Fraunces',serif;font-size:26px;font-weight:700;color:var(--green-mid);line-height:1;}
.calc-result-col__unit{font-size:10px;color:rgba(255,255,255,.32);margin-top:2px;}
.calc-result-col__cost{font-size:14px;font-weight:700;color:#fff;margin:8px 0 3px;}
.calc-shop-btn{display:block;width:100%;margin-top:12px;background:var(--green);color:#fff;font-size:13px;font-weight:700;padding:10px;border-radius:var(--r);text-align:center;border:none;cursor:pointer;font-family:'Nunito Sans',sans-serif;transition:background .18s;text-decoration:none;}
.calc-shop-btn:hover{background:var(--green-light);}

/* ── APPLICATION TYPES ── */
.app-types{background:var(--cream);padding:80px 0;}
.app-types__header{text-align:center;margin-bottom:56px;}
.app-types__title{font-size:clamp(26px,3.5vw,42px);font-weight:700;color:var(--green-dark);margin-bottom:12px;}
.app-types__sub{font-size:16px;color:var(--text-muted);max-width:520px;margin:0 auto;}
.app-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;}
.app-card{background:var(--warm-white);border:1px solid var(--border-light);border-radius:var(--r-xl);padding:0;overflow:hidden;transition:transform .2s,border-color .2s;}
.app-card:hover{transform:translateY(-3px);border-color:var(--green-mid);}
.app-card__header{padding:24px 28px;display:flex;align-items:center;gap:16px;}
.app-card__icon{width:52px;height:52px;border-radius:var(--r-lg);background:var(--green-pale);display:flex;align-items:center;justify-content:center;font-size:26px;flex-shrink:0;}
.app-card__title{font-size:20px;font-weight:700;color:var(--green-dark);}
.app-card__sub{font-size:12px;color:var(--text-muted);margin-top:2px;}
.app-card__body{padding:0 28px 28px;}
.app-card__steps{display:flex;flex-direction:column;gap:8px;margin-bottom:16px;}
.app-step{display:flex;align-items:flex-start;gap:10px;font-size:13px;color:var(--text-muted);line-height:1.6;}
.app-step-num{width:20px;height:20px;border-radius:50%;background:var(--green-pale);color:var(--green);font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px;}
.app-card__callout{background:var(--green-pale);border-radius:var(--r);padding:12px 14px;font-size:13px;color:var(--green-dark);font-weight:600;line-height:1.5;}
.app-card__callout span{font-weight:400;color:var(--text-muted);}

/* ── MISTAKES ── */
.mistakes{background:var(--warm-white);padding:80px 0;}
.mistakes__header{text-align:center;margin-bottom:52px;}
.mistakes__title{font-size:clamp(26px,3.5vw,42px);font-weight:700;color:var(--green-dark);margin-bottom:12px;}
.mistakes__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.mistake-card{background:var(--cream);border:1px solid var(--border-light);border-radius:var(--r-lg);padding:24px;border-top:3px solid #EF4444;}
.mistake-card__wrong{display:flex;align-items:flex-start;gap:10px;margin-bottom:14px;}
.mistake-card__x{font-size:16px;flex-shrink:0;line-height:1.4;}
.mistake-card__wrong-text{font-size:14px;font-weight:700;color:#991B1B;line-height:1.4;}
.mistake-card__divider{height:1px;background:var(--border-light);margin:14px 0;position:relative;}
.mistake-card__divider::after{content:'INSTEAD';position:absolute;top:50%;left:0;transform:translateY(-50%);background:var(--cream);padding-right:10px;font-size:10px;font-weight:700;letter-spacing:1.5px;color:var(--green);}
.mistake-card__right{font-size:13px;color:var(--text-muted);line-height:1.7;}
.mistake-card__right strong{color:var(--green-dark);}

/* ── SEASONAL GUIDE ── */
.seasonal{background:var(--green-dark);padding:80px 0;position:relative;overflow:hidden;}
.seasonal__bg{position:absolute;inset:0;background:repeating-linear-gradient(42deg,rgba(255,255,255,.012) 0,rgba(255,255,255,.012) 1px,transparent 1px,transparent 24px);}
.seasonal__inner{position:relative;z-index:1;}
.seasonal__header{text-align:center;margin-bottom:52px;}
.seasonal__title{font-size:clamp(26px,3.5vw,42px);font-weight:700;color:#fff;margin-bottom:12px;}
.seasonal__sub{font-size:16px;color:rgba(255,255,255,.6);max-width:520px;margin:0 auto;}
.season-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;}
.season-card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:var(--r-xl);padding:28px;transition:background .2s,border-color .2s;}
.season-card:hover{background:rgba(255,255,255,.1);border-color:rgba(192,221,151,.3);}
.season-icon{font-size:36px;margin-bottom:14px;display:block;}
.season-name{font-family:'Fraunces',serif;font-size:20px;font-weight:700;color:#fff;margin-bottom:4px;}
.season-priority{font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;margin-bottom:14px;display:block;}
.season-priority--high{color:#86EFAC;}
.season-priority--med{color:var(--green-mid);}
.season-priority--low{color:rgba(255,255,255,.4);}
.season-tips{display:flex;flex-direction:column;gap:8px;}
.season-tip{display:flex;align-items:flex-start;gap:8px;font-size:13px;color:rgba(255,255,255,.6);line-height:1.5;}
.season-tip-dot{width:4px;height:4px;border-radius:50%;background:var(--green-mid);flex-shrink:0;margin-top:6px;}

/* ── CTA ── */
.hta-cta{background:var(--green);padding:72px 0;}
.hta-cta__inner{text-align:center;max-width:700px;margin:0 auto;}
.hta-cta h2{font-size:clamp(28px,4vw,46px);font-weight:700;color:#fff;margin-bottom:14px;}
.hta-cta p{font-size:17px;color:rgba(255,255,255,.75);margin-bottom:36px;line-height:1.7;}
.hta-cta__btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;}

/* ── RESPONSIVE ── */
@media(max-width:900px){
  .hta-hero__inner{grid-template-columns:1fr;gap:0;}
  .hta-hero__visual-col{display:none;}
  .hta-stats{grid-template-columns:repeat(2,1fr);}
  .before-start__inner{grid-template-columns:1fr;gap:40px;}
  .depth-grid{grid-template-columns:1fr;}
  .mini-calc__inner{grid-template-columns:1fr;gap:36px;}
  .app-grid{grid-template-columns:1fr;}
  .mistakes__grid{grid-template-columns:1fr;}
  .season-grid{grid-template-columns:repeat(2,1fr);}
}
@media(max-width:600px){
  .hta-hero{padding:48px 0 0;}
  .hta-stats{grid-template-columns:1fr 1fr;padding:0 20px;}
  .step-block{grid-template-columns:52px 1fr;}
  .step-visual{grid-template-columns:1fr 1fr;}
  .season-grid{grid-template-columns:1fr;}
  .calc-row,.calc-result-cols{grid-template-columns:1fr;}
}

/* ══ GALLERY PAGE ══ */
/* HERO */
.gallery-hero{background:var(--green-dark);padding:60px 0;position:relative;overflow:hidden;}
.gallery-hero__bg{position:absolute;inset:0;background:radial-gradient(ellipse 70% 100% at 85% 50%,rgba(99,153,34,.25) 0%,transparent 60%);}
.gallery-hero__inner{position:relative;z-index:1;max-width:760px;}
.gallery-hero__pill{display:inline-flex;align-items:center;gap:7px;background:rgba(192,221,151,.15);color:var(--green-mid);font-size:11px;font-weight:700;letter-spacing:1.8px;text-transform:uppercase;padding:6px 14px;border-radius:100px;margin-bottom:18px;border:1px solid rgba(192,221,151,.22);}
.gallery-hero__title{font-size:clamp(34px,5vw,56px);font-weight:700;color:#fff;line-height:1.06;margin-bottom:16px;}
.gallery-hero__title em{font-style:italic;color:var(--green-mid);}
.gallery-hero__body{font-size:17px;color:rgba(255,255,255,.68);line-height:1.75;max-width:600px;margin-bottom:28px;}
.gallery-hero__note{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);border-radius:var(--r);padding:10px 16px;font-size:13px;color:rgba(255,255,255,.65);}
.gallery-hero__note strong{color:var(--green-mid);}

/* FILTER TABS */
.gallery-filter{background:var(--warm-white);border-bottom:1px solid var(--border-light);padding:0;position:sticky;top:102px;z-index:100;}
.gallery-filter__inner{max-width:1100px;margin:0 auto;padding:0 32px;display:flex;align-items:center;gap:6px;overflow-x:auto;scrollbar-width:none;height:54px;}
.gallery-filter__inner::-webkit-scrollbar{display:none;}
.gf-btn{padding:8px 18px;border-radius:100px;border:2px solid var(--border);background:transparent;font-size:13px;font-weight:700;color:var(--text-muted);cursor:pointer;font-family:'Nunito Sans',sans-serif;transition:all .18s;white-space:nowrap;}
.gf-btn:hover{border-color:var(--green);color:var(--green);}
.gf-btn.active{background:var(--green-dark);border-color:var(--green-dark);color:#fff;}
.gf-count{font-size:11px;opacity:.6;margin-left:3px;}

/* GALLERY GRID */
.gallery-section{padding:48px 0 80px;background:var(--cream);}
.gallery-category{margin-bottom:64px;}
.gallery-category:last-child{margin-bottom:0;}
.gallery-category__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:28px;padding-bottom:16px;border-bottom:2px solid var(--green-pale);}
.gallery-category__title{font-size:24px;font-weight:700;color:var(--green-dark);}
.gallery-category__sub{font-size:14px;color:var(--text-muted);margin-top:2px;}
.gallery-category__count{font-size:13px;font-weight:700;color:var(--green);background:var(--green-pale);padding:4px 12px;border-radius:100px;}

/* Masonry-style grid */
.gallery-grid{display:grid;gap:16px;}
.gallery-grid--4{grid-template-columns:repeat(4,1fr);}
.gallery-grid--3{grid-template-columns:repeat(3,1fr);}
.gallery-grid--feature{grid-template-columns:2fr 1fr 1fr;grid-template-rows:auto auto;}
.gallery-grid--pairs{grid-template-columns:repeat(2,1fr);}

/* Photo cards */
.photo-card{position:relative;overflow:hidden;border-radius:var(--r-lg);background:var(--green-pale);cursor:pointer;group;}
.photo-card:hover .photo-card__overlay{opacity:1;}
.photo-card:hover .photo-placeholder{transform:scale(1.02);}
.photo-card--tall{grid-row:span 2;}
.photo-card--wide{grid-column:span 2;}

.photo-placeholder{width:100%;height:100%;min-height:220px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:24px;text-align:center;background:linear-gradient(135deg,var(--green-pale) 0%,var(--green-mid) 100%);transition:transform .3s;}
.photo-placeholder--dark{background:linear-gradient(135deg,#1e3d08 0%,var(--green-dark) 100%);}
.photo-placeholder--medium{background:linear-gradient(135deg,var(--green) 0%,var(--green-light) 100%);}
.photo-placeholder--ba-before{background:linear-gradient(135deg,#d6d3cd 0%,#a8a49c 100%);}
.photo-placeholder--ba-after{background:linear-gradient(135deg,var(--green-pale) 0%,var(--green-mid) 100%);}
.photo-placeholder--product{background:linear-gradient(135deg,#f0ede8 0%,#e0dbd2 100%);}

.photo-icon{font-size:36px;opacity:.7;}
.photo-shot-title{font-family:'Fraunces',serif;font-size:15px;font-weight:600;color:var(--green-dark);line-height:1.3;}
.photo-shot-title--light{color:rgba(255,255,255,.9);}
.photo-shot-desc{font-size:12px;color:var(--text-muted);line-height:1.55;max-width:220px;}
.photo-shot-desc--light{color:rgba(255,255,255,.6);}
.photo-badge{position:absolute;top:12px;left:12px;font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;padding:4px 10px;border-radius:100px;z-index:2;}
.photo-badge--placeholder{background:rgba(255,255,255,.85);color:var(--green-dark);}
.photo-badge--ba{background:var(--green-dark);color:var(--green-mid);}
.photo-badge--tip{background:rgba(0,0,0,.45);color:#fff;}

.photo-card__overlay{position:absolute;inset:0;background:rgba(39,80,10,.92);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px;text-align:center;opacity:0;transition:opacity .25s;}
.photo-card__overlay-icon{font-size:20px;margin-bottom:10px;}
.photo-card__overlay-title{font-family:'Fraunces',serif;font-size:16px;font-weight:700;color:#fff;margin-bottom:6px;line-height:1.3;}
.photo-card__overlay-desc{font-size:12px;color:rgba(255,255,255,.75);line-height:1.6;}
.photo-card__overlay-shot{margin-top:12px;background:rgba(255,255,255,.12);border-radius:var(--r);padding:8px 12px;font-size:11px;color:var(--green-mid);font-weight:600;line-height:1.5;}

/* Shot spec tag */
.shot-spec{display:inline-flex;align-items:center;gap:5px;background:rgba(255,255,255,.2);border-radius:100px;padding:3px 9px;font-size:10px;font-weight:700;color:rgba(255,255,255,.85);margin-top:8px;}
.shot-spec--dark{background:rgba(0,0,0,.2);color:rgba(255,255,255,.7);}

/* Before/After pair */
.ba-pair{display:grid;grid-template-columns:1fr 1fr;gap:3px;border-radius:var(--r-lg);overflow:hidden;}
.ba-pair__label{position:absolute;top:12px;left:12px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1px;padding:3px 9px;border-radius:100px;}
.ba-pair__label--before{background:rgba(0,0,0,.5);color:#fff;}
.ba-pair__label--after{background:var(--green-dark);color:var(--green-mid);}

/* Shot count pill */
.shot-total{display:flex;align-items:center;gap:10px;background:var(--warm-white);border-radius:var(--r-xl);padding:20px 28px;margin-bottom:40px;border:1px solid var(--border-light);}
.shot-total__num{font-family:'Fraunces',serif;font-size:36px;font-weight:700;color:var(--green);line-height:1;}
.shot-total__text{font-size:14px;color:var(--text-muted);line-height:1.5;}
.shot-total__text strong{color:var(--green-dark);display:block;font-size:15px;}

/* CTA */
.gallery-cta{background:var(--green-dark);padding:64px 0;}
.gallery-cta__inner{text-align:center;max-width:640px;margin:0 auto;}
.gallery-cta h2{font-family:'Fraunces',serif;font-size:clamp(26px,4vw,42px);font-weight:700;color:#fff;margin-bottom:12px;}
.gallery-cta p{font-size:16px;color:rgba(255,255,255,.65);margin-bottom:28px;line-height:1.7;}
.gallery-cta__btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;}

/* Responsive */
@media(max-width:900px){
  .gallery-grid--4{grid-template-columns:repeat(2,1fr);}
  .gallery-grid--feature{grid-template-columns:1fr 1fr;}
  .gallery-grid--feature .photo-card--wide{grid-column:span 2;}
}
@media(max-width:600px){
  .gallery-filter__inner{padding:0 20px;}
  .gallery-grid--4,.gallery-grid--3,.gallery-grid--feature{grid-template-columns:1fr 1fr;}
  .gallery-grid--feature .photo-card--tall{grid-row:span 1;}
  .photo-card__overlay{display:none;}
  .ba-pair{grid-template-columns:1fr;}
}

/* ══ SHIPPING PAGE ══ */
.ship-hero{background:var(--green-dark);padding:60px 0;position:relative;overflow:hidden;}
.ship-hero__bg{position:absolute;inset:0;background:radial-gradient(ellipse 70% 100% at 80% 50%,rgba(99,153,34,.28) 0%,transparent 65%);}
.ship-hero__inner{position:relative;z-index:1;max-width:680px;}
.ship-hero__pill{display:inline-flex;align-items:center;gap:7px;background:rgba(192,221,151,.15);color:var(--green-mid);font-size:11px;font-weight:700;letter-spacing:1.8px;text-transform:uppercase;padding:6px 14px;border-radius:100px;margin-bottom:18px;border:1px solid rgba(192,221,151,.22);}
.ship-hero__title{font-size:clamp(32px,5vw,52px);font-weight:700;color:#fff;line-height:1.06;margin-bottom:16px;}
.ship-hero__title em{font-style:italic;color:var(--green-mid);}
.ship-hero__body{font-size:17px;color:rgba(255,255,255,.68);line-height:1.75;margin-bottom:28px;}
.ship-hero__pills{display:flex;gap:10px;flex-wrap:wrap;}
.ship-pill{display:flex;align-items:center;gap:7px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);border-radius:100px;padding:7px 16px;font-size:13px;color:rgba(255,255,255,.75);font-weight:600;}

/* Delivery types */
.delivery-types{background:var(--warm-white);padding:72px 0;}
.del-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;}
.del-card{border-radius:var(--r-xl);overflow:hidden;border:2px solid var(--border-light);transition:border-color .2s,transform .2s;}
.del-card:hover{border-color:var(--green-mid);transform:translateY(-2px);}
.del-card__head{padding:28px 32px;display:flex;align-items:center;gap:18px;}
.del-card__head--res{background:var(--green-dark);}
.del-card__head--com{background:#1a3a6b;}
.del-card__icon{font-size:36px;}
.del-card__type{font-family:'Fraunces',serif;font-size:22px;font-weight:700;color:#fff;}
.del-card__tag{font-size:12px;color:rgba(255,255,255,.55);margin-top:2px;}
.del-card__body{padding:28px 32px;background:var(--cream);}
.del-feature{display:flex;align-items:flex-start;gap:12px;margin-bottom:16px;}
.del-feature:last-child{margin-bottom:0;}
.del-check{width:22px;height:22px;border-radius:50%;background:var(--green-pale);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px;}
.del-check--warn{background:#FEF3C7;}
.del-feature h4{font-size:14px;font-weight:700;color:var(--green-dark);margin-bottom:2px;}
.del-feature p{font-size:13px;color:var(--text-muted);line-height:1.6;}

/* Transit & packaging */
.transit-section{background:var(--cream);padding:72px 0;}
.transit-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:48px;}
.transit-card{background:var(--warm-white);border:1px solid var(--border-light);border-radius:var(--r-lg);padding:28px;text-align:center;}
.transit-card__icon{font-size:40px;margin-bottom:14px;display:block;}
.transit-card__title{font-size:17px;font-weight:700;color:var(--green-dark);margin-bottom:8px;}
.transit-card__body{font-size:13px;color:var(--text-muted);line-height:1.7;}
.transit-card__val{font-family:'Fraunces',serif;font-size:28px;font-weight:700;color:var(--green);margin:10px 0 4px;}
.transit-card__unit{font-size:12px;color:var(--text-muted);}

/* FAQ */
.ship-faq{background:var(--warm-white);padding:72px 0;}
.sfaq-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 48px;max-width:900px;margin:0 auto;}
.sfaq-item{border-bottom:1px solid var(--border-light);}
.sfaq-q{width:100%;background:none;border:none;padding:16px 0;text-align:left;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:12px;font-family:'Nunito Sans',sans-serif;}
.sfaq-q-text{font-size:14px;font-weight:700;color:var(--green-dark);line-height:1.4;}
.sfaq-chevron{width:18px;height:18px;border-radius:50%;background:var(--green-pale);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .2s;}
.sfaq-chevron svg{transition:transform .25s;}
.sfaq-item.open .sfaq-chevron{background:var(--green);}
.sfaq-item.open .sfaq-chevron svg{transform:rotate(180deg);}
.sfaq-item.open .sfaq-chevron path{stroke:#fff;}
.sfaq-a{max-height:0;overflow:hidden;transition:max-height .3s ease;}
.sfaq-item.open .sfaq-a{max-height:300px;}
.sfaq-a-inner{padding:0 0 16px;font-size:13px;color:var(--text-muted);line-height:1.72;}
.sfaq-a-inner strong{color:var(--green-dark);}

.ship-cta{background:var(--green);padding:56px 0;text-align:center;}
.ship-cta__inner{max-width:560px;margin:0 auto;}
.ship-cta h2{font-size:clamp(24px,3.5vw,38px);font-weight:700;color:#fff;margin-bottom:12px;}
.ship-cta p{font-size:15px;color:rgba(255,255,255,.72);margin-bottom:24px;}

@media(max-width:900px){.del-grid{grid-template-columns:1fr;}.transit-grid{grid-template-columns:1fr 1fr;}.sfaq-grid{grid-template-columns:1fr;}}
@media(max-width:600px){.transit-grid{grid-template-columns:1fr;}}

/* ══ VIDEO PAGE ══ */
.video-hero{background:var(--green-dark);padding:60px 0;text-align:center;position:relative;overflow:hidden;}
.video-hero__bg{position:absolute;inset:0;background:radial-gradient(ellipse 60% 80% at 50% 50%,rgba(99,153,34,.25) 0%,transparent 65%);}
.video-hero__inner{position:relative;z-index:1;max-width:640px;margin:0 auto;}
.video-hero__pill{display:inline-flex;align-items:center;gap:7px;background:rgba(192,221,151,.15);color:var(--green-mid);font-size:11px;font-weight:700;letter-spacing:1.8px;text-transform:uppercase;padding:6px 14px;border-radius:100px;margin-bottom:18px;border:1px solid rgba(192,221,151,.22);}
.video-hero__title{font-size:clamp(30px,5vw,52px);font-weight:700;color:#fff;line-height:1.06;margin-bottom:14px;}
.video-hero__title em{font-style:italic;color:var(--green-mid);}
.video-hero__body{font-size:17px;color:rgba(255,255,255,.68);line-height:1.75;}

/* Featured video */
.featured-video{background:var(--warm-white);padding:64px 0;}
.video-placeholder{background:var(--green-dark);border-radius:var(--r-xl);aspect-ratio:16/9;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;position:relative;overflow:hidden;max-width:880px;margin:0 auto 32px;}
.video-placeholder__bg{position:absolute;inset:0;background:repeating-linear-gradient(42deg,rgba(255,255,255,.015) 0,rgba(255,255,255,.015) 1px,transparent 1px,transparent 32px);}
.video-play{width:80px;height:80px;background:rgba(255,255,255,.15);border:3px solid rgba(255,255,255,.4);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;position:relative;z-index:1;}
.video-play:hover{background:var(--green);border-color:var(--green);}
.video-play svg{width:32px;height:32px;fill:#fff;margin-left:4px;}
.video-placeholder__title{font-family:'Fraunces',serif;font-size:22px;font-weight:700;color:#fff;position:relative;z-index:1;text-align:center;padding:0 24px;}
.video-placeholder__sub{font-size:14px;color:rgba(255,255,255,.55);position:relative;z-index:1;text-align:center;}
.video-placeholder__badge{position:absolute;top:20px;left:20px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);border-radius:var(--r);padding:8px 14px;font-size:12px;font-weight:700;color:rgba(255,255,255,.75);z-index:2;}
.video-placeholder__badge strong{color:var(--green-mid);display:block;font-size:10px;text-transform:uppercase;letter-spacing:1px;margin-bottom:2px;}
.video-placeholder__time{position:absolute;bottom:20px;right:20px;background:rgba(0,0,0,.6);border-radius:6px;padding:4px 10px;font-size:13px;font-weight:700;color:#fff;z-index:2;}

.featured-video__meta{max-width:880px;margin:0 auto;}
.featured-video__title{font-family:'Fraunces',serif;font-size:24px;font-weight:700;color:var(--green-dark);margin-bottom:8px;}
.featured-video__desc{font-size:15px;color:var(--text-muted);line-height:1.7;}

/* Video grid */
.video-grid-section{background:var(--cream);padding:64px 0;}
.vgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.vcard{background:var(--warm-white);border:1px solid var(--border-light);border-radius:var(--r-lg);overflow:hidden;transition:transform .2s,border-color .2s;}
.vcard:hover{transform:translateY(-3px);border-color:var(--green-mid);}
.vcard__thumb{background:var(--green-dark);aspect-ratio:16/9;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;}
.vcard__thumb-bg{position:absolute;inset:0;background:repeating-linear-gradient(42deg,rgba(255,255,255,.015) 0,rgba(255,255,255,.015) 1px,transparent 1px,transparent 24px);}
.vcard__play{width:52px;height:52px;background:rgba(255,255,255,.15);border:2px solid rgba(255,255,255,.35);border-radius:50%;display:flex;align-items:center;justify-content:center;position:relative;z-index:1;}
.vcard__play svg{width:20px;height:20px;fill:#fff;margin-left:3px;}
.vcard__thumb--col2{background:linear-gradient(135deg,#1a3a6b,#2a5298);}
.vcard__thumb--col3{background:linear-gradient(135deg,var(--green-dark),#4a7c2a);}
.vcard__thumb--col4{background:linear-gradient(135deg,#4a1942,#7a3069);}
.vcard__thumb--col5{background:linear-gradient(135deg,#1a3a2a,#2a5c3a);}
.vcard__thumb--col6{background:linear-gradient(135deg,#3a2a1a,#6a4a2a);}
.vcard__time{position:absolute;bottom:10px;right:10px;background:rgba(0,0,0,.65);border-radius:4px;padding:3px 7px;font-size:11px;font-weight:700;color:#fff;z-index:2;}
.vcard__coming{position:absolute;top:10px;left:10px;background:var(--amber);border-radius:4px;padding:3px 8px;font-size:10px;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:.5px;z-index:2;}
.vcard__body{padding:18px 20px;}
.vcard__category{font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--green);margin-bottom:5px;}
.vcard__title{font-size:15px;font-weight:700;color:var(--green-dark);margin-bottom:7px;line-height:1.35;}
.vcard__desc{font-size:13px;color:var(--text-muted);line-height:1.6;}

/* Shoot guide */
.shoot-guide{background:var(--green-dark);padding:64px 0;}
.shoot-guide__inner{position:relative;z-index:1;}
.shoot-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:40px;}
.shoot-card{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);border-radius:var(--r-lg);padding:24px;}
.shoot-card__num{font-family:'Fraunces',serif;font-size:36px;font-weight:700;color:var(--green-mid);line-height:1;margin-bottom:6px;}
.shoot-card__title{font-size:16px;font-weight:700;color:#fff;margin-bottom:8px;}
.shoot-card__list{display:flex;flex-direction:column;gap:6px;}
.shoot-card__item{display:flex;align-items:flex-start;gap:8px;font-size:13px;color:rgba(255,255,255,.6);line-height:1.5;}
.shoot-dot{width:4px;height:4px;border-radius:50%;background:var(--green-mid);flex-shrink:0;margin-top:5px;}

@media(max-width:900px){.vgrid{grid-template-columns:1fr 1fr;}.shoot-grid{grid-template-columns:1fr;}}
@media(max-width:600px){.vgrid{grid-template-columns:1fr;}}

/* ══ BLOG PAGE ══ */
.blog-hero{background:var(--green-dark);padding:60px 0;position:relative;overflow:hidden;}
.blog-hero__bg{position:absolute;inset:0;background:radial-gradient(ellipse 70% 100% at 80% 50%,rgba(99,153,34,.28) 0%,transparent 65%);}
.blog-hero__inner{position:relative;z-index:1;max-width:640px;}
.blog-hero__pill{display:inline-flex;align-items:center;gap:7px;background:rgba(192,221,151,.15);color:var(--green-mid);font-size:11px;font-weight:700;letter-spacing:1.8px;text-transform:uppercase;padding:6px 14px;border-radius:100px;margin-bottom:18px;border:1px solid rgba(192,221,151,.22);}
.blog-hero__title{font-size:clamp(30px,4.5vw,50px);font-weight:700;color:#fff;line-height:1.06;margin-bottom:14px;}
.blog-hero__title em{font-style:italic;color:var(--green-mid);}
.blog-hero__body{font-size:17px;color:rgba(255,255,255,.68);line-height:1.75;}

.blog-featured{background:var(--warm-white);padding:64px 0;}
.bf-card{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;background:var(--green-pale);border-radius:var(--r-xl);padding:48px;border:1px solid var(--green-mid);}
.bf-card__img{background:var(--green-dark);border-radius:var(--r-lg);aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;}
.bf-card__img-ph{display:flex;flex-direction:column;align-items:center;gap:10px;opacity:.4;}
.bf-card__category{font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--green);margin-bottom:8px;}
.bf-card__title{font-family:'Fraunces',serif;font-size:clamp(22px,3vw,32px);font-weight:700;color:var(--green-dark);margin-bottom:14px;line-height:1.2;}
.bf-card__excerpt{font-size:15px;color:var(--text-muted);line-height:1.75;margin-bottom:22px;}
.bf-card__meta{font-size:13px;color:var(--text-muted);display:flex;align-items:center;gap:10px;}
.bf-card__meta-dot{width:3px;height:3px;background:var(--text-light);border-radius:50%;}

.blog-grid-section{background:var(--cream);padding:64px 0;}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.article-card{background:var(--warm-white);border:1px solid var(--border-light);border-radius:var(--r-lg);overflow:hidden;transition:transform .2s,border-color .2s;}
.article-card:hover{transform:translateY(-3px);border-color:var(--green-mid);}
.article-card__img{aspect-ratio:16/9;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;}
.article-card__img-ph{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;width:100%;height:100%;padding:20px;}
.article-card__body{padding:22px 24px;}
.article-card__category{font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--green);margin-bottom:6px;}
.article-card__title{font-size:17px;font-weight:700;color:var(--green-dark);margin-bottom:8px;line-height:1.3;}
.article-card__excerpt{font-size:13px;color:var(--text-muted);line-height:1.65;margin-bottom:14px;}
.article-card__meta{font-size:12px;color:var(--text-light);display:flex;align-items:center;gap:8px;}
.article-card__meta-dot{width:3px;height:3px;background:var(--text-light);border-radius:50%;}
.article-card__read-more{font-size:13px;font-weight:700;color:var(--green);display:flex;align-items:center;gap:4px;margin-top:12px;}
.article-card__read-more svg{transition:transform .2s;}
.article-card:hover .article-card__read-more svg{transform:translateX(3px);}

.newsletter{background:var(--green-dark);padding:64px 0;text-align:center;}
.newsletter__inner{max-width:540px;margin:0 auto;}
.newsletter h2{font-size:clamp(24px,3.5vw,38px);font-weight:700;color:#fff;margin-bottom:12px;}
.newsletter p{font-size:15px;color:rgba(255,255,255,.65);margin-bottom:28px;line-height:1.7;}
.newsletter__form{display:flex;gap:0;max-width:420px;margin:0 auto;border-radius:var(--r-lg);overflow:hidden;border:2px solid rgba(255,255,255,.2);}
.newsletter__input{flex:1;background:rgba(255,255,255,.1);border:none;padding:14px 18px;font-size:14px;color:#fff;font-family:'Nunito Sans',sans-serif;outline:none;}
.newsletter__input::placeholder{color:rgba(255,255,255,.4);}
.newsletter__submit{background:var(--green);color:#fff;border:none;padding:14px 22px;font-family:'Nunito Sans',sans-serif;font-weight:700;font-size:14px;cursor:pointer;transition:background .2s;white-space:nowrap;}
.newsletter__submit:hover{background:var(--green-light);}
.newsletter__note{font-size:12px;color:rgba(255,255,255,.38);margin-top:12px;}

@media(max-width:900px){.bf-card{grid-template-columns:1fr;gap:32px;}.blog-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:600px){.blog-grid{grid-template-columns:1fr;}}

/* ══ REVIEWS PAGE ══ */
.reviews-hero{background:var(--green-dark);padding:60px 0;position:relative;overflow:hidden;text-align:center;}
.reviews-hero__bg{position:absolute;inset:0;background:radial-gradient(ellipse 60% 80% at 50% 50%,rgba(99,153,34,.25) 0%,transparent 65%);}
.reviews-hero__inner{position:relative;z-index:1;max-width:640px;margin:0 auto;}
.reviews-hero__score{font-family:'Fraunces',serif;font-size:80px;font-weight:700;color:var(--green-mid);line-height:1;margin-bottom:6px;}
.reviews-hero__stars{font-size:28px;color:#F0A500;letter-spacing:4px;margin-bottom:12px;}
.reviews-hero__sub{font-size:13px;color:rgba(255,255,255,.5);margin-bottom:24px;}
.reviews-hero__title{font-size:clamp(26px,3.5vw,40px);font-weight:700;color:#fff;margin-bottom:12px;}
.reviews-hero__body{font-size:16px;color:rgba(255,255,255,.65);line-height:1.7;margin-bottom:28px;}
.reviews-hero__trust{display:flex;align-items:center;justify-content:center;gap:24px;flex-wrap:wrap;}
.trust-pill{display:flex;align-items:center;gap:7px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);border-radius:100px;padding:7px 16px;font-size:13px;color:rgba(255,255,255,.7);font-weight:600;}
.trust-pill strong{color:var(--green-mid);}

.reviews-stats{background:var(--warm-white);padding:48px 0;border-bottom:1px solid var(--border-light);}
.reviews-stats__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:32px;text-align:center;}
.rstat{padding:0 16px;}
.rstat__num{font-family:'Fraunces',serif;font-size:42px;font-weight:700;color:var(--green-dark);line-height:1;margin-bottom:4px;}
.rstat__lbl{font-size:13px;color:var(--text-muted);font-weight:600;}

.rating-breakdown{background:var(--cream);padding:56px 0;}
.rating-breakdown__inner{display:grid;grid-template-columns:200px 1fr;gap:56px;align-items:center;max-width:800px;margin:0 auto;}
.rating-big{text-align:center;}
.rating-big__num{font-family:'Fraunces',serif;font-size:72px;font-weight:700;color:var(--green-dark);line-height:1;}
.rating-big__stars{font-size:24px;color:#F0A500;letter-spacing:2px;margin:6px 0;}
.rating-big__sub{font-size:13px;color:var(--text-muted);}
.rating-bars{display:flex;flex-direction:column;gap:10px;}
.rbar{display:flex;align-items:center;gap:12px;}
.rbar__label{font-size:13px;color:var(--text-muted);font-weight:600;width:40px;text-align:right;flex-shrink:0;}
.rbar__track{flex:1;height:10px;background:var(--border-light);border-radius:100px;overflow:hidden;}
.rbar__fill{height:100%;background:var(--green);border-radius:100px;transition:width 1s ease;}
.rbar__count{font-size:12px;color:var(--text-muted);width:40px;flex-shrink:0;}

.reviews-grid-section{padding:64px 0;background:var(--warm-white);}
.reviews-filter{display:flex;gap:8px;justify-content:center;margin-bottom:40px;flex-wrap:wrap;}
.rf-btn{padding:8px 20px;border-radius:100px;border:2px solid var(--border);background:transparent;font-size:13px;font-weight:700;color:var(--text-muted);cursor:pointer;font-family:'Nunito Sans',sans-serif;transition:all .18s;}
.rf-btn:hover{border-color:var(--green);color:var(--green);}
.rf-btn.active{background:var(--green-dark);border-color:var(--green-dark);color:#fff;}
.rcard-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.rcard{background:var(--cream);border:1px solid var(--border-light);border-radius:var(--r-lg);padding:26px;transition:border-color .2s;}
.rcard:hover{border-color:var(--green-mid);}
.rcard__header{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:14px;}
.rcard__stars{color:#F0A500;font-size:14px;letter-spacing:2px;}
.rcard__verified{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--green);background:var(--green-pale);border-radius:100px;padding:3px 8px;}
.rcard__body{font-family:'Fraunces',serif;font-size:15px;font-style:italic;color:var(--green-dark);line-height:1.6;margin-bottom:16px;}
.rcard__footer{display:flex;align-items:center;justify-content:space-between;gap:8px;}
.rcard__author{font-size:13px;font-weight:700;color:var(--green);}
.rcard__meta{font-size:11px;color:var(--text-light);}
.rcard__product{font-size:11px;color:var(--text-muted);margin-top:2px;}

.reviews-featured{background:var(--green-pale);padding:56px 0;}
.rfeatured{max-width:760px;margin:0 auto;text-align:center;}
.rfeatured__stars{font-size:28px;color:#F0A500;letter-spacing:4px;margin-bottom:20px;}
.rfeatured__quote{font-family:'Fraunces',serif;font-size:clamp(20px,3vw,28px);font-style:italic;color:var(--green-dark);line-height:1.55;margin-bottom:22px;}
.rfeatured__author{font-size:15px;font-weight:700;color:var(--green);}
.rfeatured__meta{font-size:13px;color:var(--text-muted);margin-top:4px;}

.write-review{background:var(--green-dark);padding:56px 0;text-align:center;}
.write-review__inner{max-width:560px;margin:0 auto;}
.write-review h2{font-size:clamp(24px,3.5vw,36px);font-weight:700;color:#fff;margin-bottom:12px;}
.write-review p{font-size:15px;color:rgba(255,255,255,.65);margin-bottom:24px;line-height:1.7;}
.write-review__btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;}

@media(max-width:900px){.reviews-stats__grid{grid-template-columns:repeat(2,1fr);}.rating-breakdown__inner{grid-template-columns:1fr;gap:32px;}.rcard-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:600px){.rcard-grid{grid-template-columns:1fr;}.reviews-hero__trust{flex-direction:column;gap:10px;}}

/* ══ 404 PAGE ══ */
body{display:flex;flex-direction:column;min-height:100vh;}
.four-oh-four{flex:1;display:flex;align-items:center;justify-content:center;background:var(--cream);padding:80px 32px;}
.fof-inner{max-width:640px;text-align:center;}
.fof-num{font-family:'Fraunces',serif;font-size:clamp(100px,20vw,160px);font-weight:700;line-height:.9;color:var(--green-pale);position:relative;display:inline-block;margin-bottom:8px;}
.fof-num::after{content:'404';position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:var(--green-dark);font-size:inherit;}
.fof-icon{font-size:48px;margin-bottom:20px;display:block;}
.fof-title{font-family:'Fraunces',serif;font-size:clamp(26px,4vw,40px);font-weight:700;color:var(--green-dark);margin-bottom:14px;}
.fof-body{font-size:16px;color:var(--text-muted);line-height:1.75;margin-bottom:36px;max-width:480px;margin-left:auto;margin-right:auto;}
.fof-links{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;max-width:500px;margin:0 auto 36px;}
.fof-link{display:flex;align-items:center;gap:12px;background:var(--warm-white);border:1px solid var(--border-light);border-radius:var(--r-lg);padding:16px 18px;text-decoration:none;transition:border-color .2s,transform .2s;}
.fof-link:hover{border-color:var(--green-mid);transform:translateY(-2px);}
.fof-link__icon{font-size:24px;flex-shrink:0;}
.fof-link__text{font-size:14px;font-weight:700;color:var(--green-dark);}
.fof-link__sub{font-size:12px;color:var(--text-muted);margin-top:1px;}
.fof-search{display:flex;gap:0;max-width:420px;margin:0 auto;border-radius:var(--r-lg);overflow:hidden;border:2px solid var(--border);}
.fof-search input{flex:1;background:var(--warm-white);border:none;padding:13px 16px;font-size:14px;color:var(--text);font-family:'Nunito Sans',sans-serif;outline:none;}
.fof-search button{background:var(--green);color:#fff;border:none;padding:13px 20px;font-family:'Nunito Sans',sans-serif;font-weight:700;font-size:14px;cursor:pointer;transition:background .2s;}
.fof-search button:hover{background:var(--green-dark);}
.fof-help{margin-top:28px;font-size:13px;color:var(--text-muted);}
.fof-help a{color:var(--green);font-weight:600;}
@media(max-width:600px){.fof-links{grid-template-columns:1fr;}.four-oh-four{padding:60px 20px;}}

/* ══════════════════════════════════════════════════════════
   CSS BRIDGE — maps Liquid section class names to styles
   These rules cover mismatches between section HTML and 
   the reference CSS extracted from the static HTML.
══════════════════════════════════════════════════════════ */

/* ── Product Grid: .pgrid__cards → .cards layout ── */
.pgrid__cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.pgrid__tabs { display: flex; gap: 8px; justify-content: center; margin-bottom: 40px; flex-wrap: wrap; }
.pgrid__controls { margin-bottom: 24px; }
.pgrid__note { display: flex; align-items: center; gap: 8px; margin-top: 32px; padding: 16px 20px; background: var(--green-pale); border-radius: var(--r); font-size: 14px; color: var(--green-dark); font-weight: 600; }
.d-info { display: none; text-align: center; font-size: 13px; color: var(--amber); background: var(--amber-pale); border: 1px solid #FDE68A; border-radius: var(--r); padding: 10px 16px; margin-bottom: 20px; }

@media(max-width:900px){ .pgrid__cards { grid-template-columns: repeat(2, 1fr); } }
@media(max-width:600px){ .pgrid__cards { grid-template-columns: 1fr; } .pgrid__tabs { gap: 4px; } .tab { padding: 7px 14px; font-size: 12px; } }

/* ── Benefits Grid: .benefit-card → card styles ── */
.benefit-card { background: var(--warm-white); border: 1px solid var(--border-light); border-radius: var(--r-lg); padding: 32px 28px; transition: box-shadow .2s, transform .2s; }
.benefit-card:hover { box-shadow: 0 8px 32px rgba(59,109,17,.1); transform: translateY(-3px); }
.benefit-card__icon { font-size: 32px; margin-bottom: 16px; }
.benefit-card__title { font-family: 'Fraunces', serif; font-size: 20px; font-weight: 700; color: var(--green-dark); margin-bottom: 10px; }
.benefit-card__body { font-size: 14px; color: var(--text-muted); line-height: 1.7; margin-bottom: 16px; }
.benefit-card__stat { display: inline-flex; align-items: center; gap: 6px; font-size: 12px; font-weight: 700; color: var(--green); background: var(--green-pale); padding: 5px 12px; border-radius: 100px; }
.benefit-card__stat::before { content: '✓'; }

/* ── Calculator Section ── */
.calc-section { padding: 96px 0; background: var(--green-dark); color: #fff; }
.calc__header { text-align: center; margin-bottom: 40px; }
.calc__header .eyebrow { color: var(--green-mid); }
.calc__title { font-size: clamp(28px, 4vw, 46px); font-weight: 700; color: #fff; margin-bottom: 12px; }
.calc__sub { font-size: 17px; color: rgba(255,255,255,.6); max-width: 540px; margin: 0 auto; }
.calc__body { max-width: 820px; margin: 0 auto; }
.calc__inputs { background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.12); border-radius: var(--r-xl); padding: 36px 32px; margin-bottom: 24px; }
.calc__row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-bottom: 16px; }
.calc__field { display: flex; flex-direction: column; gap: 6px; }
.calc__lbl { font-size: 12px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; color: rgba(255,255,255,.5); }
.calc__input { padding: 12px 16px; border-radius: var(--r); border: 1px solid rgba(255,255,255,.2); background: rgba(255,255,255,.06); color: #fff; font-family: 'Nunito Sans', sans-serif; font-size: 15px; font-weight: 600; transition: border-color .2s; appearance: none; -webkit-appearance: none; }
.calc__input:focus { outline: none; border-color: var(--green-mid); }
.calc__input option { background: var(--green-dark); color: #fff; }
.calc__delivery-toggle { display: flex; justify-content: center; gap: 10px; margin: 20px 0; }
.calc__specs { display: flex; flex-direction: column; gap: 8px; margin-top: 16px; }
.calc__spec { display: flex; align-items: center; gap: 8px; font-size: 12px; color: rgba(255,255,255,.45); }
.calc__spec-dot { width: 5px; height: 5px; background: var(--green-mid); border-radius: 50%; flex-shrink: 0; }

/* Calculator results */
.calc__results { background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.15); border-radius: var(--r-xl); padding: 32px; }
.calc__result-banner { text-align: center; font-size: 15px; font-weight: 700; color: var(--green-mid); margin-bottom: 24px; padding-bottom: 20px; border-bottom: 1px solid rgba(255,255,255,.1); }
.calc__result-cols { display: grid; grid-template-columns: 1fr 1fr; gap: 32px; margin-bottom: 24px; }
.calc__col { text-align: center; }
.calc__col-lbl { font-size: 12px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; color: rgba(255,255,255,.45); margin-bottom: 8px; }
.calc__col-qty { font-family: 'Fraunces', serif; font-size: 36px; font-weight: 700; color: var(--green-mid); line-height: 1; margin-bottom: 6px; }
.calc__col-unit { font-size: 12px; color: rgba(255,255,255,.4); margin-bottom: 8px; }
.calc__col-cost { font-size: 18px; font-weight: 700; color: #fff; margin-bottom: 12px; }
.calc__shop-btn { display: inline-flex; align-items: center; gap: 6px; padding: 8px 18px; border-radius: var(--r); background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.2); color: #fff; font-size: 13px; font-weight: 700; text-decoration: none; transition: all .2s; }
.calc__shop-btn:hover { background: rgba(255,255,255,.18); }
.calc__result-cta { text-align: center; }
@media(max-width:600px){ .calc__row { grid-template-columns: 1fr; } .calc__result-cols { grid-template-columns: 1fr; } .calc__inputs { padding: 24px 20px; } }

/* ── Why Us Section ── */
.why-us { padding: 96px 0; background: var(--cream); }
.why-us__header { text-align: center; margin-bottom: 48px; }
.why-us__title { font-size: clamp(28px, 4vw, 46px); font-weight: 700; color: var(--green-dark); margin-bottom: 12px; }
.why-us__sub { font-size: 17px; color: var(--text-muted); max-width: 540px; margin: 0 auto; }
.why-us__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.why-card { background: var(--warm-white); border: 1px solid var(--border-light); border-radius: var(--r-lg); padding: 32px 28px; transition: box-shadow .2s; }
.why-card:hover { box-shadow: 0 8px 24px rgba(59,109,17,.08); }
.why-card__icon { font-size: 28px; margin-bottom: 14px; }
.why-card__title { font-family: 'Fraunces', serif; font-size: 18px; font-weight: 700; color: var(--green-dark); margin-bottom: 10px; }
.why-card__body { font-size: 14px; color: var(--text-muted); line-height: 1.7; margin-bottom: 14px; }
.why-card__stat { font-size: 12px; font-weight: 700; color: var(--green); }
@media(max-width:900px){ .why-us__grid { grid-template-columns: repeat(2, 1fr); } }
@media(max-width:600px){ .why-us__grid { grid-template-columns: 1fr; } }

/* ── How It Works Section ── */
.how { padding: 96px 0; background: var(--warm-white); }
.how__header { text-align: center; margin-bottom: 48px; }
.how__title { font-size: clamp(28px, 4vw, 46px); font-weight: 700; color: var(--green-dark); margin-bottom: 12px; }
.how__sub { font-size: 17px; color: var(--text-muted); max-width: 540px; margin: 0 auto; }
.how__steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; counter-reset: step-counter; }
.how-step { text-align: center; position: relative; }
.how-step__num { display: inline-flex; align-items: center; justify-content: center; width: 48px; height: 48px; background: var(--green-pale); border-radius: 50%; font-family: 'Fraunces', serif; font-size: 20px; font-weight: 700; color: var(--green); margin-bottom: 20px; }
.how-step__icon { font-size: 28px; margin-bottom: 8px; }
.how-step__title { font-family: 'Fraunces', serif; font-size: 18px; font-weight: 700; color: var(--green-dark); margin-bottom: 10px; }
.how-step__body { font-size: 14px; color: var(--text-muted); line-height: 1.7; }
.how__visual { display: flex; align-items: center; justify-content: center; gap: 16px; background: var(--green-pale); border-radius: var(--r-xl); padding: 32px; margin-top: 40px; }
.how__visual-num { font-family: 'Fraunces', serif; font-size: 48px; font-weight: 700; color: var(--green); }
.how__visual-unit { font-size: 14px; color: var(--green-dark); font-weight: 600; }
@media(max-width:900px){ .how__steps { grid-template-columns: 1fr; gap: 40px; } }

/* ── Reviews Section ── */
.reviews { padding: 96px 0; background: var(--warm-white); }
.reviews__header { text-align: center; margin-bottom: 40px; }
.reviews__stars { font-size: 28px; color: #F59E0B; margin-bottom: 8px; letter-spacing: 4px; }
.reviews__title { font-size: clamp(28px, 4vw, 46px); font-weight: 700; color: var(--green-dark); margin-bottom: 12px; }
.reviews__sub { font-size: 17px; color: var(--text-muted); max-width: 540px; margin: 0 auto; }
.reviews__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.review-card { background: var(--cream); border: 1px solid var(--border-light); border-radius: var(--r-lg); padding: 32px; }
.review-card__stars { font-size: 16px; color: #F59E0B; margin-bottom: 14px; letter-spacing: 2px; }
.review-card__quote { font-size: 15px; color: var(--text); line-height: 1.7; margin-bottom: 20px; font-style: italic; }
.review-card__author { font-size: 14px; font-weight: 700; color: var(--green-dark); }
.review-card__location { font-size: 12px; color: var(--text-muted); }
.review-card__product { font-size: 11px; color: var(--text-light); margin-top: 4px; }
@media(max-width:900px){ .reviews__grid { grid-template-columns: 1fr 1fr; } }
@media(max-width:600px){ .reviews__grid { grid-template-columns: 1fr; } }

/* ── Guarantee Bar ── */
.guarantee { padding: 56px 0; background: var(--green-pale); }
.guarantee__inner { display: flex; align-items: center; gap: 40px; flex-wrap: wrap; }
.guarantee__badge { flex-shrink: 0; text-align: center; }
.guarantee__badge-num { font-family: 'Fraunces', serif; font-size: 42px; font-weight: 700; color: var(--green); line-height: 1; }
.guarantee__badge-txt { font-size: 11px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; color: var(--green-dark); margin-top: 4px; }
.guarantee__content { flex: 1; min-width: 280px; }
.guarantee__content h2 { font-size: 24px; font-weight: 700; color: var(--green-dark); margin-bottom: 10px; }
.guarantee__content p { font-size: 14px; color: var(--text-muted); line-height: 1.7; }
.trust-badges { display: flex; gap: 24px; margin-left: auto; }
.trust-badge { text-align: center; }
.trust-badge__icon { font-size: 24px; margin-bottom: 6px; }
.trust-badge__lbl { font-size: 11px; font-weight: 700; color: var(--green-dark); line-height: 1.4; }
@media(max-width:900px){ .guarantee__inner { justify-content: center; text-align: center; } .trust-badges { margin-left: 0; } }

/* ── Footer extras ── */
.footer__brand-col { min-width: 0; }
.footer__social { display: flex; gap: 12px; margin-top: 16px; }
.footer__social-link { display: flex; align-items: center; justify-content: center; width: 36px; height: 36px; border-radius: 50%; background: rgba(255,255,255,.08); color: rgba(255,255,255,.5); transition: all .2s; }
.footer__social-link:hover { background: rgba(255,255,255,.15); color: var(--green-mid); }

/* ── Mulch Comparison (vs) Section ── */
.vs-section { padding: 96px 0; background: var(--cream); }
.vs__header { text-align: center; margin-bottom: 40px; }
.vs__title { font-size: clamp(28px, 4vw, 46px); font-weight: 700; color: var(--green-dark); margin-bottom: 12px; }
.vs__sub { font-size: 17px; color: var(--text-muted); max-width: 540px; margin: 0 auto; }

/* ── Masters Moment ── */
.masters-moment { background: var(--green-dark); color: #fff; padding: 0; overflow: hidden; }
.masters-photo { position: relative; }
.masters-photo img { width: 100%; height: 400px; object-fit: cover; }
.masters-photo__placeholder { width: 100%; height: 400px; background: linear-gradient(145deg, #1e3d08, #3B6D11, #639922); display: flex; align-items: center; justify-content: center; }

/* ── FAQ Section ── */
.faq { padding: 96px 0; background: var(--warm-white); }
.faq__header { text-align: center; margin-bottom: 48px; }
.faq__title { font-size: clamp(28px, 4vw, 46px); font-weight: 700; color: var(--green-dark); margin-bottom: 12px; }
.faq__sub { font-size: 17px; color: var(--text-muted); max-width: 540px; margin: 0 auto; }
.faq__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.faq__item { border: 1px solid var(--border-light); border-radius: var(--r); overflow: hidden; background: var(--cream); }
.faq__q { display: flex; align-items: center; justify-content: space-between; width: 100%; padding: 18px 20px; border: none; background: none; cursor: pointer; font-family: 'Nunito Sans', sans-serif; font-size: 15px; font-weight: 700; color: var(--green-dark); text-align: left; gap: 12px; transition: background .15s; }
.faq__q:hover { background: var(--green-pale); }
.faq__q-text { flex: 1; }
.faq__chevron { transition: transform .25s; display: flex; }
.faq__a { max-height: 0; overflow: hidden; transition: max-height .3s ease; }
.faq__a-inner { padding: 0 20px 18px; font-size: 14px; color: var(--text-muted); line-height: 1.75; }
.faq__item.open .faq__chevron { transform: rotate(180deg); }
.faq__item.open .faq__a { max-height: 300px; }
.faq__cta { text-align: center; margin-top: 48px; }
@media(max-width:700px){ .faq__grid { grid-template-columns: 1fr; } }

/* ── Main Page (generic Shopify page content) ── */
.page-content { padding: 80px 0; }
.page-content h1 { font-size: clamp(28px, 4vw, 42px); font-weight: 700; color: var(--green-dark); margin-bottom: 24px; }
.page-content .rte { font-size: 16px; line-height: 1.8; color: var(--text); max-width: 720px; }
.page-content .rte h2 { font-family: 'Fraunces', serif; font-size: 24px; color: var(--green-dark); margin: 32px 0 12px; }
.page-content .rte p { margin-bottom: 16px; }
.page-content .rte ul, .page-content .rte ol { margin: 16px 0; padding-left: 24px; }
.page-content .rte img { border-radius: var(--r-lg); margin: 24px 0; }

/* ── 404 Page ── */
.fof { padding: 120px 0; text-align: center; }
.fof__icon { font-size: 64px; margin-bottom: 24px; opacity: .3; }
.fof h1 { font-size: 48px; font-weight: 700; color: var(--green-dark); margin-bottom: 12px; }
.fof p { font-size: 18px; color: var(--text-muted); margin-bottom: 32px; }
.fof-links { display: flex; justify-content: center; gap: 16px; flex-wrap: wrap; margin-bottom: 40px; }
.fof-link { display: flex; align-items: center; gap: 10px; padding: 14px 24px; border-radius: var(--r-lg); background: var(--warm-white); border: 1px solid var(--border-light); text-decoration: none; transition: all .18s; }
.fof-link:hover { border-color: var(--green); box-shadow: 0 4px 16px rgba(59,109,17,.08); }
.fof-link__icon { font-size: 20px; }
.fof-link__text { font-size: 14px; font-weight: 700; color: var(--green-dark); }
.fof-link__sub { font-size: 12px; color: var(--text-muted); }

/* ── Cart Page ── */
.cart-page { padding: 80px 0; }
.cart-page h1 { font-size: 32px; font-weight: 700; color: var(--green-dark); margin-bottom: 32px; }
.cart-page__empty { text-align: center; padding: 60px 0; }
.cart-page__item { display: flex; gap: 16px; padding: 20px 0; border-bottom: 1px solid var(--border-light); }
.cart-page__total { padding: 24px 0; text-align: right; }

/* ── Collection Page ── */
.collection-page { padding: 80px 0; }
.collection-page__header { margin-bottom: 32px; }
.collection-page__header h1 { font-size: 32px; font-weight: 700; color: var(--green-dark); }
.collection-page__desc { font-size: 16px; color: var(--text-muted); margin-top: 8px; }

/* ── How It Works: Steps 3-across horizontal layout ── */
.how__steps-row { display: grid; grid-template-columns: repeat(3, 1fr); gap: 40px; margin-bottom: 48px; }
.how__step-col { text-align: center; }
.how__step-col .step__num { margin: 0 auto 20px; }
.how__step-title { font-family: 'Fraunces', serif; font-size: 20px; font-weight: 700; color: var(--green-dark); margin-bottom: 12px; }
.how__step-body { font-size: 14px; color: var(--text-muted); line-height: 1.75; }
@media(max-width:700px){ .how__steps-row { grid-template-columns: 1fr; gap: 32px; } }

/* ── Calculator: Green header text ── */
.calc__header .eyebrow { color: var(--green); }
.calc__title { color: var(--green-dark) !important; }
.calc__sub { color: var(--text-muted) !important; }

/* ── Dual Filter System ── */
.pgrid__filter-group { display: flex; align-items: center; gap: 12px; justify-content: center; margin-bottom: 16px; flex-wrap: wrap; }
.pgrid__filter-label { font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; color: var(--text-muted); white-space: nowrap; }
.pgrid__filter-group .tabs { margin-bottom: 0; }
@media(max-width:600px){ .pgrid__filter-group { flex-direction: column; gap: 8px; } .pgrid__filter-label { display: none; } }

/* ══════════════════════════════════════════
   PRODUCT DETAIL PAGE
══════════════════════════════════════════ */

/* Breadcrumb */
.pdp-breadcrumb { padding: 16px 0; font-size: 13px; color: var(--text-light); }
.pdp-breadcrumb a { color: var(--text-muted); text-decoration: none; }
.pdp-breadcrumb a:hover { color: var(--green); }
.pdp-breadcrumb span { margin: 0 8px; }
.pdp-breadcrumb__current { color: var(--green); font-weight: 600; }

/* Product Hero */
.pdp { padding: 0 0 64px; background: var(--warm-white); }
.pdp__inner { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: start; }

/* Gallery */
.pdp__gallery { position: sticky; top: 120px; }
.pdp__main-img { border-radius: var(--r-xl); overflow: hidden; background: var(--cream); aspect-ratio: 1; display: flex; align-items: center; justify-content: center; }
.pdp__main-img img { width: 100%; height: 100%; object-fit: cover; }
.pdp__img-placeholder { display: flex; flex-direction: column; align-items: center; gap: 12px; font-size: 64px; opacity: .3; }
.pdp__img-placeholder span { font-size: 13px; }
.pdp__thumbs { display: flex; gap: 10px; margin-top: 12px; overflow-x: auto; padding: 4px 0; }
.pdp__thumb { width: 72px; height: 72px; border-radius: var(--r); overflow: hidden; border: 2px solid transparent; cursor: pointer; flex-shrink: 0; background: none; padding: 0; }
.pdp__thumb img { width: 100%; height: 100%; object-fit: cover; }
.pdp__thumb.active { border-color: var(--green); }
.pdp__thumb:hover { border-color: var(--green-mid); }

/* Info */
.pdp__badges { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 16px; }
.pdp__badge { display: inline-flex; align-items: center; gap: 5px; font-size: 11px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; padding: 4px 12px; border-radius: 100px; }
.pdp__badge--a { background: var(--green-pale); color: var(--green); }
.pdp__badge--b { background: var(--amber-pale); color: var(--amber); }
.pdp__badge--needle { background: var(--cream); color: var(--text-muted); border: 1px solid var(--border-light); letter-spacing: 0; text-transform: none; }
.pdp__badge--del { background: var(--cream); color: var(--text-muted); border: 1px solid var(--border-light); letter-spacing: 0; text-transform: none; }
.pdp__title { font-size: clamp(24px, 3.5vw, 36px); font-weight: 700; color: var(--green-dark); margin-bottom: 20px; line-height: 1.15; }
.pdp__price-block { margin-bottom: 24px; padding: 20px 24px; background: var(--green-pale); border-radius: var(--r-lg); }
.pdp__price { font-family: 'Fraunces', serif; font-size: 36px; font-weight: 700; color: var(--green-dark); line-height: 1; }
.pdp__price-note { font-size: 13px; color: var(--green); font-weight: 600; margin-top: 6px; }
.pdp__desc { font-size: 15px; color: var(--text-muted); line-height: 1.75; margin-bottom: 28px; }
.pdp__desc.rte { max-width: 100%; }

/* Form */
.pdp__form { margin-bottom: 24px; }
.pdp__variant-label { font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; color: var(--text-muted); margin-bottom: 8px; display: block; }
.pdp__variant-select { width: 100%; padding: 12px 16px; border: 1.5px solid var(--border); border-radius: var(--r); font-family: 'Nunito Sans', sans-serif; font-size: 15px; font-weight: 600; color: var(--text); background: var(--warm-white); margin-bottom: 16px; appearance: none; }
.pdp__variants { margin-bottom: 16px; }
.pdp__qty-row { margin-bottom: 16px; }
.pdp__qty-controls { display: flex; align-items: center; border: 1.5px solid var(--border); border-radius: var(--r); overflow: hidden; width: fit-content; }
.pdp__qty-btn { width: 44px; height: 44px; border: none; background: none; cursor: pointer; font-size: 20px; color: var(--green-dark); display: flex; align-items: center; justify-content: center; transition: background .15s; }
.pdp__qty-btn:hover { background: var(--green-pale); }
.pdp__qty-input { width: 52px; height: 44px; border: none; border-left: 1.5px solid var(--border); border-right: 1.5px solid var(--border); text-align: center; font-family: 'Nunito Sans', sans-serif; font-size: 16px; font-weight: 700; color: var(--text); }
.pdp__qty-input::-webkit-inner-spin-button { display: none; }
.pdp__add-btn { width: 100%; justify-content: center; font-size: 17px; padding: 16px 24px; }

/* Trust */
.pdp__trust { display: flex; flex-direction: column; gap: 10px; padding-top: 20px; border-top: 1px solid var(--border-light); }
.pdp__trust-item { display: flex; align-items: center; gap: 10px; font-size: 14px; font-weight: 600; color: var(--text-muted); }

/* ── Specs Bar ── */
.pdp-specs { padding: 48px 0; background: var(--green-dark); color: #fff; }
.pdp-specs__grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 32px; text-align: center; }
.pdp-specs__icon { font-size: 28px; margin-bottom: 8px; }
.pdp-specs__val { font-family: 'Fraunces', serif; font-size: 24px; font-weight: 700; color: var(--green-mid); line-height: 1; margin-bottom: 4px; }
.pdp-specs__lbl { font-size: 12px; color: rgba(255,255,255,.5); font-weight: 600; text-transform: uppercase; letter-spacing: 1px; }

/* ── Benefits Strip ── */
.pdp-benefits { padding: 56px 0; background: var(--green-pale); }
.pdp-benefits__title { font-size: 24px; font-weight: 700; color: var(--green-dark); text-align: center; margin-bottom: 32px; }
.pdp-benefits__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.pdp-benefits__item { display: flex; gap: 14px; align-items: flex-start; }
.pdp-benefits__icon { font-size: 24px; flex-shrink: 0; margin-top: 2px; }
.pdp-benefits__item strong { font-size: 14px; color: var(--green-dark); }
.pdp-benefits__item span { font-size: 13px; color: var(--text-muted); }

/* ── How to Apply ── */
.pdp-apply { padding: 80px 0; background: var(--warm-white); }
.pdp-apply__inner { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center; }
.pdp-apply__title { font-size: clamp(24px, 3vw, 36px); font-weight: 700; color: var(--green-dark); margin-bottom: 32px; }
.pdp-apply__steps { display: flex; flex-direction: column; gap: 24px; }
.pdp-apply__step { display: flex; gap: 16px; align-items: flex-start; }
.pdp-apply__step .step__num { flex-shrink: 0; }
.pdp-apply__step strong { color: var(--green-dark); }
.pdp-apply__step div:last-child { font-size: 15px; color: var(--text-muted); line-height: 1.65; }
.pdp-apply__visual { display: flex; flex-direction: column; align-items: center; gap: 16px; }
.pdp-apply__depth { display: flex; align-items: flex-end; gap: 16px; height: 200px; }
.pdp-apply__depth-bar { width: 80px; background: var(--green-pale); border-radius: var(--r) var(--r) 0 0; display: flex; align-items: flex-start; justify-content: center; padding-top: 12px; transition: all .3s; }
.pdp-apply__depth-bar span { font-family: 'Fraunces', serif; font-size: 18px; font-weight: 700; color: var(--green); }
.pdp-apply__depth-bar--rec { background: var(--green); }
.pdp-apply__depth-bar--rec span { color: #fff; }
.pdp-apply__depth-labels { display: flex; gap: 16px; font-size: 12px; color: var(--text-muted); text-align: center; }
.pdp-apply__depth-labels span { width: 80px; }

/* ── Calculator CTA ── */
.pdp-calc-cta { padding: 48px 0; background: var(--cream); }
.pdp-calc-cta__inner { display: flex; align-items: center; justify-content: space-between; gap: 32px; background: var(--warm-white); border: 1px solid var(--border-light); border-radius: var(--r-xl); padding: 36px 40px; }
.pdp-calc-cta__inner h3 { font-size: 22px; font-weight: 700; color: var(--green-dark); margin-bottom: 6px; }
.pdp-calc-cta__inner p { font-size: 15px; color: var(--text-muted); }

/* ── Responsive ── */
@media(max-width:900px){
  .pdp__inner { grid-template-columns: 1fr; gap: 32px; }
  .pdp__gallery { position: static; }
  .pdp-specs__grid { grid-template-columns: repeat(3, 1fr); gap: 20px; }
  .pdp-benefits__grid { grid-template-columns: repeat(2, 1fr); }
  .pdp-apply__inner { grid-template-columns: 1fr; gap: 40px; }
  .pdp-calc-cta__inner { flex-direction: column; text-align: center; }
}
@media(max-width:600px){
  .pdp-specs__grid { grid-template-columns: repeat(2, 1fr); }
  .pdp-benefits__grid { grid-template-columns: 1fr; }
  .pdp-apply__depth-bar { width: 60px; }
  .pdp-apply__depth-labels span { width: 60px; font-size: 10px; }
}

/* ── Product card links ── */
a.card__img { display: block; text-decoration: none; }
a.card__name { text-decoration: none; color: var(--green-dark); }
a.card__name:hover { color: var(--green); }

/* ── Sticky Navigation Fix ── */
/* Shopify wraps sections in .shopify-section divs which can break sticky.
   Target the header section wrapper specifically. */
.shopify-section--header {
  position: sticky;
  top: 0;
  z-index: 200;
}
/* Also handle when there's no specific class */
#shopify-section-header {
  position: sticky;
  top: 0;
  z-index: 200;
}

/* ══════════════════════════════════════════
   DYNAMIC PRODUCT DESCRIPTION (Product Grid)
══════════════════════════════════════════ */
.pgrid__desc { max-width: 800px; margin: 0 auto 32px; }
.pgrid__desc-inner { background: var(--warm-white); border: 1px solid var(--border-light); border-radius: var(--r-lg); padding: 24px 28px; transition: all .3s ease; }
.pgrid__desc-name { font-family: 'Fraunces', serif; font-size: 20px; color: var(--green-dark); }
.pgrid__desc-species { font-size: 13px; font-weight: 400; color: var(--text-light); font-style: italic; }
.pgrid__desc-text { font-size: 14px; color: var(--text-muted); line-height: 1.72; margin-bottom: 12px; }
.pgrid__desc-coverage { font-size: 13px; font-weight: 600; color: var(--green); background: var(--green-pale); padding: 8px 14px; border-radius: var(--r); display: inline-block; }

/* ══════════════════════════════════════════
   CART PAGE
══════════════════════════════════════════ */
.cart-page { padding: 32px 0 80px; }

/* Empty cart */
.cart-empty { text-align: center; padding: 80px 0; }
.cart-empty__icon { font-size: 64px; margin-bottom: 20px; opacity: .6; }
.cart-empty__title { font-family: 'Fraunces', serif; font-size: 32px; color: var(--green-dark); margin-bottom: 12px; }
.cart-empty__body { font-size: 16px; color: var(--text-muted); max-width: 420px; margin: 0 auto 28px; line-height: 1.7; }

/* Cart header */
.cart-head { display: flex; align-items: baseline; gap: 16px; margin-bottom: 32px; padding-bottom: 20px; border-bottom: 2px solid var(--green-pale); }
.cart-head__title { font-family: 'Fraunces', serif; font-size: 32px; font-weight: 700; color: var(--green-dark); }
.cart-head__count { font-size: 15px; color: var(--text-muted); }

/* Cart layout: items left, summary right */
.cart-layout { display: grid; grid-template-columns: 1fr 380px; gap: 40px; align-items: start; }

/* Cart items */
.cart-items { display: flex; flex-direction: column; gap: 0; }
.cart-item { display: grid; grid-template-columns: 100px 1fr auto; gap: 20px; padding: 24px 0; border-bottom: 1px solid var(--border-light); align-items: start; }

/* Cart item image */
.cart-item__img { width: 100px; height: 100px; border-radius: var(--r); overflow: hidden; background: var(--cream); flex-shrink: 0; }
.cart-item__img img { width: 100%; height: 100%; object-fit: cover; }
.cart-item__img-ph { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; font-size: 32px; opacity: .4; }

/* Cart item details */
.cart-item__badges { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 8px; }
.cart-item__badge { font-size: 10px; font-weight: 700; letter-spacing: 0.5px; text-transform: uppercase; padding: 2px 8px; border-radius: 100px; }
.cart-item__badge--a { background: var(--green-pale); color: var(--green); }
.cart-item__badge--b { background: var(--amber-pale); color: var(--amber); }
.cart-item__badge--type { background: var(--cream); color: var(--text-muted); border: 1px solid var(--border-light); text-transform: none; }
.cart-item__title { font-size: 15px; font-weight: 700; color: var(--green-dark); text-decoration: none; display: block; margin-bottom: 4px; line-height: 1.35; }
.cart-item__title:hover { color: var(--green); }
.cart-item__variant { font-size: 13px; color: var(--text-muted); margin-bottom: 8px; }
.cart-item__coverage { font-size: 12px; color: var(--green); font-weight: 600; margin-bottom: 4px; }
.cart-item__delivery { font-size: 12px; color: var(--text-light); }

/* Cart item actions */
.cart-item__actions { text-align: right; display: flex; flex-direction: column; align-items: flex-end; gap: 8px; }
.cart-item__price { font-family: 'Fraunces', serif; font-size: 20px; font-weight: 700; color: var(--green-dark); }
.cart-item__unit-price { font-size: 12px; color: var(--text-light); }
.cart-item__qty { display: flex; align-items: center; border: 1.5px solid var(--border); border-radius: var(--r); overflow: hidden; }
.cart-item__qty-btn { width: 34px; height: 34px; border: none; background: none; cursor: pointer; font-size: 16px; color: var(--green-dark); display: flex; align-items: center; justify-content: center; }
.cart-item__qty-btn:hover { background: var(--green-pale); }
.cart-item__qty-input { width: 40px; height: 34px; border: none; border-left: 1.5px solid var(--border); border-right: 1.5px solid var(--border); text-align: center; font-family: 'Nunito Sans', sans-serif; font-size: 14px; font-weight: 700; color: var(--text); }
.cart-item__qty-input::-webkit-inner-spin-button { display: none; }
.cart-item__remove { font-size: 12px; color: var(--text-light); text-decoration: underline; }
.cart-item__remove:hover { color: #c00; }

/* Order summary */
.cart-summary { position: sticky; top: 120px; }
.cart-summary__box { background: var(--cream); border: 1px solid var(--border-light); border-radius: var(--r-xl); padding: 28px; }
.cart-summary__title { font-family: 'Fraunces', serif; font-size: 20px; font-weight: 700; color: var(--green-dark); margin-bottom: 20px; }
.cart-summary__row { display: flex; justify-content: space-between; align-items: center; padding: 8px 0; font-size: 14px; color: var(--text-muted); }
.cart-summary__row--total { font-size: 18px; font-weight: 700; color: var(--green-dark); padding: 16px 0 8px; }
.cart-summary__val { font-weight: 700; color: var(--text); }
.cart-summary__val--free { color: var(--green); }
.cart-summary__divider { height: 1px; background: var(--border-light); margin: 8px 0; }
.cart-summary__note { display: flex; align-items: center; gap: 8px; font-size: 13px; font-weight: 600; color: var(--green); margin: 16px 0; padding: 12px 14px; background: var(--green-pale); border-radius: var(--r); }
.cart-summary__delivery { margin: 16px 0; }
.cart-summary__checkout { width: 100%; justify-content: center; font-size: 17px; padding: 16px 24px; margin-top: 8px; }
.cart-summary__continue { text-align: center; margin-top: 16px; }
.cart-summary__continue a { font-size: 13px; color: var(--text-muted); text-decoration: none; }
.cart-summary__continue a:hover { color: var(--green); }

/* Trust badges */
.cart-trust { display: flex; flex-direction: column; gap: 10px; margin-top: 20px; padding: 16px 20px; }
.cart-trust__item { display: flex; align-items: center; gap: 10px; font-size: 13px; font-weight: 600; color: var(--text-muted); }

/* Delivery app widget styling overrides */
.cart-summary__delivery select,
.cart-summary__delivery input,
.cart-summary__delivery .date-picker { font-family: 'Nunito Sans', sans-serif; border: 1.5px solid var(--border); border-radius: var(--r); padding: 10px 14px; font-size: 14px; width: 100%; }

/* Responsive */
@media(max-width:900px){
  .cart-layout { grid-template-columns: 1fr; }
  .cart-summary { position: static; }
  .cart-item { grid-template-columns: 80px 1fr; }
  .cart-item__actions { grid-column: 1 / -1; flex-direction: row; align-items: center; justify-content: space-between; }
}
@media(max-width:500px){
  .cart-item { grid-template-columns: 1fr; }
  .cart-item__img { width: 100%; height: 160px; }
}
