/* ============================================================
   INSIZE Catalog — статический CSS для WordPress-темы
   Цвет бренда: #00693E  |  Шрифт: system-ui / Inter
   ============================================================ */

/* ---------- Reset & Base ---------------------------------- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --green:    #00693E;
  --green-10: rgba(0, 105, 62, .10);
  --green-20: rgba(0, 105, 62, .20);
  --muted:    #6b7280;
  --border:   #e5e7eb;
  --bg:       #ffffff;
  --bg-gray:  #f9fafb;
  --text:     #111827;
  --radius:   .75rem;
  --shadow-sm: 0 1px 3px rgba(0,0,0,.08);
  --shadow-md: 0 4px 12px rgba(0,0,0,.12);
  --max-w: 1440px;
  --px: clamp(1rem, 4vw, 2rem);
}

html { scroll-behavior: smooth; overflow-x: hidden; }

body {
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Inter", sans-serif;
  font-size: 16px;
  line-height: 1.6;
  color: var(--text);
  background: var(--bg);
  overflow-x: hidden;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
ul, ol { list-style: none; }
button { cursor: pointer; font-family: inherit; }
address { font-style: normal; }

/* ---------- Layout Helpers -------------------------------- */
.container {
  width: 100%;
  max-width: var(--max-w);
  margin-inline: auto;
  padding-inline: var(--px);
}

.sr-only {
  position: absolute; width: 1px; height: 1px;
  overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap;
}

/* ---------- Typography ------------------------------------ */
h1 { font-size: clamp(1.8rem, 5vw, 3.5rem); font-weight: 700; line-height: 1.15; }
h2 { font-size: clamp(1.4rem, 3vw, 2rem);   font-weight: 700; line-height: 1.2; }
h3 { font-size: 1.1rem; font-weight: 600; }
h4 { font-size: .875rem; font-weight: 600; }
.text-muted  { color: var(--muted); }
.text-xs     { font-size: .75rem; }
.text-sm     { font-size: .875rem; }
.text-green  { color: var(--green); }
.label-tag {
  font-size: .7rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: .1em; color: var(--green);
}

