/* product-page.css — Individual product page styles for YB Ausome Shoppe */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --baltic-blue:#000abe;
  --lime-moss:#4bb417;
  --cta-yellow:#FFD000;
  --white:#ffffff;
  --black:#000000;
  --off:#f5f5f8;
  --border:#e0e0e0;
  --border-strong:#000000;
  --text:#000000;
  --muted:#444;
  --faint:#777;
  --radius:8px;
  --radius-lg:12px;
  --font-body:'Nunito Sans',system-ui,sans-serif;
  --font-display:'Nunito',system-ui,sans-serif;
  --shadow:0 4px 16px rgba(0,0,0,.06);
  --max-w:1280px;
}

html{background:var(--lime-moss)}
body{font-family:var(--font-body);color:var(--text);font-size:15px;line-height:1.6;min-height:100vh;background:var(--lime-moss)}

/* ── Skip link ── */
.skip-link{position:absolute;top:-100px;left:16px;background:var(--cta-yellow);color:var(--black);padding:12px 24px;font-weight:700;font-size:16px;text-decoration:none;z-index:1000;transition:top .2s}
.skip-link:focus{top:16px;outline:3px solid var(--white);outline-offset:2px}

/* ── Header ── */
header{background:var(--baltic-blue)}
.site-nav{max-width:var(--max-w);margin:0 auto;padding:0 48px;display:flex;align-items:center;justify-content:space-between;min-height:64px}
.nav-logo{font-family:var(--font-display);font-size:clamp(1.05rem,.95rem + .45vw,1.3rem);font-weight:700;color:var(--white);text-decoration:none}
.nav-logo span{color:var(--white)}
.site-links{display:flex;gap:32px;list-style:none}
.site-links a{color:var(--white);text-decoration:none;font-size:clamp(.88rem,.82rem + .3vw,1rem);font-weight:600}
.site-links a:hover,.site-links a:focus-visible{opacity:.9;text-decoration:underline}
.nav-shop-btn{background:var(--cta-yellow);color:var(--black);text-decoration:none;font-size:clamp(.85rem,.8rem + .2vw,.95rem);font-weight:700;padding:10px 22px;border-radius:4px;display:inline-flex;align-items:center;gap:6px}
.nav-shop-btn:hover,.nav-shop-btn:focus-visible{background:var(--lime-moss)}
.nav-cart-count{background:var(--white);color:var(--black);border-radius:99px;min-width:20px;height:20px;display:inline-flex;align-items:center;justify-content:center;font-size:11px;padding:0 5px}

/* ── Main ── */
.product-main{max-width:var(--max-w);margin:0 auto;background:var(--white);padding:0 0 3rem}

/* ── Breadcrumbs ── */
.breadcrumbs{padding:14px 32px;font-size:13px;color:var(--faint);border-bottom:1px solid var(--border)}
.breadcrumbs ol{list-style:none;display:flex;flex-wrap:wrap;gap:4px}
.breadcrumbs li{display:flex;align-items:center;gap:4px}
.breadcrumbs li:not(:last-child)::after{content:'/';color:var(--faint)}
.breadcrumbs a{color:var(--baltic-blue);text-decoration:none;font-weight:500}
.breadcrumbs a:hover{text-decoration:underline}
.breadcrumbs [aria-current]{color:var(--text);font-weight:600}

/* ── Product layout ── */
.product-layout{display:grid;grid-template-columns:1fr 1fr;gap:40px;padding:32px 32px 0;align-items:start}

