/*
 Theme Name:   Eli Sweet Café
 Theme URI:    https://elisweetcafe.com
 Description:  Custom child theme for Eli Sweet Café — Home Bakery specializing in fondant cakes. Forest green & soft pink branding.
 Author:       Arman Dabiri
 Author URI:   https://elisweetcafe.com
 Template:     astra
 Version:      1.0.0
 License:      GNU General Public License v2 or later
 License URI:  http://www.gnu.org/licenses/gpl-2.0.html
 Text Domain:  eli-sweet-cafe
 Tags:         bakery, woocommerce, food, cake, custom-colors
*/

/* ==========================================================================
   Eli Sweet Café — Custom Branding
   Color Palette:
     Forest Green (Primary):  #2D5A3D
     Soft Pink (Secondary):   #F5C6D0
     Light Cream (BG):        #FFF8F0
     Dark Brown (Text):       #3D2B1F
     Gold Accent (CTA):       #D4A76A
     Deep Green (Hover):      #1E3F2B
     Blush (Light Pink):      #FDE8ED
   ========================================================================== */

/* ---------- Import Google Fonts ---------- */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500&family=Lato:wght@300;400;700&display=swap');

/* ---------- CSS Custom Properties ---------- */
:root {
  --esc-green:        #2D5A3D;
  --esc-green-dark:   #1E3F2B;
  --esc-green-light:  #3A7A52;
  --esc-pink:         #F5C6D0;
  --esc-pink-light:   #FDE8ED;
  --esc-cream:        #FFF8F0;
  --esc-brown:        #3D2B1F;
  --esc-brown-light:  #6B5244;
  --esc-gold:         #D4A76A;
  --esc-gold-hover:   #C4944F;
  --esc-white:        #FFFFFF;
  --esc-shadow:       0 2px 12px rgba(45, 90, 61, 0.08);
  --esc-shadow-hover: 0 4px 20px rgba(45, 90, 61, 0.15);
  --esc-radius:       8px;
  --esc-radius-lg:    16px;
  --esc-font-heading: 'Playfair Display', Georgia, 'Times New Roman', serif;
  --esc-font-body:    'Lato', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  --esc-transition:   all 0.3s ease;
}

/* ---------- Global Reset & Base ---------- */
body {
  font-family: var(--esc-font-body);
  color: var(--esc-brown);
  background-color: var(--esc-cream);
  line-height: 1.7;
  font-size: 16px;
  -webkit-font-smoothing: antialiased;
}

/* ---------- Typography ---------- */
h1, h2, h3, h4, h5, h6,
.entry-title,
.page-title,
.site-title,
.woocommerce-loop-product__title,
.product_title {
  font-family: var(--esc-font-heading);
  color: var(--esc-green);
  font-weight: 600;
  line-height: 1.3;
}

h1, .entry-title { font-size: 2.4rem; }
h2 { font-size: 2rem; }
h3 { font-size: 1.6rem; }
h4 { font-size: 1.3rem; }

p {
  margin-bottom: 1.2em;
  color: var(--esc-brown);
}

a {
  color: var(--esc-green);
  text-decoration: none;
  transition: var(--esc-transition);
}

a:hover,
a:focus {
  color: var(--esc-gold);
}

/* ---------- Site Header ---------- */
.site-header,
.ast-primary-header,
header.site-header {
  background-color: var(--esc-white) !important;
  border-bottom: 2px solid var(--esc-pink);
  box-shadow: var(--esc-shadow);
}

.site-title a,
.ast-site-title-wrap a {
  font-family: var(--esc-font-heading);
  color: var(--esc-green) !important;
  font-weight: 700;
  font-size: 1.6rem;
  letter-spacing: 0.5px;
}

.site-description {
  color: var(--esc-brown-light);
  font-family: var(--esc-font-body);
  font-style: italic;
  font-size: 0.85rem;
}

