/* =========================================================
   Prime Keychains - Premium white + gold/black theme
   ========================================================= */

:root{
  --bg:          #ffffff;
  --bg-alt:      #faf7f1;
  --ink:         #111111;
  --ink-soft:    #3a3a3a;
  --muted:       #7a7a7a;
  --line:        #ece7dc;
  --gold:        #c9a24a;
  --gold-deep:   #a88233;
  --gold-soft:   #f2e6c8;
  --black:       #0b0b0b;
  --radius:      14px;
  --radius-lg:   22px;
  --shadow-sm:   0 1px 2px rgba(17,17,17,.04), 0 1px 1px rgba(17,17,17,.03);
  --shadow-md:   0 10px 30px rgba(17,17,17,.07), 0 2px 6px rgba(17,17,17,.04);
  --shadow-lg:   0 24px 60px rgba(17,17,17,.12);
  --ease:        cubic-bezier(.2,.7,.2,1);
  --serif:       "Cormorant Garamond", Georgia, serif;
  --sans:        "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:var(--sans);
  font-size:16px;line-height:1.6;
  color:var(--ink);background:var(--bg);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none;transition:color .2s var(--ease)}
a:hover{color:var(--gold-deep)}
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;line-height:1.15;margin:0 0 .6rem;color:var(--ink)}
h1{font-size:clamp(2.1rem,4.4vw,3.4rem);letter-spacing:-.01em}
h2{font-size:clamp(1.7rem,3vw,2.4rem);letter-spacing:-.005em}
h3{font-size:1.25rem}
h4{font-size:1.05rem;font-family:var(--sans);font-weight:600}
p{margin:0 0 1rem}
ul.plain{list-style:none;padding:0;margin:0}
ul.plain li{margin:.4rem 0}
.muted{color:var(--muted)}
.small{font-size:.875rem}
.center{text-align:center}

/* ---------- Layout ---------- */
.container{max-width:1180px;margin:0 auto;padding:0 1.25rem}
.section{padding:4rem 0}
.section-alt{background:var(--bg-alt)}
.section-head{max-width:720px;margin:0 auto 2.4rem;text-align:center}
.section-head .muted{margin-top:.4rem}

.eyebrow{
  display:inline-block;
  font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold-deep);font-weight:600;margin-bottom:.8rem;
}
.pill{
  display:inline-block;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink-soft);background:var(--bg-alt);
  border:1px solid var(--line);border-radius:999px;padding:.25rem .65rem;
}

.grid{display:grid;gap:1.5rem}
.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}
@media (max-width:960px){ .grid-3,.grid-4{grid-template-columns:repeat(2,1fr)} }
@media (max-width:560px){ .grid-2,.grid-3,.grid-4{grid-template-columns:1fr} }

/* ---------- Header ---------- */
.site-header{
  position:sticky;top:0;z-index:40;
  background:rgba(255,255,255,.92);
  backdrop-filter:saturate(180%) blur(10px);
  border-bottom:1px solid var(--line);
}
.site-header .nav{display:flex;align-items:center;justify-content:space-between;padding:.9rem 1.25rem}

