@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,400;9..144,500;9..144,600&display=swap');

/* ===== RESET ===== */
*{margin:0;padding:0;box-sizing:border-box;}

/* ===== THEME VARIABLES ===== */
:root{
  --bg:#0b0b0b;
  --bg-soft:#101010;
  --bg-card:#141414;
  --line:#1f1f1f;
  --line-strong:#2a2a2a;
  --text:#e6e6e6;
  --text-dim:#9a9a9a;
  --muted:#6a6a6a;
  --white:#ffffff;
  --container:1280px;
  --radius:4px;
}

[data-theme="light"]{
  --bg:#f8f7f4;
  --bg-soft:#f1f0ec;
  --bg-card:#e9e8e3;
  --line:#d8d6d0;
  --line-strong:#c2c0ba;
  --text:#1a1918;
  --text-dim:#6a6866;
  --muted:#9e9c98;
  --white:#0b0b0b;
}

html{scroll-behavior:smooth;}

body{
  font-family:'Inter',system-ui,-apple-system,sans-serif;
  background:var(--bg);
  color:var(--text);
  -webkit-font-smoothing:antialiased;
  line-height:1.5;
  overflow-x:hidden;
  font-weight:300;
}

a{text-decoration:none;color:inherit;}
img{max-width:100%;display:block;}
button{font-family:inherit;}

/* ===== TYPOGRAPHY ===== */
/* Cormorant Garamond for Cyrillic headings; Cinzel for Latin decorative only */
h1,h2,h3,h4,.gothic{
  font-family:'Cormorant Garamond','Georgia',serif;
  font-weight:600;
  letter-spacing:.02em;
}

.logo{
  font-family:'Pirata One',serif;
  font-weight:400;
  letter-spacing:.15em;
  font-size:20px;
}

/* ===== LAYOUT ===== */
.container{
  max-width:var(--container);
  margin:0 auto;
  padding:0 28px;
}

.section{padding:64px 0;}
.section--sm{padding:40px 0;}
.section--tight{padding-top:16px;}

.section-header{
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
  gap:24px;
  margin-bottom:32px;
}

.section-label{
  font-family:'Inter',sans-serif;
  font-size:10px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--muted);
  margin-bottom:10px;
}

.section-title{
  font-size:clamp(24px,3.5vw,40px);
  font-weight:600;
  letter-spacing:.02em;
  line-height:1.1;
  color:var(--text);
}

.section-link{
  font-size:13px;
  color:var(--muted);
  transition:.3s;
  font-family:'Inter',sans-serif;
}
.section-link:hover{color:var(--text);}

/* ===== BUTTONS ===== */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:12px 22px;
  border-radius:2px;
  font-size:12px;
  font-weight:400;
  letter-spacing:.08em;
  text-transform:uppercase;
  transition:.3s;
  border:1px solid var(--line-strong);
  background:transparent;
  color:var(--text);
  cursor:pointer;
  font-family:'Inter',sans-serif;
}
.btn:hover{
  border-color:var(--text-dim);
  color:var(--white);
}
.btn-primary{
  background:transparent;
  border-color:var(--line-strong);
}
.btn-primary:hover{
  background:var(--text);
  color:var(--bg);
  border-color:var(--text);
}
.btn-ghost{
  border-color:var(--line);
  color:var(--text-dim);
}

/* ===== HEADER ===== */
.header{
  position:fixed;
  top:0;left:0;right:0;
  z-index:100;
  backdrop-filter:blur(16px);
  background:rgba(11,11,11,.82);
  border-bottom:1px solid var(--line);
  transition:background .3s;
}
[data-theme="light"] .header{
  background:rgba(248,247,244,.88);
}
.header-inner{
  height:60px;
  display:flex;
  align-items:center;
  justify-content:space-between;
}
.nav{display:flex;gap:28px;}
.nav a{
  font-size:12px;
  color:var(--text-dim);
  transition:.3s;
  letter-spacing:.06em;
}
.nav a:hover,.nav a.active{color:var(--white);}

.header-right{
  display:flex;
  align-items:center;
  gap:12px;
}

.lang-switch{display:flex;gap:4px;font-size:11px;letter-spacing:.05em;}
.lang-switch button{
  background:none;
  border:none;
  color:var(--muted);
  cursor:pointer;
  transition:.3s;
  padding:3px 5px;
  font-family:inherit;
}
.lang-switch button.active,
.lang-switch button:hover{color:var(--white);}

/* Theme toggle button */
.theme-toggle{
  width:34px;height:34px;
  border-radius:50%;
  border:1px solid var(--line-strong);
  background:transparent;
  color:var(--text-dim);
  cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:.3s;
}
.theme-toggle:hover{border-color:var(--text-dim);color:var(--white);}
.theme-toggle svg{width:15px;height:15px;}
/* Show correct icon per theme */
html:not([data-theme="light"]) .icon-sun{ display:none; }
html[data-theme="light"] .icon-moon{ display:none; }

.cart-btn{
  width:34px;height:34px;
  border-radius:50%;
  border:1px solid var(--line-strong);
  display:flex;align-items:center;justify-content:center;
  position:relative;
  transition:.3s;
  color:var(--text-dim);
}
.cart-btn:hover{border-color:var(--text-dim);color:var(--white);}
.cart-count{
  position:absolute;
  top:-4px;right:-4px;
  min-width:16px;height:16px;padding:0 3px;
  border-radius:50%;
  background:var(--bg);
  color:var(--text);
  border:1px solid var(--line-strong);
  font-size:9px;
  display:flex;align-items:center;justify-content:center;
  font-weight:500;
}
.cart-count[data-count="0"]{display:none;}

.mobile-toggle{display:none;}

/* ===== HERO ===== */
.hero{
  padding:80px 0 12px;
  text-align:center;
}
.hero .container{
  display:flex;
  flex-direction:column;
  align-items:center;
}
.hero-kicker{
  display:inline-flex;
  align-items:center;
  gap:16px;
  font-family:'Cinzel',serif;
  font-size:13px;
  font-weight:500;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--text-dim);
  margin-bottom:14px;
}
.hero-kicker::before,
.hero-kicker::after{
  content:'';
  display:inline-block;
  width:44px;
  height:1px;
  background:linear-gradient(90deg, transparent, var(--line-strong), transparent);
}
.hero-title{
  font-family:'Cormorant Garamond','Georgia',serif;
  font-size:clamp(44px,6vw,80px);
  font-weight:600;
  line-height:1;
  letter-spacing:.04em;
  margin:0 0 12px;
  color:var(--text);
}
.hero-subtitle{
  font-size:13px;
  color:var(--text-dim);
  max-width:480px;
  letter-spacing:.04em;
}
.hero-subtitle:empty{display:none;}

/* ===== FILTERS ===== */
.filters{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin-bottom:28px;
}
.filter-btn{
  padding:8px 14px;
  border-radius:2px;
  background:transparent;
  border:1px solid var(--line);
  color:var(--text-dim);
  cursor:pointer;
  transition:.3s;
  font-size:11px;
  letter-spacing:.08em;
  text-transform:uppercase;
  font-family:'Inter',sans-serif;
}
.filter-btn:hover{color:var(--text);border-color:var(--line-strong);}
.filter-btn.active{
  color:var(--white);
  border-color:var(--text-dim);
}

/* ===== PRODUCTS ===== */
.products-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:16px;
}
.product-card{
  background:var(--bg-soft);
  border-radius:var(--radius);
  overflow:hidden;
  border:1px solid var(--line);
  transition:.4s ease;
  display:flex;flex-direction:column;
  position:relative;
  text-decoration:none;
  color:inherit;
}
.product-card:hover{
  border-color:rgba(255,255,255,.15);
  transform:translateY(-4px);
  box-shadow:0 20px 44px -24px rgba(0,0,0,.65);
}
[data-theme="light"] .product-card:hover{
  border-color:rgba(0,0,0,.18);
  box-shadow:0 20px 44px -24px rgba(0,0,0,.15);
}
.product-image{
  position:relative;
  aspect-ratio:1;
  overflow:hidden;
  background:var(--bg-card);
}
.product-image img{
  width:100%;height:100%;
  object-fit:cover;
  transition:transform .6s ease;
}
.product-card:hover .product-image img{transform:scale(1.06);}

.product-image::after{
  content:'';
  position:absolute;
  left:0;right:0;bottom:0;
  height:55%;
  background:linear-gradient(180deg, transparent, rgba(8,8,8,.85));
  opacity:0;
  transition:.35s ease;
  pointer-events:none;
}
.product-card:hover .product-image::after{opacity:1;}

.product-tag{
  position:absolute;
  top:10px;left:10px;
  padding:4px 9px;
  background:rgba(10,10,10,.85);
  backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.08);
  border-radius:2px;
  font-size:9px;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--text);
  z-index:2;
}

.product-quick{
  position:absolute;
  left:12px;right:12px;bottom:12px;
  display:flex;
  justify-content:center;
  opacity:0;
  transform:translateY(8px);
  transition:.35s ease;
  z-index:3;
}
.product-card:hover .product-quick{
  opacity:1;
  transform:translateY(0);
}
.product-quick button{
  flex:1;
  padding:10px 14px;
  background:rgba(255,255,255,.95);
  color:#000;
  border:none;
  border-radius:2px;
  font-family:'Inter',sans-serif;
  font-size:10px;
  font-weight:500;
  letter-spacing:.18em;
  text-transform:uppercase;
  cursor:pointer;
  transition:.25s;
}
[data-theme="light"] .product-quick button{
  background:rgba(0,0,0,.88);
  color:#fff;
}
.product-quick button:hover{background:#fff;}
[data-theme="light"] .product-quick button:hover{background:#000;}

/* Compact one-line product info */
.product-info{
  padding:10px 12px 12px;
  display:flex;
  flex-direction:column;
  gap:0;
}
.product-row{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:8px;
}
.product-name{
  font-family:'Cormorant Garamond','Georgia',serif;
  font-size:15px;
  font-weight:600;
  color:var(--text);
  letter-spacing:.02em;
  transition:color .3s;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  flex:1;
  min-width:0;
}
.product-card:hover .product-name{color:var(--white);}
.product-price{
  font-family:'Cinzel',serif;
  font-size:13px;
  font-weight:500;
  color:var(--text);
  letter-spacing:.02em;
  white-space:nowrap;
  flex-shrink:0;
}
.product-old{
  font-size:11px;
  color:var(--muted);
  text-decoration:line-through;
  margin-right:6px;
}

/* Wrapper for products CTA below grid */
.catalog-cta-wrap{
  display:flex;
  justify-content:center;
  margin-top:40px;
}

/* ===== CTA LINKS (redesigned: minimal underline) ===== */
.cta-reviews{
  display:inline-flex;
  align-items:center;
  gap:14px;
  font-family:'Cinzel',serif;
  font-size:11px;
  letter-spacing:.25em;
  text-transform:uppercase;
  color:var(--text-dim);
  position:relative;
  padding-bottom:5px;
  transition:color .35s;
  background:transparent;
  border:none;
  cursor:pointer;
}
.cta-reviews::after{
  content:'';
  position:absolute;
  bottom:0;left:0;
  width:0;
  height:1px;
  background:var(--text);
  transition:width .4s cubic-bezier(.4,0,.2,1);
}
.cta-reviews:hover{color:var(--text);}
.cta-reviews:hover::after{width:100%;}
.cta-reviews .arrow{
  display:inline-block;
  transition:transform .35s ease;
}
.cta-reviews:hover .arrow{transform:translateX(6px);}

.reviews-cta-wrap{
  display:flex;
  justify-content:center;
  margin-top:32px;
}

/* ===== REVIEWS ===== */
.reviews-row{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:16px;
  align-items:stretch;
}
.review-card{
  background:var(--bg-soft);
  border:1px solid var(--line);
  border-radius:var(--radius);
  display:flex;
  flex-direction:column;
  overflow:hidden;
  transition:.35s;
  height:100%;
}
.review-card--linked{cursor:pointer;}
.review-card:hover{
  border-color:var(--line-strong);
  transform:translateY(-2px);
}

.review-images{
  aspect-ratio:1/1;
  display:grid;
  grid-template-columns:1fr;
  gap:2px;
  background:var(--bg-card);
  overflow:hidden;
}
.review-images--two{grid-template-columns:1fr 1fr;}
.review-img{
  width:100%;height:100%;
  overflow:hidden;
}
.review-img img{
  width:100%;height:100%;
  object-fit:cover;
  transition:.5s;
}
.review-card:hover .review-img img{transform:scale(1.04);}

.review-body{
  padding:18px 18px 16px;
  display:flex;flex-direction:column;
  gap:12px;
  flex:1;
}
.review-text{
  font-size:13px;
  color:var(--text-dim);
  line-height:1.6;
  font-style:italic;
  display:-webkit-box;
  -webkit-line-clamp:6;
  -webkit-box-orient:vertical;
  overflow:hidden;
  min-height:calc(13px * 1.6 * 6);
}
.review-meta{
  display:flex;
  justify-content:space-between;
  align-items:center;
  font-size:12px;
  color:var(--muted);
  letter-spacing:.03em;
  margin-top:auto;
  padding-top:10px;
  border-top:1px solid var(--line);
}
.review-author{
  color:var(--text);
  font-family:'Cormorant Garamond','Georgia',serif;
  font-size:14px;
  font-weight:600;
  letter-spacing:.03em;
}

/* ===== FAQ ===== */
.faq-header{margin-bottom:28px;}
.faq-list{
  border-top:1px solid var(--line);
}
.faq-item{
  border-bottom:1px solid var(--line);
}
.faq-q{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:18px 0;
  cursor:pointer;
  gap:20px;
  font-family:'Cormorant Garamond','Georgia',serif;
  font-size:18px;
  font-weight:500;
  color:var(--text-dim);
  transition:color .3s;
  user-select:none;
}
.faq-q:hover{color:var(--text);}
.faq-icon{
  flex-shrink:0;
  font-size:20px;
  color:var(--muted);
  line-height:1;
  transition:transform .35s, color .3s;
  font-weight:300;
}
.faq-item.open .faq-q{color:var(--text);}
.faq-item.open .faq-icon{
  transform:rotate(45deg);
  color:var(--text-dim);
}
.faq-a{
  max-height:0;
  overflow:hidden;
  transition:max-height .38s cubic-bezier(.4,0,.2,1);
}
.faq-a-inner{
  padding:0 0 20px;
  font-size:14px;
  color:var(--text-dim);
  line-height:1.75;
  max-width:600px;
}
.faq-item.open .faq-a{max-height:400px;}

/* ===== GALLERY ===== */
.gallery-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:12px;
}
.gallery-item{
  position:relative;
  overflow:hidden;
  border-radius:var(--radius);
  aspect-ratio:1;
  background:var(--bg-card);
  border:1px solid var(--line);
}
.gallery-item img{
  width:100%;height:100%;
  object-fit:cover;
  transition:.5s;
}
.gallery-item:hover img{transform:scale(1.05);}
.gallery-caption{
  position:absolute;
  left:12px;bottom:12px;
  font-size:10px;
  padding:5px 9px;
  background:rgba(10,10,10,.85);
  backdrop-filter:blur(8px);
  border:1px solid var(--line);
  border-radius:2px;
  color:var(--text-dim);
  letter-spacing:.05em;
}

/* ===== CONTACTS ===== */
.contact-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:40px;
}
.contact-item{
  padding:18px 20px;
  border-radius:var(--radius);
  background:var(--bg-soft);
  border:1px solid var(--line);
  margin-bottom:12px;
  transition:.3s;
}
.contact-item:hover{border-color:var(--line-strong);}
.contact-item .label{
  display:block;
  font-size:10px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--muted);
  margin-bottom:6px;
}
.contact-item .value{
  font-size:15px;
  color:var(--text);
  letter-spacing:.02em;
}
.contact-item .sub{
  font-size:13px;
  color:var(--text-dim);
  margin-top:4px;
}
.socials-list{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:12px;
}
.social-chip{
  padding:9px 14px;
  border:1px solid var(--line);
  border-radius:2px;
  color:var(--text-dim);
  font-size:11px;
  letter-spacing:.1em;
  text-transform:uppercase;
  transition:.3s;
}
.social-chip:hover{
  color:var(--text);
  border-color:var(--text-dim);
}

