/* =====================================================================
   RIDGID Tools SK — Industrial Premium Ecommerce Design System
   Brand: RIDGID (red / black / steel)
   Distributor: ant s.r.o.
   ===================================================================== */

:root{
  /* RIDGID red palette */
  --ant-50:  #fff1f3;
  --ant-100: #ffdde1;
  --ant-200: #ffb3bd;
  --ant-300: #ff7e8e;
  --ant-400: #f04a60;
  --ant-500: #c81c01;   /* primary */
  --ant-600: #a31600;
  --ant-700: #7f0719;
  --ant-800: #5c0512;
  --ant-900: #3d030c;

  /* Steel / ink */
  --ink-50:  #f4f5f7;
  --ink-100: #e6e8ec;
  --ink-200: #c7cad0;
  --ink-300: #9aa0a8;
  --ink-400: #6b7079;
  --ink-500: #4a4d53;
  --ink-600: #34363c;
  --ink-700: #25272c;
  --ink-800: #1a1b1f;
  --ink-900: #0b0b0e;

  /* Accents */
  --gold-400: #ffc300;
  --gold-500: #f5a800;
  --green-500: #1a7f3e;
  --green-600: #146531;
  --amber-500: #d97706;

  /* Shadows */
  --shadow-soft:  0 4px 24px -8px rgba(11,11,14,.10), 0 2px 6px -2px rgba(11,11,14,.05);
  --shadow-card:  0 8px 32px -12px rgba(11,11,14,.14), 0 2px 8px -4px rgba(11,11,14,.08);
  --shadow-pop:   0 12px 40px -12px rgba(200,28,1,.45);
  --shadow-hover: 0 18px 48px -16px rgba(200,28,1,.20), 0 4px 12px -4px rgba(11,11,14,.10);

  /* Surfaces */
  --surface: #ffffff;
  --surface-2: #f7f8fa;
  --surface-3: #eef0f3;
  --border: #e6e8ec;
}

/* ---------- Reset & base ---------- */
*{box-sizing:border-box}
html{scroll-behavior:smooth;overflow-x:clip}
body{
  font-family:'Inter','Helvetica Neue',system-ui,sans-serif;
  -webkit-font-smoothing:antialiased;
  background:#fff;
  color:var(--ink-800);
  overflow-x:clip;
}

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

/* ---------- Utility helpers used by all pages ---------- */
.no-scrollbar::-webkit-scrollbar{display:none}
.no-scrollbar{-ms-overflow-style:none;scrollbar-width:none}

