/* Aviv Skincare — Theme stylesheet */
:root{
  --forest:#052C04;
  --forest-700:#0a3d08;
  --blush:#DEA19B;
  --blush-200:#ecc8c4;
  --cream:#FAF3EE;
  --cocoa:#2A1A14;
  --line:rgba(42,26,20,.12);
  --muted:#6b5b53;
  --container:1240px;
  --radius:2px;
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;background:var(--cream);color:var(--cocoa);
  font-family:'Inter',system-ui,sans-serif;font-size:16px;line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--forest);text-decoration:none;transition:color .2s}
a:hover{color:var(--blush)}
h1,h2,h3,h4{font-family:'Cormorant Garamond',Georgia,serif;font-weight:500;color:var(--forest);margin:0 0 .5em;letter-spacing:-.01em;line-height:1.15}
h1{font-size:clamp(2.4rem,5vw,4rem)}
h2{font-size:clamp(2rem,3.5vw,3rem)}
h3{font-size:1.6rem}
p{margin:0 0 1em}
.container{max-width:var(--container);margin:0 auto;padding:0 1.5rem}
.section{padding:6rem 0}
.section--tight{padding:4rem 0}
.eyebrow{font-family:'Inter',sans-serif;font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;color:var(--blush);font-weight:500;margin-bottom:1rem;display:inline-block}
.btn{display:inline-block;padding:.95rem 2rem;font-family:'Inter',sans-serif;font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;font-weight:500;border:1px solid var(--forest);background:var(--forest);color:var(--cream);cursor:pointer;transition:all .25s;border-radius:var(--radius)}
.btn:hover{background:transparent;color:var(--forest)}
.btn--ghost{background:transparent;color:var(--forest)}
.btn--ghost:hover{background:var(--forest);color:var(--cream)}
.btn--light{background:var(--cream);color:var(--forest);border-color:var(--cream)}
.btn--light:hover{background:transparent;color:var(--cream);border-color:var(--cream)}

/* Announcement */
.announcement{background:var(--forest);color:var(--cream);text-align:center;padding:.6rem 1rem;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase}

/* Header */
.site-header{position:sticky;top:0;z-index:50;background:var(--cream);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;padding:1.1rem 1.5rem;max-width:var(--container);margin:0 auto;gap:2rem}
.brand{font-family:'Cormorant Garamond',serif;font-size:1.8rem;color:var(--forest);font-weight:500;letter-spacing:.04em}
.brand a{color:inherit}
.menu{display:flex;gap:2.2rem;list-style:none;margin:0;padding:0}
.menu a{font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;font-weight:500;color:var(--cocoa)}
.menu a:hover,.menu .current-menu-item a{color:var(--forest)}
.nav-actions{display:flex;gap:1.2rem;align-items:center}
.nav-actions a{font-size:.78rem;letter-spacing:.18em;text-transform:uppercase}
.cart-count{display:inline-block;background:var(--blush);color:var(--forest);border-radius:999px;padding:.05rem .5rem;font-size:.7rem;margin-left:.3rem}
.nav-toggle{display:none;background:none;border:0;font-size:1.4rem;color:var(--forest);cursor:pointer}
@media(max-width:900px){
  .nav-toggle{display:block}
  .menu{display:none;position:absolute;top:100%;left:0;right:0;background:var(--cream);flex-direction:column;padding:1.5rem;gap:1.2rem;border-bottom:1px solid var(--line)}
  .menu.is-open{display:flex}
  .nav{position:relative}
}

/* Hero */
.hero{position:relative;background:var(--forest);color:var(--cream);overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1fr 1fr;min-height:78vh}
.hero-copy{padding:6rem 4rem;display:flex;flex-direction:column;justify-content:center}
.hero-copy h1{color:var(--cream);font-size:clamp(2.6rem,5vw,4.4rem)}
.hero-copy p{color:rgba(250,243,238,.78);font-size:1.1rem;max-width:32rem;margin-bottom:2rem}
.hero-copy .eyebrow{color:var(--blush)}
.hero-image{background-size:cover;background-position:center;min-height:50vh}
@media(max-width:900px){.hero-grid{grid-template-columns:1fr}.hero-copy{padding:4rem 1.5rem}}

