/* ============================================================
   Subastas · каталог — стили на основе subastas-design-system
   (Direction B "Confianza"). Токены + kit + компоненты в одном файле.
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Manrope:wght@400;500;600;700;800&display=swap');

/* ---------- Tokens: color ---------- */
:root {
  --c-white:#FFFFFF; --c-ink-50:#F5F7FA; --c-ink-100:#EEF2F7; --c-ink-150:#E8EDF3;
  --c-ink-200:#E1E7EF; --c-ink-300:#C7D0DC; --c-ink-400:#97A3B4; --c-ink-500:#5C6B7F;
  --c-ink-600:#415064; --c-ink-700:#2C3A4E; --c-ink-900:#0F1B2D; --c-black:#07101C;
  --c-blue-50:#F2F6FE; --c-blue-100:#E4ECFD; --c-blue-200:#C2D4FA; --c-blue-300:#8FB0F4;
  --c-blue-500:#3D6DE8; --c-blue-600:#1A52DE; --c-blue-700:#1340B0; --c-blue-800:#0F3389;
  --c-teal-50:#E9F8F6; --c-teal-100:#CFF0EC; --c-teal-500:#16ADA6; --c-teal-600:#0E9C97; --c-teal-700:#0B7A76;
  --c-green-50:#E7F4ED; --c-green-100:#CFE9DA; --c-green-600:#15A05A; --c-green-700:#137A48; --c-green-800:#0E5C37;
  --c-amber-50:#FBF0DD; --c-amber-100:#F6E1B8; --c-amber-600:#C77A12; --c-amber-700:#9A5D0C;
  --c-red-50:#FBEAEA; --c-red-100:#F6D2D2; --c-red-600:#D23B3B; --c-red-700:#A82A2A;
  --c-gold-500:#C79A3A; --c-gold-100:#F4EAD0;

  --surface-app:var(--c-ink-50); --surface-card:var(--c-white); --surface-raised:var(--c-white);
  --surface-sunken:var(--c-ink-100); --surface-inverse:var(--c-ink-900); --surface-hover:var(--c-ink-100);
  --surface-selected:var(--c-blue-50);
  --text-strong:var(--c-ink-900); --text-body:var(--c-ink-700); --text-muted:var(--c-ink-500);
  --text-subtle:var(--c-ink-400); --text-inverse:var(--c-white); --text-link:var(--c-blue-600); --text-on-primary:var(--c-white);
  --border-subtle:var(--c-ink-200); --border-default:var(--c-ink-300); --border-strong:var(--c-ink-400); --border-focus:var(--c-blue-600);
  --brand:var(--c-blue-600); --brand-hover:var(--c-blue-700); --brand-active:var(--c-blue-800);
  --brand-subtle:var(--c-blue-50); --brand-subtle-2:var(--c-blue-100); --accent:var(--c-teal-600); --accent-subtle:var(--c-teal-50);
  --ring:0 0 0 3px var(--c-blue-200);
  --state-open-fg:var(--c-green-700); --state-open-bg:var(--c-green-50); --state-open-dot:var(--c-green-600);
  --state-soon-fg:var(--c-amber-700); --state-soon-bg:var(--c-amber-50); --state-soon-dot:var(--c-amber-600);
  --state-upcoming-fg:var(--c-blue-700); --state-upcoming-bg:var(--c-blue-50); --state-upcoming-dot:var(--c-blue-600);
  --state-closed-fg:var(--c-ink-500); --state-closed-bg:var(--c-ink-100); --state-closed-dot:var(--c-ink-400);
  --state-featured-fg:var(--c-amber-700); --state-featured-bg:var(--c-gold-100);
  --price-bid:var(--c-blue-600); --price-start:var(--c-ink-900); --price-strike:var(--c-ink-400); --price-down:var(--c-green-700);

  /* typography */
  --font-display:'Space Grotesk', ui-sans-serif, system-ui, sans-serif;
  --font-body:'Manrope', ui-sans-serif, system-ui, -apple-system, sans-serif;
  --fw-regular:400; --fw-medium:500; --fw-semibold:600; --fw-bold:700; --fw-extra:800;
  --fs-display-xl:3.5rem; --fs-display-l:2.75rem; --fs-display-m:2rem; --fs-h1:1.625rem; --fs-h2:1.3125rem;
  --fs-h3:1.125rem; --fs-body-lg:1.0625rem; --fs-body:0.9375rem; --fs-body-sm:0.8125rem; --fs-caption:0.75rem; --fs-overline:0.6875rem;
  --lh-tight:1.05; --lh-snug:1.2; --lh-normal:1.5; --lh-relaxed:1.65;
  --ls-tighter:-0.03em; --ls-tight:-0.015em; --ls-normal:0; --ls-wide:0.04em; --ls-overline:0.12em;

  /* spacing / radius / shadow / motion / layout */
  --space-3:8px; --space-4:12px; --space-5:16px; --space-6:20px; --space-7:24px; --space-8:32px;
  --radius-xs:4px; --radius-sm:6px; --radius-md:9px; --radius-lg:12px; --radius-xl:16px; --radius-2xl:22px; --radius-pill:999px;
  --shadow-xs:0 1px 1px rgba(15,27,45,0.04);
  --shadow-sm:0 1px 2px rgba(15,27,45,0.06), 0 1px 3px rgba(15,27,45,0.04);
  --shadow-md:0 2px 4px rgba(15,27,45,0.06), 0 6px 16px -8px rgba(15,27,45,0.16);
  --shadow-lg:0 4px 8px rgba(15,27,45,0.06), 0 16px 40px -16px rgba(15,27,45,0.22);
  --shadow-xl:0 8px 16px rgba(15,27,45,0.08), 0 32px 64px -24px rgba(15,27,45,0.28);
  --shadow-card-hover:0 4px 10px rgba(15,27,45,0.07), 0 18px 44px -20px rgba(26,82,222,0.20);
  --ease-standard:cubic-bezier(0.2,0,0.1,1);
  --dur-fast:120ms; --dur-base:180ms; --dur-slow:280ms;
  --container-max:1240px; --gutter:24px; --header-h:68px; --z-header:100;
}

/* ---------- base ---------- */
*, *::before, *::after { box-sizing:border-box; }
html, body { margin:0; padding:0; }
body { font-family:var(--font-body); background:var(--surface-app); color:var(--text-body);
  font-size:var(--fs-body); line-height:var(--lh-normal); -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; }
a { color:inherit; text-decoration:none; }
button { font-family:inherit; }
img, svg { display:block; }

.k-container { max-width:var(--container-max); margin:0 auto; padding:0 var(--space-7); }
.k-app { min-height:100vh; display:flex; flex-direction:column; }
.k-main { flex:1; }

