
/* Preload critical fonts and optimize */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

/* Improved focus styles for better accessibility */
a:focus-visible, button:focus-visible{outline:3px solid var(--accent);outline-offset:3px;border-radius:3px}

:root{
  --bg:#faf7f2;
  --ink:#222;
  --muted:#5c5c5c;
  --accent:#b27a01; /* honey-gold */
  --card:#ffffff;
  --border:#e6e2da;
  --shadow: 0 6px 24px rgba(0,0,0,.06);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Inter,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--ink);}
a{color:var(--accent);text-decoration:none}
a:focus-visible, button:focus-visible{outline:3px solid var(--accent);outline-offset:3px;border-radius:3px}
.skip-link{position:absolute;left:-999px;top:0;background:var(--accent);color:#fff;padding:10px 14px;border-radius:0 0 6px 6px;font-weight:700;z-index:999}
.skip-link:focus{left:8px}
.visually-hidden{position:absolute !important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}
header{position:sticky;top:0;background:var(--card);box-shadow:var(--shadow);z-index:50}
.container{max-width:1100px;margin:0 auto;padding:0 20px}
.nav{display:flex;align-items:center;gap:24px;padding:12px 0}
.nav img{height:56px;width:auto}
.nav a{font-weight:600;color:var(--ink)}
.nav .spacer{flex:1}
.nav .links{display:flex;align-items:center;gap:24px;flex:1;flex-wrap:wrap}
.nav-toggle{display:none;background:var(--accent);color:#fff;border:none;font-size:20px;line-height:1;border-radius:8px;padding:10px 14px;cursor:pointer;font-weight:700}
.contact-btn{margin-left:auto}

/* Hero with background image */
.hero-img{
  position:relative;
  min-height:52vh;
  display:flex;
  align-items:center;
  background-size:cover;
  background-position:center;
}
.hero-overlay{
  position:absolute;inset:0;background:linear-gradient( to right, rgba(0,0,0,.55), rgba(0,0,0,.25), rgba(0,0,0,.15) );
}
.hero-content{
  position:relative;
  color:#fff;
  padding:48px 0;
}
.hero-content h1{font-size:40px;line-height:1.1;margin:0 0 10px}
.hero-content p{opacity:.95;font-size:18px;margin:0 0 16px}

.btn{display:inline-block;padding:12px 16px;border-radius:10px;background:var(--accent);color:white;font-weight:700}
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.card{background:var(--card);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow);overflow:hidden}
.card img{width:100%;height:220px;object-fit:cover;background:#ddd;transition:transform .4s ease}
.card:hover img{transform:scale(1.04)}
.card .pad{padding:14px}
.badge{display:inline-block;background:#f2efe6;color:#8a6a20;font-weight:700;font-size:12px;padding:4px 8px;border-radius:999px;margin-right:8px}
.price{font-weight:800}
footer{margin-top:48px;padding:28px 0;border-top:1px solid var(--border);color:var(--muted);}
.section{padding:36px 0}
.kicker{letter-spacing:.12em;text-transform:uppercase;font-size:12px;color:var(--muted);font-weight:700}
table{width:100%;border-collapse:collapse}
td,th{padding:10px;border-bottom:1px solid var(--border);text-align:left}
.gallery{columns:3 240px;column-gap:14px}
.gallery img{width:100%;margin:0 0 14px;border-radius:12px;box-shadow:var(--shadow)}
.notice{padding:12px 14px;background:#fffdea;border:1px solid #f1e6a4;border-radius:12px}
.small{font-size:13px;color:var(--muted)}

/* Keep stock line and low stock badge for current soap grid */
.stock-line{color:var(--ink);background:#f8f5ee;padding:4px 8px;border-radius:8px;display:inline-block;margin-top:6px}

/* Simple responsive soap grid (auto-fit 240px -> 2 or 3 wide) */
.soap-cards-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;align-items:stretch}
.soap-cell{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:14px 14px 16px;box-shadow:var(--shadow);display:flex;flex-direction:column;align-items:flex-start;position:relative;min-height:100%}
.soap-cell-img-wrap{width:100%;aspect-ratio:1/1;border-radius:12px;overflow:hidden;background:#eee;margin:0 0 10px}
.soap-cell-img-wrap img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s ease}
.soap-cell:hover .soap-cell-img-wrap img{transform:scale(1.05)}
.soap-cell-name{font-weight:600;font-size:16px;line-height:1.25;margin:0 0 4px}
.soap-cell-scent{margin:0 0 8px;min-height:32px}
.soap-cell-meta{background:#f8f5ee;padding:6px 10px;border-radius:10px;margin-top:auto}
.soap-cell.coming-soon{background:linear-gradient(135deg,#fff8e1,#ffffff);border-color:#f1c232;position:relative}
.soap-cell.coming-soon::before{content:"New";position:absolute;top:8px;right:8px;background:#f1c232;color:#7a5900;font-size:10px;font-weight:700;padding:4px 8px;border-radius:12px;letter-spacing:.5px;text-transform:uppercase}
.soap-cell.coming-soon .soap-cell-img-wrap{position:relative}
.soap-cell.coming-soon .soap-cell-img-wrap::after{content:"";position:absolute;inset:0;background:rgba(241,194,50,.15);border-radius:12px}
.low-stock-pill{display:inline-block;background:#ffe1e1;color:#b30000;font-weight:700;font-size:10px;padding:3px 6px;border-radius:999px;letter-spacing:.5px;margin-left:6px}
 .bundle-note{color:var(--muted);font-weight:500;margin-left:4px}
@media (max-width:560px){
  .soap-cell{padding:12px}
}

@media (max-width:900px){
  .grid{grid-template-columns:1fr 1fr}
  .hero-content h1{font-size:34px}
}
@media (max-width:600px){
  .grid{grid-template-columns:1fr}
  .hero-content h1{font-size:28px}
}

/* Mobile navigation */
@media (max-width:820px){
  .nav{flex-wrap:wrap}
  .nav-toggle{display:inline-block;margin-left:auto}
  .nav .links{flex-basis:100%;order:3;display:none;flex-direction:column;align-items:stretch;gap:12px;padding:12px 0}
  .nav .links a{display:block}
  .nav .links.open{display:flex}
  .contact-btn{margin-left:0}
}

@media (max-width:520px){
  .nav img{height:48px}
  .btn{padding:10px 14px;font-size:14px}
  .hero-content{padding:40px 0}
  .hero-content p{font-size:16px}
  .gallery{columns:1 180px}
}
