/* ===========================================================================
   Sky Pearl — main stylesheet. Mobile-first (base ~380px), min-width queries.
   =========================================================================== */

/* ----------------------------------------------------- base */
body{
  font-family:var(--font-sans);font-size:var(--text-base);line-height:1.6;
  color:var(--color-text);background:var(--color-bg);-webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--color-primary);text-decoration:none;transition:color var(--duration-fast) var(--ease)}
a:hover{color:var(--color-primary-hover)}
h1,h2,h3,h4{font-family:var(--font-display);color:var(--color-text);line-height:1.15;margin:0 0 .5em;font-weight:600}
h1{font-size:var(--text-3xl)}h2{font-size:var(--text-2xl)}h3{font-size:var(--text-xl)}
p{margin:0 0 1em}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 var(--space-5)}
.sr-only{position:absolute!important;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap}
:focus-visible{outline:3px solid var(--color-accent);outline-offset:2px}

/* ----------------------------------------------------- buttons */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  font-family:var(--font-sans);font-weight:600;font-size:var(--text-sm);line-height:1;
  min-height:46px;padding:0 var(--space-6);border:0;border-radius:var(--radius-pill);
  background:var(--color-primary);color:var(--color-text-inverse);cursor:pointer;
  transition:background var(--duration-fast) var(--ease),transform var(--duration-fast) var(--ease);
  text-align:center
}
.btn:hover{background:var(--color-primary-hover);color:#fff;transform:translateY(-1px)}
.btn--accent{background:var(--color-accent)}.btn--accent:hover{background:var(--color-accent-hover)}
.btn--ghost{background:transparent;color:var(--color-primary);box-shadow:inset 0 0 0 1.5px var(--color-primary)}
.btn--ghost:hover{background:var(--color-primary);color:#fff}
.btn--block{width:100%}
.btn--lg{min-height:52px;font-size:var(--text-base);padding:0 var(--space-8)}

/* ----------------------------------------------------- forms */
input[type=text],input[type=email],input[type=password],input[type=tel],input[type=number],
input[type=search],textarea,select,.input{
  width:100%;font-size:16px;font-family:var(--font-sans);color:var(--color-text);
  background:#fff;border:1px solid var(--color-border-strong);border-radius:var(--radius-md);
  padding:var(--space-3) var(--space-4);min-height:46px;transition:border-color var(--duration-fast) var(--ease)
}
input:focus,textarea:focus,select:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 3px rgba(32,27,111,.12)}
label{display:block;font-size:var(--text-sm);font-weight:600;margin-bottom:var(--space-2)}

/* ----------------------------------------------------- announcement bar */
.announce{background:var(--color-primary);color:#fff;font-size:var(--text-xs);letter-spacing:.02em}
.announce__inner{display:flex;align-items:center;justify-content:center;gap:var(--space-3);min-height:36px;text-align:center;position:relative}
.announce strong{color:var(--color-accent)}
.announce__close{position:absolute;right:var(--space-4);background:none;border:0;color:#fff;cursor:pointer;font-size:1.1rem;line-height:1;opacity:.8}
.announce__close:hover{opacity:1}
.announce.is-hidden{display:none}

/* ----------------------------------------------------- header */
.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.97);
  backdrop-filter:saturate(150%) blur(8px);border-bottom:1px solid var(--color-border);
  transition:box-shadow var(--duration-fast) var(--ease)}
/* keep sticky header below the WP admin bar when logged in */
body.admin-bar .site-header{top:32px}
@media screen and (max-width:782px){body.admin-bar .site-header{top:46px}}
.site-header.is-shrunk{box-shadow:var(--shadow-md)}
.header-inner{display:flex;align-items:center;gap:var(--space-4);min-height:var(--header-h);
  transition:min-height var(--duration-fast) var(--ease)}
.site-header.is-shrunk .header-inner{min-height:58px}
.brand{display:flex;align-items:center;flex:0 0 auto}
.brand img,.brand .custom-logo{max-height:44px!important;width:auto!important;height:auto!important;
  transition:max-height var(--duration-fast) var(--ease)}
.site-header.is-shrunk .brand img,.site-header.is-shrunk .brand .custom-logo{max-height:36px!important}
.brand-text{font-family:var(--font-display);font-weight:700;font-size:var(--text-xl);color:var(--color-primary)}
.brand-text span{color:var(--color-accent)}

.primary-nav{margin-left:var(--space-6);display:none}
.primary-nav ul{list-style:none;display:flex;gap:var(--space-2);margin:0;padding:0}
.primary-nav a{font-weight:500;font-size:var(--text-sm);color:var(--color-text);padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);display:block}
.primary-nav a:hover,.primary-nav .current-menu-item>a{color:var(--color-primary);background:var(--color-surface-alt)}