/* ===== PRODUCT PAGE ===== */
.product-page-grid{
  display:grid;
  grid-template-columns:1.2fr 1fr;
  gap:56px;
  align-items:flex-start;
}
.product-gallery{display:flex;flex-direction:column;gap:12px;}
.product-gallery-main{
  aspect-ratio:1;
  background:var(--bg-card);
  border:1px solid var(--line);
  border-radius:var(--radius);
  overflow:hidden;
}
.product-gallery-main img{width:100%;height:100%;object-fit:cover;}
.product-thumbs{display:flex;gap:8px;flex-wrap:wrap;}
.product-thumb{
  width:76px;height:76px;
  background:var(--bg-card);
  border:1px solid var(--line);
  border-radius:2px;
  overflow:hidden;
  cursor:pointer;
  transition:.3s;
}
.product-thumb.active,.product-thumb:hover{border-color:var(--text-dim);}
.product-thumb img{width:100%;height:100%;object-fit:cover;}

.product-detail h1{
  font-family:'Cormorant Garamond','Georgia',serif;
  font-size:clamp(26px,3.5vw,38px);
  font-weight:600;
  margin-bottom:10px;
  letter-spacing:.02em;
}
.product-detail .price-block{
  font-size:22px;
  margin:16px 0 22px;
  letter-spacing:.02em;
  font-family:'Cinzel',serif;
}
.product-detail .desc{
  color:var(--text-dim);
  font-size:14px;
  line-height:1.75;
  margin-bottom:24px;
}
.specs-table{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:0;
  margin-bottom:28px;
  border-top:1px solid var(--line);
}
.specs-row{display:contents;}
.specs-row > div{
  padding:12px 0;
  border-bottom:1px solid var(--line);
  font-size:13px;
}
.specs-row .specs-label{color:var(--muted);letter-spacing:.05em;}
.specs-row .specs-value{color:var(--text);text-align:right;}

/* ===== CART / CHECKOUT ===== */
.cart-list{display:flex;flex-direction:column;gap:12px;margin-bottom:24px;}
.cart-row{
  display:grid;
  grid-template-columns:84px 1fr auto auto auto;
  align-items:center;
  gap:16px;
  padding:12px;
  background:var(--bg-soft);
  border:1px solid var(--line);
  border-radius:var(--radius);
}
.cart-row img{
  width:84px;height:84px;
  object-fit:cover;
  border-radius:2px;
  background:var(--bg-card);
}
.cart-row .title{
  font-family:'Cormorant Garamond','Georgia',serif;
  font-size:16px;
  font-weight:600;
}
.cart-row .meta{font-size:11px;color:var(--muted);margin-top:3px;}
.qty{
  display:inline-flex;
  align-items:center;
  border:1px solid var(--line);
  border-radius:2px;
}
.qty button{
  width:28px;height:28px;
  background:transparent;
  border:none;
  color:var(--text-dim);
  cursor:pointer;
  font-size:14px;
}
.qty button:hover{color:var(--white);}
.qty span{
  min-width:28px;
  text-align:center;
  font-size:12px;
}
.cart-row .price{font-size:13px;font-family:'Cinzel',serif;}
.cart-row .remove{
  background:transparent;border:none;
  color:var(--muted);cursor:pointer;
  font-size:16px;
}
.cart-row .remove:hover{color:var(--text);}

.cart-summary{
  margin-top:20px;
  padding:20px;
  background:var(--bg-soft);
  border:1px solid var(--line);
  border-radius:var(--radius);
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:20px;
}
.cart-total{
  font-family:'Cinzel',serif;
  font-size:20px;
  letter-spacing:.02em;
}
.empty-state{
  padding:64px 20px;
  text-align:center;
  color:var(--muted);
  border:1px dashed var(--line);
  border-radius:var(--radius);
}
.empty-state h3{
  font-family:'Cormorant Garamond','Georgia',serif;
  font-size:26px;
  color:var(--text-dim);
  margin-bottom:10px;
  letter-spacing:.05em;
}

/* ===== FORM ===== */
.form{
  background:var(--bg-soft);
  padding:26px;
  border-radius:var(--radius);
  border:1px solid var(--line);
}
.form-grid{display:grid;gap:12px;}
.input,.textarea,.select{
  width:100%;
  background:var(--bg);
  border:1px solid var(--line);
  border-radius:2px;
  padding:12px 14px;
  color:var(--text);
  font-size:13px;
  outline:none;
  transition:.3s;
  font-family:inherit;
}
.input:focus,.textarea:focus,.select:focus{border-color:var(--text-dim);}
.textarea{min-height:100px;resize:vertical;}
.field-label{
  font-size:10px;
  letter-spacing:.15em;
  text-transform:uppercase;
  color:var(--muted);
  margin-bottom:5px;
  display:block;
}

/* Delivery options */
.delivery-options{
  display:flex;
  flex-direction:column;
  gap:6px;
  margin:8px 0 16px;
}
.delivery-opt{
  display:flex;
  align-items:center;
  gap:10px;
  cursor:pointer;
  font-size:13px;
  color:var(--text-dim);
  padding:10px 14px;
  border:1px solid var(--line);
  border-radius:2px;
  transition:.3s;
}
.delivery-opt:hover{border-color:var(--line-strong);color:var(--text);}
.delivery-opt input[type="radio"]{
  accent-color:var(--text);
  flex-shrink:0;
}
.delivery-opt:has(input:checked){
  border-color:var(--text-dim);
  color:var(--text);
}
.delivery-field{
  display:flex;
  flex-direction:column;
  gap:5px;
}

/* ===== FOOTER ===== */
.footer{
  padding:32px 0;
  border-top:1px solid var(--line);
  margin-top:32px;
}
.footer-inner{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:24px;
  flex-wrap:wrap;
}
.footer-copy{display:none;}/* hidden per design */
.footer-links{display:flex;gap:18px;flex-wrap:wrap;}
.footer-links a{
  color:var(--muted);
  font-size:11px;
  letter-spacing:.05em;
  transition:.3s;
}
.footer-links a:hover{color:var(--text);}

/* ===== TOAST ===== */
.toast{
  position:fixed;
  bottom:20px;left:50%;
  transform:translateX(-50%) translateY(16px);
  padding:12px 20px;
  background:var(--bg-card);
  border:1px solid var(--line-strong);
  border-radius:2px;
  color:var(--text);
  font-size:12px;
  letter-spacing:.05em;
  opacity:0;
  pointer-events:none;
  transition:.3s;
  z-index:200;
}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0);}

/* ========= ADDITIONS v2 ========= */

/* Inner page hero - smaller scale */
body[data-page]:not([data-page="home"]) .hero-title{
  font-size:clamp(26px,4vw,46px);
}

/* Product tag — pill shape + color variants */
.product-tag{
  border-radius:20px;
  padding:3px 10px;
  font-size:9px;
  font-weight:500;
  letter-spacing:.12em;
  background:rgba(14,14,14,.9);
  color:var(--text);
  border:none;
  backdrop-filter:none;
}
.product-tag--new{background:rgba(99,102,241,.92);color:#fff;}
.product-tag--hit{background:rgba(220,38,38,.9);color:#fff;}
.product-tag--sale{background:rgba(16,185,129,.9);color:#fff;}
.product-tag--limited{background:rgba(217,119,6,.92);color:#fff;}
[data-theme="light"] .product-tag{background:rgba(20,20,20,.82);color:#fff;}

/* Social icons — circle buttons */
.social-icon{
  width:44px;height:44px;
  display:inline-flex;align-items:center;justify-content:center;
  border:1px solid var(--line);
  border-radius:50%;
  color:var(--text-dim);
  transition:border-color .3s,color .3s,transform .3s;
}
.social-icon:hover{
  border-color:var(--text-dim);
  color:var(--white);
  transform:translateY(-2px);
}
.social-icon svg{width:18px;height:18px;}

/* === FOOTER REDESIGN === */
.footer{padding:0;border-top:1px solid var(--line);margin-top:48px;}
.footer-top{
  display:grid;
  grid-template-columns:1.1fr 1fr;
  gap:48px;
  align-items:flex-start;
  padding:40px 0 32px;
}
.footer-brand-wrap{}
.footer-tagline{
  font-size:11px;color:var(--muted);
  letter-spacing:.05em;
  margin:6px 0 18px;
  line-height:1.5;
}
.footer-socials{display:flex;gap:8px;flex-wrap:wrap;}
.footer-socials .social-icon{width:32px;height:32px;}
.footer-socials .social-icon svg{width:14px;height:14px;}
.footer-nav-row{display:flex;gap:40px;padding-top:4px;}
.footer-col-head{
  font-size:10px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--muted);margin-bottom:14px;
}
.footer-col a{
  display:block;font-size:12px;
  color:var(--text-dim);letter-spacing:.04em;
  margin-bottom:9px;transition:.3s;
}
.footer-col a:hover{color:var(--text);}
.footer-bottom{
  border-top:1px solid var(--line);
  padding:14px 0;
  display:flex;justify-content:space-between;align-items:center;
  font-size:10px;color:var(--muted);letter-spacing:.06em;gap:16px;flex-wrap:wrap;
}

/* === CONTACTS PAGE REDESIGN === */
.contacts-page-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:64px;
  align-items:flex-start;
}
.contacts-info{display:flex;flex-direction:column;gap:28px;}
.block-title{
  font-family:'Cormorant Garamond','Georgia',serif;
  font-size:20px;font-weight:600;letter-spacing:.02em;
  margin-bottom:14px;
}
.manager-card{
  display:flex;align-items:flex-start;gap:14px;
  padding:18px 20px;
  background:var(--bg-soft);border:1px solid var(--line);
  border-radius:var(--radius);margin-bottom:10px;transition:border-color .3s;
}
.manager-card:hover{border-color:var(--line-strong);}
.manager-avatar{
  width:44px;height:44px;border-radius:50%;
  background:var(--bg-card);border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  font-family:'Cormorant Garamond',serif;font-size:20px;color:var(--text-dim);
}
.manager-info .m-name{font-family:'Cormorant Garamond',serif;font-size:16px;font-weight:600;}
.manager-info .m-role{
  font-size:10px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--muted);margin:2px 0 8px;
}
.manager-info .m-links{display:flex;flex-direction:column;gap:3px;font-size:12px;}
.manager-info .m-links a{color:var(--text-dim);transition:.3s;}
.manager-info .m-links a:hover{color:var(--text);}
.socials-icons-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:4px;}

.contact-form-box{
  background:var(--bg-soft);border:1px solid var(--line);
  border-radius:var(--radius);padding:32px;
}
.contact-form-box .form-heading{
  font-family:'Cormorant Garamond','Georgia',serif;
  font-size:26px;font-weight:600;letter-spacing:.02em;margin-bottom:6px;
}
.contact-form-box .form-sub{
  font-size:12px;color:var(--muted);margin-bottom:22px;letter-spacing:.04em;
}

/* === SUCCESS MODAL === */
.success-back{
  position:fixed;inset:0;
  background:rgba(0,0,0,.75);
  backdrop-filter:blur(6px);
  display:flex;align-items:center;justify-content:center;
  z-index:600;padding:20px;
  opacity:0;pointer-events:none;transition:opacity .35s;
}
.success-back.show{opacity:1;pointer-events:auto;}
.success-box{
  background:var(--bg);border:1px solid var(--line-strong);
  border-radius:10px;padding:48px 36px;
  max-width:400px;width:100%;text-align:center;
  transform:scale(.88) translateY(24px);
  transition:transform .45s cubic-bezier(.34,1.56,.64,1);
}
.success-back.show .success-box{transform:scale(1) translateY(0);}
.success-ico{
  width:60px;height:60px;border-radius:50%;
  border:1px solid rgba(16,185,129,.35);
  background:rgba(16,185,129,.08);
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 20px;color:#10b981;
}
.success-box h3{
  font-family:'Cormorant Garamond','Georgia',serif;
  font-size:26px;font-weight:600;margin-bottom:10px;letter-spacing:.02em;
}
.success-box p{font-size:13px;color:var(--text-dim);line-height:1.7;margin-bottom:24px;}
.success-order-num{
  font-family:'Cinzel',serif;font-size:13px;letter-spacing:.1em;
  color:var(--text-dim);margin-bottom:20px;
}

/* === CART PAGE v2 === */
.cart-layout{
  display:grid;
  grid-template-columns:1fr 360px;
  gap:32px;align-items:flex-start;
}
.cart-items-wrap{}
.cart-page-title{
  font-family:'Cormorant Garamond',serif;
  font-size:20px;font-weight:600;letter-spacing:.02em;
  margin-bottom:16px;padding-bottom:14px;border-bottom:1px solid var(--line);
  display:flex;justify-content:space-between;align-items:center;
}
.cart-page-title .count{font-size:12px;color:var(--muted);font-family:'Inter',sans-serif;font-weight:300;letter-spacing:.04em;}
.cart-row-v2{
  display:grid;
  grid-template-columns:88px 1fr auto;
  align-items:center;gap:16px;
  padding:16px 0;border-bottom:1px solid var(--line);
}
.cart-row-v2 img{
  width:88px;height:88px;object-fit:cover;
  border-radius:var(--radius);background:var(--bg-card);border:1px solid var(--line);
}
.cart-row-v2 .ci-name{
  font-family:'Cormorant Garamond',serif;font-size:17px;font-weight:600;margin-bottom:3px;
}
.cart-row-v2 .ci-unit{font-size:11px;color:var(--muted);margin-bottom:10px;}
.cart-row-v2 .ci-controls{display:flex;align-items:center;gap:10px;}
.cart-row-v2 .ci-remove{
  background:none;border:none;color:var(--muted);cursor:pointer;
  font-size:17px;line-height:1;transition:.3s;padding:0 0 0 4px;
}
.cart-row-v2 .ci-remove:hover{color:var(--text);}
.cart-row-v2 .ci-total{
  font-family:'Cinzel',serif;font-size:14px;letter-spacing:.02em;
  white-space:nowrap;text-align:right;
}
.cart-sidebar{position:sticky;top:80px;display:flex;flex-direction:column;gap:14px;}
.cart-sidebar-box{
  background:var(--bg-soft);border:1px solid var(--line);
  border-radius:var(--radius);padding:22px;
}
.cart-sidebar-title{
  font-family:'Cormorant Garamond',serif;font-size:18px;font-weight:600;
  margin-bottom:14px;
}
.cart-sum-row{
  display:flex;justify-content:space-between;align-items:center;
  font-size:13px;padding:8px 0;
  border-bottom:1px solid var(--line);color:var(--text-dim);
}
.cart-sum-row:last-of-type{border-bottom:none;}
.cart-grand{
  display:flex;justify-content:space-between;align-items:center;
  padding:14px 0 18px;
  border-top:1px solid var(--line);margin-top:4px;
}
.cart-grand .gl{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);}
.cart-grand .gv{font-family:'Cinzel',serif;font-size:22px;}
.cart-trust{display:flex;flex-direction:column;gap:7px;margin-top:4px;}
.cart-trust-item{
  display:flex;align-items:center;gap:8px;
  font-size:11px;color:var(--muted);letter-spacing:.03em;
}
.cart-trust-item svg{flex-shrink:0;color:var(--text-dim);width:14px;height:14px;}
.cart-continue{
  font-size:11px;color:var(--muted);letter-spacing:.04em;
  display:inline-flex;align-items:center;gap:6px;margin-top:16px;
  transition:.3s;
}
.cart-continue:hover{color:var(--text);}