/* ---------- Header ---------- */
.k-header { position:sticky; top:0; z-index:var(--z-header); background:rgba(255,255,255,0.92);
  backdrop-filter:saturate(140%) blur(8px); border-bottom:1px solid var(--border-subtle); }
.k-header__bar { display:flex; align-items:center; gap:var(--space-7); height:var(--header-h); }
.k-logo { font-family:var(--font-display); font-weight:700; font-size:23px; letter-spacing:var(--ls-tighter);
  color:var(--text-strong); cursor:pointer; flex:none; }
.k-logo .dot { color:var(--brand); }
.k-nav { display:flex; align-items:center; gap:var(--space-6); font-weight:var(--fw-semibold); font-size:var(--fs-body-sm); }
.k-nav a { color:var(--text-body); padding:6px 0; cursor:pointer; }
.k-nav a:hover { color:var(--brand); }
.k-header__search { flex:1; max-width:440px; }
.k-header__right { margin-left:auto; display:flex; align-items:center; gap:var(--space-4); flex:none; }
.k-iconbtn { width:40px; height:40px; border-radius:var(--radius-pill); border:1px solid var(--border-subtle);
  background:var(--surface-card); color:var(--text-body); display:flex; align-items:center; justify-content:center; cursor:pointer; }
.k-iconbtn:hover { background:var(--surface-hover); color:var(--brand); }
.k-iconbtn svg { width:19px; height:19px; }