.brand{display:inline-flex;align-items:center;gap:.65rem}
.brand-mark{
  width:42px;height:42px;border-radius:50%;
  background:linear-gradient(140deg,#1a1a1a,#2b2b2b 65%,#000);
  color:var(--gold);display:grid;place-items:center;
  font-family:var(--serif);font-weight:700;font-size:1.15rem;letter-spacing:.02em;
  box-shadow:0 0 0 1px var(--gold) inset, 0 4px 14px rgba(0,0,0,.15);
}
.brand-text{display:flex;flex-direction:column;line-height:1.05}
.brand-text strong{font-family:var(--serif);font-size:1.18rem;letter-spacing:.02em}
.brand-text em{font-style:normal;font-size:.72rem;letter-spacing:.2em;color:var(--muted);text-transform:uppercase}

.nav-menu{display:flex;align-items:center;gap:1.6rem}
.nav-menu a{font-weight:500;color:var(--ink-soft)}
.nav-menu a:hover{color:var(--ink)}
.nav-menu a.btn{color:#111}

.nav-toggle{
  display:none;background:transparent;border:0;padding:.4rem;cursor:pointer;
}
.nav-toggle span{display:block;width:24px;height:2px;background:var(--ink);margin:5px 0;border-radius:2px;transition:.2s var(--ease)}

@media (max-width:820px){
  .nav-toggle{display:block}
  .nav-menu{
    position:absolute;top:100%;left:0;right:0;
    background:#fff;border-bottom:1px solid var(--line);
    flex-direction:column;align-items:stretch;gap:0;
    padding:.5rem 1.25rem 1rem;
    transform:translateY(-8px);opacity:0;pointer-events:none;
    transition:.18s var(--ease);
  }
  .nav-menu a{padding:.7rem 0;border-bottom:1px solid var(--line)}
  .nav-menu a:last-child{border:0}
  .site-header.open .nav-menu{transform:none;opacity:1;pointer-events:auto}
}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.45rem;
  font-weight:600;font-size:.95rem;line-height:1;letter-spacing:.02em;
  padding:.85rem 1.25rem;border-radius:999px;
  border:1px solid transparent;cursor:pointer;
  transition:transform .15s var(--ease), box-shadow .2s var(--ease), background .2s, color .2s, border-color .2s;
}
.btn-sm{padding:.6rem .9rem;font-size:.85rem}
.btn-block{width:100%}
.btn-gold{
  background:linear-gradient(135deg,var(--gold) 0%,var(--gold-deep) 100%);
  color:#1a1306;box-shadow:0 6px 18px rgba(201,162,74,.32);
}
.btn-gold:hover{transform:translateY(-1px);box-shadow:0 10px 22px rgba(201,162,74,.4);color:#1a1306}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:#fff}
.btn-danger{background:#fff;color:#b02828;border-color:#e9c7c7}
.btn-danger:hover{background:#b02828;color:#fff;border-color:#b02828}

/* ---------- Hero ---------- */
.hero{position:relative;overflow:hidden;isolation:isolate}
.hero-bg{
  position:absolute;inset:0;z-index:-1;
  background:
    radial-gradient(1000px 500px at 85% -10%, rgba(201,162,74,.18), transparent 60%),
    radial-gradient(800px 400px at -10% 110%, rgba(201,162,74,.12), transparent 60%),
    linear-gradient(180deg,#fffdf8 0%,#ffffff 70%);
}
.hero-inner{padding:5rem 0 4.5rem;text-align:center}
.hero h1{margin-top:.4rem}
.hero .gold{
  background:linear-gradient(135deg,var(--gold-deep),var(--gold));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.hero .lead{max-width:640px;margin:1.2rem auto 1.8rem;font-size:1.1rem;color:var(--ink-soft)}
.hero-actions{display:flex;flex-wrap:wrap;gap:.8rem;justify-content:center}

/* ---------- Category cards ---------- */
.cat-card{
  position:relative;display:block;overflow:hidden;
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:2.2rem 1.6rem;min-height:180px;
  transition:transform .25s var(--ease), box-shadow .25s var(--ease), border-color .25s;
}
.cat-card::before{
  content:"";position:absolute;inset:auto -30% -60% auto;width:260px;height:260px;
  background:radial-gradient(circle,var(--gold-soft),transparent 60%);
  opacity:0;transition:opacity .3s var(--ease);
}
.cat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--gold)}
.cat-card:hover::before{opacity:1}
.cat-card-body{position:relative;z-index:1}
.cat-card h3{font-size:1.6rem;margin:.25rem 0 .6rem}

/* Category card with image */
.cat-card.has-media{padding:0;display:flex;flex-direction:column;min-height:0}
.cat-card.has-media::before{display:none}
.cat-card-media{
  aspect-ratio:4/3;overflow:hidden;background:var(--bg-alt);
  position:relative;
}
.cat-card-media::after{
  content:"";position:absolute;inset:0;z-index:2;
  background:linear-gradient(180deg,rgba(0,0,0,0) 55%,rgba(0,0,0,.35) 100%);
  pointer-events:none;
}
.cat-card-media img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  opacity:0;
  transition:opacity .2s var(--ease), transform .6s var(--ease);
}
.cat-card-media img.is-active{opacity:1}
.cat-card.has-media:hover .cat-card-media img.is-active{transform:scale(1.05)}
.cat-card.has-media .cat-card-body{padding:1.4rem 1.6rem 1.7rem}

/* Hint that the card has a hover-cycling gallery (small dot counter) */
.cat-card.has-hover-gallery .cat-card-media::before{
  content:"";position:absolute;z-index:3;
  top:.7rem;right:.7rem;width:8px;height:8px;border-radius:50%;
  background:var(--gold);box-shadow:0 0 0 4px rgba(255,255,255,.7);
}
.link-arrow{display:inline-block;margin-top:.9rem;font-weight:600;color:var(--gold-deep)}
.link-arrow::after{content:"";display:inline-block;margin-left:.25rem;transition:transform .2s var(--ease)}
.cat-card:hover .link-arrow::after{transform:translateX(3px)}

/* ---------- Product cards ---------- */
.product-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;display:flex;flex-direction:column;
  transition:transform .25s var(--ease), box-shadow .25s var(--ease), border-color .25s;
}
.product-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--gold)}
.product-media{
  position:relative;
  display:block;aspect-ratio:1/1;overflow:hidden;background:var(--bg-alt);
}
.product-media img{
  position:absolute;inset:0;
  width:100%;height:100%;object-fit:cover;
  opacity:0;
  transition:opacity .2s var(--ease), transform .5s var(--ease);
}
.product-media img.is-active{opacity:1}
.product-card:hover .product-media img.is-active{transform:scale(1.04)}

