:root{
  --bg: #fbfaf7;
  --bg2:#f5f1e8;
  --ink:#0b1220;
  --muted:#4b5563;
  --line: rgba(11,18,32,.10);
  --card: rgba(255,255,255,.72);
  --card2: rgba(255,255,255,.86);
  --shadow: 0 18px 50px rgba(11,18,32,.10);
  --shadow2: 0 10px 25px rgba(11,18,32,.08);
  --r: 18px;
  --r2: 28px;
  --max: 1160px;
  --blue:#2a86d6;
  --blue2:#1f6fb4;
  --gold:#f2c94c;
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
  color:var(--ink);
  background:
    radial-gradient(1200px 650px at 20% -10%, rgba(242,201,76,.25), transparent 55%),
    radial-gradient(1200px 650px at 85% 10%, rgba(42,134,214,.16), transparent 55%),
    linear-gradient(180deg, var(--bg), var(--bg2));
  line-height:1.45;
}
a{color:inherit}
img{max-width:100%; display:block}
button{font:inherit}
.container{max-width:var(--max); margin:0 auto; padding:0 20px}
@media (min-width: 900px){ .container{padding:0 28px} }
.topbar{
  position:sticky; top:0; z-index:50;
  backdrop-filter: blur(10px);
  background: rgba(251,250,247,.75);
  border-bottom:1px solid var(--line);
}
.nav{
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 0;
  gap:18px;
}
.brand{
  display:flex; align-items:center; gap:12px; text-decoration:none;
}
.brand img{width:44px; height:44px; border-radius:12px; box-shadow: var(--shadow2); background:#fff}
.brand .t1{font-weight:800; letter-spacing:-.02em}
.brand .t2{font-size:13px; color:var(--muted); margin-top:2px}
.navlinks{display:flex; gap:10px; align-items:center; flex-wrap:wrap; justify-content:flex-end;}
.pill{
  text-decoration:none;
  padding:10px 14px;
  border-radius:999px;
  border:1px solid var(--line);
  background: rgba(255,255,255,.55);
  color:var(--ink);
  font-weight:600;
}
.pill:hover{background: rgba(255,255,255,.85)}
.pill.primary{background: var(--blue); border-color: rgba(42,134,214,.35); color:white;}
.pill.primary:hover{background: var(--blue2)}
.pill.ghost{background: transparent;}
.cartbtn{display:flex; align-items:center; gap:10px;}
.badge{
  display:inline-flex; align-items:center; justify-content:center;
  min-width:22px; height:22px; padding:0 6px;
  background: rgba(11,18,32,.08);
  border-radius:999px;
  font-size:12px; font-weight:800;
}
.hero{padding: clamp(28px, 4vw, 64px) 0 28px;}
.heroGrid{display:grid; gap:26px; align-items:center;}
@media (min-width: 980px){ .heroGrid{ grid-template-columns: 1.08fr .92fr; gap:44px; } }
.kicker{
  font-size:12px; letter-spacing:.14em; text-transform:uppercase;
  color: var(--blue2); font-weight:800;
}
.h1{
  font-size: clamp(40px, 5vw, 72px);
  line-height: 1.02; letter-spacing:-.04em; margin:12px 0 14px;
}
.lede{font-size: clamp(16px, 1.6vw, 18px); color: var(--muted); max-width: 52ch;}
.actions{display:flex; gap:12px; flex-wrap:wrap; margin-top:18px;}
.linkArrow{display:inline-flex; align-items:center; gap:10px; text-decoration:none; padding:10px 12px; border-radius:999px;}
.linkArrow:hover{background: rgba(11,18,32,.06)}
.heroArt{
  position:relative; border-radius: var(--r2);
  background: rgba(255,255,255,.55);
  border: 1px solid var(--line);
  box-shadow: var(--shadow);
  overflow:hidden; padding: 18px;
}
.heroArtInner{display:grid; gap:14px; align-items:center;}
.heroCan{width:min(420px, 100%); margin: 0 auto; filter: drop-shadow(0 22px 35px rgba(11,18,32,.18));}
.miniRow{display:flex; gap:10px; flex-wrap:wrap; margin-top:18px;}
.chip{
  font-size:12px; font-weight:700; color: rgba(11,18,32,.78);
  padding:8px 10px; border-radius:999px;
  border: 1px solid var(--line);
  background: rgba(255,255,255,.50);
}
.section{padding: 10px 0 56px;}
.sectionTitleRow{display:flex; align-items:flex-end; justify-content:space-between; gap:16px; flex-wrap:wrap; margin: 0 0 12px;}
.h2{font-size: clamp(22px, 2.2vw, 30px); letter-spacing:-.02em; margin:0;}
.subtleLink{color: var(--blue2); font-weight:800; text-decoration:none;}
.subtleLink:hover{text-decoration:underline}
.carousel{
  position:relative; border-radius: var(--r2);
  overflow:hidden; border: 1px solid var(--line);
  background: rgba(255,255,255,.55);
  box-shadow: var(--shadow);
}
.slide{display:none; min-height: 260px; align-items:stretch;}
.slide.active{display:grid}
@media (min-width: 860px){ .slide.active{grid-template-columns: 1.1fr .9fr} }
.slideMedia{position:relative; background: #e9e6de; min-height: 260px;}
.slideMedia img{width:100%; height:100%; object-fit:cover; opacity:.96;}
.slideOverlay{position:absolute; inset:0; background: linear-gradient(90deg, rgba(0,0,0,.56), rgba(0,0,0,.06));}
.slideCopy{position:absolute; left:18px; bottom:18px; right:18px; color:white;}
.slideCopy h3{margin:0 0 8px; font-size: clamp(22px, 3vw, 36px); letter-spacing:-.03em;}
.slideCopy p{margin:0 0 14px; opacity:.9; max-width:50ch}
.slideCta{
  display:inline-flex; align-items:center; gap:10px;
  padding:10px 14px; border-radius:999px;
  background: rgba(255,255,255,.92);
  color:#111827; text-decoration:none; font-weight:900;
}
.slideInfo{padding:18px 18px 10px; display:grid; gap:10px; align-content:center;}
.slideInfo .tag{font-weight:900; color: var(--blue2); text-transform:uppercase; letter-spacing:.12em; font-size:12px}
.slideInfo .name{font-size:22px; letter-spacing:-.02em; font-weight:900}
.slideInfo .meta{color: var(--muted)}
.dots{position:absolute; right:14px; bottom:14px; display:flex; gap:6px;}
.dot{width:8px; height:8px; border-radius:999px; background: rgba(255,255,255,.55); border: 1px solid rgba(255,255,255,.65);}
.dot.active{background: rgba(255,255,255,.95)}
.grid{display:grid; gap:16px;}
@media (min-width: 700px){ .grid{grid-template-columns: repeat(2,1fr)} }
@media (min-width: 1000px){ .grid{grid-template-columns: repeat(3,1fr)} }
.card{
  border-radius: var(--r); border: 1px solid var(--line);
  background: rgba(255,255,255,.70);
  box-shadow: var(--shadow2);
  overflow:hidden; display:flex; flex-direction:column; min-height: 100%;
  transition: transform .18s ease, box-shadow .18s ease;
}
.card:hover{transform: translateY(-3px); box-shadow: var(--shadow)}
.cardMedia{
  background: rgba(255,255,255,.75);
  padding: 14px;
  height: 260px;
  display:flex;
  align-items:center;
  justify-content:center;
}
.cardMedia img{
  width:100%;
  height:100%;
  object-fit:contain;
  object-position:center;
  filter: drop-shadow(0 16px 22px rgba(11,18,32,.16));
}
@media (max-width: 520px){ .cardMedia{height: 220px} }
.cardBody{padding:14px 14px 16px; display:grid; gap:10px}
.cardTitleRow{display:flex; align-items:flex-start; justify-content:space-between; gap:10px}
.cardTitle{font-weight:900; letter-spacing:-.02em; margin:0}
.price{font-weight:900}
.cardDesc{color: var(--muted); margin:0}
.cardActions{display:flex; gap:10px; flex-wrap:wrap; margin-top:4px}
.smallbtn{
  padding:10px 12px; border-radius:999px; border:1px solid var(--line);
  background: rgba(255,255,255,.75); font-weight:800; text-decoration:none;
}
.smallbtn:hover{background: rgba(255,255,255,.95)}
.smallbtn.primary{background: var(--blue); border-color: rgba(42,134,214,.35); color:white;}
.smallbtn.primary:hover{background: var(--blue2)}
.valueRow{display:grid; gap:14px;}
@media (min-width: 900px){ .valueRow{grid-template-columns: repeat(3, 1fr)} }
.value{padding:18px; border-radius: var(--r); border:1px solid var(--line); background: rgba(255,255,255,.66);}
.value h4{margin:0 0 6px; font-weight:900; letter-spacing:-.02em}
.value p{margin:0; color: var(--muted)}
.note{
  margin-top:16px; padding:16px; border-radius: var(--r);
  border:1px solid rgba(42,134,214,.22);
  background: rgba(42,134,214,.08);
  color: rgba(11,18,32,.88); font-weight:700;
}
.footer{margin-top: 48px; border-top: 1px solid var(--line); background: rgba(255,255,255,.35);}
.footerGrid{display:grid; gap:18px; padding: 22px 0;}
@media (min-width: 900px){ .footerGrid{grid-template-columns: 1.2fr 1fr 1fr} }
.footer h5{margin:0 0 8px; font-weight:900}
.footer p, .footer a{color: rgba(11,18,32,.74); font-size:14px}
.footer a{text-decoration:none}
.footer a:hover{text-decoration:underline}
.tiny{font-size:12px; color: rgba(11,18,32,.55)}
.pageHead{padding: 34px 0 10px;}
.pageHead .h1{font-size: clamp(34px, 4.3vw, 54px)}
.productGrid{display:grid; gap:18px;}
@media (min-width: 980px){ .productGrid{grid-template-columns: 1.05fr .95fr; gap:34px} }
.gallery{
  border-radius: var(--r2); border: 1px solid var(--line);
  background: rgba(255,255,255,.62); box-shadow: var(--shadow2); overflow:hidden;
}
.galleryMain{
  padding:18px;
  height: 456px;
  display:flex;
  align-items:center;
  justify-content:center;
}
.galleryMain img{
  width:100%;
  height:100%;
  object-fit:contain;
  object-position:center;
  filter: drop-shadow(0 22px 30px rgba(11,18,32,.18));
}
@media (max-width: 520px){ .galleryMain{height: 340px} }
.galleryThumbs{display:flex; gap:10px; padding: 12px 12px 14px; border-top:1px solid var(--line); overflow:auto;}
.thumb{
  flex:0 0 auto; width:76px; height:76px; border-radius:14px;
  border:1px solid var(--line); background: rgba(255,255,255,.75);
  display:flex; align-items:center; justify-content:center; cursor:pointer;
}
.thumb img{max-height:60px}
.thumb.active{outline:3px solid rgba(42,134,214,.35)}
.panel{
  border-radius: var(--r2); border: 1px solid var(--line);
  background: rgba(255,255,255,.66); box-shadow: var(--shadow2); padding:18px;
}
.panel h2{margin:0 0 6px; letter-spacing:-.02em}
.panel .muted{color: var(--muted)}
.hr{height:1px; background: var(--line); margin:14px 0}
.stack{display:grid; gap:10px}
.formGrid{display:grid; gap:12px}
@media (min-width: 760px){ .formGrid{grid-template-columns: repeat(2, 1fr)} }
.field{display:grid; gap:6px; font-weight:700}
.field span{font-size:14px}
.field input,.field textarea{
  width:100%;
  border:1px solid var(--line);
  border-radius:12px;
  padding:10px 12px;
  font:inherit;
  color:var(--ink);
  background: rgba(255,255,255,.85);
}
.field textarea{resize:vertical; min-height:120px}
.row{display:flex; justify-content:space-between; gap:12px; align-items:flex-start; flex-wrap:wrap}
.drawer{
  position:fixed; top:0; right:-420px; width:min(420px, 92vw); height:100%;
  background: rgba(255,255,255,.96); border-left:1px solid var(--line);
  box-shadow: -20px 0 60px rgba(11,18,32,.18);
  z-index:100; transition: right .22s ease; display:flex; flex-direction:column;
}
.drawer.open{right:0}
.drawerHead{padding:16px 16px 12px; display:flex; justify-content:space-between; align-items:center; border-bottom:1px solid var(--line);}
.drawerBody{padding:14px 16px; overflow:auto; flex:1}
.drawerFoot{padding:14px 16px; border-top:1px solid var(--line)}
.cartItem{display:grid; grid-template-columns: 64px 1fr; gap:12px; padding:10px 0; border-bottom:1px solid rgba(11,18,32,.06);}
.cartItem img{width:64px; height:64px; object-fit:contain}
.qty{display:inline-flex; gap:8px; align-items:center; border:1px solid var(--line); border-radius:999px; padding:6px 10px; background: rgba(255,255,255,.8);}
.qty button{border:0; background:transparent; font-weight:900; cursor:pointer; padding:2px 6px}
.qty span{min-width:18px; text-align:center; font-weight:900}
.backdrop{position:fixed; inset:0; background: rgba(11,18,32,.38); z-index:90; display:none;}
.backdrop.show{display:block}
:focus-visible{outline: 3px solid rgba(242,201,76,.9); outline-offset: 2px}
