/*
Theme Name: Aratrika Child
Template: astra
Version: 3.0
*/

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;1,300;1,400;1,500&family=Jost:wght@300;400;500&family=Noto+Serif+Devanagari:wght@300;400&display=swap');

:root {
  --ivory:    #F5F0E8;
  --ivory2:   #EDE8DF;
  --burgundy: #6B1E2E;
  --burg2:    #8B2535;
  --gold:     #C9A84C;
  --charcoal: #1A1714;
  --text:     #2C2420;
  --muted:    #8C7B6B;
  --border:   #E0D8CC;
  --font-d:   'Cormorant Garamond', Georgia, serif;
  --font-h:   'Noto Serif Devanagari', serif;
  --font-b:   'Jost', sans-serif;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
body { background: var(--ivory); color: var(--text); font-family: var(--font-b); }
img { display: block; max-width: 100%; }
a { text-decoration: none; color: inherit; }

/* ── HERO ── */
.aratrika-hero {
  display: grid;
  grid-template-columns: 2fr 3fr;
  min-height: 88vh;
  max-height: 100vh;
  background: var(--burgundy);
  overflow: hidden;
  align-items: stretch;
}
.hero-text {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 60px 40px 60px 56px;
  min-width: 0;
  z-index: 2;
  position: relative;
}
.hero-eyebrow {
  font-family: var(--font-b);
  font-size: 0.62rem;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: rgba(245,240,232,0.55);
  margin-bottom: 24px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.hero-eyebrow::before {
  content: '';
  display: inline-block;
  width: 28px;
  height: 1px;
  background: rgba(245,240,232,0.35);
}
.hero-headline {
  font-family: var(--font-d);
  font-size: clamp(2.8rem, 4vw, 4.4rem);
  font-weight: 300;
  line-height: 1.06;
  color: var(--ivory);
  margin-bottom: 18px;
}
.hero-headline em {
  font-style: italic;
  display: block;
  color: #E8D49A;
}
.hero-sub {
  font-family: var(--font-b);
  font-size: 0.78rem;
  font-weight: 300;
  line-height: 1.9;
  color: rgba(245,240,232,0.58);
  max-width: 280px;
  margin-bottom: 44px;
}
.hero-buttons { display: flex; gap: 12px; flex-wrap: wrap; }
.hero-cta-primary {
  font-family: var(--font-b);
  font-size: 0.65rem;
  font-weight: 500;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--charcoal);
  background: var(--gold);
  padding: 13px 28px;
  border: none;
  transition: background 0.2s;
  display: inline-block;
}
.hero-cta-primary:hover { background: #E8D49A; color: var(--charcoal); }
.hero-cta-secondary {
  font-family: var(--font-b);
  font-size: 0.65rem;
  font-weight: 500;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: rgba(245,240,232,0.8);
  background: transparent;
  border: 1px solid rgba(245,240,232,0.35);
  padding: 13px 28px;
  display: inline-block;
  transition: border-color 0.2s;
}
.hero-cta-secondary:hover { border-color: rgba(245,240,232,0.7); color: var(--ivory); }

/* collage — 2 cols, left spans full height */
.hero-collage {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 1fr 1fr;
  gap: 3px;
  height: 88vh;
}
.hero-collage-item {
  position: relative;
  overflow: hidden;
  display: block;
  min-height: 0;
}
.hero-collage-item:first-child { grid-row: 1 / 3; }
.hero-collage-item img {
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: top center;
  transition: transform 0.6s ease;
  display: block;
}
.hero-collage-item:hover img { transform: scale(1.04); }
.collage-label {
  position: absolute;
  bottom: 14px; left: 14px;
  font-family: var(--font-b);
  font-size: 0.62rem;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #fff;
  background: rgba(26,23,20,0.5);
  padding: 5px 10px;
  backdrop-filter: blur(3px);
  z-index: 2;
}
.collage-badge {
  position: absolute;
  top: 12px; left: 12px;
  font-family: var(--font-b);
  font-size: 0.58rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #fff;
  background: var(--burgundy);
  padding: 4px 8px;
  z-index: 2;
}
.collage-badge.bestseller { background: #7A5C1E; }
.collage-placeholder {
  width: 100%; height: 100%;
  min-height: 240px;
  background: var(--burg2);
  display: flex;
  align-items: flex-end;
  padding: 14px;
}
.collage-placeholder span {
  font-family: var(--font-b);
  font-size: 0.62rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(245,240,232,0.5);
}

/* ── MARQUEE ── */
.aratrika-marquee {
  background: var(--burgundy);
  padding: 10px 0;
  overflow: hidden;
  white-space: nowrap;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}
.marquee-track {
  display: inline-block;
  animation: marqueeScroll 32s linear infinite;
  font-family: var(--font-b);
  font-size: 0.65rem;
  font-weight: 400;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(245,240,232,0.85);
}
@keyframes marqueeScroll {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

/* ── NEW ARRIVALS ── */
.aratrika-new-arrivals {
  padding: 72px 60px;
  background: var(--ivory);
}
.section-header-row {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  margin-bottom: 36px;
}
.section-label {
  font-family: var(--font-b);
  font-size: 0.62rem;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--muted);
  display: block;
  margin-bottom: 5px;
}
.section-title {
  font-family: var(--font-d);
  font-size: clamp(1.8rem, 2.5vw, 2.5rem);
  font-weight: 400;
  color: var(--text);
  line-height: 1.1;
}
.section-title em { font-style: italic; color: var(--burgundy); }
.view-all {
  font-family: var(--font-b);
  font-size: 0.65rem;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text);
  border-bottom: 1px solid var(--text);
  padding-bottom: 2px;
  transition: color 0.2s, border-color 0.2s;
  white-space: nowrap;
}
.view-all:hover { color: var(--burgundy); border-color: var(--burgundy); }

/* WooCommerce product grid — match original exactly */
.aratrika-new-arrivals ul.products {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 20px !important;
  margin: 0 !important;
  padding: 0 !important;
  float: none !important;
  clear: both !important;
}
.aratrika-new-arrivals ul.products::before,
.aratrika-new-arrivals ul.products::after { display: none !important; }
.aratrika-new-arrivals ul.products li.product {
  width: 100% !important;
  margin: 0 !important;
  float: none !important;
  background: transparent !important;
  border: none !important;
  padding: 0 !important;
  position: relative !important;
}
.aratrika-new-arrivals ul.products li.product a.woocommerce-loop-product__link {
  display: block;
  position: relative;
  overflow: hidden;
}
.aratrika-new-arrivals ul.products li.product a.woocommerce-loop-product__link img {
  width: 100% !important;
  height: 380px !important;
  object-fit: cover !important;
  object-position: top center !important;
  display: block !important;
  margin: 0 !important;
  padding: 0 !important;
  transition: transform 0.5s ease !important;
}
.aratrika-new-arrivals ul.products li.product:hover img { transform: scale(1.04) !important; }
.aratrika-new-arrivals ul.products li.product .woocommerce-loop-product__title {
  font-family: var(--font-d) !important;
  font-size: 1rem !important;
  font-weight: 400 !important;
  color: var(--text) !important;
  padding: 10px 0 3px !important;
  margin: 0 !important;
  line-height: 1.3 !important;
}
.aratrika-new-arrivals ul.products li.product .price {
  font-family: var(--font-b) !important;
  font-size: 0.82rem !important;
  color: var(--text) !important;
  font-weight: 400 !important;
  display: block !important;
}
.aratrika-new-arrivals ul.products li.product .price ins { text-decoration: none !important; }
.aratrika-new-arrivals ul.products li.product a.button,
.aratrika-new-arrivals ul.products li.product .added_to_cart { display: none !important; }

/* product tag + wishlist on cards */
.prod-tag {
  position: absolute;
  top: 12px; left: 12px;
  font-family: var(--font-b);
  font-size: 0.56rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #fff;
  background: var(--burgundy);
  padding: 4px 7px;
  z-index: 3;
  pointer-events: none;
}
.prod-tag.bestseller { background: #7A5C1E; }
.prod-wish {
  position: absolute;
  top: 10px; right: 10px;
  width: 30px; height: 30px;
  background: rgba(255,255,255,0.9);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 0.9rem;
  z-index: 3;
  cursor: pointer;
  color: var(--text);
}
.prod-cat {
  font-family: var(--font-b);
  font-size: 0.58rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--muted);
  margin-top: 10px;
  display: block;
}

/* ── OUR STORY ── */
.aratrika-story {
  display: grid;
  grid-template-columns: 28% 44% 28%;
  grid-template-rows: 420px;
  margin: 60px 0;
}
.story-left {
  background: var(--burgundy);
  padding: 48px 48px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  position: relative;
  min-height: 420px;
}
.story-est {
  font-family: var(--font-b);
  font-size: 0.58rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: rgba(245,240,232,0.45);
  margin-bottom: 28px;
}
.story-brand-en {
  font-family: var(--font-d);
  font-size: clamp(2.8rem, 3.5vw, 3.6rem);
  font-weight: 400;
  color: var(--ivory);
  letter-spacing: 0.18em;
  display: block;
  line-height: 1;
  margin-bottom: 6px;
}
.story-brand-hi {
  font-family: var(--font-h);
  font-size: 1.05rem;
  color: rgba(245,240,232,0.55);
  display: block;
  margin-bottom: 28px;
}
.story-quote-left {
  font-family: var(--font-d);
  font-size: 0.88rem;
  font-style: italic;
  color: rgba(245,240,232,0.6);
  line-height: 1.75;
  max-width: 260px;
}
.story-middle {
  background: var(--ivory);
  padding: 48px 56px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.story-our-story {
  font-family: var(--font-b);
  font-size: 0.62rem;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 18px;
}
.story-quote-main {
  font-family: var(--font-d);
  font-size: clamp(1.2rem, 1.8vw, 1.65rem);
  font-style: italic;
  font-weight: 400;
  color: var(--text);
  line-height: 1.4;
  margin-bottom: 20px;
}
.story-body {
  font-family: var(--font-b);
  font-size: 0.78rem;
  font-weight: 300;
  line-height: 1.9;
  color: var(--muted);
  max-width: 480px;
  margin-bottom: 36px;
}
.story-stats {
  display: flex;
  gap: 44px;
  flex-wrap: wrap;
}
.stat-number {
  font-family: var(--font-d);
  font-size: 1.9rem;
  font-weight: 400;
  color: var(--text);
  display: block;
  line-height: 1.1;
}
.stat-label {
  font-family: var(--font-b);
  font-size: 0.6rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--muted);
  display: block;
  margin-top: 2px;
}
.story-image {
  position: relative;
  overflow: hidden;
  height: 100%;
  background: var(--ivory2);
}
.story-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  display: block;
}

/* ── SHOP THE OCCASION ── */
.aratrika-occasions {
  padding: 72px 60px;
  background: var(--ivory);
}
.occasions-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 3px;
  margin-top: 36px;
}
.occasion-card {
  position: relative;
  overflow: hidden;
  display: block;
  aspect-ratio: 3/4;
  background: var(--ivory2);
  min-height: 360px;
}
.occasion-card img {
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: top center;
  transition: transform 0.6s ease;
  display: block;
}
.occasion-card:hover img { transform: scale(1.05); }
.occasion-card::after {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(26,23,20,0.72) 0%, transparent 52%);
  pointer-events: none;
}
.occasion-info {
  position: absolute;
  bottom: 18px; left: 18px;
  z-index: 2;
}
.occasion-season {
  font-family: var(--font-b);
  font-size: 0.56rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(245,240,232,0.7);
  display: inline-block;
  background: rgba(107,30,46,0.8);
  padding: 3px 8px;
  margin-bottom: 8px;
}
.occasion-tag {
  font-family: var(--font-b);
  font-size: 0.58rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(245,240,232,0.6);
  display: block;
  margin-bottom: 3px;
}
.occasion-name {
  font-family: var(--font-d);
  font-size: 1.25rem;
  font-style: italic;
  font-weight: 400;
  color: #fff;
  display: block;
  margin-bottom: 3px;
  line-height: 1.2;
}
.occasion-cats {
  font-family: var(--font-b);
  font-size: 0.58rem;
  letter-spacing: 0.08em;
  color: rgba(245,240,232,0.45);
}
.occasion-placeholder {
  width: 100%;
  height: 100%;
  min-height: 380px;
  background: var(--ivory2);
}