/* === CHECKOUT v2 === */
.checkout-layout{
  display:grid;
  grid-template-columns:1fr 380px;
  gap:32px;align-items:flex-start;
}
.checkout-form-box{
  background:var(--bg-soft);border:1px solid var(--line);
  border-radius:var(--radius);padding:28px;
}
.checkout-section-title{
  font-family:'Cormorant Garamond',serif;font-size:18px;font-weight:600;letter-spacing:.02em;
  margin:22px 0 14px;padding-bottom:10px;border-bottom:1px solid var(--line);
}
.checkout-section-title:first-child{margin-top:0;}
.checkout-sidebar{position:sticky;top:80px;display:flex;flex-direction:column;gap:14px;}
.checkout-summary-box{
  background:var(--bg-soft);border:1px solid var(--line);
  border-radius:var(--radius);padding:22px;
}
.checkout-summary-title{
  font-family:'Cormorant Garamond',serif;font-size:17px;font-weight:600;margin-bottom:14px;
}
.ck-item{
  display:flex;justify-content:space-between;gap:12px;
  padding:8px 0;border-bottom:1px solid var(--line);font-size:13px;
}
.ck-item:last-of-type{border-bottom:none;}
.ck-item .ci{color:var(--text-dim);flex:1;line-height:1.4;}
.ck-item .cp{font-family:'Cinzel',serif;font-size:12px;white-space:nowrap;}
.ck-total{
  display:flex;justify-content:space-between;align-items:center;
  margin-top:12px;padding-top:12px;
}
.ck-total .tl{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);}
.ck-total .tv{font-family:'Cinzel',serif;font-size:22px;}
.promo-box{
  background:var(--bg-soft);border:1px solid var(--line);
  border-radius:var(--radius);padding:16px;
}
.promo-box .field-label{margin-bottom:7px;}
.promo-row{display:flex;gap:8px;}
.promo-row .input{flex:1;}
.promo-row .btn{flex-shrink:0;padding:12px 14px;font-size:11px;}