/* ── Gallery ── */
.product-gallery__main{background:var(--off);border-radius:var(--radius-lg);aspect-ratio:1;display:flex;align-items:center;justify-content:center;overflow:hidden;border:1px solid var(--border)}
.product-gallery__main img{max-width:100%;max-height:100%;object-fit:contain;display:block}
.product-gallery__placeholder{color:var(--faint);font-size:14px}
.product-gallery__thumbs{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}
.product-gallery__thumb{width:72px;height:72px;border:2px solid var(--border);border-radius:var(--radius);background:var(--white);padding:4px;cursor:pointer;transition:border-color .15s}
.product-gallery__thumb:hover{border-color:var(--baltic-blue)}
.product-gallery__thumb.active{border-color:var(--baltic-blue);box-shadow:0 0 0 2px rgba(0,10,190,.16)}
.product-gallery__thumb img{width:100%;height:100%;object-fit:contain;display:block}

/* ── Product info ── */
.product-info{padding-top:8px}
.product-info__title{font-family:var(--font-display);font-size:clamp(1.5rem,2.5vw,2rem);font-weight:700;line-height:1.2;margin-bottom:8px}
.product-info__price{font-size:1.5rem;font-weight:700;color:var(--text);margin-bottom:8px}
.product-info__fulfillment{font-size:13px;color:var(--faint);margin-bottom:20px;padding:6px 12px;background:var(--off);border-radius:99px;display:inline-block}

/* ── Variant pickers ── */
#variant-pickers{margin-bottom:16px}
.variant-section{margin-bottom:16px}
.variant-section__label{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--text);margin-bottom:8px}
.variant-swatches{display:flex;flex-wrap:wrap;gap:8px}
.variant-swatch--dot{width:38px;height:38px;border-radius:999px;border:2.5px solid var(--border);cursor:pointer;position:relative;display:flex;align-items:center;justify-content:center;transition:border-color .15s,transform .15s}
.variant-swatch--dot:hover{transform:scale(1.08)}
.variant-swatch--dot.active{border-color:var(--baltic-blue);transform:scale(1.12);box-shadow:0 0 0 3px rgba(0,10,190,.18)}
.variant-swatch--dot.dimmed{opacity:.35}
.variant-swatch__dot{width:26px;height:26px;border-radius:999px;display:block}
.variant-color-name{font-size:14px;font-weight:600;margin:6px 0 12px;min-height:20px}
.variant-sizes{display:flex;flex-wrap:wrap;gap:6px}
.variant-size{padding:8px 16px;border:1.5px solid var(--border);border-radius:var(--radius);font-size:14px;font-weight:600;cursor:pointer;background:var(--white);color:var(--text);font-family:inherit;transition:border-color .12s,background .12s}
.variant-size:hover{border-color:var(--baltic-blue)}
.variant-size.active{background:var(--text);color:var(--white);border-color:var(--text)}
.variant-loading{padding:12px 0;color:var(--faint);font-size:14px}