/* ── INSTAGRAM ── */
.aratrika-instagram {
  padding: 72px 60px;
  background: var(--ivory);
  text-align: center;
  border-top: 1px solid var(--border);
}
.insta-follow {
  font-family: var(--font-b);
  font-size: 0.62rem;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 8px;
}
.insta-handle {
  font-family: var(--font-d);
  font-size: clamp(2rem, 4vw, 3.2rem);
  font-style: italic;
  font-weight: 400;
  color: var(--text);
  display: block;
  margin-bottom: 5px;
  line-height: 1;
}
.insta-sub {
  font-family: var(--font-b);
  font-size: 0.65rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 36px;
  display: block;
}
.insta-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 4px;
}
.insta-tile {
  aspect-ratio: 1;
  overflow: hidden;
  background: var(--ivory2);
  position: relative;
}
.insta-tile img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 0.5s ease;
}
.insta-tile:hover img { transform: scale(1.06); }

/* ── FOOTER ── */
.aratrika-footer {
  background: var(--ivory);
  padding: 56px 60px 0;
  border-top: 1px solid var(--border);
}
.footer-grid {
  display: grid;
  grid-template-columns: 1.8fr 1fr 1fr 1fr;
  gap: 40px;
  padding-bottom: 48px;
  border-bottom: 1px solid var(--border);
}
.footer-logo-en {
  font-family: var(--font-d);
  font-size: 1.5rem;
  font-weight: 400;
  color: var(--burgundy);
  display: block;
  letter-spacing: 0.08em;
  line-height: 1.1;
}
.footer-logo-hi {
  font-family: var(--font-h);
  font-size: 0.82rem;
  color: var(--muted);
  display: block;
  margin-bottom: 14px;
}
.footer-tagline {
  font-family: var(--font-b);
  font-size: 0.75rem;
  font-weight: 300;
  line-height: 1.85;
  color: var(--muted);
  max-width: 210px;
}
.footer-col-title {
  font-family: var(--font-b);
  font-size: 0.62rem;
  font-weight: 500;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--text);
  margin-bottom: 16px;
}
.footer-links { list-style: none; padding: 0; margin: 0; }
.footer-links li { margin-bottom: 9px; }
.footer-links a {
  font-family: var(--font-b);
  font-size: 0.76rem;
  color: var(--muted);
  transition: color 0.2s;
}
.footer-links a:hover { color: var(--burgundy); }
.footer-bottom {
  display: flex;
  justify-content: space-between;
  padding: 16px 0;
  font-family: var(--font-b);
  font-size: 0.68rem;
  color: var(--muted);
}