.header-actions{margin-left:auto;display:flex;align-items:center;gap:var(--space-2)}
.icon-btn{position:relative;display:inline-flex;align-items:center;justify-content:center;
  width:44px;height:44px;border-radius:50%;color:var(--color-primary);background:transparent;border:0;cursor:pointer}
.icon-btn:hover{background:var(--color-surface-alt);color:var(--color-primary)}
.icon-btn svg{width:21px;height:21px}
.cart-count{position:absolute;top:4px;right:3px;min-width:18px;height:18px;padding:0 4px;
  background:var(--color-accent);color:#fff;font-size:.66rem;font-weight:700;border-radius:var(--radius-pill);
  display:flex;align-items:center;justify-content:center}

/* header search (expand) */
.header-search{position:absolute;left:0;right:0;top:100%;background:#fff;border-bottom:1px solid var(--color-border);
  padding:var(--space-4) 0;box-shadow:var(--shadow-md);display:none;z-index:49}
.header-search.is-open{display:block}
.header-search form{display:flex;gap:var(--space-2);max-width:var(--wrap);margin:0 auto;padding:0 var(--space-5)}

/* ----------------------------------------------------- mobile drawer */
.drawer-overlay{position:fixed;inset:0;background:rgba(24,18,88,.45);opacity:0;visibility:hidden;transition:.25s;z-index:60}
.drawer-overlay.open{opacity:1;visibility:visible}
.drawer{position:fixed;top:0;right:-340px;width:320px;max-width:86vw;height:100%;background:#fff;z-index:61;
  transition:right var(--duration-slow) var(--ease);padding:var(--space-6);overflow-y:auto}
.drawer.open{right:0}
.drawer__head{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-4)}
.drawer__close{background:none;border:0;color:var(--color-primary);font-size:1.8rem;line-height:1;cursor:pointer}
.drawer ul{list-style:none;margin:0;padding:0}
.drawer a{display:block;padding:var(--space-3) 0;border-bottom:1px solid var(--color-border);color:var(--color-text);font-weight:500}

/* ----------------------------------------------------- hero */
.hero{position:relative;background:var(--color-surface-alt)}
.hero__media{position:relative;aspect-ratio:4/3;overflow:hidden}
.hero__media img{width:100%;height:100%;object-fit:cover}
.hero__panel{padding:var(--space-10) var(--space-5)}
.hero__eyebrow{font-size:var(--text-xs);font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--color-accent-hover);margin-bottom:var(--space-3)}
.hero h1{font-size:var(--text-5xl);margin-bottom:var(--space-3)}
.hero h1 em{font-style:italic;color:var(--color-primary)}
.hero p{color:var(--color-text-muted);font-size:var(--text-lg);max-width:46ch;margin-bottom:var(--space-6)}

/* ----------------------------------------------------- sections */
.section{padding:var(--space-16) 0}
.section--alt{background:var(--color-surface-alt)}
.section-head{text-align:center;max-width:640px;margin:0 auto var(--space-10)}
.section-head .eyebrow{font-size:var(--text-xs);font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--color-accent-hover)}
.section-head h2{margin:var(--space-2) 0}
.section-head p{color:var(--color-text-muted);margin:0}