/* ── Add to cart ── */
.product-info__actions{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.product-info__qty{display:flex;align-items:center;gap:8px}
.product-info__qty label{font-size:13px;color:var(--muted);font-weight:600}
.product-info__qty input{width:64px;padding:10px;border:1.5px solid var(--border);border-radius:var(--radius);font-size:15px;font-family:inherit;text-align:center}
.btn-add-to-cart{flex:1;max-width:320px;padding:14px 28px;background:var(--cta-yellow);color:var(--black);border:2px solid var(--black);border-radius:var(--radius);font-size:16px;font-weight:700;cursor:pointer;font-family:var(--font-display);transition:background .15s}
.btn-add-to-cart:hover{background:var(--lime-moss)}
.btn-add-to-cart:disabled{opacity:.45;cursor:not-allowed}
.cart-feedback{padding:10px 14px;border-radius:var(--radius);font-size:14px;font-weight:600;margin-bottom:12px}
.cart-feedback[hidden]{display:none}
.cart-feedback--ok{background:#edf7f1;color:#2d7a4f;border:1px solid #b7e4c7}
.cart-feedback--err{background:#fef2f2;color:#a40000;border:1px solid #fca5a5}

/* ── Description ── */
.product-info__details{margin-top:16px;border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}
.product-info__details summary{padding:14px 16px;font-weight:700;font-size:15px;cursor:pointer;background:var(--off);list-style:none;display:flex;align-items:center;justify-content:space-between}
.product-info__details summary::after{content:'+';font-size:18px;font-weight:700;color:var(--faint)}
.product-info__details[open] summary::after{content:'−'}
.product-info__desc{padding:16px;font-size:14px;color:var(--muted);line-height:1.7}

/* ── Related products ── */
.related-products{padding:3rem 32px 0;max-width:var(--max-w);margin:0 auto}
.related-products__title{font-family:var(--font-display);font-size:1.25rem;font-weight:700;margin-bottom:1rem}
.related-products__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px}
.related-card{text-decoration:none;color:inherit;background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:border-color .15s,box-shadow .15s}
.related-card:hover{border-color:var(--baltic-blue);box-shadow:0 2px 12px rgba(0,0,0,.08)}
.related-card__thumb{height:160px;display:flex;align-items:center;justify-content:center;background:var(--off);overflow:hidden}
.related-card__thumb img{max-width:100%;max-height:100%;object-fit:contain}
.related-card__body{padding:10px 12px}
.related-card__title{font-size:13px;font-weight:600;line-height:1.3;margin-bottom:2px}
.related-card__price{font-size:12px;color:var(--muted)}

/* ── Footer ── */
footer{background:var(--black);padding:36px 48px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:12px;max-width:var(--max-w);margin:0 auto}
.footer-logo{font-family:var(--font-display);font-size:clamp(1rem,.94rem + .28vw,1.15rem);font-weight:700;color:var(--white);text-decoration:none}
.footer-logo span{color:var(--white)}
footer p{color:var(--white);margin:0;font-size:14px}
footer a{color:var(--white)}
.footer-links{display:flex;gap:24px;list-style:none;flex-wrap:wrap;justify-content:center;margin-top:8px}
.footer-links a{font-size:clamp(.875rem,.84rem + .14vw,.95rem);color:var(--white);text-decoration:none;font-weight:600}
.footer-links a:hover,.footer-links a:focus-visible{opacity:.9}

/* ── Design hero (design.php) ── */
.design-hero{display:grid;grid-template-columns:280px 1fr;gap:32px;padding:32px;align-items:center}
.design-hero__img{border-radius:var(--radius-lg);overflow:hidden;background:var(--off);display:flex;align-items:center;justify-content:center;aspect-ratio:1}
.design-hero__img img{max-width:100%;max-height:100%;object-fit:contain}
.design-hero h1{font-family:var(--font-display);font-size:clamp(1.5rem,3vw,2.2rem);font-weight:700;line-height:1.2;margin-bottom:8px}
.design-hero__sub{font-size:15px;color:var(--muted);font-weight:600;margin-bottom:6px}
.design-hero__details{font-size:14px;color:var(--faint);line-height:1.6}
.design-products{padding:0 32px 3rem}
.design-products__title{font-family:var(--font-display);font-size:1.15rem;font-weight:700;margin-bottom:16px}
.design-products__empty{color:var(--faint);font-size:14px}
.design-products__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px}

/* ── Responsive ── */
@media(max-width:900px){
  .product-layout{grid-template-columns:1fr;gap:24px;padding:20px 16px 0}
  .product-gallery__main{aspect-ratio:auto;min-height:280px;max-height:420px}
  .site-nav{padding:0 16px;min-height:52px}
  .site-links{display:none}
  .breadcrumbs{padding:10px 16px}
  .related-products{padding:2rem 16px 0}
  .design-hero{grid-template-columns:1fr;gap:20px;padding:20px 16px}
  .design-hero__img{max-width:200px;margin:0 auto}
  .design-products{padding:0 16px 2rem}
  footer{padding:26px 16px}
}
@media(max-width:480px){
  .product-info__actions{flex-direction:column;align-items:stretch}
  .btn-add-to-cart{max-width:none}
  .related-products__grid{grid-template-columns:repeat(2,1fr)}
}
