@font-face {
  font-family: 'SummerStarshine';
  src: url('fonts/SummerStarshine.ttf') format('truetype');
  font-weight: normal;
  font-style: normal;
}

@import url('https://fonts.googleapis.com/css2?family=Kanit:wght@900&display=swap');
:root{
  --bg:#f7f7f8; --text:#111; --card-bg:#fff; --card-outline:#e6e9ee; --accent:#1652a6; --accent-gradient: linear-gradient(135deg,#1e66d0,#0d3a78); --shadow: 0 6px 18px rgba(18,24,40,0.08); --filter-bg:#fff; --filter-text:#111; --share-border:#d0d6dd; --hero-dark: linear-gradient(135deg,#0b1220,#0f1624);
}
[data-theme="dark"]{ --bg:#0b0b0d; --text:#eeeeee; --card-bg:#0f1113; --card-outline:#2a2f3a; --accent:#6ea8ff; --accent-gradient: linear-gradient(135deg,#6ea8ff,#3a6fcf); --shadow: 0 8px 20px rgba(0,0,0,0.6); --filter-bg:#17181a; --filter-text:#eaeaea; --share-border:#3a3f47; --hero-dark: linear-gradient(135deg,#071020,#0b1626); }
*{box-sizing:border-box} body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial;background:var(--bg);color:var(--text);min-height:100vh;transition:background .25s,color .25s}
.site-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;gap:12px;border-bottom:1px solid var(--card-outline);background:var(--card-bg);position:sticky;top:0;z-index:60}
.logo{height:44px;width:auto}.header-right button{background:transparent;border:0;font-size:1.2rem;cursor:pointer;padding:8px;border-radius:8px}
.hero{padding:28px 16px;text-align:center;background:var(--accent-gradient);color:#fff;border-bottom:1px solid var(--card-outline)}[data-theme="dark"] .hero{background:var(--hero-dark)} .hero h2{margin:0 0 8px;font-size:2rem}.cta{display:inline-block;padding:10px 16px;border-radius:10px;background:#fff;color:var(--accent);text-decoration:none;font-weight:600}
.controls{display:flex;gap:10px;padding:14px;flex-wrap:wrap;align-items:center;justify-content:center}.controls input,.controls select{padding:10px;border-radius:10px;border:1px solid var(--card-outline);background:var(--filter-bg);color:var(--filter-text);min-width:150px;transition:box-shadow .15s,border-color .15s}.controls input:focus,.controls select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 4px rgba(22,82,166,0.12)}
.products-grid{display:grid;gap:18px;padding:18px;grid-template-columns:repeat(1,1fr)}@media(min-width:640px){.products-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:980px){.products-grid{grid-template-columns:repeat(3,1fr)}}
.card{background:var(--card-bg);border-radius:12px;border:1px solid var(--card-outline);box-shadow:var(--shadow);overflow:hidden;display:flex;flex-direction:column;transition:transform .18s,box-shadow .18s}.card:hover{transform:translateY(-6px);box-shadow:0 18px 30px rgba(0,0,0,0.12)}.card .img-wrap{background:var(--card-outline);padding:12px}.card img{width:100%;height:340px;max-height:45vh;object-fit:contain;background:var(--card-outline);padding:12px;display:block;margin:0 auto}.card .card-body{padding:12px;display:flex;flex-direction:column;gap:8px}.card .meta{font-size:.9rem;color:var(--text);opacity:.85}.price{font-weight:700;color:var(--accent)}.card .actions{display:flex;gap:8px;padding:12px;border-top:1px solid var(--card-outline);background:transparent}.btn{flex:1;padding:10px;border-radius:10px;border:0;cursor:pointer;transition:transform .12s}.btn:hover{transform:translateY(-2px)}.btn-cta{background:var(--accent-gradient);color:white;font-weight:600}.btn-share{background:transparent;border:1px solid var(--share-border);color:var(--filter-text)}[data-theme="dark"] .btn-share{border:1px solid var(--share-border); color:var(--filter-text); background:transparent}
.lightbox{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,0.75);z-index:1100;visibility:hidden;opacity:0;transition:opacity .15s}.lightbox[aria-hidden="false"]{visibility:visible;opacity:1}.lb-content img{max-width:90vw;max-height:80vh;object-fit:contain}.lb-close{position:absolute;top:18px;right:18px;background:transparent;border:0;color:white;font-size:28px;cursor:pointer}.lb-nav{position:absolute;top:50%;transform:translateY(-50%);background:transparent;border:0;color:white;font-size:36px;cursor:pointer;padding:12px}.lb-prev{left:6px}.lb-next{right:6px}
.popup{position:fixed;inset:0;z-index:1200;display:none;align-items:center;justify-content:center}.popup[aria-hidden="false"]{display:flex}.popup-overlay{position:absolute;inset:0;background:rgba(0,0,0,0.45)}.popup-inner{position:relative;z-index:10;max-width:520px;width:90%}.popup-content{background:var(--card-bg);padding:20px;border-radius:12px;border:1px solid var(--card-outline);box-shadow:var(--shadow);position:relative;text-align:center}.popup-close{position:absolute;top:8px;right:8px;background:transparent;border:0;font-size:18px;cursor:pointer}
.scroll-top{position:fixed;right:16px;bottom:24px;padding:10px;border-radius:50%;border:0;background:var(--accent);color:white;box-shadow:var(--shadow);display:none;cursor:pointer;z-index:1400}.scroll-top:hover{transform:translateY(-3px)}
.site-footer{text-align:center;padding:20px;font-size:.95rem;background:var(--card-bg);border-top:1px solid var(--card-outline);margin-top:40px}
@media(max-width:420px){.card img{height:260px}.controls{padding:10px}}