/* category tiles */
.cat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-5)}
.cat-card{display:flex;flex-direction:column;align-items:center;gap:var(--space-3);text-align:center}
.cat-card__media{width:100%;aspect-ratio:1/1;border-radius:var(--radius-lg);overflow:hidden;background:#fff;box-shadow:var(--shadow-sm)}
.cat-card__media img{width:100%;height:100%;object-fit:cover;transition:transform var(--duration-slow) var(--ease)}
.cat-card:hover .cat-card__media img{transform:scale(1.05)}
.cat-card span{font-family:var(--font-display);font-weight:600;font-size:var(--text-lg);color:var(--color-text)}

/* brand story strip */
.story{display:grid;gap:var(--space-8);align-items:center}
.story__media{border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:4/3}
.story__media img{width:100%;height:100%;object-fit:cover}
.story h2{font-size:var(--text-3xl)}

/* trust strip */
.trust{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-6)}
.trust__item{display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--space-2)}
.trust__item svg{width:30px;height:30px;color:var(--color-primary)}
.trust__item b{font-size:var(--text-sm);font-family:var(--font-sans)}
.trust__item small{color:var(--color-text-muted);font-size:var(--text-xs)}

/* newsletter band */
.news-band{background:var(--color-surface-deep);color:#fff;border-radius:var(--radius-lg);padding:var(--space-12) var(--space-6);text-align:center}
.news-band h2{color:#fff}
.news-band p{color:rgba(255,255,255,.82);max-width:46ch;margin:0 auto var(--space-6)}
.news-form{display:flex;gap:var(--space-2);max-width:440px;margin:0 auto}
.news-form input{flex:1}
.news-form__msg{margin-top:var(--space-3);font-size:var(--text-sm);min-height:1.2em}

/* ----------------------------------------------------- product card (shared) */
.product-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-5)}
.card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--color-border);
  border-radius:var(--radius-lg);overflow:hidden;transition:box-shadow var(--duration-fast) var(--ease),transform var(--duration-fast) var(--ease)}
