/*
 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 ---------- */
/* Fonts are enqueued in functions.php for better performance. */

/* ---------- 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;
  }
}

/* =====================================================================
   Real-World Bakery UX Upgrades
   Inspired by modern bakery ecommerce patterns (hero-first layout,
   trust messaging, sticky conversion points, and polished cards).
   ===================================================================== */

/* Layout rhythm */
.site-content,
.ast-container,
.entry-content {
  max-width: 1200px;
}

.entry-content > * {
  margin-bottom: clamp(1rem, 2vw, 2rem);
}

/* Sticky header for easier shopping navigation */
.site-header,
.ast-primary-header {
  position: sticky;
  top: 0;
  z-index: 100;
  backdrop-filter: blur(8px);
}

/* Better focus accessibility */
a:focus-visible,
button:focus-visible,
input:focus-visible,
textarea:focus-visible,
select:focus-visible {
  outline: 3px solid rgba(212, 167, 106, 0.45);
  outline-offset: 2px;
}

/* Hero block shortcode */
.esc-hero {
  background:
    radial-gradient(circle at 0% 0%, rgba(245, 198, 208, 0.35), transparent 35%),
    radial-gradient(circle at 100% 100%, rgba(212, 167, 106, 0.22), transparent 30%),
    var(--esc-white);
  border: 1px solid rgba(45, 90, 61, 0.08);
  border-radius: 24px;
  padding: clamp(24px, 4vw, 56px);
  box-shadow: var(--esc-shadow-hover);
}

.esc-hero__inner {
  max-width: 780px;
}

.esc-hero__logo {
  width: min(280px, 50%);
  margin-bottom: 1rem;
}

.esc-kicker {
  color: var(--esc-green-light);
  letter-spacing: 2px;
  text-transform: uppercase;
  font-size: 0.8rem;
  font-weight: 700;
  margin-bottom: 0.5rem;
}

.esc-hero__description {
  max-width: 65ch;
  color: var(--esc-brown-light);
  font-size: 1.05rem;
}

.esc-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin: 1.25rem 0 1rem;
}

.esc-btn-secondary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(45, 90, 61, 0.2);
  border-radius: var(--esc-radius);
  padding: 12px 24px;
  font-size: 0.9rem;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: var(--esc-green) !important;
  background: var(--esc-white);
}

.esc-btn-secondary:hover {
  border-color: var(--esc-green);
  background: var(--esc-pink-light);
  color: var(--esc-green-dark) !important;
}

.esc-trust-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.esc-trust-list li {
  background: var(--esc-pink-light);
  border: 1px solid rgba(245, 198, 208, 0.8);
  color: var(--esc-green);
  border-radius: 999px;
  padding: 7px 12px;
  font-size: 0.82rem;
  font-weight: 700;
}

/* Utility store notice bar */
.esc-store-notice {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  background: var(--esc-green);
  color: var(--esc-cream);
  border-radius: 12px;
  padding: 12px;
  font-size: 0.88rem;
}

.esc-store-notice span {
  background: rgba(255, 255, 255, 0.08);
  border-radius: 8px;
  padding: 10px;
  text-align: center;
}

/* Higher-converting product cards */
.woocommerce ul.products li.product {
  display: flex;
  flex-direction: column;
}

.woocommerce ul.products li.product .button {
  margin-top: auto !important;
}

.woocommerce ul.products li.product .price {
  padding: 0 16px 10px;
}

.woocommerce ul.products li.product .star-rating {
  margin: 0 16px 10px;
}

/* Sections and rows created in block editor */
.wp-block-group.is-style-default,
.wp-block-columns {
  background: transparent;
}

.wp-block-cover,
.wp-block-group.has-background,
.wp-block-media-text {
  border-radius: var(--esc-radius-lg);
  overflow: hidden;
}

/* Testimonials and quote blocks */
.wp-block-quote,
.wp-block-pullquote {
  border-left: 4px solid var(--esc-pink);
  border-radius: 0 12px 12px 0;
  background: linear-gradient(90deg, rgba(253, 232, 237, 0.8), rgba(255, 255, 255, 0.95));
  padding: 20px;
}

/* Footer newsletter/forms */
.site-footer input[type="email"],
.site-footer input[type="text"],
.site-footer textarea {
  border-color: rgba(255, 248, 240, 0.35) !important;
  background: rgba(255, 255, 255, 0.96);
}

/* Mobile menu polish */
@media (max-width: 921px) {
  .ast-mobile-menu-buttons {
    padding-right: 8px;
  }

  .main-header-menu {
    background: var(--esc-white);
    border-radius: 12px;
    box-shadow: var(--esc-shadow-hover);
    margin-top: 10px;
    padding: 12px;
  }

  .esc-store-notice {
    grid-template-columns: 1fr;
  }
}

/* Reduced motion preference */
@media (prefers-reduced-motion: reduce) {
  * {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}