/* ── RESPONSIVE ── */
@media (max-width: 960px) {
  .aratrika-hero { grid-template-columns: 1fr; }
  .hero-collage { min-height: 60vw; grid-template-rows: 1fr 1fr; }
  .aratrika-new-arrivals ul.products { grid-template-columns: repeat(2,1fr) !important; }
  .occasions-grid { grid-template-columns: repeat(2,1fr); }
  .aratrika-story { grid-template-columns: 1fr; }
.story-left, .story-middle, .story-image { min-height: auto; }
.story-image { aspect-ratio: 4/3; }
  .insta-grid { grid-template-columns: repeat(3,1fr); }
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .aratrika-new-arrivals,
  .aratrika-occasions,
  .aratrika-instagram,
  .aratrika-footer { padding: 48px 24px; }
  .story-right { padding: 40px 28px; }
}
@media (max-width: 520px) {
  .aratrika-new-arrivals ul.products { grid-template-columns: 1fr !important; }
  .occasions-grid { grid-template-columns: 1fr; }
  .insta-grid { grid-template-columns: repeat(2,1fr); }
  .footer-grid { grid-template-columns: 1fr; }
}

/* NUCLEAR GRID FIX — force 4 columns no matter what */
.aratrika-new-arrivals .products,
.aratrika-new-arrivals ul.products,
ul.products {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  width: 100% !important;
  float: none !important;
  clear: both !important;
}
.aratrika-new-arrivals .products li,
.aratrika-new-arrivals ul.products li.product,
ul.products li.product {
  width: 100% !important;
  float: none !important;
  margin: 0 !important;
  clear: none !important;
}