/* Promises */
.promises{background:var(--cream);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.promise-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0}
.promise{padding:3rem 2rem;text-align:center;border-right:1px solid var(--line)}
.promise:last-child{border-right:0}
.promise h4{font-size:1.15rem;margin-bottom:.4rem;color:var(--forest)}
.promise p{font-size:.9rem;color:var(--muted);margin:0}
@media(max-width:900px){.promise-grid{grid-template-columns:1fr 1fr}.promise{border-bottom:1px solid var(--line)}.promise:nth-child(odd){border-right:1px solid var(--line)}.promise:nth-child(even){border-right:0}}

/* Featured / Product Grid */
.product-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:3rem}
@media(max-width:1000px){.product-grid{grid-template-columns:repeat(2,1fr);gap:2rem}}
@media(max-width:600px){.product-grid{grid-template-columns:1fr}}
.product-card{display:block;color:inherit;transition:transform .3s}
.product-card:hover{transform:translateY(-4px)}
.product-card .pc-img{aspect-ratio:4/5;background:var(--blush-200);overflow:hidden;margin-bottom:1.2rem;position:relative}
.product-card img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.product-card:hover img{transform:scale(1.04)}
.product-card .badge{position:absolute;top:1rem;left:1rem;background:var(--forest);color:var(--cream);font-size:.65rem;letter-spacing:.2em;text-transform:uppercase;padding:.35rem .7rem}
.product-card h3{font-size:1.4rem;margin-bottom:.2rem}
.product-card .tagline{font-size:.85rem;color:var(--muted);margin-bottom:.4rem}
.product-card .price{font-size:.95rem;color:var(--forest);font-weight:500}

/* Section heading */
.section-head{text-align:center;max-width:42rem;margin:0 auto 4rem}
.section-head p{color:var(--muted);font-size:1.05rem;margin-top:.5rem}

/* Ingredients */
.ingredient-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line)}
@media(max-width:900px){.ingredient-grid{grid-template-columns:repeat(2,1fr)}}
.ingredient{background:var(--cream);padding:2.5rem 1.8rem;text-align:left}
.ingredient .ing-name{font-family:'Cormorant Garamond',serif;font-size:1.6rem;color:var(--forest);margin-bottom:.25rem}
.ingredient .ing-source{font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--blush);margin-bottom:1rem}
.ingredient .ing-benefit{font-size:.95rem;color:var(--cocoa);margin:0}

/* Story */
.story{background:var(--forest);color:var(--cream)}
.story h2{color:var(--cream)}
.story .container{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
@media(max-width:900px){.story .container{grid-template-columns:1fr}}
.story p{color:rgba(250,243,238,.8);font-size:1.05rem}
.story-image{aspect-ratio:4/5;background-size:cover;background-position:center}

/* Newsletter */
.newsletter{background:var(--blush);color:var(--forest);text-align:center;padding:5rem 1.5rem}
.newsletter h2{color:var(--forest)}
.newsletter p{max-width:34rem;margin:0 auto 2rem;color:var(--cocoa)}
.newsletter form{display:flex;max-width:30rem;margin:0 auto;gap:.5rem}
.newsletter input{flex:1;padding:.95rem 1rem;border:1px solid var(--forest);background:transparent;color:var(--forest);font-family:inherit;font-size:.9rem;border-radius:var(--radius)}
.newsletter input::placeholder{color:rgba(5,44,4,.5)}
@media(max-width:600px){.newsletter form{flex-direction:column}}

/* Footer */
.site-footer{background:var(--cocoa);color:var(--cream);padding:5rem 0 2rem}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;margin-bottom:3rem}
@media(max-width:900px){.footer-grid{grid-template-columns:1fr 1fr;gap:2rem}}
.site-footer h4{color:var(--cream);font-size:1.05rem;font-family:'Inter',sans-serif;font-weight:500;text-transform:uppercase;letter-spacing:.18em;margin-bottom:1.2rem}
.site-footer a{color:rgba(250,243,238,.7)}
.site-footer a:hover{color:var(--blush)}
.site-footer ul{list-style:none;padding:0;margin:0}
.site-footer li{margin-bottom:.6rem;font-size:.9rem}
.footer-brand .brand{color:var(--cream);font-size:2rem}
.footer-brand p{color:rgba(250,243,238,.6);max-width:22rem;margin-top:1rem;font-size:.9rem}
.footer-bottom{border-top:1px solid rgba(250,243,238,.1);padding-top:2rem;display:flex;justify-content:space-between;font-size:.8rem;color:rgba(250,243,238,.5);flex-wrap:wrap;gap:1rem}