/* ---------- Navigation ---------- */
.main-navigation a,
.ast-header-break-point .main-header-menu a,
.main-header-menu > .menu-item > a {
  font-family: var(--esc-font-body);
  color: var(--esc-brown) !important;
  font-weight: 400;
  font-size: 0.95rem;
  text-transform: uppercase;
  letter-spacing: 1px;
  padding: 0.5em 1em;
  transition: var(--esc-transition);
}

.main-navigation a:hover,
.main-header-menu > .menu-item > a:hover,
.main-header-menu > .menu-item.current-menu-item > a {
  color: var(--esc-green) !important;
}

/* Active nav indicator */
.main-header-menu > .menu-item.current-menu-item > a {
  border-bottom: 2px solid var(--esc-gold);
}

/* ---------- Buttons ---------- */
button,
input[type="submit"],
.button,
.wp-block-button__link,
.ast-button,
a.button,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce input.button.alt,
.woocommerce #respond input#submit.alt {
  background-color: var(--esc-gold) !important;
  color: var(--esc-white) !important;
  border: none !important;
  border-radius: var(--esc-radius) !important;
  font-family: var(--esc-font-body);
  font-weight: 700;
  font-size: 0.9rem;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  padding: 12px 28px !important;
  cursor: pointer;
  transition: var(--esc-transition);
  box-shadow: 0 2px 8px rgba(212, 167, 106, 0.3);
}

button:hover,
input[type="submit"]:hover,
.button:hover,
.wp-block-button__link:hover,
.ast-button:hover,
a.button:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover,
.woocommerce input.button.alt:hover {
  background-color: var(--esc-gold-hover) !important;
  box-shadow: 0 4px 16px rgba(212, 167, 106, 0.4);
  transform: translateY(-1px);
}

/* Secondary / outline button */
.woocommerce a.button.alt.disabled,
.woocommerce a.button.alt:disabled,
.woocommerce button.button.alt.disabled,
.woocommerce button.button.alt:disabled {
  background-color: var(--esc-pink) !important;
  color: var(--esc-brown) !important;
  opacity: 0.7;
}

/* ---------- WooCommerce Product Cards ---------- */
.woocommerce ul.products li.product,
.wc-block-grid__product {
  background: var(--esc-white);
  border-radius: var(--esc-radius-lg);
  box-shadow: var(--esc-shadow);
  padding: 0;
  overflow: hidden;
  transition: var(--esc-transition);
  border: 1px solid rgba(245, 198, 208, 0.3);
}

.woocommerce ul.products li.product:hover,
.wc-block-grid__product:hover {
  box-shadow: var(--esc-shadow-hover);
  transform: translateY(-4px);
}

.woocommerce ul.products li.product img,
.wc-block-grid__product img {
  border-radius: var(--esc-radius-lg) var(--esc-radius-lg) 0 0;
  transition: var(--esc-transition);
}

.woocommerce ul.products li.product:hover img {
  opacity: 0.95;
}

.woocommerce ul.products li.product .woocommerce-loop-product__title,
.wc-block-grid__product .wc-block-grid__product-title {
  font-family: var(--esc-font-heading);
  color: var(--esc-green);
  font-size: 1.15rem;
  padding: 12px 16px 4px;
}

.woocommerce ul.products li.product .price,
.wc-block-grid__product .wc-block-grid__product-price {
  color: var(--esc-gold) !important;
  font-family: var(--esc-font-body);
  font-weight: 700;
  font-size: 1.1rem;
  padding: 0 16px 12px;
}

.woocommerce ul.products li.product .price del {
  color: var(--esc-brown-light) !important;
  opacity: 0.5;
}

.woocommerce ul.products li.product .price ins {
  color: var(--esc-gold) !important;
  text-decoration: none;
}

/* Sale badge */
.woocommerce span.onsale {
  background-color: var(--esc-pink) !important;
  color: var(--esc-green) !important;
  font-family: var(--esc-font-body);
  font-weight: 700;
  font-size: 0.8rem;
  border-radius: var(--esc-radius);
  padding: 4px 12px;
  min-height: auto;
  line-height: 1.5;
}

