:root{
  --black:#111;
  --white:#fff;
  --off-white:#f8f6f2;
  --cream:#ede9e1;
  --mid:#888;
  --border:#ddd;
  --accent:#c9a96e;
  --sale:#c0392b;
  --radius:8px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:'Inter',sans-serif;
  color:var(--black);
  background:var(--white);
  font-size:15px;
  line-height:1.6;
}
h1,h2,h3,h4{font-family:'Inter',sans-serif;font-weight:600;line-height:1.15}
a{color:inherit;text-decoration:none}
img{max-width:100%}
.container{max-width:1280px;margin:0 auto;padding:0 28px}

/* ---------- Placeholder ---------- */
.ph{
  position:relative;
  width:100%;
  aspect-ratio:600/400;
  background-color:var(--off-white);
  background-image:repeating-linear-gradient(
    45deg,
    transparent 0,
    transparent 11px,
    rgba(0,0,0,.045) 11px,
    rgba(0,0,0,.045) 12px
  );
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
}
.ph span{
  font-size:12px;
  letter-spacing:.08em;
  color:var(--mid);
  text-transform:uppercase;
  background:rgba(248,246,242,.7);
  padding:4px 10px;
}
.ph.dark{
  background-color:#1a1a1a;
  background-image:repeating-linear-gradient(
    45deg,
    transparent 0,
    transparent 11px,
    rgba(255,255,255,.05) 11px,
    rgba(255,255,255,.05) 12px
  );
}

/* ---------- Buttons ---------- */
.btn{
  display:inline-block;
  font-family:'Inter',sans-serif;
  font-size:12px;
  font-weight:700;
  letter-spacing:.1em;
  text-transform:uppercase;
  padding:15px 34px;
  cursor:pointer;
  border:1px solid var(--black);
  transition:.2s;
}
.btn-primary{background:var(--black);color:var(--white)}
.btn-primary:hover{background:#000}
.btn-outline{background:transparent;color:var(--black)}
.btn-outline:hover{background:var(--black);color:var(--white)}

/* ---------- Topbar ---------- */
.topbar{
  background:var(--black);
  color:var(--white);
  text-align:center;
  font-size:12px;
  letter-spacing:.05em;
  padding:9px 12px;
}

/* ---------- Header ---------- */
.header{
  position:sticky;
  top:0;
  z-index:200;
  background:var(--white);
  border-bottom:1px solid var(--border);
}
.header__inner{
  display:grid;
  grid-template-columns:1fr auto 1fr;
  align-items:center;
  gap:20px;
  height:82px;
}
.header__left{display:flex;align-items:center;gap:14px}
.hamburger{
  background:none;border:1px solid var(--border);
  width:42px;height:42px;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;color:var(--black);transition:.2s;flex:none;
}
.hamburger:hover{border-color:var(--black);background:var(--off-white)}
.hamburger svg{width:20px;height:20px}
.brand{display:flex;flex-direction:column;line-height:1}
.logo{
  font-family:'Inter',sans-serif;
  font-size:28px;
  font-weight:700;
  letter-spacing:.16em;
  text-transform:uppercase;
}
.brand__tag{
  font-size:9.5px;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--mid);
  margin-top:4px;
}
.brand__tag::before{content:"✦ ";color:var(--accent)}
.header__icons{
  display:flex;
  justify-content:flex-end;
  align-items:center;
  gap:22px;
}
.header__icons a{
  position:relative;
  display:inline-flex;
  color:var(--black);
}
.header__icons svg{width:20px;height:20px}
.cart-badge{
  position:absolute;
  top:-7px;right:-9px;
  background:var(--accent);
  color:var(--white);
  font-size:10px;
  font-weight:700;
  min-width:16px;height:16px;
  display:flex;align-items:center;justify-content:center;
  font-family:'Inter',sans-serif;
}

/* ---------- Navigation (3-level CSS hover) ---------- */
.nav>ul{list-style:none;display:flex;gap:34px}
.nav>ul>li{position:relative}
.nav>ul>li>a{
  display:block;
  text-transform:uppercase;
  font-size:12px;
  letter-spacing:.06em;
  font-weight:500;
  padding:27px 0;
}
.nav>ul>li>a:hover{color:var(--accent)}
.nav .sale-link>a{color:var(--sale)}