/* Industrial steel mesh hero bg */
.mesh-industrial{
  background:
    radial-gradient(60% 60% at 12% 10%, rgba(200,28,1,.10) 0%, rgba(200,28,1,0) 60%),
    radial-gradient(45% 55% at 92% 20%, rgba(11,11,14,.20) 0%, rgba(11,11,14,0) 60%),
    radial-gradient(70% 60% at 80% 100%, rgba(255,195,0,.06) 0%, rgba(255,195,0,0) 60%),
    linear-gradient(180deg,#ffffff 0%,#f4f5f7 100%);
}

.mesh-dark{
  background:
    radial-gradient(50% 60% at 10% 0%, rgba(200,28,1,.30) 0%, rgba(200,28,1,0) 60%),
    radial-gradient(40% 50% at 100% 20%, rgba(200,28,1,.12) 0%, rgba(200,28,1,0) 60%),
    linear-gradient(135deg,#1a1b1f 0%,#0b0b0e 60%,#0b0b0e 100%);
}

/* Industrial blueprint grid */
.grid-blueprint{
  background-image:
    linear-gradient(rgba(11,11,14,.06) 1px,transparent 1px),
    linear-gradient(90deg,rgba(11,11,14,.06) 1px,transparent 1px);
  background-size:32px 32px;
  -webkit-mask-image:radial-gradient(ellipse at center,#000 40%,transparent 75%);
          mask-image:radial-gradient(ellipse at center,#000 40%,transparent 75%);
}
.grid-blueprint-dark{
  background-image:
    linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);
  background-size:32px 32px;
  -webkit-mask-image:radial-gradient(ellipse at center,#000 40%,transparent 80%);
          mask-image:radial-gradient(ellipse at center,#000 40%,transparent 80%);
}

/* Diagonal warning stripe accent (industrial) */
.stripe-warning{
  background:repeating-linear-gradient(45deg,#ffc300 0 14px,#0b0b0e 14px 28px);
}
.stripe-thin{
  background:repeating-linear-gradient(135deg,rgba(11,11,14,.05) 0 6px,transparent 6px 12px);
}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  font-weight:700;letter-spacing:.01em;
  border:1px solid transparent;border-radius:.625rem;
  padding:0 1.1rem;height:2.75rem;
  transition:transform .12s ease,background .15s ease,color .15s ease,box-shadow .2s ease,border-color .15s;
  cursor:pointer;line-height:1;
  font-size:.875rem;
}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--ant-500);color:#fff;box-shadow:var(--shadow-pop)}
.btn-primary:hover{background:var(--ant-600)}
.btn-dark{background:var(--ink-900);color:#fff}
.btn-dark:hover{background:var(--ink-700)}
.btn-outline{background:#fff;color:var(--ink-800);border-color:var(--ink-200)}
.btn-outline:hover{border-color:var(--ant-500);color:var(--ant-600)}
.btn-outline.is-on-dark{background:transparent;color:#fff;border-color:rgba(255,255,255,.4)}
.btn-outline.is-on-dark:hover{background:rgba(255,255,255,.1);border-color:#fff;color:#fff}
.btn-ghost{background:transparent;color:var(--ink-700)}
.btn-ghost:hover{background:var(--ink-50);color:var(--ink-900)}
.btn-lg{height:3.25rem;padding:0 1.5rem;font-size:.95rem;border-radius:.75rem}
.btn-xl{height:3.5rem;padding:0 1.75rem;font-size:1rem;border-radius:.875rem}
.btn-sm{height:2.25rem;padding:0 .8rem;font-size:.8rem}
.btn-icon{width:2.75rem;padding:0}

/* ---------- Badges ---------- */
.badge{
  display:inline-flex;align-items:center;gap:.25rem;
  padding:.2rem .55rem;border-radius:.375rem;
  font-size:.68rem;font-weight:800;letter-spacing:.04em;text-transform:uppercase;
  line-height:1.2;
}
.badge-sale{background:var(--ant-500);color:#fff}
.badge-new{background:var(--ink-900);color:#fff}
.badge-stock{background:#ecfdf3;color:var(--green-600);border:1px solid #b6f0c8}
.badge-pro{background:linear-gradient(135deg,#0b0b0e,#34363c);color:#ffc300;border:1px solid #ffc300}
.badge-warranty{background:#fef3c7;color:#92400e;border:1px solid #fde68a}
.badge-tip{background:#eff6ff;color:#1d4ed8;border:1px solid #bfdbfe}
.badge-low{background:#fff7ed;color:#c2410c;border:1px solid #fed7aa}
.badge-out{background:var(--ink-100);color:var(--ink-500);border:1px solid var(--ink-200)}

/* ---------- Header ---------- */
.topbar{
  background:var(--ink-900);color:#fff;
  font-size:.75rem;
}
.topbar a{color:#fff;opacity:.85}
.topbar a:hover{color:#fff;opacity:1}

.site-header{
  position:sticky;top:0;z-index:60;background:#fff;border-bottom:1px solid var(--border);
  box-shadow:0 1px 0 rgba(0,0,0,.02);
}

/* Logo lockup */
.logo-lockup{display:inline-flex;align-items:center;gap:.6rem}
.logo-mark{
  display:inline-flex;align-items:center;justify-content:center;
  font-weight:900;font-size:1.05rem;letter-spacing:.05em;
  background:var(--ant-500);color:#fff;
  padding:.45rem .7rem;border-radius:.375rem;
  box-shadow:inset 0 -3px 0 rgba(0,0,0,.18);
  font-family:'Inter',sans-serif;
}
.logo-divider{width:1px;height:1.5rem;background:var(--ink-200)}
.logo-sub{font-size:.7rem;color:var(--ink-500);letter-spacing:.18em;text-transform:uppercase;font-weight:600;line-height:1.2}
.logo-sub strong{display:block;color:var(--ink-900);font-size:.85rem;letter-spacing:.08em}

/* Search bar */
.search-input{
  width:100%;height:3rem;padding:0 7.5rem 0 3rem;
  background:var(--ink-50);border:1px solid var(--border);
  border-radius:.625rem;font-size:.9rem;font-weight:500;color:var(--ink-800);
  transition:all .15s;
}
.search-input::placeholder{color:var(--ink-400)}
.search-input:focus{outline:none;background:#fff;border-color:var(--ant-500);box-shadow:0 0 0 4px rgba(200,28,1,.10)}

/* Header icon button */
.hdr-icon{
  position:relative;display:inline-flex;align-items:center;justify-content:center;
  width:2.75rem;height:2.75rem;border-radius:.5rem;color:var(--ink-700);
  transition:background .15s;
}
.hdr-icon:hover{background:var(--ink-50);color:var(--ink-900)}
.hdr-icon-primary{background:var(--ant-500);color:#fff;box-shadow:var(--shadow-pop)}
.hdr-icon-primary:hover{background:var(--ant-600);color:#fff}
.hdr-badge{
  position:absolute;top:-2px;right:-2px;min-width:1.1rem;height:1.1rem;padding:0 .25rem;border-radius:9999px;
  background:var(--ink-900);color:#fff;font-size:.65rem;font-weight:800;display:flex;align-items:center;justify-content:center;
}
.hdr-icon-primary .hdr-badge{background:#fff;color:var(--ant-600)}

/* ---------- Primary navigation ---------- */
.nav-strip{
  background:var(--ink-900);color:#fff;
  position:relative; /* Mega menu wrap anchors here (full nav width) */
}
/* Override the Tailwind .relative class on <li class="mega-trigger relative">
   so mega-wrap attaches to .nav-strip (wider) instead of the narrow trigger li */
.nav-strip li.mega-trigger,
.nav-strip li.mega-trigger.relative{position:static}
.nav-link{
  display:inline-flex;align-items:center;gap:.4rem;
  padding:0 .9rem;height:3rem;
  font-size:.85rem;font-weight:700;letter-spacing:.01em;color:#fff;
  border-bottom:3px solid transparent;
  transition:border-color .15s,background .15s;
  text-transform:none;
}
.nav-link:hover{background:rgba(255,255,255,.06);border-bottom-color:var(--ant-500)}
.nav-link.is-mega{background:var(--ant-500);border-bottom-color:var(--ant-500)}
.nav-link.is-mega:hover{background:var(--ant-600)}

/* Mega menu */
.mega-wrap{
  position:absolute;left:0;right:0;top:100%;z-index:60;
  visibility:hidden;opacity:0;transform:translateY(4px);
  transition:opacity .18s,transform .18s,visibility 0s linear .2s;
}
.mega-trigger:hover .mega-wrap,
.mega-wrap:hover,
.mega-trigger:focus-within .mega-wrap{
  visibility:visible;opacity:1;transform:translateY(0);transition-delay:0s,0s,0s;
}
.mega-panel{
  background:#fff;border:1px solid var(--border);border-top:3px solid var(--ant-500);
  box-shadow:var(--shadow-card);border-radius:0 0 1rem 1rem;overflow:hidden;margin-top:0;
}
.mega-col{padding:1.25rem 1.25rem;border-right:1px solid var(--border)}
.mega-col:last-child{border-right:none}
.mega-col h4{
  font-size:.7rem;text-transform:uppercase;letter-spacing:.12em;color:var(--ink-500);font-weight:800;margin-bottom:.6rem;
  display:flex;align-items:center;gap:.5rem;
}
.mega-col h4 .dot{width:.3rem;height:.3rem;background:var(--ant-500);border-radius:9999px}
.mega-col ul{display:flex;flex-direction:column;gap:.25rem}
.mega-col li a{
  display:flex;align-items:center;justify-content:space-between;
  padding:.4rem .5rem;border-radius:.4rem;font-size:.85rem;color:var(--ink-700);font-weight:500;
}
.mega-col li a:hover{background:var(--ant-50);color:var(--ant-700)}
.mega-col li a .count{font-size:.7rem;color:var(--ink-400)}
.mega-col li a:hover .count{color:var(--ant-500)}

/* ---------- Hero ---------- */
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.35rem .75rem;border-radius:9999px;
  background:rgba(200,28,1,.10);color:var(--ant-700);
  font-size:.72rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;
  border:1px solid rgba(200,28,1,.20);
}
.hero-title{
  font-size:clamp(2rem,5vw,3.75rem);font-weight:900;line-height:1.08;letter-spacing:-.02em;color:var(--ink-900);
}
.hero-title em{font-style:normal;background:linear-gradient(135deg,var(--ant-500),var(--ant-700));-webkit-background-clip:text;background-clip:text;color:transparent}

/* ---------- Product card ---------- */
.product-card{
  position:relative;background:#fff;border:1px solid var(--border);border-radius:.875rem;overflow:hidden;
  transition:border-color .2s,box-shadow .25s,transform .25s;
  display:flex;flex-direction:column;
}
.product-card:hover{border-color:var(--ant-500);box-shadow:var(--shadow-hover);transform:translateY(-2px)}
/* Wrapper around the clickable image (relative anchor for overlays) */
.product-card .pc-media-wrap{
  position:relative;background:#fff;overflow:hidden;border-radius:.875rem .875rem 0 0;
}
.product-card .pc-media{
  position:relative;display:flex;align-items:center;justify-content:center;
  aspect-ratio:1/1;background:#fff;overflow:hidden;
}
.product-card .pc-media img,
.product-card .pc-media svg.pc-photo{
  max-width:90%;max-height:90%;width:auto;height:auto;object-fit:contain;display:block;
  transition:transform .5s cubic-bezier(.2,.8,.2,1);
}
.product-card:hover .pc-media img,
.product-card:hover .pc-media svg.pc-photo{transform:scale(1.04)}

/* Overlays positioned relative to .pc-media-wrap */
.product-card .pc-badges{
  position:absolute;top:.6rem;left:.6rem;
  display:flex;flex-direction:column;gap:.3rem;z-index:3;pointer-events:none;
}
.product-card .pc-badges > *{pointer-events:auto}

.product-card .pc-wish{
  position:absolute;top:.6rem;right:.6rem;z-index:3;
  width:2.25rem;height:2.25rem;
  display:inline-flex;align-items:center;justify-content:center;
  border-radius:9999px;background:#fff;border:1px solid var(--border);color:var(--ink-500);
  box-shadow:0 2px 8px -2px rgba(11,11,14,.08);
  transition:color .15s,border-color .15s,background .15s,transform .15s;
}
.product-card .pc-wish:hover{color:var(--ant-500);border-color:var(--ant-300);transform:scale(1.06)}
.product-card .pc-wish.is-active{color:var(--ant-500);background:var(--ant-50);border-color:var(--ant-300)}

/* Quick add action — gradient bar slides up from bottom of image area */
.product-card .pc-quick{
  position:absolute;left:0;right:0;bottom:0;z-index:3;
  padding:1.4rem .65rem .65rem;
  background:linear-gradient(180deg,rgba(11,11,14,0) 0%,rgba(11,11,14,.55) 55%,rgba(11,11,14,.85) 100%);
  display:flex;gap:.4rem;align-items:stretch;
  transform:translateY(100%);
  transition:transform .28s cubic-bezier(.2,.8,.2,1);
  pointer-events:none;
}
.product-card .pc-quick > *{pointer-events:auto}
.product-card:hover .pc-quick{transform:translateY(0)}

/* Primary "Add to cart" button inside the quick bar */
.product-card .pc-quick .pc-add{
  flex:1;height:2.5rem;font-size:.82rem;font-weight:800;
  background:var(--ant-500);color:#fff;border:0;border-radius:.55rem;
  display:inline-flex;align-items:center;justify-content:center;gap:.4rem;
  box-shadow:0 6px 18px -4px rgba(200,28,1,.55);
  transition:background .15s,transform .12s;cursor:pointer;
}
.product-card .pc-quick .pc-add:hover{background:var(--ant-600)}
.product-card .pc-quick .pc-add:active{transform:translateY(1px)}
.product-card .pc-quick .pc-add svg{width:1rem;height:1rem;flex-shrink:0}

/* Touch / mobile: always show the quick bar (no hover) */
@media (hover:none),(max-width:1024px){
  .product-card .pc-quick{transform:translateY(0)}
  .product-card .pc-quick{
    padding:1.2rem .55rem .55rem;
  }
}

.product-card .pc-body{padding:.85rem 1rem 1rem;display:flex;flex-direction:column;gap:.45rem;flex:1}
.product-card .pc-brand{font-size:.7rem;color:var(--ink-400);font-weight:700;letter-spacing:.06em;text-transform:uppercase}
.product-card .pc-title{font-size:.95rem;font-weight:700;color:var(--ink-900);line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:2.4em}
.product-card .pc-title:hover{color:var(--ant-700)}
.product-card .pc-meta{display:flex;align-items:center;gap:.5rem;font-size:.72rem;color:var(--ink-500)}
.product-card .pc-meta .sku{font-family:ui-monospace,SFMono-Regular,Menlo,monospace}
.product-card .pc-stock{display:inline-flex;align-items:center;gap:.3rem;font-size:.72rem;font-weight:700;color:var(--green-600)}
.product-card .pc-stock .dot{width:.45rem;height:.45rem;background:var(--green-500);border-radius:9999px;box-shadow:0 0 0 3px rgba(26,127,62,.15)}
.product-card .pc-stock.low{color:#c2410c}
.product-card .pc-stock.low .dot{background:#ea580c;box-shadow:0 0 0 3px rgba(234,88,12,.15)}
.product-card .pc-stock.out{color:var(--ink-400)}
.product-card .pc-stock.out .dot{background:var(--ink-300);box-shadow:none}

.pc-price{display:flex;align-items:baseline;gap:.55rem;margin-top:auto}
.pc-price .now{font-size:1.3rem;font-weight:900;color:var(--ink-900);letter-spacing:-.01em}
.pc-price .now.sale{color:var(--ant-600)}
.pc-price .was{font-size:.85rem;color:var(--ink-400);text-decoration:line-through;font-weight:600}
.pc-price .vat{font-size:.7rem;color:var(--ink-400);font-weight:500;margin-left:auto}

.pc-price-secondary{font-size:.72rem;color:var(--ink-500);font-weight:500}

.pc-actions{display:flex;gap:.4rem;margin-top:.5rem}
.pc-actions .btn{flex:1}

/* Compact variant for related items */
.product-card.compact .pc-media{aspect-ratio:4/3}
.product-card.compact .pc-body{padding:.7rem .8rem .8rem}

/* ---------- Mini horizontal product (PDP "Pridajte k objednávke") ---------- */
.pc-mini-grid{display:flex;flex-direction:column;gap:.45rem}
.pc-mini{
  display:flex;align-items:center;gap:.7rem;
  padding:.55rem .65rem;
  background:#fff;border:1px solid var(--border);border-radius:.6rem;
  transition:border-color .15s,box-shadow .15s,background .15s;
}
.pc-mini:hover{border-color:var(--ant-300);background:#fffafb}
.pc-mini-thumb{
  width:3rem;height:3rem;background:var(--ink-50);border-radius:.4rem;
  display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0;
}
.pc-mini-thumb img{max-width:85%;max-height:85%;object-fit:contain}
.pc-mini-meta{flex:1;min-width:0;display:flex;flex-direction:column;gap:.1rem}
.pc-mini-title{
  font-size:.8rem;font-weight:700;color:var(--ink-900);line-height:1.25;
  overflow:hidden;text-overflow:ellipsis;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;
}
.pc-mini-title:hover{color:var(--ant-700)}
.pc-mini-price{font-size:.72rem;color:var(--ink-500);font-weight:600;line-height:1.2}
.pc-mini-price strong{color:var(--ink-900);font-weight:800;font-size:.82rem;margin-right:.25rem}
.pc-mini-price strong.sale{color:var(--ant-600)}
.pc-mini-add{
  width:2rem;height:2rem;border-radius:.4rem;border:0;cursor:pointer;flex-shrink:0;
  background:var(--ant-500);color:#fff;
  display:inline-flex;align-items:center;justify-content:center;
  box-shadow:0 3px 8px -2px rgba(200,28,1,.45);
  transition:background .15s,transform .12s;
}
.pc-mini-add:hover{background:var(--ant-600)}
.pc-mini-add:active{transform:translateY(1px)}
.pc-mini-add svg{width:1rem;height:1rem}

/* ---------- Filter sidebar ---------- */
.filter-section{border-bottom:1px solid var(--border);padding:1rem 0}
.filter-section:first-child{padding-top:0}
.filter-section:last-child{border-bottom:none}
.filter-title{display:flex;align-items:center;justify-content:space-between;font-size:.8rem;font-weight:800;color:var(--ink-900);letter-spacing:.03em;text-transform:uppercase;margin-bottom:.7rem}
.filter-option{display:flex;align-items:center;gap:.55rem;padding:.35rem 0;cursor:pointer;font-size:.875rem;color:var(--ink-700)}
.filter-option:hover{color:var(--ant-700)}
.filter-option input[type=checkbox]{appearance:none;width:1rem;height:1rem;border:1.5px solid var(--ink-300);border-radius:.25rem;background:#fff;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:all .15s}
.filter-option input[type=checkbox]:checked{background:var(--ant-500);border-color:var(--ant-500)}
.filter-option input[type=checkbox]:checked::after{content:"";width:.55rem;height:.3rem;border-left:2px solid #fff;border-bottom:2px solid #fff;transform:translateY(-1px) rotate(-45deg)}
.filter-option .count{margin-left:auto;font-size:.72rem;color:var(--ink-400)}
.filter-option:hover .count{color:var(--ant-500)}

/* Filter drawer (mobile) */
.filter-drawer{
  position:fixed;left:0;right:0;bottom:0;z-index:80;
  background:#fff;border-radius:1.25rem 1.25rem 0 0;
  max-height:88vh;display:flex;flex-direction:column;
  transform:translateY(100%);transition:transform .35s cubic-bezier(.2,.8,.2,1);
}
.filter-drawer.open{transform:translateY(0)}
.filter-backdrop{position:fixed;inset:0;z-index:79;background:rgba(11,11,14,.55);backdrop-filter:blur(4px);display:none}
.filter-backdrop.open{display:block}

/* ---------- Range slider (basic visual) ---------- */
.range-track{position:relative;height:.375rem;background:var(--ink-100);border-radius:9999px}
.range-fill{position:absolute;top:0;height:100%;background:var(--ant-500);border-radius:9999px}
.range-thumb{position:absolute;top:50%;transform:translate(-50%,-50%);width:1.1rem;height:1.1rem;background:#fff;border:2px solid var(--ant-500);border-radius:9999px;box-shadow:0 2px 6px rgba(0,0,0,.15)}

/* ---------- Sort select ---------- */
.select{
  appearance:none;height:2.75rem;padding:0 2.5rem 0 1rem;
  background:#fff url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='%234a4d53'><path d='M5.5 7.5l4.5 4.5 4.5-4.5'/></svg>") no-repeat right .75rem center / 1rem;
  border:1px solid var(--ink-200);border-radius:.5rem;
  font-size:.875rem;font-weight:600;color:var(--ink-800);
  cursor:pointer;
}
.select:focus{outline:none;border-color:var(--ant-500);box-shadow:0 0 0 4px rgba(200,28,1,.10)}

/* ---------- Breadcrumbs ---------- */
.breadcrumbs{display:flex;flex-wrap:wrap;align-items:center;gap:.3rem;font-size:.78rem;color:var(--ink-500)}
.breadcrumbs a{color:var(--ink-500);transition:color .15s}
.breadcrumbs a:hover{color:var(--ant-600)}
.breadcrumbs .sep{color:var(--ink-300)}
.breadcrumbs .current{color:var(--ink-800);font-weight:600}

/* ---------- Tag pills ---------- */
.pill{
  display:inline-flex;align-items:center;gap:.4rem;
  padding:0 .85rem;height:2.25rem;border-radius:9999px;
  background:#fff;border:1px solid var(--border);
  font-size:.8rem;font-weight:600;color:var(--ink-700);
  transition:all .15s;white-space:nowrap;
}
.pill:hover{border-color:var(--ant-500);color:var(--ant-700)}
.pill.is-active{background:var(--ink-900);color:#fff;border-color:var(--ink-900)}
.pill .count{font-size:.7rem;color:var(--ink-400)}
.pill.is-active .count{color:rgba(255,255,255,.65)}

/* ---------- Trust strip ---------- */
.trust-row{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--border)}
@media(min-width:768px){.trust-row{grid-template-columns:repeat(4,1fr)}}
.trust-item{background:#fff;padding:1.25rem;display:flex;align-items:center;gap:.85rem}
.trust-item .ico{
  width:2.5rem;height:2.5rem;border-radius:.5rem;
  background:var(--ant-50);color:var(--ant-600);
  display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;
}
.trust-item .ti-title{font-size:.85rem;font-weight:800;color:var(--ink-900);line-height:1.2}
.trust-item .ti-sub{font-size:.75rem;color:var(--ink-500);margin-top:.15rem}

/* ---------- Section heading ---------- */
.eyebrow{
  font-size:.72rem;font-weight:800;letter-spacing:.16em;text-transform:uppercase;color:var(--ant-600);
  display:inline-flex;align-items:center;gap:.45rem;
}
.eyebrow .bar{width:1.5rem;height:2px;background:var(--ant-500);border-radius:2px}

.h2{font-size:clamp(1.6rem,3vw,2.4rem);font-weight:900;letter-spacing:-.015em;color:var(--ink-900);line-height:1.1}
.h3{font-size:clamp(1.25rem,2.2vw,1.7rem);font-weight:800;letter-spacing:-.01em;color:var(--ink-900);line-height:1.2}

/* ---------- Footer ---------- */
.site-footer{
  background:var(--ink-900);color:#cbcdd2;
  padding-top:3rem;
}
.site-footer a{color:#cbcdd2}
.site-footer a:hover{color:#fff}
.site-footer h5{color:#fff;font-size:.85rem;font-weight:800;letter-spacing:.04em;text-transform:uppercase;margin-bottom:1rem}
.site-footer .col p, .site-footer .col li{font-size:.85rem;line-height:1.6}
.footer-bottom{border-top:1px solid #1f2126;margin-top:2.5rem;padding:1.25rem 0;color:#888c93;font-size:.78rem}

/* ---------- Product detail (PDP) ---------- */
.pdp-gallery-main{
  position:relative;aspect-ratio:1/1;background:#fff;border:1px solid var(--border);border-radius:1rem;overflow:hidden;
  display:flex;align-items:center;justify-content:center;
}
.pdp-gallery-main img,.pdp-gallery-main svg{max-width:80%;max-height:80%}
.pdp-thumbs{display:grid;grid-template-columns:repeat(5,1fr);gap:.5rem}
.pdp-thumb{
  aspect-ratio:1/1;background:#fff;border:1px solid var(--border);border-radius:.625rem;overflow:hidden;cursor:pointer;
  display:flex;align-items:center;justify-content:center;transition:border-color .15s;
}
.pdp-thumb:hover{border-color:var(--ant-400)}
.pdp-thumb.is-active{border-color:var(--ant-500);box-shadow:0 0 0 2px rgba(200,28,1,.15)}
.pdp-thumb img,.pdp-thumb svg{max-width:75%;max-height:75%}

.pdp-price-now{font-size:2.4rem;font-weight:900;color:var(--ink-900);letter-spacing:-.02em;line-height:1}
.pdp-price-now.sale{color:var(--ant-600)}
.pdp-price-was{font-size:1.1rem;color:var(--ink-400);text-decoration:line-through;font-weight:600}
.pdp-price-save{display:inline-flex;align-items:center;gap:.35rem;padding:.25rem .6rem;border-radius:.4rem;background:var(--ant-500);color:#fff;font-weight:800;font-size:.8rem}

.qty-input{
  display:inline-flex;align-items:center;border:1px solid var(--ink-200);border-radius:.625rem;overflow:hidden;background:#fff;
}
.qty-input button{width:2.75rem;height:3rem;background:#fff;color:var(--ink-700);font-size:1.1rem;font-weight:700;display:flex;align-items:center;justify-content:center;transition:background .15s}
.qty-input button:hover{background:var(--ink-50);color:var(--ant-600)}
.qty-input input{width:3rem;height:3rem;border:0;border-left:1px solid var(--ink-100);border-right:1px solid var(--ink-100);text-align:center;font-weight:700;font-size:1rem;color:var(--ink-900);background:#fff}
.qty-input input:focus{outline:none}

.tabs{display:flex;gap:.25rem;border-bottom:1px solid var(--border);overflow-x:auto}
.tab{
  padding:.8rem 1rem;font-size:.85rem;font-weight:700;color:var(--ink-500);
  border-bottom:3px solid transparent;cursor:pointer;white-space:nowrap;
  transition:all .15s;background:none;border-top:0;border-left:0;border-right:0;
}
.tab:hover{color:var(--ink-900)}
.tab.is-active{color:var(--ant-600);border-bottom-color:var(--ant-500)}

/* Spec table */
.spec-table{width:100%;border-collapse:collapse}
.spec-table tr{border-bottom:1px solid var(--border)}
.spec-table th,.spec-table td{padding:.7rem 0;font-size:.875rem;text-align:left;vertical-align:top}
.spec-table th{color:var(--ink-500);font-weight:600;width:40%}
.spec-table td{color:var(--ink-900);font-weight:600}

/* Download item */
.dl-item{
  display:flex;align-items:center;gap:.85rem;
  padding:.85rem 1rem;border:1px solid var(--border);border-radius:.75rem;background:#fff;
  transition:border-color .15s,box-shadow .15s;
}
.dl-item:hover{border-color:var(--ant-400);box-shadow:var(--shadow-soft)}
.dl-item .ico{
  width:2.5rem;height:2.5rem;border-radius:.5rem;background:var(--ink-50);color:var(--ant-600);
  display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;
}
.dl-item .meta{flex:1;min-width:0}
.dl-item .name{font-size:.875rem;font-weight:700;color:var(--ink-900);line-height:1.2}
.dl-item .size{font-size:.72rem;color:var(--ink-500);margin-top:.15rem}

/* ---------- Cart ---------- */
.cart-row{display:grid;grid-template-columns:96px 1fr auto;gap:1rem;padding:1.25rem 0;border-bottom:1px solid var(--border);align-items:center}
.cart-row .thumb{aspect-ratio:1/1;background:var(--ink-50);border-radius:.625rem;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;overflow:hidden}
.cart-row .thumb svg, .cart-row .thumb img{max-width:80%;max-height:80%}
.cart-row .title{font-size:.95rem;font-weight:700;color:var(--ink-900);line-height:1.3}
.cart-row .meta{font-size:.78rem;color:var(--ink-500);margin-top:.2rem}
.cart-row .row-price{font-weight:800;color:var(--ink-900);font-size:1rem;text-align:right;white-space:nowrap}
@media(max-width:640px){
  .cart-row{grid-template-columns:72px 1fr;grid-template-rows:auto auto;gap:.75rem}
  .cart-row .thumb{grid-row:1/3}
  .cart-row .row-actions{grid-column:1/3;display:flex;justify-content:space-between;align-items:center}
}

/* ---------- Order summary ---------- */
.summary{background:#fff;border:1px solid var(--border);border-radius:1rem;padding:1.25rem}
.summary .row{display:flex;align-items:center;justify-content:space-between;padding:.4rem 0;font-size:.9rem;color:var(--ink-700)}
.summary .row.total{font-weight:900;font-size:1.15rem;color:var(--ink-900);border-top:1px solid var(--border);padding-top:.8rem;margin-top:.4rem}
.summary .row .val{font-weight:700;color:var(--ink-900)}

/* ---------- Steps (checkout) ---------- */
.steps{display:flex;gap:0;width:100%}
.step{flex:1;display:flex;align-items:center;gap:.6rem;padding:.85rem 1rem;background:#fff;border:1px solid var(--border);position:relative}
.step:first-child{border-radius:.625rem 0 0 .625rem}
.step:last-child{border-radius:0 .625rem .625rem 0}
.step + .step{margin-left:-1px}
.step .num{width:1.75rem;height:1.75rem;border-radius:9999px;background:var(--ink-100);color:var(--ink-500);display:inline-flex;align-items:center;justify-content:center;font-weight:800;font-size:.8rem;flex-shrink:0}
.step.is-active{background:#fff;border-color:var(--ant-500);z-index:1}
.step.is-active .num{background:var(--ant-500);color:#fff}
.step.is-done .num{background:var(--green-500);color:#fff}
.step .step-label{font-size:.8rem;font-weight:700;color:var(--ink-700)}
.step.is-active .step-label{color:var(--ink-900)}

/* ---------- Form fields ---------- */
.field{display:flex;flex-direction:column;gap:.35rem}
.field label{font-size:.8rem;font-weight:700;color:var(--ink-700)}
.field .req{color:var(--ant-500)}
.input,.textarea{
  width:100%;height:2.75rem;padding:0 .9rem;
  background:#fff;border:1px solid var(--ink-200);border-radius:.5rem;
  font-size:.9rem;color:var(--ink-900);transition:border-color .15s,box-shadow .15s;
}
textarea.input,textarea.textarea,.textarea{height:auto;min-height:8rem;padding:.75rem .9rem;resize:vertical;line-height:1.55}
.input:focus,.textarea:focus{outline:none;border-color:var(--ant-500);box-shadow:0 0 0 4px rgba(200,28,1,.10)}
.field .hint{font-size:.72rem;color:var(--ink-500)}

/* Shipping/payment options */
.option-tile{
  display:flex;align-items:center;gap:.85rem;
  padding:1rem;border:1px solid var(--border);border-radius:.75rem;background:#fff;cursor:pointer;
  transition:border-color .15s,box-shadow .15s;
}
.option-tile:hover{border-color:var(--ant-300)}
.option-tile.is-selected{border-color:var(--ant-500);box-shadow:0 0 0 3px rgba(200,28,1,.10)}
.option-tile .opt-ico{width:2.5rem;height:2.5rem;border-radius:.5rem;background:var(--ink-50);color:var(--ink-700);display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}
.option-tile.is-selected .opt-ico{background:var(--ant-50);color:var(--ant-600)}
.option-tile .opt-title{font-weight:700;color:var(--ink-900);font-size:.9rem;line-height:1.2}
.option-tile .opt-sub{font-size:.75rem;color:var(--ink-500);margin-top:.15rem}
.option-tile .opt-price{font-weight:800;color:var(--ink-900);font-size:.95rem;margin-left:auto;white-space:nowrap}

/* ---------- Hero CTAs in dark hero ---------- */
.hero-dark{background:var(--ink-900);color:#fff}
.hero-dark .h2,.hero-dark h2,.hero-dark h1{color:#fff}

/* ---------- Mobile menu drawer ---------- */
.mm-drawer{
  position:fixed;inset:0;z-index:90;background:#fff;display:none;flex-direction:column;
}
.mm-drawer.open{display:flex}
.mm-head{padding:1rem 1rem;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.mm-body{flex:1;overflow-y:auto;padding:.5rem 0}
.mm-link{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--border);font-size:.95rem;font-weight:700;color:var(--ink-900)}
.mm-link:hover{background:var(--ink-50);color:var(--ant-600)}

/* ---------- Mini cart drawer ---------- */
.minicart{
  position:fixed;top:0;right:0;bottom:0;width:100%;max-width:420px;background:#fff;
  z-index:90;display:flex;flex-direction:column;transform:translateX(100%);transition:transform .3s cubic-bezier(.2,.8,.2,1);
  box-shadow:-12px 0 40px rgba(0,0,0,.2);
}
.minicart.open{transform:translateX(0)}

/* ---------- Sticky add-to-cart bar (PDP) ---------- */
.pdp-sticky{
  position:fixed;left:0;right:0;bottom:0;z-index:50;background:#fff;border-top:1px solid var(--border);
  box-shadow:0 -10px 24px -8px rgba(0,0,0,.10);padding:.75rem 1rem;
  transform:translateY(100%);transition:transform .3s ease;
}
.pdp-sticky.open{transform:translateY(0)}

/* ---------- Marquee ---------- */
@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.marquee{display:flex;width:max-content;animation:marquee 50s linear infinite}

/* ---------- Fade up ---------- */
@keyframes fadeUp{0%{opacity:0;transform:translateY(14px)}100%{opacity:1;transform:translateY(0)}}
.fade-up{animation:fadeUp .55s ease-out both}

/* ---------- Spinning gear (small accent) ---------- */
@keyframes spin{to{transform:rotate(360deg)}}
.gear-spin{animation:spin 14s linear infinite}

/* ---------- Helpers ---------- */
.container-x{max-width:1280px;margin-left:auto;margin-right:auto;padding-left:1rem;padding-right:1rem}
@media(min-width:1024px){.container-x{padding-left:1.5rem;padding-right:1.5rem}}

.divider-h{height:1px;background:var(--border)}
.divider-y{width:1px;background:var(--border);align-self:stretch}

.kbd{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:1.4rem;height:1.4rem;padding:0 .4rem;
  background:var(--ink-50);border:1px solid var(--border);border-bottom-width:2px;
  border-radius:.35rem;font-size:.7rem;font-family:ui-monospace,monospace;color:var(--ink-600);font-weight:600;
}

/* Industrial accent corners on featured cards */
.corner-frame{position:relative}
.corner-frame::before,.corner-frame::after{content:"";position:absolute;width:18px;height:18px;border:2px solid var(--ant-500);pointer-events:none}
.corner-frame::before{top:-2px;left:-2px;border-right:0;border-bottom:0}
.corner-frame::after{bottom:-2px;right:-2px;border-left:0;border-top:0}

/* ====================================================================
   Category tile — cinematic full-bleed scene with overlay text
   .has-scene → real photo cover-fit
   .is-product → product centered on industrial dark composite bg
   ==================================================================== */
.cat-tile{
  position:relative;display:block;
  background:#0b0b0e;border:1px solid var(--border);border-radius:.875rem;
  overflow:hidden;
  aspect-ratio:4/5;
  text-decoration:none;
  transition:border-color .25s,transform .3s cubic-bezier(.2,.8,.2,1),box-shadow .3s;
  isolation:isolate;
}
.cat-tile:hover{
  border-color:var(--ant-500);
  transform:translateY(-5px);
  box-shadow:0 24px 50px -18px rgba(200,28,1,.32),0 4px 16px -4px rgba(11,11,14,.18);
}
/* Top red ribbon on hover */
.cat-tile::before{
  content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:var(--ant-500);
  transform:scaleX(0);transform-origin:left;
  transition:transform .4s cubic-bezier(.2,.8,.2,1);
  z-index:7;
}
.cat-tile:hover::before{transform:scaleX(1)}

/* Image area fills entire tile */
.cat-tile .ct-image-area{
  position:absolute;inset:0;z-index:0;
  overflow:hidden;
}

/* Background fallback (visible only if image fails to load) */
.cat-tile .ct-image-area{background:#0b0b0e}
.cat-tile.is-product .ct-image-area{
  background:radial-gradient(70% 80% at 50% 35%,#2c2e33 0%,#0b0b0e 70%);
}

/* Image: full tile height, natural width (aspect preserved), slightly muted.
   Hover: scale 1.2 + full opacity */
.cat-tile img.ct-art{
  position:absolute;
  width:auto;
  height:100%;
  opacity:.85;
  z-index:0;
  filter:drop-shadow(0 8px 12px rgba(11,11,14,.12));
  transition:transform .35s cubic-bezier(.2,.8,.2,1),opacity .25s;
  pointer-events:none;
}
.cat-tile:hover img.ct-art{
  transform:scale(1.2);
  opacity:1;
}

/* Corner brackets (industrial) */
.cat-tile .ct-corner{
  position:absolute;width:16px;height:16px;
  border:2px solid rgba(255,255,255,.4);
  z-index:5;transition:opacity .25s,border-color .25s,width .25s,height .25s;
}
.cat-tile .ct-corner.tl{top:.85rem;left:.85rem;border-right:0;border-bottom:0}
.cat-tile .ct-corner.br{bottom:7.5rem;right:.85rem;border-left:0;border-top:0}
.cat-tile:hover .ct-corner{opacity:1;border-color:var(--ant-500);width:20px;height:20px}

/* Index number top-left */
.cat-tile .ct-index{
  position:absolute;top:2.2rem;left:1.9rem;z-index:5;
  font-family:ui-monospace,SFMono-Regular,Menlo,monospace;
  font-size:.66rem;font-weight:800;letter-spacing:.1em;
  color:rgba(255,255,255,.78);
  text-shadow:0 1px 4px rgba(0,0,0,.7);
}
.cat-tile .ct-index::before{
  content:"";display:inline-block;width:.45rem;height:.45rem;
  background:var(--ant-500);border-radius:9999px;
  vertical-align:.075rem;margin-right:.45rem;
  box-shadow:0 0 8px rgba(200,28,1,.7);
}

/* Bottom overlay with text — gradient up to image */
.cat-tile .ct-body{
  position:absolute;bottom:0;left:0;right:0;
  z-index:4;padding:5rem 1.2rem 1.2rem;
  background:linear-gradient(180deg,rgba(11,11,14,0) 0%,rgba(11,11,14,.55) 35%,rgba(11,11,14,.92) 75%,rgba(11,11,14,.98) 100%);
  color:#fff;
  display:flex;flex-direction:column;gap:.15rem;
}
.cat-tile .ct-title{
  font-size:1.2rem;font-weight:900;color:#fff;
  letter-spacing:-.015em;line-height:1.1;
  text-shadow:0 1px 4px rgba(0,0,0,.4);
}
.cat-tile .ct-subtitle{
  font-size:.78rem;color:rgba(255,255,255,.72);
  font-weight:600;line-height:1.25;
  margin-top:.1rem;
}
/* Footer row: count + price */
.cat-tile .ct-footer{
  display:flex;align-items:center;justify-content:space-between;
  margin-top:.7rem;padding-top:.7rem;
  border-top:1px dashed rgba(255,255,255,.18);
  font-size:.72rem;
}
.cat-tile .ct-meta{color:rgba(255,255,255,.65);font-weight:600}
.cat-tile .ct-price{color:#ff7e8e;font-weight:800;letter-spacing:.01em}

/* Arrow CTA top-right — visible default, animates on hover */
.cat-tile .ct-arrow{
  position:absolute;top:.85rem;right:.85rem;z-index:6;
  width:2.4rem;height:2.4rem;border-radius:.55rem;
  background:rgba(200,28,1,.85);color:#fff;backdrop-filter:blur(6px);
  display:inline-flex;align-items:center;justify-content:center;
  box-shadow:0 8px 20px -4px rgba(200,28,1,.45);
  transform:scale(.85);opacity:.75;
  transition:transform .35s cubic-bezier(.4,1.5,.5,1),opacity .2s,background .2s;
}
.cat-tile:hover .ct-arrow{transform:scale(1) rotate(0);opacity:1;background:var(--ant-500)}
.cat-tile .ct-arrow svg{width:1.05rem;height:1.05rem}

/* Soft "industrial" card */
.indus-card{background:#fff;border:1px solid var(--border);border-radius:1rem;padding:1.25rem}

/* Sticky filters/toolbar */
.toolbar-sticky{position:sticky;top:7.5rem;z-index:30;background:rgba(255,255,255,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--border)}

/* Reduce paddings on mobile */
@media(max-width:640px){
  .container-x{padding-left:.85rem;padding-right:.85rem}
}

/* =====================================================================
   v2 additions: Team, Blog, Article, Callouts, Avatar, Reading progress
   ===================================================================== */

/* ---------- Avatars ---------- */
.av{
  position:relative;display:inline-flex;align-items:center;justify-content:center;
  border-radius:9999px;color:#fff;font-weight:800;letter-spacing:.02em;
  background:linear-gradient(135deg,#c81c01,#7f0719);
  flex-shrink:0;text-transform:uppercase;
  box-shadow:inset 0 -3px 0 rgba(0,0,0,.10);
}
.av img{width:100%;height:100%;border-radius:9999px;object-fit:cover}
.av-xs{width:1.75rem;height:1.75rem;font-size:.65rem}
.av-sm{width:2.5rem;height:2.5rem;font-size:.8rem}
.av-md{width:3.25rem;height:3.25rem;font-size:1rem}
.av-lg{width:4.5rem;height:4.5rem;font-size:1.25rem}
.av-xl{width:5.5rem;height:5.5rem;font-size:1.5rem}
.av-2xl{width:7rem;height:7rem;font-size:1.9rem}
.av-status{position:absolute;bottom:0;right:0;width:.85rem;height:.85rem;border:2px solid #fff;border-radius:9999px}
.av-status.online{background:#1a7f3e}
.av-status.away{background:#f5a800}
.av-status.off{background:#9aa0a8}
/* Soft hue variants */
.av-steel{background:linear-gradient(135deg,#34363c,#0b0b0e)}
.av-amber{background:linear-gradient(135deg,#f5a800,#9a5d00)}
.av-ink{background:linear-gradient(135deg,#4a4d53,#1a1b1f)}
.av-warm{background:linear-gradient(135deg,#a31600,#3d030c)}

/* ---------- Team card ---------- */
.team-card{
  position:relative;background:#fff;border:1px solid var(--border);border-radius:1rem;padding:1.1rem;
  transition:border-color .2s,box-shadow .25s,transform .25s;
  display:flex;flex-direction:column;
}
.team-card:hover{border-color:var(--ant-500);box-shadow:var(--shadow-hover);transform:translateY(-2px)}
.team-card .tc-head{display:flex;align-items:center;gap:.85rem;margin-bottom:.6rem}
.team-card .tc-name{font-size:.95rem;font-weight:800;color:var(--ink-900);line-height:1.2}
.team-card .tc-role{font-size:.74rem;color:var(--ink-500);font-weight:600;margin-top:.1rem}
.team-card .tc-actions{display:flex;gap:.35rem;margin-top:auto;padding-top:.7rem}
.team-card .tc-actions a{
  display:inline-flex;align-items:center;justify-content:center;gap:.3rem;
  height:2rem;padding:0 .7rem;border:1px solid var(--border);border-radius:.4rem;
  font-size:.72rem;font-weight:700;color:var(--ink-700);transition:border-color .15s,color .15s;
}
.team-card .tc-actions a:hover{border-color:var(--ant-500);color:var(--ant-700)}
.team-card .tc-actions a.is-primary{background:var(--ant-500);color:#fff;border-color:var(--ant-500)}
.team-card .tc-actions a.is-primary:hover{background:var(--ant-600)}
.team-card .tc-region{
  position:absolute;top:.7rem;right:.7rem;
  font-size:.62rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;
  padding:.18rem .42rem;border-radius:.3rem;
  background:var(--ink-50);color:var(--ink-600);border:1px solid var(--border);
}
.team-card .tc-meta{font-size:.72rem;color:var(--ink-500);margin-top:.3rem}

/* Division card */
.div-card{
  background:#fff;border:1px solid var(--border);border-radius:1rem;padding:1.25rem;
  display:flex;flex-direction:column;gap:.8rem;
  transition:border-color .2s,box-shadow .25s;
}
.div-card:hover{border-color:var(--ant-500)}
.div-card .dc-code{
  display:inline-flex;align-items:center;justify-content:center;
  width:3rem;height:3rem;border-radius:.6rem;
  background:var(--ink-900);color:var(--ant-400);
  font-weight:900;letter-spacing:.05em;font-size:.85rem;
}
.div-card.is-ele .dc-code{background:linear-gradient(135deg,#ffc300,#9a5d00);color:#0b0b0e}
.div-card.is-wel .dc-code{background:linear-gradient(135deg,#f04a60,#7f0719)}
.div-card.is-cle .dc-code{background:linear-gradient(135deg,#1a7f3e,#0a3219)}
.div-card.is-plu .dc-code{background:linear-gradient(135deg,#1d4ed8,#0b1b5e);color:#fff}
.div-card.is-pla .dc-code{background:linear-gradient(135deg,#34363c,#0b0b0e)}

/* ---------- Blog ---------- */
.blog-card{
  position:relative;background:#fff;border:1px solid var(--border);border-radius:1rem;overflow:hidden;
  transition:border-color .2s,box-shadow .25s,transform .25s;display:flex;flex-direction:column;
}
.blog-card:hover{border-color:var(--ant-500);box-shadow:var(--shadow-hover);transform:translateY(-2px)}
.blog-card .bc-media{position:relative;aspect-ratio:16/10;overflow:hidden;background:var(--ink-50)}
.blog-card .bc-media img,
.blog-card .bc-media svg{width:100%;height:100%;object-fit:cover;transition:transform .5s cubic-bezier(.2,.8,.2,1)}
.blog-card:hover .bc-media img{transform:scale(1.04)}
.blog-card .bc-cat{
  position:absolute;top:.7rem;left:.7rem;
  display:inline-flex;align-items:center;gap:.3rem;
  background:var(--ant-500);color:#fff;
  font-size:.65rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;
  padding:.25rem .55rem;border-radius:.3rem;
}
.blog-card .bc-cat.is-guide{background:#1d4ed8}
.blog-card .bc-cat.is-news{background:var(--ink-900)}
.blog-card .bc-cat.is-howto{background:#1a7f3e}
.blog-card .bc-body{padding:1.1rem;display:flex;flex-direction:column;gap:.55rem;flex:1}
.blog-card .bc-meta{display:flex;align-items:center;gap:.65rem;font-size:.72rem;color:var(--ink-500);font-weight:600}
.blog-card .bc-meta .dot{width:.25rem;height:.25rem;background:var(--ink-300);border-radius:9999px}
.blog-card .bc-title{font-size:1.05rem;font-weight:800;line-height:1.25;color:var(--ink-900)}
.blog-card .bc-title:hover{color:var(--ant-700)}
.blog-card .bc-excerpt{font-size:.85rem;color:var(--ink-500);line-height:1.5;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.blog-card .bc-author{display:flex;align-items:center;gap:.6rem;margin-top:auto;padding-top:.6rem;border-top:1px solid var(--border)}
.blog-card .bc-author .name{font-size:.78rem;font-weight:700;color:var(--ink-800);line-height:1.1}
.blog-card .bc-author .role{font-size:.68rem;color:var(--ink-400)}

/* Featured (large) variant */
.blog-card.is-featured{flex-direction:row}
.blog-card.is-featured .bc-media{flex:1;aspect-ratio:4/3;min-height:380px;max-height:520px;align-self:stretch}
.blog-card.is-featured .bc-body{flex:1;padding:1.75rem 2rem;justify-content:center;gap:.8rem}
.blog-card.is-featured .bc-title{font-size:1.85rem}
.blog-card.is-featured .bc-excerpt{font-size:.95rem;-webkit-line-clamp:4}
@media(max-width:900px){.blog-card.is-featured{flex-direction:column}.blog-card.is-featured .bc-media{aspect-ratio:16/10;min-height:240px;max-height:none}}

/* ---------- Article (blog detail) ---------- */
.read-progress{
  position:fixed;top:0;left:0;right:0;height:3px;z-index:70;
  background:transparent;pointer-events:none;
}
.read-progress .rp-bar{height:100%;background:var(--ant-500);transition:width .1s linear;width:0}

.article-hero{
  background:linear-gradient(180deg,#ffffff 0%,#f7f8fa 100%);
  border-bottom:1px solid var(--border);
}

.article-content{
  font-size:1.0625rem;line-height:1.75;color:var(--ink-700);
  min-width:0;overflow-wrap:break-word;word-wrap:break-word;
}
.article-content > *{max-width:100%}
.article-content pre{white-space:pre-wrap;word-break:break-word;max-width:100%;overflow-x:auto}
@media (max-width:767px){
  .article-content table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch;width:100%;white-space:nowrap}
}
.article-content h2{
  font-size:clamp(1.4rem,2.4vw,1.85rem);
  font-weight:900;color:var(--ink-900);
  margin:2.5rem 0 1rem;
  letter-spacing:-.01em;line-height:1.2;
  scroll-margin-top:8rem;
  position:relative;padding-left:.85rem;
}
.article-content h2::before{
  content:"";position:absolute;left:0;top:.45em;bottom:.25em;width:4px;
  background:var(--ant-500);border-radius:2px;
}
.article-content h3{
  font-size:clamp(1.15rem,1.8vw,1.4rem);
  font-weight:800;color:var(--ink-900);margin:1.75rem 0 .8rem;line-height:1.3;
  scroll-margin-top:8rem;
}
.article-content h4{font-size:1.05rem;font-weight:800;color:var(--ink-900);margin:1.4rem 0 .5rem}
.article-content p{margin:0 0 1.15rem}
.article-content p strong{color:var(--ink-900);font-weight:700}
.article-content a{color:var(--ant-600);font-weight:600;border-bottom:1px solid rgba(200,28,1,.25)}
.article-content a:hover{color:var(--ant-700);border-color:var(--ant-500)}
.article-content ul,.article-content ol{margin:0 0 1.4rem 1.25rem;padding:0}
.article-content ul li,.article-content ol li{margin:.4rem 0}
.article-content ul li::marker{color:var(--ant-500)}
.article-content ol li::marker{color:var(--ant-500);font-weight:700}
.article-content blockquote{
  margin:1.6rem 0;padding:1rem 1.25rem;
  border-left:4px solid var(--ant-500);background:#fff7f9;border-radius:0 .5rem .5rem 0;
  font-style:italic;color:var(--ink-700);
}
.article-content blockquote cite{display:block;margin-top:.5rem;font-style:normal;font-size:.82rem;color:var(--ink-500);font-weight:700}
.article-content figure{margin:1.6rem 0}
.article-content figure img{border-radius:.625rem;border:1px solid var(--border)}
.article-content figcaption{margin-top:.6rem;font-size:.82rem;color:var(--ink-500);text-align:center}
.article-content table{width:100%;border-collapse:collapse;margin:1.4rem 0;font-size:.95rem;border:1px solid var(--border);border-radius:.625rem;overflow:hidden}
.article-content table th{background:var(--ink-900);color:#fff;text-align:left;padding:.7rem .85rem;font-weight:800;font-size:.82rem;text-transform:uppercase;letter-spacing:.04em}
.article-content table td{padding:.7rem .85rem;border-bottom:1px solid var(--border);vertical-align:top}
.article-content table tr:last-child td{border-bottom:0}
.article-content table tr:nth-child(even) td{background:var(--ink-50)}
.article-content table td strong{color:var(--ink-900)}

/* TL;DR / answer box (AEO) */
.tldr{
  border:1px solid var(--ant-200);background:#fff7f9;border-left:4px solid var(--ant-500);
  border-radius:.625rem;padding:1.1rem 1.25rem;margin:1.5rem 0;
}
.tldr .tldr-eyebrow{
  font-size:.72rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--ant-600);
  display:inline-flex;align-items:center;gap:.4rem;margin-bottom:.4rem;
}
.tldr p{margin:0;color:var(--ink-800);font-weight:500}
.tldr ul{margin-top:.5rem !important;margin-bottom:0 !important}

/* Callout boxes */
.callout{
  position:relative;
  border:1px solid var(--border);border-left:4px solid var(--ink-400);background:var(--ink-50);
  border-radius:.5rem;padding:1rem 1.15rem;margin:1.4rem 0;
  font-size:.95rem;
}
.callout .callout-title{font-weight:800;color:var(--ink-900);margin-bottom:.25rem;display:flex;align-items:center;gap:.45rem}
.callout p:last-child{margin-bottom:0}
.callout.is-tip{border-left-color:#1a7f3e;background:#ecfdf3}
.callout.is-tip .callout-title{color:#0a3219}
.callout.is-warn{border-left-color:#d97706;background:#fff7ed}
.callout.is-warn .callout-title{color:#7c2d12}
.callout.is-info{border-left-color:#1d4ed8;background:#eff6ff}
.callout.is-info .callout-title{color:#1e3a8a}
.callout.is-pro{border-left-color:var(--ant-500);background:#fff7f9}
.callout.is-pro .callout-title{color:var(--ant-700)}

/* Pull quote */
.pull-quote{
  margin:1.8rem 0;padding:1.4rem 1.6rem;
  background:var(--ink-900);color:#fff;border-radius:.75rem;position:relative;
  font-size:1.15rem;font-weight:600;line-height:1.5;
}
.pull-quote::before{content:"\201C";position:absolute;top:-.2em;left:.6rem;font-size:4rem;color:var(--ant-500);font-family:Georgia,serif;line-height:1}
.pull-quote cite{display:block;margin-top:.6rem;font-size:.82rem;font-weight:700;color:var(--ant-400);font-style:normal;letter-spacing:.04em;text-transform:uppercase}

/* Step list */
.steplist{counter-reset:step;margin:1.4rem 0;padding:0;list-style:none}
.steplist li{
  position:relative;padding:1rem 1rem 1rem 3.5rem;
  background:#fff;border:1px solid var(--border);border-radius:.625rem;margin-bottom:.55rem;
}
.steplist li::before{
  counter-increment:step;content:counter(step);
  position:absolute;left:1rem;top:1rem;
  width:1.85rem;height:1.85rem;border-radius:9999px;
  background:var(--ant-500);color:#fff;font-weight:900;
  display:inline-flex;align-items:center;justify-content:center;font-size:.85rem;
}
.steplist li strong{display:block;color:var(--ink-900);margin-bottom:.2rem}

/* Inline product callout in article */
.in-article-product{
  display:flex;align-items:center;gap:1rem;
  background:#fff;border:1px solid var(--ant-200);border-radius:.75rem;
  padding:1rem;margin:1.4rem 0;
}
.in-article-product .iap-img{width:5rem;height:5rem;background:var(--ink-50);border-radius:.5rem;display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0}
.in-article-product .iap-img img{max-width:80%;max-height:80%}
.in-article-product .iap-meta{flex:1;min-width:0}
.in-article-product .iap-eyebrow{font-size:.68rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--ant-600)}
.in-article-product .iap-title{font-size:.95rem;font-weight:800;color:var(--ink-900);line-height:1.2;margin-top:.2rem}
.in-article-product .iap-price{font-size:.82rem;color:var(--ink-500);margin-top:.15rem}

/* TOC sidebar */
.toc{position:sticky;top:8rem}
.toc-title{font-size:.72rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-500);margin-bottom:.7rem;display:flex;align-items:center;gap:.45rem}
.toc-list{list-style:none;margin:0;padding:0;border-left:2px solid var(--border)}
.toc-list li{position:relative}
.toc-list a{
  display:block;padding:.5rem .9rem;font-size:.82rem;color:var(--ink-500);font-weight:600;
  border-left:2px solid transparent;margin-left:-2px;transition:color .15s,border-color .15s;line-height:1.35;
}
.toc-list a:hover{color:var(--ant-600)}
.toc-list a.is-active{color:var(--ant-600);border-left-color:var(--ant-500);background:rgba(200,28,1,.04)}
.toc-list a.lvl-3{padding-left:1.6rem;font-size:.78rem}

/* Share rail */
.share-rail{display:flex;flex-wrap:wrap;gap:.4rem;align-items:center}
.share-rail .sr-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;font-weight:800;color:var(--ink-500);margin-right:.25rem}
.share-btn{display:inline-flex;align-items:center;justify-content:center;width:2.25rem;height:2.25rem;border-radius:.5rem;border:1px solid var(--border);color:var(--ink-600);background:#fff;transition:all .15s}
.share-btn:hover{border-color:var(--ant-500);color:var(--ant-600)}

/* FAQ */
.faq-list details{
  background:#fff;border:1px solid var(--border);border-radius:.625rem;
  padding:1rem 1.15rem;margin-bottom:.55rem;transition:border-color .15s;
}
.faq-list details:hover{border-color:var(--ant-300)}
.faq-list details[open]{border-color:var(--ant-500);background:#fff7f9}
.faq-list summary{
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
  list-style:none;cursor:pointer;font-weight:700;color:var(--ink-900);font-size:1.02rem;line-height:1.35;
}
.faq-list summary::-webkit-details-marker{display:none}
.faq-list summary .ico{
  flex-shrink:0;width:1.85rem;height:1.85rem;border-radius:.4rem;
  background:var(--ink-50);color:var(--ant-600);
  display:inline-flex;align-items:center;justify-content:center;transition:transform .2s;
}
.faq-list details[open] summary .ico{transform:rotate(45deg);background:var(--ant-500);color:#fff}
.faq-list .faq-body{margin-top:.7rem;color:var(--ink-700);font-size:.95rem;line-height:1.65}

/* Author card */
.author-card{
  display:flex;gap:1.15rem;align-items:center;
  padding:1.25rem;background:#fff;border:1px solid var(--border);border-radius:1rem;
}
.author-card .ac-name{font-size:1.05rem;font-weight:800;color:var(--ink-900);line-height:1.2}
.author-card .ac-role{font-size:.78rem;color:var(--ant-600);font-weight:700;letter-spacing:.04em;text-transform:uppercase;margin-top:.1rem}
.author-card .ac-bio{font-size:.88rem;color:var(--ink-600);margin-top:.4rem;line-height:1.55}
.author-card .ac-social{margin-top:.5rem;display:flex;gap:.3rem}

/* Comparison table polished */
.cmp-table{width:100%;border-collapse:separate;border-spacing:0;margin:1.4rem 0;border:1px solid var(--border);border-radius:.75rem;overflow:hidden;font-size:.92rem}
.cmp-table th{background:var(--ink-900);color:#fff;padding:.85rem .85rem;text-align:left;font-size:.78rem;font-weight:800;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}
.cmp-table td{padding:.85rem .85rem;border-bottom:1px solid var(--border);vertical-align:top}
.cmp-table tr:last-child td{border-bottom:0}
.cmp-table tr td:first-child{font-weight:800;color:var(--ink-900);background:var(--ink-50)}
.cmp-table .ok{color:#1a7f3e;font-weight:800}
.cmp-table .no{color:#9aa0a8;font-weight:700}
.cmp-table .meh{color:#d97706;font-weight:700}

/* =====================================================================
   v3 additions: Real RIDGID + ant brand lockup image
   ===================================================================== */
.logo-link{display:inline-flex;align-items:center;gap:.6rem;line-height:1}
.logo-img{height:2.5rem;width:auto;display:block}
@media(min-width:1024px){ .logo-img{height:2.8rem} }
.logo-img-sm{height:2.25rem;width:auto;display:block}
/* Footer / dark background — keep logo on white plate so red bar & black mark stay correct */
.logo-plate{
  display:inline-flex;align-items:center;justify-content:center;
  background:#fff;padding:.5rem .75rem;border-radius:.5rem;
  box-shadow:0 4px 14px -6px rgba(0,0,0,.4);
}
.logo-plate .logo-img{height:2.4rem}

/* =====================================================================
   v4 additions: Variant product detail page (table + mobile cards)
   ===================================================================== */

/* Price-from block in buy box (no main ATC) */
.price-from{margin-top:0}
.price-from-label{
  font-size:.72rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-500);
}
.price-from-row{display:flex;align-items:baseline;gap:.65rem;flex-wrap:wrap;margin-top:.2rem}
.price-from-now{font-size:2.5rem;font-weight:900;color:var(--ink-900);letter-spacing:-.02em;line-height:1}
.price-from-now.sale{color:var(--ant-600)}
.price-from-was{font-size:1rem;color:var(--ink-400);text-decoration:line-through;font-weight:600}
.price-from-save{
  display:inline-flex;align-items:center;gap:.3rem;padding:.2rem .55rem;border-radius:.4rem;
  background:var(--ant-500);color:#fff;font-weight:800;font-size:.75rem;
}
.price-from-meta{display:flex;flex-wrap:wrap;gap:.5rem 1rem;font-size:.85rem;color:var(--ink-500);margin-top:.5rem}
.price-from-meta strong{color:var(--ink-900);font-weight:700}
.price-from-stock{
  display:inline-flex;align-items:center;gap:.4rem;font-size:.85rem;font-weight:700;color:var(--green-600);
}
.price-from-stock .dot{width:.55rem;height:.55rem;background:var(--green-500);border-radius:9999px;box-shadow:0 0 0 3px rgba(26,127,62,.18)}

/* "Choose variant" big CTA pill — replaces ATC button */
.btn-pick-variant{
  display:inline-flex;align-items:center;justify-content:center;gap:.55rem;
  width:100%;height:3.5rem;padding:0 1.5rem;border-radius:.875rem;
  background:var(--ant-500);color:#fff;font-weight:800;font-size:1rem;letter-spacing:.01em;
  border:0;cursor:pointer;box-shadow:var(--shadow-pop);
  transition:background .15s,transform .12s;
}
.btn-pick-variant:hover{background:var(--ant-600)}
.btn-pick-variant:active{transform:translateY(1px)}
.btn-pick-variant svg{width:1.25rem;height:1.25rem;flex-shrink:0;animation:pickArrow 1.6s ease-in-out infinite}
@keyframes pickArrow{0%,100%{transform:translateY(0)}50%{transform:translateY(4px)}}

/* ----- Variant table (desktop) ----- */
.variant-section{background:#fff;padding:3rem 0 3.5rem;border-top:1px solid var(--border)}
.variant-section .vs-head{display:flex;align-items:end;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-bottom:1.25rem}
.variant-section h2{font-size:clamp(1.4rem,2.4vw,1.9rem);font-weight:900;color:var(--ink-900);letter-spacing:-.01em;line-height:1.2}
.variant-section .vs-sub{color:var(--ink-500);font-size:.95rem;margin-top:.25rem}

.variant-filter{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:1rem}
.variant-filter .pill{font-size:.78rem;height:2.1rem;padding:0 .8rem}

.variant-table-wrap{
  background:#fff;border:1px solid var(--border);border-radius:1rem;overflow:hidden;
  box-shadow:var(--shadow-soft);
}
.variant-table{width:100%;border-collapse:collapse;font-size:.92rem}
.variant-table thead th{
  background:var(--ink-900);color:#fff;
  font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;font-weight:800;
  padding:.85rem 1rem;text-align:left;white-space:nowrap;
}
.variant-table thead th.right{text-align:right}
.variant-table thead th.center{text-align:center}
.variant-table tbody tr{border-bottom:1px solid var(--border);transition:background .15s,box-shadow .15s}
.variant-table tbody tr:hover{background:#fffafb}
.variant-table tbody tr.is-selected{background:#fff7f9;box-shadow:inset 4px 0 0 var(--ant-500)}
.variant-table tbody tr:last-child{border-bottom:0}
.variant-table tbody td{padding:1rem;vertical-align:middle}
.variant-table tbody td.right{text-align:right}
.variant-table tbody td.center{text-align:center}

.vt-product{display:flex;gap:.85rem;align-items:center;min-width:280px}
.vt-product .thumb{
  width:3.5rem;height:3.5rem;background:#fff;border:1px solid var(--border);border-radius:.5rem;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden;
}
.vt-product .thumb img{max-width:85%;max-height:85%;object-fit:contain}
.vt-product .meta{min-width:0}
.vt-product .name{font-weight:700;color:var(--ink-900);line-height:1.3;font-size:.92rem}
.vt-product .sub{font-size:.72rem;color:var(--ink-500);margin-top:.2rem;display:inline-flex;align-items:center;gap:.4rem;flex-wrap:wrap}
.vt-product .sub .vt-tag{
  display:inline-flex;align-items:center;padding:.05rem .4rem;border-radius:.25rem;
  background:var(--ink-100);color:var(--ink-700);font-weight:700;font-size:.65rem;letter-spacing:.04em;text-transform:uppercase;
}
.vt-product .sub .vt-tag.is-aku{background:#fff7d6;color:#7c4f00}
.vt-product .sub .vt-tag.is-net{background:#dbeafe;color:#1e40af}
.vt-product .sub .vt-tag.is-zero{background:var(--ink-100);color:var(--ink-700)}

.vt-sku{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.78rem;color:var(--ink-500);white-space:nowrap}

.vt-stock{display:inline-flex;align-items:center;gap:.4rem;font-size:.78rem;font-weight:700;color:var(--green-600);white-space:nowrap}
.vt-stock .dot{width:.5rem;height:.5rem;background:var(--green-500);border-radius:9999px;box-shadow:0 0 0 3px rgba(26,127,62,.15)}
.vt-stock.low{color:#c2410c}
.vt-stock.low .dot{background:#ea580c;box-shadow:0 0 0 3px rgba(234,88,12,.15)}
.vt-stock.out{color:var(--ink-400)}
.vt-stock.out .dot{background:var(--ink-300);box-shadow:none}

.vt-price{font-weight:900;color:var(--ink-900);font-size:1.05rem;line-height:1.15;white-space:nowrap}
.vt-price.sale{color:var(--ant-600)}
.vt-price-was{font-size:.78rem;color:var(--ink-400);text-decoration:line-through;font-weight:600;display:block;line-height:1.2}
.vt-price-vat{font-size:.78rem;color:var(--ink-500);font-weight:600;white-space:nowrap}

/* Compact qty input for table rows */
.qty-mini{display:inline-flex;align-items:center;border:1px solid var(--ink-200);border-radius:.5rem;overflow:hidden;background:#fff}
.qty-mini button{
  width:1.85rem;height:2.25rem;background:#fff;color:var(--ink-700);font-weight:700;font-size:1rem;
  display:flex;align-items:center;justify-content:center;border:0;cursor:pointer;transition:background .15s,color .15s;
}
.qty-mini button:hover{background:var(--ink-50);color:var(--ant-600)}
.qty-mini input{
  width:2.5rem;height:2.25rem;border:0;border-left:1px solid var(--ink-100);border-right:1px solid var(--ink-100);
  text-align:center;font-weight:700;font-size:.88rem;color:var(--ink-900);background:#fff;
}
.qty-mini input:focus{outline:none}

/* Add-to-cart for table row */
.vt-add{
  display:inline-flex;align-items:center;gap:.4rem;
  height:2.25rem;padding:0 .9rem;border-radius:.5rem;border:0;cursor:pointer;
  background:var(--ant-500);color:#fff;font-weight:800;font-size:.78rem;
  box-shadow:0 4px 12px -3px rgba(200,28,1,.5);
  transition:background .15s,transform .12s;white-space:nowrap;
}
.vt-add:hover{background:var(--ant-600)}
.vt-add:active{transform:translateY(1px)}
.vt-add svg{width:.95rem;height:.95rem;flex-shrink:0}
.vt-add.is-disabled{background:var(--ink-200);color:var(--ink-500);box-shadow:none;cursor:not-allowed}

/* ----- Mobile variant cards ----- */
.variant-cards{display:none;flex-direction:column;gap:.65rem}
@media(max-width:900px){
  .variant-table-wrap{display:none}
  .variant-cards{display:flex}
}
.variant-card{
  background:#fff;border:1px solid var(--border);border-radius:.875rem;padding:1rem;
  display:grid;grid-template-columns:64px 1fr;gap:.85rem 1rem;
}
.variant-card.is-selected{border-color:var(--ant-500);box-shadow:0 0 0 3px rgba(200,28,1,.1)}
.variant-card .vc-thumb{
  width:64px;height:64px;background:#fff;border:1px solid var(--border);border-radius:.5rem;
  display:flex;align-items:center;justify-content:center;overflow:hidden;grid-row:1/3;
}
.variant-card .vc-thumb img{max-width:85%;max-height:85%;object-fit:contain}
.variant-card .vc-head{min-width:0}
.variant-card .vc-name{font-weight:700;color:var(--ink-900);line-height:1.3;font-size:.92rem}
.variant-card .vc-meta{font-size:.72rem;color:var(--ink-500);margin-top:.2rem;display:flex;flex-wrap:wrap;gap:.4rem;align-items:center}
.variant-card .vc-bottom{grid-column:1/3;display:flex;align-items:flex-end;gap:.85rem;justify-content:space-between;padding-top:.65rem;border-top:1px solid var(--border)}
.variant-card .vc-pricewrap{min-width:0}
.variant-card .vc-actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0}

/* Sticky variant bar (replaces single ATC bar on variant PDP) */
.pdp-sticky-var{
  position:fixed;left:0;right:0;bottom:0;z-index:50;background:#fff;border-top:1px solid var(--border);
  box-shadow:0 -10px 24px -8px rgba(0,0,0,.1);padding:.75rem 1rem;
  transform:translateY(100%);transition:transform .3s ease;
}
.pdp-sticky-var.open{transform:translateY(0)}

/* Sale flag for variant rows */
.vt-saleflag{
  display:inline-flex;align-items:center;padding:.05rem .35rem;border-radius:.25rem;
  background:var(--ant-500);color:#fff;font-weight:800;font-size:.62rem;letter-spacing:.04em;text-transform:uppercase;margin-left:.35rem;
}

/* =====================================================================
   v5 additions: Footer polish, social icons, ant logo filter, AI search
   ===================================================================== */

/* ---------- Footer brand area ---------- */
.site-footer{padding-top:3.5rem}
.footer-brand{display:flex;flex-direction:column;gap:1rem;max-width:32rem}
.footer-tagline{font-size:.92rem;line-height:1.65;color:#cbcdd2}
.footer-tagline strong{color:#fff;font-weight:700}

/* ant logo on dark — convert dark logo to pure white using filter */
.ant-mark{
  display:inline-flex;align-items:center;gap:.7rem;
  padding-top:.85rem;border-top:1px solid rgba(255,255,255,.08);
}
.ant-mark .ant-mark-img{
  height:1.6rem;width:auto;display:block;
  filter:brightness(0) invert(1);
  opacity:.85;transition:opacity .15s;
}
.ant-mark:hover .ant-mark-img{opacity:1}
.ant-mark .ant-mark-meta{font-size:.78rem;color:#9aa0a8;line-height:1.35}
.ant-mark .ant-mark-meta strong{display:block;color:#cbcdd2;font-weight:700;letter-spacing:.02em}

/* Address block (semantic, multi-line) */
.footer-address{font-style:normal;font-size:.88rem;line-height:1.7;color:#cbcdd2}
.footer-address strong{color:#fff;font-weight:700;letter-spacing:.01em}
.footer-address .row{display:block}

.footer-meta{font-size:.78rem;color:#9aa0a8;line-height:1.7;margin-top:.6rem}
.footer-meta .row{display:block}
.footer-meta strong{color:#cbcdd2;font-weight:700}

/* Footer contact links cluster */
.footer-contacts{display:flex;flex-direction:column;gap:.45rem;margin-top:.6rem;font-size:.88rem}
.footer-contacts a{
  display:inline-flex;align-items:center;gap:.55rem;color:#cbcdd2;font-weight:600;
  transition:color .15s;
}
.footer-contacts a:hover{color:#fff}
.footer-contacts a svg{width:1rem;height:1rem;color:var(--ant-400);flex-shrink:0}

/* ---------- Social icons ---------- */
.social-row{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.85rem}
.social-btn{
  display:inline-flex;align-items:center;justify-content:center;
  width:2.4rem;height:2.4rem;border-radius:.5rem;
  background:rgba(255,255,255,.06);color:#cbcdd2;border:1px solid rgba(255,255,255,.08);
  transition:background .15s,color .15s,border-color .15s,transform .15s;
}
.social-btn:hover{background:var(--ant-500);color:#fff;border-color:var(--ant-500);transform:translateY(-2px)}
.social-btn svg{width:1.05rem;height:1.05rem}

/* ---------- Footer bottom strip ---------- */
.footer-bottom{
  margin-top:3rem;padding:1.5rem 0;
  border-top:1px solid rgba(255,255,255,.08);
  font-size:.78rem;color:#888c93;
}
.footer-bottom .row{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1rem}
.footer-legal{display:flex;flex-wrap:wrap;gap:.35rem 1.25rem}
.footer-legal a{color:#888c93;transition:color .15s}
.footer-legal a:hover{color:#cbcdd2}

/* ---------- AI Search Suggestions (fytko-inspired) ---------- */
@keyframes aiPulse{0%,100%{opacity:.4;transform:scale(.85)}50%{opacity:1;transform:scale(1)}}
@keyframes aiShimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}
@keyframes aiSlideIn{0%{opacity:0;transform:translateY(6px)}100%{opacity:1;transform:translateY(0)}}
@keyframes aiSparkle{0%,100%{transform:scale(1) rotate(0)}25%{transform:scale(1.2) rotate(15deg)}50%{transform:scale(.95) rotate(-10deg)}75%{transform:scale(1.1) rotate(5deg)}}

.ai-suggest{
  position:absolute;top:calc(100% + .55rem);left:0;right:0;z-index:60;
  background:#fff;border:1px solid var(--border);border-radius:.875rem;
  box-shadow:var(--shadow-card);overflow:hidden;
  max-height:min(72vh,640px);overflow-y:auto;
}
.ai-suggest-head{
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
  padding:.75rem 1rem;background:linear-gradient(90deg,#fff7f9 0%,#fff 100%);
  border-bottom:1px solid var(--border);
}
.ai-suggest-head .ai-status{
  display:inline-flex;align-items:center;gap:.45rem;
  font-size:.72rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--ant-700);
}
.ai-suggest-head .ai-sparkle{
  display:inline-flex;align-items:center;justify-content:center;
  width:1.4rem;height:1.4rem;border-radius:.35rem;
  background:linear-gradient(135deg,var(--ant-500),var(--ant-700));
  color:#fff;
  animation:aiSparkle 3.5s ease-in-out infinite;
}
.ai-suggest-head .ai-sparkle svg{width:.85rem;height:.85rem}
.ai-suggest-head .ai-dots{display:inline-flex;gap:.2rem}
.ai-suggest-head .ai-dots .ai-dot{width:.4rem;height:.4rem;border-radius:9999px;background:var(--ant-500);animation:aiPulse 1.2s ease-in-out infinite}
.ai-suggest-head .ai-dots .ai-dot:nth-child(2){animation-delay:.15s}
.ai-suggest-head .ai-dots .ai-dot:nth-child(3){animation-delay:.3s}
.ai-suggest-head .ai-meta{font-size:.7rem;color:var(--ink-400);font-weight:600}
.ai-suggest-head .ai-meta .ai-kbd{
  display:inline-flex;align-items:center;justify-content:center;
  height:1.3rem;padding:0 .35rem;
  background:var(--ink-50);border:1px solid var(--border);border-bottom-width:2px;border-radius:.3rem;
  font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.65rem;color:var(--ink-700);font-weight:700;margin-left:.3rem;
}
.ai-shimmer{
  background:linear-gradient(90deg,var(--ink-600) 0%,var(--ant-500) 50%,var(--ink-600) 100%);
  background-size:200% 100%;animation:aiShimmer 2.2s linear infinite;
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
  font-weight:800;
}

.ai-suggest-section{padding:.55rem 0}
.ai-suggest-section + .ai-suggest-section{border-top:1px solid var(--border)}
.ai-suggest-section .ai-section-title{
  display:flex;align-items:center;gap:.45rem;
  padding:.4rem 1rem;font-size:.65rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-500);
}
.ai-suggest-section .ai-section-title svg{width:.85rem;height:.85rem;color:var(--ant-500)}

.ai-row{
  display:flex;align-items:center;gap:.85rem;
  padding:.55rem 1rem;cursor:pointer;
  transition:background .12s;animation:aiSlideIn .35s ease-out both;
}
.ai-row:hover,.ai-row.is-active{background:var(--ant-50)}
.ai-row .ai-thumb{
  width:2.4rem;height:2.4rem;background:var(--ink-50);border-radius:.4rem;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden;
}
.ai-row .ai-thumb img{max-width:85%;max-height:85%;object-fit:contain}
.ai-row .ai-thumb-icon{
  width:2.4rem;height:2.4rem;border-radius:.4rem;flex-shrink:0;
  background:var(--ant-50);color:var(--ant-600);
  display:flex;align-items:center;justify-content:center;
}
.ai-row .ai-thumb-icon svg{width:1.15rem;height:1.15rem}
.ai-row .ai-meta{flex:1;min-width:0}
.ai-row .ai-name{font-size:.88rem;font-weight:700;color:var(--ink-900);line-height:1.3}
.ai-row .ai-name mark{background:#fff7d6;color:inherit;padding:0 .15em;border-radius:.15em;font-weight:700}
.ai-row .ai-sub{font-size:.72rem;color:var(--ink-500);margin-top:.1rem}
.ai-row .ai-price{font-weight:800;color:var(--ant-600);font-size:.85rem;white-space:nowrap}
.ai-row .ai-arrow{color:var(--ink-300);transition:transform .15s,color .15s}
.ai-row:hover .ai-arrow{color:var(--ant-500);transform:translateX(2px)}

.ai-suggest-footer{
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
  padding:.6rem 1rem;background:var(--ink-50);border-top:1px solid var(--border);
  font-size:.72rem;color:var(--ink-500);
}
.ai-suggest-footer .ai-tip{display:inline-flex;align-items:center;gap:.4rem;font-weight:600}
.ai-suggest-footer .ai-go{display:inline-flex;align-items:center;gap:.35rem;color:var(--ant-600);font-weight:800}

/* ---------- Account / Login UI ---------- */
.auth-wrap{min-height:calc(100vh - 200px);display:flex;align-items:center;background:linear-gradient(180deg,#f7f8fa 0%,#fff 100%)}
.auth-card{
  width:100%;max-width:30rem;background:#fff;border:1px solid var(--border);
  border-radius:1rem;box-shadow:var(--shadow-card);padding:2rem;
}
.auth-card-wide{max-width:60rem}

.auth-h1{font-size:1.6rem;font-weight:900;color:var(--ink-900);letter-spacing:-.01em;line-height:1.15;margin-bottom:.4rem}
.auth-lead{color:var(--ink-500);font-size:.95rem;margin-bottom:1.4rem}
.auth-divider{display:flex;align-items:center;gap:.85rem;margin:1.2rem 0;color:var(--ink-400);font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em}
.auth-divider::before,.auth-divider::after{content:"";flex:1;height:1px;background:var(--border)}
.auth-link{color:var(--ant-600);font-weight:700}
.auth-link:hover{color:var(--ant-700);text-decoration:underline}

/* "Your sales rep" sticky card */
.rep-card{
  background:#fff;border:1px solid var(--border);border-radius:.875rem;
  padding:1.15rem;display:flex;flex-direction:column;gap:.85rem;
}
.rep-card .rep-head{display:flex;align-items:center;gap:.85rem}
.rep-card .rep-photo{width:3.5rem;height:3.5rem;border-radius:9999px;overflow:hidden;flex-shrink:0;background:var(--ink-100)}
.rep-card .rep-photo img{width:100%;height:100%;object-fit:cover}
.rep-card .rep-name{font-size:1rem;font-weight:800;color:var(--ink-900);line-height:1.15}
.rep-card .rep-role{font-size:.72rem;color:var(--ant-600);font-weight:700;text-transform:uppercase;letter-spacing:.06em;margin-top:.1rem}
.rep-card .rep-meta{font-size:.78rem;color:var(--ink-500);margin-top:.2rem}
.rep-card .rep-actions{display:flex;gap:.4rem}
.rep-card .rep-actions a{
  flex:1;display:inline-flex;align-items:center;justify-content:center;gap:.35rem;
  height:2.5rem;border-radius:.5rem;font-size:.8rem;font-weight:700;
  transition:all .15s;
}
.rep-card .rep-actions .rep-call{background:var(--ant-500);color:#fff}
.rep-card .rep-actions .rep-call:hover{background:var(--ant-600)}
.rep-card .rep-actions .rep-mail{background:#fff;color:var(--ink-800);border:1px solid var(--border)}
.rep-card .rep-actions .rep-mail:hover{border-color:var(--ant-500);color:var(--ant-600)}
.rep-card .rep-extra{
  display:flex;align-items:center;gap:.5rem;padding:.65rem;
  background:var(--ink-50);border-radius:.5rem;font-size:.72rem;color:var(--ink-600);
}
.rep-card .rep-extra svg{width:1rem;height:1rem;color:var(--ant-500);flex-shrink:0}

/* Account dashboard sidebar nav */
.dash-nav{display:flex;flex-direction:column;gap:.2rem}
.dash-nav a{
  display:flex;align-items:center;gap:.65rem;padding:.7rem .85rem;border-radius:.55rem;
  font-size:.88rem;font-weight:600;color:var(--ink-700);transition:background .12s,color .12s;
}
.dash-nav a:hover{background:var(--ink-50);color:var(--ink-900)}
.dash-nav a.is-active{background:var(--ant-50);color:var(--ant-700);font-weight:800}
.dash-nav a svg{width:1.1rem;height:1.1rem;color:var(--ink-400);flex-shrink:0}
.dash-nav a.is-active svg{color:var(--ant-500)}
.dash-nav .count{margin-left:auto;font-size:.72rem;background:var(--ink-100);color:var(--ink-600);font-weight:700;padding:.05rem .4rem;border-radius:.3rem}
.dash-nav a.is-active .count{background:var(--ant-500);color:#fff}

.stat-tile{
  background:#fff;border:1px solid var(--border);border-radius:.875rem;padding:1.1rem;
}
.stat-tile .stat-val{font-size:1.65rem;font-weight:900;color:var(--ink-900);letter-spacing:-.01em;line-height:1.1}
.stat-tile .stat-label{font-size:.75rem;font-weight:700;color:var(--ink-500);text-transform:uppercase;letter-spacing:.06em;margin-top:.25rem}
.stat-tile .stat-trend{font-size:.72rem;font-weight:700;margin-top:.5rem}
.stat-tile .stat-trend.up{color:var(--green-600)}
.stat-tile .stat-trend.down{color:#b91c1c}

/* ---------- Newsletter strip — distinct from footer ---------- */
.newsletter-strip{
  position:relative;
  background:linear-gradient(135deg, #1a1b1f 0%, #25272c 55%, #2c2e33 100%);
  border-top:3px solid var(--ant-500);
  color:#fff;
  overflow:hidden;
}
.newsletter-strip::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(60% 100% at 90% 50%, rgba(200,28,1,.12) 0%, rgba(200,28,1,0) 60%),
    radial-gradient(40% 80% at 10% 100%, rgba(255,195,0,.04) 0%, rgba(255,195,0,0) 60%);
}
.newsletter-strip > *{position:relative}
.newsletter-strip .news-title{font-size:1.45rem;font-weight:900;color:#fff;letter-spacing:-.01em;line-height:1.2}
.newsletter-strip .news-sub{color:#9aa0a8;font-size:.88rem;margin-top:.35rem}
.newsletter-strip .news-input{
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  color:#fff;
}
.newsletter-strip .news-input::placeholder{color:#6b7079}
.newsletter-strip .news-input:focus{
  background:rgba(255,255,255,.1);
  border-color:var(--ant-400);
  box-shadow:0 0 0 4px rgba(200,28,1,.18);
}

/* (Removed duplicate v3 .cat-tile img.ct-art rule — superseded by v5 block above ~line 720) */

/* =====================================================================
   v7 additions: Upsell features (demo mode) — toggleable via floating panel
   Set body class `.demo-disabled-{key}` to hide [data-feature="{key}"]
   ===================================================================== */

/* Toggle base — hidden when feature disabled */
[data-feature].feat-hidden{display:none !important}

/* ---------- UPSELL: container reset ---------- */
.upsell{
  position:relative;
  background:#fff;border:1px solid var(--border);border-radius:.75rem;
  padding:.95rem 1rem;margin-top:.7rem;
}
.upsell-head{
  display:flex;align-items:center;gap:.5rem;
  font-size:.72rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-500);
  margin-bottom:.6rem;
}
.upsell-head svg{width:1rem;height:1rem;color:var(--ant-500)}
.upsell-head .badge{background:var(--ant-500);color:#fff;padding:.15rem .4rem;border-radius:.3rem;font-size:.6rem;letter-spacing:.06em}

/* ---------- 1) Quantity discount ladder ---------- */
.qty-ladder{display:grid;grid-template-columns:repeat(4,1fr);gap:.4rem}
.qty-step{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:.55rem .4rem;border:1px solid var(--border);border-radius:.45rem;background:var(--ink-50);
  transition:all .15s;
}
.qty-step.is-current{background:#fff;border-color:var(--ant-500);box-shadow:0 0 0 3px rgba(200,28,1,.10)}
.qty-step .qty-amt{font-size:.7rem;font-weight:800;color:var(--ink-700);text-transform:uppercase;letter-spacing:.04em}
.qty-step .qty-save{
  margin-top:.15rem;font-size:.65rem;font-weight:800;letter-spacing:.04em;
  background:var(--ant-500);color:#fff;padding:.05rem .35rem;border-radius:.2rem;
}
.qty-step .qty-price{font-size:.82rem;font-weight:900;color:var(--ink-900);margin-top:.2rem;line-height:1}

/* ---------- 2) Quantity upgrade nudge ---------- */
.upsell-nudge{
  display:flex;align-items:center;gap:.65rem;
  background:linear-gradient(135deg,#fff7d6,#fde68a);
  border:1px solid #f5a800;border-left:4px solid #d97706;
  padding:.7rem .9rem;
}
.upsell-nudge .up-icon{
  flex-shrink:0;width:1.85rem;height:1.85rem;border-radius:9999px;
  background:#fff;color:#b45309;font-weight:900;
  display:inline-flex;align-items:center;justify-content:center;
  box-shadow:0 1px 3px rgba(0,0,0,.1);
}
.upsell-nudge .up-text{flex:1;font-size:.82rem;color:#7c2d12;line-height:1.3}
.upsell-nudge .up-text strong{color:#92400e;font-weight:800}
.upsell-nudge .up-action{
  flex-shrink:0;background:#92400e;color:#fff;border:0;cursor:pointer;
  padding:.4rem .75rem;border-radius:.4rem;font-size:.78rem;font-weight:800;
  transition:background .15s;
}
.upsell-nudge .up-action:hover{background:#7c2d12}

/* ---------- 3) Buy X get Y ---------- */
.upsell-bxgy{
  background:linear-gradient(135deg,#fff,#fff7f9);border-color:var(--ant-200);
  border-left:4px solid var(--ant-500);
}
.upsell-bxgy .bxgy-banner{
  display:flex;align-items:center;gap:.55rem;margin-bottom:.7rem;
  font-size:.92rem;color:var(--ink-900);line-height:1.3;
}
.upsell-bxgy .bxgy-banner .badge{
  flex-shrink:0;background:var(--ant-500);color:#fff;
  font-size:.62rem;font-weight:800;letter-spacing:.06em;
  padding:.18rem .5rem;border-radius:.3rem;
}
.upsell-bxgy .bxgy-banner s{color:var(--ink-400);font-weight:600}
.upsell-bxgy .bxgy-mini{
  display:flex;align-items:center;gap:.7rem;
  padding:.55rem;background:#fff;border:1px solid var(--ant-200);border-radius:.5rem;
}
.upsell-bxgy .bxgy-mini img{width:3rem;height:3rem;object-fit:contain;background:var(--ink-50);border-radius:.35rem;padding:.2rem}
.upsell-bxgy .bxgy-mini .name{font-weight:700;color:var(--ink-900);font-size:.85rem;line-height:1.2}
.upsell-bxgy .bxgy-mini .meta{font-size:.7rem;color:var(--ink-500);margin-top:.15rem}
.upsell-bxgy .bxgy-mini .gift-tag{
  margin-left:auto;background:#1a7f3e;color:#fff;
  padding:.25rem .5rem;border-radius:.3rem;font-weight:800;font-size:.7rem;letter-spacing:.04em;
}

/* ---------- 4) Frequently bought together ---------- */
.upsell-fbt{padding:1.1rem 1.15rem}
.upsell-fbt .fbt-row{display:flex;align-items:stretch;gap:.4rem;flex-wrap:wrap}
.upsell-fbt .fbt-item{
  flex:1 1 0;min-width:8rem;
  display:flex;flex-direction:column;align-items:center;gap:.35rem;
  background:#fff;border:1px solid var(--border);border-radius:.55rem;
  padding:.7rem .55rem;cursor:pointer;transition:all .15s;
  position:relative;
}
.upsell-fbt .fbt-item:hover{border-color:var(--ant-300)}
.upsell-fbt .fbt-item input[type=checkbox]{position:absolute;top:.4rem;left:.4rem;width:1rem;height:1rem;accent-color:var(--ant-500)}
.upsell-fbt .fbt-item.is-this{background:var(--ant-50);border-color:var(--ant-200)}
.upsell-fbt .fbt-item img{width:3.2rem;height:3.2rem;object-fit:contain;background:var(--ink-50);border-radius:.35rem;padding:.2rem}
.upsell-fbt .fbt-item .name{font-size:.75rem;font-weight:700;color:var(--ink-900);line-height:1.2;text-align:center}
.upsell-fbt .fbt-item .price{font-size:.78rem;font-weight:800;color:var(--ant-600)}
.upsell-fbt .fbt-plus{display:flex;align-items:center;font-size:1.1rem;font-weight:300;color:var(--ink-400);padding:0 .15rem;align-self:center}
.upsell-fbt .fbt-total{
  margin-top:.85rem;padding-top:.85rem;border-top:1px dashed var(--border);
  display:flex;flex-wrap:wrap;align-items:center;gap:.65rem;
}
.upsell-fbt .fbt-total .total-block{flex:1;min-width:8rem}
.upsell-fbt .fbt-total .total-amt{font-size:1.15rem;font-weight:900;color:var(--ink-900);line-height:1.1}
.upsell-fbt .fbt-total .total-amt s{color:var(--ink-400);font-weight:600;font-size:.85rem;margin-left:.4rem}
.upsell-fbt .fbt-total .fbt-save{font-size:.75rem;color:#15803d;font-weight:700;margin-top:.1rem}

/* ---------- 5) Free shipping progress ---------- */
.upsell-ship{padding:.85rem 1rem}
.upsell-ship .ship-bar{height:.5rem;background:var(--ink-100);border-radius:9999px;overflow:hidden;margin-bottom:.45rem}
.upsell-ship .ship-fill{height:100%;background:linear-gradient(90deg,var(--ant-500),#1a7f3e);border-radius:9999px;transition:width .4s;position:relative}
.upsell-ship .ship-fill::after{
  content:"";position:absolute;right:0;top:50%;transform:translate(50%,-50%);
  width:.85rem;height:.85rem;border-radius:9999px;background:#fff;border:2px solid var(--green-500);
}
.upsell-ship.is-done .ship-fill{background:var(--green-500)}
.upsell-ship.is-done .ship-fill::after{border-color:var(--green-500)}
.upsell-ship .ship-text{font-size:.82rem;color:var(--ink-700);display:flex;align-items:center;gap:.35rem}
.upsell-ship .ship-text strong{color:var(--ink-900);font-weight:800}
.upsell-ship.is-done .ship-text strong{color:#15803d}
.upsell-ship .ship-text svg{width:1rem;height:1rem;color:var(--green-500)}

/* ---------- 6) Service add-ons ---------- */
.upsell-service{padding:.85rem 1rem}
.upsell-service > label{
  display:flex;align-items:center;gap:.7rem;
  padding:.6rem .65rem;border:1px solid var(--border);border-radius:.5rem;
  cursor:pointer;transition:border-color .15s,background .15s;
  margin-top:.4rem;
}
.upsell-service > label:first-of-type{margin-top:0}
.upsell-service > label:hover{border-color:var(--ant-300);background:#fff7f9}
.upsell-service > label input{flex-shrink:0;width:1rem;height:1rem;accent-color:var(--ant-500)}
.upsell-service > label > div{flex:1;min-width:0}
.upsell-service > label strong{display:block;font-size:.85rem;font-weight:800;color:var(--ink-900);line-height:1.2}
.upsell-service > label span.svc-sub{display:block;font-size:.72rem;color:var(--ink-500);margin-top:.15rem;line-height:1.3}
.upsell-service > label span.svc-price{flex-shrink:0;font-size:.82rem;font-weight:900;color:var(--ant-600);white-space:nowrap}
.upsell-service > label span.svc-price.is-free{color:#1a7f3e}

/* ---------- 7) B2B tier ladder ---------- */
.upsell-b2b{
  background:linear-gradient(135deg,#0b0b0e,#1a1b1f);color:#fff;border:0;
  padding:1rem 1.1rem;
}
.upsell-b2b .b2b-head{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:#cbcdd2;margin-bottom:.6rem}
.upsell-b2b .b2b-head .badge{background:var(--ant-500);color:#fff;padding:.15rem .5rem;border-radius:.3rem;font-size:.6rem;font-weight:800;letter-spacing:.06em}
.upsell-b2b .b2b-head strong{color:#ffc300;font-weight:900;letter-spacing:.04em}
.upsell-b2b .b2b-bar{height:.45rem;background:#34363c;border-radius:9999px;overflow:hidden;margin-bottom:.4rem}
.upsell-b2b .b2b-fill{height:100%;background:linear-gradient(90deg,#ffc300,#f5a800);border-radius:9999px;transition:width .4s}
.upsell-b2b .b2b-meta{font-size:.75rem;color:#9aa0a8}
.upsell-b2b .b2b-meta strong{color:#ffc300;font-weight:800}

/* ---------- 8) Gift threshold ---------- */
.upsell-gift{
  background:linear-gradient(135deg,#fff,#ecfdf3);border-color:#6fe095;
  border-left:4px solid #1a7f3e;
  display:flex;align-items:center;gap:.7rem;padding:.8rem 1rem;
}
.upsell-gift .gift-ico{
  flex-shrink:0;width:2.4rem;height:2.4rem;border-radius:.5rem;background:#1a7f3e;color:#fff;
  display:inline-flex;align-items:center;justify-content:center;
}
.upsell-gift .gift-ico svg{width:1.2rem;height:1.2rem}
.upsell-gift .gift-text{flex:1;font-size:.82rem;color:var(--ink-700);line-height:1.3}
.upsell-gift .gift-text strong{color:var(--ink-900);font-weight:800;display:block}

/* ---------- DEMO PANEL (floating settings) ---------- */
.demo-panel{
  position:fixed;right:1rem;bottom:1rem;z-index:80;
  width:21rem;max-width:calc(100vw - 2rem);
  background:var(--ink-900);color:#fff;
  border-radius:1rem;border:1px solid #1f2126;
  box-shadow:0 18px 48px -12px rgba(0,0,0,.55),0 4px 12px -4px rgba(0,0,0,.35);
  transition:transform .3s cubic-bezier(.2,.8,.2,1);
  font-family:'Inter','system-ui',sans-serif;
}
.demo-panel:not(.open){transform:translateY(calc(100% - 3rem))}
.demo-toggle{
  width:100%;display:flex;align-items:center;justify-content:space-between;gap:.6rem;
  padding:.85rem 1rem;background:transparent;color:#fff;border:0;cursor:pointer;
  font-weight:800;font-size:.85rem;letter-spacing:.02em;text-align:left;
}
.demo-toggle .demo-toggle-l{display:flex;align-items:center;gap:.55rem}
.demo-toggle .demo-spark{
  display:inline-flex;align-items:center;justify-content:center;
  width:1.5rem;height:1.5rem;border-radius:.4rem;
  background:linear-gradient(135deg,var(--ant-500),var(--ant-700));
  color:#fff;
}
.demo-toggle .demo-spark svg{width:.85rem;height:.85rem}
.demo-toggle .demo-meta{font-size:.65rem;color:#9aa0a8;font-weight:700;letter-spacing:.08em;text-transform:uppercase}
.demo-toggle .demo-chev{
  width:1rem;height:1rem;color:#9aa0a8;transition:transform .2s;
}
.demo-panel.open .demo-toggle .demo-chev{transform:rotate(180deg)}

.demo-body{
  padding:.4rem 1rem 1rem;border-top:1px solid #1f2126;
  max-height:60vh;overflow-y:auto;
}
.demo-body .demo-row{
  display:flex;align-items:center;gap:.6rem;
  padding:.5rem 0;border-bottom:1px solid #1f2126;
  cursor:pointer;
}
.demo-body .demo-row:last-of-type{border-bottom:0}
.demo-body .demo-row input{
  appearance:none;width:2.4rem;height:1.3rem;background:#34363c;border-radius:9999px;
  position:relative;cursor:pointer;transition:background .2s;flex-shrink:0;
}
.demo-body .demo-row input::after{
  content:"";position:absolute;top:.15rem;left:.15rem;
  width:1rem;height:1rem;background:#fff;border-radius:9999px;transition:transform .2s;
}
.demo-body .demo-row input:checked{background:var(--ant-500)}
.demo-body .demo-row input:checked::after{transform:translateX(1.1rem)}
.demo-body .demo-row .demo-label{flex:1;min-width:0}
.demo-body .demo-row .demo-label strong{display:block;font-size:.82rem;font-weight:700;color:#fff;line-height:1.2}
.demo-body .demo-row .demo-label span{display:block;font-size:.7rem;color:#888c93;margin-top:.1rem}
.demo-body .demo-footer{
  display:flex;align-items:center;justify-content:space-between;
  margin-top:.65rem;padding-top:.65rem;border-top:1px solid #1f2126;
  font-size:.72rem;color:#888c93;
}
.demo-body .demo-reset{
  background:#1f2126;color:#cbcdd2;border:0;cursor:pointer;
  padding:.4rem .65rem;border-radius:.35rem;font-weight:700;font-size:.72rem;
  transition:background .15s,color .15s;
}
.demo-body .demo-reset:hover{background:var(--ant-500);color:#fff}

/* =====================================================================
   v8: Thank-you / Order confirmation page
   ===================================================================== */

/* Hero with animated checkmark + confetti */
.ty-hero{
  position:relative;overflow:hidden;
  background:linear-gradient(180deg,#ecfdf3 0%,#ffffff 65%);
  border-bottom:1px solid var(--border);
}
.ty-hero::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background-image:
    radial-gradient(circle at 8% 10%, rgba(200,28,1,.10) 0%, transparent 4%),
    radial-gradient(circle at 88% 18%, rgba(255,195,0,.18) 0%, transparent 4%),
    radial-gradient(circle at 15% 78%, rgba(26,127,62,.18) 0%, transparent 4%),
    radial-gradient(circle at 92% 88%, rgba(200,28,1,.14) 0%, transparent 4%),
    radial-gradient(circle at 50% 5%, rgba(255,195,0,.12) 0%, transparent 3%),
    radial-gradient(circle at 32% 18%, rgba(26,127,62,.10) 0%, transparent 3%),
    radial-gradient(circle at 70% 72%, rgba(200,28,1,.10) 0%, transparent 3%);
}

@keyframes tickPop{0%{transform:scale(0) rotate(-30deg);opacity:0}60%{transform:scale(1.15) rotate(5deg)}100%{transform:scale(1) rotate(0);opacity:1}}
@keyframes tickRing{0%{transform:scale(.4);opacity:.7}80%{opacity:.05}100%{transform:scale(2.4);opacity:0}}
@keyframes confettiFall{
  0%{transform:translateY(-20px) rotate(0);opacity:0}
  10%{opacity:1}
  100%{transform:translateY(80px) rotate(180deg);opacity:0}
}

.ty-tick{
  position:relative;width:5rem;height:5rem;margin:0 auto 1rem;
  background:#1a7f3e;color:#fff;border-radius:9999px;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 12px 32px -8px rgba(26,127,62,.55),0 4px 12px -4px rgba(26,127,62,.30);
  animation:tickPop .55s cubic-bezier(.2,.8,.2,1) both;
}
.ty-tick::after{
  content:"";position:absolute;inset:-4px;border-radius:9999px;
  border:3px solid rgba(26,127,62,.45);
  animation:tickRing 1.4s ease-out infinite;
}
.ty-tick svg{width:2.5rem;height:2.5rem}

.ty-eyebrow{
  display:inline-flex;align-items:center;gap:.5rem;
  font-size:.72rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--green-600);
  background:#d1fadf;border:1px solid #6fe095;
  padding:.3rem .7rem;border-radius:9999px;
}
.ty-h1{font-size:clamp(1.8rem,4vw,2.8rem);font-weight:900;letter-spacing:-.02em;color:var(--ink-900);line-height:1.05}
.ty-h1 strong{color:var(--green-600)}
.ty-lead{font-size:1.05rem;color:var(--ink-600);max-width:36rem;line-height:1.5}

/* Confetti pieces */
.ty-confetti{position:absolute;width:.5rem;height:.75rem;opacity:0;animation:confettiFall 2s ease-out forwards}
.ty-confetti:nth-child(1){left:10%;top:18%;background:var(--ant-500);animation-delay:.3s;animation-duration:1.8s}
.ty-confetti:nth-child(2){left:25%;top:14%;background:var(--gold-400);animation-delay:.5s;animation-duration:2.2s;transform:rotate(35deg)}
.ty-confetti:nth-child(3){left:42%;top:16%;background:var(--green-500);animation-delay:.4s;animation-duration:2s}
.ty-confetti:nth-child(4){left:58%;top:12%;background:var(--ant-500);animation-delay:.7s;animation-duration:2.4s;transform:rotate(-20deg)}
.ty-confetti:nth-child(5){left:73%;top:15%;background:var(--gold-400);animation-delay:.55s;animation-duration:2.1s}
.ty-confetti:nth-child(6){left:88%;top:20%;background:var(--green-500);animation-delay:.65s;animation-duration:1.9s;transform:rotate(45deg)}

/* Info bar — 4 tile summary below hero */
.ty-info-bar{
  display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--border);
  border:1px solid var(--border);border-radius:.875rem;overflow:hidden;
}
@media(min-width:768px){.ty-info-bar{grid-template-columns:repeat(4,1fr)}}
.ty-info-tile{background:#fff;padding:1rem 1.1rem;display:flex;align-items:center;gap:.85rem}
.ty-info-tile .ico{
  width:2.5rem;height:2.5rem;border-radius:.5rem;flex-shrink:0;
  background:var(--ant-50);color:var(--ant-600);
  display:inline-flex;align-items:center;justify-content:center;
}
.ty-info-tile .ico svg{width:1.2rem;height:1.2rem}
.ty-info-tile .label{font-size:.7rem;font-weight:700;color:var(--ink-500);text-transform:uppercase;letter-spacing:.06em;line-height:1.2}
.ty-info-tile .value{font-size:.92rem;font-weight:800;color:var(--ink-900);line-height:1.2;margin-top:.15rem;word-break:break-word}
.ty-info-tile .value.mono{font-family:ui-monospace,SFMono-Regular,Menlo,monospace}
.ty-info-tile a.value{color:var(--ant-600)}
.ty-info-tile a.value:hover{text-decoration:underline}

/* Timeline (vertical for cart-style horizontal — adapted to thank-you) */
.ty-timeline{
  display:grid;grid-template-columns:1fr;gap:0;
  background:#fff;border:1px solid var(--border);border-radius:.875rem;overflow:hidden;
}
.ty-timeline .ty-step{
  position:relative;display:flex;align-items:flex-start;gap:.85rem;
  padding:1rem 1.1rem;
  border-bottom:1px solid var(--border);
}
.ty-timeline .ty-step:last-child{border-bottom:none}
.ty-timeline .ty-step .ty-num{
  flex-shrink:0;width:2rem;height:2rem;border-radius:9999px;
  display:inline-flex;align-items:center;justify-content:center;
  font-weight:900;font-size:.85rem;background:var(--ink-100);color:var(--ink-500);
}
.ty-timeline .ty-step.is-done .ty-num{background:var(--green-500);color:#fff}
.ty-timeline .ty-step.is-active .ty-num{background:var(--ant-500);color:#fff;box-shadow:0 0 0 4px rgba(200,28,1,.18)}
.ty-timeline .ty-step .ty-meta{flex:1;min-width:0}
.ty-timeline .ty-step .ty-meta strong{display:block;font-size:.95rem;font-weight:800;color:var(--ink-900)}
.ty-timeline .ty-step .ty-meta .ty-when{font-size:.78rem;color:var(--ink-500);margin-top:.1rem}
.ty-timeline .ty-step .ty-meta .ty-desc{font-size:.82rem;color:var(--ink-600);margin-top:.25rem;line-height:1.4}
.ty-timeline .ty-step .ty-tag{
  flex-shrink:0;font-size:.65rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;
  padding:.2rem .5rem;border-radius:.3rem;align-self:center;
}
.ty-timeline .ty-step.is-done .ty-tag{background:#d1fadf;color:#0a3219}
.ty-timeline .ty-step.is-active .ty-tag{background:var(--ant-500);color:#fff}
.ty-timeline .ty-step.is-pending .ty-tag{background:var(--ink-100);color:var(--ink-500)}

/* Add-to-order grace period banner */
.ty-grace{
  position:relative;
  background:linear-gradient(135deg,#fff7d6,#fde68a);
  border:1px solid #f5a800;border-left:4px solid #d97706;border-radius:.75rem;
  padding:1rem 1.15rem;
}
.ty-grace-head{display:flex;align-items:center;gap:.55rem;font-weight:900;color:#92400e;font-size:1.02rem}
.ty-grace-head svg{width:1.2rem;height:1.2rem}
.ty-grace-sub{font-size:.85rem;color:#7c2d12;margin-top:.25rem;line-height:1.4}
.ty-grace-countdown{
  display:inline-flex;align-items:center;gap:.4rem;
  margin-top:.65rem;padding:.35rem .65rem;background:#fff;border-radius:.4rem;
  font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.85rem;font-weight:800;color:#92400e;
  box-shadow:0 1px 3px rgba(0,0,0,.06);
}
.ty-grace-countdown::before{
  content:"";width:.5rem;height:.5rem;background:#d97706;border-radius:9999px;
  animation:tickRing 1.4s ease-out infinite;
}

/* Document download cards */
.ty-doc-grid{display:grid;grid-template-columns:1fr;gap:.55rem}
@media(min-width:640px){.ty-doc-grid{grid-template-columns:repeat(2,1fr)}}
.ty-doc{
  display:flex;align-items:center;gap:.75rem;
  padding:.7rem .85rem;background:#fff;border:1px solid var(--border);border-radius:.55rem;
  transition:border-color .15s,box-shadow .15s;
}
.ty-doc:hover{border-color:var(--ant-300);box-shadow:var(--shadow-soft)}
.ty-doc .ty-doc-ico{
  flex-shrink:0;width:2.4rem;height:2.4rem;border-radius:.4rem;
  background:#fff7f9;color:var(--ant-600);
  display:inline-flex;align-items:center;justify-content:center;
}
.ty-doc .ty-doc-ico svg{width:1.15rem;height:1.15rem}
.ty-doc .ty-doc-meta{flex:1;min-width:0}
.ty-doc .ty-doc-name{font-weight:700;color:var(--ink-900);font-size:.85rem;line-height:1.2}
.ty-doc .ty-doc-size{font-size:.72rem;color:var(--ink-500);margin-top:.1rem}
.ty-doc .ty-doc-arrow{color:var(--ink-300)}
.ty-doc:hover .ty-doc-arrow{color:var(--ant-500)}

/* Referral banner */
.ty-referral{
  background:linear-gradient(135deg,#0b0b0e 0%,#1a1b1f 60%,#25272c 100%);
  color:#fff;border-radius:1rem;padding:1.5rem;position:relative;overflow:hidden;
}
.ty-referral::before{
  content:"";position:absolute;width:40%;height:140%;right:-10%;top:-20%;
  background:radial-gradient(closest-side,rgba(200,28,1,.35) 0%,transparent 70%);
  pointer-events:none;
}
.ty-referral .ty-ref-eyebrow{
  font-size:.7rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--ant-400);
}
.ty-referral h3{font-size:1.4rem;font-weight:900;color:#fff;margin-top:.4rem;line-height:1.15}
.ty-referral p{color:#cbcdd2;font-size:.9rem;margin-top:.5rem;line-height:1.45}
.ty-referral .ty-ref-code{
  display:inline-flex;align-items:center;gap:.6rem;
  padding:.55rem .85rem;margin-top:.85rem;
  background:#fff;color:var(--ink-900);border-radius:.5rem;
  font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-weight:800;letter-spacing:.06em;
}
.ty-referral .ty-ref-code button{
  background:none;border:0;color:var(--ant-600);font-weight:800;font-size:.78rem;cursor:pointer;
  padding:.1rem .4rem;border-left:1px solid var(--border);text-transform:uppercase;letter-spacing:.06em;
}

/* Quick actions row */
.ty-actions{display:flex;flex-wrap:wrap;gap:.5rem}
.ty-actions a, .ty-actions button{
  flex:1 1 calc(50% - .25rem);min-width:8rem;
  display:inline-flex;align-items:center;justify-content:center;gap:.4rem;
}

/* Print-only / hide-on-print helpers */
@media print{
  .topbar, header.site-header, .site-footer, .demo-panel, .ty-grace, .ty-referral, .ty-actions, .ty-print-hide{display:none !important}
  .ty-hero{background:#fff;border:0;padding:1rem 0}
  .ty-hero::before{display:none}
  .ty-tick{box-shadow:none}
  .ty-tick::after{display:none}
  body{background:#fff;color:#000;font-size:11pt}
  .container-x{max-width:none;padding:0 1cm}
  a{color:#000;text-decoration:none}
}

/* =====================================================================
   v9: Hero USP pill row + Dôverujú nám marquee
   ===================================================================== */
.hero-usp{
  display:flex;flex-wrap:wrap;gap:.45rem;list-style:none;margin:0;padding:0;
}
.hero-usp li{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.45rem .8rem;background:#fff;border:1px solid var(--border);
  border-radius:9999px;font-size:.78rem;color:var(--ink-700);
  white-space:nowrap;line-height:1;
  transition:border-color .15s,box-shadow .15s;
}
.hero-usp li:hover{border-color:var(--ant-300);box-shadow:0 1px 4px rgba(11,11,14,.04)}
.hero-usp li svg{width:1rem;height:1rem;color:var(--ant-500);flex-shrink:0}
.hero-usp li strong{color:var(--ink-900);font-weight:800}

/* Marquee for trust strip */
@keyframes mqScroll{0%{transform:translateX(0)}100%{transform:translateX(-100%)}}
.marquee-trust{
  flex:1;min-width:0;display:flex;overflow:hidden;
  -webkit-mask-image:linear-gradient(90deg,transparent 0,#000 5%,#000 95%,transparent 100%);
          mask-image:linear-gradient(90deg,transparent 0,#000 5%,#000 95%,transparent 100%);
}
.marquee-trust .mq-track{
  display:flex;align-items:center;gap:1.5rem;flex-shrink:0;
  animation:mqScroll 35s linear infinite;
  padding-right:1.5rem;
}
.marquee-trust:hover .mq-track{animation-play-state:paused}
.marquee-trust .mq-track > span{
  font-size:.78rem;font-weight:800;letter-spacing:.04em;color:var(--ink-700);
  white-space:nowrap;text-transform:uppercase;
}
.marquee-trust .mq-track > span.mq-dot{
  width:.3rem;height:.3rem;border-radius:9999px;background:var(--ant-500);opacity:.6;
}

/* =====================================================================
   v10: Event landing page (vystava-*) — Aquatherm/MSV/ISH template
   ===================================================================== */

/* Hero — dark cinematic with event branding + optional video bg */
.evt-hero{
  position:relative;overflow:hidden;
  background:linear-gradient(135deg,#0b0b0e 0%,#1a1b1f 50%,#0b0b0e 100%);
  color:#fff;border-bottom:3px solid var(--ant-500);
  isolation:isolate;
}
.evt-hero-video{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;object-position:center;
  z-index:0;pointer-events:none;
  opacity:.55;
  filter:saturate(.85) contrast(1.05);
}
/* Dark overlay above video, below content — text readability */
.evt-hero-overlay{
  position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    linear-gradient(180deg,rgba(11,11,14,.4) 0%,rgba(11,11,14,.6) 60%,rgba(11,11,14,.82) 100%),
    linear-gradient(135deg,rgba(11,11,14,.5) 0%,transparent 40%,rgba(200,28,1,.10) 100%);
}
/* Respect reduced-motion preference */
@media (prefers-reduced-motion:reduce){.evt-hero-video{display:none}}
/* On small screens skip video — save bandwidth */
@media (max-width:640px){.evt-hero-video{display:none}}
.evt-hero::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:32px 32px;
  -webkit-mask-image:radial-gradient(ellipse at center,#000 30%,transparent 80%);
          mask-image:radial-gradient(ellipse at center,#000 30%,transparent 80%);
}
.evt-hero::after{
  content:"";position:absolute;
  width:60%;height:120%;right:-15%;top:-10%;
  background:radial-gradient(closest-side,rgba(200,28,1,.32) 0%,transparent 70%);
  pointer-events:none;
}
.evt-eyebrow{
  display:inline-flex;align-items:center;gap:.55rem;
  font-size:.72rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--ant-400);
  background:rgba(200,28,1,.15);border:1px solid rgba(200,28,1,.35);
  padding:.4rem .85rem;border-radius:9999px;
}
.evt-eyebrow .dot{width:.45rem;height:.45rem;background:var(--ant-500);border-radius:9999px;animation:tickRing 1.4s ease-out infinite}
.evt-h1{font-size:clamp(2.4rem,5.5vw,4.5rem);font-weight:900;letter-spacing:-.025em;line-height:.95;color:#fff}
.evt-h1 em{color:#ffc300;font-style:normal}
.evt-lead{font-size:1.1rem;color:#cbcdd2;max-width:38rem;line-height:1.5}

.evt-countdown{
  display:inline-flex;align-items:center;gap:.65rem;flex-wrap:wrap;
  padding:.85rem 1.1rem;background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.12);border-radius:.75rem;
  font-family:ui-monospace,SFMono-Regular,Menlo,monospace;
}
.evt-countdown .cd-unit{display:inline-flex;flex-direction:column;align-items:center;min-width:3rem}
.evt-countdown .cd-num{font-size:1.4rem;font-weight:900;color:#fff;letter-spacing:-.03em;line-height:1}
.evt-countdown .cd-lbl{font-size:.6rem;color:#9aa0a8;text-transform:uppercase;letter-spacing:.12em;margin-top:.2rem;font-family:'Inter',sans-serif}
.evt-countdown .cd-sep{color:#34363c;font-size:1.2rem}

/* Stand badge */
.evt-stand{
  display:inline-flex;align-items:center;gap:.7rem;
  padding:.85rem 1.1rem;background:var(--ant-500);color:#fff;border-radius:.75rem;
  box-shadow:0 12px 28px -8px rgba(200,28,1,.55);
}
.evt-stand .label{font-size:.65rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.7)}
.evt-stand .value{font-size:1.15rem;font-weight:900;line-height:1;margin-top:.15rem}
.evt-stand svg{width:1.4rem;height:1.4rem;flex-shrink:0}

/* Day schedule tabs */
.evt-day-tabs{
  display:flex;gap:.3rem;border-bottom:2px solid var(--border);margin-bottom:1rem;overflow-x:auto;
}
.evt-day-tab{
  flex:1;min-width:7.5rem;padding:.8rem 1rem;background:transparent;border:0;cursor:pointer;
  font-weight:800;color:var(--ink-500);text-align:center;line-height:1.2;
  border-bottom:3px solid transparent;margin-bottom:-2px;
  transition:all .15s;font-size:.85rem;white-space:nowrap;
}
.evt-day-tab .d-day{font-size:.72rem;font-weight:700;color:var(--ink-400);text-transform:uppercase;letter-spacing:.06em}
.evt-day-tab .d-date{font-size:1rem;font-weight:900;color:var(--ink-900);margin-top:.15rem}
.evt-day-tab:hover{color:var(--ant-600)}
.evt-day-tab.is-active{border-bottom-color:var(--ant-500);color:var(--ant-600)}
.evt-day-tab.is-active .d-day{color:var(--ant-500)}

.evt-schedule{display:none;flex-direction:column;gap:.4rem}
.evt-schedule.is-active{display:flex}
.evt-slot{
  display:grid;grid-template-columns:5rem 1fr auto;gap:1rem;align-items:center;
  padding:.85rem 1.1rem;background:#fff;border:1px solid var(--border);border-radius:.55rem;
  transition:border-color .15s,transform .15s;
}
.evt-slot:hover{border-color:var(--ant-300);transform:translateX(2px)}
.evt-slot .slot-time{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-weight:800;color:var(--ant-600);font-size:.95rem}
.evt-slot .slot-meta strong{display:block;font-weight:800;color:var(--ink-900);font-size:.92rem;line-height:1.2}
.evt-slot .slot-meta .slot-sub{font-size:.75rem;color:var(--ink-500);margin-top:.15rem;line-height:1.3}
.evt-slot .slot-presenter{font-size:.72rem;color:var(--ink-400);font-weight:600;text-align:right;flex-shrink:0}
.evt-slot.is-live{border-color:var(--ant-500);background:#fff7f9}
.evt-slot.is-live .slot-time{color:var(--ant-500)}
.evt-slot.is-live::after{
  content:"NAŽIVO";position:absolute;top:.5rem;right:.5rem;
  background:var(--ant-500);color:#fff;font-size:.6rem;font-weight:800;letter-spacing:.06em;
  padding:.15rem .4rem;border-radius:.25rem;
}

/* Showcase products (event special) */
.evt-showcase{display:grid;grid-template-columns:repeat(auto-fill,minmax(15rem,1fr));gap:1rem}
.evt-show-card{
  position:relative;background:#fff;border:1px solid var(--border);border-radius:.75rem;overflow:hidden;
  transition:border-color .2s,transform .25s,box-shadow .25s;
}
.evt-show-card:hover{border-color:var(--ant-500);transform:translateY(-3px);box-shadow:var(--shadow-hover)}
.evt-show-card .esc-media{aspect-ratio:4/3;background:linear-gradient(135deg,#fff,#f7f8fa);display:flex;align-items:center;justify-content:center;overflow:hidden;border-bottom:1px solid var(--border)}
.evt-show-card .esc-media img{max-width:80%;max-height:80%;object-fit:contain;transition:transform .4s}
.evt-show-card:hover .esc-media img{transform:scale(1.06)}
.evt-show-card .esc-tag{
  position:absolute;top:.7rem;left:.7rem;z-index:2;
  display:inline-flex;align-items:center;gap:.3rem;
  background:var(--ant-500);color:#fff;
  font-size:.62rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;
  padding:.25rem .55rem;border-radius:.3rem;
}
.evt-show-card .esc-tag.is-new{background:#ffc300;color:#1a1b1f}
.evt-show-card .esc-tag.is-live{background:#1a7f3e;color:#fff}
.evt-show-card .esc-body{padding:.85rem 1rem}
.evt-show-card .esc-name{font-weight:800;color:var(--ink-900);font-size:.92rem;line-height:1.25}
.evt-show-card .esc-sub{font-size:.72rem;color:var(--ink-500);margin-top:.2rem;line-height:1.3}
.evt-show-card .esc-price-row{display:flex;align-items:end;justify-content:space-between;margin-top:.55rem;padding-top:.55rem;border-top:1px dashed var(--border)}
.evt-show-card .esc-price-row .now{font-weight:900;color:var(--ant-600);font-size:1.05rem;line-height:1}
.evt-show-card .esc-price-row .was{font-size:.78rem;color:var(--ink-400);text-decoration:line-through;margin-left:.4rem}
.evt-show-card .esc-price-row .save{font-size:.65rem;background:var(--ant-500);color:#fff;padding:.15rem .35rem;border-radius:.25rem;font-weight:800;letter-spacing:.04em}

/* Form spotlight */
.evt-form-card{
  background:linear-gradient(180deg,#fff 0%,#fafbfd 100%);
  border:2px solid var(--ant-200);border-radius:1.25rem;
  padding:2rem;position:relative;overflow:hidden;
}
.evt-form-card::before{
  content:"";position:absolute;width:30%;height:140%;right:-10%;top:-20%;
  background:radial-gradient(closest-side,rgba(255,195,0,.12) 0%,transparent 70%);
  pointer-events:none;
}

/* Past editions gallery */
.evt-gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem}
@media(min-width:768px){.evt-gallery{grid-template-columns:repeat(4,1fr)}}
.evt-gallery img{
  width:100%;aspect-ratio:1/1;object-fit:cover;border-radius:.5rem;
  transition:transform .35s,filter .25s;cursor:pointer;
}
.evt-gallery img:hover{transform:scale(1.03);filter:saturate(1.1)}

/* Map wrapper */
.evt-map-wrap{position:relative;border-radius:1rem;overflow:hidden;border:1px solid var(--border);aspect-ratio:16/10;background:#f7f8fa}
.evt-map-wrap img{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;display:block}
.evt-map-pin{
  position:absolute;top:72%;left:52%;
  transform:translate(-50%,-50%);
  width:3rem;height:3rem;background:var(--ant-500);color:#fff;border-radius:9999px;
  display:inline-flex;align-items:center;justify-content:center;
  box-shadow:0 8px 24px -4px rgba(200,28,1,.55),0 0 0 4px rgba(255,255,255,.85);
  animation:tickPop .6s cubic-bezier(.2,.8,.2,1) both;
  z-index:2;
}
.evt-map-pin::after{
  content:"";position:absolute;inset:-6px;border:3px solid rgba(200,28,1,.5);border-radius:9999px;
  animation:tickRing 1.6s ease-out infinite;
}
.evt-map-pin svg{width:1.4rem;height:1.4rem}
.evt-map-cap{
  position:absolute;top:72%;left:52%;
  transform:translate(-50%,-260%);
  background:#fff;padding:.45rem .8rem;border-radius:.45rem;border:1px solid var(--border);
  font-size:.78rem;font-weight:800;color:var(--ant-600);white-space:nowrap;
  box-shadow:0 6px 16px -2px rgba(0,0,0,.18);z-index:2;
}
.evt-map-cap::after{
  content:"";position:absolute;bottom:-5px;left:50%;transform:translateX(-50%) rotate(45deg);
  width:8px;height:8px;background:#fff;border-right:1px solid var(--border);border-bottom:1px solid var(--border);
}

/* FAQ accordion */
.evt-faq details{
  border:1px solid var(--border);border-radius:.55rem;padding:0;background:#fff;
  margin-bottom:.55rem;transition:border-color .15s;
}
.evt-faq details[open]{border-color:var(--ant-300)}
.evt-faq summary{
  list-style:none;cursor:pointer;padding:1rem 1.1rem;
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
  font-weight:800;color:var(--ink-900);font-size:.92rem;line-height:1.3;
}
.evt-faq summary::-webkit-details-marker{display:none}
.evt-faq summary::after{
  content:"+";font-weight:900;color:var(--ant-500);font-size:1.4rem;line-height:1;
  width:1.5rem;height:1.5rem;display:inline-flex;align-items:center;justify-content:center;
  transition:transform .2s;
}
.evt-faq details[open] summary::after{transform:rotate(45deg)}
.evt-faq details p{margin:0 1.1rem 1rem;font-size:.88rem;color:var(--ink-600);line-height:1.55}

/* Team thumbnails at booth */
.evt-team{display:grid;grid-template-columns:repeat(2,1fr);gap:.85rem}
@media(min-width:640px){.evt-team{grid-template-columns:repeat(4,1fr)}}
.evt-team-card{
  display:flex;flex-direction:column;align-items:center;text-align:center;
  background:#fff;border:1px solid var(--border);border-radius:.75rem;padding:1rem .85rem;
  transition:border-color .15s,transform .2s;
}
.evt-team-card:hover{border-color:var(--ant-300);transform:translateY(-2px)}
.evt-team-card img{width:5rem;height:5rem;border-radius:9999px;object-fit:cover;border:3px solid var(--ant-100)}
.evt-team-card .et-name{font-weight:800;color:var(--ink-900);font-size:.9rem;margin-top:.55rem}
.evt-team-card .et-role{font-size:.72rem;color:var(--ink-500);margin-top:.15rem;line-height:1.3}
.evt-team-card .et-badge{
  margin-top:.5rem;font-size:.62rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;
  background:var(--ant-50);color:var(--ant-600);padding:.2rem .45rem;border-radius:.25rem;
}

/* Pulsing dot in topbar event link */
@keyframes topbarPulse{0%{box-shadow:0 0 0 0 rgba(200,28,1,.7)}70%{box-shadow:0 0 0 6px rgba(200,28,1,0)}100%{box-shadow:0 0 0 0 rgba(200,28,1,0)}}
.topbar-pulse{animation:topbarPulse 1.6s ease-out infinite}