/* Add to cart on product cards */
.woocommerce ul.products li.product .button {
  margin: 0 16px 16px !important;
  width: calc(100% - 32px);
  text-align: center;
  font-size: 0.8rem !important;
  padding: 10px 20px !important;
}

/* ---------- Single Product Page ---------- */
.woocommerce div.product .product_title {
  font-family: var(--esc-font-heading);
  color: var(--esc-green);
  font-size: 2.2rem;
  margin-bottom: 0.5em;
}

.woocommerce div.product p.price {
  color: var(--esc-gold) !important;
  font-size: 1.5rem;
  font-weight: 700;
}

.woocommerce div.product .woocommerce-product-details__short-description {
  color: var(--esc-brown);
  font-size: 1rem;
  line-height: 1.8;
  border-left: 3px solid var(--esc-pink);
  padding-left: 16px;
  margin: 1em 0;
}

/* Product tabs */
.woocommerce div.product .woocommerce-tabs ul.tabs li a {
  font-family: var(--esc-font-body);
  color: var(--esc-brown-light);
  text-transform: uppercase;
  letter-spacing: 1px;
  font-size: 0.85rem;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li.active a {
  color: var(--esc-green);
  border-bottom-color: var(--esc-gold);
}

/* Product gallery */
.woocommerce div.product div.images img {
  border-radius: var(--esc-radius-lg);
}

/* ---------- Cart & Checkout ---------- */
.woocommerce-cart .woocommerce table.cart,
.woocommerce-checkout .woocommerce-checkout {
  background: var(--esc-white);
  border-radius: var(--esc-radius-lg);
  padding: 24px;
  box-shadow: var(--esc-shadow);
}

.woocommerce table.cart th {
  font-family: var(--esc-font-heading);
  color: var(--esc-green);
  font-size: 0.9rem;
  text-transform: uppercase;
  letter-spacing: 1px;
}

.woocommerce .cart-collaterals .cart_totals {
  background: var(--esc-pink-light);
  border-radius: var(--esc-radius-lg);
  padding: 24px;
}

.woocommerce-checkout h3 {
  font-family: var(--esc-font-heading);
  color: var(--esc-green);
  border-bottom: 2px solid var(--esc-pink);
  padding-bottom: 0.5em;
  margin-bottom: 1em;
}

/* Form inputs */
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select,
input[type="text"],
input[type="email"],
input[type="tel"],
input[type="password"],
input[type="number"],
textarea,
select {
  border: 1px solid rgba(45, 90, 61, 0.2) !important;
  border-radius: var(--esc-radius) !important;
  padding: 10px 14px !important;
  font-family: var(--esc-font-body);
  font-size: 0.95rem;
  transition: var(--esc-transition);
  background-color: var(--esc-white);
}

.woocommerce form .form-row input.input-text:focus,
input[type="text"]:focus,
input[type="email"]:focus,
textarea:focus {
  border-color: var(--esc-green) !important;
  box-shadow: 0 0 0 2px rgba(45, 90, 61, 0.1);
  outline: none;
}

/* ---------- My Account ---------- */
.woocommerce-MyAccount-navigation ul {
  list-style: none;
  padding: 0;
}

.woocommerce-MyAccount-navigation ul li a {
  display: block;
  padding: 12px 16px;
  border-radius: var(--esc-radius);
  color: var(--esc-brown);
  font-family: var(--esc-font-body);
  transition: var(--esc-transition);
}

.woocommerce-MyAccount-navigation ul li a:hover,
.woocommerce-MyAccount-navigation ul li.is-active a {
  background-color: var(--esc-pink-light);
  color: var(--esc-green);
}

/* ---------- Sidebar & Widgets ---------- */
.widget-title,
.wp-block-heading {
  font-family: var(--esc-font-heading);
  color: var(--esc-green);
  font-size: 1.2rem;
  border-bottom: 2px solid var(--esc-pink);
  padding-bottom: 0.5em;
  margin-bottom: 1em;
}

.widget {
  background: var(--esc-white);
  border-radius: var(--esc-radius-lg);
  padding: 20px;
  margin-bottom: 24px;
  box-shadow: var(--esc-shadow);
}

/* ---------- Footer ---------- */
.site-footer,
.ast-footer,
footer.site-footer {
  background-color: var(--esc-green) !important;
  color: var(--esc-cream) !important;
  padding: 40px 0 20px;
}

.site-footer a,
.ast-footer a {
  color: var(--esc-pink) !important;
  transition: var(--esc-transition);
}

.site-footer a:hover,
.ast-footer a:hover {
  color: var(--esc-gold) !important;
}

.site-footer .widget-title {
  color: var(--esc-cream);
  border-bottom-color: rgba(245, 198, 208, 0.3);
}

.ast-small-footer {
  background-color: var(--esc-green-dark) !important;
  color: rgba(255, 248, 240, 0.7) !important;
  border-top: 1px solid rgba(245, 198, 208, 0.2);
}

/* ---------- WooCommerce Messages ---------- */
.woocommerce-message {
  border-top-color: var(--esc-green) !important;
  background-color: var(--esc-pink-light);
}

.woocommerce-message::before {
  color: var(--esc-green) !important;
}

.woocommerce-info {
  border-top-color: var(--esc-gold) !important;
  background-color: #FFF5E6;
}

.woocommerce-error {
  border-top-color: #C0392B !important;
}

/* ---------- Star Ratings ---------- */
.woocommerce .star-rating span::before,
.woocommerce .star-rating::before {
  color: var(--esc-gold) !important;
}

/* ---------- Breadcrumbs ---------- */
.woocommerce .woocommerce-breadcrumb,
.ast-breadcrumbs {
  font-size: 0.85rem;
  color: var(--esc-brown-light);
  padding: 12px 0;
}

.woocommerce .woocommerce-breadcrumb a {
  color: var(--esc-green);
}

/* ---------- Coming Soon / Maintenance Page ---------- */
.wp-block-cover,
.wp-block-cover-image {
  border-radius: var(--esc-radius-lg);
}

/* ---------- Blog / Posts ---------- */
.entry-meta,
.entry-meta a {
  color: var(--esc-brown-light);
  font-size: 0.85rem;
}

.entry-meta a:hover {
  color: var(--esc-green);
}

article.post {
  background: var(--esc-white);
  border-radius: var(--esc-radius-lg);
  padding: 24px;
  margin-bottom: 24px;
  box-shadow: var(--esc-shadow);
}

/* ---------- Cottage Food Notice (Custom) ---------- */
.cottage-food-notice {
  background: var(--esc-pink-light);
  border: 1px solid var(--esc-pink);
  border-radius: var(--esc-radius);
  padding: 16px 20px;
  font-size: 0.85rem;
  color: var(--esc-brown);
  margin: 16px 0;
}

.cottage-food-notice strong {
  color: var(--esc-green);
}

/* ---------- Instagram Feed Section (Custom) ---------- */
.esc-instagram-section {
  background: var(--esc-pink-light);
  padding: 60px 0;
  text-align: center;
}

.esc-instagram-section h2 {
  font-family: var(--esc-font-heading);
  color: var(--esc-green);
  margin-bottom: 8px;
}

.esc-instagram-section .esc-handle {
  color: var(--esc-gold);
  font-size: 1.1rem;
  font-weight: 700;
}

/* ---------- Responsive ---------- */
@media (max-width: 768px) {
  h1, .entry-title { font-size: 1.8rem; }
  h2 { font-size: 1.5rem; }
  h3 { font-size: 1.25rem; }

  .woocommerce ul.products li.product {
    margin-bottom: 20px;
  }

  .woocommerce div.product .product_title {
    font-size: 1.6rem;
  }

  .site-footer {
    text-align: center;
  }
}

@media (max-width: 480px) {
  body {
    font-size: 15px;
  }

  .woocommerce ul.products li.product .button {
    font-size: 0.75rem !important;
    padding: 8px 16px !important;
  }
}

/* ---------- Print Styles ---------- */
@media print {
  .site-header,
  .site-footer,
  .woocommerce-breadcrumb {
    display: none;
  }

  body {
    background: white;
    color: black;
  }
}
