/* SK SERVICE — red & white clean theme */
:root{
  --red:#b1181a;
  --dark:#0c0c0c;
  --text:#1b1b1b;
  --muted:#6b6b6b;
  --bg:#fafafa;
  --card:#ffffff;
  --radius:16px;
  --shadow:0 10px 25px rgba(0,0,0,.08);
  --line:#eee;
  --container-max: 1280px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{ font-size: clamp(15px, 1.1vw, 18px); }
body{
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  color:var(--text); background:var(--bg);
  padding-left: env(safe-area-inset-left); padding-right: env(safe-area-inset-right);
}
.container{max-width:min(var(--container-max),96vw);margin:0 auto;padding:0 16px}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%;height:auto}
.no-scroll{overflow:hidden}

/* Header */
.site-header{background:#fff;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:40}
.header-row{display:flex;align-items:center;gap:16px;min-height:72px}
.brand{display:flex;align-items:center;gap:10px;font-weight:700;font-size:18px}
.brand img{border-radius:999px}
.search{flex:1;display:flex;align-items:center;background:#f2f2f2;border-radius:999px;padding:8px 10px;max-width:700px}
.search input{flex:1;border:none;background:transparent;outline:none;font-size:15px;padding:6px 8px}
.search button{border:none;background:var(--red);color:#fff;border-radius:999px;padding:8px 14px;display:flex;align-items:center;gap:6px;cursor:pointer}
.actions{display:flex;align-items:center;gap:14px}
.actions .link{padding:10px 12px;border-radius:10px}
.actions .link:hover{background:#f5f5f5}
.cart{display:flex;align-items:center;gap:8px;position:relative;padding:8px 10px;border-radius:10px;background:#fff;box-shadow:0 1px 0 #eee}
.cart:hover{background:#f9f9f9}
.cart-count{position:absolute;top:-6px;right:-6px;background:var(--red);color:#fff;border-radius:999px;padding:2px 6px;font-size:12px}

/* Nav scroller */
.nav-scroller{border-top:1px solid var(--line);background:#fff; box-shadow: inset 0 -1px 0 var(--line); }
.nav-wrap{display:flex;gap:18px;overflow:auto;padding:10px 0;justify-content:space-between;align-items:center}
.nav-links{display:flex;gap:18px;overflow:auto}
.nav-link{padding:6px 8px;color:#555}
.nav-link.hot{color:var(--red);font-weight:600}
.config-btn{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--red);color:#fff;font-weight:700;
  padding:10px 16px;border-radius:999px;white-space:nowrap;
  box-shadow:0 1px 0 #eee; margin-right:6px;
}
.config-btn:hover{filter:brightness(0.95)}

/* Burger (hidden on desktop) */
.burger{ display:none }
@media (max-width:1024px){
  .burger{
    display:flex; background:#fff; border:1px solid #eaeaea; border-radius:12px;
    width:42px; height:42px; align-items:center; justify-content:center; gap:4px; padding:0 6px
  }
  .burger span{ display:block; width:22px; height:2px; background:#111; border-radius:2px }
  .nav-scroller .container.nav-wrap .nav-links{ display:none }
  .config-btn{ display:none }
}

/* Mobile off-canvas menu */
.mnav-backdrop{
  position:fixed; inset:0; background:rgba(0,0,0,.32); opacity:0; transition:opacity .2s ease; z-index:90;
}
.mnav-backdrop.show{ opacity:1 }
.mnav{
  position:fixed; top:0; left:0; bottom:0; width:84vw; max-width:360px; background:#fff; z-index:100;
  transform:translateX(-100%); transition:transform .2s ease; box-shadow:0 16px 48px rgba(0,0,0,.18);
  display:flex; flex-direction:column; padding:12px;
}
.mnav.open{ transform:none }
.mnav-head{ display:flex; align-items:center; justify-content:space-between; gap:8px; margin-bottom:8px }
.mnav-brand{ display:flex; align-items:center; gap:10px; font-weight:700 }
.mnav-close{ background:#fff; border:1px solid var(--line); border-radius:10px; width:36px; height:36px; display:grid; place-items:center }
.mnav-search{ display:flex; gap:8px; margin-bottom:8px }
.mnav-search input{ flex:1; padding:10px 12px; border:1px solid #e5e5e5; border-radius:10px }
.mnav-search button{ padding:0 10px; border:1px solid #e5e5e5; border-radius:10px; background:#fff }
.mnav-link, .mnav-config{ display:block; padding:10px 12px; border-radius:10px; text-decoration:none; color:#111 }
.mnav-link:hover{ background:#f6f7f8 }
.mnav-config{ background:var(--red); color:#fff; text-align:center; margin-top:6px }
.mnav-hr{ height:1px; background:var(--line); margin:8px 0 }

/* Hero */
.hero{position:relative;background:linear-gradient(135deg, #fff 0%, #fff 40%, rgba(177,24,26,.07) 100%);}
.hero .container{display:grid;grid-template-columns:1.2fr .8fr;gap:24px;align-items:center;padding:26px 16px}
.hero h1{font-size:36px;line-height:1.1;margin:8px 0 12px}
.hero p{color:var(--muted);max-width:600px}
.hero .cta{display:flex;gap:12px;margin-top:18px}
.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 18px;border-radius:12px;border:1px solid transparent;font-weight:600;cursor:pointer}
.btn-primary{background:var(--red);color:#fff}
.btn-outline{background:#fff;border-color:#ddd}
.hero-card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px}

/* Full-bleed Slider (full width) */
.slider{
  position:relative;overflow:hidden;background:#fff;
  width:100%;max-width:none;border-radius:0;margin:0; box-shadow:var(--shadow);
}
.slides{display:flex;transition:transform .5s ease; width:100%}
.slide{min-width:100%;display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:center;padding:40px clamp(16px,5vw,60px);background:#fff}
.slide h2{font-size:32px;margin:0 0 8px}
.slide p{color:var(--muted);margin:0 0 12px}
.slide img{border-radius:20px;box-shadow:var(--shadow);width:100%;height:auto;object-fit:cover}
.slider-nav{position:absolute;inset:auto 12px 12px auto;display:flex;gap:8px}
.slider-nav button{width:10px;height:10px;border-radius:50%;border:none;background:#ddd;cursor:pointer}
.slider-nav button.active{background:var(--red)}
@media (max-width:900px){
  .slide{grid-template-columns:1fr;padding:30px 20px;text-align:center}
  .slide img{margin-top:18px}
}

/* Sections & grids */
.section{padding:28px 0}
.section h2{font-size:22px;margin:6px 0 14px}
.grid{display:grid;grid-template-columns:repeat(6,1fr);gap:14px}
@media (max-width: 1200px){ .grid{ grid-template-columns: repeat(5,1fr); } }
@media (max-width: 1024px){ .grid{ grid-template-columns: repeat(4,1fr); } }
@media (max-width: 820px){  .grid{ grid-template-columns: repeat(3,1fr); } }
@media (max-width: 560px){  .grid{ grid-template-columns: repeat(2,1fr); } }
@media (max-width: 360px){  .grid{ grid-template-columns: 1fr; } }

/* Category cards */
.cat-card{background:var(--card);border-radius:14px;padding:14px;box-shadow:var(--shadow);display:flex;align-items:center;gap:12px;min-height:74px;transition:transform .2s}
.cat-card:hover{transform:translateY(-2px)}
.cat-icon{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;background:#ffecec;color:var(--red);font-weight:700}
/* Category w/ subcats on home */
.cat-card.with-sub{
  background:#fff;border:1px solid var(--line);border-radius:14px;padding:12px;display:flex;flex-direction:column;gap:10px;
  transition:box-shadow .2s ease, transform .05s ease;
}
.cat-card.with-sub:hover{ box-shadow:0 8px 24px rgba(0,0,0,.06); transform:translateY(-1px); }
.cat-head{ display:flex; align-items:center; gap:12px; color:inherit; }
.cat-name{ font-weight:600; }
.cat-more{ color:var(--muted); font-size:12px; }
.subcats{ display:flex; flex-wrap:wrap; gap:6px; }
.subcat{
  display:inline-block;padding:6px 10px;border:1px solid var(--line);border-radius:999px;font-size:12px;line-height:1;color:#374151;background:#fafafa
}
.subcat:hover{ border-color:#d9d9df;background:#f3f4f6 }
@media (max-width: 640px){
  .cat-card.with-sub{ padding:10px }
  .subcat{ font-size:11px; padding:6px 9px }
}

/* Products */
.products{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
@media (max-width: 1100px){ .products{ grid-template-columns: repeat(3,1fr); } }
@media (max-width: 820px){  .products{ grid-template-columns: repeat(2,1fr); } }
@media (max-width: 420px){  .products{ grid-template-columns: 1fr; } }
.prod{background:var(--card);border-radius:16px;box-shadow:var(--shadow);padding:12px;display:flex;flex-direction:column}
.prod img{border-radius:12px;aspect-ratio:4/3;object-fit:cover;background:#f2f2f2}
.prod h3{font-size:16px;margin:10px 0 6px; line-height:1.25; }
.price{font-weight:700;font-size:18px}
.buy{margin-top:auto;display:flex;gap:10px}
.buy .btn{flex:1;justify-content:center}

/* Filters / Catalog */
.filters{display:grid;grid-template-columns:260px 1fr;gap:16px;align-items:start}
.filter-card{background:var(--card);border-radius:14px;box-shadow:var(--shadow);padding:16px; position:sticky; top:72px; }
.filter-card h3{margin:0 0 10px;font-size:16px}
.filter-group{margin-bottom:14px}
.filter-group label{display:block;font-size:13px;color:var(--muted);margin-bottom:6px}
.filter-group input[type="text"],
.filter-group input[type="number"],
.filter-group select{width:100%;padding:10px;border:1px solid #e5e5e5;border-radius:10px;background:#fff}
.btn-filter{width:100%;margin-top:8px}
.catalog-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.sort{display:flex;align-items:center;gap:10px}
.sort select{padding:8px 10px;border:1px solid #e5e5e5;border-radius:10px;background:#fff}
@media (max-width: 900px){
  .filters{grid-template-columns:1fr}
  .filter-card{ position:static; }
  .catalog-head{ flex-wrap:wrap; gap:10px }
  .sort{ margin-left:auto }
}
@media (max-width: 480px){
  .sort{ width:100%; justify-content:space-between }
  .sort select{ flex:1 }
}

/* Product page */
.product-card{display:grid;grid-template-columns:1fr 1fr;gap:24px; align-items:start }
.product-gallery img{border-radius:16px;box-shadow:var(--shadow);background:#f5f5f5}
.product-info h1{margin:0 0 8px}
.product-info .price{font-size:24px;margin:10px 0 16px}
.product-info .buy .btn{height:44px}
@media (max-width:560px){
  .product-info .buy{flex-direction:column}
  .product-info .buy .btn{width:100%; min-height:44px}
}

/* Tables / Cart */
.table{width:100%;border-collapse:separate;border-spacing:0 10px}
.table th{font-weight:600;text-align:left;font-size:14px;color:#666}
.table td{background:var(--card);padding:12px;border-top:1px solid #eee;border-bottom:1px solid #eee}
.qty{width:72px;padding:8px;border:1px solid #e5e5e5;border-radius:10px}
.cart-summary{background:var(--card);border-radius:16px;box-shadow:var(--shadow);padding:16px}
.cart-actions{display:flex;justify-content:space-between;gap:10px;margin-top:12px}
@media (max-width:920px){
  .table{ display:block; overflow-x:auto; white-space:nowrap; border-spacing:0 }
  .table thead{ position:sticky; top:0; background:#fff }
}
@media (max-width:560px){
  .cart-actions{ flex-wrap:wrap }
  .cart-actions .btn{ flex:1 1 48%; justify-content:center }
}
.filter-card form .btn,
.btn-filter{ min-height:44px }

/* Footer */
.site-footer{background:#111;color:#ddd;margin-top:28px}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:18px;padding:24px 16px}
.brand-min{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.copyright{text-align:center;border-top:1px solid #222;padding:12px;color:#aaa}
@media (max-width:820px){ .foot-grid{ grid-template-columns:1fr 1fr } }
@media (max-width:520px){ .foot-grid{ grid-template-columns:1fr } }

/* Promo (Акции) */
.promo-grid{ display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:12px }
@media (max-width:1024px){ .promo-grid{ grid-template-columns:repeat(2,minmax(0,1fr)) } }
@media (max-width:640px){  .promo-grid{ grid-template-columns:1fr } }
.promo-card{ background:#fff; border:1px solid var(--line); border-radius:14px; overflow:hidden; display:flex; flex-direction:column }
.promo-cover{ position:relative; aspect-ratio: 16/7; background:#f6f7f8 }
.promo-cover img{ width:100%; height:100%; object-fit:cover }
.promo-badge{ position:absolute; right:10px; top:10px; background:#111; color:#fff; font-size:12px; padding:4px 8px; border-radius:999px }
.promo-body{ padding:12px; display:flex; flex-direction:column; gap:6px }
.promo-title{ margin:0 }
.promo-sub{ color:var(--muted); font-size:13px }
.promo-text{ margin:6px 0 8px; color:#374151 }
.promo-cta{ display:flex; gap:8px; margin-top:auto; flex-wrap:wrap }

/* Contacts */
.grid-contacts{ display:grid; grid-template-columns: 1.1fr 1fr; gap:16px; align-items:start }
@media (max-width:1024px){ .grid-contacts{ grid-template-columns:1fr } }
.contact-cards{ display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:12px }
@media (max-width:640px){ .contact-cards{ grid-template-columns:1fr } }
.contact-card{ background:#fff; border:1px solid var(--line); border-radius:12px; padding:12px }
.contact-title{ font-weight:600; margin-bottom:6px }
.contact-line{ color:#374151 }
.contact-link{ color:#111; text-decoration:none; border-bottom:1px dashed #ccc }
.contact-link:hover{ border-bottom-color:#999 }
.contact-form{ background:#fff; border:1px solid var(--line); border-radius:12px; padding:12px; display:flex; flex-direction:column; gap:8px }
.contact-form .form-row{ display:flex; gap:8px }
@media (max-width:640px){ .contact-form .form-row{ flex-direction:column } }
.contact-form .input{ width:100% }
.form-note{ color:var(--muted); font-size:12px }
.contact-map{ height:320px; border:1px solid var(--line); border-radius:12px; overflow:hidden }

/* Delivery */
.delivery-grid{ display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:12px }
@media (max-width:1200px){ .delivery-grid{ grid-template-columns:repeat(2,minmax(0,1fr)) } }
@media (max-width:640px){  .delivery-grid{ grid-template-columns:1fr } }
.ul{ margin:0; padding-left:18px }
.ol{ margin:0; padding-left:18px }
.faq summary{ cursor:pointer; padding:8px 10px; background:#f6f7f8; border-radius:10px; margin-bottom:6px }
.faq div{ padding:4px 2px 8px 10px; color:#374151 }

/* Catalog flyout panel — light (no dim, scrollable page, compact) */
.catalog-panel{
  position:fixed; inset:0; z-index:1000; pointer-events:none;
}
.catalog-panel__backdrop{
  display:none !important;     /* убрали затемнение */
}
.catalog-panel__inner{
  position:absolute; top:12px; right:12px;
  width:min(820px,92vw);       /* компактнее */
  max-height:calc(100vh - 24px);
  background:#fff; border:1px solid var(--line);
  border-radius:16px; box-shadow:0 12px 30px rgba(0,0,0,.12);
  transform:translateX(calc(100% + 12px)); /* выезжает из-за правого края */
  transition:transform .22s ease;
  display:flex; flex-direction:column;
  pointer-events:auto;
}
.catalog-panel.open{ pointer-events:auto; }
.catalog-panel.open .catalog-panel__inner{ transform:none; }

.catalog-panel__head{
  display:flex; align-items:center; justify-content:space-between;
  padding:10px 12px; border-bottom:1px solid var(--line)
}
.catalog-panel__title{ font-size:16px; font-weight:700 }
.catalog-panel__close{
  background:#fff; border:1px solid #e5e7eb; border-radius:10px;
  padding:8px; cursor:pointer
}
.catalog-panel__close:hover{ background:#f8f9fb }

.catalog-panel__body{
  padding:10px 12px 16px;
  overflow:auto; max-height:calc(100vh - 24px - 48px);
}

.catalog-grid{ display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:12px }
@media (max-width:720px){ .catalog-grid{ grid-template-columns:1fr } }

.catalog-col{
  background:#fff; border:1px solid var(--line);
  border-radius:12px; padding:10px; box-shadow:0 1px 0 rgba(0,0,0,.03)
}
.cat-head-link{ display:flex; align-items:center; gap:10px; color:inherit; padding:6px; border-radius:10px }
.cat-head-link:hover{ background:#f8f9fb }
.cat-icon{ font-size:20px; width:28px; text-align:center }
.cat-title{ font-weight:600 }

.sub-toggle{
  margin-top:6px; width:100%;
  display:flex; align-items:center; justify-content:space-between;
  gap:6px; padding:7px 9px;
  background:#fff; border:1px solid #e5e7eb; border-radius:10px; cursor:pointer
}
.sub-toggle[aria-expanded="true"]{ background:#f6f7fb }
.sub-list{
  display:grid; gap:6px; padding:8px; margin-top:6px;
  background:#fbfbfd; border:1px dashed #e5e7eb; border-radius:10px
}
.sub-link{ display:flex; align-items:center; padding:6px 8px; border-radius:8px; color:#111827 }
.sub-link:hover{ background:#eef2ff }
.catalog-empty{padding:12px;background:#fbfbfd;border:1px dashed #e5e7eb;border-radius:12px}

/* Wider screens fine-tune */
@media (min-width: 1600px){
  .products{ gap: 18px; }
  .grid{ gap: 16px; }
}
@media (min-width: 1400px){ :root{ --container-max: 1380px; } }
@media (min-width: 1600px){ :root{ --container-max: 1480px; } }
@media (min-width: 1800px){ :root{ --container-max: 1560px; } }
@media (min-width: 2000px){ :root{ --container-max: 1680px; } }

/* Adaptive small tweaks */
@media (max-width: 860px){
  .header-row{ flex-wrap: wrap; gap:14px }
  .brand img{ width:40px; height:40px }
  .brand span{ font-size:16px }
  .search{ order:3; width:100%; max-width:none }
  .actions{ margin-left:auto }
}
@media (max-width: 520px){
  .actions .link{ display:none }
  .cart-text{ display:none }
  .cart{ padding:8px }
  .container{ padding-left:12px; padding-right:12px }
}

/* Reduce motion */
@media (prefers-reduced-motion: reduce){
  .slides{ transition:none }
  .cat-card, .prod, .config-btn{ transition:none }
}
/* === Compact product cards (safe overrides) === */

/* Больше колонок, компактные отступы */
.products{
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)) !important;
  gap: 12px !important;
}

/* Сама карточка — меньше паддинги/радиус/тень */
.prod{
  padding: 10px !important;
  border-radius: 12px !important;
  box-shadow: 0 6px 18px rgba(0,0,0,.06) !important;
}

/* Фото — чуть меньше, аккуратнее скругление */
.prod img{
  border-radius: 10px !important;
  aspect-ratio: 4 / 3 !important;   /* сохраняем пропорции */
  object-fit: cover;
}

/* Название — компактнее и в 2 строки максимум */
.prod h3{
  font-size: 14px !important;
  margin: 8px 0 4px !important;
  line-height: 1.25;
  display: -webkit-box;
  -webkit-line-clamp: 2;   /* обрезаем до 2 строк */
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* Цена — тоже компактнее */
.price{
  font-size: 16px !important;
}

/* Кнопки — ниже и меньше */
.buy{
  margin-top: auto;
  gap: 8px !important;
}
.buy .btn{
  padding: 10px 12px !important;
  min-height: 36px !important;
  font-size: 13px !important;
  border-radius: 10px !important;
  justify-content: center;
}

/* Чуть плотнее сетка на очень широких экранах */
@media (min-width: 1400px){
  .products{ gap: 14px !important; }
}
/* На узких — держим удобочитаемость */
@media (max-width: 420px){
  .products{ grid-template-columns: repeat(2, 1fr) !important; }
}