/* delivery cards */
.delivery-opt-card{
  display:flex;align-items:flex-start;gap:12px;cursor:pointer;
  padding:14px 16px;border:1px solid var(--line);
  border-radius:var(--radius);transition:.3s;margin-bottom:8px;
}
.delivery-opt-card:hover{border-color:var(--line-strong);}
.delivery-opt-card:has(input:checked){border-color:var(--text-dim);background:var(--bg-card);}
.delivery-opt-card input[type="radio"]{margin-top:2px;accent-color:var(--text);flex-shrink:0;}
.d-name{font-size:13px;font-weight:500;color:var(--text);}
.d-sub{font-size:11px;color:var(--muted);margin-top:2px;}
.delivery-warn{
  display:flex;align-items:flex-start;gap:8px;
  padding:10px 13px;margin-top:8px;
  background:rgba(245,158,11,.06);
  border:1px solid rgba(245,158,11,.2);
  border-radius:var(--radius);
  font-size:12px;color:#b8830a;line-height:1.55;
}
[data-theme="light"] .delivery-warn{color:#7c5a06;}

/* СДЭК */
.sdek-select-btn{
  display:inline-flex;align-items:center;gap:8px;
  margin-top:8px;padding:9px 16px;
  border:1px solid var(--line-strong);border-radius:var(--radius);
  font-size:11px;letter-spacing:.07em;text-transform:uppercase;
  color:var(--text-dim);cursor:pointer;background:transparent;
  font-family:inherit;transition:.3s;
}
.sdek-select-btn:hover{border-color:var(--text-dim);color:var(--text);}
.sdek-selected-label{
  font-size:12px;color:var(--text-dim);margin-top:6px;display:none;
  padding:8px 12px;background:var(--bg-card);border:1px solid var(--line);
  border-radius:2px;
}
.sdek-selected-label.show{display:block;}

/* СДЭК modal */
.sdek-modal-back{
  position:fixed;inset:0;background:rgba(0,0,0,.8);backdrop-filter:blur(4px);
  z-index:600;display:flex;align-items:center;justify-content:center;
  opacity:0;pointer-events:none;transition:opacity .35s;padding:20px;
}
.sdek-modal-back.show{opacity:1;pointer-events:auto;}
.sdek-modal{
  background:var(--bg);border:1px solid var(--line-strong);border-radius:8px;
  width:min(800px,100%);
  height:min(88vh,720px);
  max-height:88vh;
  display:flex;flex-direction:column;
  overflow:hidden;
  transform:scale(.92);transition:transform .35s cubic-bezier(.34,1.56,.64,1);
}
.sdek-modal-back.show .sdek-modal{transform:scale(1);}
.sdek-modal-head{
  display:flex;justify-content:space-between;align-items:center;
  padding:16px 22px;border-bottom:1px solid var(--line);flex-shrink:0;
}
.sdek-modal-head h4{font-family:'Cinzel',serif;font-size:13px;letter-spacing:.1em;text-transform:uppercase;}
.sdek-close{background:none;border:none;color:var(--muted);cursor:pointer;font-size:22px;line-height:1;transition:.3s;}
.sdek-close:hover{color:var(--text);}
.sdek-modal-body{flex:1 1 0;min-height:0;overflow:hidden;position:relative;background:var(--bg-card);display:flex;flex-direction:column;}
#cdek-widget-container{width:100%;height:100%;min-height:0;display:flex;flex-direction:column;flex:1;}

/* product page image smaller */
.product-page-grid{grid-template-columns:1fr 1.1fr;}
.product-gallery-main{aspect-ratio:4/3;}

/* === RESPONSIVE v2 === */
@media(max-width:960px){
  .cart-layout,.checkout-layout{grid-template-columns:1fr;}
  .cart-sidebar,.checkout-sidebar{position:relative;top:0;}
  .contacts-page-grid{grid-template-columns:1fr;gap:32px;}
  .footer-top{grid-template-columns:1fr;gap:28px;}
  .footer-nav-row{gap:24px;}
}
@media(max-width:768px){
  .cart-row-v2{grid-template-columns:70px 1fr;gap:12px;}
  .cart-row-v2 img{width:70px;height:70px;}
  .checkout-form-box,.contact-form-box{padding:20px;}
  .success-box{padding:36px 24px;}
}

/* ===== RESPONSIVE ===== */
@media(max-width:1100px){
  .products-grid{grid-template-columns:repeat(3,1fr);}
  .reviews-row{grid-template-columns:repeat(2,1fr);}
  .product-page-grid{grid-template-columns:1fr;gap:28px;}
  .gallery-grid{grid-template-columns:repeat(2,1fr);}
}
@media(max-width:768px){
  .container{padding:0 16px;}
  .section{padding:48px 0;}
  .nav{display:none;}
  .mobile-toggle{display:flex;}
  .products-grid{grid-template-columns:repeat(2,1fr);}
  .reviews-row{grid-template-columns:1fr;}
  .contact-grid{grid-template-columns:1fr;gap:24px;}
  .cart-row{
    grid-template-columns:64px 1fr;
    grid-template-areas:"img info" "img qty" "price remove .";
    gap:8px;
  }
  .cart-row img{width:64px;height:64px;grid-area:img;}
  .gallery-grid{grid-template-columns:1fr;}
  .hero{padding:88px 0 10px;}
  .faq-q{font-size:16px;}
}

/* ===================================================================== */
/* ============== PREMIUM POLISH v3 (final refinement) ================== */
/* ===================================================================== */

/* --- Softer line palette (rgba — выглядит мягче и не «режет» глаз) --- */
:root{
  --line:rgba(255,255,255,.07);
  --line-strong:rgba(255,255,255,.14);
  --line-soft:rgba(255,255,255,.04);
}
[data-theme="light"]{
  --line:rgba(0,0,0,.08);
  --line-strong:rgba(0,0,0,.18);
  --line-soft:rgba(0,0,0,.04);
}

/* --- Refined header --- */
.header-inner{height:64px;}
.logo{font-size:17px;letter-spacing:.18em;font-weight:400;}
.nav{gap:32px;}
.nav a{
  font-size:11px;letter-spacing:.16em;
  text-transform:uppercase;font-weight:400;
}
.lang-switch button{font-size:10px;letter-spacing:.12em;padding:3px 4px;}
.theme-toggle,.cart-btn{width:32px;height:32px;}
.theme-toggle svg,.cart-btn svg{width:13px;height:13px;}

/* --- Hero: centered, elegant breathing room --- */
.hero{padding:100px 0 20px;}
body[data-page]:not([data-page="home"]) .hero{padding:110px 0 18px;}
.hero-title{
  letter-spacing:.04em;
  font-weight:500;
}
body[data-page]:not([data-page="home"]) .hero-title{
  font-size:clamp(34px,4.5vw,52px);
}
.hero-kicker{
  font-size:10px;letter-spacing:.32em;font-weight:400;
}
.hero-kicker::before,.hero-kicker::after{width:48px;}
.hero-subtitle{
  font-size:12px;letter-spacing:.05em;
  color:var(--muted);
  font-style:italic;
  font-family:'Cormorant Garamond',serif;
  font-size:14px;
  max-width:520px;
}

/* --- Section rhythm --- */
.section{padding:80px 0;}
.section--sm{padding:48px 0;}
.section--tight{padding-top:24px;}
.section-header{margin-bottom:36px;}
.section-label{
  font-size:10px;letter-spacing:.28em;
  color:var(--muted);
}
.section-title{
  font-weight:500;letter-spacing:.03em;
}

/* --- Filter buttons --- */
.filters{gap:6px;margin-bottom:32px;}
.filter-btn{
  padding:9px 18px;
  font-size:10px;letter-spacing:.14em;
  border-color:var(--line);
  border-radius:2px;
}
.filter-btn:hover{color:var(--text);border-color:var(--line-strong);}
.filter-btn.active{
  background:var(--text);
  color:var(--bg);
  border-color:var(--text);
}

/* --- Product cards: clean, borderless, focus on image --- */
.products-grid{gap:24px;}
.product-card{
  background:transparent;
  border:none;
  border-radius:0;
  transition:transform .4s ease;
}
.product-card:hover{
  transform:translateY(-4px);
  box-shadow:none;
  border:none;
}
.product-image{
  border-radius:4px;
  border:1px solid var(--line);
  background:var(--bg-soft);
}
.product-info{
  padding:16px 4px 4px;
}
.product-row{align-items:baseline;gap:12px;}
.product-name{
  font-family:'Cormorant Garamond','Georgia',serif;
  font-size:18px;font-weight:600;
  letter-spacing:.015em;
  color:var(--text);
}
.product-price{
  font-family:'Cormorant Garamond','Georgia',serif;
  font-style:normal;
  font-size:18px;font-weight:600;
  letter-spacing:.01em;
  color:var(--text);
}
.product-old{
  font-family:'Inter',sans-serif;
  font-style:normal;
  font-size:12px;font-weight:300;
  text-decoration:line-through;
  color:var(--muted);
  margin-right:8px;
}

/* --- Tags: subtle, refined --- */
.product-tag{
  padding:4px 11px;
  border-radius:30px;
  font-size:8.5px;
  letter-spacing:.18em;
  font-weight:500;
  background:rgba(8,8,8,.78);
  color:rgba(255,255,255,.92);
  border:1px solid rgba(255,255,255,.08);
  backdrop-filter:blur(10px);
}
.product-tag--new{background:rgba(79,93,166,.88);border-color:transparent;color:#fff;}
.product-tag--hit{background:rgba(178,54,56,.88);border-color:transparent;color:#fff;}
.product-tag--sale{background:rgba(48,128,98,.88);border-color:transparent;color:#fff;}
.product-tag--limited{background:rgba(166,118,40,.92);border-color:transparent;color:#fff;}

/* Light theme: tags need darker bg */
[data-theme="light"] .product-tag{
  background:rgba(15,15,15,.82);
  color:#fff;
  border-color:transparent;
}

/* Quick-add button refined */
.product-quick{left:14px;right:14px;bottom:14px;}
.product-quick button{
  padding:11px 14px;
  font-size:10px;letter-spacing:.2em;
  border-radius:2px;
  background:rgba(255,255,255,.96);
  color:#0a0a0a;
}

/* --- Buttons: refined premium style --- */
.btn{
  padding:13px 26px;
  font-size:11px;
  letter-spacing:.18em;
  border-radius:2px;
  font-weight:400;
  border-width:1px;
}
.btn-primary{
  background:var(--text);
  color:var(--bg);
  border-color:var(--text);
}
.btn-primary:hover{
  background:transparent;
  color:var(--text);
  border-color:var(--text);
}
.btn-ghost{
  border-color:var(--line-strong);
  color:var(--text-dim);
}
.btn-ghost:hover{
  color:var(--text);
  border-color:var(--text-dim);
  background:transparent;
}

/* --- Form: cleaner inputs --- */
.input,.textarea,.select{
  background:transparent;
  border:1px solid var(--line-strong);
  border-radius:3px;
  padding:13px 15px;
  font-size:13px;
  letter-spacing:.02em;
  transition:border-color .25s;
}
.input:focus,.textarea:focus,.select:focus{
  border-color:var(--text-dim);
  outline:none;
}
.input::placeholder,.textarea::placeholder{
  color:var(--muted);
  letter-spacing:.02em;
}
.field-label{
  font-size:10px;
  letter-spacing:.22em;
  color:var(--muted);
  margin-bottom:7px;
  font-weight:400;
}
.textarea{min-height:90px;}
.form{
  background:transparent;
  border:none;
  padding:0;
}
.form-grid{gap:16px;}

/* --- Reviews polish --- */
.reviews-row{gap:20px;}
.review-card{
  background:transparent;
  border:1px solid var(--line);
  border-radius:4px;
}
.review-card:hover{
  border-color:var(--line-strong);
  transform:translateY(-3px);
}
.review-body{padding:22px 22px 20px;}
.review-text{
  font-family:'Cormorant Garamond','Georgia',serif;
  font-size:15px;
  line-height:1.65;
  font-style:italic;
  color:var(--text-dim);
}
.review-author{
  font-family:'Cormorant Garamond',serif;
  font-style:normal;
  font-size:14px;
  font-weight:600;
  letter-spacing:.02em;
}

/* --- Footer: balanced, refined --- */
.footer{margin-top:88px;}
.footer-top{
  padding:52px 0 36px;
  grid-template-columns:1.2fr 1fr;
  gap:64px;
  align-items:flex-start;
}
.footer-brand-wrap .logo{font-size:18px;}
.footer-tagline{
  font-size:11px;letter-spacing:.05em;
  color:var(--text-dim);
  max-width:280px;line-height:1.7;
  margin:10px 0 22px;
  font-family:'Cormorant Garamond',serif;
  font-style:italic;
  font-size:13px;
}
.footer-socials{gap:10px;}
.footer-socials .social-icon{
  width:34px;height:34px;
  border:1px solid var(--line);
}
.footer-socials .social-icon svg{width:13px;height:13px;}
.footer-socials .social-icon:hover{
  border-color:var(--text-dim);
  transform:translateY(-2px);
}
.footer-nav-row{gap:56px;justify-content:flex-end;padding-top:6px;}
.footer-col-head{
  font-size:9.5px;letter-spacing:.28em;
  color:var(--muted);margin-bottom:18px;font-weight:400;
}
.footer-col a{
  font-size:11px;letter-spacing:.08em;
  margin-bottom:11px;
  color:var(--text-dim);
}
.footer-col a:hover{color:var(--text);}
.footer-bottom{
  font-size:10px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--muted);
  padding:20px 0;
  border-top:1px solid var(--line);
}

/* --- Social icons (universal) --- */
.social-icon{
  width:40px;height:40px;
  border:1px solid var(--line);
  transition:border-color .3s,transform .3s,color .3s;
}
.social-icon svg{width:15px;height:15px;}
.social-icon:hover{
  border-color:var(--text-dim);
  color:var(--text);
}

/* --- Contacts page --- */
.contacts-page-grid{gap:72px;}
.contacts-info{gap:36px;}
.block-title{
  font-family:'Cormorant Garamond',serif;
  font-size:22px;font-weight:600;letter-spacing:.02em;
  margin-bottom:18px;
  padding-bottom:14px;
  border-bottom:1px solid var(--line);
}
.manager-card{
  background:transparent;
  border:1px solid var(--line);
  padding:22px 24px;
  border-radius:4px;
  gap:18px;
}
.manager-card:hover{border-color:var(--line-strong);}
.manager-avatar{
  width:48px;height:48px;
  border:1px solid var(--line-strong);
  background:transparent;
  font-size:22px;font-weight:500;
  color:var(--text);
}
.manager-info .m-name{
  font-size:18px;letter-spacing:.02em;
}
.manager-info .m-role{
  font-size:9.5px;letter-spacing:.22em;color:var(--muted);
}
.manager-info .m-links{
  font-size:13px;
  gap:6px;
  display:flex;flex-direction:column;
}
.manager-info .m-links a,
.manager-info .m-links > span{
  display:inline-flex;
  align-items:center;
  gap:10px;
  color:var(--text-dim);
  text-decoration:none;
  letter-spacing:.01em;
  transition:color .2s;
  padding:2px 0;
}
.manager-info .m-links a:hover{
  color:var(--text);
}
.manager-info .m-link-ico{
  display:inline-flex;
  align-items:center;justify-content:center;
  width:24px;height:24px;
  border-radius:50%;
  background:var(--glass-bg, rgba(255,255,255,.04));
  border:1px solid var(--glass-border, rgba(255,255,255,.08));
  color:var(--text-dim);
  flex-shrink:0;
  transition:color .2s,border-color .2s;
}
.manager-info .m-links a:hover .m-link-ico{
  color:var(--text);
  border-color:var(--text-dim);
}
[data-theme="light"] .manager-info .m-link-ico{
  background:rgba(0,0,0,.03);
  border-color:rgba(0,0,0,.1);
}
.socials-icons-row{gap:10px;}

.contact-form-box{
  background:transparent;
  border:1px solid var(--line);
  border-radius:4px;
  padding:36px;
}
.contact-form-box .form-heading{
  font-size:28px;letter-spacing:.02em;
  margin-bottom:8px;
}
.contact-form-box .form-sub{
  font-family:'Cormorant Garamond',serif;
  font-style:italic;
  font-size:13.5px;
  letter-spacing:.02em;
  color:var(--text-dim);
  margin-bottom:28px;
}

/* --- Cart layout polish --- */
.cart-layout{gap:48px;}
.cart-page-title{
  font-size:24px;
  padding-bottom:18px;margin-bottom:6px;
  border-bottom:1px solid var(--line);
}
.cart-page-title .count{
  font-family:'Cormorant Garamond',serif;
  font-style:italic;
  font-size:13px;letter-spacing:.02em;color:var(--text-dim);
}
.cart-row-v2{
  padding:24px 0;
  grid-template-columns:104px 1fr auto;
  gap:24px;
  border-bottom:1px solid var(--line);
  align-items:center;
}
.cart-row-v2 img{
  width:104px;height:104px;border-radius:3px;
  border:1px solid var(--line);
}
.cart-row-v2 .ci-name{
  font-family:'Cormorant Garamond','Georgia',serif;
  font-size:22px;font-weight:600;
  letter-spacing:.015em;margin-bottom:6px;
  color:var(--text);
}
.cart-row-v2 .ci-unit{
  font-family:'Inter',sans-serif;font-style:normal;
  font-size:13px;color:var(--text-dim);margin-bottom:14px;
  letter-spacing:.02em;font-weight:300;
}
.cart-row-v2 .ci-total{
  font-family:'Cormorant Garamond','Georgia',serif;
  font-style:normal;font-weight:600;
  font-size:24px;color:var(--text);
  letter-spacing:.01em;
}
.cart-row-v2 .ci-remove{
  width:28px;height:28px;
  border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  font-size:16px;line-height:1;
}
.cart-row-v2 .ci-remove:hover{
  color:var(--text);
  background:var(--bg-soft);
}

/* Quantity selector polish */
.qty{
  border:1px solid var(--line-strong);
  border-radius:2px;
}
.qty button{
  width:30px;height:30px;
  font-size:14px;
  transition:color .25s;
}
.qty button:hover{color:var(--text);background:transparent;}
.qty span{
  min-width:30px;
  font-family:'Cormorant Garamond',serif;
  font-size:14px;font-weight:600;
  font-style:normal;
}

.cart-sidebar{gap:18px;}
.cart-sidebar-box{
  background:transparent;
  border:1px solid var(--line);
  border-radius:4px;
  padding:28px 26px;
}
.cart-sidebar-title{
  font-size:20px;
  margin-bottom:18px;
  padding-bottom:14px;
  border-bottom:1px solid var(--line);
  letter-spacing:.02em;
}
.cart-sum-row{
  padding:11px 0;
  font-size:14px;
  letter-spacing:.02em;
  color:var(--text-dim);
}
.cart-sum-row > :last-child{
  font-family:'Cormorant Garamond','Georgia',serif;
  font-style:normal;font-weight:600;
  font-size:16px;
  color:var(--text);
}
.cart-grand{
  padding:18px 0 22px;
  margin-top:6px;
  border-top:none;
}
.cart-grand .gl{
  font-size:10px;letter-spacing:.28em;
  color:var(--muted);
}
.cart-grand .gv{
  font-family:'Cormorant Garamond','Georgia',serif;
  font-style:normal;
  font-size:30px;font-weight:600;letter-spacing:.01em;
  color:var(--text);
}

/* Trust badges refined */
.cart-trust{
  margin-top:8px;
  padding-top:18px;
  border-top:1px solid var(--line);
  gap:11px;
}
.cart-trust-item{
  font-size:11px;
  letter-spacing:.04em;
  color:var(--text-dim);
  gap:10px;
}
.cart-trust-item svg{
  width:13px;height:13px;
  color:var(--text-dim);
  opacity:.65;
}

.cart-continue{
  font-size:10px;letter-spacing:.18em;
  text-transform:uppercase;
  margin-top:24px;
  color:var(--text-dim);
}

/* --- Checkout layout polish --- */
.checkout-layout{gap:40px;}
.checkout-form-box{
  background:transparent;
  border:1px solid var(--line);
  border-radius:4px;
  padding:36px 32px;
}
.checkout-section-title{
  font-family:'Cormorant Garamond',serif;
  font-size:20px;font-weight:600;letter-spacing:.02em;
  margin:30px 0 18px;
  padding-bottom:12px;
  border-bottom:1px solid var(--line);
}
.checkout-section-title:first-child{margin-top:0;}

.checkout-sidebar{gap:18px;}
.checkout-summary-box,.promo-box{
  background:transparent;
  border:1px solid var(--line);
  border-radius:4px;
  padding:26px 24px;
}
.checkout-summary-title{
  font-size:18px;
  margin-bottom:16px;
  padding-bottom:12px;
  border-bottom:1px solid var(--line);
  letter-spacing:.02em;
}
.ck-item{
  padding:11px 0;font-size:14px;
}
.ck-item .ci{
  font-family:'Inter',sans-serif;letter-spacing:.02em;
  color:var(--text-dim);font-weight:300;
}
.ck-item .cp{
  font-family:'Cormorant Garamond','Georgia',serif;
  font-style:normal;font-weight:600;
  font-size:16px;
  color:var(--text);
}
.ck-total{
  margin-top:14px;
  padding-top:14px;
}
.ck-total .tl{font-size:10px;letter-spacing:.28em;color:var(--muted);}
.ck-total .tv{
  font-family:'Cormorant Garamond','Georgia',serif;
  font-style:normal;font-size:30px;font-weight:600;letter-spacing:.01em;
  color:var(--text);
}

.promo-box{padding:22px 24px;}
.promo-box .field-label{margin-bottom:9px;}
.promo-row{gap:8px;}
.promo-row .btn{padding:13px 18px;font-size:10px;letter-spacing:.15em;}

/* Delivery option cards refined */
.delivery-opt-card{
  padding:16px 18px;
  border:1px solid var(--line);
  border-radius:3px;
  margin-bottom:8px;
  gap:14px;
}
.delivery-opt-card:hover{
  border-color:var(--line-strong);
}
.delivery-opt-card:has(input:checked){
  border-color:var(--text);
  background:transparent;
}
.d-name{
  font-size:13.5px;letter-spacing:.02em;font-weight:500;
}
.d-sub{
  font-family:'Cormorant Garamond',serif;
  font-style:italic;
  font-size:12px;
  color:var(--text-dim);
  margin-top:3px;
}

.delivery-warn{
  padding:12px 14px;
  border-radius:3px;
  font-size:11.5px;line-height:1.6;
  background:rgba(166,118,40,.06);
  border-color:rgba(166,118,40,.22);
  color:#a67628;
}

.sdek-select-btn{
  padding:11px 18px;
  font-size:10px;letter-spacing:.16em;
  border-radius:2px;
  border-color:var(--line-strong);
}
.sdek-selected-label{
  font-size:12px;
  padding:10px 14px;
  background:var(--bg-soft);
  border-radius:3px;
  font-family:'Cormorant Garamond',serif;
  font-style:italic;
  font-size:13px;
}

/* --- Product page refined --- */
.product-page-grid{
  gap:64px;
  grid-template-columns:1fr 1fr;
}
.product-gallery-main{
  aspect-ratio:1/1;
  border-radius:4px;
  border:1px solid var(--line);
  max-width:480px;
}
.product-gallery{max-width:480px;}
.product-thumbs{gap:10px;}
.product-thumb{
  width:68px;height:68px;border-radius:3px;
  border-color:var(--line);
}
.product-detail h1{
  font-size:clamp(30px,3.8vw,46px);
  font-weight:500;letter-spacing:.025em;
}
.product-detail .price-block{
  font-family:'Cormorant Garamond','Georgia',serif;
  font-style:normal;
  font-size:34px;font-weight:600;
  letter-spacing:.01em;
  margin:18px 0 26px;
  color:var(--text);
}
.product-detail .desc{
  font-family:'Cormorant Garamond',serif;
  font-size:15.5px;line-height:1.8;
  font-style:normal;
  color:var(--text-dim);
}
.specs-table{margin-top:8px;}
.specs-row > div{padding:14px 0;font-size:13px;}
.specs-row .specs-label{
  letter-spacing:.06em;font-size:11px;text-transform:uppercase;
}
.specs-row .specs-value{
  font-family:'Cormorant Garamond',serif;
  font-style:italic;font-size:14px;
}

/* --- FAQ polish --- */
.faq-header{margin-bottom:36px;text-align:center;}
.faq-list{border-top:1px solid var(--line);max-width:760px;margin:0 auto;}
.faq-q{
  padding:24px 4px;
  font-size:19px;
  font-weight:500;
  color:var(--text-dim);
}
.faq-q:hover{color:var(--text);}
.faq-icon{font-size:18px;color:var(--text-dim);}
.faq-a-inner{
  font-family:'Cormorant Garamond',serif;
  font-size:15px;line-height:1.75;
  padding:0 4px 22px;
  color:var(--text-dim);
}

/* --- CTA refined --- */
.cta-reviews{
  font-size:10px;
  letter-spacing:.32em;
  padding-bottom:6px;
}
.catalog-cta-wrap,.reviews-cta-wrap{margin-top:44px;}

/* --- Success modal refined --- */
.success-back{padding:24px;}
.success-box{
  padding:56px 40px 44px;
  border-radius:4px;
  border:1px solid var(--line-strong);
}
.success-ico{
  width:54px;height:54px;
  background:transparent;
  border:1px solid var(--line-strong);
  color:var(--text);
  margin-bottom:24px;
}
.success-box h3{
  font-size:28px;font-weight:500;letter-spacing:.02em;
  margin-bottom:14px;
}
.success-box p{
  font-family:'Cormorant Garamond',serif;
  font-size:14.5px;line-height:1.7;font-style:normal;
  margin-bottom:28px;
}
.success-order-num{
  font-family:'Cormorant Garamond',serif;
  font-style:italic;font-weight:600;
  font-size:14px;letter-spacing:.05em;
  color:var(--text);
  margin-bottom:24px;
}

/* --- СДЭК modal refined --- */
.sdek-modal{border-radius:4px;}
.sdek-modal-head{padding:18px 24px;}
.sdek-modal-head h4{font-size:12px;letter-spacing:.18em;}

/* --- Empty state refined --- */
.empty-state{
  padding:80px 24px;
  border:1px solid var(--line);
  border-radius:4px;
  background:transparent;
}
.empty-state h3{
  font-size:30px;font-weight:500;letter-spacing:.02em;
  margin-bottom:14px;
}

/* --- Container slight narrower for premium feel --- */
@media(min-width:1280px){
  .container{max-width:1200px;}
}

/* --- Make sure focus rings on cards aren't ugly --- */
a:focus-visible,button:focus-visible{outline:1px solid var(--text-dim);outline-offset:2px;}

/* --- Responsive polish --- */
@media(max-width:960px){
  .hero{padding:88px 0 18px;}
  body[data-page]:not([data-page="home"]) .hero{padding:96px 0 14px;}
  .section{padding:60px 0;}
  .contact-form-box,.checkout-form-box{padding:24px;}
  .footer-nav-row{justify-content:flex-start;}
}
@media(max-width:768px){
  .nav{display:none;}
  .header-inner{height:58px;}
  .products-grid{gap:14px;}
  .cart-row-v2{padding:18px 0;}
  .cart-row-v2 img{width:80px;height:80px;}
}

/* ===================================================================== */
/* ============== LIQUID GLASS v4 — final design overhaul =============== */
/* ===================================================================== */

/* ---------- New font stack ---------- */
body, button, input, textarea, select{
  font-family:'Manrope','SF Pro Display',system-ui,-apple-system,sans-serif;
  font-feature-settings:'ss01','cv11';
  font-weight:400;
  letter-spacing:-.005em;
}
h1,h2,h3,h4,h5,h6,
.gothic,
.product-name,.product-price,
.cart-row-v2 .ci-name,.cart-row-v2 .ci-total,
.cart-grand .gv,.ck-total .tv,
.review-text,.review-author,
.block-title,.manager-info .m-name,
.cart-sidebar-title,.cart-page-title,
.checkout-section-title,.checkout-summary-title,
.product-detail h1,.product-detail .price-block,
.contact-form-box .form-heading,
.success-box h3,
.faq-q,
.specs-row .specs-value,
.ck-item .cp,
.cart-sum-row > :last-child,
.empty-state h3,
.hero-title,
.section-title{
  font-family:'Playfair Display','Georgia',serif;
  letter-spacing:-.005em;
}
.logo{font-family:'Pirata One',serif;}

/* ---------- Glass tokens ---------- */
:root{
  --glass-bg:rgba(255,255,255,0.035);
  --glass-bg-stronger:rgba(255,255,255,0.07);
  --glass-bg-modal:rgba(20,20,22,0.6);
  --glass-border:rgba(255,255,255,0.09);
  --glass-border-strong:rgba(255,255,255,0.16);
  --glass-shadow:0 8px 32px -8px rgba(0,0,0,0.5);
  --glass-shadow-lg:0 24px 60px -12px rgba(0,0,0,0.65);
  --glass-highlight:inset 0 1px 0 rgba(255,255,255,0.08);
  --radius-lg:18px;
  --radius-md:12px;
  --radius-sm:10px;
}
[data-theme="light"]{
  --glass-bg:rgba(255,255,255,0.5);
  --glass-bg-stronger:rgba(255,255,255,0.7);
  --glass-bg-modal:rgba(248,247,244,0.85);
  --glass-border:rgba(0,0,0,0.07);
  --glass-border-strong:rgba(0,0,0,0.15);
  --glass-shadow:0 8px 32px -8px rgba(0,0,0,0.1);
  --glass-shadow-lg:0 24px 60px -12px rgba(0,0,0,0.18);
  --glass-highlight:inset 0 1px 0 rgba(255,255,255,0.7);
}

/* ---------- Apply glass to all card surfaces ---------- */
.cart-sidebar-box,
.checkout-form-box,
.checkout-summary-box,
.promo-box,
.contact-form-box,
.manager-card,
.review-card,
.delivery-opt-card,
.empty-state,
.product-image,
.product-gallery-main,
.product-thumb,
.cart-row-v2 img,
.gallery-item,
.sdek-selected-label,
.contact-item,
.stat{
  background:var(--glass-bg);
  -webkit-backdrop-filter:blur(40px) saturate(180%);
  backdrop-filter:blur(40px) saturate(180%);
  border:1px solid var(--glass-border);
  box-shadow:var(--glass-shadow), var(--glass-highlight);
  border-radius:var(--radius-md);
}
.review-card,
.manager-card,
.cart-sidebar-box,
.checkout-form-box,
.checkout-summary-box,
.promo-box,
.contact-form-box{
  border-radius:var(--radius-lg);
}

/* Product image: rounded corners (как скриншот на iOS) */
.product-image{
  border-radius:18px;
  overflow:hidden;
}
.product-card:hover .product-image{
  box-shadow:0 16px 40px -12px rgba(0,0,0,0.55), var(--glass-highlight);
}

/* Product gallery */
.product-gallery-main{
  border-radius:20px;
}
.product-thumb{
  border-radius:10px;
}

/* Cart row image */
.cart-row-v2 img{
  border-radius:14px;
}

/* Gallery items */
.gallery-item{
  border-radius:14px;
}

/* ---------- Glass tags: subtle, frosted ---------- */
.product-tag{
  background:rgba(255,255,255,0.1);
  -webkit-backdrop-filter:blur(20px) saturate(200%);
  backdrop-filter:blur(20px) saturate(200%);
  border:1px solid rgba(255,255,255,0.18);
  color:rgba(255,255,255,0.95);
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.15), 0 4px 12px -2px rgba(0,0,0,0.25);
  padding:5px 13px;
  border-radius:24px;
  font-size:10px;
  letter-spacing:.14em;
  font-weight:500;
  text-transform:uppercase;
  font-family:'Manrope',sans-serif;
}
.product-tag--new{
  background:rgba(120,128,200,0.2);
  border-color:rgba(140,148,220,0.32);
  color:#dde0fa;
}
.product-tag--hit{
  background:rgba(200,80,80,0.2);
  border-color:rgba(220,100,100,0.32);
  color:#ffdcdc;
}
.product-tag--sale{
  background:rgba(80,180,140,0.2);
  border-color:rgba(100,200,160,0.32);
  color:#d2f5e2;
}
.product-tag--limited{
  background:rgba(220,160,80,0.22);
  border-color:rgba(240,180,100,0.32);
  color:#ffeac8;
}
[data-theme="light"] .product-tag{
  background:rgba(15,15,15,0.65);
  border-color:rgba(255,255,255,0.18);
  color:#fff;
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.15), 0 4px 12px -2px rgba(0,0,0,0.15);
}
[data-theme="light"] .product-tag--new{background:rgba(60,70,160,0.85);}
[data-theme="light"] .product-tag--hit{background:rgba(160,40,40,0.85);}
[data-theme="light"] .product-tag--sale{background:rgba(40,140,90,0.85);}
[data-theme="light"] .product-tag--limited{background:rgba(180,120,40,0.85);}

/* ---------- Header glass ---------- */
.header{
  background:rgba(11,11,11,0.55);
  -webkit-backdrop-filter:blur(28px) saturate(180%);
  backdrop-filter:blur(28px) saturate(180%);
  border-bottom:1px solid var(--glass-border);
}
[data-theme="light"] .header{
  background:rgba(248,247,244,0.7);
}

/* ---------- Buttons: liquid glass ---------- */
.btn{
  border-radius:30px;
  padding:14px 28px;
  font-weight:500;
  letter-spacing:.1em;
  font-size:11px;
  text-transform:uppercase;
  transition:transform .3s, box-shadow .3s, background .3s;
}
.btn-primary{
  background:var(--text);
  color:var(--bg);
  border:1px solid var(--text);
  box-shadow:0 6px 18px -4px rgba(0,0,0,0.4);
}
.btn-primary:hover{
  transform:translateY(-2px);
  box-shadow:0 14px 28px -8px rgba(0,0,0,0.5);
  background:var(--text);
  color:var(--bg);
}
.btn-ghost{
  background:var(--glass-bg);
  -webkit-backdrop-filter:blur(20px);
  backdrop-filter:blur(20px);
  border:1px solid var(--glass-border-strong);
  color:var(--text-dim);
}
.btn-ghost:hover{
  background:var(--glass-bg-stronger);
  color:var(--text);
  border-color:var(--text-dim);
}

/* ---------- Inputs: glass ---------- */
.input,.textarea,.select{
  background:var(--glass-bg);
  -webkit-backdrop-filter:blur(20px);
  backdrop-filter:blur(20px);
  border:1px solid var(--glass-border-strong);
  border-radius:12px;
  padding:14px 16px;
  font-size:14px;
  letter-spacing:0;
  font-family:'Manrope',sans-serif;
}
.input:focus,.textarea:focus,.select:focus{
  border-color:var(--text-dim);
  background:var(--glass-bg-stronger);
}
.field-label{
  font-family:'Manrope',sans-serif;
  font-size:11px;letter-spacing:.18em;
  color:var(--muted);font-weight:500;
}

/* ---------- Social icons glass ---------- */
.social-icon{
  background:var(--glass-bg);
  -webkit-backdrop-filter:blur(20px);
  backdrop-filter:blur(20px);
  border:1px solid var(--glass-border);
  border-radius:50%;
}
.social-icon:hover{
  background:var(--glass-bg-stronger);
  transform:translateY(-2px);
}

/* ---------- Quantity glass ---------- */
.qty{
  background:var(--glass-bg);
  -webkit-backdrop-filter:blur(20px);
  backdrop-filter:blur(20px);
  border:1px solid var(--glass-border-strong);
  border-radius:30px;
  padding:2px;
}
.qty button{
  width:32px;height:32px;
  border-radius:50%;
}

/* ---------- Filter buttons glass ---------- */
.filter-btn{
  background:var(--glass-bg);
  -webkit-backdrop-filter:blur(20px);
  backdrop-filter:blur(20px);
  border:1px solid var(--glass-border);
  border-radius:30px;
  padding:10px 20px;
  font-family:'Manrope',sans-serif;
  font-size:11px;
}
.filter-btn:hover{background:var(--glass-bg-stronger);}
.filter-btn.active{
  background:var(--text);
  color:var(--bg);
  border-color:var(--text);
}

/* ---------- Modal: heavy glass ---------- */
.modal,.success-box,.sdek-modal{
  background:var(--glass-bg-modal);
  -webkit-backdrop-filter:blur(60px) saturate(200%);
  backdrop-filter:blur(60px) saturate(200%);
  border:1px solid var(--glass-border);
  box-shadow:var(--glass-shadow-lg), var(--glass-highlight);
  border-radius:24px;
}
.success-back,.sdek-modal-back,.modal-back{
  background:rgba(0,0,0,0.4);
  -webkit-backdrop-filter:blur(8px);
  backdrop-filter:blur(8px);
}
[data-theme="light"] .success-back,
[data-theme="light"] .sdek-modal-back{
  background:rgba(255,255,255,0.3);
}

/* ---------- Hero unified (Каталог = Галерея) ---------- */
.hero{
  padding:100px 0 22px;
  text-align:center;
}
.hero-title{
  font-size:clamp(38px,5vw,64px);
  letter-spacing:-.015em;
  font-weight:500;
}
.hero-kicker{
  font-family:'Manrope',sans-serif;
  font-size:11px;
  letter-spacing:.28em;
  font-weight:500;
  color:var(--text-dim);
  text-transform:uppercase;
  margin-bottom:16px;
}
.hero-kicker::before,.hero-kicker::after{
  background:linear-gradient(90deg, transparent, var(--glass-border-strong), transparent);
}
.hero-subtitle{
  font-family:'Manrope',sans-serif;
  font-size:14px;font-style:normal;
  letter-spacing:.02em;color:var(--text-dim);
  margin-top:14px;font-weight:400;
}

/* Section labels using Manrope */
.section-label,.cart-grand .gl,.ck-total .tl,.field-label,
.footer-col-head,.product-tag,
.cta-reviews,.filter-btn,.nav a,.lang-switch button,
.delivery-opt-card .d-name,.btn,.cart-trust-item,
.section-title-center .kick,.success-modal h3,
.faq-icon,.product-quick button,.section-label{
  font-family:'Manrope',sans-serif;
}

/* Typography refinements */
.product-name{
  font-size:18px;font-weight:600;letter-spacing:-.015em;
}
.product-price{
  font-size:18px;font-weight:600;letter-spacing:-.01em;
}
.cart-row-v2 .ci-name{
  font-size:22px;font-weight:600;letter-spacing:-.01em;
}
.cart-row-v2 .ci-total{
  font-size:24px;font-weight:600;letter-spacing:-.01em;
}
.cart-grand .gv,.ck-total .tv{
  font-size:32px;font-weight:600;letter-spacing:-.015em;
}
.product-detail h1{
  font-size:clamp(32px,4vw,48px);font-weight:500;letter-spacing:-.02em;
}
.product-detail .price-block{
  font-size:36px;font-weight:600;letter-spacing:-.015em;
}
.section-title{
  font-size:clamp(28px,3.5vw,42px);font-weight:500;letter-spacing:-.015em;
}
.review-text{
  font-size:15px;font-style:normal;font-weight:400;line-height:1.7;
  letter-spacing:-.005em;
}
.review-author{
  font-size:14px;font-weight:600;font-style:normal;
}
.faq-q{
  font-size:18px;font-weight:500;letter-spacing:-.01em;
}
.faq-a-inner{
  font-family:'Manrope',sans-serif;font-size:14px;line-height:1.7;
  letter-spacing:-.005em;
}
.contact-form-box .form-heading{font-size:28px;font-weight:500;letter-spacing:-.02em;}
.success-box h3{font-size:28px;font-weight:500;letter-spacing:-.02em;}
.checkout-section-title{font-size:20px;font-weight:600;letter-spacing:-.01em;}
.checkout-summary-title,.cart-sidebar-title{font-size:18px;font-weight:600;letter-spacing:-.01em;}
.cart-page-title{font-size:24px;font-weight:600;letter-spacing:-.015em;}
.block-title{font-size:22px;font-weight:600;letter-spacing:-.015em;}
.manager-info .m-name{font-size:18px;font-weight:600;letter-spacing:-.01em;}

/* ---------- Toast glass ---------- */
.toast{
  background:var(--glass-bg-modal);
  -webkit-backdrop-filter:blur(40px);
  backdrop-filter:blur(40px);
  border:1px solid var(--glass-border);
  border-radius:14px;
  font-family:'Manrope',sans-serif;
  font-size:13px;letter-spacing:0;
  box-shadow:var(--glass-shadow);
}

/* ---------- Mobile menu trigger ---------- */
.mobile-toggle{
  display:none;
  background:var(--glass-bg);
  -webkit-backdrop-filter:blur(20px);
  backdrop-filter:blur(20px);
  border:1px solid var(--glass-border);
  border-radius:50%;
  width:36px;height:36px;
  align-items:center;justify-content:center;
  cursor:pointer;color:var(--text);
}
.mobile-toggle svg{width:16px;height:16px;}

/* ================== ПЕРЕРАБОТАННЫЕ ТЕГИ (читаемые glass) ================== */
.product-tag{
  position:absolute;top:12px;left:12px;
  padding:6px 12px;
  font-size:10px;font-weight:600;
  letter-spacing:.14em;text-transform:uppercase;
  font-family:'Manrope','Inter',sans-serif;
  border-radius:6px;
  background:rgba(15,15,18,.78) !important;
  color:#fff !important;
  border:1px solid rgba(255,255,255,.12) !important;
  -webkit-backdrop-filter:blur(20px) saturate(160%);
  backdrop-filter:blur(20px) saturate(160%);
  box-shadow:
    0 4px 12px rgba(0,0,0,.25),
    inset 0 1px 0 rgba(255,255,255,.08);
  z-index:3;
  text-shadow:0 1px 2px rgba(0,0,0,.4);
}
/* Цветной акцент — точка слева вместо заливки фона */
.product-tag::before{
  content:'';
  display:inline-block;
  width:6px;height:6px;
  border-radius:50%;
  margin-right:8px;
  vertical-align:middle;
  background:rgba(255,255,255,.6);
  box-shadow:0 0 6px currentColor;
}
.product-tag--new{color:#fff !important;}
.product-tag--new::before{background:#6e8cff;color:#6e8cff;}
.product-tag--hit{color:#fff !important;}
.product-tag--hit::before{background:#ff6b6b;color:#ff6b6b;}
.product-tag--sale{color:#fff !important;}
.product-tag--sale::before{background:#4ade80;color:#4ade80;}
.product-tag--limited{color:#fff !important;}
.product-tag--limited::before{background:#fbbf24;color:#fbbf24;}

/* Светлая тема — тоже тёмный фон у тегов (для контраста на любых картинках) */
[data-theme="light"] .product-tag{
  background:rgba(15,15,18,.82) !important;
  color:#fff !important;
  border-color:rgba(255,255,255,.1) !important;
}

/* ================== СДЭК PICKER ================== */
.sdek-picker{
  display:flex;flex-direction:column;
  height:100%;
  min-height:0;
  background:var(--bg);
}
.sdek-picker-search{
  position:relative;
  padding:14px 18px;
  border-bottom:1px solid var(--line);
  flex-shrink:0;
}
.sdek-picker-search svg{
  position:absolute;left:30px;top:50%;transform:translateY(-50%);
  color:var(--muted);pointer-events:none;
}
.sdek-picker-search .input{
  padding-left:38px;
  height:42px;
  font-size:13px;
}
.sdek-cities-list{
  flex-shrink:0;
  max-height:200px;
  overflow-y:auto;
  border-bottom:1px solid var(--line);
}
.sdek-cities-list:empty{display:none;border-bottom:none;}
.sdek-city-item{
  display:flex;
  width:100%;
  align-items:center;justify-content:space-between;
  padding:11px 18px;
  background:transparent;border:none;
  color:var(--text-dim);
  font-size:13px;
  cursor:pointer;
  text-align:left;
  transition:background .2s,color .2s;
  font-family:inherit;
}
.sdek-city-item:hover{
  background:var(--bg-soft);
  color:var(--text);
}
.sdek-arrow{color:var(--muted);font-size:14px;}
.sdek-offices-list{
  flex:1 1 0;
  min-height:0;
  overflow-y:auto;
  -webkit-overflow-scrolling:touch;
  padding:8px 0;
  /* nice scrollbar */
  scrollbar-width:thin;
  scrollbar-color:var(--line-strong) transparent;
}
.sdek-offices-list::-webkit-scrollbar{width:6px;}
.sdek-offices-list::-webkit-scrollbar-thumb{background:var(--line-strong);border-radius:3px;}
.sdek-offices-list::-webkit-scrollbar-track{background:transparent;}
.sdek-offices-head{
  padding:12px 18px 14px;
  font-size:11px;
  letter-spacing:.04em;
  color:var(--muted);
  border-bottom:1px solid var(--line);
  margin-bottom:6px;
}
.sdek-offices-head b{color:var(--text);font-weight:600;}
.sdek-office-item{
  display:block;width:100%;text-align:left;
  padding:14px 18px;
  background:transparent;border:none;
  border-bottom:1px solid var(--line);
  cursor:pointer;
  font-family:inherit;
  color:var(--text);
  transition:background .2s;
}
.sdek-office-item:hover{background:var(--bg-soft);}
.sdek-office-item:last-child{border-bottom:none;}
.sof-name{
  font-family:'Playfair Display',serif;
  font-size:15px;font-weight:600;
  margin-bottom:4px;
  color:var(--text);
}
.sof-addr{
  font-size:12px;color:var(--text-dim);
  line-height:1.5;
}
.sof-time{
  font-size:11px;color:var(--muted);margin-top:5px;
}
.sdek-hint{
  padding:32px 20px;text-align:center;
  font-size:13px;color:var(--muted);
}
.sdek-err{color:#ff6b6b;}
.sdek-fallback{
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  height:100%;min-height:420px;padding:32px;
  text-align:center;color:var(--text-dim);
}

/* СДЭК pickup label styling (compact and readable) */
.sdek-selected-label{
  font-family:'Manrope',sans-serif;
  font-size:12.5px;line-height:1.55;
  font-style:normal;
  letter-spacing:0;
}
.sdek-selected-label b{font-weight:600;color:var(--text);}

/* ================== FIX MOBILE MENU CASCADE ================== */
/* Гарантируем что hamburger показывается на всех узких экранах */
@media(max-width:900px){
  .nav{display:none !important;}
  .mobile-toggle{display:inline-flex !important;}
  .lang-switch{display:none;} /* экономим место в header */
}
.mobile-menu.show ~ .mobile-menu-back,
.mobile-menu-back.show{
  opacity:1 !important;pointer-events:auto !important;
}

/* Mobile menu sheet */
.mobile-menu{
  position:fixed;top:0;right:-100%;
  width:min(320px,80%);height:100vh;
  background:var(--glass-bg-modal);
  -webkit-backdrop-filter:blur(60px) saturate(200%);
  backdrop-filter:blur(60px) saturate(200%);
  border-left:1px solid var(--glass-border);
  padding:80px 28px 28px;
  z-index:200;
  transition:right .35s cubic-bezier(.4,0,.2,1);
  display:flex;flex-direction:column;gap:22px;
}
.mobile-menu.show{right:0;}
.mobile-menu a{
  font-family:'Playfair Display',serif;
  font-size:22px;font-weight:500;letter-spacing:-.015em;
  color:var(--text-dim);transition:.3s;
}
.mobile-menu a:hover,.mobile-menu a.active{color:var(--text);}
.mobile-menu-back{
  position:fixed;inset:0;
  background:rgba(0,0,0,0.4);
  -webkit-backdrop-filter:blur(4px);
  backdrop-filter:blur(4px);
  z-index:199;
  opacity:0;pointer-events:none;
  transition:opacity .3s;
}
.mobile-menu-back.show{opacity:1;pointer-events:auto;}
.mobile-close{
  position:absolute;top:20px;right:20px;
  background:none;border:none;color:var(--text);
  cursor:pointer;font-size:24px;line-height:1;
}

/* ============= MOBILE OPTIMIZATIONS ============= */
@media(max-width:900px){
  .container{padding:0 18px;}
  .hero{padding:88px 0 18px;}
  .hero-title{font-size:clamp(32px,7vw,44px);}
  .hero-kicker{font-size:10px;letter-spacing:.2em;}
  .hero-subtitle{font-size:13px;}
  .section{padding:48px 0;}

  .nav{display:none;}
  .mobile-toggle{display:flex;}
  .header-inner{height:58px;}
  .header-right{gap:8px;}

  /* Catalog grid: 2 columns */
  .products-grid{grid-template-columns:1fr 1fr; gap:10px;}
  .product-name{font-size:15px;}
  .product-price{font-size:15px;}
  .product-image{border-radius:14px;}
  .product-info{padding:12px 4px 4px;}
  .product-quick{display:none;}

  /* Cart mobile */
  .cart-layout{gap:24px;}
  .cart-row-v2{
    grid-template-columns:80px 1fr;
    grid-template-areas:
      "img info"
      "img controls"
      "total total";
    gap:14px;padding:18px 0;
  }
  .cart-row-v2 img{
    grid-area:img;width:80px;height:80px;border-radius:12px;
  }
  .cart-row-v2 > div:nth-child(2){grid-area:info;}
  .cart-row-v2 .ci-name{font-size:18px;}
  .cart-row-v2 .ci-total{
    grid-area:total;text-align:left;font-size:20px;
    padding-top:6px;border-top:1px solid var(--glass-border);
  }
  .cart-page-title{font-size:20px;}
  .cart-sidebar-box{padding:22px 18px;}
  .cart-sidebar-title{font-size:17px;}
  .cart-grand .gv{font-size:26px;}

  /* Checkout mobile */
  .checkout-layout{gap:18px;}
  .checkout-form-box{padding:22px 18px;}
  .checkout-section-title{font-size:18px;}
  .checkout-summary-box,.promo-box{padding:20px 18px;}
  .delivery-opt-card{padding:14px 16px;}

  /* Contacts mobile */
  .contacts-page-grid{grid-template-columns:1fr;gap:28px;}
  .contact-form-box{padding:24px 20px;}
  .contact-form-box .form-heading{font-size:24px;}
  .manager-card{padding:18px;gap:14px;}

  /* Gallery mobile */
  .gallery-grid{grid-template-columns:1fr 1fr;gap:8px;}

  /* Reviews mobile */
  .reviews-row{grid-template-columns:1fr;gap:14px;}

  /* Footer mobile */
  .footer{margin-top:48px;}
  .footer-top{
    grid-template-columns:1fr;
    padding:32px 0 24px;gap:24px;
  }
  .footer-nav-row{gap:36px;justify-content:flex-start;flex-wrap:wrap;}
  .footer-bottom{
    flex-direction:column;align-items:flex-start;
    gap:8px;padding:18px 0;
  }
  .footer-tagline{max-width:none;}

  /* FAQ mobile */
  .faq-q{font-size:16px;padding:18px 4px;}

  /* Product page mobile */
  .product-page-grid{grid-template-columns:1fr;gap:24px;}
  .product-detail h1{font-size:clamp(26px,7vw,34px);}
  .product-detail .price-block{font-size:28px;margin:14px 0 20px;}
  .product-gallery{max-width:none;}
  .product-gallery-main{max-width:none;border-radius:16px;}

  /* Modals mobile */
  .success-box{padding:36px 24px;border-radius:20px;}
  .sdek-modal{border-radius:18px;width:calc(100% - 24px);}

  /* Buttons mobile */
  .btn{padding:13px 22px;}
}

@media(max-width:480px){
  .products-grid{grid-template-columns:1fr 1fr;gap:8px;}
  .filters{gap:6px;}
  .filter-btn{padding:8px 14px;font-size:10px;}
  .hero-title{font-size:clamp(28px,8vw,38px);}
}

/* ---------- Smooth animations everywhere ---------- */
.product-card,.review-card,.manager-card,.delivery-opt-card,
.btn,.social-icon,.filter-btn,.cart-btn,.theme-toggle,
.mobile-toggle,.gallery-item,.cart-row-v2 .ci-remove{
  transition:transform .3s cubic-bezier(.34,1.56,.64,1),
             border-color .3s,
             background .3s,
             box-shadow .3s,
             color .3s;
}

/* ===================================================================== */
/* ============== REFINEMENT v5 — numerals, ambient, legal ============= */
/* ===================================================================== */

/* ---------- Numerals: expressive yet even & restrained (Fraunces) ----- */
:root{
  --font-num:'Fraunces','Playfair Display','Georgia',serif;
}
.product-price,
.product-old,
.product-detail .price-block,
.ck-item .cp,
.ck-total .tv,
.cart-row-v2 .ci-total,
.cart-row-v2 .ci-unit,
.cart-grand .gv,
.cart-sum-row > :last-child,
.qty span,
.success-order-num{
  font-family:var(--font-num);
  font-optical-sizing:auto;
  font-variant-numeric:lining-nums tabular-nums;
  font-feature-settings:'lnum' 1,'tnum' 1;
  -webkit-font-smoothing:antialiased;
}
/* Tuned weights/spacing so figures sit calm and even */
.product-price{font-weight:500;letter-spacing:.005em;}
.product-detail .price-block{font-weight:500;letter-spacing:.005em;}
.ck-total .tv,.cart-grand .gv{font-weight:500;letter-spacing:.01em;}
.ck-item .cp{font-weight:500;font-size:15px;}
.cart-row-v2 .ci-total{font-weight:500;}
.product-old{font-weight:400;letter-spacing:0;}

/* ---------- Ambient shimmering background (subtle, premium) ---------- */
:root{
  --amb-1:rgba(120,128,200,.10);
  --amb-2:rgba(200,150,90,.08);
  --amb-3:rgba(90,160,150,.06);
}
[data-theme="light"]{
  --amb-1:rgba(90,100,180,.10);
  --amb-2:rgba(190,140,70,.10);
  --amb-3:rgba(70,150,130,.07);
}
body::before{
  content:'';
  position:fixed;inset:-20% -20% -20% -20%;
  z-index:-2;
  pointer-events:none;
  background:
    radial-gradient(42% 38% at 18% 12%, var(--amb-1), transparent 70%),
    radial-gradient(46% 42% at 85% 22%, var(--amb-2), transparent 72%),
    radial-gradient(50% 46% at 50% 92%, var(--amb-3), transparent 74%);
  filter:blur(10px);
  animation:ambientDrift 26s ease-in-out infinite alternate;
}
/* Fine grain / vignette layer for depth */
body::after{
  content:'';
  position:fixed;inset:0;
  z-index:-1;
  pointer-events:none;
  background:
    radial-gradient(120% 100% at 50% 0%, transparent 60%, rgba(0,0,0,.28) 100%);
  opacity:.7;
}
[data-theme="light"] body::after{
  background:radial-gradient(120% 100% at 50% 0%, transparent 62%, rgba(0,0,0,.06) 100%);
}
@keyframes ambientDrift{
  0%{transform:translate3d(0,0,0) scale(1);}
  50%{transform:translate3d(-2.5%,1.5%,0) scale(1.06);}
  100%{transform:translate3d(2%,-1.5%,0) scale(1.03);}
}
@media (prefers-reduced-motion:reduce){
  body::before{animation:none;}
}

/* Thin shimmer line under the header — concentrated in the center,
   fading to almost invisible toward the screen edges */
.header::after{
  content:'';
  position:absolute;left:0;right:0;bottom:-1px;height:1px;
  background:linear-gradient(90deg,
    transparent 0%,
    rgba(255,255,255,.015) 28%,
    var(--glass-border-strong) 50%,
    rgba(255,255,255,.015) 72%,
    transparent 100%);
  pointer-events:none;
}
[data-theme="light"] .header::after{
  background:linear-gradient(90deg,
    transparent 0%,
    rgba(0,0,0,.02) 28%,
    var(--glass-border-strong) 50%,
    rgba(0,0,0,.02) 72%,
    transparent 100%);
}
.header{position:sticky;top:0;z-index:100;}

/* ---------- Logo image support ---------- */
.logo{display:inline-flex;align-items:center;gap:0;}
.logo img{
  height:30px;width:auto;max-width:200px;
  object-fit:contain;display:block;
}
.footer-brand-wrap .logo img{height:34px;}
@media(max-width:900px){ .logo img{height:26px;} }
/* In light theme, optionally invert a white PNG logo if marked */
[data-theme="light"] .logo img.logo-invert{filter:invert(1);}

/* ---------- Footer: requisites + legal links ---------- */
.footer-bottom{
  display:flex;flex-direction:column;gap:14px;
  align-items:flex-start;
  text-transform:none;letter-spacing:.01em;
}
.footer-legal-links{
  display:flex;flex-wrap:wrap;gap:8px 22px;
}
.footer-legal-links a{
  font-family:'Manrope',sans-serif;
  font-size:11px;letter-spacing:.04em;
  color:var(--text-dim);
  text-transform:none;
  transition:color .25s;
}
.footer-legal-links a:hover{color:var(--text);}
.footer-requisites{
  font-family:'Manrope',sans-serif;
  font-size:11px;line-height:1.7;letter-spacing:.01em;
  color:var(--muted);
  text-transform:none;
  max-width:760px;
}
.footer-requisites b{color:var(--text-dim);font-weight:600;}
.footer-requisites .req-sep{margin:0 8px;opacity:.5;}

/* ---------- Consent checkboxes (forms collecting personal data) ------- */
.consent-row{
  display:flex;align-items:flex-start;gap:12px;
  margin:6px 0 4px;cursor:pointer;
  font-family:'Manrope',sans-serif;
}
.consent-row input[type="checkbox"]{position:absolute;opacity:0;width:0;height:0;}
.consent-box{
  flex-shrink:0;margin-top:1px;
  width:20px;height:20px;border-radius:6px;
  background:var(--glass-bg);
  border:1px solid var(--glass-border-strong);
  -webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);
  display:inline-flex;align-items:center;justify-content:center;
  transition:background .25s,border-color .25s,transform .15s;
}
.consent-box svg{width:12px;height:12px;color:var(--bg);opacity:0;transform:scale(.5);transition:opacity .2s,transform .2s;}
.consent-row input:checked + .consent-box{
  background:var(--text);border-color:var(--text);
}
.consent-row input:checked + .consent-box svg{opacity:1;transform:scale(1);}
.consent-row input:focus-visible + .consent-box{outline:2px solid var(--text-dim);outline-offset:2px;}
.consent-text{
  font-size:11.5px;line-height:1.6;color:var(--text-dim);
  letter-spacing:.005em;
}
.consent-text a{color:var(--text);text-decoration:underline;text-underline-offset:2px;text-decoration-color:var(--line-strong);}
.consent-text a:hover{text-decoration-color:var(--text);}

/* ---------- Legal pages ---------- */
.legal-page{
  max-width:840px;margin:0 auto;
  padding:8px 0 40px;
}
.legal-page .legal-meta{
  font-family:'Manrope',sans-serif;
  font-size:12px;color:var(--muted);letter-spacing:.04em;
  margin-bottom:32px;padding-bottom:20px;
  border-bottom:1px solid var(--line);
}
.legal-page h2{
  font-family:'Playfair Display',serif;
  font-size:22px;font-weight:600;letter-spacing:-.01em;
  margin:34px 0 14px;color:var(--text);
}
.legal-page h2:first-of-type{margin-top:0;}
.legal-page h3{
  font-family:'Playfair Display',serif;
  font-size:17px;font-weight:600;
  margin:22px 0 10px;color:var(--text);
}
.legal-page p,.legal-page li{
  font-family:'Manrope',sans-serif;
  font-size:14px;line-height:1.8;letter-spacing:.005em;
  color:var(--text-dim);margin-bottom:12px;
}
.legal-page ul,.legal-page ol{padding-left:22px;margin-bottom:14px;}
.legal-page li{margin-bottom:7px;}
.legal-page .legal-req{
  margin-top:36px;padding:24px 26px;
  background:var(--glass-bg);
  border:1px solid var(--glass-border);
  -webkit-backdrop-filter:blur(40px);backdrop-filter:blur(40px);
  border-radius:var(--radius-lg);
  box-shadow:var(--glass-shadow),var(--glass-highlight);
}
.legal-page .legal-req h2{margin-top:0;}
.legal-page .legal-req p{margin-bottom:6px;}
.legal-toc{
  display:flex;flex-wrap:wrap;gap:8px 18px;
  margin-bottom:34px;
}
.legal-toc a{
  font-family:'Manrope',sans-serif;font-size:12px;
  color:var(--text-dim);letter-spacing:.03em;
}
.legal-toc a:hover{color:var(--text);}

/* ===================================================================== */
/* ============== REFINEMENT v6 — fixes & product gallery ============== */
/* ===================================================================== */

/* Spec values: clean & restrained (was ornate Playfair italic) */
.specs-row .specs-value{
  font-family:'Manrope',sans-serif !important;
  font-style:normal !important;
  font-weight:500;
  letter-spacing:.005em;
  font-variant-numeric:lining-nums tabular-nums;
  color:var(--text);
}

/* Logo image: a touch larger so it has presence */
.logo img{height:40px;max-width:240px;}
.footer-brand-wrap .logo img{height:46px;}
@media(max-width:900px){ .logo img{height:32px;} }

/* ---------- Product gallery: arrows ---------- */
.product-gallery-main{position:relative;}
.pg-arrow{
  position:absolute;top:50%;transform:translateY(-50%);
  width:44px;height:44px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:var(--glass-bg-stronger);
  -webkit-backdrop-filter:blur(20px) saturate(160%);
  backdrop-filter:blur(20px) saturate(160%);
  border:1px solid var(--glass-border-strong);
  color:var(--text);cursor:pointer;z-index:4;
  box-shadow:var(--glass-shadow);
  opacity:0;transition:opacity .25s,background .25s,transform .25s;
}
.product-gallery-main:hover .pg-arrow{opacity:1;}
.pg-arrow:hover{background:var(--text);color:var(--bg);}
.pg-arrow svg{width:18px;height:18px;}
.pg-arrow.pg-prev{left:12px;}
.pg-arrow.pg-next{right:12px;}
.product-gallery-main #pg-main{cursor:zoom-in;}
/* small "click to zoom" hint */
.pg-zoom-hint{
  position:absolute;bottom:12px;right:12px;z-index:4;
  display:flex;align-items:center;gap:6px;
  padding:7px 12px;border-radius:20px;
  background:var(--glass-bg-stronger);
  -webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);
  border:1px solid var(--glass-border);
  font-family:'Manrope',sans-serif;font-size:10px;letter-spacing:.1em;
  text-transform:uppercase;color:var(--text-dim);
  opacity:0;transition:opacity .25s;pointer-events:none;
}
.product-gallery-main:hover .pg-zoom-hint{opacity:.9;}
.pg-zoom-hint svg{width:12px;height:12px;}
@media(max-width:900px){ .pg-arrow{opacity:1;width:38px;height:38px;} .pg-zoom-hint{display:none;} }

/* Video thumb (play badge overlay) */
.product-thumb.is-video{position:relative;}
.product-thumb.is-video::after{
  content:'';position:absolute;inset:0;
  background:rgba(0,0,0,.35);
  display:block;
}
.product-thumb.is-video .pg-play{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:24px;height:24px;border-radius:50%;
  background:rgba(255,255,255,.92);color:#111;
  display:flex;align-items:center;justify-content:center;z-index:2;
}
.product-thumb.is-video .pg-play svg{width:11px;height:11px;}

/* ---------- Lightbox (zoom image / play video) ---------- */
.lightbox-back{
  position:fixed;inset:0;z-index:300;
  display:none;align-items:center;justify-content:center;
  padding:5vh 5vw;
  background:rgba(0,0,0,.78);
  -webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);
}
.lightbox-back.show{display:flex;}
.lightbox-content{
  position:relative;
  max-width:86vw;max-height:86vh;
  display:flex;align-items:center;justify-content:center;
}
.lightbox-content img,
.lightbox-content video,
.lightbox-content iframe{
  max-width:86vw;max-height:86vh;
  width:auto;height:auto;
  border-radius:14px;
  box-shadow:var(--glass-shadow-lg);
  background:#000;
}
.lightbox-content iframe{width:min(86vw,1000px);aspect-ratio:16/9;height:auto;}
.lightbox-close{
  position:fixed;top:22px;right:26px;z-index:301;
  width:44px;height:44px;border-radius:50%;
  background:var(--glass-bg-stronger);
  -webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);
  border:1px solid var(--glass-border-strong);
  color:var(--text);font-size:22px;line-height:1;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
}
.lightbox-close:hover{background:var(--text);color:var(--bg);}
.lightbox-nav{
  position:fixed;top:50%;transform:translateY(-50%);z-index:301;
  width:50px;height:50px;border-radius:50%;
  background:var(--glass-bg-stronger);
  -webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);
  border:1px solid var(--glass-border-strong);
  color:var(--text);cursor:pointer;
  display:flex;align-items:center;justify-content:center;
}
.lightbox-nav:hover{background:var(--text);color:var(--bg);}
.lightbox-nav svg{width:20px;height:20px;}
.lightbox-nav.lb-prev{left:20px;}
.lightbox-nav.lb-next{right:20px;}
@media(max-width:900px){
  .lightbox-content,.lightbox-content img,.lightbox-content video{max-width:92vw;max-height:80vh;}
  .lightbox-nav{width:40px;height:40px;}
  .lightbox-nav.lb-prev{left:8px;} .lightbox-nav.lb-next{right:8px;}
}

/* Inline product video block (under gallery) */
.product-video-inline{
  margin-top:14px;border-radius:14px;overflow:hidden;
  border:1px solid var(--glass-border);
  background:#000;
}
.product-video-inline video,
.product-video-inline iframe{width:100%;display:block;aspect-ratio:16/9;border:0;}

/* Track-by-number form on orders page */
.track-direct-box{margin-top:20px;}
.track-direct-row{display:flex;gap:10px;flex-wrap:wrap;}
.track-direct-row .input{flex:1;min-width:180px;}
.track-direct-row .select{flex:0 0 180px;}

/* ===================================================================== */
/* ============== REFINEMENT v7 — logo, arrows, crop, etc. ============= */
/* ===================================================================== */

/* --- Product gallery arrows: solid, readable on ANY image / theme --- */
.pg-arrow{
  background:rgba(18,18,20,.72) !important;
  border:1px solid rgba(255,255,255,.22) !important;
  color:#fff !important;
  box-shadow:0 4px 16px rgba(0,0,0,.4), inset 0 1px 0 rgba(255,255,255,.12);
}
.pg-arrow:hover{
  background:#fff !important;
  color:#111 !important;
  border-color:#fff !important;
}
[data-theme="light"] .pg-arrow{
  background:rgba(255,255,255,.85) !important;
  border-color:rgba(0,0,0,.16) !important;
  color:#111 !important;
}
[data-theme="light"] .pg-arrow:hover{background:#111 !important;color:#fff !important;border-color:#111 !important;}

/* --- Header logo: larger, slightly overflowing the bar (PNG) --- */
.header{overflow:visible;}
.logo img{height:88px;max-width:300px;transform:translateY(15px);}
@media(max-width:900px){ .logo img{height:58px;transform:translateY(9px);max-width:190px;} }

/* --- Footer logo: noticeably bigger --- */
.footer-brand-wrap .logo{display:block;}
.footer-brand-wrap .logo img{height:104px;max-width:300px;transform:none;}
@media(max-width:900px){ .footer-brand-wrap .logo img{height:76px;} }

/* --- Logo "remove contrast / background" option (PNG on dark bg) --- */
.logo img.logo-blend{
  mix-blend-mode:screen;
  filter:contrast(.92) brightness(1.04);
}
[data-theme="light"] .logo img.logo-blend{
  mix-blend-mode:multiply;
}

/* --- Checkout success: "remember order number" note --- */
.success-remember{
  display:flex;align-items:flex-start;gap:10px;text-align:left;
  margin:6px auto 18px;max-width:380px;
  padding:13px 16px;border-radius:12px;
  background:var(--glass-bg);
  border:1px solid var(--glass-border-strong);
  -webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);
  font-family:'Manrope',sans-serif;
  font-size:12px;line-height:1.6;color:var(--text-dim);
}
.success-remember b{color:var(--text);font-weight:600;}
.success-order-num{font-size:18px;}

/* --- Admin: reorder buttons --- */
.reorder-btn{
  min-width:30px;padding:5px 9px;font-size:14px;line-height:1;
  cursor:pointer;
}
.reorder-btn:disabled{opacity:.3;cursor:not-allowed;}

/* --- Admin: minimal logo crop modal --- */
.crop-modal-back{
  position:fixed;inset:0;z-index:400;
  display:none;align-items:center;justify-content:center;
  background:rgba(0,0,0,.6);
  -webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);
}
.crop-modal-back.show{display:flex;}
.crop-modal{
  background:var(--glass-bg-modal);
  -webkit-backdrop-filter:blur(40px) saturate(160%);backdrop-filter:blur(40px) saturate(160%);
  border:1px solid var(--glass-border);
  border-radius:18px;padding:22px;width:min(380px,92vw);
  box-shadow:var(--glass-shadow-lg);
}
.crop-modal h4{font-family:'Playfair Display',serif;font-size:18px;font-weight:600;margin-bottom:6px;}
.crop-modal .crop-hint{font-family:'Manrope',sans-serif;font-size:12px;color:var(--text-dim);margin-bottom:14px;line-height:1.5;}
.crop-stage{
  position:relative;width:300px;height:300px;max-width:100%;
  margin:0 auto;border-radius:14px;overflow:hidden;
  background:#0d0d10;border:1px solid var(--glass-border-strong);
  cursor:grab;touch-action:none;
}
.crop-stage:active{cursor:grabbing;}
.crop-stage img{position:absolute;top:0;left:0;transform-origin:0 0;user-select:none;pointer-events:none;max-width:none;}
.crop-stage::after{
  content:'';position:absolute;inset:0;pointer-events:none;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.18);
  border-radius:14px;
}
.crop-zoom-row{display:flex;align-items:center;gap:10px;margin:16px 0 18px;}
.crop-zoom-row label{font-family:'Manrope',sans-serif;font-size:11px;color:var(--muted);letter-spacing:.1em;text-transform:uppercase;}
.crop-zoom{flex:1;}
.crop-actions{display:flex;gap:10px;justify-content:flex-end;}

/* ===================================================================== */
/* ============== REFINEMENT v8 — premium finishing details =========== */
/* ===================================================================== */

/* --- Grain / film texture overlay (kills "digital flatness") --- */
#fx-grain{
  position:fixed;inset:0;z-index:1;
  pointer-events:none;
  opacity:.035;
  mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:160px 160px;
}
[data-theme="light"] #fx-grain{opacity:.05;mix-blend-mode:multiply;}
@media (prefers-reduced-motion:reduce){ #fx-grain{opacity:.025;} }

/* --- Centered gradient dividers (replace flat lines) --- */
.footer-bottom{border-top:none !important;position:relative;}
.footer-bottom::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--glass-border-strong) 50%,transparent);
}
.faq-list{border-top:none !important;position:relative;}
.faq-list::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--glass-border-strong) 50%,transparent);
}
.legal-page .legal-meta{border-bottom:none;position:relative;padding-bottom:22px;}
.legal-page .legal-meta::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--glass-border-strong) 50%,transparent);
}

