﻿.flash__note-icon {
  display: inline-block;
  vertical-align: -3px;
  margin-right: 6px;
}
/* condensed professional light theme matching the original preview */
:root{--bg:#f3f6fb;--card:#fff;--line:#dbe4ef;--text:#0b1736;--muted:#5f6f86;--navy:#0f1724;--shadow:0 12px 28px rgba(15,23,42,.08);--success:#059669;--successDark:#047857}
*{box-sizing:border-box}body{margin:0;font-family:Inter,system-ui,Segoe UI,Arial,sans-serif;background:linear-gradient(#f7f8fc,#edf2f9);color:var(--text)}a{text-decoration:none;color:inherit}
.container{max-width:1180px;margin:0 auto;padding:12px 20px 60px}.topbar{height:60px;display:flex;align-items:center;padding:0 2px;background:transparent;border:none;border-radius:0;box-shadow:none;justify-content:space-between;}.brand{display:flex;gap:10px;align-items:center;font-weight:700}.brand__logo{height:70px;width:auto;object-fit:contain;display:block}.icon{width:50px;height:50px;color:#000000;flex-shrink:0}.brand__text{display:flex;flex-direction:column;gap:2px}.brand__name{font-size:44px;line-height:1;font-weight:700;letter-spacing:-.015em;color:#0f172a}.brand__tagline{font-size:16px;font-weight:400;color:#64748b;letter-spacing:.03em;line-height:1;white-space:nowrap}.chip{padding:8px 12px;border-radius:999px;border:1px solid var(--line);font-size:13px;background:#fff;color:#334155}.hero{display:grid;grid-template-columns:1.03fr .97fr;gap:28px;margin-top:14px}.card{background:var(--card);border:1px solid var(--line);border-radius:22px;box-shadow:var(--shadow);padding:20px}
.badgePill{display:inline-block;background:var(--navy);color:#fff;border-radius:999px;padding:6px 12px;font-size:12px;font-weight:700}.heroCardMain h1{font-size:46px;line-height:1.08;letter-spacing:-.03em;margin:14px 0 18px;max-width:15ch}.subtitle{margin:0;color:#475569;line-height:1.60;font-size:15px}.searchCard{margin-top:20px;border:1px solid #d7e3f2;border-radius:18px;padding:30px 28px;background:linear-gradient(180deg,#f8fbff 0%,#f2f6fd 100%);position:relative}
.searchCardHelp{position:absolute;top:12px;right:12px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;border:none;background:transparent;color:#94a3b8;cursor:pointer;padding:0;transition:background .18s,color .18s;z-index:1}
.searchCardHelp:hover{background:rgba(37,99,235,.08);color:#2563eb}.searchRow{display:flex;align-items:flex-end;margin-top:0;width:100%}.inputWrap{position:relative;flex:1;min-width:0}
.inputWrap.vinInput{max-width:100%;width:100%;position:relative;display:flex;flex-direction:column}
.vinField{position:relative}
.inputWrap.vinInput input{padding-right:110px}
.vinLabelRow{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}
.vinLabelGroup{display:flex;align-items:center;gap:5px}
.inputLabel{display:block;font-size:14px;font-weight:700;color:#111827;letter-spacing:.24px;text-transform:uppercase;opacity:.92;margin:0}
.labelHelpBtn{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;border:none;background:transparent;color:#94a3b8;cursor:pointer;padding:0;transition:all .18s;flex-shrink:0}
.labelHelpBtn:hover{background:#e0e7ef;border-color:#475569;color:#1e293b}
.labelHelpBtn:focus{outline:2px solid rgba(37,99,235,.3);outline-offset:2px}
.inputHelpBtn{position:absolute;right:8px;top:50%;transform:translateY(-50%);height:34px;width:34px;border-radius:999px;border:1px solid rgba(15,23,42,.12);background:#f8fafc;color:#111827;font-weight:800;line-height:1;display:grid;place-items:center;cursor:pointer;transition:all 0.2s}
.inputHelpBtn:hover{background:#e5e7eb;border-color:#d1d5db;transform:translateY(-50%) scale(1.05)}
.inputHelpBtn:focus{outline:3px solid rgba(37,99,235,.25);outline-offset:2px}
.vinField::before{content:none}.inputWrap.vinInput input{width:100%;height:72px;border:2px solid var(--line);border-radius:18px;padding:0 14px 0 22px;font-size:18px;font-weight:700;transition:all 0.2s;background:#fff;letter-spacing:2px;text-transform:uppercase}.primaryBtn{height:64px;border:none;border-radius:18px;background:var(--navy);color:#fff;font-weight:700;padding:0 32px;cursor:pointer;transition:all 0.2s;font-size:16px}.primaryBtn:hover{background:#051b44;transform:translateY(-2px);box-shadow:0 8px 20px rgba(15,23,42,.16)}
.primaryBtn:active{transform:translateY(0);box-shadow:0 4px 12px rgba(15,23,42,.12)}
.primaryBtn:disabled{opacity:.55;cursor:not-allowed;transform:none}.searchMeta{margin-top:10px;display:flex;gap:8px;flex-wrap:wrap;color:var(--muted);font-size:11px}.statusLine{margin-top:10px}.status{padding:10px 12px;border:1px solid var(--line);border-radius:12px;background:#fff;font-size:13px}.status.ok{background:#d1fae5;border-color:#6ee7b7;color:#047857;font-weight:500}.status.warn{background:#fef9c3;border-color:#fcd34d;color:#78350f;font-weight:500}.status.bad{background:#fee2e2;border-color:#f87171;color:#b91c1c;font-weight:500}
.trust{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:12px}.trustItem{border:1px solid var(--line);border-radius:14px;padding:12px;background:#fff;text-align:left}.trustTitle{font-weight:700;font-size:14px}.trustDesc{font-size:12px;color:var(--muted);margin-top:4px;line-height:1.4}
.trustItem--vehicles .trustTitle{font-size:14px;line-height:1.2;letter-spacing:0;color:#0b1736}
.trustItem--vehicles .trustDesc{font-size:12px;line-height:1.4;color:var(--muted);font-weight:500;margin-top:4px}
.trustItem--vehicles .vehiclesCountValue{display:block;font-size:clamp(16px,2.4vw,28px);line-height:1.05;font-weight:800;letter-spacing:-.02em;color:#0f1724;margin:6px 0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sidePreview h3{margin:0;font-size:22px}.mutedSmall{font-size:12px;color:var(--muted)}.score{border:1px solid var(--line);border-radius:999px;padding:6px 10px;font-size:12px;white-space:nowrap}.header{display:flex;justify-content:space-between;gap:8px}.kpisTop{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:10px}.kpiBox{border:1px solid var(--line);border-radius:12px;background:#f8fbff;padding:10px}.kpiBox .lbl{font-size:9px;color:var(--muted);text-transform:uppercase;letter-spacing:.07em;font-weight:700;margin-bottom:4px}.kpiBox .val{font-weight:700}
.sectionTitle{font-size:40px;letter-spacing:-.03em;margin:36px 0 8px}.sectionSub{color:#475569;max-width:760px}.featureGrid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:16px}.feature{background:#fff;border:1px solid var(--line);border-radius:14px;padding:16px}.feature h4{margin:6px 0}.feature p{margin:0;color:var(--muted);font-size:13px}
.btn,.btnPrimary{height:40px;border-radius:10px;padding:0 12px;cursor:pointer}.btn{border:1px solid var(--line);background:#fff}.btnPrimary{border:1px solid var(--navy);background:var(--navy);color:#fff}
.btnAdd{border:1px solid var(--success);background:var(--success);color:#fff}
.btnAdd:hover{background:var(--successDark);border-color:var(--successDark);transform:translateY(-1px);box-shadow:0 10px 18px rgba(5,150,105,.18)}
.btnAdd:active{transform:translateY(0);box-shadow:none}
/* Functional results blocks */
.meta{display:flex;flex-wrap:wrap;align-items:center;column-gap:8px;row-gap:8px;margin-top:12px;padding-top:6px}.pill{border:1px solid var(--line);background:#fff;border-radius:999px;padding:4px 10px;font-size:12px;line-height:1.1}.pill--ok{background:#ecfeff}.pill--warn{background:#fffbeb}
.results{display:none;grid-template-columns:1fr;gap:12px;margin-top:16px}.summary,.kpis,.chartWrap,.tableWrap{background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow)}.summary{padding:18px 20px}.summary .line1{display:flex;justify-content:space-between;gap:14px;align-items:flex-start;flex-wrap:wrap;margin-bottom:10px}
.summary .line1 > div{min-width:0}
.summaryHeading{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.summaryHeading #sumVin{margin:0}
.summaryHeading #verdictBadge{transform:translateY(-3px);padding:4px 10px;line-height:1}
.summary #sumVin{display:block;line-height:1.14;margin:0 0 8px;font-size:19px}
.summary #sumLast{display:block;line-height:1.52;overflow-wrap:anywhere;word-break:break-word}
.vtd{margin:4px 0 6px}
.vtd__item{font-size:13px;color:#374151}.vtd__item strong{font-weight:600;color:#111827}
.vtd__sep{color:#D1D5DB;font-size:12px}
#vtdHero{margin:0px 0 8px}
.vtd__hero-title{font-size:18px;font-weight:700;color:#111827;line-height:1.2}
.vtd__hero-year{font-size:18px;font-weight:400;color:#94a3b8;line-height:1.2}
.vtd-brand{display:flex;align-items:center;gap:10px;margin:8px 0 4px}
.vtd-brand__logo{height:32px;width:auto;object-fit:contain;flex-shrink:0}
.vtd-brand__name{font-size:15px;font-weight:700;color:#0F172A}
.vtd-brand__year{font-weight:400;color:#94a3b8}
.vtd-blocks{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:12px;margin:6px 0 4px}
.vtd-blocks--3{grid-template-columns:1fr 1fr 1fr}
.vtd-block{background:#F8FAFC;border:1px solid #E2E8F0;border-radius:10px;padding:12px 14px}
.vtd-block__title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#94A3B8;margin-bottom:8px}
.vtd-block__row{display:flex;justify-content:space-between;align-items:baseline;gap:8px;padding:3px 0;border-bottom:1px solid #F1F5F9}
.vtd-block__row:last-child{border-bottom:none}
.vtd-block__lbl{font-size:12px;color:#64748B;white-space:nowrap;flex-shrink:0}
.vtd-block__val{font-size:12px;font-weight:600;color:#0F172A;text-align:right}
.vtd-block--stk{display:flex;flex-direction:column;align-items:center;justify-content:flex-start}
.vtd-block__stk-img{width:100%;flex:1;display:flex;align-items:center;justify-content:center;margin-top:4px}
.stk-wrap{position:relative;display:inline-block;line-height:0}
.stk-img{max-width:100%;max-height:120px;object-fit:contain;display:block}
.stk-yr{position:absolute;font-size:14px;font-weight:900;color:#111;font-family:Arial Black,Arial,sans-serif;line-height:1;pointer-events:none}
.stk-dot{position:absolute;width:12px;height:12px;border-radius:50%;background:#fff;transform:translate(-50%,-50%);pointer-events:none}
.stk-status{margin-top:6px;font-size:12px;font-weight:700;letter-spacing:.06em}
.stk-status--ok{color:#15803d}
.stk-status--expired{color:#dc2626}
/* ── 5-column grid for VTD with color swatch ───────────────────────────────── */
.vtd-blocks--5{grid-template-columns:1fr 1fr 1fr 0.9fr 0.9fr}
/* Color swatch block */
.vtd-block--color{display:flex;flex-direction:column;align-items:center;justify-content:flex-start}
.vtd-color-swatch{width:min(100%,120px);aspect-ratio:1/1;border-radius:10px;box-shadow:0 2px 8px rgba(0,0,0,.18),inset 0 0 0 1px rgba(0,0,0,.12);position:relative;overflow:hidden;margin:6px 0 6px;background:var(--car-color,#ccc)}
.vtd-color-swatch-img{width:min(100%,120px);aspect-ratio:1/1;border-radius:10px;box-shadow:0 2px 8px rgba(0,0,0,.18),inset 0 0 0 1px rgba(0,0,0,.12);margin:6px 0 6px;display:block;object-fit:cover}
.vtd-color-label{font-size:11px;font-weight:700;color:#334155;text-align:center;letter-spacing:.03em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
.vtd-color-finish{display:block;margin-top:4px;padding:2px 8px;border-radius:99px;background:#F1F5F9;font-size:9px;font-weight:600;color:#64748B;letter-spacing:.05em;text-transform:uppercase;text-align:center;align-self:center}
/* Finish effects — all via ::after pseudo-element, no inline styles */
.vtd-color-swatch::after{content:'';position:absolute;inset:0;border-radius:inherit;pointer-events:none}
/* Flat gloss: elliptical top highlight + bottom shadow */
.vtd-color-swatch.finish--flat::after{background:radial-gradient(ellipse 120% 60% at 50% -10%,rgba(255,255,255,.28) 0%,rgba(255,255,255,.00) 70%),linear-gradient(180deg,rgba(255,255,255,.10) 0%,rgba(255,255,255,.00) 40%,rgba(0,0,0,.10) 100%)}
/* Metallic: sharp angled band + counter-gradient for flake depth */
.vtd-color-swatch.finish--metal::after{background:linear-gradient(138deg,rgba(255,255,255,.00) 0%,rgba(255,255,255,.00) 26%,rgba(255,255,255,.38) 42%,rgba(255,255,255,.12) 50%,rgba(255,255,255,.00) 64%,rgba(255,255,255,.00) 100%),linear-gradient(228deg,rgba(255,255,255,.00) 0%,rgba(255,255,255,.08) 55%,rgba(255,255,255,.00) 100%),linear-gradient(180deg,rgba(255,255,255,.06) 0%,rgba(0,0,0,.08) 100%)}
/* Pearl: radial glow + dual-angle shimmer (tri-coat) */
.vtd-color-swatch.finish--pearl::after{background:radial-gradient(ellipse 80% 55% at 38% 30%,rgba(255,255,255,.35) 0%,transparent 65%),linear-gradient(130deg,rgba(255,255,255,.00) 0%,rgba(255,255,255,.30) 42%,rgba(255,255,255,.06) 56%,rgba(255,255,255,.00) 76%),linear-gradient(310deg,rgba(255,255,255,.00) 0%,rgba(255,255,255,.14) 50%,rgba(255,255,255,.00) 80%),linear-gradient(180deg,rgba(255,255,255,.08) 0%,rgba(0,0,0,.06) 100%)}
/* Matte: diffuse top bloom only, bottom darkening — zero specular */
.vtd-color-swatch.finish--mat::after{background:radial-gradient(ellipse 90% 50% at 50% 0%,rgba(255,255,255,.14) 0%,rgba(255,255,255,.04) 55%,transparent 80%),linear-gradient(180deg,rgba(0,0,0,.00) 0%,rgba(0,0,0,.10) 100%)}

@media(max-width:1100px){.vtd-blocks--5{grid-template-columns:1fr 1fr 1fr 0.9fr 0.9fr}}
@media(max-width:900px){.vtd-blocks,.vtd-blocks--5{grid-template-columns:1fr 1fr}}
@media(max-width:520px){
  /* Prevent horizontal scroll */
  body{overflow-x:hidden}
  /* Container */
  .container{padding:8px 12px 40px}
  /* VTD grid */
  .vtd-blocks{grid-template-columns:1fr}
  .vtd-blocks--5{grid-template-columns:1fr 1fr}
  .vtd-blocks--5>:nth-child(-n+3){grid-column:1/-1}
  /* Consistent card radius + padding across all sections */
  .card{border-radius:16px;padding:16px}
  .searchCard{padding:18px 14px;border-radius:14px}
  .summary{padding:14px 16px;border-radius:16px}
  .tableWrap{padding:12px 14px 16px;border-radius:16px}
  .kpis{border-radius:16px}
  .chartWrap{border-radius:16px}
  .feature{border-radius:14px;padding:14px}
  /* Hero gap = results gap */
  .hero{gap:10px !important}
  .results{gap:10px;margin-top:10px}
  /* KPI top: 2 columns on narrow screen */
  .kpisTop{grid-template-columns:1fr 1fr}
  /* Chart height — smaller on mobile */
  .chartCanvasShell{height:220px}
  .sidePreview .chartCanvasShell{height:220px}
  /* Section heading */
  .sectionTitle{font-size:26px !important;margin:18px 0 6px !important}
  .sectionSub{font-size:13px}
  /* emptyCard */
  .emptyCard{padding:20px 16px}
  /* tableTools: stack title above controls */
  .tableTools{flex-direction:column;align-items:flex-start;gap:8px;margin-bottom:14px}
  .tableTools__right{width:100%;justify-content:space-between}
  .tableTools__actions .btnPdfExport--compact{height:38px;padding:0 14px}
  .segBtn{height:36px;padding:0 12px;font-size:12px}
  /* Tooltip overflow guard */
  .tip,.sidePreview .tip{min-width:120px;max-width:calc(100vw - 24px)}
  /* kpis grid */
  .kpis{grid-template-columns:1fr 1fr !important}
}
@media(max-width:420px){
  /* Extra-small phones — layout & sizing (no h1/h2 here, handled at end of file) */
  .container{padding:6px 10px 32px}
  .card{padding:14px;border-radius:14px}
  .summary{padding:12px 14px}
  .tableWrap{padding:10px 12px 14px}
  .kpisTop{grid-template-columns:1fr}
  .vtd-color-swatch,.vtd-color-swatch-img{width:min(100%,80px)}
  .chartCanvasShell{height:190px}
  .sidePreview .chartCanvasShell{height:190px}
  .sectionTitle{font-size:22px !important}
  .emptyCard{padding:16px 12px}
}
.summary #verdictDesc{display:block;margin-top:10px;line-height:1.56}
.summary #verdictDesc + .mutedSmall{display:block;margin-top:10px !important;line-height:1.5}
.summaryTopRight{display:flex;align-items:center;gap:10px;margin-left:auto}
.summaryTopRight .btnPdfExport{height:36px;padding:0 14px;border-radius:12px;font-size:13px;letter-spacing:.01em;box-shadow:0 6px 14px rgba(198,40,40,.18), inset 0 1px 0 rgba(255,255,255,.16)}
.summaryTopRight .btnPdfExport:hover{box-shadow:0 10px 18px rgba(183,28,28,.22), inset 0 1px 0 rgba(255,255,255,.14)}
.summaryActions{margin-top:16px;display:flex;gap:10px;flex-wrap:wrap}
.summaryActions .btnAddSummary,
.summaryActions .btnPdfExport{
  height:44px;
  padding:0 18px;
  border-radius:14px;
  font-size:15px;
  line-height:1;
}
.btnAddSummary{
  border:1px solid #047857;
  background:linear-gradient(135deg,#10b981 0%, #059669 100%);
  color:#fff;
  font-weight:700;
  letter-spacing:.01em;
  box-shadow:0 10px 18px rgba(5,150,105,.2), inset 0 1px 0 rgba(255,255,255,.2);
}
.btnAddSummary:hover{
  background:linear-gradient(135deg,#059669 0%, #047857 100%);
  border-color:#065f46;
  transform:translateY(-1px);
  box-shadow:0 14px 24px rgba(5,150,105,.24), inset 0 1px 0 rgba(255,255,255,.18);
}
.btnAddSummary:focus-visible{
  outline:none;
  box-shadow:0 0 0 4px rgba(5,150,105,.22), 0 10px 18px rgba(5,150,105,.2), inset 0 1px 0 rgba(255,255,255,.2);
}
.btnAddSummary:active{
  transform:translateY(0);
  box-shadow:0 6px 12px rgba(5,150,105,.18), inset 0 1px 0 rgba(255,255,255,.16);
}
.btnPdfExport{
  border:1px solid #d32f2f;
  background:linear-gradient(135deg,#ed1c24 0%,#c62828 100%);
  color:#fff;
  font-weight:700;
  letter-spacing:.01em;
  box-shadow:0 10px 18px rgba(198,40,40,.22), inset 0 1px 0 rgba(255,255,255,.18);
}
.btnPdfExport:hover{
  background:linear-gradient(135deg,#d32f2f 0%,#b71c1c 100%);
  border-color:#b71c1c;
  transform:translateY(-1px);
  box-shadow:0 14px 24px rgba(183,28,28,.26), inset 0 1px 0 rgba(255,255,255,.14);
}
.btnPdfExport:focus-visible{
  outline:none;
  box-shadow:0 0 0 4px rgba(211,47,47,.24), 0 10px 18px rgba(198,40,40,.22), inset 0 1px 0 rgba(255,255,255,.18);
}
.btnPdfExport:active{
  transform:translateY(0);
  box-shadow:0 6px 12px rgba(183,28,28,.2), inset 0 1px 0 rgba(255,255,255,.14);
}
.btnPdfExport:disabled{
  border-color:#fecaca;
  background:linear-gradient(135deg,#fca5a5 0%,#f87171 100%);
  color:#fff;
  cursor:not-allowed;
  transform:none;
  box-shadow:none;
}
@media (max-width:680px){.summaryTopRight{width:100%;justify-content:flex-start;margin-left:0;margin-top:4px}}
.verdict{display:inline-flex;align-items:center;border:1px solid var(--line);border-radius:999px;padding:5px 10px;font-size:12px;font-weight:700}
.verdict.good{background:#ecfdf5;border-color:#a7f3d0;color:#047857}
.verdict.bad{background:#fef2f2;border-color:#fecaca;color:#b42318}
.verdict.muted{background:#f8fafc;border-color:var(--line);color:#475569}
.verdict.warn{background:#fffbeb;border-color:#fde68a;color:#b45309}
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;padding:10px}.kpi{border:1px solid var(--line);border-radius:12px;background:#f8fafc;padding:10px}.kpi__label{font-size:11px;color:var(--muted)}.kpi__val{font-weight:700;margin-top:4px}.kpi__meta{font-size:11px;color:var(--muted);margin-top:4px}
.chartWrap{padding:12px}.chartHead{display:flex;justify-content:space-between;gap:8px;align-items:center}.chartCanvasShell{height:340px;position:relative;margin-top:10px}.chartCanvasShell canvas{width:100%;height:100%;display:block;border:none;border-radius:10px;background:#fff}.tip{display:none;position:absolute;background:#0b1736;color:#fff;border-radius:10px;padding:8px 10px;font-size:12px;min-width:180px;pointer-events:none}
.tableWrap{padding:16px 20px 20px}.tableTools{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px;gap:12px;padding-bottom:14px;border-bottom:1px solid var(--line)}.tableTools__title{font-size:clamp(20px,2.2vw,34px);font-weight:800;color:#0f172a;letter-spacing:-.02em;line-height:1.08}.tableTools__right{display:flex;align-items:center;gap:8px}.seg{display:flex;gap:6px}.segBtn{border:1px solid var(--line);background:#fff;border-radius:10px;padding:6px 10px;cursor:pointer;font-size:12px}.segBtn[aria-pressed=true]{background:var(--navy);color:#fff;border-color:var(--navy)}.sortSel{height:34px;border:1px solid var(--line);border-radius:10px;padding:0 8px}
.tableTools__actions{display:flex;align-items:center;gap:8px}
/* Share button */
.btnShare{display:inline-flex;align-items:center;gap:6px;border:1px solid #2563eb;background:linear-gradient(135deg,#3b82f6 0%,#1d4ed8 100%);color:#fff;font-weight:700;letter-spacing:.01em;box-shadow:0 4px 12px rgba(37,99,235,.22),inset 0 1px 0 rgba(255,255,255,.18);border-radius:10px;cursor:pointer;transition:background .15s,box-shadow .15s,transform .1s}
.btnShare:hover{background:linear-gradient(135deg,#2563eb 0%,#1e40af 100%);border-color:#1d4ed8;transform:translateY(-1px);box-shadow:0 6px 16px rgba(29,78,216,.28),inset 0 1px 0 rgba(255,255,255,.14)}
.btnShare:active{transform:translateY(0);box-shadow:0 2px 6px rgba(29,78,216,.2)}
.btnShare:disabled{background:linear-gradient(135deg,#93c5fd 0%,#60a5fa 100%);border-color:#bfdbfe;color:#fff;cursor:not-allowed;transform:none;box-shadow:none}
.btnShare--compact{height:34px;padding:0 13px;font-size:12px}
.tableTools__actions .btnPdfExport--compact{display:inline-flex;align-items:center;gap:5px;height:34px;padding:0 12px;border-radius:10px;font-size:12px;font-weight:700;letter-spacing:.01em;box-shadow:0 4px 10px rgba(198,40,40,.16),inset 0 1px 0 rgba(255,255,255,.14)}
.tableTools__actions .btnPdfExport--compact:hover{box-shadow:0 6px 14px rgba(183,28,28,.2),inset 0 1px 0 rgba(255,255,255,.12)}
.table{width:100%;border-collapse:separate;border-spacing:0 8px}.table th{font-size:12px;color:var(--muted);text-align:left;padding:0 8px 4px}.table td{padding:10px 8px;background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line);font-size:13px}.table td:first-child{border-left:1px solid var(--line);border-radius:10px 0 0 10px}.table td:last-child{border-right:1px solid var(--line);border-radius:0 10px 10px 0}.table tr.row-bad td{background:#fef2f2;border-color:#fecaca}.mono{font-variant-numeric:tabular-nums}.right{text-align:right}.nowrap{white-space:nowrap}.muted{color:var(--muted)}.note-pill{display:inline-block;background:#f1f5f9;border-radius:999px;padding:3px 8px;font-size:11px}
.placeText{display:-webkit-box;display:box;-webkit-box-orient:vertical;box-orient:vertical;-webkit-line-clamp:2;line-clamp:2;overflow:hidden;text-overflow:ellipsis;white-space:normal;overflow-wrap:anywhere;word-break:break-word;line-height:1.35;max-height:calc(1.35em * 2)}
.noteMobile{display:none}
.sourceMobile{display:none}
.dateCell{display:inline-flex;align-items:baseline;gap:4px}.dateCell__day,.dateCell__year{display:inline}
.badge{display:inline-flex;align-items:center;gap:5px;border:1px solid var(--line);border-radius:999px;padding:3px 9px;font-size:12px;font-weight:500;background:#fff}.badge__dot{width:6px;height:6px;border-radius:50%;background:#94a3b8}.badge--verified{background:#ecfdf5;border-color:#bbf7d0}.badge--verified .badge__dot{background:#10b981}.badge--unverified{background:#fff7ed;border-color:#fdba74}.badge--unverified .badge__dot{background:#f59e0b}.badge--suspicious{background:#fef2f2;border-color:#fca5a5}.badge--suspicious .badge__dot{background:#ef4444}.badge--src-verified{background:#ecfeff;border-color:#a5f3fc}.badge--src-verified .badge__dot{background:#0891b2}.badge--src-community{background:#fff7ed;border-color:#fed7aa}.badge--src-community .badge__dot{background:#f97316}.badge--src-import{background:#f5f3ff;border-color:#ddd6fe}.badge--src-import .badge__dot{background:#8b5cf6}
/* modals */
dialog{border:none;border-radius:16px;padding:0;box-shadow:0 30px 90px rgba(2,6,23,.25);width:min(560px,calc(100% - 24px))}dialog::backdrop{background:rgba(15,23,42,.35)}.modal{padding:18px;position:relative}.modal-close{position:absolute;top:12px;right:12px;width:32px;height:32px;border:none;background:#f8fafc;border-radius:8px;cursor:pointer;font-size:20px;color:#6b7280;display:flex;align-items:center;justify-content:center;transition:all 0.2s}.modal-close:hover{background:#ecf0f1;color:#1f2937}.modal-close:focus{outline:2px solid var(--navy);outline-offset:1px}.field label{display:block;font-size:13px;font-weight:600;margin-bottom:6px}.field input{width:100%;border:1px solid var(--line);border-radius:10px;padding:10px}.errorMessage{min-height:16px;font-size:12px;color:#dc2626;margin-top:4px}.fieldWrap.is-error input,.fieldWrap.is-error .readonly{border-color:#ef4444}.modalActions{display:flex;justify-content:flex-end;gap:8px;margin-top:12px}.flash{margin:10px 0;padding:10px 12px;border:1px solid var(--line);border-radius:12px;background:#fff;display:flex;justify-content:space-between;align-items:center}.flash--success{background:#ecfdf5;border-color:#bbf7d0}.flash--info{background:#ecfeff;border-color:#a5f3fc}.flash__left{display:flex;gap:10px;align-items:center}.flash__dot{width:8px;height:8px;border-radius:50%;background:#10b981}.flash--info .flash__dot{background:#0891b2}.flash__x{border:0;background:none;font-size:16px;cursor:pointer;color:var(--muted)}
@media (max-width:980px){.hero{grid-template-columns:1fr}.trust{grid-template-columns:1fr}.featureGrid{grid-template-columns:1fr 1fr}.kpis{grid-template-columns:1fr 1fr}.heroCardMain h1{font-size:40px}}
@media (max-width:980px){
  .table{table-layout:fixed;width:100%}
  .table th,.table td{white-space:normal;overflow-wrap:anywhere;word-break:break-word}
  .table td.nowrap{white-space:normal}
  .table th:nth-child(1),.table td:nth-child(1){width:88px}
  .table th:nth-child(2),.table td:nth-child(2){width:110px}
  .table th:nth-child(4),.table td:nth-child(4){width:128px}
  .table th:nth-child(5),.table td:nth-child(5){width:118px}
  .table td:nth-child(3){overflow-wrap:anywhere;word-break:break-word}
}
@media (max-width:680px){.searchRow{display:grid;grid-template-columns:1fr;align-items:end;gap:10px}.searchRow .vinInput{grid-column:1;grid-row:1}.searchRow #submitBtn{grid-column:1;grid-row:2;width:100%;justify-self:stretch}.searchRow #vinError{grid-column:1;grid-row:3;min-height:0}.featureGrid{grid-template-columns:1fr}.kpisTop{grid-template-columns:1fr}.kpis{grid-template-columns:1fr}.brand__logo{height:38px}.brand__name{font-size:21px}.brand__tagline{font-size:10px}.dateCell{flex-direction:column;align-items:flex-start;gap:0;line-height:1.15}.dateCell__year{font-size:12px;color:var(--muted)}.pvMakeLogo{width:38px;height:38px}}
@media (max-width:680px){.tableWrap .table th:nth-child(4),.tableWrap .table td:nth-child(4),.tableWrap .table th:nth-child(5),.tableWrap .table td:nth-child(5){display:none}}
@media (max-width:680px){.sourceMobile{display:block;margin-top:6px;font-size:11px;line-height:1.35;white-space:normal}.sourceMobile__label{color:var(--muted);font-weight:600}.sourceMobile__value{color:#334155}}
@media (max-width:680px){.noteMobile{display:block;margin-top:6px;font-size:11px;line-height:1.35;white-space:normal}.noteMobile__label{color:var(--muted);font-weight:600}.noteMobile__value{color:#334155}}
@media (max-width:420px){.searchRow{grid-template-columns:1fr;gap:10px}.searchRow .vinInput{grid-column:1;grid-row:1}.searchRow #submitBtn{grid-column:1;grid-row:2;width:100%;justify-self:stretch}.searchRow #vinError{grid-column:1;grid-row:3}}

/* Hero chart placement (single chart only) */
@media (min-width:1100px){
  .pvMakeLogo{width:88px;height:88px}
  .pvMakeName{font-size:clamp(22px,2.4vw,32px)}
  .pvScoreBadge{width:128px;height:96px}
  .pvScoreNum{font-size:28px}
  .pvScoreSuffix{font-size:20px}
}
.chartWrap--hero{margin-top:22px;padding:0;border-radius:0;box-shadow:none}
.sidePreview .chartHead strong{
  font-size:clamp(24px,2.2vw,34px);
  line-height:1.08;
  letter-spacing:-.02em;
  font-weight:800;
  color:#0f172a;
}
.sidePreview .chartHead{
  margin-bottom:13px;
  padding-top:0;
  margin-top:-15px;
  border-bottom:none;
}
.sidePreview #chartHint{
  display:none;
}
.sidePreview .chartCanvasShell{
  margin-top:6px;
}
@media (max-width:900px){
  .sidePreview .chartHead{
    flex-direction:column;
    align-items:flex-start;
    gap:6px;
  }
  .sidePreview #chartHint{
    text-align:left;
  }
}
.sidePreview .chartCanvasShell{height:380px}
.sidePreview .tip{min-width:150px}

/* v5 graph polish */
.chartWrap--hero,.sidePreview .chartWrap{background:transparent!important;border:none!important;box-shadow:none!important;padding:6px 0!important;}
.sidePreview .chartCanvasShell{height:380px}
.chartCanvasShell canvas{background:transparent;}
#tip{box-shadow:0 10px 30px rgba(2,6,23,.18);border:1px solid rgba(255,255,255,.2)}
.tip__lbl{opacity:.6;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.04em}

.topbar .chip{display:none}
.sidePreview .header{align-items:flex-start}
.headerLeft{flex:1;min-width:0}
.headerRight{display:flex;flex-direction:column;align-items:flex-end;gap:8px;flex-shrink:0;margin-left:12px}
/* Brand name — prominent */
.pvMake{
  display:flex;
  align-items:center;
  gap:12px;
  margin-bottom:2px;
}
.pvMake:empty{display:none}
.pvMakeLogo{
  width:72px;
  height:72px;
  object-fit:contain;
  flex-shrink:0;
  border-radius:10px;
}
.pvMakeInfo{
  display:flex;
  flex-direction:column;
  gap:3px;
}
.pvMakeName{
  font-size:clamp(18px,2.2vw,30px);
  font-weight:800;
  color:#0f172a;
  letter-spacing:-.022em;
  line-height:1.1;
}
.pvMakeYear{
  font-size:13px;
  font-weight:600;
  color:#64748b;
  letter-spacing:.01em;
}
/* VIN — pod rok výroby */
.pvVin{display:none}
.pvVinRow{
  display:block;
  font-size:13px;
  font-weight:600;
  color:#64748b;
  letter-spacing:.01em;
  margin-top:2px;
}
.pvVinRow strong{
  font-weight:600;
  color:#64748b;
}
.pvVinRow:empty{display:none}
.chartVin{position:absolute;bottom:32px;right:14px;font-size:10px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;color:#cbd5e1;font-weight:600;letter-spacing:.14em;text-transform:uppercase;line-height:1;pointer-events:none;z-index:1}
.chartVin:empty{display:none}
/* Trust score badge */
.pvScoreBadge{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  width:118px;
  height:90px;
  border-radius:14px;
  background:#f8fafc;
  border:1.5px solid #e2e8f0;
  transition:background .3s,border-color .3s,color .3s;
  flex-shrink:0;
  gap:0;
  padding:8px 10px;
}
.pvScoreLbl{
  font-size:8px;
  color:#94a3b8;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.07em;
  text-align:center;
  line-height:1.2;
  white-space:nowrap;
  margin-bottom:5px;
}
.pvScoreNum{
  font-size:26px;
  font-weight:900;
  line-height:1;
  color:#475569;
  letter-spacing:-.03em;
  transition:color .3s;
  display:flex;
  align-items:baseline;
  gap:0;
}
.pvScoreSuffix{
  font-size:18px;
  font-weight:700;
  color:#94a3b8;
  letter-spacing:-.02em;
  margin-left:2px;
}
.pvScoreText{
  font-size:12px;
  font-weight:600;
  color:#94a3b8;
  text-align:center;
  line-height:1.3;
  margin-top:5px;
  white-space:normal;
}
/* 3-digit score (100) — scale down to fit fixed badge */
.pvScoreBadge--d3 .pvScoreNum    { font-size:20px }
.pvScoreBadge--d3 .pvScoreSuffix { font-size:13px }
.pvScoreBadge--d3 .pvScoreText   { font-size:9px; letter-spacing:-.02em }
@media (min-width:1100px){
  .pvScoreBadge--d3 .pvScoreNum    { font-size:22px }
  .pvScoreBadge--d3 .pvScoreSuffix { font-size:15px }
  .pvScoreBadge--d3 .pvScoreText   { font-size:10px }
}
/* 5-tier score colors */
.pvScoreBadge.score--5{background:#f0fdf4;border-color:#86efac}
.pvScoreBadge.score--5 .pvScoreNum{color:#15803d}
.pvScoreBadge.score--5 .pvScoreText{color:#15803d}
.pvScoreBadge.score--4{background:#f0fdf4;border-color:#bbf7d0}
.pvScoreBadge.score--4 .pvScoreNum{color:#16a34a}
.pvScoreBadge.score--4 .pvScoreText{color:#16a34a}
.pvScoreBadge.score--3{background:#fefce8;border-color:#fde047}
.pvScoreBadge.score--3 .pvScoreNum{color:#a16207}
.pvScoreBadge.score--3 .pvScoreText{color:#a16207}
.pvScoreBadge.score--2{background:#fff7ed;border-color:#fed7aa}
.pvScoreBadge.score--2 .pvScoreNum{color:#c2410c}
.pvScoreBadge.score--2 .pvScoreText{color:#c2410c}
.pvScoreBadge.score--1{background:#fef2f2;border-color:#fecaca}
.pvScoreBadge.score--1 .pvScoreNum{color:#dc2626}
.pvScoreBadge.score--1 .pvScoreText{color:#dc2626}
.sidePreview .kpiBox.kpiBox--riskHigh{
  background:#fef2f2;
  border-color:#fecaca;
}
.sidePreview .kpiBox.kpiBox--riskLow{
  background:#ecfdf5;
  border-color:#bbf7d0;
}
.sidePreview .kpiBox.kpiBox--riskNeutral{
  background:#f8fafc;
  border-color:var(--line);
}
.btnSm{padding:8px 12px;font-size:13px;border-radius:12px}
.sectionSub{max-width:860px}

.fieldControl{position:relative}.fieldControl .fieldIcon{position:absolute;left:10px;top:50%;transform:translateY(-50%);font-size:14px;opacity:.75;pointer-events:none}.fieldControl input,.fieldControl .readonly{width:100%;border:1px solid var(--line);border-radius:10px;padding:10px 10px 10px 34px;background:#fff}.fieldControl .readonly{min-height:42px;display:flex;align-items:center;background:#f8fafc}.fieldWrap.is-error .fieldControl input,.fieldWrap.is-error .fieldControl .readonly{border-color:#ef4444}.field--check{margin-top:12px}.checkRow{display:flex;align-items:center;gap:8px;font-size:13px}.checkRow input{width:16px;height:16px}



.headerSupport{margin-left:auto;display:inline-flex;align-items:center;gap:6px;height:44px;padding:0 18px;color:#2563eb!important;border-color:#bfdbfe;font-weight:600;font-size:13px;line-height:1;white-space:nowrap}
.headerSupport:hover{background:#eff6ff;border-color:#93c5fd}
.headerAdd{margin-left:8px}
.headerAdd.btnAdd{height:44px;padding:0 18px;border-radius:14px;font-size:15px;font-weight:700;letter-spacing:.005em;background:linear-gradient(135deg,#0891b2 0%,#0f1724 100%);border-color:#0c7a9c;box-shadow:0 10px 24px rgba(8,145,178,.22), inset 0 1px 0 rgba(255,255,255,.14)}
.headerAdd.btnAdd:hover{background:linear-gradient(135deg,#06b6d4 0%,#0c7a9c 100%);border-color:#0891b2;transform:translateY(-1px);box-shadow:0 14px 28px rgba(8,145,178,.3), inset 0 1px 0 rgba(255,255,255,.12)}
.headerAdd.btnAdd:focus-visible{outline:none;box-shadow:0 0 0 4px rgba(8,145,178,.3), 0 10px 24px rgba(8,145,178,.22)}
@media (max-width:720px){.headerAdd{height:40px;padding:0 14px;font-size:14px;border-radius:12px}}

/* UX polishing */
.inputWrap input:focus{outline:none;border-color:#0891b2;box-shadow:0 0 0 4px rgba(8,145,178,.12), 0 4px 12px rgba(8,145,178,.15)}
.inputWrap input:focus-visible{outline:none;border-color:#0f172a;box-shadow:0 0 0 4px rgba(15,23,42,.12), 0 4px 12px rgba(15,23,42,.15)}
.inputWrap.vinInput input:focus{border-color:#0891b2;box-shadow:0 0 0 4px rgba(8,145,178,.12), 0 6px 20px rgba(8,145,178,.15)}
.vinHint{margin-top:8px;font-size:12px;line-height:1.5;color:#64748b}
.vinDecode{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px;min-height:0}
.vinDecode:empty{margin-top:0}
.vinDecode__item{display:inline-flex;align-items:center;gap:6px;background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:5px 12px;font-size:13px;line-height:1.3;box-shadow:0 1px 3px rgba(15,23,42,.05)}
.vinDecode__lbl{color:#64748b;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.vinDecode__item strong{color:#0f172a;font-weight:700}

/* Inline field validation */
.fieldError{min-height:18px;margin-top:8px;font-size:12px;line-height:1.3;color:#b42318;}
.inputInvalid{border-color:#f04438 !important; box-shadow:0 0 0 4px rgba(240,68,56,.15) !important;}
/* Empty state card polish */
.emptyState{display:none;margin-top:16px;}
.emptyCard{width:100%;border:1px solid var(--line);background:#fff;border-radius:16px;padding:28px 32px 26px;box-shadow:var(--shadow);text-align:center;}
.emptyCard__head{display:flex;align-items:center;gap:9px;justify-content:center;margin-bottom:6px;}
.emptyCard__iconInline{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:10px;background:#eff6ff;flex-shrink:0;}
.emptyCard__title{font-weight:700;font-size:17px;color:#0f172a;}
.emptyCard__vin{font-family:'Segoe UI Mono','SF Mono','Fira Code','Fira Mono','Roboto Mono',monospace;font-size:16px;font-weight:600;color:#e2e8f0;background:#0f172a;border:none;border-radius:14px;padding:10px 28px;display:block;width:fit-content;margin:0 auto 18px;letter-spacing:.22em;text-transform:uppercase;box-shadow:0 2px 12px rgba(15,23,42,.28),inset 0 1px 0 rgba(255,255,255,.06);}
.emptyCard__desc{font-size:13px;color:#475569;line-height:1.6;margin-bottom:10px;max-width:560px;margin-left:auto;margin-right:auto;}
.emptyCard__demo{font-size:12px;color:#64748b;margin-bottom:18px;padding:8px 14px;background:#f8fafc;border-radius:8px;border:1px dashed #cbd5e1;display:inline-block;}
.emptyCard__actions{display:flex;justify-content:center;gap:8px;flex-wrap:wrap;}
/* Risk highlight */
.riskHigh{color:#b42318;}
.riskLow{color:#047857;}
.riskNeutral{color:#475569;}
.riskHighPill{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border-radius:999px;border:1px solid rgba(180,35,24,.25);background:rgba(180,35,24,.08);color:#b42318;font-weight:650;}
.kpi__meta.anomalyWarn{color:#b45309;font-weight:600}
.kpi__meta.anomalyOk{color:#047857;font-weight:600}
.kpi__meta.anomalyMuted{color:#475569}


/* Pagination */
.pager{display:flex; justify-content:center; align-items:center; gap:8px; margin-top:20px; padding:0 80px; position:relative; flex-wrap:wrap}
.pager.hidden{display:none}
.pgBtn{height:36px; min-width:36px; padding:0 12px; border:1.5px solid #e2e8f0; background:#fff; border-radius:10px; cursor:pointer; font-weight:700; font-size:16px; color:#374151; transition:background .15s,border-color .15s}
.pgBtn:hover:not([disabled]){background:#f1f5f9; border-color:#cbd5e1}
.pgBtn[disabled]{opacity:.35; cursor:not-allowed}
.pgNumbers{display:flex; align-items:center; gap:5px; flex-wrap:wrap}
.pgNum{height:36px; min-width:36px; padding:0 10px; border:1.5px solid #e2e8f0; background:#fff; border-radius:10px; cursor:pointer; font-weight:600; font-size:14px; color:#374151; transition:background .15s,border-color .15s}
.pgNum:hover:not([aria-current="page"]){background:#f1f5f9; border-color:#cbd5e1}
.pgNum[aria-current="page"]{background:#0f172a; color:#fff; border-color:#0f172a; box-shadow:0 2px 6px rgba(15,23,42,.2)}
.pgEll{padding:0 4px; color:#94a3b8; font-weight:700; font-size:15px}
.pgMeta{position:absolute; right:0; color:#94a3b8; font-size:12px; font-weight:500; white-space:nowrap}
@media (max-width: 640px){
  .pager{padding:0; justify-content:center}
  .pgMeta{position:static; width:100%; text-align:center; margin-top:6px}
}


/* VIN input inline counter */
.inputWrap.vinInput{position:relative;}
.inputWrap.vinInput input{padding-right:110px;}
.inputCounter{position:absolute;right:50px;top:50%;transform:translateY(-50%);font-size:12px;line-height:1;letter-spacing:.2px;color:#164e63;background:#cffafe;border:none;border-radius:999px;padding:6px 10px;user-select:none;font-weight:600}
@media (max-width:480px){.brand__logo{height:32px}}
@media (max-width:520px){
  .inputWrap.vinInput input{padding-right:110px;}
  .inputCounter{right:48px;}
}

/* VIN search — button absolutně uvnitř inputu, counter vlevo od něj */
.vinLabelRow{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:6px}
.vinLabelRow .inputLabel{margin-bottom:0}
.vinLabelRow .inputHelpBtn{position:static;transform:none;height:30px;width:30px}
.vinField{position:relative;display:block}
.vinFieldMain{position:relative;display:block}
.vinField #vin{padding-right:188px;width:100%}
.vinInputActions{position:absolute;right:130px;top:8px;bottom:8px;display:flex;flex-direction:column;align-items:center;justify-content:space-between;pointer-events:none}
.vinCounterInline{display:block;font-weight:700;font-size:13px;color:#94a3b8;font-variant-numeric:tabular-nums;letter-spacing:.02em;line-height:1;background:none;border:none;padding:0}
.clearVinBtn{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border:none;background:none;padding:0;cursor:pointer;color:#94a3b8;opacity:.55;transition:color .2s,opacity .2s,background .2s;pointer-events:auto;border-radius:10px;flex-shrink:0}
.clearVinBtn:hover{color:#2563eb;opacity:1;background:rgba(37,99,235,.09)}
.clearVinBtn.has-value{opacity:.7;color:#94a3b8}
.clearVinBtn.has-value:hover{color:#ef4444;opacity:1;background:rgba(239,68,68,.09)}
.clearVinBtn .vinBtn-camera{display:block}
.clearVinBtn .vinBtn-trash{display:none}
.clearVinBtn.has-value .vinBtn-camera{display:none}
.clearVinBtn.has-value .vinBtn-trash{display:block}
.vinField #submitBtn{position:absolute;right:6px;top:50%;transform:translateY(-50%);height:calc(100% - 12px);padding:0 22px;border-radius:14px;font-size:16px;font-weight:800;letter-spacing:.01em;white-space:nowrap;background:linear-gradient(135deg,#2563EB 0%,#1d4ed8 100%);box-shadow:0 2px 12px rgba(37,99,235,.30);transition:all .2s}
.vinField #submitBtn:hover{background:linear-gradient(135deg,#1d4ed8 0%,#1e40af 100%);box-shadow:0 4px 20px rgba(37,99,235,.45)}
.vinField #submitBtn:active{box-shadow:0 2px 8px rgba(37,99,235,.3)}
.vinField #submitBtn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}

@media (max-width:680px){
  .vinField #vin{padding-right:62px}
  .vinInputActions{right:8px;flex-direction:row;align-items:center;gap:4px;top:50%;bottom:auto;transform:translateY(-50%)}
  .vinField #submitBtn{position:static;transform:none;width:100%;height:54px;border-radius:14px;font-size:16px;margin-top:10px;display:flex;align-items:center;justify-content:center}
}
@media (max-width:420px){
  .vinField #submitBtn{font-size:15px;height:50px}
}


/* No-data illustration shown in the chart area when VIN has no records */
.noDataImg{
  width: 100%;  height: 100%;  max-height: 360px;  object-fit: contain;
  display: block;
  border-radius: 14px;
  background: #ffffff;
  border: 1px solid var(--line);
  padding: 10px;
}

/* Add modal visual refinement (logic unchanged) */
#addModal .modal{padding:24px 24px 20px;font-size:15px;line-height:1.45;color:#1f2937}
#addModal h3{margin:2px 0 8px;font-size:30px;line-height:1.14;font-weight:700;letter-spacing:-.018em;color:#0b1736}
#addModal .sectionSub{font-size:15px;line-height:1.55;color:#475569;max-width:none}
#addModal .field{margin-top:12px}
#addModal .field label{font-size:13px;font-weight:600;letter-spacing:.24px;text-transform:none;color:#334155}
#addModal .fieldControl input,
#addModal .fieldControl .readonly{height:52px;border:2px solid var(--line);border-radius:14px;padding:0 12px 0 40px;background:#fff;font-size:17px;font-weight:600;line-height:1.4;color:#1f2937;transition:all 0.2s}
#addModal .fieldControl input::placeholder{font-family:inherit;font-weight:700;font-size:15px;color:#94a3b8;letter-spacing:normal}
#addModal .fieldControl .readonly{display:flex;align-items:center}
.addDateInfo{display:flex;align-items:baseline;gap:8px;padding:4px 0 2px}
.addDateLabel{font-size:13px;font-weight:600;color:#64748b}
.addDateValue{font-size:17px;font-weight:700;color:#0f172a}
.addDateNote{font-size:11px;color:#94a3b8;font-weight:400}
.addFormConsent{font-size:12.5px;color:#94a3b8;text-align:center;margin:10px 0 8px;}
#addDateWrapper{margin-top:-32px;}
#addModal .fieldControl--vin{--vin-counter-w:56px;position:relative}
#addModal .fieldControl--vin input{padding-right:calc(var(--vin-counter-w) + 52px)}
#addModal .fieldControl--vin .vscan-trigger{right:calc(var(--vin-counter-w) + 12px);top:50%;transform:translateY(-50%);position:absolute}
#addModal .addVinCounter{right:8px;top:50%;transform:translateY(-50%);font-size:12px;padding:6px 9px;color:#164e63;background:#cffafe;border-radius:999px;line-height:1;font-weight:700;min-width:var(--vin-counter-w);text-align:center}
#addModal .addVinLabelRow{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
#addModal .addVinLabelRow label{margin-bottom:0!important}
#addModal .addVinHelpBtn{position:static!important;width:auto!important;height:28px;padding:0 12px;border:1px solid rgba(15,23,42,.12);border-radius:999px;background:#f8fafc;color:#0f172a;font-size:12px;font-weight:700;line-height:28px;display:inline-flex;align-items:center;justify-content:center;white-space:nowrap;transform:none!important;flex-shrink:0}
#addModal .addVinHelpBtn:hover{background:#eef2f7;border-color:#cbd5e1;transform:none!important}
#addModal .addVinHelpBtn:focus{outline:2px solid rgba(37,99,235,.25);outline-offset:2px}
#addModal .fieldControl input:focus,
#addModal .fieldControl .readonly:focus{outline:none;border-color:#0891b2;box-shadow:0 0 0 4px rgba(8,145,178,.12), 0 4px 12px rgba(8,145,178,.15)}
#addModal .fieldControl input:focus-visible{outline:none;border-color:#0891b2;box-shadow:0 0 0 4px rgba(8,145,178,.12), 0 4px 12px rgba(8,145,178,.15)}
#addModal .fieldIcon{left:12px;top:50%;transform:translateY(-50%);width:16px;height:16px;display:grid;place-items:center;font-size:0;color:#64748b;opacity:1}
#addModal .fieldIcon::before{font-size:14px;line-height:1;font-weight:700}
#addModal .icon-vin::before{content:"▭";font-size:15px;font-weight:700;letter-spacing:0}
#addModal .icon-date::before{content:"◷"}
#addModal .icon-km::before{content:"⇅"}
#addModal .icon-place::before{content:"";display:block;width:14px;height:14px;background-repeat:no-repeat;background-position:center;background-size:14px 14px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%230f1724' d='M12 22s7-6.2 7-12a7 7 0 10-14 0c0 5.8 7 12 7 12z'/%3E%3Ccircle cx='12' cy='10' r='3.2' fill='%2322d3ee'/%3E%3C/svg%3E")}
#addModal .field--check{margin-top:10px;margin-bottom:12px;padding:12px 12px;border:1px solid var(--line);border-radius:12px;background:#fff}
#addModal .checkRow{display:flex;align-items:center;gap:10px;font-size:15px;font-weight:600;line-height:1.2;color:#334155}
#addModal .checkRow input{accent-color:var(--navy);margin:0;width:22px;height:22px;flex:0 0 auto}
#addModal #gRecaptchaWidget{margin-top:4px}
#addModal .modalActions{margin-top:16px;gap:10px}
#addModal #addCancel{height:44px;padding:0 16px;border-radius:12px;font-size:15px;font-weight:600}
#addModal #addSubmitBtn{height:52px;padding:0 32px;border-radius:14px;font-size:18px;font-weight:700}
#addModal #addSubmitBtn:disabled{opacity:.55;cursor:not-allowed;filter:saturate(.7);box-shadow:none;transform:none}
#addModal .errorMessage{font-size:13px;margin-top:6px}
#addVinWrapper .fieldControl input{font-family:inherit;font-size:17px;font-weight:600;letter-spacing:normal;background:#fff;border-color:var(--line);color:#1f2937}
#addVinWrapper .fieldControl input:focus{border-color:#0891b2;box-shadow:0 0 0 4px rgba(8,145,178,.12), 0 4px 12px rgba(8,145,178,.15);background:#fff}
#addVinWrapper .fieldControl input::placeholder{font-family:inherit;font-size:15px;letter-spacing:normal;font-weight:700;color:#94a3b8}

/* How VIN modal refinement */
#howVinModal .modal{padding:32px 32px 24px}
#howVinModal .modal-close,
#addModal .modal-close{
  border:none;
  background:#f1f5f9;
  color:#94a3b8;
  box-shadow:none;
}
#howVinModal .modal-close:hover,
#addModal .modal-close:hover{
  background:#e2e8f0;
  color:#64748b;
}
#howVinModal .modal-close,
#addModal .modal-close{
  width:40px;
  height:40px;
  border-radius:999px;
  border:none !important;
  outline:none !important;
  appearance:none;
  -webkit-appearance:none;
}
#howVinModal .modal-close:focus,
#howVinModal .modal-close:focus-visible,
#howVinModal .modal-close:active,
#addModal .modal-close:focus,
#addModal .modal-close:focus-visible,
#addModal .modal-close:active{
  border:none !important;
  outline:none !important;
  box-shadow:none !important;
}
#howVinModal h3{margin:2px 0 12px;font-size:40px;line-height:1.12;font-weight:800;letter-spacing:-.02em;color:#0b1736}
#howVinModal .sectionSub{font-size:16px;line-height:1.6;color:#475569;max-width:none;margin:0}
#howVinModal .vinTips{margin:16px 0 10px 0;padding-left:22px;color:#1e293b;font-size:15px;line-height:1.6}
#howVinModal .vinTips li{margin-bottom:10px;padding-left:4px}
#howVinModal .vinTips__note{margin-top:14px;font-size:14px;color:#64748b;line-height:1.6}

/* Close icon size consistency */
.modal-close{width:36px;height:36px;font-size:24px}
.flash__x{font-size:18px}
@media (max-width:620px){#addModal .fieldControl--vin{--vin-help-w:88px;--vin-counter-w:50px}#addModal .fieldControl--vin input{padding-right:calc(var(--vin-help-w) + var(--vin-counter-w) + 20px)}#addModal .addVinHelpBtn{height:32px;font-size:11px;padding:0 8px}#addModal .addVinCounter{font-size:11px;padding:5px 8px}}

/* ── Rich success toast (fixed, top-right) ── */
.toast-wrap{position:fixed;top:24px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:12px;pointer-events:none}
.flash--success-rich{
  pointer-events:all !important;
  position:relative !important;
  display:flex !important;
  flex-direction:column !important;
  align-items:stretch !important;
  justify-content:flex-start !important;
  background:#fff !important;
  border:0 !important;
  border-radius:18px !important;
  padding:0 !important;
  margin:0 !important;
  box-shadow:0 2px 4px rgba(0,0,0,.04),0 8px 24px rgba(0,0,0,.10),0 24px 64px rgba(0,0,0,.12),0 0 0 1px rgba(34,197,94,.15) !important;
  width:440px;
  max-width:calc(100vw - 48px);
  gap:0;
  overflow:hidden;
  animation:toastIn .35s cubic-bezier(.34,1.46,.64,1) both
}
@keyframes toastIn{from{opacity:0;transform:translateX(90px) scale(.94)}to{opacity:1;transform:translateX(0) scale(1)}}
.flash--success-rich.removing{animation:toastOut .22s ease-in forwards !important}
@keyframes toastOut{to{opacity:0;transform:translateX(90px) scale(.94)}}

/* Header strip */
.flash__header{
  background:linear-gradient(135deg,#047857 0%,#10b981 100%);
  padding:18px 20px 16px;
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px
}
.flash__header-left{display:flex;align-items:center;gap:14px}
.flash__icon{
  width:44px;height:44px;border-radius:50%;
  background:rgba(255,255,255,.22);
  border:2px solid rgba(255,255,255,.45);
  color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-size:22px;font-weight:700;flex-shrink:0;
  box-shadow:0 2px 8px rgba(0,0,0,.15)
}
.flash__title{font-size:17px;font-weight:800;color:#fff;line-height:1.2;letter-spacing:-.2px}
.flash__subtitle{font-size:12.5px;color:rgba(255,255,255,.85);margin-top:3px;font-weight:400}
.flash__x{
  border:0;background:rgba(255,255,255,.16);cursor:pointer;
  color:rgba(255,255,255,.9);font-size:13px;line-height:1;
  width:28px;height:28px;border-radius:8px;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;margin-top:0;transition:background .15s,color .15s
}
.flash__x:hover{background:rgba(255,255,255,.3);color:#fff}

/* Body */
.flash__body{padding:18px 20px 16px}
.flash__vin-row{display:none}

.flash__vin-plain {
  font-family: 'JetBrains Mono', 'Fira Mono', 'Consolas', monospace;
  font-size: 17px;
  font-weight: 700;
  color: #334155;
  background: none;
  border: none;
  border-radius: 0;
  padding: 0;
  letter-spacing: 2px;
  display: inline-block;
  line-height: 1.4;
  margin: 2px 0;
  box-shadow: none;
  user-select: all;
}

.flash__cta-row {
  display: flex;
  justify-content: flex-end;
  margin-top: 18px;
}
.flash__cta-close {
  min-width: 120px;
  font-size: 15px;
  font-weight: 700;
  border-radius: 12px;
  padding: 10px 0;
  box-shadow: 0 2px 8px rgba(15,23,42,0.08);
}

.flash__x--big {
  font-size: 28px !important;
  color: #1e293b !important;
  background: rgba(255,255,255,0.18) !important;
  width: 38px !important;
  height: 38px !important;
  border-radius: 10px !important;
  top: 10px;
  right: 10px;
  transition: background .15s, color .15s;
}
.flash__x--big:hover {
  background: #e0e7ef !important;
  color: #0891b2 !important;
}
.flash__table{
  display:grid;grid-template-columns:72px 1fr;
  gap:10px 14px
}
.flash__lbl{
  font-size:10.5px;font-weight:700;text-transform:uppercase;
  letter-spacing:.7px;color:#94a3b8;white-space:nowrap;padding-top:3px
}
.flash__val{color:#0f172a;font-weight:600;font-size:14px;line-height:1.4}
.flash__note{
  margin-top:14px;padding-top:12px;
  border-top:1px solid #f1f5f9;
  font-size:12px;color:#94a3b8;
  display:flex;align-items:center;gap:6px;
  line-height:1.4
}

/* Progress bar */
.flash__progress{height:5px;background:#dcfce7}
.flash__progress-bar{
  height:100%;
  background:linear-gradient(90deg,#059669 0%,#34d399 100%);
  transform-origin:left;
  animation:progressShrink var(--dur,16s) linear forwards
}
@keyframes progressShrink{from{transform:scaleX(1)}to{transform:scaleX(0)}}

@media(max-width:500px){
  .toast-wrap{top:0;right:0;left:0;padding:0}
  .flash--success-rich{width:100% !important;max-width:100%;border-radius:0 0 18px 18px !important}
}

/* Dialog layering so VIN help is never hidden under Add modal */
#modalBackdrop{position:fixed;inset:0;background:rgba(15,23,42,.35);z-index:1090}
dialog{position:absolute;z-index:1100}
#addModal{z-index:1200}
#howVinModal{z-index:1300;width:min(520px,calc(100% - 32px));border-radius:20px;box-shadow:0 24px 64px rgba(2,6,23,.22),0 2px 8px rgba(2,6,23,.08)}

/* When there is no data, force-hide the canvas to avoid any stale draw artifacts */
.chartCanvasShell.is-nodata canvas{
  display: none !important;
  visibility: hidden !important;
  opacity: 0 !important;
}

/* Professional footer styling */
.siteFooter {
  max-width: 1180px;
  margin: 0 auto;
  padding: 28px 20px 16px;
  border-top: 1px solid var(--line);
  background: transparent;
  text-align: center;
}

.footerInner {
  font-size: 14px;
  color: var(--muted);
  letter-spacing: -0.01em;
}
.footerLink{background:none;border:none;padding:0;font:inherit;font-size:inherit;color:var(--muted);cursor:pointer;text-decoration:none;transition:color .15s}
.footerLink:hover{color:#334155;text-decoration:underline;text-underline-offset:3px;text-decoration-color:#cbd5e1}
/* Contact modal */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(15,23,42,.45);backdrop-filter:blur(3px);align-items:flex-start;justify-content:center;z-index:9999;padding:32px 16px;overflow-y:auto}
.modal-overlay:not([hidden]){display:flex}
.modal-box{background:#fff;border-radius:18px;padding:32px 28px 28px;width:100%;box-shadow:0 24px 60px rgba(0,0,0,.18);position:relative}
.modal-box--sm{max-width:480px}
#contactModal .modal-close{position:absolute;top:14px;right:14px;width:40px;height:40px;border-radius:999px;border:none;background:#f1f5f9;color:#94a3b8;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s}
#contactModal .modal-close:hover{background:#e2e8f0;color:#475569}
#contactModal .modal-close:focus,#contactModal .modal-close:focus-visible,#contactModal .modal-close:active{border:none !important;outline:none !important;box-shadow:none !important}
.modal-title{font-size:20px;font-weight:800;color:#0f172a;letter-spacing:-.02em;margin-bottom:6px}
.modal-desc{font-size:13px;color:#64748b;margin-bottom:20px}
.cform-group{margin-bottom:14px}
.cform-label{display:block;font-size:12px;font-weight:600;color:#475569;text-transform:uppercase;letter-spacing:.04em;margin-bottom:5px}
.cform-input{width:100%;height:52px;border:2px solid var(--line);border-radius:14px;padding:0 14px;font-size:17px;font-weight:600;color:#1f2937;background:#fff;transition:all .2s;font-family:inherit;line-height:1.4}
.cform-input::placeholder{font-size:15px;font-weight:700;color:#94a3b8}
.cform-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 4px rgba(59,130,246,.12),0 4px 12px rgba(59,130,246,.15)}
.cform-textarea{height:auto;min-height:130px;padding:14px;resize:vertical;line-height:1.5}
.cform-error{margin-bottom:12px;padding:10px 14px;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;font-size:13px;color:#b91c1c}
.cform-success{margin-bottom:12px;padding:10px 14px;background:#f0fdf4;border:1px solid #86efac;border-radius:8px;font-size:13px;color:#166534}
.cform-success--sent{display:none;flex-direction:column;align-items:center;gap:12px;padding:40px 20px 24px;text-align:center;margin-bottom:0;background:none;border:none}
.cform-success--sent:not([hidden]){display:flex}
.cform-success--sent strong{font-size:20px;font-weight:800;color:#0f172a;letter-spacing:-.02em}
.cform-success--sent span{font-size:14px;color:#64748b;line-height:1.5}
.cform-close-ok{margin-top:8px;padding:0 28px;height:42px;font-size:14px}
.cform-captcha{margin:8px 0 4px;display:flex;justify-content:center}
.cform-submit{width:100%;justify-content:center;height:42px;font-size:14px;margin-top:4px}
.btnPrimary{background:linear-gradient(135deg,#3b82f6 0%,#1d4ed8 100%);border:1px solid #2563eb;color:#fff;font-weight:700;box-shadow:0 4px 12px rgba(37,99,235,.22),inset 0 1px 0 rgba(255,255,255,.18);border-radius:10px;cursor:pointer;transition:background .15s,box-shadow .15s,transform .1s}
.btnPrimary:hover{background:linear-gradient(135deg,#2563eb 0%,#1e40af 100%);transform:translateY(-1px);box-shadow:0 6px 16px rgba(29,78,216,.28)}
.btnPrimary:disabled{opacity:.6;cursor:not-allowed;transform:none}
/* ── VIN Scanner ─────────────────────────────────────────────── */
.vscan-trigger{position:absolute;right:68px;top:50%;transform:translateY(-50%);width:34px;height:34px;border:none;background:none;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:8px;color:#64748b;padding:0;transition:background 0.15s,color 0.15s;flex-shrink:0}
.vscan-trigger:hover{background:#eff6ff;color:#2563eb}
.vscan-trigger:active{background:#dbeafe}
/* Overlay */
.vscan{position:fixed;inset:0;z-index:2100;display:flex;align-items:center;justify-content:center;background:rgba(2,6,23,.85);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);padding:16px}
.vscan[hidden]{display:none!important}
/* Panel — šířka optimalizovaná pro horizontální VIN */
.vscan__panel{background:#0f172a;border-radius:20px;width:min(720px,calc(100vw - 32px));overflow:hidden;box-shadow:0 48px 120px rgba(0,0,0,.75),0 0 0 1px rgba(255,255,255,.08)}
/* Hlavička */
.vscan__head{display:flex;align-items:center;justify-content:space-between;padding:16px 20px 14px;border-bottom:1px solid rgba(255,255,255,.07)}
.vscan__title{font-size:14px;font-weight:700;color:#f1f5f9;letter-spacing:.01em;display:flex;align-items:center;gap:8px}
.vscan__close{width:34px;height:34px;border:none;background:rgba(255,255,255,.08);border-radius:9px;color:#94a3b8;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s;line-height:1}
.vscan__close:hover{background:rgba(255,255,255,.16);color:#f1f5f9}
/* Náhled kamery */
.vscan__viewport{position:relative;background:#000;overflow:hidden;height:290px;width:100%}
.vscan__video{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);min-width:100%;min-height:100%;width:auto;height:auto;object-fit:cover;display:block}
/* Vigneta — ztmavení okrajů, fokus na rámeček */
.vscan__overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse 72% 52% at 50% 50%,transparent 30%,rgba(2,6,23,.60) 100%)}
/* Rámeček — horizontální tvar pro VIN kód / čárový kód */
.vscan__frame{position:relative;width:92%;height:78px;border:1.5px solid rgba(14,165,233,.50);border-radius:8px}
.vscan__corner{position:absolute;width:20px;height:20px;border-color:#0ea5e9;border-style:solid}
.vscan__corner--tl{top:-2px;left:-2px;border-width:3px 0 0 3px;border-radius:5px 0 0 0}
.vscan__corner--tr{top:-2px;right:-2px;border-width:3px 3px 0 0;border-radius:0 5px 0 0}
.vscan__corner--bl{bottom:-2px;left:-2px;border-width:0 0 3px 3px;border-radius:0 0 0 5px}
.vscan__corner--br{bottom:-2px;right:-2px;border-width:0 3px 3px 0;border-radius:0 0 5px 0}
.vscan__scanline{position:absolute;left:6px;right:6px;height:2px;background:linear-gradient(90deg,transparent 0%,rgba(14,165,233,.65) 20%,#0ea5e9 50%,rgba(14,165,233,.65) 80%,transparent 100%);box-shadow:0 0 10px rgba(14,165,233,.70),0 0 24px rgba(14,165,233,.25);animation:vscan-sweep 2.4s ease-in-out infinite;top:0;border-radius:1px}
@keyframes vscan-sweep{0%,100%{top:4px;opacity:1}50%{top:calc(100% - 6px);opacity:.70}}
.vscan__hint{position:absolute;bottom:0;left:0;right:0;padding:8px 16px 12px;text-align:center;font-size:12px;font-weight:500;color:rgba(255,255,255,.60);background:linear-gradient(0deg,rgba(2,6,23,.70) 0%,transparent 100%);letter-spacing:.01em}
/* Oblast výsledku (po rozpoznání) */
.vscan__result{padding:18px 22px 14px;background:rgba(14,165,233,.06);border-top:1px solid rgba(14,165,233,.14)}
.vscan__result-label{font-size:10px;font-weight:700;color:#38bdf8;letter-spacing:.12em;text-transform:uppercase;margin-bottom:8px}
.vscan__result-vin{display:block;width:100%;box-sizing:border-box;font-size:17px;font-weight:700;color:#f1f5f9;letter-spacing:3px;font-variant-numeric:tabular-nums;word-break:break-all;margin-bottom:12px;line-height:1.4;background:#1e293b;border:1.5px solid #334155;border-radius:10px;padding:11px 16px;text-align:center;text-transform:uppercase;outline:none;transition:border-color .2s,box-shadow .2s}
.vscan__result-vin:focus{border-color:#0ea5e9;box-shadow:0 0 0 3px rgba(14,165,233,.15)}
.vscan__result-row{display:flex;gap:8px}
/* Patička s tlačítkem */
.vscan__footer{padding:14px 20px 18px;display:flex;flex-direction:column;align-items:center;gap:10px;border-top:1px solid rgba(255,255,255,.06)}
.vscan__btn{height:40px;padding:0 18px;border-radius:10px;border:1px solid rgba(255,255,255,.11);background:rgba(255,255,255,.07);color:#cbd5e1;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s;display:inline-flex;align-items:center;gap:6px;white-space:nowrap}
.vscan__btn:hover{background:rgba(255,255,255,.14);color:#f1f5f9;border-color:rgba(255,255,255,.22)}
.vscan__btn--primary{background:#0ea5e9;border-color:#0ea5e9;color:#fff;box-shadow:0 2px 10px rgba(14,165,233,.30)}
.vscan__btn--primary:hover{background:#0284c7;border-color:#0284c7;box-shadow:0 4px 18px rgba(14,165,233,.42)}
/* OCR tlačítko — hlavní CTA, plná šířka, barva aplikace */
.vscan__btn--ocr{width:100%;max-width:420px;justify-content:center;height:50px;padding:0 24px;background:linear-gradient(135deg,#2563eb 0%,#1d4ed8 100%);border:none;color:#fff;font-size:15px;font-weight:700;border-radius:13px;box-shadow:0 4px 18px rgba(37,99,235,.40);letter-spacing:.01em}
.vscan__btn--ocr:hover{background:linear-gradient(135deg,#1d4ed8 0%,#1e40af 100%);box-shadow:0 6px 26px rgba(37,99,235,.52)}
.vscan__btn--ocr:disabled{opacity:.45;cursor:not-allowed;box-shadow:none}
.vscan__ocr-status{font-size:12px;color:#64748b;line-height:1.5;text-align:center}

/* ── Colour palette v3 ───────────────────────────────────────────────────────
   Primary:    #2563EB   (blue)
   Success:    #16A34A   (green)
   Danger:     #DC2626   (red)
   Neutral:    #64748B
   Background: #F8FAFC
   All rules override the original condensed styles via cascade.
──────────────────────────────────────────────────────────────────────────── */

/* 0 ── CSS variable overrides */
:root {
  --navy:        #2563EB;
  --success:     #16A34A;
  --successDark: #15803D;
  --muted:       #64748B;
  --line:        #E2E8F0;
  --shadow:      0 1px 3px rgba(15,23,42,.06), 0 4px 16px rgba(15,23,42,.07);
}

/* 1 ── Page background */
body {
  background: #F8FAFC;
  min-height: 100vh;
}

/* 2 ── Hero — no coloured wrapper, just the gap between two cards */
.hero {
  position: static;
  padding: 0;
  border-radius: 0;
  background: none;
  border: none;
  box-shadow: none;
}

/* 3 ── Cards — clean white, simple border + soft shadow */
.card {
  background: #fff;
  border: 1px solid #E2E8F0;
  box-shadow: 0 1px 3px rgba(15,23,42,.06), 0 4px 16px rgba(15,23,42,.06);
}

/* 4 ── Search card */
.searchCard {
  background: linear-gradient(160deg,#f0f7ff 0%,#e8f0fe 100%);
  border: 1.5px solid #bfdbfe;
  box-shadow: 0 4px 24px rgba(37,99,235,.08), 0 1px 4px rgba(37,99,235,.06);
}

/* 5 ── Primary button — #2563EB (matches logo + header button) */
.primaryBtn {
  background: #2563EB;
  box-shadow: 0 1px 3px rgba(37,99,235,.25);
}
.primaryBtn:hover {
  background: #1D4ED8;
  transform: translateY(-1px);
  box-shadow: 0 4px 14px rgba(37,99,235,.32);
}

/* 6 ── VIN input — clean white */
.inputWrap.vinInput input {
  background: #fff;
  border-color: #CBD5E1;
}
.inputWrap.vinInput input:focus {
  border-color: #2563EB;
  box-shadow: 0 0 0 3px rgba(37,99,235,.12);
}
.inputWrap.vinInput input::placeholder {
  font-weight: 400;
  font-size: 16px;
  letter-spacing: .01em;
  text-transform: none;
  color: #b0bec8;
  opacity: 1;
}

/* 7 ── Trust items — clean, no coloured top border */
.trustItem {
  background: #fff;
  border: 1px solid #E2E8F0;
}

/* 8 ── Feature grid — clean */
.feature { background: #fff; border-color: #E2E8F0; }
.feature h4 { color: #0F172A; margin: 0; }
.feature__head { display: flex; align-items: center; gap: 10px; margin-bottom: 10px; }
.feature__icon {
  display: inline-flex; align-items: center; justify-content: center;
  width: 36px; height: 36px; border-radius: 10px; flex-shrink: 0;
}
.feature__icon--blue    { background: #EFF6FF; color: #2563EB; }
.feature__icon--green   { background: #F0FDF4; color: #16A34A; }
.feature__icon--red     { background: #FEF2F2; color: #DC2626; }
.feature__icon--neutral { background: #F1F5F9; color: #64748B; }

/* 9 ── Section heading — plain dark, no gradient text effect */
.sectionTitle {
  background: none;
  -webkit-background-clip: unset;
  background-clip: unset;
  -webkit-text-fill-color: #0F172A;
  color: #0F172A;
}

/* 10 ── KPI / stat boxes */
.kpis .kpi,
.kpisTop .kpiBox {
  background: #F8FAFC;
  border-color: #E2E8F0;
}

/* 11 ── Status line */
.status {
  background: #fff;
  border-color: #E2E8F0;
  color: #374151;
}

/* 12 ── Topbar — transparent, original style */
.topbar {
  padding: 0 2px;
  margin-bottom: 0;
}

/* Brand icon sizing — responsive */
.topbar { height: 80px !important; }
.brand__icon { width: 72px; height: 72px; flex-shrink: 0; }
.brand__name em { font-style: normal; color: #2563EB; }
@media (max-width: 760px) {
  .brand__tagline { display: none; }
  .brand__name { font-size: 32px !important; }
}
@media (max-width: 680px) {
  .topbar { height: 64px !important; }
  .brand__icon { width: 52px; height: 52px; }
  .brand__name { font-size: 26px !important; }
  .headerSupport { padding: 0 12px; }
  .headerAdd { padding: 0 12px !important; }
}
@media (max-width: 480px) {
  .topbar { height: 56px !important; }
  .brand__icon { width: 40px; height: 40px; }
  .brand__name { font-size: 22px !important; }
  .headerSupportLabel { display: none; }
  .headerSupport { padding: 0 10px; gap: 0; }
  .headerAdd { padding: 0 12px !important; font-size: 13px !important; }
}

/* 13 ── "Přidat záznam" header button — solid primary */
.headerAdd.btnAdd {
  background: #2563EB;
  border-color: #2563EB;
  box-shadow: 0 1px 3px rgba(37,99,235,.25);
}
.headerAdd.btnAdd:hover {
  background: #1D4ED8;
  border-color: #1D4ED8;
  box-shadow: 0 4px 14px rgba(37,99,235,.32);
  transform: translateY(-1px);
}

/* 14 ── Add record buttons (green) */
.btnAdd {
  background: #16A34A;
  border-color: #16A34A;
}
.btnAdd:hover {
  background: #15803D;
  border-color: #15803D;
}
.btnAddSummary {
  background: #16A34A;
  border-color: #16A34A;
  box-shadow: 0 1px 3px rgba(22,163,74,.25);
}
.btnAddSummary:hover {
  background: #15803D;
  border-color: #15803D;
  box-shadow: 0 4px 12px rgba(22,163,74,.3);
}

/* 15 ── Verdict badge in summary — hidden (shown as pill in meta row instead) */
#verdictBadge { display: none; }

/* Verdict pill colours */
.verdict.good { background: #F0FDF4; border-color: #BBF7D0; color: #16A34A; }
.verdict.bad  { background: #FEF2F2; border-color: #FECACA; color: #DC2626; }
.verdict.warn { background: #FFFBEB; border-color: #FDE68A; color: #B45309; }

/* 16 ── Source badges — neutral dot colours */
.badge--verified    { background: #F0FDF4; border-color: #BBF7D0; }
.badge--verified .badge__dot { background: #16A34A; }
.badge--suspicious  { background: #FEF2F2; border-color: #FECACA; }
.badge--suspicious .badge__dot { background: #DC2626; }

/* 16b ── Record type badges */
.badge--rectype {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .02em;
  padding: 2px 8px;
  border-radius: 999px;
  border: 1px solid;
  display: inline-flex;
  align-items: center;
  white-space: nowrap;
}
.badge--rt-1 { background: #F0FDF4; border-color: #BBF7D0; color: #15803D; } /* STK – zelená */
.badge--rt-2 { background: #eff6ff; border-color: #bfdbfe; color: #1d4ed8; } /* Inzerce – světle modrá */
.badge--rt-3 { background: #f0f9ff; border-color: #bae6fd; color: #0369a1; } /* Web – azurová */
.badge--rt-4 { background: #FAF5FF; border-color: #E9D5FF; color: #7E22CE; } /* Pojišťovna – fialová */
.badge--rt-5 { background: #FFF1F2; border-color: #FECDD3; color: #BE123C; } /* Autobazar – červená */
.badge--rt-6 { background: #F8FAFC; border-color: #E2E8F0; color: #64748B; } /* Ostatní – šedá */
/* Source pills pod grafem — sdílí barvy s badge--rt-* */
#pvSourcePill{gap:4px;flex-wrap:wrap;align-items:center;}
.src-pill{display:inline-flex;align-items:center;font-size:11px;font-weight:600;padding:2px 8px;border-radius:999px;border:1px solid transparent;}
.src-pill--verified  { background:#F0FDF4; border-color:#BBF7D0; color:#15803D; }
.src-pill--community { background:#fff7ed; border-color:#fed7aa; color:#c2410c; }
.src-pill--rt-1 { background:#F0FDF4; border-color:#BBF7D0; color:#15803D; }
.src-pill--rt-2 { background:#eff6ff; border-color:#bfdbfe; color:#1d4ed8; }
.src-pill--rt-3 { background:#f0f9ff; border-color:#bae6fd; color:#0369a1; }
.src-pill--rt-4 { background:#FAF5FF; border-color:#E9D5FF; color:#7E22CE; }
.src-pill--rt-5 { background:#FFF1F2; border-color:#FECDD3; color:#BE123C; }
.src-pill--rt-6 { background:#F8FAFC; border-color:#E2E8F0; color:#64748B; }

/* 17 ── Segment active button */
.segBtn[aria-pressed=true] {
  background: #2563EB;
  border-color: #2563EB;
}

/* 18 ── Score badge colours (5-tier, defined above) */
.pvScoreBadge.score--high { background: #F0FDF4; border-color: #BBF7D0; }
.pvScoreBadge.score--low  .pvScoreNum { color: #DC2626; }
.pvScoreBadge.score--low  { background: #FEF2F2; border-color: #FECACA; }
.pvScoreBadge.score--mid  .pvScoreNum { color: #D97706; }
.pvScoreBadge.score--mid  { background: #FFFBEB; border-color: #FDE68A; }

/* 19 ── Risk highlight colours */
.riskHigh    { color: #DC2626; }
.riskLow     { color: #16A34A; }
.riskNeutral { color: #64748B; }

/* 19b ── howVinModal confirm button */
#howVinModal .modalActions .btnPrimary {
  height: 44px;
  padding: 0 28px;
  border-radius: 12px;
  font-size: 15px;
  font-weight: 700;
  background: #2563EB;
  border-color: #2563EB;
  box-shadow: 0 1px 3px rgba(37,99,235,.25);
}
#howVinModal .modalActions .btnPrimary:hover {
  background: #1D4ED8;
  border-color: #1D4ED8;
  box-shadow: 0 4px 14px rgba(37,99,235,.32);
}

/* 20 ── Footer */
.siteFooter { border-top-color: #E2E8F0; }

/* 21 ── Pagination active page */
.pgNum[aria-current="page"] { background: #2563EB; border-color: #2563EB; }

/* 22 ── Modal & form inputs — focus ring primary blue (was cyan #0891b2) */
.inputWrap input:focus,
.inputWrap input:focus-visible {
  border-color: #2563EB !important;
  box-shadow: 0 0 0 3px rgba(37,99,235,.12), 0 4px 12px rgba(37,99,235,.10) !important;
}
.inputWrap.vinInput input:focus {
  border-color: #2563EB !important;
  box-shadow: 0 0 0 3px rgba(37,99,235,.12), 0 6px 20px rgba(37,99,235,.12) !important;
}
#addModal .fieldControl input:focus,
#addModal .fieldControl input:focus-visible,
#addModal .fieldControl .readonly:focus,
#addVinWrapper .fieldControl input:focus {
  border-color: #2563EB !important;
  box-shadow: 0 0 0 3px rgba(37,99,235,.12), 0 4px 12px rgba(37,99,235,.10) !important;
}

/* 23 ── VIN counter badge — neutral místo cyan */
.inputCounter,
#addModal .addVinCounter {
  color: #374151;
  background: #E2E8F0;
}


/* 25 ── Chart wrap — white (původně cyan gradient) */
.chartWrap--hero {
  background: #fff;
  border: 1px solid #E2E8F0;
  padding-top: 2px !important;
}
.chartCanvasShell canvas {
  background: #fff;
  border: none;
}

/* 26 ── Skip-to-content */
.skip-link{position:absolute;top:-100px;left:16px;z-index:9999;background:#2563eb;color:#fff;padding:8px 16px;border-radius:0 0 8px 8px;font-size:14px;font-weight:600;text-decoration:none;transition:top .15s}
.skip-link:focus{top:0}

/* 27 ── Risk alert */
.riskAlert{margin-top:10px;background:#fff5f5;border:1px solid #fca5a5;border-radius:10px;padding:10px 14px;display:flex;flex-direction:column;gap:6px}
.riskAlert__row{display:flex;align-items:center;gap:8px;font-size:12.5px;line-height:1.4}
.riskAlert__row--main strong{color:#991b1b;font-size:13px;font-weight:700}
.riskAlert__row span{color:#78350f}
.riskAlert__row strong{color:#78350f}

/* 27 ── Flash close hover — blue místo cyan */
.flash__x--big:hover { color: #2563EB !important; }

/* 27 ── Timeline */
.timeline{position:relative;padding:12px 12px 12px 38px}
/* Per-item line segments replace the single ::before line */
.tl-item{position:relative;padding-bottom:16px}
.tl-item:last-child{padding-bottom:0}
/* Line segment: from dot centre downward to next item */
.tl-item::after{
  content:'';position:absolute;
  left:-16px;top:26px;bottom:0;
  width:3px;transform:translateX(-50%);
  background:#CBD5E1;border-radius:2px
}
.tl-item:last-child::after{display:none}
/* Fraud connection — red dashed */
.tl-item--fraud-next::after{
  background:repeating-linear-gradient(
    to bottom,
    #ef4444 0px,#ef4444 6px,
    transparent 6px,transparent 12px
  )
}
.tl-dot{position:absolute;left:-23px;top:12px;width:14px;height:14px;border-radius:50%;border:2.5px solid #fff;z-index:1}
.tl-dot--ok  {background:#22c55e;box-shadow:0 0 0 2px #22c55e40}
.tl-dot--warn{background:#f59e0b;box-shadow:0 0 0 2px #f59e0b40}
.tl-dot--bad {background:#dc2626;box-shadow:0 0 0 3px #dc262640;animation:pulse-bad 1.8s ease-in-out infinite}
@keyframes pulse-bad{0%,100%{box-shadow:0 0 0 3px #dc262640}50%{box-shadow:0 0 0 7px #dc262618,0 0 0 12px #dc26260a}}
/* Normal card — alternating backgrounds */
.tl-card{background:#fff;border:1px solid #E2E8F0;border-radius:12px;padding:14px 16px;transition:box-shadow .15s}
.tl-card:hover{box-shadow:0 2px 10px rgba(15,23,42,.07)}
/* Bad card — subtle red tint, no aggressive decoration */
.tl-card--bad{
  background:#FFF5F5;
  border:1px solid #FECACA;
  border-radius:12px
}
.tl-card--bad:hover{box-shadow:0 2px 10px rgba(220,38,38,.09)}
/* Card head layout */
.tl-card__head{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-bottom:4px}
.tl-card__date{font-size:13px;color:#64748B;font-weight:500}
.tl-card--bad .tl-card__date{color:#ef4444;font-weight:600}
.tl-card__km-wrap{display:flex;flex-direction:column;align-items:flex-end;gap:5px;flex-shrink:0}
.tl-card__km{font-size:20px;font-weight:800;color:#0F172A;letter-spacing:-.02em}
.tl-card--bad .tl-card__km{color:#dc2626;font-size:22px;font-weight:900}
.tl-card__km-diff{font-size:13px;font-weight:600;letter-spacing:.01em}
.tl-card__km-diff--neg{color:#dc2626}
.tl-card__km-diff--pos{color:#16a34a}
.tl-card__km-diff--zero{color:#94a3b8;font-weight:400}
.tl-card__place{font-size:13px;color:#334155;margin:3px 0 6px;line-height:1.35}
.tl-card__foot{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-top:6px}
.tl-source{font-size:12px;color:#64748B}
.tl-note{background:none;padding:0;color:#94a3b8;font-size:12px;font-style:italic;white-space:nowrap}
.tl-place{display:inline-flex;align-items:center;gap:4px;color:#475569}
/* ── Story bridge between timeline records ── */
.tl-bridge{margin:6px 0 2px}
/* Normal progression — very subtle */
.tl-bridge--ok{
  text-align:center;font-size:11px;font-weight:500;
  color:#cbd5e1;letter-spacing:.01em;padding:2px 0 4px
}
/* Fraud bridge — alert style */
.tl-bridge--fraud{
  display:flex;align-items:center;gap:9px;
  background:#fef2f2;
  border:1px solid #fecaca;
  border-radius:8px;padding:10px 14px;margin:8px 0 4px;
  box-shadow:0 1px 4px rgba(239,68,68,.08)
}
.tl-bridge__icon{flex-shrink:0;line-height:0}
.tl-bridge__body{min-width:0;display:flex;flex-wrap:wrap;align-items:baseline;gap:4px}
.tl-bridge__title{font-size:12px;font-weight:700;color:#dc2626}
.tl-bridge__detail{font-size:11.5px;color:#64748b}
.tl-bridge__detail strong{font-weight:700;color:#dc2626}
@media (max-width: 820px) {
  .hero { grid-template-columns: 1fr !important; gap: 16px !important; }
  .heroCardMain h1 { font-size: 36px !important; }
  .kpis { grid-template-columns: 1fr 1fr !important; }
}

@media (max-width: 680px) {
  .hero { padding: 0; }
  .heroCardMain h1 { font-size: 30px !important; }
  .kpis { grid-template-columns: 1fr 1fr !important; }
  .featureGrid { grid-template-columns: 1fr !important; }
}

@media(max-width:480px){
  /* Timeline */
  .tl-card__km{font-size:17px}
  .timeline{padding-left:30px}
  .tl-dot{left:-18px}
  .tl-item::after{left:-12px}
  /* H1 smaller */
  .heroCardMain h1{font-size:26px !important}
  /* Pagination tap targets */
  .pgBtn,.pgNum{height:44px;min-width:44px}
}
/* ── Extra-small phones (≤ 420px) — must be last to win cascade ── */
@media(max-width:420px){
  .heroCardMain h1{font-size:22px !important}
  .sectionTitle{font-size:20px !important;margin:16px 0 4px !important}
}