/* ── PRODUCT GRID (custom shortcode cards) ── */
.products-grid {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 20px !important;
}
.product-card { position: relative; }
.product-card-img {
  display: block;
  position: relative;
  overflow: hidden;
  background: var(--ivory2);
  height: 380px;
}
.product-card-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
  display: block;
  transition: transform 0.5s ease;
}
.product-card:hover .product-card-img img { transform: scale(1.04); }
.product-tag {
  position: absolute;
  top: 12px; left: 12px;
  font-family: var(--font-b);
  font-size: 0.56rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #fff;
  background: var(--burgundy);
  padding: 4px 7px;
  z-index: 3;
}
.product-tag.bestseller { background: #7A5C1E; }
.wishlist-btn {
  position: absolute;
  top: 10px; right: 10px;
  width: 30px; height: 30px;
  background: rgba(255,255,255,0.9);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 0.9rem;
  z-index: 3;
  cursor: pointer;
  color: var(--text);
}
.product-cat-label {
  font-family: var(--font-b);
  font-size: 0.56rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--muted);
  margin-top: 12px;
  margin-bottom: 2px;
  display: block;
}
.product-name {
  font-family: var(--font-d);
  font-size: 1rem;
  font-weight: 400;
  color: var(--text);
  margin-bottom: 3px;
  line-height: 1.3;
}
.product-price {
  font-family: var(--font-b);
  font-size: 0.82rem;
  color: var(--text);
  font-weight: 400;
}
.product-placeholder {
  width: 100%; height: 100%;
  min-height: 320px;
  background: var(--ivory2);
  display: flex; align-items: center; justify-content: center;
}
.product-placeholder span {
  font-family: var(--font-d);
  font-size: 0.9rem;
  color: var(--muted);
  text-align: center;
  padding: 12px;
}