/* --- Typography polish: balanced headings + ligatures --- */
h1,h2,h3,h4,.hero-title,.section-title,.product-name,
.product-detail h1,.block-title,.success-box h3{
  text-wrap:balance;
}
body,button,input,textarea,select{
  font-feature-settings:'ss01','cv11','liga' 1,'calt' 1;
}

/* --- Empty states: subtle illustration instead of "—" --- */
.empty-state{position:relative;}
.empty-state::before{
  content:'';
  display:block;width:54px;height:54px;margin:0 auto 20px;
  opacity:.35;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23999' stroke-width='1' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 3h12l4 6-10 13L2 9z'/%3E%3Cpath d='M11 3 8 9l4 13 4-13-3-6'/%3E%3Cpath d='M2 9h20'/%3E%3C/svg%3E") center/contain no-repeat;
}
.empty-state h3{font-size:22px;}

/* --- Skeleton shimmer (loading placeholder) --- */
.skel-card{pointer-events:none;}
.skel{
  position:relative;overflow:hidden;
  background:var(--glass-bg);
  border:1px solid var(--glass-border);
  border-radius:18px;
}
.skel::after{
  content:'';position:absolute;inset:0;
  transform:translateX(-100%);
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.06) 50%,transparent);
  animation:skelShimmer 1.3s infinite;
}
[data-theme="light"] .skel::after{background:linear-gradient(90deg,transparent,rgba(0,0,0,.04) 50%,transparent);}
.skel-img{aspect-ratio:1/1;}
.skel-line{height:13px;border-radius:6px;margin-top:14px;}
.skel-line.w60{width:60%;}
.skel-line.w30{width:30%;margin-top:10px;}
@keyframes skelShimmer{100%{transform:translateX(100%);}}
@media (prefers-reduced-motion:reduce){ .skel::after{animation:none;} }