/* Visual hint that a card has a hover-cycling gallery */
.product-card.has-hover-gallery .product-media::before{
  content:"";position:absolute;z-index:3;
  top:.7rem;right:.7rem;width:8px;height:8px;border-radius:50%;
  background:var(--gold);box-shadow:0 0 0 4px rgba(255,255,255,.7);
}
.product-body{padding:1rem 1.1rem 1.2rem;display:flex;flex-direction:column;gap:.6rem;flex:1}
.product-body h3{font-size:1.08rem;margin:0}
.product-body h3 a:hover{color:var(--gold-deep)}
.product-body .btn{margin-top:auto}

/* ---------- Page head ---------- */
.page-head{
  background:linear-gradient(180deg,#fffdf8,#fff);
  border-bottom:1px solid var(--line);
  padding:3.2rem 0 2.4rem;text-align:center;
}
.breadcrumbs{font-size:.85rem;color:var(--muted);margin-bottom:.6rem}
.breadcrumbs a:hover{color:var(--gold-deep)}
.breadcrumbs span{color:var(--ink)}

/* ---------- Product detail ---------- */
.product-detail{
  display:grid;grid-template-columns:1.05fr 1fr;gap:2.4rem;
  padding:1rem 0 1rem;
}
@media (max-width:860px){.product-detail{grid-template-columns:1fr}}

/* Gallery: vertical thumb strip + main image */
.product-gallery{
  display:grid;grid-template-columns:80px 1fr;gap:1rem;align-items:start;
}
.gallery-thumbs{
  display:flex;flex-direction:column;gap:.6rem;
  max-height:560px;overflow-y:auto;padding-right:.2rem;
  scrollbar-width:thin;
}
.gallery-thumbs::-webkit-scrollbar{width:6px}
.gallery-thumbs::-webkit-scrollbar-thumb{background:var(--line);border-radius:3px}
.thumb-btn{
  padding:0;border:1px solid var(--line);background:#fff;
  border-radius:10px;overflow:hidden;cursor:pointer;
  aspect-ratio:1/1;transition:border-color .2s var(--ease), transform .15s var(--ease), box-shadow .2s var(--ease);
}
.thumb-btn img{width:100%;height:100%;object-fit:cover;display:block}
.thumb-btn:hover{border-color:var(--gold);transform:translateY(-1px)}
.thumb-btn.is-active{border-color:var(--gold);box-shadow:0 0 0 2px rgba(201,162,74,.25)}
.gallery-main{
  border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;
  background:var(--bg-alt);aspect-ratio:1/1;
}
.gallery-main img{
  width:100%;height:100%;object-fit:cover;
  transition:opacity .25s var(--ease);
}
@media (max-width:640px){
  .product-gallery{grid-template-columns:1fr}
  .gallery-thumbs{
    flex-direction:row;overflow-x:auto;overflow-y:hidden;max-height:none;
    order:2;padding:.2rem 0;
  }
  .thumb-btn{flex:0 0 72px}
  .gallery-main{order:1}
}

/* Old fallback class kept so nothing breaks if referenced elsewhere */
.product-detail-media{border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;background:var(--bg-alt);aspect-ratio:1/1}
.product-detail-media img{width:100%;height:100%;object-fit:cover}
.product-detail-info h1{margin-top:.4rem}
.product-detail-info .hero-actions{justify-content:flex-start;margin:1.2rem 0}
.meta-list{list-style:none;padding:0;margin:1rem 0 0;border-top:1px dashed var(--line)}
.meta-list li{padding:.7rem 0;border-bottom:1px dashed var(--line)}
.prose{color:var(--ink-soft);font-size:1.02rem}
.prose p{margin:0 0 .9rem}
.prose-container{max-width:780px;margin:0 auto}

/* ---------- Trust / stats ---------- */
.trust-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
@media (max-width:720px){.trust-grid{grid-template-columns:1fr}}
.trust{text-align:center;padding:2rem 1rem;border:1px solid var(--line);border-radius:var(--radius-lg);background:#fff}
.trust-num{font-family:var(--serif);font-size:2.4rem;color:var(--gold-deep);margin-bottom:.3rem}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:2rem}
@media (max-width:860px){.contact-grid{grid-template-columns:1fr}}
.contact-info,.contact-form{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:2rem;
}
.contact-list li{padding:.6rem 0;border-bottom:1px dashed var(--line)}
.contact-list li:last-child{border:0}

/* ---------- Forms ---------- */
.form label{display:block;margin:0 0 1rem;font-weight:500;color:var(--ink-soft);font-size:.9rem}
.form input[type="text"],
.form input[type="email"],
.form input[type="password"],
.form input[type="file"],
.form select,
.form textarea{
  width:100%;margin-top:.35rem;padding:.75rem .9rem;
  font:inherit;color:var(--ink);background:#fff;
  border:1px solid var(--line);border-radius:10px;
  transition:border-color .2s, box-shadow .2s;
}
.form input:focus,.form select:focus,.form textarea:focus{
  outline:0;border-color:var(--gold);box-shadow:0 0 0 3px rgba(201,162,74,.18);
}
.form textarea{resize:vertical;min-height:110px}
.form-actions{display:flex;gap:.6rem;flex-wrap:wrap;margin-top:.5rem}
.form-inline{display:flex;gap:1rem;align-items:flex-end;flex-wrap:wrap}
.form-inline .grow{flex:1 1 260px}

.alert{
  border-radius:10px;padding:.8rem 1rem;margin:0 0 1rem;
  border:1px solid transparent;font-size:.92rem;
}
.alert-success{background:#f1faf1;border-color:#cce6cc;color:#1f6b33}
.alert-error  {background:#fdf2f2;border-color:#f2c7c7;color:#9a1f1f}
.alert-info   {background:#f4f6fb;border-color:#d4dcee;color:#284786}

/* ---------- Footer ---------- */
.site-footer{margin-top:4rem;background:#0b0b0b;color:#d9d4c8}
.site-footer .brand-text strong{color:#fff}
.site-footer .brand-text em{color:#999}
.site-footer a{color:#d9d4c8}
.site-footer a:hover{color:var(--gold)}
.site-footer h4{color:#fff;margin-bottom:.8rem;font-family:var(--sans);letter-spacing:.02em}
.footer-grid{
  display:grid;grid-template-columns:1.3fr 1fr 1fr;gap:2.5rem;
  padding:3rem 1.25rem 2rem;
}
@media (max-width:720px){.footer-grid{grid-template-columns:1fr}}
.footer-bottom{border-top:1px solid #1e1e1e;padding:1rem 0;font-size:.85rem;color:#8a8a8a}

/* ---------- Utility ---------- */
.right{text-align:right}
code{background:#f5efe1;padding:.08rem .4rem;border-radius:5px;font-size:.85em;color:#6a4b0f}