@media (max-width: 960px) {
  .products-grid { grid-template-columns: repeat(2,1fr) !important; }
}
@media (max-width: 520px) {
  .products-grid { grid-template-columns: 1fr !important; }
}

/* Force hero to break out of any Astra container constraints */
.aratrika-fullpage .site-content,
.aratrika-fullpage #content,
.aratrika-fullpage .ast-container,
.aratrika-fullpage .content-area,
.aratrika-fullpage .entry-content,
.aratrika-fullpage article,
.aratrika-fullpage .entry {
  max-width: 100% !important;
  width: 100% !important;
  padding: 0 !important;
  margin: 0 !important;
  float: none !important;
}
/* =====================================================================
   ARATRIKA — Single Product Page styling (Method 2)
   Paste this block at the BOTTOM of your child theme's style.css.
   Scoped to .arpd-product-page so it never affects other pages.
   ===================================================================== */

/* Layout: image left, summary right (matches mockup) */
.arpd-product-page.woocommerce div.product {
  display: grid;
  grid-template-columns: 48% 52%;
  gap: 48px;
  align-items: start;
}
.arpd-product-page.woocommerce div.product .woocommerce-product-gallery {
  width: 100% !important;
  float: none !important;
  margin: 0 !important;
}
.arpd-product-page.woocommerce div.product .summary.entry-summary {
  width: 100% !important;
  float: none !important;
  margin: 0 !important;
  padding-left: 8px;
}
/* tabs + related span full width below the two columns */
.arpd-product-page.woocommerce div.product .woocommerce-tabs,
.arpd-product-page.woocommerce div.product .related.products {
  grid-column: 1 / -1;
}

/* Breadcrumb */
.arpd-product-page .woocommerce-breadcrumb {
  font-family: 'Jost', sans-serif;
  font-size: 0.72rem;
  letter-spacing: 0.04em;
  color: #8C7B6B;
  margin-bottom: 18px;
}

