/* ============================================================
   SUPERMAMA — Premium Motherhood E-Commerce
   Design System & Styles
   ============================================================ */

/* --- Fonts --- */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap');

/* --- CSS Variables --- */
:root {
  --clr-bg:         #FDF8F4;
  --clr-bg-warm:    #F5E9DD;
  --clr-bg-hero:    #F0E2D4;
  --clr-white:      #FFFFFF;
  --clr-card:       #FFFFFF;
  --clr-border:     #E8DDD4;
  --clr-text:       #2D2A26;
  --clr-text-muted: #6B6560;
  --clr-text-light: #9B938C;
  --clr-accent:     #A65C5C;
  --clr-accent-hover:#8E4E4E;
  --clr-accent-light:#D4A0A0;
  --clr-badge-new:  #A65C5C;
  --clr-star:       #E8B94A;
  --clr-telegram:   #229ED9;
  --clr-telegram-hover:#1B87B8;
  --clr-success:    #5BA65C;
  --clr-overlay:    rgba(45,42,38,0.55);

  --radius-sm:   8px;
  --radius-md:   16px;
  --radius-lg:   24px;
  --radius-xl:   32px;
  --radius-full: 999px;

  --shadow-sm:   0 1px 3px rgba(45,42,38,0.06);
  --shadow-md:   0 4px 16px rgba(45,42,38,0.08);
  --shadow-lg:   0 8px 32px rgba(45,42,38,0.12);
  --shadow-card: 0 2px 12px rgba(45,42,38,0.07);
  --shadow-btn:  0 2px 8px rgba(166,92,92,0.25);

  --font-main: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  --container:  1280px;
  --header-h:   72px;
  --topbar-h:   36px;
  --transition: 0.3s cubic-bezier(0.4,0,0.2,1);
}

/* --- Reset --- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--font-main);font-size:16px;line-height:1.6;color:var(--clr-text);background:var(--clr-bg);-webkit-font-smoothing:antialiased;overflow-x:hidden}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button,input,select,textarea{font:inherit;border:none;background:none;outline:none}
ul,ol{list-style:none}
h1,h2,h3,h4,h5,h6{line-height:1.2;font-weight:700}

/* --- Utilities --- */
.container{max-width:var(--container);margin:0 auto;padding:0 24px}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);border:0}

/* ============================================================
   TOP BAR
   ============================================================ */