/* Page hero */
.page-hero{background:var(--forest);color:var(--cream);padding:5rem 1.5rem;text-align:center}
.page-hero h1{color:var(--cream)}
.page-hero .eyebrow{color:var(--blush)}
.breadcrumb{font-size:.75rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-bottom:1.5rem}
.breadcrumb a{color:var(--muted)}
.breadcrumb a:hover{color:var(--forest)}
.breadcrumb .sep{margin:0 .5rem;color:var(--line)}

/* Accordion */
.acc-group{max-width:48rem;margin:0 auto 4rem}
.acc-group h3{font-size:1.05rem;font-family:'Inter',sans-serif;text-transform:uppercase;letter-spacing:.18em;color:var(--blush);margin-bottom:1.5rem;text-align:center}
.acc-item{border-bottom:1px solid var(--line)}
.acc-btn{width:100%;text-align:left;padding:1.5rem 0;background:none;border:0;font-family:'Cormorant Garamond',serif;font-size:1.4rem;color:var(--forest);cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:1rem}
.acc-btn .ico{font-size:1.5rem;transition:transform .25s}
.acc-item.is-open .acc-btn .ico{transform:rotate(45deg)}
.acc-body{display:none;padding:0 0 1.5rem;color:var(--muted);font-size:1rem}
.acc-item.is-open .acc-body{display:block}

/* WooCommerce single product */
.woocommerce-page .container,.single-product .container{max-width:var(--container)}
.single-product div.product{display:grid;grid-template-columns:1fr 1fr;gap:4rem;padding:4rem 1.5rem;max-width:var(--container);margin:0 auto}
@media(max-width:900px){.single-product div.product{grid-template-columns:1fr;gap:2rem;padding:2rem 1.5rem}}
.single-product .product_title{font-size:2.6rem;margin-bottom:.5rem}
.single-product .price{font-size:1.3rem;color:var(--forest);font-weight:500;margin-bottom:1.5rem;display:block}
.single-product .woocommerce-product-details__short-description{color:var(--muted);font-size:1rem;margin-bottom:2rem}
.single-product .cart{margin-bottom:2rem}
.single-product .quantity{margin-right:1rem}
.single-product .quantity input{width:4rem;padding:.7rem;border:1px solid var(--line);text-align:center}
.single-product .single_add_to_cart_button{padding:.95rem 2.2rem;background:var(--forest);color:var(--cream);border:1px solid var(--forest);font-family:'Inter',sans-serif;font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;cursor:pointer;border-radius:var(--radius)}
.single-product .single_add_to_cart_button:hover{background:transparent;color:var(--forest)}
.woocommerce-tabs{grid-column:1/-1;border-top:1px solid var(--line);padding-top:3rem;margin-top:2rem}
.woocommerce-tabs ul.tabs{list-style:none;padding:0;display:flex;gap:2rem;border-bottom:1px solid var(--line);margin-bottom:2rem}
.woocommerce-tabs ul.tabs li a{display:block;padding:1rem 0;font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;color:var(--muted)}
.woocommerce-tabs ul.tabs li.active a{color:var(--forest);border-bottom:2px solid var(--forest)}