.card:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px)}
.card__media{position:relative;aspect-ratio:4/5;overflow:hidden;display:block;
  background:radial-gradient(120% 90% at 50% 18%,#ffffff 0%,#f4f1ec 100%)}
.card__media img{width:100%;height:100%;object-fit:cover;display:block;
  filter:drop-shadow(0 10px 14px rgba(24,18,88,.14));transition:transform var(--duration-slow) var(--ease)}
.card:hover .card__media img{transform:scale(1.04)}
.card__media::after{content:"";position:absolute;inset:0;pointer-events:none;
  box-shadow:inset 0 0 0 1px rgba(24,18,88,.05),inset 0 -40px 40px -30px rgba(24,18,88,.10)}
.card__badges{position:absolute;top:var(--space-3);left:var(--space-3);display:flex;flex-direction:column;gap:var(--space-1);z-index:2}
.badge{font-size:var(--text-xs);font-weight:700;padding:.3em .7em;border-radius:var(--radius-pill);line-height:1}
.badge--sale{background:var(--color-sale);color:#fff}
.badge--new{background:var(--color-primary);color:#fff}
.badge--best{background:var(--color-accent);color:#fff}
.badge--low{background:var(--color-sale-bg);color:var(--color-warning)}
.badge--out{background:var(--color-surface-alt);color:var(--color-stock-out)}
.card__body{display:flex;flex-direction:column;gap:var(--space-1);padding:var(--space-4);flex:1}
.card__cat{font-size:var(--text-xs);letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-muted)}
.card__title{font-family:var(--font-sans);font-size:var(--text-sm);font-weight:600;margin:0;line-height:1.35}
.card__title a{color:var(--color-text)}.card__title a:hover{color:var(--color-primary)}
.price{font-family:var(--price-font);font-weight:700;color:var(--color-text)}
.price del{color:var(--color-text-muted);font-weight:400;margin-right:.4em}
.price ins{color:var(--color-sale);text-decoration:none}
.card__foot{margin-top:auto;padding:0 var(--space-4) var(--space-4)}
.card .btn{width:100%}

/* ----------------------------------------------------- breadcrumb + page header */
.page-hero{background:var(--color-surface-alt);padding:var(--space-10) 0;text-align:center;border-bottom:1px solid var(--color-border)}
.page-hero h1{margin:0}
.breadcrumb{font-size:var(--text-sm);color:var(--color-text-muted);margin-bottom:var(--space-3)}
.breadcrumb a{color:var(--color-text-muted)}.breadcrumb a:hover{color:var(--color-primary)}

/* ----------------------------------------------------- accordion */
.accordion__item{border-bottom:1px solid var(--color-border)}
.accordion__btn{width:100%;display:flex;justify-content:space-between;align-items:center;gap:var(--space-3);
  background:none;border:0;padding:var(--space-4) 0;font-family:var(--font-sans);font-size:var(--text-base);
  font-weight:600;color:var(--color-text);cursor:pointer;text-align:left}
.accordion__btn::after{content:"+";font-size:1.4rem;color:var(--color-primary);transition:transform var(--duration-fast)}
.accordion__btn[aria-expanded=true]::after{content:"–"}
.accordion__panel{display:none;padding:0 0 var(--space-4);color:var(--color-text-muted)}
.accordion__panel.is-open{display:block}

/* ----------------------------------------------------- content prose */
.prose{max-width:760px;margin:0 auto}
.prose h2{margin-top:var(--space-8)}
.prose img{border-radius:var(--radius-md);margin:var(--space-4) 0}

/* ----------------------------------------------------- 404 */
.notfound{text-align:center;padding:var(--space-24) 0}
.notfound .code{font-family:var(--font-display);font-size:var(--text-5xl);color:var(--color-primary)}

/* ----------------------------------------------------- footer */
.site-footer{background:var(--color-surface-deep);color:#cfcbe6;padding:var(--space-16) 0 0;font-size:var(--text-sm)}
.footer-cols{display:grid;grid-template-columns:1fr;gap:var(--space-2)}
.footer-col{border-bottom:1px solid rgba(255,255,255,.12)}
.footer-col__head{display:flex;justify-content:space-between;align-items:center;width:100%;background:none;border:0;
  color:#fff;font-family:var(--font-display);font-size:var(--text-lg);padding:var(--space-4) 0;cursor:pointer;text-align:left}
.footer-col__head::after{content:"+";color:var(--color-accent);font-size:1.3rem}
.footer-col__head[aria-expanded=true]::after{content:"–"}
.footer-col__body{display:none;padding-bottom:var(--space-4)}
.footer-col__body.is-open{display:block}
.footer-col ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--space-3)}
.site-footer a{color:#cfcbe6}.site-footer a:hover{color:#fff}
.foot-brand img{max-height:58px;width:auto;height:auto;margin-bottom:var(--space-4);filter:brightness(0) invert(1)}
.foot-brand p{color:#a8a4c8;max-width:34ch}
.foot-social{display:flex;gap:var(--space-3);margin-top:var(--space-4)}
.foot-social a{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center}
.foot-social a:hover{background:var(--color-accent)}
.foot-social svg{width:18px;height:18px}
.footer-pay{display:flex;flex-wrap:wrap;gap:var(--space-2);align-items:center;justify-content:center;padding:var(--space-6) 0;border-top:1px solid rgba(255,255,255,.12);margin-top:var(--space-8)}
.footer-pay span{background:#fff;color:var(--color-text);font-weight:700;font-size:.7rem;padding:.3em .6em;border-radius:var(--radius-sm)}
.footer-bottom{text-align:center;color:#a8a4c8;font-size:var(--text-xs);padding-bottom:var(--space-8)}

/* ===========================================================================
   Breakpoints (min-width, mobile-first)
   =========================================================================== */
@media(min-width:600px){
  .cat-grid{grid-template-columns:repeat(3,1fr)}
  .product-grid{grid-template-columns:repeat(3,1fr)}
  .trust{grid-template-columns:repeat(4,1fr)}
  .news-form{gap:var(--space-3)}
}
@media(min-width:768px){
  .primary-nav{display:block}
  .nav-toggle{display:none}
  .hero{display:grid;grid-template-columns:1.05fr .95fr;align-items:center}
  .hero__media{aspect-ratio:auto;height:100%;min-height:460px}
  .hero__panel{padding:var(--space-24) var(--space-12)}
  .story{grid-template-columns:1fr 1fr}
  .cat-grid{grid-template-columns:repeat(4,1fr)}
  .footer-cols{grid-template-columns:1.6fr 1fr 1fr 1.4fr;gap:var(--space-8)}
  .footer-col{border-bottom:0}
  .footer-col__head{cursor:default;pointer-events:none;padding-top:0}
  .footer-col__head::after{display:none}
  .footer-col__body{display:block!important}
}
@media(min-width:1024px){
  .product-grid{grid-template-columns:repeat(4,1fr)}
  .product-grid--3{grid-template-columns:repeat(3,1fr)}
}