/* ---------- Hero ---------- */
.k-hero { background:linear-gradient(180deg, var(--c-ink-900) 0%, #13243A 100%); color:#fff;
  padding:56px 0 60px; position:relative; overflow:hidden; }
.k-hero--slim { padding:40px 0 44px; }
.k-hero__grid { position:absolute; inset:0; opacity:0.10;
  background-image:linear-gradient(rgba(255,255,255,0.5) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,0.5) 1px, transparent 1px);
  background-size:44px 44px; mask-image:radial-gradient(ellipse 80% 80% at 70% 0%, #000 30%, transparent 75%); }
.k-hero__inner { position:relative; }
.k-hero__eyebrow { display:inline-flex; align-items:center; gap:8px; font-size:var(--fs-body-sm); font-weight:var(--fw-bold);
  color:var(--c-blue-300); letter-spacing:0.02em; margin-bottom:14px; }
.k-hero__eyebrow svg { width:16px; height:16px; color:var(--c-teal-500); }
.k-hero h1 { font-family:var(--font-display); font-weight:700; font-size:var(--fs-display-l); line-height:var(--lh-tight);
  letter-spacing:var(--ls-tighter); margin:0 0 14px; max-width:18ch; }
.k-hero--slim h1 { font-size:var(--fs-display-m); }
.k-hero p { font-size:var(--fs-body-lg); color:#C7D3E4; max-width:54ch; margin:0 0 24px; }
.k-hero__search { background:#fff; border-radius:var(--radius-xl); padding:10px; box-shadow:var(--shadow-xl);
  display:flex; gap:8px; max-width:720px; align-items:stretch; }
.k-hero__search .grow { flex:1; }
.k-hero__stats { display:flex; gap:40px; margin-top:28px; }
.k-hero__stat b { font-family:var(--font-display); font-weight:700; font-size:28px; display:block; font-variant-numeric:tabular-nums; }
.k-hero__stat span { font-size:var(--fs-body-sm); color:#9FB0C6; }
.k-hero__trust { display:flex; flex-wrap:wrap; gap:16px; margin-top:18px; }
.k-hero__trust span { display:inline-flex; align-items:center; gap:7px; font-size:var(--fs-body-sm); color:#C7D3E4; font-weight:var(--fw-semibold); }
.k-hero__trust svg { width:16px; height:16px; color:var(--c-teal-500); }

/* ---------- Sections ---------- */
.k-section { padding:40px 0; }
.k-section__head { display:flex; align-items:flex-end; justify-content:space-between; gap:16px; margin-bottom:22px; }
.k-section__head h2 { font-family:var(--font-display); font-weight:600; font-size:var(--fs-display-m);
  letter-spacing:var(--ls-tight); color:var(--text-strong); margin:0; }
.k-grid { display:grid; gap:20px; grid-template-columns:repeat(auto-fill, minmax(280px, 1fr)); }
.k-eyebrow { display:inline-flex; align-items:center; gap:7px; font-size:var(--fs-overline); font-weight:var(--fw-bold);
  letter-spacing:var(--ls-overline); text-transform:uppercase; color:var(--c-amber-700); margin-bottom:8px; }
.k-eyebrow--brand { color:var(--brand); }

/* ---------- Native form controls (system-styled) ---------- */
.k-input, .k-select { width:100%; height:40px; padding:0 12px; font-family:var(--font-body); font-size:var(--fs-body);
  color:var(--text-strong); background:var(--surface-card); border:1px solid var(--border-default); border-radius:var(--radius-md);
  transition:border-color var(--dur-fast), box-shadow var(--dur-fast); }
.k-input--sm, .k-select--sm { height:36px; font-size:var(--fs-body-sm); }
.k-input:focus, .k-select:focus { outline:none; border-color:var(--border-focus); box-shadow:var(--ring); }
.k-input::placeholder { color:var(--text-subtle); }
.k-input--icon { padding-left:38px; }
.k-fieldwrap { position:relative; flex:1; }
.k-fieldwrap > svg { position:absolute; left:12px; top:50%; transform:translateY(-50%); width:18px; height:18px; color:var(--text-subtle); pointer-events:none; }
.k-select { appearance:none; -webkit-appearance:none; cursor:pointer; padding-right:34px;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%235C6B7F' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='m6 9 6 6 6-6'/></svg>");
  background-repeat:no-repeat; background-position:right 10px center; }
.k-check { display:flex; align-items:center; gap:9px; font-size:var(--fs-body); color:var(--text-body); cursor:pointer; }
.k-check input { width:17px; height:17px; accent-color:var(--brand); flex:none; }
.k-check .cnt { margin-left:auto; font-size:var(--fs-body-sm); color:var(--text-subtle); font-variant-numeric:tabular-nums; }

/* ---------- Results ---------- */
.k-results { display:grid; grid-template-columns:264px 1fr; gap:28px; padding:28px 0 56px; align-items:start; }
.k-facets { position:sticky; top:calc(var(--header-h) + 20px); background:var(--surface-card); border:1px solid var(--border-subtle);
  border-radius:var(--radius-lg); padding:4px 18px 18px; }
.k-facet { padding:16px 0; border-bottom:1px solid var(--border-subtle); }
.k-facet:last-child { border-bottom:none; }
.k-facet h4 { font-size:var(--fs-body-sm); font-weight:var(--fw-bold); color:var(--text-strong); margin:0 0 12px; }
.k-facet__list { display:flex; flex-direction:column; gap:11px; }
.k-results__head { display:flex; align-items:center; justify-content:space-between; gap:16px; margin-bottom:16px; flex-wrap:wrap; }
.k-results__count { font-size:var(--fs-body); color:var(--text-muted); }
.k-results__count b { color:var(--text-strong); font-variant-numeric:tabular-nums; }
.k-chips { display:flex; flex-wrap:wrap; gap:8px; margin-bottom:18px; }
.k-results__grid { display:grid; gap:18px; grid-template-columns:repeat(auto-fill, minmax(300px, 1fr)); }
.k-empty { background:var(--surface-card); border:1px dashed var(--border-default); border-radius:var(--radius-lg);
  padding:48px; text-align:center; color:var(--text-muted); }
.k-empty a { color:var(--brand); font-weight:var(--fw-bold); }

/* ---------- Pager ---------- */
.k-pager { display:flex; align-items:center; justify-content:center; gap:16px; margin-top:32px; }
.k-pager .info { color:var(--text-muted); font-size:var(--fs-body-sm); font-variant-numeric:tabular-nums; }
.k-pager .disabled { color:var(--c-ink-300); }

/* ---------- Lot detail ---------- */
.k-pagetitle { font-family:var(--font-display); font-weight:700; font-size:var(--fs-h1); letter-spacing:var(--ls-tight); color:var(--text-strong); margin:4px 0 6px; }
.k-pageintro { color:var(--text-muted); font-size:var(--fs-body); max-width:72ch; margin:0 0 18px; line-height:var(--lh-normal); }

.k-detail { padding:24px 0 64px; }
.k-breadcrumb { display:flex; align-items:center; gap:8px; font-size:var(--fs-body-sm); color:var(--text-muted); margin-bottom:18px; flex-wrap:wrap; }
.k-breadcrumb a { cursor:pointer; }
.k-breadcrumb a:hover { color:var(--brand); }
.k-breadcrumb svg { width:14px; height:14px; }
.k-detail__cols { display:grid; grid-template-columns:1.6fr 1fr; gap:32px; align-items:start; }
.k-gallery { display:grid; grid-template-columns:2fr 1fr; gap:10px; }
.k-gallery__main { aspect-ratio:16/11; border-radius:var(--radius-lg); background:var(--c-ink-100);
  display:flex; align-items:center; justify-content:center; color:var(--c-ink-300); position:relative; overflow:hidden; }
.k-gallery__main svg { width:56px; height:56px; }
.k-gallery__side { display:grid; grid-template-rows:1fr 1fr; gap:10px; }
.k-gallery__thumb { border-radius:var(--radius-md); background:var(--c-ink-100); display:flex; align-items:center; justify-content:center; color:var(--c-ink-300); }
.k-gallery__thumb svg { width:30px; height:30px; }
.k-detail h1 { font-family:var(--font-display); font-weight:700; font-size:var(--fs-display-m); letter-spacing:var(--ls-tight);
  color:var(--text-strong); margin:18px 0 6px; line-height:var(--lh-snug); }
.k-detail__loc { display:flex; align-items:center; gap:6px; color:var(--text-muted); font-size:var(--fs-body); margin-bottom:18px; }
.k-detail__loc svg { width:16px; height:16px; }
.k-specrow { display:flex; flex-wrap:wrap; gap:10px; margin-bottom:24px; }
.k-spec { display:flex; align-items:center; gap:8px; background:var(--surface-card); border:1px solid var(--border-subtle);
  border-radius:var(--radius-md); padding:10px 14px; }
.k-spec svg { width:18px; height:18px; color:var(--text-muted); }
.k-spec b { font-size:var(--fs-body); color:var(--text-strong); white-space:nowrap; }
.k-spec span { font-size:var(--fs-caption); color:var(--text-muted); display:block; }
.k-prose h3 { font-family:var(--font-display); font-weight:600; font-size:var(--fs-h2); color:var(--text-strong); margin:28px 0 10px; }
.k-prose p { color:var(--text-body); margin:0 0 12px; max-width:64ch; }
.k-doclist { display:flex; flex-direction:column; gap:8px; margin-top:6px; }
.k-doc { display:flex; align-items:center; gap:12px; padding:13px 16px; border:1px solid var(--border-subtle);
  border-radius:var(--radius-md); background:var(--surface-card); cursor:pointer; }
.k-doc:hover { border-color:var(--c-blue-200); background:var(--brand-subtle); }
.k-doc svg { width:18px; height:18px; color:var(--brand); flex:none; }
.k-doc b { font-size:var(--fs-body-sm); color:var(--text-strong); flex:1; }
.k-doc span { font-size:var(--fs-caption); color:var(--text-muted); }

/* Legal status */
.k-legal { display:flex; flex-direction:column; gap:12px; margin:6px 0 4px; }
.k-legal__row { display:grid; grid-template-columns:168px 1fr; gap:14px; align-items:start; }
.k-legal__k { font-size:var(--fs-body-sm); color:var(--text-muted); font-weight:var(--fw-bold); padding-top:2px; }
.k-legal__v { font-size:var(--fs-body); color:var(--text-body); }
.k-legal__note { font-size:var(--fs-body-sm); color:var(--text-muted); margin-top:5px; line-height:var(--lh-normal); }
.k-legal__warn { display:flex; align-items:center; gap:8px; font-size:var(--fs-body-sm); color:var(--c-amber-700);
  background:var(--c-amber-50); border:1px solid var(--c-amber-100); border-radius:var(--radius-md); padding:11px 14px; margin-top:12px; }
.k-legal__warn svg { width:16px; height:16px; flex:none; }
@media (max-width:560px) { .k-legal__row { grid-template-columns:1fr; gap:2px; } }

/* Info / bid panel */
.k-bidpanel { position:sticky; top:calc(var(--header-h) + 20px); background:var(--surface-card);
  border:1px solid var(--border-subtle); border-radius:var(--radius-xl); padding:22px; box-shadow:var(--shadow-md); }
.k-bidpanel__top { display:flex; justify-content:space-between; align-items:center; gap:12px; }
.k-bidpanel__row { display:flex; align-items:flex-end; justify-content:space-between; gap:16px; margin:14px 0; }
.k-bidpanel__cd { background:var(--c-ink-50); border:1px solid var(--border-subtle); border-radius:var(--radius-lg);
  padding:14px 16px; display:flex; align-items:center; justify-content:space-between; gap:12px; margin:16px 0; }
.k-bidpanel__cd .lab { font-size:var(--fs-caption); color:var(--text-muted); font-weight:var(--fw-bold);
  text-transform:uppercase; letter-spacing:var(--ls-overline); }
.k-bidpanel__btns { display:flex; gap:8px; margin-top:10px; }
.k-bidpanel__meta { display:flex; flex-direction:column; gap:10px; margin-top:18px; padding-top:18px; border-top:1px solid var(--border-subtle); }
.k-bidpanel__meta div { display:flex; justify-content:space-between; gap:12px; font-size:var(--fs-body-sm); }
.k-bidpanel__meta .lab { color:var(--text-muted); }
.k-bidpanel__meta .val { color:var(--text-strong); font-weight:var(--fw-semibold); text-align:right; font-variant-numeric:tabular-nums; }
.k-safe { display:flex; align-items:center; gap:8px; margin-top:16px; font-size:var(--fs-caption); color:var(--text-muted); }
.k-safe svg { width:15px; height:15px; color:var(--c-green-700); flex:none; }

/* ---------- Lot detail · data-forward (sin fotos) ---------- */
.k-lothead { margin-bottom:22px; }
.k-lothead__badges { display:flex; flex-wrap:wrap; gap:8px; margin-bottom:12px; }
.k-keychips { display:flex; flex-wrap:wrap; gap:8px; margin-top:14px; }
.k-keychip { display:inline-flex; align-items:center; gap:7px; background:var(--surface-card); border:1px solid var(--border-subtle);
  border-radius:var(--radius-md); padding:7px 12px; font-size:var(--fs-body-sm); color:var(--text-body); }
.k-keychip svg { width:15px; height:15px; color:var(--text-subtle); }
.k-keychip b { color:var(--text-strong); font-weight:var(--fw-bold); }
.k-keychip--mono b { font-family:var(--font-mono); font-size:var(--fs-caption); }

.k-block { margin-top:28px; }
.k-block__h { display:flex; align-items:center; gap:9px; font-family:var(--font-display); font-weight:600;
  font-size:var(--fs-h2); color:var(--text-strong); letter-spacing:var(--ls-tight); margin:0 0 14px; }
.k-block__h svg { width:19px; height:19px; color:var(--text-subtle); }

.k-note { display:flex; gap:10px; align-items:flex-start; background:var(--c-amber-50); border:1px solid var(--c-amber-100);
  border-radius:var(--radius-md); padding:12px 14px; margin-top:14px; }
.k-note svg { width:17px; height:17px; color:var(--c-amber-700); flex:none; margin-top:1px; }
.k-note span { font-size:var(--fs-body-sm); color:var(--c-amber-700); line-height:var(--lh-normal); }

/* legal long-text fields (cargas / inscripción / info adicional) */
.k-legaltext { display:flex; flex-direction:column; gap:14px; margin-top:16px; }
.k-legaltext__k { font-size:var(--fs-overline); font-weight:var(--fw-bold); letter-spacing:var(--ls-overline);
  text-transform:uppercase; color:var(--text-muted); margin-bottom:5px; display:flex; align-items:center; gap:6px; }
.k-legaltext__k svg { width:14px; height:14px; color:var(--text-subtle); }
.k-legaltext__v { font-size:var(--fs-body-sm); color:var(--text-body); line-height:var(--lh-normal); }

/* external official doc links (BOE) */
.k-boe { display:flex; flex-direction:column; gap:8px; }
.k-boe__item { display:flex; align-items:center; gap:13px; padding:14px 16px; border:1px solid var(--border-subtle);
  border-radius:var(--radius-md); background:var(--surface-card); cursor:pointer; text-decoration:none;
  transition:border-color var(--dur-fast), background var(--dur-fast); }
.k-boe__item:hover { border-color:var(--c-blue-200); background:var(--brand-subtle); }
.k-boe__ic { width:38px; height:38px; flex:none; border-radius:var(--radius-sm); background:var(--brand-subtle); color:var(--brand);
  display:flex; align-items:center; justify-content:center; }
.k-boe__ic svg { width:19px; height:19px; }
.k-boe__txt { flex:1; min-width:0; }
.k-boe__txt b { display:block; font-size:var(--fs-body); color:var(--text-strong); font-weight:var(--fw-bold); }
.k-boe__txt span { font-size:var(--fs-caption); color:var(--text-muted); }
.k-boe__ext { color:var(--text-subtle); flex:none; }
.k-boe__ext svg { width:16px; height:16px; }

/* Tabs (Documentación) */
.k-tabs { display:flex; gap:2px; border-bottom:1px solid var(--border-subtle); margin-bottom:14px; }
.k-tab { appearance:none; background:none; border:none; cursor:pointer; font-family:var(--font-body);
  font-size:var(--fs-body-sm); font-weight:var(--fw-semibold); color:var(--text-muted);
  padding:9px 14px; border-bottom:2px solid transparent; margin-bottom:-1px;
  transition:color var(--dur-fast), border-color var(--dur-fast); }
.k-tab:hover { color:var(--text-strong); }
.k-tab.is-active { color:var(--brand); border-bottom-color:var(--brand); }
.k-tab__n { color:var(--text-subtle); font-weight:var(--fw-medium); font-variant-numeric:tabular-nums; }
.k-tab.is-active .k-tab__n { color:var(--brand); }
.k-tabpanel { display:none; }
.k-tabpanel.is-active { display:block; }

.k-organo { display:flex; align-items:center; gap:12px; padding:15px 16px; border:1px solid var(--border-subtle);
  border-radius:var(--radius-md); background:var(--c-ink-50); }
.k-organo svg { width:20px; height:20px; color:var(--text-muted); flex:none; }
.k-organo b { font-size:var(--fs-body); color:var(--text-strong); font-weight:var(--fw-semibold); }
.k-organo span { display:block; font-size:var(--fs-caption); color:var(--text-muted); }

/* cross-links */
.k-crosslinks { display:flex; flex-wrap:wrap; gap:10px; margin-top:30px; padding-top:24px; border-top:1px solid var(--border-subtle); }
.k-crosslink { display:inline-flex; align-items:center; gap:8px; background:var(--surface-card); border:1px solid var(--border-default);
  border-radius:var(--radius-pill); padding:9px 15px; font-size:var(--fs-body-sm); font-weight:var(--fw-semibold);
  color:var(--text-body); cursor:pointer; text-decoration:none; transition:border-color var(--dur-fast), color var(--dur-fast), background var(--dur-fast); }
.k-crosslink:hover { border-color:var(--c-blue-200); color:var(--brand); background:var(--brand-subtle); }
.k-crosslink svg { width:15px; height:15px; color:var(--brand); }

/* SpecList — propiedades clave→valor */
.sbs-spl { font-family:var(--font-body); }
.sbs-spl--rows { display:flex; flex-direction:column; }
.sbs-spl--rows .sbs-spl__item { display:flex; align-items:baseline; justify-content:space-between; gap:16px;
  padding:11px 0; border-bottom:1px solid var(--border-subtle); }
.sbs-spl--rows .sbs-spl__item:last-child { border-bottom:none; }
.sbs-spl--rows .sbs-spl__k { display:flex; align-items:center; gap:6px; font-size:var(--fs-body-sm); color:var(--text-muted); flex:none; }
.sbs-spl--rows .sbs-spl__v { font-size:var(--fs-body-sm); color:var(--text-strong); font-weight:var(--fw-semibold); text-align:right; }
.sbs-spl--grid { display:grid; gap:1px; background:var(--border-subtle);
  border:1px solid var(--border-subtle); border-radius:var(--radius-lg); overflow:hidden; }
.sbs-spl--grid .sbs-spl__item { background:var(--surface-card); padding:13px 16px; display:flex; flex-direction:column; gap:5px; }
.sbs-spl--grid .sbs-spl__k { display:flex; align-items:center; gap:6px; font-size:var(--fs-overline); font-weight:var(--fw-bold);
  letter-spacing:var(--ls-overline); text-transform:uppercase; color:var(--text-muted); }
.sbs-spl--grid .sbs-spl__v { font-size:var(--fs-body); color:var(--text-strong); font-weight:var(--fw-semibold); line-height:1.3; }
.sbs-spl__ic { display:inline-flex; flex:none; color:var(--text-subtle); }
.sbs-spl__ic svg { width:14px; height:14px; display:block; }
.sbs-spl__v--muted { color:var(--text-subtle) !important; font-weight:var(--fw-medium) !important; }
.sbs-spl__v--mono { font-family:var(--font-mono); font-weight:var(--fw-semibold) !important; }
.sbs-spl--rows .sbs-spl__v--mono { font-size:var(--fs-body-sm) !important; letter-spacing:0.01em; }
.sbs-spl--grid .sbs-spl__v--mono { align-self:flex-start; font-size:var(--fs-caption) !important; letter-spacing:0.03em;
  background:var(--c-ink-50); border:1px solid var(--border-subtle); border-radius:var(--radius-xs);
  padding:3px 7px; line-height:1.3; white-space:nowrap; max-width:100%; overflow-x:auto; }
.sbs-spl__st { display:inline-flex; align-items:center; gap:7px; font-weight:var(--fw-semibold); }
.sbs-spl__dot { width:8px; height:8px; border-radius:var(--radius-pill); flex:none; background:var(--text-subtle); }
.sbs-spl__st--ok { color:var(--c-green-700); }
.sbs-spl__st--ok .sbs-spl__dot { background:var(--c-green-700); }
.sbs-spl__st--warn { color:var(--c-red-600); }
.sbs-spl__st--warn .sbs-spl__dot { background:var(--c-red-600); }
.sbs-spl__st--unknown { color:var(--text-muted); }
.sbs-spl__st--unknown .sbs-spl__dot { background:var(--text-subtle); }
@media (max-width:560px) { .sbs-spl--grid { grid-template-columns:1fr 1fr !important; } }

/* ---------- Footer ---------- */
.k-footer { background:var(--surface-inverse); color:#B9C5D6; margin-top:24px; padding:48px 0 32px; }
.k-footer__top { display:grid; grid-template-columns:1.6fr repeat(3, 1fr); gap:32px; padding-bottom:32px; border-bottom:1px solid rgba(255,255,255,0.10); }
.k-footer__brand { font-family:var(--font-display); font-weight:700; font-size:22px; color:#fff; letter-spacing:var(--ls-tighter); }
.k-footer__brand .dot { color:var(--c-blue-300); }
.k-footer p { font-size:var(--fs-body-sm); line-height:var(--lh-normal); max-width:36ch; margin:12px 0 0; }
.k-footer h5 { color:#fff; font-size:var(--fs-body-sm); font-weight:var(--fw-bold); margin:0 0 14px; }
.k-footer ul { list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:10px; }
.k-footer li { font-size:var(--fs-body-sm); }
.k-footer li a:hover { color:#fff; }
.k-footer__bottom { display:flex; justify-content:space-between; gap:16px; padding-top:24px; font-size:var(--fs-caption); color:#7E8DA3; flex-wrap:wrap; }
.k-footer__bottom a { color:#B9C5D6; text-decoration:underline; }
.k-footer__bottom a:hover { color:#fff; }

/* ---------- Home sections ---------- */
.k-section__head p { margin:4px 0 0; color:var(--text-muted); font-size:var(--fs-body); }
.k-lift { margin-top:0; position:relative; z-index:1; }

.k-cats { display:grid; grid-template-columns:repeat(6, 1fr); gap:12px; }
.k-cat { background:var(--surface-card); border:1px solid var(--border-subtle); border-radius:var(--radius-lg);
  padding:18px 16px; cursor:pointer; transition:border-color var(--dur-fast), box-shadow var(--dur-fast), transform var(--dur-fast); }
.k-cat:hover { border-color:var(--c-blue-200); box-shadow:var(--shadow-md); transform:translateY(-2px); }
.k-cat__ic { width:38px; height:38px; border-radius:var(--radius-md); background:var(--brand-subtle); color:var(--brand);
  display:flex; align-items:center; justify-content:center; margin-bottom:12px; }
.k-cat__ic svg { width:20px; height:20px; }
.k-cat b { display:block; font-size:var(--fs-body); color:var(--text-strong); font-weight:var(--fw-bold); }
.k-cat span { font-size:var(--fs-caption); color:var(--text-muted); }

.k-strip { display:flex; gap:16px; overflow-x:auto; padding:4px 4px 16px; scroll-snap-type:x mandatory; }
.k-strip > * { scroll-snap-align:start; flex:0 0 300px; }
.k-strip::-webkit-scrollbar { height:8px; }
.k-strip::-webkit-scrollbar-thumb { background:var(--c-ink-300); border-radius:999px; }

.k-provinces { display:grid; grid-template-columns:repeat(4, 1fr); gap:12px; }
.k-prov { display:flex; align-items:center; justify-content:space-between; gap:10px; background:var(--surface-card);
  border:1px solid var(--border-subtle); border-radius:var(--radius-md); padding:15px 16px; cursor:pointer;
  transition:border-color var(--dur-fast), background var(--dur-fast); }
.k-prov:hover { border-color:var(--c-blue-200); background:var(--brand-subtle); }
.k-prov__name { display:flex; align-items:center; gap:9px; font-weight:var(--fw-bold); color:var(--text-strong); font-size:var(--fs-body); }
.k-prov__name svg { width:16px; height:16px; color:var(--text-subtle); }
.k-prov__count { font-size:var(--fs-body-sm); color:var(--text-muted); font-variant-numeric:tabular-nums; }

.k-steps { display:grid; grid-template-columns:repeat(3, 1fr); gap:22px; }
.k-step { position:relative; padding-top:8px; }
.k-step__n { width:44px; height:44px; border-radius:var(--radius-md); background:var(--c-ink-900); color:#fff;
  display:flex; align-items:center; justify-content:center; font-family:var(--font-display); font-weight:700; font-size:19px; margin-bottom:16px; }
.k-step h3 { font-family:var(--font-display); font-weight:600; font-size:var(--fs-h2); color:var(--text-strong); margin:0 0 6px; letter-spacing:var(--ls-tight); }
.k-step p { color:var(--text-muted); font-size:var(--fs-body); margin:0; max-width:34ch; }

.k-procs { display:grid; grid-template-columns:repeat(4, 1fr); gap:16px; }
.k-proc { background:var(--surface-card); border:1px solid var(--border-subtle); border-radius:var(--radius-lg);
  padding:22px 20px; cursor:pointer; transition:border-color var(--dur-fast), box-shadow var(--dur-fast), transform var(--dur-fast); }
.k-proc:hover { border-color:var(--c-blue-200); box-shadow:var(--shadow-md); transform:translateY(-2px); }
.k-proc__ic { width:44px; height:44px; border-radius:var(--radius-md); display:flex; align-items:center; justify-content:center; margin-bottom:16px; background:var(--brand-subtle); color:var(--brand); }
.k-proc__ic svg { width:22px; height:22px; }
.k-proc h3 { font-family:var(--font-display); font-weight:600; font-size:var(--fs-h3); color:var(--text-strong); margin:0 0 6px; }
.k-proc p { color:var(--text-muted); font-size:var(--fs-body-sm); margin:0 0 14px; line-height:var(--lh-normal); }
.k-proc__link { display:inline-flex; align-items:center; gap:5px; font-size:var(--fs-body-sm); font-weight:var(--fw-bold); color:var(--brand); }
.k-proc__link svg { width:15px; height:15px; }

.k-trustband { background:var(--surface-card); border-top:1px solid var(--border-subtle); border-bottom:1px solid var(--border-subtle); }
.k-trustband__grid { display:grid; grid-template-columns:repeat(4, 1fr); gap:28px; padding:44px 0; }
.k-value { display:flex; gap:14px; }
.k-value__ic { width:40px; height:40px; flex:none; border-radius:var(--radius-md); background:var(--accent-subtle); color:var(--c-teal-700);
  display:flex; align-items:center; justify-content:center; }
.k-value__ic svg { width:20px; height:20px; }
.k-value b { display:block; font-size:var(--fs-body); color:var(--text-strong); font-weight:var(--fw-bold); margin-bottom:3px; }
.k-value span { font-size:var(--fs-body-sm); color:var(--text-muted); line-height:var(--lh-normal); }

.k-cta { background:linear-gradient(120deg, var(--c-blue-700) 0%, var(--c-blue-600) 60%, #2D6BE8 100%);
  border-radius:var(--radius-2xl); padding:44px 48px; display:flex; align-items:center; justify-content:space-between;
  gap:32px; color:#fff; position:relative; overflow:hidden; }
.k-cta__grid { position:absolute; inset:0; opacity:0.14;
  background-image:linear-gradient(rgba(255,255,255,0.6) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,0.6) 1px, transparent 1px);
  background-size:40px 40px; mask-image:radial-gradient(ellipse 70% 90% at 90% 50%, #000 20%, transparent 70%); }
.k-cta__txt { position:relative; }
.k-cta h2 { font-family:var(--font-display); font-weight:700; font-size:var(--fs-display-m); letter-spacing:var(--ls-tight); margin:0 0 8px; }
.k-cta p { margin:0; color:#DCE6FA; font-size:var(--fs-body-lg); max-width:46ch; }
.k-cta__form { position:relative; display:flex; gap:10px; flex:none; align-items:stretch; }
.k-cta__form .grow { width:280px; }
.k-cta__form .k-fieldwrap > svg { color:var(--text-subtle); }

/* ============================================================
   Components
   ============================================================ */

/* Badge */
.sbs-badge { display:inline-flex; align-items:center; gap:6px; font-family:var(--font-body); font-weight:var(--fw-bold);
  font-size:var(--fs-caption); line-height:1; letter-spacing:0.01em; padding:5px 10px; border-radius:var(--radius-pill);
  background:var(--c-ink-100); color:var(--text-body); white-space:nowrap; border:1px solid transparent; }
.sbs-badge--sm { font-size:var(--fs-overline); padding:3px 8px; }
.sbs-badge__dot { width:7px; height:7px; border-radius:50%; background:currentColor; flex:none; }
.sbs-badge--neutral { background:var(--c-ink-100); color:var(--text-body); }
.sbs-badge--brand { background:var(--brand-subtle); color:var(--brand-hover); }
.sbs-badge--open { background:var(--state-open-bg); color:var(--state-open-fg); }
.sbs-badge--open .sbs-badge__dot { background:var(--state-open-dot); }
.sbs-badge--soon { background:var(--state-soon-bg); color:var(--state-soon-fg); }
.sbs-badge--soon .sbs-badge__dot { background:var(--state-soon-dot); }
.sbs-badge--upcoming { background:var(--state-upcoming-bg); color:var(--state-upcoming-fg); }
.sbs-badge--upcoming .sbs-badge__dot { background:var(--state-upcoming-dot); }
.sbs-badge--closed { background:var(--state-closed-bg); color:var(--state-closed-fg); }
.sbs-badge--closed .sbs-badge__dot { background:var(--state-closed-dot); }
.sbs-badge--featured { background:var(--state-featured-bg); color:var(--state-featured-fg); }
.sbs-badge--danger { background:var(--c-red-50); color:var(--c-red-700); }
.sbs-badge--solid { background:var(--brand); color:#fff; }

/* Button */
.sbs-btn { --_bg:var(--brand); --_fg:var(--text-on-primary); --_bd:transparent;
  display:inline-flex; align-items:center; justify-content:center; gap:8px; font-family:var(--font-body); font-weight:var(--fw-bold);
  border:1px solid var(--_bd); background:var(--_bg); color:var(--_fg); border-radius:var(--radius-md); cursor:pointer;
  white-space:nowrap; text-decoration:none; line-height:1; letter-spacing:0.01em;
  transition:background var(--dur-fast) var(--ease-standard), border-color var(--dur-fast) var(--ease-standard),
    box-shadow var(--dur-fast) var(--ease-standard), transform var(--dur-fast) var(--ease-standard); }
.sbs-btn:focus-visible { outline:none; box-shadow:var(--ring); }
.sbs-btn:active { transform:translateY(0.5px); }
.sbs-btn:disabled, .sbs-btn[aria-disabled="true"] { cursor:not-allowed; opacity:0.5; }
.sbs-btn__ic { display:inline-flex; }
.sbs-btn__ic svg { width:1.15em; height:1.15em; display:block; }
.sbs-btn--sm { font-size:var(--fs-body-sm); padding:7px 12px; }
.sbs-btn--md { font-size:var(--fs-body); padding:10px 16px; }
.sbs-btn--lg { font-size:var(--fs-body-lg); padding:13px 22px; border-radius:var(--radius-lg); }
.sbs-btn--block { width:100%; }
.sbs-btn--primary { --_bg:var(--brand); --_fg:var(--text-on-primary); box-shadow:var(--shadow-xs); }
.sbs-btn--primary:hover:not(:disabled) { --_bg:var(--brand-hover); }
.sbs-btn--primary:active:not(:disabled) { --_bg:var(--brand-active); }
.sbs-btn--secondary { --_bg:var(--surface-card); --_fg:var(--text-strong); --_bd:var(--border-default); }
.sbs-btn--secondary:hover:not(:disabled) { --_bg:var(--surface-hover); --_bd:var(--border-strong); }
.sbs-btn--ghost { --_bg:transparent; --_fg:var(--brand); --_bd:transparent; }
.sbs-btn--ghost:hover:not(:disabled) { --_bg:var(--brand-subtle); }
.sbs-btn--subtle { --_bg:var(--brand-subtle); --_fg:var(--brand-hover); --_bd:transparent; }
.sbs-btn--subtle:hover:not(:disabled) { --_bg:var(--brand-subtle-2); }

/* PriceStat */
.sbs-ps { display:flex; flex-direction:column; gap:3px; font-family:var(--font-body); }
.sbs-ps__k { font-size:var(--fs-overline); font-weight:var(--fw-bold); letter-spacing:var(--ls-overline); text-transform:uppercase; color:var(--text-muted); }
.sbs-ps__v { font-family:var(--font-display); font-weight:var(--fw-bold); font-variant-numeric:tabular-nums; letter-spacing:-0.01em; color:var(--price-start); line-height:1.1; }
.sbs-ps--sm .sbs-ps__v { font-size:var(--fs-h3); }
.sbs-ps--md .sbs-ps__v { font-size:var(--fs-h2); }
.sbs-ps--lg .sbs-ps__v { font-size:var(--fs-display-m); }
.sbs-ps--bid .sbs-ps__v { color:var(--price-bid); }
.sbs-ps--strike .sbs-ps__v { color:var(--price-strike); text-decoration:line-through; font-weight:var(--fw-medium); }

/* Countdown */
.sbs-cd { display:inline-flex; align-items:center; gap:6px; font-family:var(--font-display); }
.sbs-cd__seg { display:inline-flex; flex-direction:column; align-items:center; min-width:34px;
  background:var(--c-ink-900); color:#fff; border-radius:var(--radius-sm); padding:5px 6px; }
.sbs-cd__seg b { font-size:16px; font-weight:700; line-height:1; font-variant-numeric:tabular-nums; }
.sbs-cd__seg span { font-size:8px; font-weight:700; letter-spacing:0.08em; text-transform:uppercase; opacity:0.6; margin-top:3px; }
.sbs-cd--soon .sbs-cd__seg { background:var(--c-amber-600); }
.sbs-cd--inline { font-family:var(--font-body); font-weight:700; gap:7px; align-items:center; }
.sbs-cd--inline .sbs-cd__ic { display:inline-flex; color:var(--text-muted); }
.sbs-cd--inline .sbs-cd__ic svg { width:15px; height:15px; }
.sbs-cd--inline .sbs-cd__txt { font-variant-numeric:tabular-nums; font-size:var(--fs-body-sm); color:var(--text-strong); }
.sbs-cd--inline.sbs-cd--soon .sbs-cd__txt { color:var(--c-amber-700); }
.sbs-cd__ended { font-family:var(--font-body); font-weight:700; font-size:var(--fs-body-sm); color:var(--text-muted); }

/* FilterChip */
.sbs-chip { display:inline-flex; align-items:center; gap:7px; font-family:var(--font-body); font-size:var(--fs-body-sm);
  font-weight:var(--fw-semibold); color:var(--text-body); background:var(--surface-card); border:1px solid var(--border-default);
  border-radius:var(--radius-pill); padding:6px 12px; cursor:pointer; white-space:nowrap;
  transition:background var(--dur-fast) var(--ease-standard), border-color var(--dur-fast) var(--ease-standard), color var(--dur-fast) var(--ease-standard); }
.sbs-chip:hover { border-color:var(--border-strong); background:var(--surface-hover); }
.sbs-chip svg { width:15px; height:15px; }
.sbs-chip--active { background:var(--brand-subtle); border-color:var(--c-blue-200); color:var(--brand-hover); }
.sbs-chip--active:hover { background:var(--brand-subtle-2); }
.sbs-chip__x { display:inline-flex; margin:-2px -4px -2px 0; border-radius:50%; padding:2px; color:inherit; opacity:0.7; }
.sbs-chip__x:hover { opacity:1; background:rgba(15,27,45,0.08); }
.sbs-chip__x svg { width:13px; height:13px; }

/* LotCard */
.sbs-lot { position:relative; display:flex; flex-direction:column; background:var(--surface-card);
  border:1px solid var(--border-subtle); border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow-sm);
  text-decoration:none; color:inherit;
  transition:box-shadow var(--dur-base) var(--ease-standard), border-color var(--dur-base) var(--ease-standard), transform var(--dur-base) var(--ease-standard); }
.sbs-lot--link { cursor:pointer; }
.sbs-lot--link:hover { box-shadow:var(--shadow-card-hover); border-color:var(--c-blue-200); transform:translateY(-2px); }
.sbs-lot__photo { position:relative; aspect-ratio:4/3; background:var(--c-ink-100) center/cover no-repeat;
  display:flex; align-items:center; justify-content:center; }
.sbs-lot__ph { color:var(--c-ink-300); }
.sbs-lot__ph svg { width:42px; height:42px; }
.sbs-lot__topl { position:absolute; top:12px; left:12px; display:flex; gap:6px; }
.sbs-lot__disc { position:absolute; bottom:12px; left:12px; }
.sbs-lot__body { display:flex; flex-direction:column; gap:10px; padding:15px 16px 16px; flex:1; }
.sbs-lot__kicker { font-size:var(--fs-overline); font-weight:var(--fw-bold); letter-spacing:var(--ls-overline);
  text-transform:uppercase; color:var(--text-muted); display:flex; align-items:center; gap:6px; flex-wrap:wrap; }
.sbs-lot__ref { white-space:nowrap; opacity:0.65; }
.sbs-lot__title { font-family:var(--font-display); font-weight:var(--fw-semibold); font-size:var(--fs-h3);
  line-height:var(--lh-snug); letter-spacing:var(--ls-tight); color:var(--text-strong); margin:0;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.sbs-lot__loc { display:flex; align-items:center; gap:5px; font-size:var(--fs-body-sm); color:var(--text-muted); margin-top:-4px; }
.sbs-lot__loc svg { width:14px; height:14px; flex:none; }
.sbs-lot__specs { display:flex; flex-wrap:wrap; gap:6px; }
.sbs-lot__prices { display:flex; align-items:flex-end; justify-content:space-between; gap:12px; margin-top:auto; padding-top:6px; }
.sbs-lot__foot { display:flex; align-items:center; justify-content:space-between; gap:10px; border-top:1px solid var(--border-subtle); padding-top:12px; }
.sbs-lot__bids { font-size:var(--fs-caption); color:var(--text-muted); font-weight:var(--fw-semibold); }
.sbs-lot__bids b { color:var(--text-strong); font-variant-numeric:tabular-nums; }

/* Badge square (for table) */
.sbs-badge--sq { border-radius:var(--radius-sm); }

/* View toggle (list / grid) */
.k-viewtoggle { display:inline-flex; background:var(--c-ink-100); border:1px solid var(--border-subtle); border-radius:var(--radius-md); padding:3px; gap:2px; }
.k-viewtoggle a { width:34px; height:32px; border-radius:var(--radius-sm); color:var(--text-muted); cursor:pointer; display:flex; align-items:center; justify-content:center; }
.k-viewtoggle a svg { width:17px; height:17px; }
.k-viewtoggle a:hover { color:var(--text-strong); }
.k-viewtoggle a.is-active { background:var(--surface-card); color:var(--brand); box-shadow:var(--shadow-xs); }

/* LotTable (list view, no images) */
.sbs-lt { width:100%; background:var(--surface-card); border:1px solid var(--border-subtle); border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow-sm); }
.sbs-lt__table { width:100%; border-collapse:collapse; font-family:var(--font-body); }
.sbs-lt__table thead th { text-align:left; font-size:var(--fs-overline); font-weight:var(--fw-bold);
  letter-spacing:var(--ls-overline); text-transform:uppercase; color:var(--text-muted);
  padding:13px 16px; background:var(--c-ink-50); border-bottom:1px solid var(--border-subtle); white-space:nowrap; }
.sbs-lt__table th.sbs-lt--num, .sbs-lt__table td.sbs-lt--num { text-align:right; }
.sbs-lt__table tbody tr { border-bottom:1px solid var(--border-subtle); cursor:pointer; transition:background var(--dur-fast) var(--ease-standard); }
.sbs-lt__table tbody tr:last-child { border-bottom:none; }
.sbs-lt__table tbody tr:hover { background:var(--surface-hover); }
.sbs-lt__table td { padding:14px 16px; vertical-align:middle; }
.sbs-lt__lot { display:flex; align-items:flex-start; gap:12px; }
.sbs-lt__rank { font-family:var(--font-display); font-weight:700; font-size:var(--fs-body-sm); color:var(--text-subtle); font-variant-numeric:tabular-nums; padding-top:2px; min-width:18px; }
.sbs-lt__main { display:flex; flex-direction:column; gap:4px; min-width:0; }
.sbs-lt__title { font-family:var(--font-display); font-weight:var(--fw-semibold); font-size:var(--fs-body-lg);
  letter-spacing:var(--ls-tight); color:var(--text-strong); line-height:1.25; text-decoration:none;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.sbs-lt__title:hover { color:var(--brand); }
.sbs-lt__loc { display:flex; flex-direction:column; gap:3px; }
.sbs-lt__loccity { display:flex; align-items:center; gap:6px; font-size:var(--fs-body-sm); color:var(--text-body); font-weight:var(--fw-semibold); }
.sbs-lt__loccity svg { width:14px; height:14px; flex:none; color:var(--text-subtle); }
.sbs-lt__ref { font-family:var(--font-mono); font-size:11px; color:var(--text-muted); }
.sbs-lt__specs { font-size:var(--fs-body-sm); color:var(--text-muted); }
.sbs-lt__procbadges { display:flex; gap:6px; align-items:center; flex-wrap:wrap; }
.sbs-lt__price { font-family:var(--font-display); font-weight:var(--fw-bold); font-variant-numeric:tabular-nums;
  letter-spacing:-0.01em; font-size:var(--fs-h3); color:var(--price-start); line-height:1.15; }
.sbs-lt__pricesub { font-size:var(--fs-caption); color:var(--text-muted); font-variant-numeric:tabular-nums; margin-top:2px; }
.sbs-lt__apr { font-variant-numeric:tabular-nums; color:var(--price-strike); text-decoration:line-through; font-weight:var(--fw-medium); font-size:var(--fs-body-sm); }
.sbs-lt__apr.is-plain { text-decoration:none; color:var(--text-muted); }
.sbs-lt__cierre { display:flex; flex-direction:column; gap:6px; align-items:flex-start; }
.sbs-lt__actions { display:flex; align-items:center; gap:6px; justify-content:flex-end; }
.sbs-lt__go { width:34px; height:34px; border:1px solid var(--border-subtle); border-radius:var(--radius-pill);
  background:var(--surface-card); color:var(--text-body); display:flex; align-items:center; justify-content:center; }
.sbs-lt__table tbody tr:hover .sbs-lt__go { background:var(--brand); border-color:var(--brand); color:#fff; }
.sbs-lt__go svg { width:17px; height:17px; }
@media (max-width:820px) { .sbs-lt__hide-md { display:none; } }
@media (max-width:620px) { .sbs-lt__hide-sm { display:none; } }

/* ---------- Responsive ---------- */
@media (max-width:900px) {
  .k-results { grid-template-columns:1fr; }
  .k-facets { position:static; }
  .k-detail__cols { grid-template-columns:1fr; }
  .k-footer__top { grid-template-columns:1fr 1fr; }
  .k-nav { display:none; }
  .k-header__search { display:none; }
  .k-cats { grid-template-columns:repeat(3, 1fr); }
  .k-provinces { grid-template-columns:repeat(2, 1fr); }
  .k-steps { grid-template-columns:1fr; }
  .k-procs { grid-template-columns:repeat(2, 1fr); }
  .k-trustband__grid { grid-template-columns:repeat(2, 1fr); }
  .k-cta { flex-direction:column; align-items:flex-start; }
  .k-cta__form .grow { width:220px; }
  .k-hero__search { flex-wrap:wrap; }
}
@media (max-width:560px) {
  .k-footer__top { grid-template-columns:1fr; }
  .k-hero__stats { gap:24px; }
}