/* Shop archive */
.woocommerce ul.products{list-style:none;padding:0;display:grid;grid-template-columns:repeat(3,1fr);gap:3rem}
@media(max-width:1000px){.woocommerce ul.products{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.woocommerce ul.products{grid-template-columns:1fr}}
.woocommerce ul.products li.product{text-align:left}
.woocommerce ul.products li.product .woocommerce-loop-product__title{font-family:'Cormorant Garamond',serif;font-size:1.4rem;color:var(--forest);padding:1rem 0 .2rem;font-weight:500}
.woocommerce ul.products li.product .price{color:var(--forest);font-weight:500}
.woocommerce ul.products li.product a.button{background:var(--forest);color:var(--cream);padding:.7rem 1.4rem;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;display:inline-block;margin-top:.6rem;border-radius:var(--radius)}
.woocommerce ul.products li.product a.button:hover{background:var(--blush);color:var(--forest)}
.woocommerce .woocommerce-result-count,.woocommerce .woocommerce-ordering{font-size:.85rem;color:var(--muted);margin-bottom:2rem}

/* Cart, checkout basics */
.woocommerce table.shop_table{border:1px solid var(--line);border-radius:var(--radius);width:100%;border-collapse:collapse}
.woocommerce table.shop_table th,.woocommerce table.shop_table td{padding:1rem;border-bottom:1px solid var(--line)}
.woocommerce-cart .container,.woocommerce-checkout .container{padding:4rem 1.5rem}
.woocommerce-message,.woocommerce-info{background:var(--blush-200);color:var(--cocoa);padding:1rem 1.5rem;border-left:3px solid var(--forest);margin-bottom:2rem}

/* Contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;max-width:var(--container);margin:0 auto;padding:0 1.5rem}
@media(max-width:900px){.contact-grid{grid-template-columns:1fr}}
.contact-info dl{margin:0}
.contact-info dt{font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--blush);margin-bottom:.3rem;margin-top:1.5rem}
.contact-info dd{margin:0;font-size:1.05rem;color:var(--cocoa)}
.contact-form input,.contact-form textarea{width:100%;padding:.9rem 1rem;border:1px solid var(--line);background:var(--cream);font-family:inherit;font-size:.95rem;margin-bottom:1rem;border-radius:var(--radius)}
.contact-form textarea{min-height:160px;resize:vertical}

/* Utilities */
.text-center{text-align:center}
.mt-2{margin-top:2rem}

/* === AVIV custom product page === */
.aviv-product{max-width:var(--container);margin:0 auto;padding:4rem 1.5rem}
.aviv-product-top{display:grid;grid-template-columns:1fr 1fr;gap:5rem}
@media(max-width:900px){.aviv-product{padding:2rem 1.5rem}.aviv-product-top{grid-template-columns:1fr;gap:2.5rem}}
.aviv-product-gallery .aviv-product-main-img{width:100%;height:auto;aspect-ratio:4/5;object-fit:cover;background:var(--blush-200)}
.aviv-product-thumbs{display:grid;grid-template-columns:repeat(4,1fr);gap:.6rem;margin-top:.6rem}
.aviv-product-thumbs img{width:100%;aspect-ratio:1;object-fit:cover;cursor:pointer}
.aviv-product-summary{display:flex;flex-direction:column;justify-content:flex-start}
.aviv-product-title{font-size:clamp(2.2rem,4vw,3.4rem);margin:.2rem 0 .8rem;color:var(--forest);line-height:1.1}
.aviv-product-short{color:var(--muted);font-size:1.05rem;line-height:1.6;margin:0 0 1.2rem}
.aviv-product-price{font-family:'Cormorant Garamond',serif;font-size:2rem;color:var(--blush);margin-bottom:1.2rem;font-weight:500}
.aviv-product-actions{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:2rem}
.btn--buy-now{background:var(--blush);color:var(--forest);border-color:var(--blush);font-size:.85rem;padding:1.1rem 2.4rem}
.btn--buy-now:hover{background:var(--forest);color:var(--cream);border-color:var(--forest)}
.aviv-product-meta{list-style:none;padding:1.5rem 0 0;margin:0;border-top:1px solid var(--line)}
.aviv-product-meta li{padding:.7rem 0;font-size:.92rem;color:var(--cocoa)}
.aviv-product-meta strong{display:inline-block;width:9rem;color:var(--forest);font-family:'Inter',sans-serif;text-transform:uppercase;font-size:.72rem;letter-spacing:.18em;font-weight:500}
.aviv-product-fulldesc{margin-top:3.5rem;padding-top:2.5rem;border-top:1px solid var(--line)}
.aviv-product-fulldesc h2{font-size:clamp(1.6rem,2.4vw,2.2rem);color:var(--forest);margin:0 0 1.2rem}
.aviv-product-fulldesc-body{color:var(--cocoa);font-size:1.05rem;line-height:1.8}
.aviv-product-fulldesc-body p{margin:0 0 1rem}

/* === AVIV shop loop card (same size as homepage cards) === */
.woocommerce ul.products,
ul.products{list-style:none !important;padding:0 !important;margin:0 !important;display:grid !important;grid-template-columns:repeat(3,1fr) !important;gap:3rem !important}
@media(max-width:1000px){.woocommerce ul.products,ul.products{grid-template-columns:repeat(2,1fr) !important;gap:2rem !important}}
@media(max-width:600px){.woocommerce ul.products,ul.products{grid-template-columns:1fr !important}}
.aviv-loop-card{list-style:none;width:100% !important;margin:0 !important;padding:0 !important;float:none !important;clear:none !important}
.aviv-loop-link{display:block;color:inherit;transition:transform .3s}
.aviv-loop-link:hover{transform:translateY(-4px)}
.aviv-loop-img{aspect-ratio:4/5;background:var(--blush-200);overflow:hidden;margin-bottom:1.2rem;position:relative}
.aviv-loop-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s;margin:0 !important}
.aviv-loop-link:hover .aviv-loop-img img{transform:scale(1.04)}
.aviv-loop-img .badge{position:absolute;top:1rem;left:1rem;background:var(--forest);color:var(--cream);font-size:.65rem;letter-spacing:.2em;text-transform:uppercase;padding:.35rem .7rem}
.aviv-loop-title{font-family:'Cormorant Garamond',serif !important;font-size:1.4rem !important;color:var(--forest);margin:0 0 .2rem;font-weight:500;padding:0 !important}
.aviv-loop-tag{font-size:.85rem;color:var(--muted);margin-bottom:.4rem}
.aviv-loop-price{font-size:.95rem;color:var(--forest);font-weight:500;margin-bottom:.6rem}
.aviv-loop-cta{display:inline-block;border-bottom:1px solid var(--forest);font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--forest);padding-bottom:2px}
.aviv-loop-link:hover .aviv-loop-cta{color:var(--blush);border-color:var(--blush)}

/* Kill Woo default add-to-cart button styles leaking */
.woocommerce a.button.add_to_cart_button,
.woocommerce button.single_add_to_cart_button,
.woocommerce .quantity,
.woocommerce .added_to_cart{display:none !important}

/* Hero italic accent */
.hero-copy h1 em{color:var(--blush);font-style:italic;font-weight:400}
.story h2 em{color:var(--blush);font-style:italic}

/* WhatsApp pill in header */
.nav-actions .wa-link{background:var(--forest);color:var(--cream);padding:.55rem 1rem;border-radius:999px;font-size:.7rem;letter-spacing:.18em}
.nav-actions .wa-link:hover{background:var(--blush);color:var(--forest)}