/* Badge */
.arpd-product-page .arpd-badge {
  display: inline-block;
  font-family: 'Jost', sans-serif;
  font-size: 0.6rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #fff;
  background: #6B1E2E;
  padding: 6px 12px;
  margin-bottom: 14px;
}
.arpd-product-page .arpd-badge-bs { background: #7A5C1E; }

/* Category label */
.arpd-product-page .arpd-cat-label {
  display: block;
  font-family: 'Jost', sans-serif;
  font-size: 0.66rem;
  font-weight: 500;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: #C9A84C;
  margin-bottom: 8px;
}
/* hide WooCommerce's default duplicate category line in summary */
.arpd-product-page .single-product-category { display: none; }

/* Title */
.arpd-product-page .product_title.entry-title {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-size: clamp(1.9rem, 3vw, 2.7rem);
  font-weight: 500;
  line-height: 1.1;
  color: #2C2420;
  margin: 0 0 14px;
}

/* Price */
.arpd-product-page .summary .price,
.arpd-product-page .summary .price .amount {
  font-family: 'Cormorant Garamond', Georgia, serif !important;
  font-size: 2rem !important;
  font-weight: 600 !important;
  color: #6B1E2E !important;
}
.arpd-product-page .arpd-price-note {
  font-family: 'Jost', sans-serif;
  font-size: 0.74rem;
  color: #8C7B6B;
  margin: 6px 0 22px;
}

/* Divider under price block */
.arpd-product-page .summary form.cart { margin-top: 6px; }

/* Size head (label + guide link) */
.arpd-product-page .arpd-size-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 12px;
}
.arpd-product-page .arpd-size-label {
  font-family: 'Jost', sans-serif;
  font-size: 0.68rem;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: #2C2420;
}
.arpd-product-page .arpd-size-guide {
  font-family: 'Jost', sans-serif;
  font-size: 0.7rem;
  color: #C9A84C;
  text-decoration: underline;
}

/* Variation dropdown -> styled cleaner (boxes need a swatch plugin later) */
.arpd-product-page table.variations { margin-bottom: 16px; }
.arpd-product-page table.variations td.label { display: none; }
.arpd-product-page table.variations select {
  font-family: 'Jost', sans-serif;
  height: 46px;
  border: 1px solid #E0D8CC;
  background-color: #fff;
}

/* Quantity */
.arpd-product-page .summary .quantity {
  margin-bottom: 0;
}
.arpd-product-page .summary .quantity input.qty {
  height: 50px;
  width: 80px;
  border: 1px solid #E0D8CC;
  font-family: 'Jost', sans-serif;
  text-align: center;
}

