
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@400;600;700&family=EB+Garamond:wght@400;600&family=Oswald:wght@400;600;700&family=Playfair+Display:wght@400;700&family=Bebas+Neue&family=Jost:wght@300;400;500;600&family=DM+Sans:wght@400;500;600&family=Nunito:wght@400;600;700&family=Open+Sans:wght@400;600&family=Source+Sans+Pro:wght@400;600&display=swap');
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --primary:#4A7C59;
  --primary-dark:#2E5439;
  --accent:#E6EFE8;
  --bg:#F5F3EE;
  --bg-alt:#ECEAE3;
  --surface:#FFFFFF;
  --text:#1A1F18;
  --muted:#5C6355;
  --border:#CDD4C8;
  --shadow:0 22px 60px rgba(74,124,89,0.18);
  --radius:14px;
  --head-font:"Oswald","Impact",sans-serif;
  --body-font:"Open Sans","Segoe UI",sans-serif;
}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);font-family:var(--body-font);font-size:16px;line-height:1.6}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.shell{max-width:1280px;margin:0 auto;padding:0 24px}

/* NAV */
.site-nav{position:sticky;top:0;z-index:100;background:var(--surface);border-bottom:1px solid var(--border);backdrop-filter:blur(12px)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:72px;max-width:1280px;margin:0 auto;padding:0 24px}
.nav-logo{font-family:var(--head-font);font-size:1.5rem;font-weight:700;color:var(--primary);letter-spacing:0.04em}
.nav-links{display:flex;gap:32px;list-style:none}
.nav-links a{font-size:0.9rem;font-weight:500;color:var(--text);letter-spacing:0.06em;text-transform:uppercase;transition:color 0.2s}
.nav-links a:hover,.nav-links a.active{color:var(--primary)}
.nav-cart{position:relative;cursor:pointer;padding:8px;background:var(--primary);color:#fff;border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;transition:background 0.2s}
.nav-cart:hover{background:var(--primary-dark)}
.cart-badge{position:absolute;top:-4px;right:-4px;background:#e53;color:#fff;border-radius:50%;width:18px;height:18px;font-size:0.65rem;display:flex;align-items:center;justify-content:center;font-weight:700}
.nav-hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px}
.nav-hamburger span{display:block;width:24px;height:2px;background:var(--text);transition:all 0.3s}
@media(max-width:768px){.nav-links{display:none;position:absolute;top:72px;left:0;right:0;background:var(--surface);flex-direction:column;padding:20px 24px;border-bottom:1px solid var(--border);gap:16px}.nav-links.open{display:flex}.nav-hamburger{display:flex}}

/* HERO */
.hero{background:linear-gradient(135deg,#F5F3EE 0%,#E8E3D8 55%,#DDD5C5 100%);padding:100px 24px;text-align:center;position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 50% 0%,#4A7C5922 0%,transparent 70%)}
.hero-eyebrow{font-size:0.8rem;letter-spacing:0.16em;text-transform:uppercase;color:var(--primary);font-weight:600;margin-bottom:16px}
.hero h1{font-family:var(--head-font);font-size:clamp(2.4rem,6vw,4.5rem);font-weight:700;line-height:1.15;margin-bottom:20px;color:var(--text)}
.hero p{font-size:1.1rem;color:var(--muted);max-width:560px;margin:0 auto 36px}
.btn-primary{display:inline-block;background:var(--primary);color:#fff;padding:16px 40px;border-radius:999px;font-weight:600;font-size:1rem;letter-spacing:0.04em;transition:background 0.2s,transform 0.2s,box-shadow 0.2s;box-shadow:0 4px 20px #4A7C5955}
.btn-primary:hover{background:var(--primary-dark);transform:translateY(-2px);box-shadow:0 8px 28px #4A7C5966}
.btn-secondary{display:inline-block;border:2px solid var(--primary);color:var(--primary);padding:14px 36px;border-radius:999px;font-weight:600;font-size:0.95rem;transition:all 0.2s}
.btn-secondary:hover{background:var(--primary);color:#fff}

/* TRUST BADGES */
.trust-bar{background:var(--bg-alt);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:20px 24px}
.trust-inner{max-width:1280px;margin:0 auto;display:flex;justify-content:center;gap:48px;flex-wrap:wrap}
.trust-item{display:flex;align-items:center;gap:10px;font-size:0.875rem;font-weight:600;color:var(--muted)}
.trust-item span.icon{font-size:1.3rem}

/* SECTIONS */
.section-block{padding:80px 0}
.section-heading{text-align:center;margin-bottom:48px}
.section-heading .eyebrow{font-size:0.78rem;letter-spacing:0.18em;text-transform:uppercase;color:var(--primary);font-weight:600;margin-bottom:10px}
.section-heading h2{font-family:var(--head-font);font-size:clamp(1.8rem,4vw,2.8rem);font-weight:700;color:var(--text)}
.inline-heading{display:flex;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;gap:16px;text-align:left;margin-bottom:40px}
.text-link{color:var(--primary);font-weight:600;font-size:0.9rem;white-space:nowrap;border-bottom:1px solid transparent;transition:border-color 0.2s}
.text-link:hover{border-color:var(--primary)}

/* PRODUCT GRID */
.product-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:28px}
@media(max-width:1024px){.product-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:768px){.product-grid{grid-template-columns:repeat(2,1fr);gap:16px}}
@media(max-width:480px){.product-grid{grid-template-columns:1fr}}

/* FEATURED GRID — 3 col */
.featured-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
@media(max-width:900px){.featured-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.featured-grid{grid-template-columns:1fr}}

/* PRODUCT CARD */
.product-card{background:var(--surface);border-radius:var(--radius);overflow:hidden;box-shadow:0 4px 20px rgba(0,0,0,0.07);transition:transform 0.3s,box-shadow 0.3s;cursor:pointer}
.product-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.product-card-img{position:relative;overflow:hidden;background:var(--bg-alt)}
.product-card-img img{width:100%;height:300px;object-fit:cover;transition:transform 0.4s}
.product-card:hover .product-card-img img{transform:scale(1.05)}
.product-card-badge{position:absolute;top:12px;left:12px;background:var(--primary);color:#fff;font-size:0.7rem;font-weight:700;padding:4px 10px;border-radius:999px;letter-spacing:0.06em}
.product-card-body{padding:20px}
.product-card-name{font-family:var(--head-font);font-size:1.05rem;font-weight:600;margin-bottom:6px;line-height:1.3}
.product-card-meta{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.product-card-price{font-size:1.15rem;font-weight:700;color:var(--primary)}
.product-card-rating{font-size:0.8rem;color:var(--muted)}
.product-card-rating .stars{color:#f59e0b}
.product-card-orders{font-size:0.75rem;color:var(--muted);margin-bottom:14px}
.btn-atc{width:100%;background:var(--primary);color:#fff;border:none;padding:12px;border-radius:10px;font-size:0.9rem;font-weight:600;cursor:pointer;transition:background 0.2s}
.btn-atc:hover{background:var(--primary-dark)}

/* SHOP PAGE */
.shop-controls{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px;margin-bottom:32px}
.shop-controls select{padding:10px 16px;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text);font-size:0.9rem;cursor:pointer}
.result-count{font-size:0.9rem;color:var(--muted)}

/* PRODUCT PAGE */
.product-page{display:grid;grid-template-columns:1fr 1fr;gap:64px;padding:60px 0}
@media(max-width:768px){.product-page{grid-template-columns:1fr;gap:32px;padding:32px 0}}
.product-gallery img{width:100%;border-radius:var(--radius);object-fit:cover;max-height:560px}
.product-info h1{font-family:var(--head-font);font-size:clamp(1.8rem,3vw,2.4rem);font-weight:700;margin-bottom:12px}
.product-price-large{font-size:2rem;font-weight:700;color:var(--primary);margin-bottom:8px}
.product-orders-trust{font-size:0.85rem;color:var(--muted);margin-bottom:24px;display:flex;align-items:center;gap:8px}
.product-desc{color:var(--muted);line-height:1.8;margin-bottom:28px}
.variant-group{margin-bottom:20px}
.variant-group label{display:block;font-weight:600;font-size:0.85rem;letter-spacing:0.08em;text-transform:uppercase;margin-bottom:8px;color:var(--text)}
.variant-options{display:flex;flex-wrap:wrap;gap:8px}
.variant-btn{padding:8px 18px;border:2px solid var(--border);border-radius:8px;font-size:0.9rem;font-weight:500;background:transparent;cursor:pointer;color:var(--text);transition:all 0.2s}
.variant-btn.active,.variant-btn:hover{border-color:var(--primary);background:var(--primary);color:#fff}
.product-actions{display:flex;gap:12px;margin-top:28px;flex-wrap:wrap}
.product-actions .btn-primary{flex:1;text-align:center;border:none;cursor:pointer;font-family:var(--body-font);font-size:1rem}
.product-actions .btn-secondary{flex:1;text-align:center;cursor:pointer;font-family:var(--body-font);font-size:1rem}

/* REVIEWS */
.review-section{padding:60px 0;border-top:1px solid var(--border)}
.review-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;margin-top:32px}
.review-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:24px}
.review-author{font-weight:700;font-size:0.9rem;margin-bottom:4px}
.review-stars{color:#f59e0b;font-size:0.95rem;margin-bottom:10px}
.review-text{font-size:0.9rem;color:var(--muted);line-height:1.7}

/* CART */
.cart-layout{display:grid;grid-template-columns:1fr 360px;gap:32px;padding:40px 0;align-items:start}
@media(max-width:900px){.cart-layout{grid-template-columns:1fr}}
.cart-item{display:grid;grid-template-columns:100px 1fr auto;gap:16px;align-items:center;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin-bottom:16px}
.cart-item img{width:100px;height:100px;object-fit:cover;border-radius:10px}
.cart-item-name{font-weight:600;margin-bottom:4px}
.cart-item-variant{font-size:0.85rem;color:var(--muted);margin-bottom:10px}
.cart-item-qty{display:flex;align-items:center;gap:8px}
.qty-btn{background:var(--bg-alt);border:1px solid var(--border);border-radius:6px;width:30px;height:30px;cursor:pointer;font-size:1rem}
.cart-item-price{font-weight:700;font-size:1.05rem;color:var(--primary);text-align:right}
.cart-item-remove{font-size:0.8rem;color:var(--muted);cursor:pointer;text-decoration:underline;margin-top:6px;display:block;text-align:right}
.summary-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:28px;position:sticky;top:100px}
.summary-card h3{font-family:var(--head-font);font-size:1.3rem;font-weight:700;margin-bottom:20px}
.summary-row{display:flex;justify-content:space-between;font-size:0.95rem;margin-bottom:12px}
.summary-row.total{font-weight:700;font-size:1.1rem;border-top:1px solid var(--border);padding-top:12px;margin-top:8px}
.summary-card .btn-primary{width:100%;text-align:center;display:block;margin-top:20px;border:none;cursor:pointer;font-family:var(--body-font);font-size:1rem;padding:16px}

/* CHECKOUT */
.checkout-layout{display:grid;grid-template-columns:1fr 360px;gap:32px;padding:40px 0;align-items:start}
@media(max-width:900px){.checkout-layout{grid-template-columns:1fr}}
.checkout-form{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:32px}
.form-block{margin-bottom:28px}
.form-block h2{font-family:var(--head-font);font-size:1.2rem;font-weight:700;margin-bottom:16px;padding-bottom:10px;border-bottom:1px solid var(--border)}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-grid label{display:flex;flex-direction:column;gap:6px;font-size:0.85rem;font-weight:600;color:var(--text)}
.form-grid label.wide{grid-column:1/-1}
.form-grid input,.form-grid select{padding:12px 14px;border:1px solid var(--border);border-radius:8px;font-size:0.95rem;background:var(--bg);color:var(--text);transition:border-color 0.2s}
.form-grid input:focus,.form-grid select:focus{outline:none;border-color:var(--primary)}
.payment-options{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}
.payment-card{border:2px solid var(--border);border-radius:10px;padding:16px;cursor:pointer;transition:border-color 0.2s}
.payment-card.active{border-color:var(--primary)}
.payment-card strong{display:block;margin-bottom:4px}
.payment-card span{font-size:0.85rem;color:var(--muted)}
.payment-card input{margin-right:8px}
.card-fields{margin-top:16px}
.checkout-form .btn-primary{width:100%;border:none;cursor:pointer;font-family:var(--body-font);font-size:1rem;padding:16px;text-align:center}
.legal-copy{font-size:0.8rem;color:var(--muted);text-align:center;margin-top:12px}
.legal-copy a{color:var(--primary);text-decoration:underline}
.success-panel{text-align:center;padding:80px 24px}
.success-panel h2{font-family:var(--head-font);font-size:2rem;margin-bottom:16px}
.success-panel p{color:var(--muted);margin-bottom:24px}

/* ABOUT / CONTACT */
.page-intro{padding:60px 0 32px;max-width:640px}
.page-intro .eyebrow{font-size:0.78rem;letter-spacing:0.18em;text-transform:uppercase;color:var(--primary);font-weight:600;margin-bottom:12px}
.page-intro h1{font-family:var(--head-font);font-size:clamp(2rem,4vw,3rem);font-weight:700;margin-bottom:16px}
.page-intro p{color:var(--muted);line-height:1.8}
.story-grid,.contact-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;padding:40px 0 60px}
@media(max-width:768px){.story-grid,.contact-grid{grid-template-columns:1fr}}
.story-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:28px}
.story-card h2{font-family:var(--head-font);font-size:1.15rem;font-weight:700;margin-bottom:12px;color:var(--primary)}
.story-card p{font-size:0.9rem;color:var(--muted);line-height:1.7;margin-bottom:8px}

/* ABOUT SNIPPET on homepage */
.about-strip{background:var(--bg-alt);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:60px 24px;text-align:center}
.about-strip h2{font-family:var(--head-font);font-size:clamp(1.5rem,3vw,2.2rem);font-weight:700;margin-bottom:16px}
.about-strip p{color:var(--muted);max-width:600px;margin:0 auto 24px}

/* FOOTER */
.site-footer{background:#1C1C1C;color:#ccc;padding:64px 24px 32px}
.footer-inner{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr;gap:48px;margin-bottom:48px}
@media(max-width:768px){.footer-inner{grid-template-columns:1fr;gap:32px}}
.footer-brand .nav-logo{font-size:1.6rem;margin-bottom:12px;display:block;color:var(--primary)}
.footer-brand p{font-size:0.875rem;color:#999;line-height:1.7;max-width:280px}
.footer-col h4{font-size:0.8rem;letter-spacing:0.14em;text-transform:uppercase;color:#fff;font-weight:700;margin-bottom:16px}
.footer-col ul{list-style:none}
.footer-col li{margin-bottom:10px}
.footer-col a{font-size:0.875rem;color:#999;transition:color 0.2s}
.footer-col a:hover{color:var(--primary)}
.footer-bottom{border-top:1px solid #333;padding-top:24px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:0.8rem;color:#666}

/* CART DRAWER */
.cart-drawer{position:fixed;top:0;right:-420px;width:420px;max-width:100vw;height:100%;background:var(--surface);z-index:999;box-shadow:-8px 0 40px rgba(0,0,0,0.2);transition:right 0.3s ease;display:flex;flex-direction:column}
.cart-drawer.open{right:0}
.cart-drawer-header{display:flex;justify-content:space-between;align-items:center;padding:24px;border-bottom:1px solid var(--border)}
.cart-drawer-header h3{font-family:var(--head-font);font-size:1.3rem;font-weight:700}
.drawer-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--muted);transition:color 0.2s}
.drawer-close:hover{color:var(--text)}
.cart-drawer-items{flex:1;overflow-y:auto;padding:16px 24px}
.drawer-item{display:flex;gap:14px;margin-bottom:20px;padding-bottom:20px;border-bottom:1px solid var(--border)}
.drawer-item img{width:72px;height:72px;object-fit:cover;border-radius:8px;flex-shrink:0}
.drawer-item-info{flex:1}
.drawer-item-name{font-size:0.9rem;font-weight:600;margin-bottom:4px}
.drawer-item-variant{font-size:0.8rem;color:var(--muted);margin-bottom:8px}
.drawer-item-row{display:flex;justify-content:space-between;align-items:center}
.drawer-item-price{font-weight:700;color:var(--primary)}
.drawer-item-remove{font-size:0.75rem;color:var(--muted);cursor:pointer;text-decoration:underline}
.cart-drawer-footer{padding:24px;border-top:1px solid var(--border)}
.drawer-total{display:flex;justify-content:space-between;font-weight:700;font-size:1.05rem;margin-bottom:16px}
.cart-drawer-footer .btn-primary{width:100%;text-align:center;display:block;border:none;cursor:pointer;font-family:var(--body-font);font-size:1rem;padding:16px}
.cart-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.5);z-index:998;display:none}
.cart-overlay.show{display:block}
.empty-cart{text-align:center;padding:48px 24px;color:var(--muted)}
.empty-cart p{margin-bottom:16px}

/* POLICY PAGES */
.policy-content{max-width:800px;padding:60px 0 80px}
.policy-content h1{font-family:var(--head-font);font-size:2.2rem;font-weight:700;margin-bottom:8px}
.policy-content .updated{font-size:0.85rem;color:var(--muted);margin-bottom:40px}
.policy-content h2{font-family:var(--head-font);font-size:1.3rem;font-weight:700;margin:32px 0 12px;color:var(--primary)}
.policy-content p,.policy-content li{font-size:0.95rem;color:var(--muted);line-height:1.8;margin-bottom:10px}
.policy-content ul{padding-left:24px;margin-bottom:16px}