/* Lightbox side-by-side layout */
.lb-content{display:flex;gap:1.5rem;align-items:flex-start;justify-content:center;max-width:1000px;margin:auto;padding:1rem;}
.lb-left img{max-width:520px;max-height:75vh;border-radius:8px;display:block;margin:0 auto;}
.lb-right{max-width:420px;color:var(--text);}
.lb-right h3{margin:0 0 .5rem;font-size:1.4rem;color:var(--text);}
.lb-right p{margin:0;font-size:1rem;line-height:1.45;color:var(--text);}

/* Mobile: stack vertically */
@media (max-width:768px){ .lb-content{flex-direction:column;padding:0.5rem;} .lb-left img{max-width:90vw;max-height:50vh;} .lb-right{padding:0 1rem;} }



/* Lightbox description block improved for readability */
.lb-right {
  max-width: 420px;
  padding: 1rem;
  border-radius: 8px;
  background: var(--card-bg, #ffffff);
  color: var(--text, #111111);
  box-shadow: 0 2px 6px rgba(0,0,0,0.15);
}
.lb-right h3 {
  margin: 0 0 .5rem;
  font-size: 1.4rem;
  color: inherit;
}
.lb-right p {
  margin: 0;
  font-size: 1rem;
  line-height: 1.45;
  color: inherit;
}
body.dark .lb-right {
  background: #222;
  color: #f2f2f2;
}



/* Make description scrollable if too long */
.lb-right {
  max-height: 75vh;
  overflow-y: auto;
}



/* Custom scrollbar styling for description */
.lb-right::-webkit-scrollbar {
  width: 6px;
}
.lb-right::-webkit-scrollbar-track {
  background: transparent;
}
.lb-right::-webkit-scrollbar-thumb {
  background-color: rgba(100, 100, 100, 0.5);
  border-radius: 3px;
}
.lb-right:hover::-webkit-scrollbar-thumb {
  background-color: rgba(100, 100, 100, 0.8);
}

/* Firefox */
.lb-right {
  scrollbar-width: thin;
  scrollbar-color: rgba(100,100,100,0.6) transparent;
}



/* === LIGHTBOX: Accessibility & Responsive fixes (appended) ===
   - Hide/show based on aria-hidden attribute
   - Constrain image size to viewport (max-width / max-height)
   - Make layout adapt: side-by-side on wide screens, stacked on small screens
   - Ensure overlay background and scrolling/overflow handling
*/
.lightbox[aria-hidden="true"]{
  display: none !important;
}
.lightbox[aria-hidden="false"]{
  display: flex !important;
  align-items: center;
  justify-content: center;
  background: rgba(0,0,0,0.6);
  z-index: 1400;
  padding: 12px;
  overflow: auto;
}

/* Core responsive container */
.lb-content{
  display: flex;
  gap: 1.25rem;
  align-items: flex-start;
  justify-content: center;
  max-width: min(1000px, 96vw);
  width: 100%;
  margin: auto;
  padding: 1rem;
  box-sizing: border-box;
}

/* Left: image area (flexible) */
.lb-left{
  flex: 1 1 60%;
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 0; /* allow flex children to shrink properly */
}
.lb-left img{
  width: auto;
  max-width: 100%;
  height: auto;
  max-height: calc(100vh - 160px);
  object-fit: contain;
  border-radius: 8px;
  display: block;
}

/* Right: description / metadata */
.lb-right{
  flex: 0 0 320px;
  max-width: 34%;
  min-width: 220px;
  overflow: auto;
  padding: 1rem;
  box-sizing: border-box;
  background: var(--card-bg, #fff);
  border-radius: 8px;
}

/* Navigation & buttons: ensure they sit above content and are reachable on mobile */
.lb-close{
  position: fixed;
  top: 14px;
  right: 14px;
  z-index: 1501;
  background: transparent;
  border: 0;
  color: #fff;
  font-size: 26px;
  cursor: pointer;
  padding: 6px;
}
.lb-nav{
  position: fixed;
  top: 50%;
  transform: translateY(-50%);
  z-index: 1501;
  background: transparent;
  border: 0;
  color: #fff;
  font-size: 32px;
  cursor: pointer;
  padding: 10px;
  -webkit-tap-highlight-color: transparent;
}
.lb-prev{ left: 8px; }
.lb-next{ right: 8px; }

/* Smaller screens: stack vertically, make right column full width under the image */
@media (max-width: 900px){
  .lb-content{ flex-direction: column-reverse; gap: 12px; max-width: 96vw; padding: 0.75rem; }
  .lb-left{ flex: 1 1 auto; width: 100%; }
  .lb-right{ flex-basis: auto; max-width: 100%; min-width: 0; padding: 0.75rem; }
  .lb-left img{ max-height: calc(100vh - 200px); }
  .lb-close{ top: 10px; right: 10px; font-size: 22px; }
  .lb-nav{ font-size: 26px; padding: 8px; }
}

/* Extra-small: ensure image fits nicely */
@media (max-width: 480px){
  .lb-left img{ max-width: 94vw; max-height: calc(100vh - 140px); }
  .lb-right{ padding: 10px; font-size: 0.95rem; }
  .lb-prev{ left: 4px; }
  .lb-next{ right: 4px; }
}

/* Prevent body/background scroll when open is handled by JS (document.documentElement.style.overflow = 'hidden') */


/* === Lightbox mobile layout fix (force image above description) === */
@media (max-width: 900px){
  .lb-content{
    flex-direction: column !important;
  }
  .lb-left{
    order: 1;
  }
  .lb-right{
    order: 2;
  }
}












.hero-title 

.hero-title 



.hero-title .brand-name,








.hero-title {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 15px;
  text-align: center;
  margin: 0 auto;
}

.hero-title .brand-name {
  font-family: 'SummerStarshine', cursive;
  font-size: clamp(1.2rem, 4vw, 2.5rem);
  color: var(--text);
}

.hero-title .catalog-title {
  font-family: 'Kanit', sans-serif;
  font-weight: 600;
  font-size: clamp(1.2rem, 4vw, 2.5rem);
  color: var(--text);
}