/* ---------- Buttons --------------------------------------- */
.btn {
  display: inline-flex; align-items: center; gap: .5rem;
  padding: .625rem 1.5rem; border-radius: .5rem;
  font-size: .875rem; font-weight: 600;
  border: 1.5px solid transparent; transition: all .15s;
  white-space: nowrap; cursor: pointer;
  max-width: 100%; box-sizing: border-box;
}
.btn-primary  { background: var(--green); color: #fff; border-color: var(--green); }
.btn-primary:hover { background: #005a35; border-color: #005a35; }
.btn-outline  { background: transparent; color: var(--text); border-color: var(--border); }
.btn-outline:hover { border-color: var(--green); color: var(--green); }
.btn-white    { background: #fff; color: var(--green); }
.btn-white:hover { background: #f0f9f4; }
.btn-hero-ghost { background: transparent; color: #fff; border-color: transparent; }
.btn-hero-ghost:hover { background: rgba(255,255,255,.12); border-color: rgba(255,255,255,.2); }
.btn-lg       { padding: .75rem 2rem; font-size: 1rem; }
.btn-sm       { padding: .375rem .875rem; font-size: .8rem; }

/* ---------- Form ------------------------------------------ */
.form-label { display: block; font-size: .875rem; font-weight: 500; margin-bottom: .375rem; }
.form-label span.req { color: #ef4444; }
.form-control {
  width: 100%; padding: .625rem .875rem;
  border: 1.5px solid var(--border); border-radius: .5rem;
  font-size: .875rem; font-family: inherit;
  background: #fff; color: var(--text);
  transition: border-color .15s, box-shadow .15s;
  appearance: none;
}
.form-control:focus { outline: none; border-color: var(--green); box-shadow: 0 0 0 3px var(--green-10); }
.form-control::placeholder { color: #9ca3af; }
textarea.form-control { resize: vertical; min-height: 130px; }
/* Попап ассистента: одна строка ввода — не наследовать 130px и resize от форм CF7 */
textarea.form-control.popup-input {
  resize: none;
  min-height: 2.5rem;
  width: auto;
}
.form-hint { font-size: .7rem; color: var(--muted); line-height: 1.5; margin-top: .5rem; }

/* ---------- HEADER ---------------------------------------- */
.site-header {
  position: sticky; top: 0; z-index: 100;
  background: #fff; border-bottom: 1px solid var(--border);
  box-shadow: var(--shadow-sm);
  transition: box-shadow .25s;
  will-change: box-shadow;
}
.site-header.scrolled { box-shadow: var(--shadow-md); }

.header-inner {
  display: flex; align-items: center; justify-content: space-between;
  gap: 1rem; height: 4.5rem;
}

.header-logo-group { display: flex; align-items: center; gap: 1rem; flex-shrink: 1; min-width: 0; }
.logo-insize { height: 2.25rem; object-fit: contain; }

/* Header: Indust brand + dealer badge (wordpress-static) */
.header-brand-link {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  color: inherit;
}
/* Один элемент: class="logo-indust header-brand-logo" — нужна большая специфичность,
   иначе общий .logo-indust ниже по файлу перебивает height/object-fit */
.logo-indust.header-brand-logo {
  height: 2.75rem;
  width: auto;
  object-fit: contain;
}
.header-dealer-badge {
  font-size: .6rem;
  font-weight: 600;
  letter-spacing: .04em;
  color: var(--muted);
  line-height: 1.4;
  padding-left: 1px;
  max-width: 11rem;
}

.site-nav { display: flex; align-items: center; gap: .25rem; flex-shrink: 1; min-width: 0; }
.site-nav a {
  padding: .5rem 1rem; border-radius: .375rem;
  font-size: .875rem; font-weight: 500; color: rgba(17,24,39,.7);
  white-space: nowrap;
  transition: background .15s, color .15s;
}
.site-nav a:hover, .site-nav a.active { background: var(--green-10); color: var(--green); }

.header-contacts { display: flex; align-items: center; gap: 1rem; flex-shrink: 0; }
.header-phone {
  display: flex; align-items: center; gap: .375rem;
  font-size: .875rem; font-weight: 500; color: rgba(17,24,39,.8);
  white-space: nowrap;
  transition: color .15s;
}
.header-phone:hover { color: var(--green); }
.header-phone-icon { color: var(--green); flex-shrink: 0; }
.header-email-link:hover { color: var(--green); }
.logo-indust { height: 2.5rem; object-fit: contain; transition: opacity .15s; }
.logo-indust:hover { opacity: .8; }
@media (max-width: 1540px) { .header-contacts .logo-indust { display: none; } }

@media (min-width: 1100px) and (max-width: 1540px) {
  .site-nav a { padding: .5rem .5rem; }
  .header-contacts { gap: .5rem; }
}

@media (min-width: 1100px) and (max-width: 1300px) {
  .header-dealer-badge { display: none; }
  .logo-indust.header-brand-logo { height: 2.25rem; }
  .site-nav a { font-size: .75rem; padding: .45rem .4rem; }
  .site-header a[href^="mailto"] { display: none !important; }
}

@media (min-width: 1301px) and (max-width: 1380px) {
  .header-dealer-badge { display: none; }
  .site-nav a { padding: .5rem .6rem; }
  .site-header a[href^="mailto"] { display: none !important; }
}

.burger {
  display: none; padding: .5rem; border: none; background: none;
  color: rgba(17,24,39,.7); border-radius: .375rem; transition: background .15s;
}
.burger:hover { background: var(--bg-gray); }
.burger svg { width: 1.25rem; height: 1.25rem; display: block; }

.mobile-nav {
  display: none; border-top: 1px solid var(--border); background: #fff;
  padding: .75rem var(--px);
}
.mobile-nav.open { display: block; }
.mobile-nav a {
  display: block; padding: .625rem .75rem; border-radius: .375rem;
  font-size: .875rem; font-weight: 500; color: rgba(17,24,39,.8);
  transition: background .15s;
}
.mobile-nav a:hover { background: var(--bg-gray); }
.mobile-nav .mobile-extra { padding-top: .75rem; border-top: 1px solid var(--border); margin-top: .5rem; }
.mobile-nav .mobile-extra .logo-indust { height: 2rem; margin-top: .5rem; }

@media (min-width: 1100px) {
  .burger { display: none !important; }
}
@media (max-width: 1099px) {
  .site-nav, .header-contacts { display: none; }
  .burger { display: flex; align-items: center; justify-content: center; }
}

/* ---------- PAGE HEADER (breadcrumb bar) ------------------ */
.page-hero {
  background: var(--bg-gray); border-bottom: 1px solid var(--border);
  padding: 2.5rem 0;
}
.page-hero .label-tag { margin-bottom: .5rem; }
.page-hero h1 { font-size: clamp(1.6rem, 4vw, 2.5rem); }
.page-hero p { color: var(--muted); margin-top: .5rem; max-width: 40rem; }

/* Каталог: INSIZE справа в блоке над списком */
.catalog-hero-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 2rem;
}
.catalog-hero-logo {
  flex-shrink: 0;
  display: flex;
  align-items: center;
}
.catalog-hero-logo img {
  height: 2.5rem;
  width: auto;
  object-fit: contain;
  opacity: .55;
  filter: brightness(0) saturate(100%) invert(27%) sepia(77%) saturate(600%) hue-rotate(115deg) brightness(90%);
}
@media (max-width: 640px) {
  .catalog-hero-logo { display: none; }
}

/* ---------- HERO BANNER ----------------------------------- */
.hero {
  position: relative; overflow: hidden; background: #111827;
}
.hero-bg {
  position: absolute; inset: -8px; width: calc(100% + 16px); height: calc(100% + 16px);
  object-fit: cover; object-position: center; opacity: .9;
  filter: blur(5px);
}
.hero-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(90deg, rgba(0,0,0,.72) 0%, rgba(0,0,0,.60) 55%, rgba(0,0,0,.45) 100%);
}
.hero-content { position: relative; padding: 5rem 0 0; }
.hero-badge {
  display: inline-block; font-size: .75rem; font-weight: 500;
  border: 1px solid rgba(52,211,153,.5); color: #6ee7b7;
  background: rgba(255,255,255,.1); border-radius: 9999px;
  padding: .25rem .875rem; margin-bottom: 1.5rem;
}
.hero h1 { color: #fff; margin-bottom: .75rem; }
.hero h1 em { color: #34d399; font-style: normal; }
.hero-sub { color: rgba(255,255,255,.75); font-size: 1.1rem; margin-bottom: 1.5rem; }
.hero-text { font-size: 1.125rem; color: #d1d5db; line-height: 1.7; margin-bottom: 2.5rem; }
.hero-search { display: flex; gap: .5rem; max-width: 32rem; margin-bottom: 2rem; }
.hero-search .form-control {
  background: rgba(255,255,255,.1); border-color: rgba(255,255,255,.2);
  color: #fff;
}
.hero-search .form-control::placeholder { color: #9ca3af; }
.hero-search .form-control:focus { background: rgba(255,255,255,.15); }
.hero-search-wrap { position: relative; flex: 1; }
.hero-search-icon {
  position: absolute; left: .75rem; top: 50%; transform: translateY(-50%);
  color: #9ca3af; pointer-events: none;
}
.hero-search .form-control { padding-left: 2.5rem; height: 3rem; }
.hero-search .btn { height: 3rem; }
.hero-ctas { display: flex; flex-wrap: wrap; gap: .75rem; }

.hero-stats {
  position: relative; border-top: 1px solid rgba(255,255,255,.1);
  background: rgba(0,0,0,.3); margin-top: 5rem;
}
.hero-stats-inner {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 1rem; text-align: center; padding: 1rem 0;
}
.hero-stat-val { font-size: 1.25rem; font-weight: 700; color: #fff; }
.hero-stat-lbl { font-size: .75rem; color: #9ca3af; margin-top: .125rem; }

@media (max-width: 640px) {
  .hero-stats-inner { grid-template-columns: repeat(2, 1fr); }
  .btn-lg { white-space: normal; text-align: center; justify-content: center; }
}

/* ---------- SECTION HEADER -------------------------------- */
.section-header { margin-bottom: 2.5rem; }
.section-header-row {
  display: flex; align-items: flex-end; justify-content: space-between; flex-wrap: wrap; gap: 1rem;
}

/* ---------- CATEGORY CARDS -------------------------------- */
.categories-grid {
  display: grid; gap: 1rem;
  grid-template-columns: repeat(3, 1fr);
}
@media (max-width: 767px) { .categories-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 479px) { .categories-grid { grid-template-columns: 1fr; } }
.cat-card {
  display: flex; align-items: center; gap: 1rem;
  padding: 1.25rem; border-radius: var(--radius);
  border: 1px solid var(--border);
  background: var(--bg-gray); cursor: pointer;
  transition: background .15s, border-color .15s, box-shadow .15s;
  text-decoration: none; color: inherit;
}
.cat-card:hover { background: #fff; box-shadow: var(--shadow-md); border-color: var(--green-20); }
.cat-icon {
  width: 3rem; height: 3rem; border-radius: .5rem; flex-shrink: 0;
  background: var(--green-10); display: flex; align-items: center; justify-content: center;
}
.cat-icon svg { width: 1.5rem; height: 1.5rem; color: var(--green); stroke: var(--green); }
.cat-info { flex: 1; min-width: 0; }
.cat-name { font-size: .875rem; font-weight: 600; line-height: 1.3; }
.cat-count { font-size: .75rem; color: var(--muted); margin-top: .125rem; }
.cat-arrow { color: rgba(0,0,0,.25); flex-shrink: 0; transition: transform .15s, color .15s; }
.cat-card:hover .cat-arrow { transform: translateX(4px); color: var(--green); }

/* ---------- WHY US ---------------------------------------- */
.why-us { background: var(--bg-gray); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); }
.why-grid { display: grid; gap: 1.5rem; grid-template-columns: repeat(2, 1fr); }
@media (min-width: 1024px) { .why-grid { grid-template-columns: repeat(4, 1fr); } }
.why-card { text-align: center; padding: 1.5rem 1rem; }
.why-icon {
  width: 3.5rem; height: 3.5rem; border-radius: 9999px;
  background: var(--green-10); display: flex; align-items: center; justify-content: center; margin: 0 auto 1rem;
}
.why-icon svg { width: 1.75rem; height: 1.75rem; stroke: var(--green); }
.why-card h3 { margin-bottom: .5rem; }
.why-card p { font-size: .875rem; color: var(--muted); line-height: 1.6; }

/* ---------- CERTIFICATE SECTION --------------------------- */
.cert-section { background: #f9fafb; border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); }
.cert-layout { display: grid; gap: 2.5rem; grid-template-columns: 1fr 1fr; align-items: center; }
@media (max-width: 768px) { .cert-layout { grid-template-columns: 1fr; } }
.cert-img-wrap {
  display: flex; justify-content: center;
}
.cert-card {
  background: #fff; border: 1px solid var(--border); border-radius: var(--radius);
  padding: 1rem; box-shadow: var(--shadow-sm); max-width: 280px; width: 100%;
}
.cert-card img { width: 100%; object-fit: contain; display: block; }
.cert-text p { color: var(--muted); line-height: 1.75; margin-bottom: 1rem; }
.cert-text p:last-of-type { margin-bottom: 1.5rem; }

/* ---------- CONTACT FORM SECTION -------------------------- */
.contact-layout { display: grid; gap: 3rem; grid-template-columns: 1fr 1fr; align-items: start; }
@media (max-width: 768px) { .contact-layout { grid-template-columns: 1fr; } }
.contact-info-item { display: flex; gap: .75rem; align-items: flex-start; margin-bottom: 1rem; }
.contact-info-item svg { width: 1.25rem; height: 1.25rem; stroke: var(--green); flex-shrink: 0; margin-top: .125rem; }
.contact-info-item strong { display: block; font-size: .875rem; font-weight: 600; margin-bottom: .125rem; }
.contact-info-item a, .contact-info-item p { font-size: .875rem; color: var(--muted); text-decoration: none; line-height: 1.5; }
.contact-info-item a:hover { color: var(--green); }
.contact-form-box { background: #f9fafb; border: 1px solid var(--border); border-radius: var(--radius); padding: 2rem; }
.contact-form-box .form-row { display: grid; gap: .75rem; grid-template-columns: 1fr 1fr; margin-bottom: .75rem; }
@media (max-width: 480px) { .contact-form-box .form-row { grid-template-columns: 1fr; } }
.contact-form-box textarea { resize: vertical; min-height: 5rem; }
.contact-form-box .btn-submit { width: 100%; margin-top: .25rem; height: 2.75rem; font-size: .9375rem; }
.form-success { display:none; background: var(--green-10); border: 1px solid var(--green-20); color: var(--green); border-radius: var(--radius); padding: 1rem; text-align: center; font-weight: 500; }

/* ---------- AI ASSISTANT BANNER --------------------------- */
.ai-banner {
  background: var(--green); border-radius: var(--radius);
  padding: 3rem 2rem; text-align: center; color: #fff;
}
.ai-banner svg { width: 2.5rem; height: 2.5rem; margin: 0 auto 1rem; opacity: .8; stroke: #fff; }
.ai-banner h2 { color: #fff; margin-bottom: .75rem; }
.ai-banner p { color: rgba(255,255,255,.8); font-size: .875rem; max-width: 32rem; margin: 0 auto 2rem; line-height: 1.7; }

/* ---------- CERTIFICATES ---------------------------------- */
.certs-grid { display: grid; gap: 1rem; grid-template-columns: repeat(3, 1fr); }
.cert-thumb {
  border-radius: var(--radius); overflow: hidden; border: 1px solid var(--border);
  cursor: pointer; transition: transform .15s, box-shadow .15s;
  background: #fff; box-shadow: var(--shadow-sm);
}
.cert-thumb:hover { transform: scale(1.02); box-shadow: var(--shadow-md); }
.cert-thumb img { width: 100%; aspect-ratio: 4/3; object-fit: cover; }

@media (max-width: 640px) { .certs-grid { grid-template-columns: 1fr; } }

/* ---------- CATALOG PAGE ---------------------------------- */
.catalog-layout { display: flex; gap: 1.5rem; margin-top: .5rem; }

/* Sidebar */
.cat-sidebar {
  width: 220px; flex-shrink: 0;
}
@media (max-width: 1023px) { .cat-sidebar { display: none; } }

.cat-sidebar-sticky {
  position: sticky; top: 5.5rem;
  max-height: calc(100vh - 6rem);
  overflow-y: auto; padding-bottom: 1.5rem;
  scrollbar-width: thin;
}
.sidebar-label {
  font-size: .65rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: .12em; color: rgba(17,24,39,.4); margin-bottom: .5rem; padding: 0 .5rem;
}
.sidebar-cat-btn {
  width: 100%; text-align: left; display: flex; align-items: center; justify-content: space-between;
  padding: .375rem .5rem; border-radius: .375rem; border: none; background: none;
  font-size: .75rem; color: rgba(17,24,39,.65); gap: .5rem;
  transition: background .12s, color .12s; cursor: pointer; line-height: 1.3;
  text-decoration: none; box-sizing: border-box;
}
a.sidebar-cat-btn { color: rgba(17,24,39,.65); }
.sidebar-cat-btn:hover { background: var(--bg-gray); color: var(--text); }
.sidebar-cat-btn.active { background: var(--green-10); color: var(--green); font-weight: 600; }
.sidebar-cat-count { font-size: .65rem; color: var(--muted); flex-shrink: 0; font-variant-numeric: tabular-nums; }

/* Mobile category select */
.mobile-cat-select { display: none; margin-bottom: .75rem; }
@media (max-width: 1023px) { .mobile-cat-select { display: block; } }

/* Catalog main area */
.catalog-main { flex: 1; min-width: 0; }

/* Product grid */
.products-grid {
  display: grid; gap: 1rem;
  grid-template-columns: repeat(auto-fill, minmax(270px, 1fr));
}

/* Product card */
.product-card {
  border: 1px solid var(--border) !important; border-radius: var(--radius);
  background: #fff; overflow: hidden;
  display: flex !important; flex-direction: column !important;
  transition: box-shadow .2s, border-color .2s, transform .2s;
  cursor: default;
}
.product-card__link {
  text-decoration: none; color: inherit;
  display: flex; flex-direction: column; flex: 1; min-height: 0;
  cursor: pointer;
}
.product-card:hover { box-shadow: var(--shadow-md); border-color: var(--green-20) !important; transform: translateY(-2px); }
/* Image wrap — aspect-ratio:1/1 gives a reliable 1:1 square */
.product-img-wrap {
  background: #f9fafb; overflow: hidden !important; flex-shrink: 0 !important;
  position: relative; width: 100% !important;
  aspect-ratio: 1 / 1;
}
.product-img-wrap img {
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: contain; padding: .75rem;
  transition: transform .3s;
}
.pcard-noimg {
  position: absolute; inset: 0; display: flex;
  align-items: center; justify-content: center;
  color: #d1d5db;
}
.product-card:hover .product-img-wrap img { transform: scale(1.05); }
.pcard-gradient {
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,.28), transparent 60%);
  pointer-events: none;
}
.pcard-cat-chip {
  position: absolute; top: .625rem; left: .625rem; right: 2.75rem;
  font-size: .65rem; font-weight: 600; color: #fff;
  padding: .2rem .5rem; border-radius: .375rem; line-height: 1.2;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.pcard-yt-badge {
  position: absolute; top: .625rem; right: .625rem;
  background: #dc2626; color: #fff;
  padding: .25rem .375rem; border-radius: .375rem;
  display: flex; align-items: center;
}
.pcard-sku {
  position: absolute; bottom: .5rem; left: .625rem;
  font-family: monospace; font-size: .65rem; color: rgba(255,255,255,.9);
  background: rgba(0,0,0,.45); backdrop-filter: blur(4px);
  padding: .15rem .375rem; border-radius: .25rem; line-height: 1.3;
}
.pcard-photo-count {
  position: absolute; bottom: .5rem; right: .625rem;
  font-size: .65rem; color: rgba(255,255,255,.85);
  background: rgba(0,0,0,.45); backdrop-filter: blur(4px);
  padding: .15rem .375rem; border-radius: .25rem; line-height: 1.3;
  display: flex; align-items: center; gap: .2rem;
}
.product-body { padding: .875rem; flex: 1; display: flex; flex-direction: column; gap: .5rem; }
.product-code { font-size: .7rem; color: var(--muted); font-variant-numeric: tabular-nums; }
.product-name { font-size: .875rem; font-weight: 600; line-height: 1.35; flex: 1;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.product-cat { font-size: .7rem; color: var(--green); font-weight: 500; }
.pcard-chips { display: flex; flex-wrap: wrap; gap: .375rem; }
.pcard-chip {
  display: inline-flex; align-items: center; gap: .25rem;
  font-size: .65rem; color: var(--muted);
  background: rgba(0,0,0,.05); border-radius: .25rem;
  padding: .175rem .5rem; line-height: 1.3;
}
.pcard-feat-preview {
  font-size: .7rem; color: var(--muted); line-height: 1.5;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.pcard-bottom { margin-top: auto; padding-top: .25rem; }
.pcard-pdf {
  display: inline-flex; align-items: center; gap: .3rem;
  font-size: .7rem; color: var(--muted);
  text-decoration: none; transition: color .12s;
  padding: .2rem .375rem; border-radius: .25rem;
}
.pcard-pdf:hover { color: #dc2626; background: rgba(0,0,0,.04); }

/* Search / sort bar */
.catalog-controls { display: flex; gap: .75rem; flex-wrap: wrap; margin-bottom: .75rem; }
.search-wrap { position: relative; flex: 1; min-width: 200px; }
.search-icon {
  position: absolute; left: .75rem; top: 50%; transform: translateY(-50%);
  color: var(--muted); pointer-events: none; width: 1rem; height: 1rem;
}
.search-wrap .form-control { padding-left: 2.375rem; height: 2.5rem; }
.select-wrap { position: relative; }
.select-wrap select { padding-right: 2rem; height: 2.5rem; min-width: 170px; }
.select-arrow {
  position: absolute; right: .625rem; top: 50%; transform: translateY(-50%);
  pointer-events: none; color: var(--muted); width: 1rem; height: 1rem;
}

/* Attribute filters */
.attr-filters {
  display: flex; flex-wrap: wrap; align-items: center; gap: .5rem;
  padding: .625rem .75rem; background: rgba(0,0,0,.03);
  border-radius: .5rem; border: 1px solid var(--border);
  margin-bottom: .75rem;
}
.attr-label { font-size: .75rem; font-weight: 600; color: rgba(17,24,39,.6); margin-right: .25rem; }
.attr-sel-wrap select { height: 2rem; font-size: .75rem; min-width: 140px; }
.attr-sel-wrap .select-arrow { top: 50%; transform: translateY(-50%); }

/* Pagination */
.pagination { display: flex; justify-content: center; align-items: center; gap: .25rem; flex-wrap: wrap; margin-top: 2rem; }
.page-btn {
  width: 2.25rem; height: 2.25rem; border-radius: .375rem; border: 1px solid var(--border);
  background: #fff; font-size: .875rem; display: flex; align-items: center; justify-content: center;
  cursor: pointer; transition: background .12s, border-color .12s, color .12s;
  text-decoration: none; color: inherit; box-sizing: border-box;
}
.page-btn:hover:not(:disabled):not(.page-btn--disabled) { border-color: var(--green); color: var(--green); }
.page-btn.active { background: var(--green); color: #fff; border-color: var(--green); }
.page-btn:disabled, .page-btn.page-btn--disabled { opacity: .4; cursor: default; pointer-events: none; }
a.page-btn:hover { border-color: var(--green); color: var(--green); }
a.page-btn.active:hover { color: #fff; border-color: var(--green); }
.page-ellipsis { width: 2.25rem; height: 2.25rem; display: flex; align-items: center; justify-content: center; color: var(--muted); }

/* Sub-category chips */
.subcats { display: flex; flex-wrap: wrap; gap: .5rem; margin-bottom: 1rem; padding-bottom: 1rem; border-bottom: 1px solid var(--border); }
.subcat-chip {
  display: inline-flex; align-items: center; gap: .375rem;
  padding: .375rem .75rem; border-radius: 9999px; font-size: .75rem; font-weight: 500;
  border: 1px solid var(--border); background: #fff; cursor: pointer;
  transition: background .12s, border-color .12s, color .12s;
  text-decoration: none; color: inherit; box-sizing: border-box;
}
.subcat-chip:hover { border-color: rgba(0,105,62,.5); }
.subcat-chip.active { background: var(--green); color: #fff; border-color: var(--green); }

/* Results count */
.results-bar { display: flex; align-items: center; justify-content: space-between; margin-bottom: 1rem; flex-wrap: wrap; gap: .5rem; }
.results-count { font-size: .75rem; color: var(--muted); }

/* ---------- PRODUCT PAGE ---------------------------------- */
.product-breadcrumb { display: flex; align-items: center; gap: .5rem; flex-wrap: wrap; margin-bottom: 2rem; }
.product-breadcrumb a { font-size: .8rem; color: var(--muted); }
.product-breadcrumb a:hover { color: var(--green); }
.product-breadcrumb span { font-size: .8rem; color: var(--muted); }

.product-detail { display: grid; grid-template-columns: 1fr 1fr; gap: 3rem; align-items: start; }
@media (max-width: 768px) { .product-detail { grid-template-columns: 1fr; } }

.product-gallery { position: sticky; top: 5.5rem; }
.product-main-img {
  border-radius: var(--radius); border: 1px solid var(--border);
  background: #f9fafb; overflow: hidden; margin-bottom: .75rem;
}
.product-main-img img { width: 100%; aspect-ratio: 4/3; object-fit: contain; padding: 1.5rem; }
.product-thumbs { display: flex; gap: .5rem; flex-wrap: wrap; }
.product-thumb {
  width: 4rem; height: 4rem; border-radius: .375rem; border: 1px solid var(--border);
  background: #f3f4f6; overflow: hidden; cursor: pointer; transition: border-color .12s;
}
.product-thumb.active { border-color: var(--green); }
.product-thumb img { width: 100%; height: 100%; object-fit: contain; padding: .25rem; }

/* Карточка товара — как wordpress-static/product.html */
.product-detail .product-info {
  display: flex;
  flex-direction: column;
  gap: 0;
}
.product-info .product-code { font-size: .8rem; color: var(--muted); }
.product-badges {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  align-items: center;
  margin-bottom: .5rem;
}
.product-badge {
  display: inline-flex;
  align-items: center;
  font-size: .75rem;
  font-weight: 600;
  padding: .25rem .625rem;
  border-radius: .375rem;
  border: 1px solid transparent;
  line-height: 1.4;
}
.product-features-section { margin-top: 1rem; }

/* Карточка товара — отступы как в wordpress-static/product.html (воздух между блоками) */
.product-detail .product-title-main {
  margin: 0 0 .5rem;
  font-size: clamp(1.2rem, 3vw, 1.75rem);
}
.product-detail .product-name-en {
  font-size: .875rem;
  color: var(--muted);
  line-height: 1.45;
  margin: 0 0 1rem;
}
.product-detail .product-code-line {
  font-size: .875rem;
  margin: 0 0 1rem;
}
.product-detail .product-models-row {
  margin: 0 0 1rem;
}
.product-detail .product-order-main-btn {
  margin: .25rem 0 1rem;
}
.product-detail .product-sec-btns {
  margin: 0 0 1.25rem;
}
.product-detail .product-sec-btns .btn-outline {
  flex: 1;
  justify-content: center;
  min-width: min(130px, 100%);
}
@media (min-width: 480px) {
  .product-detail .product-sec-btns .btn-outline {
    min-width: 130px;
  }
}
.product-features { display: flex; flex-direction: column; gap: .625rem; }
.product-feature {
  display: flex; align-items: flex-start; gap: .625rem;
  font-size: .875rem; color: #374151; line-height: 1.5;
}
.product-feature-check { flex-shrink: 0; margin-top: .1rem; }
.product-feature-dot {
  width: .375rem; height: .375rem; border-radius: 9999px; background: var(--green);
  flex-shrink: 0; margin-top: .5rem;
}
.product-ctas { display: flex; gap: .75rem; flex-wrap: wrap; }
.product-video-wrap {
  position: relative;
  width: 100%;
  max-width: 640px;
  border-radius: var(--radius);
  overflow: hidden;
  background: #000;
}
.product-video-ratio {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
}
.product-video-ratio iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: none;
}
.attr-reset {
  margin-left: auto; font-size: .75rem; color: var(--green);
  background: none; border: none; cursor: pointer; padding: .2rem .5rem;
  border-radius: .25rem; display: inline-flex; align-items: center; gap: .25rem;
}
.attr-reset:hover { background: rgba(0,105,62,.08); }
.subcat-count { font-size: .65rem; color: inherit; opacity: .75; }

.models-table { width: 100%; border-collapse: collapse; font-size: .8rem; }
.models-table th {
  background: var(--bg-gray); padding: .625rem .75rem;
  text-align: left; font-weight: 600; border-bottom: 1px solid var(--border);
  font-size: .7rem; text-transform: uppercase; letter-spacing: .06em; color: var(--muted);
}
.models-table td { padding: .625rem .75rem; border-bottom: 1px solid var(--border); }
.models-table tr:last-child td { border-bottom: none; }
.models-table tr:hover td { background: var(--bg-gray); }
.table-wrap { overflow-x: auto; border: 1px solid var(--border); border-radius: .5rem; }

/* ---------- CONTACTS PAGE --------------------------------- */
.contacts-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 3rem; align-items: start; }
@media (max-width: 1023px) { .contacts-grid { grid-template-columns: 1fr; } }

.contact-cards { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; margin-bottom: 1.5rem; }
@media (max-width: 480px) { .contact-cards { grid-template-columns: 1fr; } }

.contact-card { background: #fff; border-radius: var(--radius); border: 1px solid var(--border); padding: 1.5rem; }
.contact-card-icon {
  width: 2.5rem; height: 2.5rem; border-radius: .5rem;
  background: var(--green-10); display: flex; align-items: center; justify-content: center; margin-bottom: 1rem;
}
.contact-card-icon svg { width: 1.25rem; height: 1.25rem; stroke: var(--green); }
.contact-card h3 { font-size: 1rem; margin-bottom: .75rem; }
.contact-card a { display: block; font-size: .875rem; color: var(--text); transition: color .12s; margin-bottom: .25rem; }
.contact-card a:hover { color: var(--green); }
.contact-card address { font-size: .875rem; color: var(--muted); line-height: 1.7; }
.contact-card p.sub { font-size: .7rem; color: var(--muted); margin-bottom: .125rem; }

.map-wrap { border-radius: var(--radius); overflow: hidden; border: 1px solid var(--border); height: 18rem; }
.map-wrap iframe { width: 100%; height: 100%; border: none; display: block; }

.contact-form-wrap { background: var(--bg-gray); border-radius: var(--radius); border: 1px solid var(--border); padding: 2rem; }
.contact-form-wrap h2 { margin-bottom: 1.5rem; }
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; margin-bottom: 1rem; }
@media (max-width: 520px) { .form-grid { grid-template-columns: 1fr; } }

/* ---------- PAYMENT / DELIVERY PAGES ---------------------- */
.info-cards { display: grid; gap: 1.5rem; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); }
.info-card { background: #fff; border-radius: var(--radius); border: 1px solid var(--border); padding: 1.5rem; }
.info-card-icon {
  width: 3rem; height: 3rem; border-radius: .5rem;
  background: var(--green-10); display: flex; align-items: center; justify-content: center; margin-bottom: 1rem;
}
.info-card-icon svg { width: 1.5rem; height: 1.5rem; stroke: var(--green); }
.info-card h3 { margin-bottom: .75rem; }
.info-card p { font-size: .875rem; color: var(--muted); margin-bottom: 1rem; line-height: 1.6; }
.info-card ul li {
  display: flex; align-items: flex-start; gap: .5rem;
  font-size: .875rem; color: var(--muted); margin-bottom: .5rem; line-height: 1.5;
}
.info-card ul li svg { width: 1rem; height: 1rem; stroke: var(--green); flex-shrink: 0; margin-top: .2rem; }

.details-box { background: var(--bg-gray); border-radius: var(--radius); border: 1px solid var(--border); padding: 2rem; }
.details-box-inner { display: flex; align-items: flex-start; gap: 1rem; }
.details-box-inner > svg { width: 1.5rem; height: 1.5rem; stroke: var(--green); flex-shrink: 0; margin-top: .25rem; }
.details-box h2 { margin-bottom: 1rem; }

.requisites-box { background: var(--green-10); border-radius: var(--radius); border: 1px solid var(--green-20); padding: 2rem; }
.requisites-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
@media (max-width: 520px) { .requisites-grid { grid-template-columns: 1fr; } }
.req-item span.lbl { display: block; font-size: .7rem; text-transform: uppercase; letter-spacing: .08em; color: var(--muted); margin-bottom: .2rem; }
.req-item span.val { font-size: .875rem; font-weight: 600; }

.notice-box {
  display: flex; align-items: flex-start; gap: .75rem;
  background: #fffbeb; border: 1px solid #fcd34d; border-radius: var(--radius); padding: 1.25rem;
}
.notice-box svg { width: 1.25rem; height: 1.25rem; stroke: #d97706; flex-shrink: 0; margin-top: .1rem; }
.notice-box p { font-size: .875rem; color: #92400e; line-height: 1.6; }
.notice-box p strong { color: #78350f; font-weight: 600; display: inline; margin-right: .25rem; }

.timing-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }
@media (max-width: 640px) { .timing-grid { grid-template-columns: 1fr; } }
.timing-item h4 { display: flex; align-items: center; gap: .5rem; margin-bottom: .5rem; font-size: .875rem; }
.timing-badge {
  display: inline-block; font-size: .65rem; font-weight: 600;
  background: var(--green); color: #fff; padding: .15rem .625rem; border-radius: 9999px;
}
.timing-item p { font-size: .875rem; color: var(--muted); line-height: 1.6; }

.cta-center { text-align: center; }
.cta-center p { color: var(--muted); margin-bottom: 1rem; }
.cta-center .btn-row,
.btn-row {
  display: flex; gap: .75rem; justify-content: center; flex-wrap: wrap;
}
@media (max-width: 640px) {
  .btn-row { flex-direction: column; align-items: stretch; gap: .625rem; }
  .btn-row .btn { width: 100%; justify-content: center; }
}

/* ---------- ASSISTANT POPUP ------------------------------- */
/* Синхронизировано с github.com/obiwanivan/Product-Catalog-Manager wordpress-static/assets/styles.css + разметка темы */

.popup-overlay {
  display: none; position: fixed; inset: 0; z-index: 200;
  background: rgba(0,0,0,.55); align-items: center; justify-content: center; padding: 1rem;
  overscroll-behavior: none;
}
.popup-overlay.open { display: flex; }
html.assistant-popup-active {
  overflow: hidden;
}
.popup-panel {
  width: min(680px, 100%); height: min(85vh, 700px);
  min-height: 0;
  max-height: 100%;
  background: #fff; display: flex; flex-direction: column;
  border-radius: .75rem; overflow: hidden;
  box-shadow: 0 20px 60px rgba(0,0,0,.25);
  animation: popIn .22s ease;
  overscroll-behavior: contain;
}
@media (max-width: 480px) {
  .popup-overlay { padding: 0; align-items: flex-end; }
  .popup-panel {
    width: 100%; max-width: 100vw; border-radius: 1rem 1rem 0 0;
    height: 92vh; height: 92dvh;
  }
  .popup-messages {
    padding: .875rem 1rem;
    padding-bottom: max(6rem, calc(4rem + env(safe-area-inset-bottom, 0px)));
  }
  .popup-hints { padding: .5rem .875rem; gap: .375rem; }
  .popup-hint { font-size: .7rem; padding: .3rem .65rem; }
  .popup-input-row {
    padding: .625rem 1rem;
    padding-bottom: max(.625rem, env(safe-area-inset-bottom));
    gap: .5rem;
    flex-wrap: nowrap;
    min-width: 0;
  }
  .popup-input-row textarea.form-control.popup-input {
    font-size: 1rem;
    min-width: 0;
    flex: 1 1 0%;
  }
  .popup-disclaimer {
    padding-bottom: max(.85rem, env(safe-area-inset-bottom));
  }
}
@keyframes popIn { from { opacity:0; transform: scale(.95); } to { opacity:1; transform: scale(1); } }
.popup-hints {
  display: flex; flex-wrap: wrap; gap: .5rem; padding: .75rem 1.25rem;
  border-top: 1px solid var(--border); background: #f9fafb;
  flex-shrink: 0;
  max-height: min(40vh, 220px);
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}
/* Подсказки только до первого сообщения пользователя (класс вешает theme.js). */
.popup-overlay.assistant-has-thread .popup-hints {
  display: none;
}
.popup-hint {
  font-size: .75rem; padding: .375rem .75rem; border-radius: 9999px;
  background: #fff; border: 1px solid var(--border); cursor: pointer; color: rgba(17,24,39,.7);
  transition: background .12s, border-color .12s, color .12s;
  white-space: nowrap;
}
.popup-hint:hover { background: var(--green-10); border-color: var(--green-20); color: var(--green); }
.popup-hints .popup-hint.tmpl-chip {
  padding: .375rem .875rem;
}

.popup-header {
  display: flex; align-items: flex-start; justify-content: space-between; gap: .75rem;
  padding: 1rem 1.25rem; border-bottom: 1px solid rgba(255,255,255,.12);
  background: var(--green); color: #fff;
}
.popup-header-text { flex: 1; min-width: 0; }
.popup-header-icon-title {
  display: flex; align-items: center; gap: .75rem;
}
.popup-header-icon {
  width: 2rem; height: 2rem; border-radius: .5rem;
  background: rgba(255,255,255,.15);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.popup-header-icon svg { display: block; }
.popup-header h3 { font-size: .9375rem; font-weight: 700; line-height: 1.15; margin: 0; color: #fff; }
.popup-subtitle {
  font-size: .6875rem; color: rgba(255,255,255,.78); margin: .2rem 0 0; line-height: 1.2;
}
.popup-close {
  background: none; border: none; color: rgba(255,255,255,.8); font-size: 1.25rem;
  cursor: pointer; padding: .25rem; border-radius: .25rem;
  transition: background .12s;
}
.popup-close:hover { background: rgba(255,255,255,.15); }

.popup-disclaimer {
  text-align: center; font-size: .6875rem; color: var(--muted);
  padding: 0 1.25rem .85rem; margin: 0;
  border-top: 1px solid var(--border); background: #fafafa;
}

.popup-messages {
  flex: 1 1 0%;
  min-width: 0;
  min-height: 0;
  overflow-y: auto;
  overflow-x: hidden;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
  padding: 1rem 1.25rem;
  /* Нижний отступ: чтобы последнее сообщение можно было прокрутить выше зоны ввода (iOS / длинные ответы) */
  padding-bottom: 2rem;
  display: flex;
  flex-direction: column;
  gap: .75rem;
}
/* Пузыри не сжимать по высоте (иначе длинный ответ с карточками превращается в полоску со скроллом). */
.popup-messages > .msg {
  flex-shrink: 0;
}
.msg { max-width: 85%; padding: .625rem .875rem; border-radius: .75rem; font-size: .875rem; line-height: 1.5; word-break: break-word; overflow-wrap: break-word; min-width: 0; }
.msg-ai { background: var(--bg-gray); border: 1px solid var(--border); align-self: flex-start; border-radius: 0 .75rem .75rem .75rem; }
.msg-user { background: var(--green); color: #fff; align-self: flex-end; border-radius: .75rem .75rem 0 .75rem; }
.msg-typing { display: flex; gap: .25rem; align-items: center; padding: .75rem; }
.msg-typing span { display: block; width: .5rem; height: .5rem; background: var(--muted); border-radius: 9999px; animation: blink 1.2s infinite; }
.msg-typing span:nth-child(2) { animation-delay: .2s; }
.msg-typing span:nth-child(3) { animation-delay: .4s; }
@keyframes blink { 0%,80%,100% { opacity: .25; } 40% { opacity: 1; } }

.popup-input-row {
  display: flex; gap: .5rem; padding: .75rem 1.25rem;
  border-top: 1px solid var(--border); align-items: flex-end;
  flex-shrink: 0;
  min-width: 0;
}
.popup-input-row textarea.form-control.popup-input {
  flex: 1 1 0%;
  min-width: 0;
  max-width: 100%;
  width: auto;
  height: 2.5rem;
  min-height: 0;
  max-height: 8rem;
  border-radius: .5rem;
  resize: none;
  overflow-y: auto;
  line-height: 1.5;
  padding: .5rem .75rem;
  box-sizing: border-box;
}
.popup-input-row .btn {
  height: 2.5rem;
  min-height: 2.5rem;
  padding-inline: 1rem;
  flex: 0 0 auto;
  flex-shrink: 0;
  align-self: flex-end;
}

/* ---------- FOOTER ---------------------------------------- */
.site-footer { background: #f3f4f6; border-top: 1px solid var(--border); color: #374151; margin-top: auto; }
.footer-inner { padding-block: 3rem; display: grid; gap: 2rem; grid-template-columns: 1fr 1fr 1fr 1fr; }
@media (max-width: 1023px) { .footer-inner { grid-template-columns: 1fr 1fr; } }
@media (max-width: 480px)  { .footer-inner { grid-template-columns: 1fr; } }

.footer-brand .logo-indust,
.footer-brand .footer-brand-logo-indust { width: 9rem; margin-bottom: .5rem; }
.footer-brand p { font-size: .75rem; color: #6b7280; line-height: 1.6; margin-top: 0; }

.footer-col h4 {
  font-size: .75rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: .1em; color: #111827; margin-bottom: 1rem;
}
.footer-col ul li { margin-bottom: .5rem; }
.footer-col ul li a { font-size: .875rem; color: #6b7280; transition: color .12s; }
.footer-col ul li a:hover { color: var(--green); }

.footer-contact-item { display: flex; align-items: flex-start; gap: .5rem; margin-bottom: .75rem; }
.footer-contact-item svg { width: 1rem; height: 1rem; stroke: var(--green); flex-shrink: 0; margin-top: .2rem; }
.footer-contact-item a { display: block; font-size: .875rem; color: #374151; transition: color .12s; }
.footer-contact-item a:hover { color: var(--green); }
.footer-contact-item a.sub { color: #6b7280; }
.footer-contact-item p { font-size: .875rem; color: #6b7280; line-height: 1.6; }

.footer-bottom {
  border-top: 1px solid var(--border); padding-block: 1.25rem;
  display: flex; flex-direction: column; align-items: center; justify-content: space-between;
  gap: .5rem; font-size: .75rem; color: #9ca3af;
}
@media (min-width: 640px) { .footer-bottom { flex-direction: row; } }

/* ---------- LIGHTBOX -------------------------------------- */
.lightbox {
  display: none; position: fixed; inset: 0; z-index: 300;
  background: rgba(0,0,0,.85); align-items: center; justify-content: center; padding: 1rem;
}
.lightbox.open { display: flex; }
.lightbox img { max-width: 56rem; width: 100%; border-radius: var(--radius); object-fit: contain; }
.lightbox-close {
  position: absolute; top: 1rem; right: 1rem; background: rgba(255,255,255,.15);
  border: none; color: #fff; font-size: 1.5rem; border-radius: .25rem;
  padding: .25rem .75rem; cursor: pointer;
}

/* ---------- MISC ------------------------------------------ */
.section { padding-block: 4rem; }
.section-sm { padding-block: 2rem; }

.two-cols { display: grid; gap: 2rem; grid-template-columns: 1fr 1fr; }
@media (max-width: 640px) { .two-cols { grid-template-columns: 1fr; } }

.badge-green {
  display: inline-block; font-size: .7rem; font-weight: 600; color: var(--green);
  background: var(--green-10); border-radius: 9999px; padding: .2rem .75rem;
}
.badge-outline-green {
  display: inline-block; font-size: .7rem; font-weight: 600; color: var(--green);
  border: 1px solid var(--green-20); border-radius: 9999px; padding: .2rem .75rem;
}

.spinner {
  width: 2.5rem; height: 2.5rem; border: 3px solid var(--border);
  border-top-color: var(--green); border-radius: 9999px;
  animation: spin .75s linear infinite; margin: 3rem auto;
}
@keyframes spin { to { transform: rotate(360deg); } }

.skeleton {
  background: linear-gradient(90deg, #f0f0f0 25%, #e8e8e8 50%, #f0f0f0 75%);
  background-size: 200% 100%; animation: shimmer 1.4s infinite;
  border-radius: .375rem;
}
@keyframes shimmer { 0% { background-position: 200% 0; } 100% { background-position: -200% 0; } }

/* toast */
.toast-container { position: fixed; bottom: 1.5rem; right: 1.5rem; z-index: 400; display: flex; flex-direction: column; gap: .5rem; }
.toast {
  background: #111827; color: #fff; padding: .875rem 1.25rem; border-radius: .5rem;
  font-size: .875rem; box-shadow: var(--shadow-md); max-width: 22rem;
  animation: fadeUp .25s ease;
}
.toast.error { background: #dc2626; }
@keyframes fadeUp { from { opacity: 0; transform: translateY(.5rem); } to { opacity: 1; transform: translateY(0); } }

/* ---- ORDER POPUP ----------------------------------------- */
.order-overlay {
  display: none; position: fixed; inset: 0; z-index: 300;
  background: rgba(0,0,0,.5); align-items: center; justify-content: center; padding: 1rem;
}
.order-overlay.open { display: flex; animation: popIn .22s ease; }
.order-panel {
  background: #fff; border-radius: .875rem; width: 100%; max-width: 560px;
  max-height: 96vh; overflow-y: auto; box-shadow: 0 24px 64px rgba(0,0,0,.22);
  padding: 1.25rem 1.5rem;
}
.order-panel-header { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: .875rem; gap: 1rem; }
.order-panel-header h3 { font-size: 1.125rem; font-weight: 700; color: var(--fg); margin: 0 0 .2rem; }
.order-panel-header p { font-size: .8125rem; color: var(--muted); margin: 0; }
.order-panel-close {
  background: none; border: none; cursor: pointer; font-size: 1.25rem;
  color: var(--muted); padding: .25rem; line-height: 1; border-radius: .25rem;
  flex-shrink: 0; transition: color .15s;
}
.order-panel-close:hover { color: var(--fg); }
.order-product-card {
  background: var(--bg-gray); border-radius: .5rem; padding: .625rem .875rem;
  margin-bottom: .875rem; border: 1px solid var(--border);
}
.order-product-card .opc-name { font-weight: 600; font-size: .875rem; margin-bottom: .2rem; line-height: 1.4; }
.order-product-card .opc-code { font-size: .75rem; color: var(--muted); font-family: monospace; }
.order-field { margin-bottom: .625rem; }
.order-field label { display: block; font-size: .8125rem; font-weight: 500; margin-bottom: .25rem; color: var(--fg); }
.order-field label .req { color: #dc2626; margin-left: .15rem; }
.order-field input, .order-field textarea, .order-field select {
  width: 100%; padding: .5rem .75rem; border: 1.5px solid var(--border);
  border-radius: .5rem; font-size: .875rem; outline: none; font-family: inherit;
  color: var(--fg); background: #fff; transition: border-color .15s; box-sizing: border-box;
}
.order-field input:focus, .order-field textarea:focus, .order-field select:focus { border-color: var(--green); }
.order-field textarea { min-height: 4rem; resize: vertical; }
.order-field select {
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23666' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right .75rem center;
  background-size: 1rem; padding-right: 2.5rem; cursor: pointer;
}
.order-fields-2col { display: grid; grid-template-columns: 1fr 1fr; gap: .625rem; }
.order-disclaimer { font-size: .7rem; color: var(--muted); margin: .25rem 0 .75rem; line-height: 1.5; }
.order-actions { display: flex; gap: .625rem; }
.order-actions .btn { flex: 1; justify-content: center; padding: .625rem 1rem; font-size: .9rem; font-weight: 600; }
.order-success { text-align: center; padding: 2rem 1rem; }
.order-success svg { color: var(--green); margin-bottom: 1rem; }
.order-success h4 { font-size: 1.125rem; font-weight: 700; margin-bottom: .5rem; }
.order-success p { color: var(--muted); font-size: .9rem; }
@media (max-width: 479px) { .order-fields-2col { grid-template-columns: 1fr; } }
