/*
Theme Name: Yomi Kids
Template: blocksy
Version: 1.0.0
Description: Custom theme for Yomi.Kids children clothing store
*/

/* ============================================
   SELF-HOSTED FONTS
   ============================================ */

/* Playfair Display 700 – cyrillic */
@font-face {
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url('fonts/playfair-display-700-cyrillic.woff2') format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}

/* Playfair Display 700 – latin-ext */
@font-face {
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url('fonts/playfair-display-700-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

/* Playfair Display 700 – latin */
@font-face {
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url('fonts/playfair-display-700-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* Poppins 400 – latin-ext */
@font-face {
  font-family: 'Poppins';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('fonts/poppins-400-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

/* Poppins 400 – latin */
@font-face {
  font-family: 'Poppins';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('fonts/poppins-400-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* Poppins 500 – latin-ext */
@font-face {
  font-family: 'Poppins';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url('fonts/poppins-500-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

/* Poppins 500 – latin */
@font-face {
  font-family: 'Poppins';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url('fonts/poppins-500-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* Poppins 600 – latin-ext */
@font-face {
  font-family: 'Poppins';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url('fonts/poppins-600-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

/* Poppins 600 – latin */
@font-face {
  font-family: 'Poppins';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url('fonts/poppins-600-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* ============================================
   VARIABLES & BASE
   ============================================ */
:root {
  --color-coral:      #f9b4ae;
  --color-teal:       #b8eef2;
  --color-yellow:     #ffe98a;
  --color-pink:       #f9c2d6;
  --color-dark:       #2d2d2d;
  --color-blue:       #6A9EF0;
  --color-mid:        #666;
  --color-light:      #faf9f7;
  --color-white:      #ffffff;
  --color-border:     #ede8e3;
  --color-gallery-bg: #f5f4f1;
  --color-add-cart:   #4a90d9;
  --color-add-cart-h: #3a7bc8;
  --font-heading:     'Playfair Display', Georgia, serif;
  --font-body:        'Poppins', system-ui, sans-serif;
  --radius:           12px;
  --radius-sm:        8px;
  --shadow:           0 4px 20px rgba(0,0,0,.06);
  --transition:       .25s ease;
}

*, *::before, *::after { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  font-family: var(--font-body);
  color: var(--color-dark);
  background: var(--color-white);
  margin: 0;
  -webkit-font-smoothing: antialiased;
}

img { max-width: 100%; height: auto; display: block; }

a { color: inherit; text-decoration: none; }

/* ============================================
   HEADER
   ============================================ */
.yk-header {
  position: sticky;
  top: 0;
  z-index: 100;
  background: linear-gradient(135deg,
    #fde8f0 0%,
    #fef3e2 25%,
    #e8f7f9 55%,
    #f0eeff 100%
  );
  border-bottom: none;
  box-shadow: none;
}

.yk-header__inner {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 24px;
  height: 72px;
  display: flex;
  align-items: center;
  gap: 32px;
}

.yk-logo img { height: 68px; width: auto; }

.yk-nav {
  flex: 1;
  display: flex;
  align-items: center;
  gap: 8px;
}

.yk-nav a {
  font-size: .875rem;
  font-weight: 500;
  color: var(--color-mid);
  padding: 6px 14px;
  border-radius: 20px;
  transition: var(--transition);
  letter-spacing: .02em;
  text-transform: uppercase;
}

.yk-nav a:hover,
.yk-nav a.current-menu-item {
  color: var(--color-dark);
  background: var(--color-teal);
}

.yk-header__actions {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-left: auto;
}

.yk-phone {
  font-size: .875rem;
  font-weight: 600;
  color: var(--color-dark);
  white-space: nowrap;
}

.yk-header__cart {
  position: relative;
  display: flex;
  align-items: center;
  gap: 6px;
  background: var(--color-coral);
  color: var(--color-dark);
  padding: 8px 16px;
  border-radius: 20px;
  font-size: .875rem;
  font-weight: 600;
  transition: var(--transition);
}

.yk-header__cart:hover { background: var(--color-pink); }

.yk-cart-count {
  background: var(--color-dark);
  color: var(--color-white);
  font-size: .7rem;
  font-weight: 700;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* ============================================
   HERO
   ============================================ */
.yk-hero {
  position: relative;
  min-height: min(600px, 85vh);
  overflow: hidden;
  background: linear-gradient(135deg,
    #fde8f0 0%,
    #fef3e2 25%,
    #e8f7f9 55%,
    #f0eeff 100%
  );
}

/* Decorative blobs */
.yk-hero::before {
  content: '';
  position: absolute;
  width: 500px;
  height: 500px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(249,178,174,.35) 0%, transparent 70%);
  top: -120px;
  right: -80px;
  pointer-events: none;
}

.yk-hero::after {
  content: '';
  position: absolute;
  width: 380px;
  height: 380px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(184,238,242,.4) 0%, transparent 70%);
  bottom: -80px;
  left: 40px;
  pointer-events: none;
}

.yk-hero__content {
  position: relative;
  z-index: 1;
  max-width: 1280px;
  margin: 0 auto;
  padding: 80px 24px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 20px;
}

.yk-hero__title {
  font-family: var(--font-heading);
  font-size: clamp(2.2rem, 5vw, 3.8rem);
  font-weight: 700;
  line-height: 1.15;
  color: var(--color-dark);
  margin: 0;
  max-width: 500px;
}

.yk-hero__subtitle {
  font-size: 1.05rem;
  color: var(--color-mid);
  margin: 0;
  max-width: 380px;
}

.yk-hero__buttons {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}

/* ============================================
   BUTTONS
   ============================================ */
.yk-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 13px 28px;
  border-radius: 30px;
  font-size: .925rem;
  font-weight: 600;
  cursor: pointer;
  border: 2px solid transparent;
  transition: var(--transition);
  text-transform: uppercase;
  letter-spacing: .04em;
}

.yk-btn--primary {
  background: var(--color-white);
  border-color: var(--color-blue);
  color: var(--color-blue);
}
.yk-btn--primary:hover { background: var(--color-blue); border-color: var(--color-blue); color: var(--color-dark); }

.yk-btn--outline {
  background: var(--color-white);
  border-color: var(--color-coral);
  color: var(--color-coral);
}
.yk-btn--outline:hover { background: var(--color-coral); border-color: var(--color-coral); color: var(--color-dark); }

/* ============================================
   CATEGORIES STRIP
   ============================================ */
.yk-cats {
  background: var(--color-light);
  padding: 48px 24px;
}

.yk-cats__inner {
  max-width: 1280px;
  margin: 0 auto;
}

.yk-section-title {
  font-family: var(--font-heading);
  font-size: clamp(1.5rem, 3vw, 2.2rem);
  font-weight: 700;
  text-align: center;
  margin: 0 0 36px;
  color: var(--color-dark);
}

.yk-cats__cols {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
}

.yk-cat-col {
  border-radius: var(--radius);
  padding: 32px;
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.yk-cat-col--boy  { background: linear-gradient(135deg, #dff6f9 0%, #c8eef2 100%); }
.yk-cat-col--girl { background: linear-gradient(135deg, #fde8f2 0%, #f9c2d6 100%); }

.yk-cat-col__header {
  display: flex;
  align-items: center;
  gap: 16px;
}

.yk-cat-col__icon {
  font-size: 2.8rem;
  line-height: 1;
}

.yk-cat-col__title {
  font-family: var(--font-heading);
  font-size: 1.6rem;
  font-weight: 700;
  margin: 0;
  color: var(--color-dark);
}

.yk-cat-col__links {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.yk-cat-link {
  display: inline-block;
  padding: 7px 14px;
  background: rgba(255,255,255,.7);
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 20px;
  font-size: .85rem;
  font-weight: 500;
  color: var(--color-dark);
  transition: var(--transition);
  backdrop-filter: blur(4px);
}

.yk-cat-link:hover {
  background: var(--color-white);
  border-color: rgba(0,0,0,.2);
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0,0,0,.08);
}

.yk-cat-col__all {
  align-self: flex-start;
  font-size: .85rem !important;
  padding: 10px 22px !important;
}

/* ============================================
   SHOP INNER WRAPPER
   ============================================ */
.yk-shop__inner {
  padding: 64px 24px;
  max-width: 1280px;
  margin: 0 auto;
}

/* ============================================
   PERKS BAR
   ============================================ */
.yk-perks {
  background: var(--color-dark);
  color: var(--color-white);
  padding: 32px 24px;
}

.yk-perks__inner {
  max-width: 1280px;
  margin: 0 auto;
  display: flex;
  justify-content: center;
  gap: 48px;
  flex-wrap: wrap;
}

.yk-perk {
  display: flex;
  align-items: center;
  gap: 12px;
}

.yk-perk__icon {
  width: 40px;
  height: 40px;
  background: rgba(255,255,255,.1);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.2rem;
}

.yk-perk__text strong {
  display: block;
  font-size: .9rem;
  font-weight: 600;
}

.yk-perk__text span {
  font-size: .78rem;
  opacity: .65;
}

/* ============================================
   FOOTER
   ============================================ */
.yk-footer {
  background: var(--color-light);
  border-top: 1px solid var(--color-border);
  padding: 48px 24px 24px;
}

.yk-footer__inner {
  max-width: 1280px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: auto repeat(3, 1fr);
  gap: 48px;
  align-items: start;
  margin-bottom: 40px;
}

.yk-footer__brand a {
  display: block;
  line-height: 0;
}

.yk-footer__brand img {
  max-width: 15vw;
  width: auto;
  height: auto;
}

.yk-footer__brand p {
  color: var(--color-mid);
  font-size: .8rem;
  line-height: 1.6;
  margin: 8px 0 0;
  max-width: 160px;
}

.yk-footer__col h4 {
  font-size: .85rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  margin: 0 0 16px;
}

.yk-footer__col ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.yk-footer__col ul li a {
  font-size: .875rem;
  color: var(--color-mid);
  transition: var(--transition);
}

.yk-footer__col ul li a:hover { color: var(--color-dark); }

.yk-footer__bottom {
  border-top: 1px solid var(--color-border);
  padding-top: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  font-size: .8rem;
  color: var(--color-mid);
  flex-wrap: wrap;
  text-align: center;
}

/* ============================================
   WOOCOMMERCE GLOBAL OVERRIDES
   ============================================ */
.woocommerce-breadcrumb,
.blocksy-breadcrumbs { display: none !important; }

/* Shop page */
.woocommerce .woocommerce-result-count { color: var(--color-mid); font-size: .875rem; }

.woocommerce .woocommerce-ordering select {
  border: 1px solid var(--color-border);
  border-radius: 20px;
  padding: 8px 16px;
  font-family: var(--font-body);
}

/* Single product */
.woocommerce div.product .product_title {
  font-family: var(--font-heading) !important;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li a {
  font-family: var(--font-body) !important;
}

.woocommerce #respond input#submit,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button {
  background: var(--color-coral) !important;
  color: var(--color-dark) !important;
  border-radius: 30px !important;
  font-weight: 600 !important;
  border: none !important;
  transition: var(--transition) !important;
}

.woocommerce #respond input#submit:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover {
  background: var(--color-pink) !important;
  color: var(--color-dark) !important;
}

.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce input.button.alt,
.woocommerce #respond input#submit.alt {
  background: var(--color-dark) !important;
  color: var(--color-white) !important;
}

.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover {
  background: #444 !important;
  color: var(--color-white) !important;
}

/* ============================================
   BLOCKSY PAGINATION OVERRIDE
   ============================================ */
[data-pagination] .page-numbers.current {
  background: var(--color-coral) !important;
  color: var(--color-dark) !important;
  border-color: var(--color-coral) !important;
}

[data-pagination] .page-numbers:not(.current):hover {
  border-color: var(--color-coral) !important;
  color: var(--color-coral) !important;
}

/* ============================================
   HIDE BLOCKSY DEFAULT HEADER/FOOTER
   ============================================ */
#header,
header.site-header { display: none !important; }

footer.site-footer,
#footer { display: none !important; }

@media (max-width: 640px) {
  .yk-header__inner { height: 60px; gap: 16px; }
  .yk-phone { display: none; }
  .yk-hero { height: 100svh; display: flex; align-items: center; justify-content: center; }
  .yk-hero__content { align-items: center; text-align: center; padding: 40px 24px; }
  .yk-hero__buttons { justify-content: center; }
  .yk-footer__inner { grid-template-columns: 1fr; }
  ul.products { --wc-columns: 1 !important; gap: 12px !important; }
  .yk-card__sizes { display: none; }
  .yk-filter-bar { gap: 10px 12px; }
  .yk-filter-gender__btn { padding: 6px 14px; font-size: .8rem; }
  .yk-cats__cols { grid-template-columns: 1fr; }
}

/* ============================================
   PAGE WRAPPER
   ============================================ */
.yk-page { min-height: 60vh; padding: 40px 24px 64px; }
.yk-page__inner { max-width: 1280px; margin: 0 auto; }
.yk-page__title { font-family: var(--font-heading); font-size: clamp(1.6rem, 3vw, 2.2rem); margin: 0 0 32px; }

/* ============================================
   SHOP GRID
   ============================================ */
.woocommerce-page .yk-page__inner ul.products,
.woocommerce ul.products {
  display: grid !important;
  grid-template-columns: repeat(var(--wc-columns, 4), 1fr) !important;
  gap: 24px !important;
  margin: 24px 0 0 !important;
  padding: 0 !important;
  list-style: none !important;
}
.woocommerce ul.products li.product {
  background: var(--color-white) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius) !important;
  overflow: hidden !important;
  transition: var(--transition) !important;
  margin: 0 !important;
  padding: 0 !important;
  float: none !important;
  width: auto !important;
}
.woocommerce ul.products li.product:hover { transform: translateY(-4px) !important; box-shadow: var(--shadow) !important; }
.woocommerce ul.products li.product a img { width: 100% !important; aspect-ratio: 3/4 !important; object-fit: cover !important; border-radius: 0 !important; margin: 0 !important; }
.woocommerce ul.products li.product .woocommerce-loop-product__title { font-size: .93rem !important; font-weight: 600 !important; padding: 12px 14px 4px !important; margin: 0 !important; }
.woocommerce ul.products li.product .price { padding: 0 14px 4px !important; font-size: .9rem !important; font-weight: 700 !important; color: var(--color-dark) !important; }
.woocommerce ul.products li.product .button { display: block !important; margin: 8px 14px 14px !important; padding: 9px !important; background: var(--color-coral) !important; color: var(--color-dark) !important; border-radius: 20px !important; font-size: .82rem !important; font-weight: 600 !important; text-align: center !important; border: none !important; transition: var(--transition) !important; }
.woocommerce ul.products li.product .button:hover { background: var(--color-pink) !important; }

/* ============================================
   PRODUCT CARD
   ============================================ */
.yk-card__link { display: block; }
.yk-card__img { width: 100%; aspect-ratio: 3/4; object-fit: cover; display: block; }
.yk-card__body { padding: 12px 14px 16px; }
.yk-card__title { display: block; font-size: .93rem; font-weight: 600; color: var(--color-dark); margin-bottom: 4px; line-height: 1.3; }
.yk-card__title:hover { color: var(--color-mid); }
.yk-card__price { font-size: .9rem; font-weight: 700; color: var(--color-dark); margin-bottom: 10px; }
.yk-card__sizes { display: flex; flex-wrap: wrap; gap: 4px; }
.yk-card__size { font-size: .72rem; font-weight: 600; padding: 3px 8px; border: 1px solid var(--color-border); border-radius: 6px; color: var(--color-mid); background: var(--color-light); }

/* ============================================
   SHOP TOP BAR
   ============================================ */
.woocommerce-products-header { display: none; }
.woocommerce-result-count { font-size: .875rem !important; color: var(--color-mid) !important; }
.woocommerce-ordering select { border: 1px solid var(--color-border) !important; border-radius: 20px !important; padding: 8px 36px 8px 16px !important; font-family: var(--font-body) !important; font-size: .875rem !important; background-color: var(--color-white) !important; cursor: pointer !important; }

/* ============================================
   GENDER + SIZE FILTER BAR
   ============================================ */
.yk-filter-bar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 12px 20px;
  padding: 16px 0 20px;
  border-bottom: 1px solid var(--color-border);
  margin-bottom: 24px;
}

.yk-filter-gender {
  display: flex;
  gap: 8px;
  flex-shrink: 0;
}

.yk-filter-gender__btn {
  padding: 7px 18px;
  border-radius: 20px;
  border: 1.5px solid;
  font-size: .85rem;
  font-weight: 600;
  background: var(--color-white);
  transition: var(--transition);
  white-space: nowrap;
}

/* Момче — синьо */
.yk-filter-gender__btn--boy {
  border-color: var(--color-blue);
  color: var(--color-blue);
}
.yk-filter-gender__btn--boy:hover,
.yk-filter-gender__btn--boy.is-active {
  background: var(--color-blue);
  color: var(--color-dark);
}

/* Момиче — корал */
.yk-filter-gender__btn--girl {
  border-color: var(--color-coral);
  color: var(--color-coral);
}
.yk-filter-gender__btn--girl:hover,
.yk-filter-gender__btn--girl.is-active {
  background: var(--color-coral);
  color: var(--color-dark);
}

.yk-filter-sizes {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.yk-filter-size {
  padding: 6px 14px;
  border-radius: 16px;
  border: 1.5px solid var(--color-border);
  font-size: .8rem;
  font-weight: 600;
  color: var(--color-mid);
  background: var(--color-white);
  transition: var(--transition);
  white-space: nowrap;
}
/* Момче — синьо */
.yk-filter-bar--boy .yk-filter-size:hover { border-color: var(--color-blue); color: var(--color-blue); }
.yk-filter-bar--boy .yk-filter-size.is-active { background: var(--color-blue); border-color: var(--color-blue); color: var(--color-dark); }

/* Момиче — корал */
.yk-filter-bar--girl .yk-filter-size:hover { border-color: var(--color-coral); color: var(--color-coral); }
.yk-filter-bar--girl .yk-filter-size.is-active { background: var(--color-coral); border-color: var(--color-coral); color: var(--color-dark); }

/* ============================================
   PAGINATION
   ============================================ */
.woocommerce nav.woocommerce-pagination ul { border: none !important; display: flex !important; gap: 6px !important; justify-content: center !important; margin-top: 40px !important; }
.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span { border: 1px solid var(--color-border) !important; border-radius: 8px !important; padding: 8px 14px !important; font-size: .875rem !important; transition: var(--transition) !important; color: var(--color-dark) !important; }
.woocommerce nav.woocommerce-pagination ul li a:hover,
.woocommerce nav.woocommerce-pagination ul li span.current { background: var(--color-coral) !important; color: var(--color-dark) !important; border-color: var(--color-coral) !important; }

/* ============================================
   SINGLE PRODUCT
   ============================================ */
.yk-single { width: 100%; max-width: 1400px; margin: 0 auto; padding: 48px 60px 80px; box-sizing: border-box; }
.yk-single__inner { display: grid; grid-template-columns: 5fr 6fr; gap: 72px; align-items: start; }

/* Gallery */
.yk-single__main-img { position: relative; border-radius: 16px; overflow: hidden; background: var(--color-gallery-bg); }
.yk-single__photo { width: 100%; aspect-ratio: 3/4; object-fit: cover; display: block; transition: opacity .3s; }
.yk-single__zoom { position: absolute; top: 14px; right: 14px; background: rgba(255,255,255,.85); border-radius: 50%; width: 38px; height: 38px; display: flex; align-items: center; justify-content: center; color: var(--color-dark); backdrop-filter: blur(4px); transition: var(--transition); }
.yk-single__zoom:hover { background: var(--color-white); }
.yk-single__thumbs { display: flex; gap: 10px; margin-top: 12px; flex-wrap: wrap; }
.yk-single__thumb { border: 2px solid transparent; border-radius: 10px; overflow: hidden; cursor: pointer; padding: 0; background: var(--color-gallery-bg); flex: 0 0 76px; transition: var(--transition); }
.yk-single__thumb img { width: 76px; height: 76px; object-fit: cover; display: block; }
.yk-single__thumb.is-active,
.yk-single__thumb:hover { border-color: var(--color-dark); }

/* Summary */
.yk-single__crumbs { font-size: .78rem; color: var(--color-mid); margin-bottom: 16px; display: flex; gap: 6px; flex-wrap: wrap; align-items: center; }
.yk-single__crumbs a { color: var(--color-mid); }
.yk-single__crumbs a:hover { color: var(--color-dark); }
.yk-single__title { font-family: var(--font-heading); font-size: clamp(1.5rem, 2.5vw, 2.2rem); line-height: 1.2; margin: 0 0 14px; color: var(--color-dark); }
.yk-single__price { font-size: 1.9rem; font-weight: 700; color: var(--color-dark); margin-bottom: 20px; }
.yk-single__price del { font-size: 1.2rem; color: var(--color-mid); font-weight: 400; margin-right: 8px; }
.yk-single__price ins { text-decoration: none; }
.yk-single__desc { color: var(--color-mid); font-size: .93rem; line-height: 1.75; margin-bottom: 24px; padding-bottom: 24px; border-bottom: 1px solid var(--color-border); }
.yk-single__desc p { margin: 0 0 8px; }

/* Variations + Add to cart */
.yk-single__summary .variations_form,
.yk-single__summary form.cart { width: 100%; }
.yk-single__summary table.variations { width: 100%; border: none; margin-bottom: 16px; border-collapse: collapse; }
.yk-single__summary table.variations td,
.yk-single__summary table.variations th { border: none; padding: 4px 0; vertical-align: middle; }
.yk-single__summary table.variations label { font-weight: 700; font-size: .78rem; text-transform: uppercase; letter-spacing: .07em; color: var(--color-dark); }
.yk-single__summary table.variations select,
.yk-single__summary .woocommerce-variation-add-to-cart select { width: 100%; border: 1.5px solid var(--color-border); border-radius: 10px; padding: 12px 16px; font-family: var(--font-body); font-size: .93rem; background: var(--color-white); cursor: pointer; margin-bottom: 4px; }
.yk-single__summary .reset_variations { font-size: .78rem; color: var(--color-mid); display: inline-block; margin-bottom: 16px; }
.yk-single__summary .woocommerce-variation-availability { margin-bottom: 12px; font-size: .85rem; color: var(--color-mid); }
.yk-single__summary form.cart { display: block; }
.yk-single__summary form.cart .qty { width: 62px; padding: 13px 10px; border: 1.5px solid var(--color-border); border-radius: 10px; font-size: 1rem; font-weight: 600; text-align: center; }
.yk-single__summary form.cart .single_add_to_cart_button { padding: 12px 28px; border-radius: 30px; font-size: .9rem; font-weight: 700; background: var(--color-add-cart); color: var(--color-white); border: none; cursor: pointer; transition: var(--transition); letter-spacing: .03em; white-space: nowrap; }
.yk-single__summary form.cart .single_add_to_cart_button:hover { background: var(--color-add-cart-h); }
.yk-single__summary form.cart .single_add_to_cart_button.disabled { background: var(--color-border); color: var(--color-mid); cursor: not-allowed; }

/* Meta */
.yk-single__meta { margin-top: 28px; padding-top: 20px; border-top: 1px solid var(--color-border); display: flex; flex-direction: column; gap: 6px; }
.yk-single__meta-row { font-size: .8rem; color: var(--color-mid); display: flex; gap: 8px; }
.yk-single__meta-row span { font-weight: 700; color: var(--color-dark); min-width: 90px; }
.yk-single__meta-row a { color: var(--color-mid); text-decoration: underline; }
.yk-single__meta-row a:hover { color: var(--color-dark); }

/* Size buttons */
.yk-single__summary .variations_form { display: block; }
.yk-size-btns { display: flex; flex-wrap: wrap; gap: 8px; margin: 8px 0 10px; align-items: center; }
.yk-size-btns ~ .woocommerce-variation-add-to-cart { display: flex; flex-direction: row; gap: 10px; align-items: center; flex-wrap: nowrap; margin-top: 0; }
.yk-size-btn { border: 1.5px solid var(--color-border); border-radius: 8px; padding: 8px 16px; font-family: var(--font-body); font-size: .88rem; font-weight: 600; cursor: pointer; background: var(--color-white); color: var(--color-dark); transition: var(--transition); }
.yk-size-btn:hover { border-color: var(--color-coral); background: var(--color-light); }
.yk-size-btn.is-active { background: var(--color-coral); color: var(--color-dark); border-color: var(--color-coral); }

/* Hide unwanted WC elements */
.yk-single__summary .reset_variations,
.yk-single__summary .woocommerce-variation-availability,
.yk-single__summary .stock { display: none !important; }

/* Qty input with +/- */
.yk-single__summary .quantity { display: flex; align-items: center; border: 1.5px solid var(--color-border); border-radius: 10px; overflow: hidden; width: auto; background: var(--color-white); }
.yk-single__summary .quantity .qty { border: none !important; width: 40px !important; padding: 10px 4px !important; text-align: center; font-size: .95rem; font-weight: 600; -moz-appearance: textfield; appearance: textfield; background: transparent; }
.yk-single__summary .quantity .qty::-webkit-inner-spin-button,
.yk-single__summary .quantity .qty::-webkit-outer-spin-button { -webkit-appearance: none; margin: 0; }
.yk-single__summary .quantity .yk-qty-btn { display: flex; align-items: center; justify-content: center; width: 34px; height: 42px; background: none; border: none; cursor: pointer; font-size: 1.1rem; font-weight: 400; color: var(--color-dark); padding: 0; line-height: 1; transition: var(--transition); }
.yk-single__summary .quantity .yk-qty-btn:hover { background: var(--color-light); }

/* Badges */
.yk-single__badges { margin-top: 20px; display: flex; flex-direction: column; gap: 8px; }
.yk-single__badge { display: flex; align-items: center; gap: 8px; font-size: .82rem; color: var(--color-mid); }
.yk-single__badge svg { color: var(--color-teal); flex-shrink: 0; }

/* Related */
.yk-single__related { margin-top: 56px; padding-top: 40px; border-top: 1px solid var(--color-border); }
.yk-single__related h3 { font-family: var(--font-heading); font-size: 1.5rem; margin-bottom: 28px; }

/* ============================================
   CART & CHECKOUT
   ============================================ */
/* Cart layout — table + totals side by side */
.woocommerce-cart .woocommerce { display: grid !important; grid-template-columns: 1fr 360px !important; gap: 32px !important; align-items: start !important; }
.woocommerce-cart .woocommerce form.woocommerce-cart-form { grid-column: 1 !important; }
.woocommerce-cart .woocommerce .cart-collaterals { grid-column: 2 !important; }
.woocommerce-cart .woocommerce .cart-collaterals .cart_totals { float: none !important; width: 100% !important; }

@media (max-width: 860px) {
  .yk-single { padding: 24px 20px 60px; }
  .yk-single__inner { grid-template-columns: 1fr; gap: 32px; }
  .woocommerce-cart .woocommerce { grid-template-columns: 1fr !important; }
  .woocommerce-cart .woocommerce form.woocommerce-cart-form { grid-column: 1 !important; }
  .woocommerce-cart .woocommerce .cart-collaterals { grid-column: 1 !important; }
  .yk-footer__inner { grid-template-columns: 1fr 1fr; }
  .yk-perks__inner { gap: 16px; flex-direction: column; align-items: flex-start; padding: 0 16px; }
  .yk-perk { width: 70%; }
  .yk-nav { display: none !important; }
  .yk-burger { display: flex !important; }
}

/* Cart product thumbnail size */
.woocommerce table.cart td.product-thumbnail img { width: 80px !important; height: 80px !important; object-fit: cover !important; border-radius: var(--radius-sm) !important; }

.woocommerce table.shop_table { border: 1px solid var(--color-border) !important; border-radius: var(--radius) !important; overflow: hidden !important; border-collapse: separate !important; border-spacing: 0 !important; }
.woocommerce table.shop_table thead th { background: var(--color-light) !important; font-size: .8rem !important; font-weight: 700 !important; text-transform: uppercase !important; letter-spacing: .05em !important; padding: 14px 16px !important; border-bottom: 1px solid var(--color-border) !important; }
.woocommerce table.shop_table td { padding: 16px !important; border-bottom: 1px solid var(--color-border) !important; vertical-align: middle !important; }
.woocommerce .cart-collaterals .cart_totals { background: var(--color-light) !important; border: 1px solid var(--color-border) !important; border-radius: var(--radius) !important; padding: 24px !important; float: none !important; width: 100% !important; }
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea { border: 1px solid var(--color-border) !important; border-radius: var(--radius-sm) !important; padding: 12px 14px !important; font-family: var(--font-body) !important; font-size: .9rem !important; transition: var(--transition) !important; width: 100% !important; }
.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus { border-color: var(--color-teal) !important; outline: none !important; box-shadow: 0 0 0 3px rgba(184,238,242,.3) !important; }

/* Cart quantity — inline buttons */
.woocommerce table.cart .quantity,
.woocommerce table.cart td.actions .quantity {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  border: 1.5px solid var(--color-border) !important;
  border-radius: 10px !important;
  overflow: hidden !important;
  width: fit-content !important;
  background: var(--color-white) !important;
}
.woocommerce table.cart .quantity .qty {
  border: none !important;
  width: 44px !important;
  padding: 8px 4px !important;
  text-align: center !important;
  font-size: .95rem !important;
  font-weight: 600 !important;
  background: transparent !important;
  -moz-appearance: textfield !important;
  appearance: textfield !important;
}
.woocommerce table.cart .quantity .qty::-webkit-inner-spin-button,
.woocommerce table.cart .quantity .qty::-webkit-outer-spin-button { -webkit-appearance: none !important; }
.woocommerce table.cart .quantity .yk-qty-btn {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 34px !important;
  height: 38px !important;
  background: none !important;
  border: none !important;
  font-size: 1.1rem !important;
  font-weight: 400 !important;
  color: var(--color-dark) !important;
  cursor: pointer !important;
  padding: 0 !important;
  transition: var(--transition) !important;
}
.woocommerce table.cart .quantity .yk-qty-btn:hover { background: var(--color-light) !important; }

/* ============================================
   MOBILE MENU
   ============================================ */
.yk-burger { display: none; flex-direction: column; gap: 5px; cursor: pointer; padding: 4px; background: none; border: none; margin-left: auto; }
.yk-burger span { display: block; width: 24px; height: 2px; background: var(--color-dark); border-radius: 2px; transition: var(--transition); }
.yk-mobile-nav { display: none; position: fixed; inset: 0; background: var(--color-white); z-index: 999; flex-direction: column; padding: 80px 32px 40px; gap: 8px; overflow-y: auto; }
.yk-mobile-nav.is-open { display: flex; }
.yk-mobile-nav__close { position: absolute; top: 20px; right: 24px; background: none; border: none; font-size: 1.8rem; cursor: pointer; color: var(--color-dark); line-height: 1; }
.yk-mobile-nav a { font-size: 1.2rem; font-weight: 600; color: var(--color-dark); padding: 14px 0; border-bottom: 1px solid var(--color-border); display: block; }