/* L2 dropdown */
.nav .l2{
  list-style:none;
  position:absolute;
  top:100%;left:0;
  min-width:210px;
  background:var(--white);
  border-top:2px solid var(--black);
  border-left:1px solid var(--border);
  border-right:1px solid var(--border);
  border-bottom:1px solid var(--border);
  box-shadow:0 14px 34px rgba(0,0,0,.08);
  opacity:0;visibility:hidden;
  transform:translateY(6px);
  transition:.18s;
}
.nav>ul>li:hover>.l2{opacity:1;visibility:visible;transform:translateY(0)}
.nav .l2>li{position:relative}
.nav .l2>li>a{
  display:block;
  padding:13px 20px;
  font-size:12px;
  letter-spacing:.06em;
  text-transform:uppercase;
  font-weight:500;
  white-space:nowrap;
}
.nav .l2>li>a:hover{background:var(--off-white);color:var(--accent)}
.nav .l2>li.has-l3>a::after{content:"›";float:right;color:var(--mid)}

/* L3 flyout */
.nav .l3{
  list-style:none;
  position:absolute;
  top:-2px;left:100%;
  min-width:200px;
  background:var(--white);
  border-top:2px solid var(--accent);
  border-left:1px solid var(--border);
  border-right:1px solid var(--border);
  border-bottom:1px solid var(--border);
  box-shadow:0 14px 34px rgba(0,0,0,.08);
  opacity:0;visibility:hidden;
  transform:translateX(6px);
  transition:.18s;
}
.nav .l2>li.has-l3:hover>.l3{opacity:1;visibility:visible;transform:translateX(0)}
.nav .l3>li>a{
  display:block;
  padding:11px 20px;
  font-size:12px;
  letter-spacing:.04em;
  white-space:nowrap;
  color:#555;
  transition:.15s;
}
.nav .l3>li>a:hover{padding-left:30px;color:var(--black)}

/* ---------- Hero ---------- */
.hero{padding:64px 0}
.hero__grid{display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:56px}
.hero__copy .eyebrow{
  text-transform:uppercase;
  letter-spacing:.2em;
  font-size:12px;
  color:var(--accent);
  font-weight:700;
  margin-bottom:18px;
}
.hero__copy h1{font-size:60px;margin-bottom:20px}
.hero__copy p{color:#555;max-width:440px;margin-bottom:32px}
.text-link{color:var(--black);font-weight:600;text-decoration:underline;text-decoration-color:var(--accent);text-underline-offset:3px;transition:.15s}
.text-link:hover{color:var(--accent)}
.hero__cta{display:flex;gap:14px;flex-wrap:wrap}

/* ---------- Section heading ---------- */
.section{padding:62px 0}
.section--alt{background:var(--off-white)}
.section__head{text-align:center;margin-bottom:42px}
.section__head .eyebrow{
  text-transform:uppercase;letter-spacing:.2em;font-size:12px;
  color:var(--accent);font-weight:700;margin-bottom:10px;
}
.section__head h2{font-size:40px}

/* ---------- Category grid ---------- */
.cat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.cat-card{display:block}
.cat-card__body{padding:16px 2px}
.cat-card h3{font-size:24px}
.cat-card .count{font-size:13px;color:var(--mid);letter-spacing:.04em}
.cat-card .ph span{transition:.2s}
.cat-card:hover h3{color:var(--accent)}

/* ---------- Product tabs ---------- */
.tabs{display:flex;justify-content:center;gap:36px;margin-bottom:40px;border-bottom:1px solid var(--border)}
.tab{
  background:none;border:none;cursor:pointer;
  font-family:'Inter',sans-serif;
  text-transform:uppercase;font-size:12px;letter-spacing:.1em;font-weight:700;
  color:var(--mid);
  padding:0 2px 16px;
  border-bottom:2px solid transparent;
  margin-bottom:-1px;
  transition:.2s;
}
.tab:hover{color:var(--black)}
.tab.active{color:var(--black);border-bottom-color:var(--black)}

.product-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:26px}
.tabpane{display:none}
.tabpane.active{display:block}
.product{position:relative;display:block;color:inherit}
.product .ph{margin-bottom:14px}
.product .badge{
  position:absolute;top:12px;left:12px;
  font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  padding:5px 10px;color:var(--white);z-index:2;
}
.badge-new{background:var(--black)}
.badge-sale{background:var(--sale)}
.product .crumb{font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--mid);margin-bottom:4px}
.product .name{font-size:15px;font-weight:500;margin-bottom:6px;transition:.15s}
.product:hover .name{color:var(--accent)}
.product .price{font-size:14px;font-weight:700}
.product .price .was{color:var(--mid);font-weight:400;text-decoration:line-through;margin-right:8px}
.product .price .now{color:var(--sale)}