/* Add to cart + Buy Now sit side by side */
.arpd-product-page .summary form.cart {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 12px;
}
.arpd-product-page .summary form.cart .quantity { flex: 0 0 auto; }
.arpd-product-page .summary .single_add_to_cart_button {
  flex: 1 1 auto;
  min-width: 180px;
  height: 50px;
  background: #fff !important;
  color: #6B1E2E !important;
  border: 1.5px solid #6B1E2E !important;
  font-family: 'Jost', sans-serif !important;
  font-size: 0.72rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.16em !important;
  text-transform: uppercase !important;
  border-radius: 0 !important;
  transition: all 0.2s !important;
}
.arpd-product-page .summary .single_add_to_cart_button:hover {
  background: #6B1E2E !important;
  color: #fff !important;
}
.arpd-product-page .summary .arpd-buy-now {
  flex: 1 1 auto;
  min-width: 180px;
  height: 50px;
  background: #6B1E2E !important;
  color: #fff !important;
  border: 1.5px solid #6B1E2E !important;
  font-family: 'Jost', sans-serif !important;
  font-size: 0.72rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.16em !important;
  text-transform: uppercase !important;
  border-radius: 0 !important;
  cursor: pointer;
  transition: all 0.2s !important;
}
.arpd-product-page .summary .arpd-buy-now:hover { background: #561825 !important; }

/* Wishlist (full-width, outline) */
.arpd-product-page .arpd-wishlist {
  display: block;
  width: 100%;
  margin-top: 12px;
  height: 46px;
  background: transparent;
  border: 1px solid #E0D8CC;
  color: #2C2420;
  font-family: 'Jost', sans-serif;
  font-size: 0.7rem;
  font-weight: 500;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  cursor: pointer;
  transition: all 0.2s;
}
.arpd-product-page .arpd-wishlist:hover { border-color: #6B1E2E; color: #6B1E2E; }
.arpd-product-page .arpd-wishlist.is-active { border-color: #6B1E2E; color: #6B1E2E; }
.arpd-product-page .arpd-wishlist.is-active .arpd-heart { color: #6B1E2E; }

/* Trust panel */
.arpd-product-page .arpd-trust {
  background: #F5F0E8;
  padding: 22px 24px;
  margin-top: 26px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.arpd-product-page .arpd-trust-row {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  font-family: 'Jost', sans-serif;
  font-size: 0.76rem;
  line-height: 1.5;
  color: #5C5048;
}
.arpd-product-page .arpd-trust-row strong { color: #2C2420; font-weight: 600; }
.arpd-product-page .arpd-trust-ic {
  color: #C9A84C;
  font-size: 1rem;
  flex: 0 0 auto;
  line-height: 1.3;
}

/* Payment chips */
.arpd-product-page .arpd-pay {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 22px;
}
.arpd-product-page .arpd-pay-label {
  font-family: 'Jost', sans-serif;
  font-size: 0.72rem;
  color: #8C7B6B;
  margin-right: 4px;
}
.arpd-product-page .arpd-chip {
  font-family: 'Jost', sans-serif;
  font-size: 0.66rem;
  letter-spacing: 0.08em;
  color: #6B1E2E;
  border: 1px solid #E0D8CC;
  padding: 5px 12px;
}

/* Tabs / description heading */
.arpd-product-page .woocommerce-tabs {
  margin-top: 56px;
  border-top: 1px solid #E0D8CC;
  padding-top: 8px;
}
.arpd-product-page .woocommerce-tabs ul.tabs li a {
  font-family: 'Jost', sans-serif !important;
  font-size: 0.72rem !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  color: #2C2420 !important;
}

/* Related products -> "You Might Also Love" */
.arpd-product-page .related.products {
  margin-top: 64px;
  border-top: 1px solid #E0D8CC;
  padding-top: 48px;
}
.arpd-product-page .related.products > h2 {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-size: clamp(1.6rem, 2.4vw, 2.2rem);
  font-weight: 400;
  color: #2C2420;
  margin-bottom: 32px;
}
.arpd-product-page .related.products ul.products {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 20px !important;
}
.arpd-product-page .related.products ul.products li.product {
  width: 100% !important;
  margin: 0 !important;
}

/* Responsive: stack on tablet/mobile */
@media (max-width: 921px) {
  .arpd-product-page.woocommerce div.product {
    grid-template-columns: 1fr;
    gap: 28px;
  }
  .arpd-product-page .related.products ul.products {
    grid-template-columns: repeat(2, 1fr) !important;
  }
  .arpd-product-page .summary .single_add_to_cart_button,
  .arpd-product-page .summary .arpd-buy-now { min-width: 140px; }
}
@media (max-width: 520px) {
  .arpd-product-page .related.products ul.products {
    grid-template-columns: 1fr !important;
  }
}
/* =====================================================================
   ARATRIKA — Product page FIXES (append below the previous product CSS)
   Fixes: layout overflow, column proportions, accordion styling,
   italic title accent. Scoped to .arpd-product-page only.
   ===================================================================== */

/* ---- FIX 1: Layout overflow + proportions ----
   Astra forces width:50%/46% floats on .images/.summary which breaks the
   grid and causes the right-side overflow. Override and let the grid rule. */
.arpd-product-page.woocommerce div.product .woocommerce-product-gallery,
.arpd-product-page.woocommerce div.product div.images {
  width: 100% !important;
  float: none !important;
  margin: 0 !important;
}
.arpd-product-page.woocommerce div.product .summary.entry-summary,
.arpd-product-page.woocommerce div.product div.summary {
  width: 100% !important;
  float: none !important;
  margin: 0 !important;
  max-width: 100% !important;
  min-width: 0 !important;
  box-sizing: border-box !important;
  overflow-wrap: anywhere;
}
/* Make sure nothing inside the summary can exceed its column */
.arpd-product-page.woocommerce div.product .summary * {
  max-width: 100%;
  box-sizing: border-box;
}
/* The cart row: keep buttons inside the column */
.arpd-product-page .summary form.cart {
  width: 100%;
  max-width: 100%;
  flex-wrap: wrap;
}
.arpd-product-page .summary .single_add_to_cart_button,
.arpd-product-page .summary .arpd-buy-now {
  flex: 1 1 0;
  min-width: 0;          /* allow shrinking so they never overflow */
  white-space: nowrap;
}
/* On narrower desktop, stack the two buttons instead of overflowing */
@media (max-width: 1100px) {
  .arpd-product-page .summary .single_add_to_cart_button,
  .arpd-product-page .summary .arpd-buy-now {
    flex: 1 1 100%;
  }
}

/* ---- FIX 2: Title italic accent ----
   Mockup shows the LAST words of the title in italic burgundy.
   Pure CSS can't split a title mid-string, so we italicize the whole
   title in the elegant serif and let it read as the mockup's style.
   (If you want only part italic, that needs the product title typed
   with an <em> — ask me and I'll show how.) */
.arpd-product-page .product_title.entry-title {
  font-family: 'Cormorant Garamond', Georgia, serif !important;
  font-weight: 500 !important;
}
.arpd-product-page .product_title.entry-title em {
  font-style: italic;
  color: #6B1E2E;
}

/* ---- FIX 3: Accordion styling for the tabs ----
   Style WooCommerce's description/additional/reviews area to look like
   the mockup's collapsible sections. WooCommerce shows these as tabs;
   we restyle them as stacked accordion-style rows. */
.arpd-product-page .woocommerce-tabs ul.tabs {
  list-style: none;
  margin: 0 0 0;
  padding: 0;
  border-bottom: none;
}
.arpd-product-page .woocommerce-tabs ul.tabs::before,
.arpd-product-page .woocommerce-tabs ul.tabs::after { display: none; }
.arpd-product-page .woocommerce-tabs ul.tabs li {
  display: block;
  border: none;
  border-top: 1px solid #E0D8CC;
  background: transparent;
  margin: 0;
  padding: 0;
}
.arpd-product-page .woocommerce-tabs ul.tabs li::before,
.arpd-product-page .woocommerce-tabs ul.tabs li::after { display: none; }
.arpd-product-page .woocommerce-tabs ul.tabs li a {
  display: block;
  padding: 18px 0 !important;
  font-family: 'Jost', sans-serif !important;
  font-size: 0.74rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.16em !important;
  text-transform: uppercase !important;
  color: #2C2420 !important;
}
.arpd-product-page .woocommerce-tabs .panel {
  font-family: 'Jost', sans-serif;
  font-size: 0.84rem;
  line-height: 1.8;
  color: #5C5048;
  padding-bottom: 24px;
}
.arpd-product-page .woocommerce-tabs .panel h2 { display: none; } /* hide duplicate heading */

/* ---- Small polish: rating row spacing if/when reviews exist ---- */
.arpd-product-page .summary .woocommerce-product-rating {
  margin: 4px 0 14px;
}
.arpd-product-page .summary .woocommerce-product-rating .star-rating { color: #C9A84C; }
/* =====================================================================
   ARATRIKA — PRECISE overflow fix (append at very bottom of style.css)
   Root cause found via DevTools: Astra's rule
     .woocommerce-js div.product form.cart .button { float:left; width:auto; }
   was floating the buttons and breaking the flex row. We kill the float
   and force the flex layout with matching/higher specificity.
   ===================================================================== */

/* Make the cart form a proper flex container (high specificity to win) */
.arpd-product-page.woocommerce div.product form.cart,
.arpd-product-page.woocommerce-page div.product form.cart {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  gap: 12px !important;
  width: 100% !important;
  max-width: 100% !important;
}

/* Kill the float that Astra puts on the buttons + let them flex */
.arpd-product-page.woocommerce div.product form.cart .button,
.arpd-product-page.woocommerce div.product form.cart .single_add_to_cart_button,
.arpd-product-page.woocommerce div.product form.cart .arpd-buy-now {
  float: none !important;
  margin-bottom: 0 !important;
  vertical-align: baseline !important;
}

/* Quantity stays compact, doesn't stretch */
.arpd-product-page.woocommerce div.product form.cart .quantity {
  flex: 0 0 auto !important;
  margin: 0 !important;
}

/* The two buttons share the remaining row width, side by side */
.arpd-product-page.woocommerce div.product form.cart .single_add_to_cart_button,
.arpd-product-page.woocommerce div.product form.cart .arpd-buy-now {
  flex: 1 1 0 !important;
  min-width: 0 !important;       /* allow shrink, never overflow */
  width: auto !important;
  white-space: nowrap;
}

/* Below 900px: quantity full width on its own line, buttons share next line */
@media (max-width: 900px) {
  .arpd-product-page.woocommerce div.product form.cart .quantity {
    flex: 1 1 100% !important;
  }
}

/* Safety: ensure the whole summary column can't exceed its grid track */
.arpd-product-page.woocommerce div.product .summary.entry-summary {
  min-width: 0 !important;
  overflow: hidden;
}