.top-bar{
  background:var(--clr-accent);color:var(--clr-white);
  height:var(--topbar-h);display:flex;align-items:center;
  font-size:13px;letter-spacing:0.03em;font-weight:600;
}
.top-bar-inner{display:flex;align-items:center;justify-content:space-between;width:100%}
.top-bar-links{display:flex;gap:20px}
.top-bar-links a{color:#fff;transition:opacity var(--transition);font-weight:600}
.top-bar-links a:hover{opacity:0.8}
.top-bar-right{display:none}

/* ============================================================
   MAIN HEADER
   ============================================================ */
.main-header{
  background:var(--clr-white);height:var(--header-h);
  position:sticky;top:0;z-index:1000;
  border-bottom:1px solid var(--clr-border);
  transition:box-shadow var(--transition);
}
.main-header.scrolled{box-shadow:var(--shadow-md)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:100%}

.logo{
  display:inline-flex;align-items:center;flex-shrink:0;
}
.logo img{
  height:30px;width:auto;display:block;
}
.footer-brand .logo img{
  height:32px;filter:brightness(0) invert(1);
}
.main-nav{display:flex;gap:32px;align-items:center}
.main-nav a{
  font-size:14px;font-weight:500;color:var(--clr-text-muted);
  transition:color var(--transition);position:relative;
}
.main-nav a::after{
  content:'';position:absolute;bottom:-4px;left:0;width:0;
  height:2px;background:var(--clr-accent);
  transition:width var(--transition);
}
.main-nav a:hover,
.main-nav a.active{color:var(--clr-text)}
.main-nav a:hover::after,
.main-nav a.active::after{width:100%}

/* Mega Menu */
.nav-mega-wrap{position:relative;display:flex;align-items:center;height:100%}
.nav-mega-wrap>a{
  font-size:14px;font-weight:500;color:var(--clr-text-muted);
  transition:color var(--transition);position:relative;
  display:flex;align-items:center;height:100%;
}
.nav-mega-wrap>a::after{
  content:'';position:absolute;bottom:0;left:0;width:0;
  height:2px;background:var(--clr-accent);transition:width var(--transition);
}
.nav-mega-wrap:hover>a,.nav-mega-wrap>a.active,.nav-mega-wrap.mega-open>a{color:var(--clr-text)}
.nav-mega-wrap:hover>a::after,.nav-mega-wrap>a.active::after,.nav-mega-wrap.mega-open>a::after{width:100%}
.mega-menu{
  display:none;position:fixed;left:50%;transform:translateX(-50%);
  width:680px;
  background:#fff;box-shadow:0 12px 40px rgba(0,0,0,0.10);
  border-top:2px solid var(--clr-accent);border-radius:0 0 var(--radius-md) var(--radius-md);
  padding:20px 0 16px;z-index:2000;
}
.mega-menu.mega-visible{display:block}
.mega-menu a{position:static;font-size:inherit;font-weight:inherit;color:inherit}
.mega-menu a::after{display:none}
.mega-menu-inner{
  padding:0 24px;
  display:grid;grid-template-columns:160px 1fr;gap:20px;
}
.mega-categories{display:flex;flex-direction:column;gap:0;border-right:1px solid var(--clr-border);padding-right:16px}
.mega-cat-btn{
  padding:7px 12px;font-size:13px;font-weight:500;color:var(--clr-text-muted);
  border:none;background:none;text-align:left;cursor:pointer;
  border-radius:var(--radius-sm);transition:all 0.15s;white-space:nowrap;
}
.mega-cat-btn:hover,.mega-cat-btn.active{background:var(--clr-bg);color:var(--clr-text);font-weight:600}
.mega-products{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.mega-product-card{
  display:flex;flex-direction:column;text-decoration:none;
  border-radius:var(--radius-sm);overflow:hidden;
  transition:box-shadow 0.2s,transform 0.2s;
}
.mega-product-card:hover{box-shadow:var(--shadow-sm);transform:translateY(-1px)}
.mega-product-card img{
  width:100%;aspect-ratio:1/1;object-fit:cover;
  background:var(--clr-bg);border-radius:var(--radius-sm);
}
.mega-product-card .mega-card-info{padding:6px 2px}
.mega-product-card .mega-card-name{
  font-size:12px;font-weight:500;color:var(--clr-text);
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
  line-height:1.3;
}
.mega-product-card .mega-card-meta{font-size:10px;color:var(--clr-text-light);margin-top:2px}
.mega-footer{
  grid-column:1/-1;display:flex;justify-content:center;
  padding-top:12px;border-top:1px solid var(--clr-border);margin-top:4px;
}
.mega-footer a{
  font-size:13px;font-weight:600;color:var(--clr-accent);
  text-decoration:none;transition:opacity 0.15s;
}
.mega-footer a:hover{opacity:0.7}

.header-actions{display:flex;align-items:center;gap:8px}
/* TODO: unhide when search is ready */
.search-bar{
  display:flex;align-items:center;background:var(--clr-bg);
  border-radius:var(--radius-full);padding:8px 16px;gap:8px;
  border:1px solid transparent;transition:border-color var(--transition);
  position:relative;
}
.search-bar:focus-within{border-color:var(--clr-accent-light)}
.search-bar input{
  border:none;background:transparent;font-size:13px;width:160px;
  color:var(--clr-text);
}
.search-bar input::placeholder{color:var(--clr-text-light)}
.search-bar svg{width:16px;height:16px;color:var(--clr-text-light);flex-shrink:0}

.search-results{
  display:none;position:absolute;top:calc(100% + 8px);left:0;right:0;
  background:#fff;border-radius:var(--radius-md);box-shadow:0 8px 32px rgba(0,0,0,0.12);
  z-index:3000;max-height:420px;overflow-y:auto;min-width:320px;
}
.search-results.active{display:block}
.search-results-group{padding:8px 0}
.search-results-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:0.06em;color:var(--clr-text-light);padding:8px 16px 4px}
a.search-result-item{text-decoration:none}
.search-result-item{display:flex;align-items:center;gap:12px;padding:10px 16px;cursor:pointer;transition:background 0.15s}
.search-result-item:hover{background:var(--clr-bg)}
.search-result-item img{width:44px;height:44px;border-radius:var(--radius-sm);object-fit:cover;flex-shrink:0}
.search-result-item .sr-icon{width:44px;height:44px;border-radius:var(--radius-sm);background:var(--clr-bg);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.search-result-item .sr-icon svg{width:20px;height:20px;color:var(--clr-text-light)}
.search-result-item .sr-info{flex:1;min-width:0}
.search-result-item .sr-name{font-size:14px;font-weight:500;color:var(--clr-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.search-result-item .sr-meta{font-size:12px;color:var(--clr-text-light);margin-top:2px}
.search-no-results{padding:24px 16px;text-align:center;color:var(--clr-text-light);font-size:14px}

.icon-btn{
  display:none !important;
  width:40px;height:40px;border-radius:50%;
  align-items:center;justify-content:center;cursor:pointer;
  transition:background var(--transition);position:relative;
}
.icon-btn:hover{background:var(--clr-bg)}
.icon-btn svg{width:20px;height:20px;color:var(--clr-text-muted)}
.cart-badge{
  position:absolute;top:4px;right:4px;
  background:var(--clr-accent);color:#fff;
  font-size:10px;font-weight:700;
  width:16px;height:16px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
}

.burger-btn{
  display:none;width:40px;height:40px;
  align-items:center;justify-content:center;cursor:pointer;
}
.burger-btn svg{width:24px;height:24px;color:var(--clr-text)}

/* Mobile search */
.mobile-search{display:none;padding:8px 0 12px;background:var(--clr-white);border-bottom:1px solid var(--clr-border)}
.mobile-search .search-bar{width:100%}
.mobile-search .search-bar input{width:100%}

/* Mobile menu overlay */
.mobile-menu-overlay{
  display:none;position:fixed;inset:0;
  background:rgba(0,0,0,0.4);z-index:2000;
  opacity:0;transition:opacity var(--transition);
}
.mobile-menu-overlay.open{display:block;opacity:1}

.mobile-menu{
  position:fixed;top:0;left:-300px;width:280px;height:100%;
  background:var(--clr-white);z-index:2001;
  padding:24px;overflow-y:auto;
  transition:left var(--transition);
}
.mobile-menu.open{left:0}
.mobile-menu-close{
  position:absolute;top:16px;right:16px;
  width:32px;height:32px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
}
.mobile-menu-close svg{width:20px;height:20px}
.mobile-menu .logo{display:block;margin-bottom:32px}
.mobile-menu nav{display:flex;flex-direction:column;gap:0}
.mobile-menu nav a{
  padding:14px 0;font-size:16px;font-weight:500;
  border-bottom:1px solid var(--clr-border);
  color:var(--clr-text);
}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:14px 28px;border-radius:var(--radius-full);
  font-size:14px;font-weight:600;cursor:pointer;
  transition:all var(--transition);text-align:center;
}
.btn-primary{
  background:#7000FF;color:#fff;
  box-shadow:0 2px 8px rgba(112,0,255,0.3);
}
.btn-primary:hover{background:#5C00D6;transform:translateY(-1px)}
.btn-secondary{
  background:var(--clr-white);color:var(--clr-text);
  border:1.5px solid var(--clr-border);
}
.btn-secondary:hover{border-color:var(--clr-accent);color:var(--clr-accent)}
.btn-outline{
  background:transparent;color:var(--clr-accent);
  border:1.5px solid var(--clr-accent);
}
.btn-outline:hover{background:var(--clr-accent);color:#fff}
.btn-white{
  background:#fff;color:var(--clr-text);
  box-shadow:var(--shadow-md);
}
.btn-white:hover{transform:translateY(-1px);box-shadow:var(--shadow-lg)}
.btn-telegram{
  background:var(--clr-telegram);color:#fff;
}
.btn-telegram:hover{background:var(--clr-telegram-hover)}
.btn-sm{padding:10px 20px;font-size:13px}
.btn-lg{padding:16px 36px;font-size:16px}
.btn-block{width:100%}

.link-arrow{
  font-size:14px;font-weight:500;color:var(--clr-accent);
  display:inline-flex;align-items:center;gap:4px;
  transition:gap var(--transition);
}
.link-arrow:hover{gap:8px}

/* ============================================================
   CHIPS / PILLS
   ============================================================ */
.chips{display:flex;flex-wrap:wrap;gap:8px}
.chip{
  padding:8px 18px;border-radius:var(--radius-full);
  font-size:13px;font-weight:500;cursor:pointer;
  background:var(--clr-white);color:var(--clr-text-muted);
  border:1.5px solid var(--clr-border);
  transition:all var(--transition);white-space:nowrap;
}
.chip:hover,.chip.active{
  background:var(--clr-accent);color:#fff;border-color:var(--clr-accent);
}

/* ============================================================
   SECTION HELPERS
   ============================================================ */
.section{padding:80px 0}
.section-sm{padding:48px 0}
.section-title{font-size:32px;font-weight:700;margin-bottom:8px}
.section-subtitle{font-size:16px;color:var(--clr-text-muted);margin-bottom:32px}
.section-header{display:flex;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;gap:16px;margin-bottom:32px}
.section-header .section-title{margin-bottom:0}

/* ============================================================
   HERO — DESKTOP (Split Layout)
   ============================================================ */
.hero{
  background:linear-gradient(135deg,var(--clr-bg-warm) 0%,var(--clr-bg-hero) 50%,#EDD5C5 100%);
  overflow:hidden;
}
.hero-inner{display:flex;align-items:center;min-height:580px;gap:48px}
.hero-left{flex:1;padding:64px 0}
.hero-left h1{
  font-size:48px;font-weight:800;line-height:1.15;
  margin-bottom:16px;max-width:540px;
}
.hero-left .subtitle{
  font-size:17px;color:var(--clr-text-muted);margin-bottom:24px;max-width:440px;
}
.hero-chips{margin-bottom:28px}
.hero-actions{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.hero-link{
  font-size:14px;color:var(--clr-accent);font-weight:500;
  border-bottom:1px dashed var(--clr-accent-light);
  transition:border-color var(--transition);
}
.hero-link:hover{border-color:var(--clr-accent)}

.hero-right{
  flex:1;position:relative;display:flex;
  align-items:center;justify-content:center;
  min-height:480px;
}
.hero-image-placeholder{
  width:100%;max-width:480px;aspect-ratio:4/5;
  border-radius:var(--radius-xl);
  background:linear-gradient(145deg,#E8D5C4 0%,#D4B8A0 40%,#C9A68E 100%);
  position:relative;overflow:hidden;
}

.hero-float-card{
  position:absolute;background:#fff;border-radius:var(--radius-md);
  padding:16px 20px;box-shadow:var(--shadow-lg);
  display:flex;align-items:center;gap:12px;
  animation:floatSlow 6s ease-in-out infinite;
}
.hero-float-card.card-top{top:60px;right:-20px;animation-delay:-2s}
.hero-float-card.card-bottom{bottom:80px;left:-20px}
.float-icon{
  width:40px;height:40px;border-radius:12px;
  background:linear-gradient(135deg,var(--clr-accent-light),var(--clr-accent));
  display:flex;align-items:center;justify-content:center;
}
.float-icon svg{width:20px;height:20px;color:#fff}
.float-text{font-size:12px;line-height:1.4}
.float-text strong{display:block;font-size:14px}

@keyframes floatSlow{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-10px)}
}

/* Hero Mobile */
.hero-mobile{
  display:none;position:relative;
  overflow:hidden;
  background:linear-gradient(180deg,var(--clr-bg-warm) 0%,var(--clr-bg-hero) 50%,#E0CFC0 100%);
}
.hero-mobile-bg{
  position:absolute;inset:0;display:flex;
  align-items:center;justify-content:center;
  pointer-events:none;
}
.hero-mobile-big-text{
  font-size:clamp(100px,22vw,180px);font-weight:900;
  color:rgba(255,255,255,0.15);letter-spacing:-0.03em;
  user-select:none;
}
.hero-mobile-content{
  position:relative;z-index:2;display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  text-align:center;padding:60px 20px 40px;min-height:auto;
}
.hero-mobile-label{
  font-size:12px;font-weight:600;letter-spacing:0.1em;
  text-transform:uppercase;color:var(--clr-text-muted);margin-bottom:16px;
}
.hero-mobile-product{
  width:80vw;max-width:340px;aspect-ratio:3/4;border-radius:var(--radius-lg);
  overflow:hidden;margin:16px auto 24px;
  background:var(--clr-bg-warm);
  box-shadow:0 8px 32px rgba(0,0,0,0.1);
}
.hero-mobile-product img{
  width:100%;height:100%;object-fit:cover;display:block;
}
.hero-mobile-title{
  font-size:26px;font-weight:700;line-height:1.3;
  margin:0 auto 12px;max-width:340px;width:100%;
}
.hero-mobile-stats{
  font-size:16px;color:var(--clr-text-muted);line-height:1.8;
  margin:0 auto 28px;max-width:340px;width:100%;
}
.hero-mobile-cta{
  display:inline-flex;align-items:center;justify-content:center;
  padding:16px 40px;border-radius:var(--radius-full);
  background:#7000FF;color:#fff;font-weight:600;
  box-shadow:0 4px 16px rgba(112,0,255,0.3);font-size:15px;
  transition:all var(--transition);
}
.hero-mobile-cta:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(112,0,255,0.35)}

/* ============================================================
   PRODUCT CARDS
   ============================================================ */
.product-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:24px;
}
.product-card{
  background:var(--clr-card);border-radius:var(--radius-md);
  overflow:hidden;transition:all var(--transition);
  box-shadow:var(--shadow-card);position:relative;
  display:flex;flex-direction:column;
}
.product-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.product-card-image{
  aspect-ratio:1;position:relative;overflow:hidden;
  background:linear-gradient(135deg,var(--clr-bg-warm),#E2D0C2);
}
.product-card-image img{
  width:100%;height:100%;object-fit:cover;display:block;
}
.product-badge{
  position:absolute;top:12px;left:12px;z-index:2;
  padding:4px 12px;border-radius:var(--radius-full);
  font-size:11px;font-weight:700;text-transform:uppercase;
  letter-spacing:0.04em;
}
.badge-new{background:var(--clr-badge-new);color:#fff}
.badge-sale{background:var(--clr-star);color:#fff}
.product-card-body{padding:16px;display:flex;flex-direction:column;flex:1}
.product-card-name{font-size:15px;font-weight:600;margin-bottom:6px;line-height:1.3}
.product-card-rating{display:flex;align-items:center;gap:6px;margin-bottom:8px;font-size:13px;color:var(--clr-text-muted);flex-wrap:nowrap}
.reviews-count{display:inline-flex;align-items:center;gap:3px;white-space:nowrap}
.reviews-count svg{width:13px;height:13px;flex-shrink:0}
.product-card-rating .stars{color:var(--clr-star);display:flex;gap:1px}
.product-card-rating .stars svg{width:14px;height:14px}
.product-card-tags{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:12px}
.product-tag{
  padding:3px 10px;border-radius:var(--radius-full);
  font-size:11px;background:var(--clr-bg);color:var(--clr-text-muted);
}
.product-card .btn{width:100%;margin-top:auto}
.product-card .btn-primary{
  background:var(--clr-accent);box-shadow:var(--shadow-btn);
}
.product-card .btn-primary:hover{background:var(--clr-accent-hover)}

/* Grid animation */
.product-card.fade-in{animation:cardFadeIn 0.4s ease forwards}
.product-card.fade-out{animation:cardFadeOut 0.25s ease forwards}
@keyframes cardFadeIn{
  from{opacity:0;transform:scale(0.95) translateY(10px)}
  to{opacity:1;transform:scale(1) translateY(0)}
}
@keyframes cardFadeOut{
  from{opacity:1;transform:scale(1)}
  to{opacity:0;transform:scale(0.95)}
}

/* ============================================================
   CATEGORY CARDS (Shop by Category)
   ============================================================ */
.category-scroll-wrap{position:relative}
.category-scroll{
  display:flex;gap:20px;overflow-x:auto;scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;scrollbar-width:none;padding:8px 0;
}
.category-scroll::-webkit-scrollbar{display:none}
.category-card{
  flex:0 0 180px;scroll-snap-align:start;text-align:center;
  cursor:pointer;transition:transform var(--transition);
}
.category-card:hover{transform:translateY(-4px)}
.category-card-img{
  width:100%;aspect-ratio:1;border-radius:var(--radius-lg);
  background:var(--clr-bg-warm);
  margin-bottom:12px;position:relative;overflow:hidden;
}
.category-card-img img{
  width:100%;height:100%;object-fit:cover;display:block;
}
.category-card-title{font-size:14px;font-weight:600}

.scroll-btn{
  position:absolute;top:50%;transform:translateY(-60%);
  width:44px;height:44px;border-radius:50%;
  background:var(--clr-white);box-shadow:var(--shadow-md);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;z-index:10;transition:all var(--transition);
  border:1px solid var(--clr-border);
}
.scroll-btn:hover{box-shadow:var(--shadow-lg);background:var(--clr-bg)}
.scroll-btn svg{width:20px;height:20px;color:var(--clr-text)}
.scroll-btn-left{left:-22px}
.scroll-btn-right{right:-22px}

/* ============================================================
   TRUST STRIP
   ============================================================ */
.trust-strip{
  background:var(--clr-white);border-radius:var(--radius-lg);
  padding:48px;box-shadow:var(--shadow-sm);
  display:grid;grid-template-columns:repeat(4,1fr);gap:32px;
  text-align:center;
}
.trust-item svg{width:40px;height:40px;color:var(--clr-accent);margin:0 auto 12px}
.trust-item h4{font-size:15px;font-weight:600;margin-bottom:6px}
.trust-item p{font-size:13px;color:var(--clr-text-muted);line-height:1.5}

/* ============================================================
   BENEFITS CARDS
   ============================================================ */
.benefits-grid{
  display:grid;grid-template-columns:repeat(5,1fr);gap:20px;
}
.benefit-card{
  background:var(--clr-card);border-radius:var(--radius-md);
  padding:28px 20px;text-align:center;
  box-shadow:var(--shadow-card);transition:all var(--transition);
}
.benefit-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.benefit-card svg{width:36px;height:36px;color:var(--clr-accent);margin:0 auto 14px}
.benefit-card h4{font-size:14px;font-weight:600;margin-bottom:6px}
.benefit-card p{font-size:13px;color:var(--clr-text-muted);line-height:1.4}

/* ============================================================
   STEPS (How it Works)
   ============================================================ */
.steps-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.step-card{text-align:center;padding:32px 20px}
.step-number{
  width:56px;height:56px;border-radius:50%;
  background:var(--clr-accent);color:#fff;
  font-size:22px;font-weight:700;
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 20px;
}
.step-card h4{font-size:17px;font-weight:600;margin-bottom:8px}
.step-card p{font-size:14px;color:var(--clr-text-muted);line-height:1.6}

/* ============================================================
   REVIEWS
   ============================================================ */
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.review-card{
  background:var(--clr-card);border-radius:var(--radius-md);
  padding:28px;box-shadow:var(--shadow-card);
}
.review-card-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.review-avatar{
  width:44px;height:44px;border-radius:50%;
  background:linear-gradient(135deg,var(--clr-accent-light),var(--clr-accent));
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-weight:700;font-size:16px;
}
.review-name{font-weight:600;font-size:15px}
.review-date{font-size:12px;color:var(--clr-text-light)}
.review-stars{display:flex;gap:2px;margin-bottom:12px}
.review-stars svg{width:16px;height:16px;color:var(--clr-star)}
.review-text{font-size:14px;color:var(--clr-text-muted);line-height:1.6}

/* ============================================================
   CTA BANNER
   ============================================================ */
.cta-banner{
  background:linear-gradient(135deg,var(--clr-accent) 0%,#C47A7A 100%);
  border-radius:var(--radius-lg);padding:64px 48px;
  text-align:center;color:#fff;
}
.cta-banner h2{font-size:32px;font-weight:700;margin-bottom:12px}
.cta-banner p{font-size:16px;opacity:0.9;margin-bottom:28px;max-width:500px;margin-left:auto;margin-right:auto}
.cta-banner .btn-white{color:var(--clr-accent)}

/* ============================================================
   ABOUT PAGE
   ============================================================ */
.page-hero{
  background:linear-gradient(135deg,var(--clr-bg-warm),var(--clr-bg-hero));
  padding:80px 0;text-align:center;
}
.page-hero h1{font-size:42px;margin-bottom:12px}
.page-hero p{font-size:17px;color:var(--clr-text-muted);max-width:560px;margin:0 auto}

.about-story{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.about-story-text h2{font-size:28px;margin-bottom:16px}
.about-story-text p{font-size:15px;color:var(--clr-text-muted);line-height:1.7;margin-bottom:12px}
.about-story-img{
  aspect-ratio:4/3;border-radius:var(--radius-lg);
  background:linear-gradient(145deg,var(--clr-bg-warm),#D4B8A0);
}

.trust-cards-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.trust-card{
  background:var(--clr-card);border-radius:var(--radius-md);
  padding:32px 24px;text-align:center;box-shadow:var(--shadow-card);
}
.trust-card svg{width:40px;height:40px;color:var(--clr-accent);margin:0 auto 14px}
.trust-card h4{font-size:16px;font-weight:600;margin-bottom:8px}
.trust-card p{font-size:14px;color:var(--clr-text-muted);line-height:1.5}

.timeline{display:flex;align-items:flex-start;justify-content:space-between;position:relative;padding:40px 0}
.timeline::before{
  content:'';position:absolute;top:28px;left:0;right:0;
  height:2px;background:var(--clr-border);
}
.timeline-step{
  text-align:center;position:relative;flex:1;padding:0 16px;
}
.timeline-dot{
  width:56px;height:56px;border-radius:50%;
  background:var(--clr-accent);color:#fff;
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 16px;position:relative;z-index:2;
  font-weight:700;font-size:18px;
}
.timeline-step h4{font-size:15px;font-weight:600;margin-bottom:4px}
.timeline-step p{font-size:13px;color:var(--clr-text-muted)}

/* ============================================================
   PRODUCTS PAGE (Catalog)
   ============================================================ */
.catalog-controls{
  display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-bottom:32px;
}
.catalog-search{
  display:none !important;align-items:center;background:var(--clr-white);
  border:1.5px solid var(--clr-border);border-radius:var(--radius-full);
  padding:10px 18px;gap:8px;flex:1;max-width:360px;
  transition:border-color var(--transition);
}
.catalog-search:focus-within{border-color:var(--clr-accent)}
.catalog-search input{flex:1;font-size:14px;background:transparent}
.catalog-search svg{width:18px;height:18px;color:var(--clr-text-light);flex-shrink:0}
.catalog-sort{
  padding:10px 18px;border:1.5px solid var(--clr-border);
  border-radius:var(--radius-full);font-size:14px;cursor:pointer;
  background:var(--clr-white);color:var(--clr-text);min-width:160px;
}
.catalog-sort:focus{border-color:var(--clr-accent)}

/* ============================================================
   PRODUCT DETAIL PAGE
   ============================================================ */
.breadcrumbs{
  font-size:13px;color:var(--clr-text-muted);padding:16px 0;
  display:flex;flex-wrap:wrap;gap:4px;
}
.breadcrumbs a{color:var(--clr-text-muted);transition:color var(--transition)}
.breadcrumbs a:hover{color:var(--clr-accent)}
.breadcrumbs span{color:var(--clr-text-light)}

.product-detail{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
.product-gallery{position:relative}

.gallery-main{
  position:relative;border-radius:var(--radius-lg);
  overflow:hidden;background:linear-gradient(145deg,var(--clr-bg-warm),#D4B8A0);
  margin-bottom:16px;aspect-ratio:1;
}
.gallery-viewport{
  width:100%;height:100%;overflow:hidden;position:relative;
  touch-action:pan-y;
}
.gallery-track{
  display:flex;height:100%;
  transition:transform 0.4s cubic-bezier(0.4,0,0.2,1);
}
.gallery-track.dragging{transition:none}
.gallery-slide{
  flex:0 0 100%;height:100%;position:relative;
}
.gallery-slide img{
  width:100%;height:100%;object-fit:cover;display:block;
  user-select:none;-webkit-user-drag:none;
}

.gallery-arrow{
  position:absolute;top:50%;transform:translateY(-50%);
  width:40px;height:40px;border-radius:50%;z-index:5;
  background:rgba(255,255,255,0.85);backdrop-filter:blur(4px);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;border:none;
  box-shadow:0 2px 8px rgba(0,0,0,0.1);
  transition:all var(--transition);opacity:0;
}
.product-gallery:hover .gallery-arrow{opacity:1}
.gallery-arrow:hover{background:#fff;box-shadow:0 4px 16px rgba(0,0,0,0.15)}
.gallery-arrow svg{width:20px;height:20px;color:var(--clr-text)}
.gallery-prev{left:12px}
.gallery-next{right:12px}

.gallery-dots{
  position:absolute;bottom:16px;left:50%;transform:translateX(-50%);
  display:flex;gap:8px;z-index:5;
}
.gallery-dot{
  width:8px;height:8px;border-radius:50%;
  background:rgba(255,255,255,0.5);cursor:pointer;
  transition:all var(--transition);border:none;
}
.gallery-dot.active{background:#fff;transform:scale(1.25)}

.gallery-counter{
  position:absolute;top:16px;right:16px;z-index:5;
  background:rgba(0,0,0,0.45);color:#fff;
  font-size:12px;font-weight:600;
  padding:4px 10px;border-radius:var(--radius-full);
}

.gallery-fullscreen-btn{
  position:absolute;top:16px;left:16px;z-index:5;
  width:36px;height:36px;border-radius:50%;border:none;
  background:rgba(0,0,0,0.45);color:#fff;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:all var(--transition);
}
.gallery-fullscreen-btn:hover{background:rgba(0,0,0,0.7)}
.gallery-fullscreen-btn svg{width:16px;height:16px}

/* Lightbox */
.lightbox{
  display:none;position:fixed;inset:0;z-index:5000;
  background:rgba(0,0,0,0.92);
  align-items:center;justify-content:center;
}
.lightbox.open{display:flex}
.lightbox-close{
  position:absolute;top:20px;right:20px;z-index:5;
  width:44px;height:44px;border-radius:50%;border:none;
  background:rgba(255,255,255,0.15);color:#fff;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:background var(--transition);
}
.lightbox-close:hover{background:rgba(255,255,255,0.3)}
.lightbox-close svg{width:24px;height:24px}
.lightbox-image{
  max-width:90vw;max-height:85vh;display:flex;
  align-items:center;justify-content:center;
}
.lightbox-image img{
  max-width:100%;max-height:85vh;object-fit:contain;
  border-radius:var(--radius-sm);user-select:none;
}
.lightbox-arrow{
  position:absolute;top:50%;transform:translateY(-50%);
  width:48px;height:48px;border-radius:50%;border:none;
  background:rgba(255,255,255,0.15);color:#fff;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:background var(--transition);
}
.lightbox-arrow:hover{background:rgba(255,255,255,0.3)}
.lightbox-arrow svg{width:24px;height:24px}
.lightbox-prev{left:20px}
.lightbox-next{right:20px}
.lightbox-counter{
  position:absolute;bottom:24px;left:50%;transform:translateX(-50%);
  color:rgba(255,255,255,0.7);font-size:14px;font-weight:500;
}

.product-thumbs{display:flex;gap:10px;flex-wrap:wrap}
.product-thumb{
  width:72px;height:72px;border-radius:var(--radius-sm);
  overflow:hidden;border:2px solid transparent;cursor:pointer;
  transition:border-color var(--transition);
  background:linear-gradient(145deg,var(--clr-bg-warm),#E0CFC0);
}
.product-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.product-thumb:hover,.product-thumb.active{border-color:var(--clr-accent)}

.product-info h1{font-size:30px;margin-bottom:12px}
.product-info .product-card-rating{font-size:14px;margin-bottom:16px}
.product-info .short-desc{font-size:15px;color:var(--clr-text-muted);line-height:1.7;margin-bottom:20px}
.product-actions{display:flex;gap:12px;margin-top:24px;flex-wrap:wrap}

.product-section{padding:48px 0;border-top:1px solid var(--clr-border)}
.product-section h2{font-size:24px;margin-bottom:24px}

/* Rich product description blocks */
.pdp-block{margin-bottom:40px}
.pdp-block h3{font-size:20px;font-weight:700;margin-bottom:20px}

.pdp-features-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:16px;
}
.pdp-feature-card{
  background:var(--clr-card);border-radius:var(--radius-md);
  padding:24px;box-shadow:var(--shadow-card);
  transition:all var(--transition);
}
.pdp-feature-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.pdp-feature-icon{
  width:44px;height:44px;border-radius:12px;
  background:linear-gradient(135deg,var(--clr-accent-light),var(--clr-accent));
  display:flex;align-items:center;justify-content:center;
  margin-bottom:14px;
}
.pdp-feature-icon svg{width:22px;height:22px;color:#fff}
.pdp-feature-card h4{font-size:15px;font-weight:600;margin-bottom:6px}
.pdp-feature-card p{font-size:13px;color:var(--clr-text-muted);line-height:1.5}

.pdp-check-list{display:flex;flex-direction:column;gap:12px}
.pdp-check-list li{
  display:flex;align-items:flex-start;gap:12px;
  font-size:14px;color:var(--clr-text-muted);line-height:1.5;
}
.pdp-check-list li svg{
  width:20px;height:20px;color:var(--clr-accent);flex-shrink:0;margin-top:1px;
}

.pdp-advantages{display:flex;flex-wrap:wrap;gap:10px}
.pdp-advantage-chip{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 18px;border-radius:var(--radius-full);
  background:var(--clr-bg-warm);font-size:14px;font-weight:500;
  color:var(--clr-text);
}
.pdp-advantage-chip svg{width:16px;height:16px;color:var(--clr-accent)}

@media(max-width:768px){
  .pdp-features-grid{grid-template-columns:1fr}
}

.specs-table{width:100%;border-collapse:collapse}
.specs-table tr{border-bottom:1px solid var(--clr-border)}
.specs-table td{padding:14px 0;font-size:14px}
.specs-table td:first-child{font-weight:600;width:40%;color:var(--clr-text)}
.specs-table td:last-child{color:var(--clr-text-muted)}

.faq-list{max-width:720px}
.faq-item{border-bottom:1px solid var(--clr-border)}
.faq-question{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 0;cursor:pointer;font-weight:600;font-size:15px;
  transition:color var(--transition);
}
.faq-question:hover{color:var(--clr-accent)}
.faq-question svg{width:20px;height:20px;transition:transform var(--transition);flex-shrink:0}
.faq-item.open .faq-question svg{transform:rotate(180deg)}
.faq-answer{
  max-height:0;overflow:hidden;
  transition:max-height 0.4s ease,padding 0.3s ease;
}
.faq-item.open .faq-answer{max-height:200px;padding-bottom:18px}
.faq-answer p{font-size:14px;color:var(--clr-text-muted);line-height:1.7}

.related-products{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}

/* Sticky mobile bottom bar */
.product-sticky-bar{
  display:none;position:fixed;bottom:0;left:0;right:0;
  background:var(--clr-white);padding:12px 16px;
  box-shadow:0 -4px 20px rgba(0,0,0,0.08);z-index:900;
  gap:10px;
}
.product-sticky-bar .btn{flex:1;padding:14px 12px;font-size:13px}

/* ============================================================
   BLOG
   ============================================================ */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.blog-card{
  background:var(--clr-card);border-radius:var(--radius-md);
  overflow:hidden;box-shadow:var(--shadow-card);
  transition:all var(--transition);
}
.blog-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.blog-card-image{
  aspect-ratio:16/10;
  background:linear-gradient(135deg,var(--clr-bg-warm),#D4B8A0);
  position:relative;
}
.blog-card-body{padding:20px}
.blog-card-meta{font-size:12px;color:var(--clr-text-light);margin-bottom:8px;display:flex;gap:12px}
.blog-card-title{font-size:17px;font-weight:600;margin-bottom:8px;line-height:1.4}
.blog-card-excerpt{font-size:14px;color:var(--clr-text-muted);line-height:1.6;margin-bottom:12px}

/* Post Page */
.post-layout{display:grid;grid-template-columns:1fr 320px;gap:48px;align-items:start}
.post-content{max-width:100%}
.post-cover{
  aspect-ratio:16/9;border-radius:var(--radius-lg);
  background:linear-gradient(135deg,var(--clr-bg-warm),#D4B8A0);
  margin-bottom:32px;
}
.post-meta{font-size:13px;color:var(--clr-text-light);margin-bottom:24px;display:flex;gap:16px}
.post-content h1{font-size:34px;margin-bottom:16px}
.post-content h2{font-size:24px;margin-top:32px;margin-bottom:12px}
.post-content h3{font-size:20px;margin-top:24px;margin-bottom:8px}
.post-content p{font-size:15px;line-height:1.8;color:var(--clr-text-muted);margin-bottom:16px}
.post-content ul,.post-content ol{margin:16px 0;padding-left:24px}
.post-content li{font-size:15px;line-height:1.7;color:var(--clr-text-muted);margin-bottom:8px;list-style:disc}

.post-sidebar{position:sticky;top:calc(var(--header-h) + var(--topbar-h) + 24px)}
.sidebar-box{
  background:var(--clr-card);border-radius:var(--radius-md);
  padding:24px;box-shadow:var(--shadow-card);margin-bottom:24px;
}
.sidebar-box h3{font-size:16px;font-weight:600;margin-bottom:16px}
.sidebar-box a{
  display:block;font-size:14px;color:var(--clr-text-muted);
  padding:10px 0;border-bottom:1px solid var(--clr-border);
  transition:color var(--transition);
}
.sidebar-box a:last-child{border-bottom:none}
.sidebar-box a:hover{color:var(--clr-accent)}

.share-btns{display:flex;gap:8px;margin-top:24px}
.share-btn{
  width:40px;height:40px;border-radius:50%;
  background:var(--clr-bg);display:flex;
  align-items:center;justify-content:center;
  transition:background var(--transition);cursor:pointer;
}
.share-btn:hover{background:var(--clr-accent-light)}
.share-btn svg{width:18px;height:18px;color:var(--clr-text-muted)}

/* ============================================================
   CONTACTS PAGE
   ============================================================ */
.contacts-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
.contact-blocks{display:grid;gap:20px}
.contact-block{
  background:var(--clr-card);border-radius:var(--radius-md);
  padding:24px;box-shadow:var(--shadow-card);
  display:flex;align-items:flex-start;gap:16px;
}
.contact-block-icon{
  width:44px;height:44px;border-radius:12px;flex-shrink:0;
  background:linear-gradient(135deg,var(--clr-accent-light),var(--clr-accent));
  display:flex;align-items:center;justify-content:center;
}
.contact-block-icon svg{width:20px;height:20px;color:#fff}
.contact-block h4{font-size:15px;font-weight:600;margin-bottom:4px}
.contact-block p{font-size:14px;color:var(--clr-text-muted)}

.contact-form{
  background:var(--clr-card);border-radius:var(--radius-md);
  padding:32px;box-shadow:var(--shadow-card);
}
.contact-form h3{font-size:20px;margin-bottom:20px}
.form-group{margin-bottom:18px}
.form-group label{display:block;font-size:13px;font-weight:600;margin-bottom:6px}
.form-input{
  width:100%;padding:12px 16px;border-radius:var(--radius-sm);
  border:1.5px solid var(--clr-border);font-size:14px;
  transition:border-color var(--transition);background:var(--clr-bg);
}
.form-input:focus{border-color:var(--clr-accent);background:#fff}
textarea.form-input{min-height:120px;resize:vertical}
.form-error{font-size:12px;color:var(--clr-accent);margin-top:4px;display:none}
.form-group.error .form-error{display:block}
.form-group.error .form-input{border-color:var(--clr-accent)}
.form-success{
  display:none;padding:16px;border-radius:var(--radius-sm);
  background:#e8f5e9;color:var(--clr-success);
  font-size:14px;font-weight:500;margin-top:16px;
}

.map-placeholder{
  aspect-ratio:16/9;border-radius:var(--radius-lg);
  background:linear-gradient(135deg,#e0e0e0,#c0c0c0);
  display:flex;align-items:center;justify-content:center;
  color:var(--clr-text-light);font-size:15px;margin-top:32px;
}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{
  background:var(--clr-text);color:rgba(255,255,255,0.8);
  padding:48px 0 24px;margin-top:80px;
}
.footer-inner{
  display:grid;grid-template-columns:1fr auto auto;gap:40px;
  align-items:start;
}
.footer-brand .logo{color:#fff;margin-bottom:8px}
.footer-brand p{font-size:14px;opacity:0.7;max-width:260px}
.footer-links{display:flex;flex-direction:column;gap:10px}
.footer-links a{font-size:14px;transition:color var(--transition)}
.footer-links a:hover{color:#fff}
.footer-support{display:flex;flex-direction:column;gap:12px;align-items:flex-start}
.footer-copy{
  grid-column:1/-1;border-top:1px solid rgba(255,255,255,0.1);
  padding-top:20px;margin-top:20px;font-size:12px;opacity:0.5;
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1024px){
  .product-grid{grid-template-columns:repeat(2,1fr)}
  .benefits-grid{grid-template-columns:repeat(3,1fr)}
  .related-products{grid-template-columns:repeat(2,1fr)}
  .hero-left h1{font-size:36px}
  .hero-right{display:none}
  .trust-cards-grid{grid-template-columns:repeat(2,1fr)}
}

@media(max-width:768px){
  :root{--header-h:60px}
  .container{padding:0 16px}
  .section{padding:48px 0}

  /* Top bar */
  .top-bar-links{display:flex;gap:12px;justify-content:center;width:100%;overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch}
  .top-bar-links::-webkit-scrollbar{display:none}
  .top-bar-links a{white-space:nowrap;font-size:11px}
  .top-bar-inner{justify-content:center}

  /* Header */
  .main-nav{display:none}
  .burger-btn{display:flex}
  .header-actions .search-bar{display:none}
  .mobile-search{display:block}
  .mobile-search .search-bar{display:flex}
  .search-results{min-width:0;left:-16px;right:-16px}
  .header-inner{gap:12px;position:relative;justify-content:flex-start}
  .header-inner .logo{position:absolute;left:50%;transform:translateX(-50%)}

  /* Hero */
  .hero{display:none}
  .hero-mobile{display:flex;flex-direction:column;align-items:center;justify-content:center}

  /* Grids */
  .product-grid{grid-template-columns:repeat(2,1fr);gap:12px}
  .trust-strip{grid-template-columns:repeat(2,1fr);padding:28px;gap:20px}
  .benefits-grid{grid-template-columns:repeat(2,1fr)}
  .steps-grid{grid-template-columns:1fr;gap:24px}
  .reviews-grid{grid-template-columns:1fr}
  .blog-grid{grid-template-columns:1fr}
  .about-story{grid-template-columns:1fr}
  .contacts-grid{grid-template-columns:1fr}
  .trust-cards-grid{grid-template-columns:1fr}
  .related-products{grid-template-columns:repeat(2,1fr)}

  /* Hide tags on product cards for mobile */
  .product-card .product-card-tags{display:none}

  /* Chips bigger on mobile */
  .chips{gap:8px;flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:4px}
  .chips::-webkit-scrollbar{display:none}
  .chip{padding:10px 20px;font-size:14px}

  /* Product detail */
  .product-detail{grid-template-columns:1fr}
  .product-sticky-bar{display:flex}
  body.product-page{padding-bottom:80px}

  /* Post */
  .post-layout{grid-template-columns:1fr}
  .post-sidebar{position:static}

  /* Footer */
  .footer-inner{grid-template-columns:1fr;gap:24px}

  /* Category cards */
  .category-card{flex:0 0 140px}
  .scroll-btn{display:none}

  /* Section */
  .section-title{font-size:24px}
  .page-hero h1{font-size:30px}
  .page-hero{padding:48px 0}

  /* CTA banner */
  .cta-banner{padding:40px 24px}
  .cta-banner h2{font-size:24px}

  /* Timeline */
  .timeline{flex-direction:column;gap:24px}
  .timeline::before{display:none}
}

@media(max-width:480px){
  .product-grid{grid-template-columns:repeat(2,1fr);gap:10px}
  .hero-mobile-product{width:75vw;max-width:280px}
  .hero-mobile-title{font-size:22px}
  .hero-mobile-stats{font-size:15px}
}