/* ===================================================================== */
/* ============== REFINEMENT v9 — cleaner product card edges ========== */
/* ===================================================================== */

/* Consistent, crisp corner radius */
.product-image{border-radius:16px;}
@media(max-width:900px){ .product-image{border-radius:14px;} }

/* Softer, shorter bottom vignette — no heavy dark blob on the rounded edge */
.product-image::after{
  height:46%;
  background:linear-gradient(180deg, transparent, rgba(0,0,0,.42));
}
[data-theme="light"] .product-image::after{
  background:linear-gradient(180deg, transparent, rgba(0,0,0,.34));
}

/* Quick-add: frosted glass pill that reads on any image / theme */
.product-quick{left:14px;right:14px;bottom:14px;}
.product-quick button{
  flex:1;
  border-radius:12px;
  padding:12px 16px;
  background:rgba(255,255,255,.16);
  -webkit-backdrop-filter:blur(18px) saturate(160%);
  backdrop-filter:blur(18px) saturate(160%);
  border:1px solid rgba(255,255,255,.28);
  color:#fff;
  box-shadow:0 6px 20px -6px rgba(0,0,0,.4), inset 0 1px 0 rgba(255,255,255,.16);
  font-family:'Manrope',sans-serif;
  font-size:10px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;
}
.product-quick button:hover{
  background:rgba(255,255,255,.96);
  color:#0a0a0a;
  border-color:#fff;
}
[data-theme="light"] .product-quick button{
  background:rgba(18,18,22,.5);
  border-color:rgba(255,255,255,.22);
  color:#fff;
}
[data-theme="light"] .product-quick button:hover{
  background:#111;color:#fff;border-color:#111;
}

/* Softer hover shadow (was a heavy near-black drop, harsh in light theme) */
.product-card:hover .product-image{
  box-shadow:0 18px 38px -16px rgba(0,0,0,0.42), var(--glass-highlight);
}
[data-theme="light"] .product-card:hover .product-image{
  box-shadow:0 18px 40px -18px rgba(0,0,0,0.26);
}

/* Clean hairline edge on the image in both themes */
.product-image{ border:1px solid var(--glass-border); }
[data-theme="light"] .product-image{ border-color:rgba(0,0,0,.06); }