/* ---------- Collection banners ---------- */
.banners{display:grid;grid-template-columns:2fr 1fr 1fr;gap:18px}
.banner{position:relative;min-height:340px;display:flex}
.banner .ph{aspect-ratio:auto;height:100%}
.banner__overlay{
  position:absolute;inset:0;
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:30px;
  background:linear-gradient(to top,rgba(0,0,0,.55),transparent 60%);
  color:var(--white);
}
.banner__overlay .eyebrow{text-transform:uppercase;letter-spacing:.18em;font-size:11px;color:var(--accent);font-weight:700;margin-bottom:8px}
.banner__overlay h3{font-size:30px;color:var(--white)}
.banner__overlay a{display:inline-block;margin-top:12px;font-size:12px;letter-spacing:.08em;text-transform:uppercase;border-bottom:1px solid var(--accent);padding-bottom:3px;width:fit-content}

/* ---------- Features bar ---------- */
.features{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.feature{display:flex;gap:14px;align-items:flex-start}
.feature svg{width:26px;height:26px;flex:none;stroke:var(--accent)}
.feature h4{font-size:18px;margin-bottom:2px}
.feature p{font-size:13px;color:var(--mid)}

/* ---------- Newsletter ---------- */
.newsletter{background:var(--black);color:var(--white);text-align:center;padding:72px 0}
.newsletter h2{font-size:40px;color:var(--white);margin-bottom:12px}
.newsletter p{color:#bbb;margin-bottom:28px}
.newsletter form{display:flex;justify-content:center;gap:0;max-width:480px;margin:0 auto}
.newsletter input{
  flex:1;
  font-family:'Inter',sans-serif;
  padding:15px 18px;
  border:1px solid #444;background:transparent;color:var(--white);
  font-size:14px;
}
.newsletter input::placeholder{color:#888}
.newsletter button{
  border:1px solid var(--white);
  background:var(--white);color:var(--black);
  font-family:'Inter',sans-serif;font-weight:700;
  text-transform:uppercase;letter-spacing:.08em;font-size:12px;
  padding:0 28px;cursor:pointer;transition:.2s;
}
.newsletter button:hover{background:var(--accent);border-color:var(--accent);color:var(--white)}

/* ---------- Footer ---------- */
.footer{background:#0c0c0c;color:#bbb;padding:64px 0 0}
.footer__grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px;padding-bottom:48px}
.footer__brand .logo{color:var(--white);margin-bottom:14px;display:inline-block}
.footer__brand p{font-size:13px;max-width:280px}
.footer h4{
  color:var(--white);font-family:'Inter',sans-serif;
  font-size:12px;letter-spacing:.1em;text-transform:uppercase;font-weight:700;
  margin-bottom:18px;
}
.footer ul{list-style:none}
.footer ul li{margin-bottom:10px}
.footer ul a{font-size:13px;color:#bbb;transition:.15s}
.footer ul a:hover{color:var(--accent)}
.footer__bottom{
  border-top:1px solid #222;
  padding:22px 0;
  font-size:12px;color:#777;
  text-align:center;
  line-height:1.8;
}
.footer__bottom .demo{color:var(--accent)}
.footer__legal{margin-top:6px;display:flex;gap:18px;justify-content:center;flex-wrap:wrap}
.footer__legal a{color:#999;transition:.15s}
.footer__legal a:hover{color:var(--accent)}

/* ---------- Overlay + Drawers ---------- */
.overlay{
  position:fixed;inset:0;
  background:rgba(0,0,0,.45);
  opacity:0;visibility:hidden;
  transition:.25s;z-index:300;
}
.overlay.open{opacity:1;visibility:visible}
.drawer{
  position:fixed;z-index:400;
  background:var(--white);
  display:flex;flex-direction:column;
  transition:transform .3s ease;
  box-shadow:0 0 40px rgba(0,0,0,.16);
}
.drawer--left{top:0;left:0;height:100%;width:340px;max-width:86vw;transform:translateX(-100%)}
.drawer--left.open{transform:translateX(0)}
.drawer--right{top:0;right:0;height:100%;width:380px;max-width:90vw;transform:translateX(100%)}
.drawer--right.open{transform:translateX(0)}
.drawer--top{top:0;left:0;width:100%;padding:24px 0 28px;transform:translateY(-100%);border-bottom:2px solid var(--black)}
.drawer--top.open{transform:translateY(0)}
.drawer__head{
  display:flex;align-items:center;justify-content:space-between;
  padding:20px 24px;border-bottom:1px solid var(--border);
}
.drawer__title{text-transform:uppercase;letter-spacing:.1em;font-size:12px;font-weight:700}
.drawer__close{
  background:none;border:none;cursor:pointer;
  font-size:26px;line-height:1;color:var(--black);
}

/* Side menu accordion */
.drawer__nav{overflow-y:auto}
.acc{list-style:none}
.acc>li{border-bottom:1px solid var(--border)}
.acc__toggle{
  width:100%;background:none;border:none;cursor:pointer;
  font-family:'Inter',sans-serif;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 24px;
  text-transform:uppercase;letter-spacing:.08em;font-size:13px;font-weight:600;
  color:var(--black);
}
.acc__toggle--sale{color:var(--sale)}
.acc__toggle span{font-size:18px;font-weight:400;color:var(--mid)}
.acc__body{display:none;padding:0 24px 18px;flex-direction:column}
.acc__body.open{display:flex}
.acc__body a{
  font-size:13px;padding:7px 0;color:#555;transition:.15s;
}
.acc__body a:hover{padding-left:6px;color:var(--black)}
.acc__group{
  margin-top:10px;text-transform:uppercase;letter-spacing:.06em;
  font-size:11px;font-weight:700;color:var(--accent)!important;
}
.acc__group:first-child{margin-top:0}

/* Search drawer */
.search__row{display:flex;align-items:center;gap:14px;border-bottom:1px solid var(--black);padding-bottom:12px}
.search__icon{width:22px;height:22px;color:var(--mid);flex:none}
.search__input{
  flex:1;border:none;background:none;outline:none;
  font-family:'Inter',sans-serif;font-size:20px;color:var(--black);
}
.search__input::placeholder{color:var(--mid)}
.search__suggest{margin-top:16px;font-size:13px;color:var(--mid);display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.search__suggest a{padding:5px 12px;border:1px solid var(--border);color:#444;transition:.15s}
.search__suggest a:hover{border-color:var(--black);color:var(--black)}

/* Cart drawer */
.cart__items{flex:1;overflow-y:auto;padding:8px 24px}
.cart__item{display:flex;gap:14px;padding:18px 0;border-bottom:1px solid var(--border)}
.cart__item .ph{width:78px;aspect-ratio:1;flex:none}
.cart__item .ph span{font-size:9px;padding:2px 5px}
.cart__info .crumb{font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--mid);margin-bottom:3px}
.cart__info .name{font-size:14px;font-weight:500;margin-bottom:6px}
.cart__meta{font-size:13px;color:#444}
.cart__foot{padding:20px 24px;border-top:1px solid var(--border)}
.cart__total{display:flex;justify-content:space-between;font-weight:700;font-size:15px;margin-bottom:16px}
.cart__checkout{display:block;width:100%;text-align:center;margin-bottom:10px}

/* ========== Sub-page components ========== */
/* Breadcrumb + page head */
.breadcrumb{font-size:12px;letter-spacing:.04em;text-transform:uppercase;color:var(--mid);padding:22px 0}
.breadcrumb a:hover{color:var(--accent)}
.breadcrumb span{color:var(--black)}
.page-head{padding:30px 0 40px;border-bottom:1px solid var(--border);margin-bottom:40px}
.page-head--center{text-align:center}
.page-head .eyebrow{text-transform:uppercase;letter-spacing:.2em;font-size:12px;color:var(--accent);font-weight:700;margin-bottom:12px}
.page-head h1{font-size:46px;margin-bottom:12px}
.page-head p{color:#666;max-width:620px}
.page-head--center p{margin:0 auto}

/* Collection toolbar + sidebar */
.shop{display:grid;grid-template-columns:230px 1fr;gap:40px;padding-bottom:80px}
.filters h4{font-size:12px;letter-spacing:.1em;text-transform:uppercase;margin-bottom:14px}
.filters ul{list-style:none;margin-bottom:30px}
.filters li{margin-bottom:9px}
.filters a{font-size:14px;color:#555;transition:.15s}
.filters a:hover,.filters a.active{color:var(--black);font-weight:600}
.shop__main .toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;font-size:13px;color:var(--mid)}
.shop__main .toolbar select{font-family:'Inter',sans-serif;padding:8px 12px;border:1px solid var(--border);background:var(--white);border-radius:var(--radius);font-size:13px}
.shop__main .product-grid{grid-template-columns:repeat(3,1fr)}
.pagination{display:flex;justify-content:center;gap:8px;margin-top:50px}
.pagination a{
  width:42px;height:42px;display:flex;align-items:center;justify-content:center;
  border:1px solid var(--border);border-radius:var(--radius);font-size:14px;transition:.15s;
}
.pagination a:hover{border-color:var(--black)}
.pagination a.active{background:var(--black);color:var(--white);border-color:var(--black)}

/* Product detail (PDP) */
.pdp{display:grid;grid-template-columns:1fr 1fr;gap:56px;padding-bottom:80px}
.pdp__gallery .ph{margin-bottom:14px}
.pdp__thumbs{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.pdp__thumbs .ph{aspect-ratio:1;cursor:pointer}
.pdp__info .crumb{font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--mid);margin-bottom:10px}
.pdp__info h1{font-size:38px;margin-bottom:14px}
.pdp__price{font-size:24px;font-weight:700;margin-bottom:6px}
.pdp__price .was{color:var(--mid);font-weight:400;text-decoration:line-through;margin-right:12px}
.pdp__price .now{color:var(--sale)}
.pdp__rating{font-size:13px;color:var(--mid);margin-bottom:24px}
.pdp__rating .stars{color:var(--accent);letter-spacing:2px}
.pdp__desc{color:#555;margin-bottom:28px;padding-bottom:28px;border-bottom:1px solid var(--border)}
.opt{margin-bottom:22px}
.opt__label{font-size:12px;letter-spacing:.08em;text-transform:uppercase;font-weight:600;margin-bottom:10px}
.swatches{display:flex;gap:10px;flex-wrap:wrap}
.swatch{
  min-width:46px;height:42px;padding:0 14px;border:1px solid var(--border);border-radius:var(--radius);
  background:var(--white);cursor:pointer;font-family:'Inter',sans-serif;font-size:13px;transition:.15s;
  display:flex;align-items:center;justify-content:center;
}
.swatch:hover,.swatch.active{border-color:var(--black)}
.pdp__actions{display:flex;gap:12px;margin:30px 0}
.qty{display:flex;align-items:center;border:1px solid var(--black);border-radius:var(--radius)}
.qty button{width:46px;height:50px;background:none;border:none;font-size:18px;cursor:pointer;font-family:'Inter',sans-serif}
.qty input{width:46px;text-align:center;border:none;outline:none;font-family:'Inter',sans-serif;font-size:15px}
.pdp__meta{font-size:13px;color:var(--mid);line-height:1.9}

/* Generic data table (cart) */
.cart-table{width:100%;border-collapse:collapse;margin-bottom:30px}
.cart-table th{text-align:left;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--mid);padding:0 0 16px;border-bottom:1px solid var(--border)}
.cart-table td{padding:20px 0;border-bottom:1px solid var(--border);vertical-align:middle}
.cart-table .ci{display:flex;gap:16px;align-items:center}
.cart-table .ci .ph{width:84px;aspect-ratio:1;flex:none}
.cart-table .ci .ph span{font-size:9px;padding:2px 5px}
.cart-table .ci .crumb{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--mid)}
.cart-table .ci .name{font-weight:500}
.cart-table .right{text-align:right}
.cart-remove{color:var(--mid);cursor:pointer}
.cart-remove:hover{color:var(--sale)}
.cart-layout{display:grid;grid-template-columns:1fr 360px;gap:50px;padding-bottom:80px}
.summary{background:var(--off-white);border-radius:var(--radius);padding:30px}
.summary h3{font-size:20px;margin-bottom:20px}
.summary .row{display:flex;justify-content:space-between;padding:9px 0;font-size:14px;color:#555}
.summary .row.total{border-top:1px solid var(--border);margin-top:10px;padding-top:16px;font-size:17px;font-weight:700;color:var(--black)}
.summary .btn{width:100%;text-align:center;margin-top:20px}

/* Checkout / forms */
.checkout-layout{display:grid;grid-template-columns:1fr 380px;gap:50px;padding-bottom:80px}
.form-section{margin-bottom:34px}
.form-section h3{font-size:18px;margin-bottom:18px;padding-bottom:12px;border-bottom:1px solid var(--border)}
.field{margin-bottom:16px}
.field label{display:block;font-size:12px;letter-spacing:.04em;text-transform:uppercase;color:#555;margin-bottom:7px}
.field input,.field select,.field textarea{
  width:100%;font-family:'Inter',sans-serif;font-size:14px;
  padding:12px 14px;border:1px solid var(--border);border-radius:var(--radius);
  background:var(--white);color:var(--black);outline:none;transition:.15s;
}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--black)}
.field textarea{min-height:130px;resize:vertical}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.pay-methods{display:flex;flex-direction:column;gap:10px}
.pay-opt{display:flex;align-items:center;gap:12px;border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;cursor:pointer;font-size:14px}
.pay-opt:hover{border-color:var(--black)}

/* Contact */
.contact-layout{display:grid;grid-template-columns:1fr 1fr;gap:56px;padding-bottom:80px}
.contact-info .ci-item{margin-bottom:24px}
.contact-info h4{font-size:12px;letter-spacing:.08em;text-transform:uppercase;margin-bottom:6px;color:var(--mid)}
.contact-info p{font-size:15px}

/* Blog */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;padding-bottom:80px}
.post{display:block;color:inherit}
.post .ph{margin-bottom:16px}
.post .meta{font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--accent);font-weight:700;margin-bottom:8px}
.post h3{font-size:21px;margin-bottom:8px;transition:.15s}
.post:hover h3{color:var(--accent)}
.post p{font-size:14px;color:#666}

/* Article + prose */
.article{max-width:760px;margin:0 auto;padding-bottom:80px}
.article .ph{margin:0 0 32px}
.prose{max-width:760px;margin:0 auto;padding-bottom:80px;color:#444}
.prose h2{font-size:26px;margin:34px 0 12px;color:var(--black)}
.prose h3{font-size:19px;margin:24px 0 10px;color:var(--black)}
.prose p{margin-bottom:16px}
.prose ul{margin:0 0 16px 22px}
.prose li{margin-bottom:8px}
.prose a{color:var(--black);text-decoration:underline;text-decoration-color:var(--accent);text-underline-offset:3px}

/* Notice band */
.notice{background:var(--off-white);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:var(--radius);padding:18px 22px;font-size:14px;color:#555;margin-bottom:30px}

/* ---------- Softened corners (radius 8) ---------- */
.ph,
.btn,
.hamburger,
.cat-card .ph,
.hero .ph,
.product .ph,
.banner,
.banner .ph,
.product .badge,
.search__suggest a,
.cart__item .ph,
.feature{border-radius:var(--radius)}
.nav .l2,.nav .l3{border-radius:var(--radius);overflow:hidden}
.newsletter form{border-radius:var(--radius);overflow:hidden}
.drawer--left{border-radius:0 var(--radius) var(--radius) 0}
.drawer--right{border-radius:var(--radius) 0 0 var(--radius)}
.drawer--top{border-radius:0 0 var(--radius) var(--radius)}
.search__input{border-radius:var(--radius)}

/* ---------- Responsive ---------- */
@media(max-width:980px){
  .hero__grid,.banners,.features,.pdp,.contact-layout{grid-template-columns:1fr}
  .cat-grid,.product-grid,.blog-grid{grid-template-columns:repeat(2,1fr)}
  .shop__main .product-grid{grid-template-columns:repeat(2,1fr)}
  .footer__grid{grid-template-columns:1fr 1fr}
  .nav{display:none}
  .hero__copy h1{font-size:42px}
  .shop,.cart-layout,.checkout-layout{grid-template-columns:1fr}
}
@media(max-width:560px){
  .cat-grid,.product-grid,.blog-grid,.shop__main .product-grid{grid-template-columns:1fr}
  .footer__grid{grid-template-columns:1fr}
  .field-row{grid-template-columns:1fr}
}
