/* ============================================
   LEGIS-CHECK — Clean SaaS Design
   Mikromobilita v ČR 2026
   ============================================ */

/* --- Reset & Base --- */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:#FAFAF8;color:#1A1814;
  font-family:'DM Sans',system-ui,-apple-system,sans-serif;
  font-size:17px;line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

/* --- CSS Variables --- */
:root{
  --bg:#FAFAF8;--bg-card:#FFFFFF;--bg-dark:#111110;--bg-quiz:#0D0D0C;
  --text:#1A1814;--text-soft:#5C5850;--text-muted:#9A9488;
  --line:#ECEAE2;--line-soft:#F3F1EB;
  --accent:#E8612D;--accent-light:#FFF0EB;--accent-dark:#C24D1E;
  --green:#1A8754;--green-light:#E8F5EC;
  --red:#C93B2B;--red-light:#FDECEB;
  --amber:#C77D15;--amber-light:#FEF5E0;
  --radius:16px;--radius-sm:10px;--radius-xs:6px;
  --shadow-sm:0 1px 3px rgba(0,0,0,.04),0 1px 2px rgba(0,0,0,.02);
  --shadow:0 4px 20px rgba(0,0,0,.06),0 1px 3px rgba(0,0,0,.04);
  --shadow-lg:0 12px 40px rgba(0,0,0,.08),0 4px 12px rgba(0,0,0,.04);
  --container:1180px;
}

/* --- Typography --- */
h1,h2,h3,h4{font-family:'Outfit',system-ui,sans-serif;color:var(--text);line-height:1.05}
h1{font-size:clamp(2.8rem,6vw,4.5rem);font-weight:700;letter-spacing:-.03em}
h2{font-size:clamp(1.8rem,4vw,2.8rem);font-weight:700;letter-spacing:-.025em}
h3{font-size:1.2rem;font-weight:600;font-family:'DM Sans',sans-serif}
h1 em,h2 em{font-style:normal;color:var(--accent)}
a{color:var(--accent);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px;font-weight:500;transition:color .2s}
a:hover{color:var(--accent-dark)}
code{font-family:'JetBrains Mono',monospace;font-size:.85em;background:var(--amber-light);padding:1px 6px;border-radius:4px}

/* --- Layout --- */
.container{max-width:var(--container);margin:0 auto;padding:0 32px}
.eyebrow{
  font-family:'JetBrains Mono',monospace;font-size:.72rem;text-transform:uppercase;
  letter-spacing:.16em;color:var(--accent);font-weight:600;
  display:inline-flex;align-items:center;gap:10px;
  background:var(--accent-light);padding:6px 16px;border-radius:99px;margin-bottom:24px;
}

/* ============================================
   TOPBAR
   ============================================ */
.topbar{
  border-bottom:1px solid var(--line);padding:12px 0;position:sticky;top:0;z-index:100;
  background:rgba(250,250,248,.92);backdrop-filter:blur(12px);
}
.topbar-inner{display:flex;justify-content:space-between;align-items:center}
.brand{font-family:'DM Sans',sans-serif;font-weight:700;font-size:1.05rem;display:flex;align-items:center;gap:10px}
.brand-icon{
  width:34px;height:34px;border-radius:var(--radius-sm);
  background:linear-gradient(135deg,var(--accent),#F59E0B);
  display:inline-flex;align-items:center;justify-content:center;
  color:#fff;font-size:18px;font-weight:800;
}
.topnav{display:flex;gap:28px;font-size:.87rem;font-weight:500}
.topnav a{color:var(--text-soft);text-decoration:none;padding-bottom:2px;border-bottom:2px solid transparent;transition:all .2s}
.topnav a:hover{border-bottom-color:var(--accent);color:var(--text)}
.mobile-menu{display:none;background:none;border:none;cursor:pointer;font-size:1.5rem;color:var(--text)}

/* ============================================
   HERO
   ============================================ */
.hero{padding:72px 0 56px;border-bottom:1px solid var(--line)}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:48px;align-items:center}
.hero h1{margin-bottom:20px}
.hero-lead{font-size:1.12rem;line-height:1.6;color:var(--text-soft);max-width:48ch;margin-bottom:32px}
.cta-btn{
  display:inline-flex;align-items:center;gap:10px;
  background:var(--text);color:#fff;
  font-family:'DM Sans',sans-serif;font-size:1.05rem;font-weight:600;
  padding:16px 36px;border-radius:99px;border:none;cursor:pointer;
  text-decoration:none;transition:all .25s;
}
.cta-btn:hover{background:var(--accent);color:#fff;transform:translateY(-1px);box-shadow:var(--shadow-lg)}
.cta-btn svg{width:18px;height:18px}

/* Hero visual cards */
.hero-visual{display:flex;gap:14px;align-items:stretch}
.vcard{
  flex:1;background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius);
  padding:20px;text-align:center;transition:all .25s;position:relative;overflow:hidden;
}
.vcard:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}
.vcard-ok{border-top:3px solid var(--green)}
.vcard-warn{border-top:3px solid var(--amber)}
.vcard-bad{border-top:3px solid var(--red)}
.vcard-status{font-family:'JetBrains Mono',monospace;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;margin-bottom:10px}
.vcard-ok .vcard-status{color:var(--green)}
.vcard-warn .vcard-status{color:var(--amber)}
.vcard-bad .vcard-status{color:var(--red)}
.vcard-svg{width:100%;height:90px;margin-bottom:10px}
.vcard-ok .vcard-svg{color:var(--green)}
.vcard-warn .vcard-svg{color:var(--amber)}
.vcard-bad .vcard-svg{color:var(--red)}
.vcard-label{font-family:'Outfit',sans-serif;font-weight:700;font-size:.95rem;margin-bottom:8px}
.vcard-tags{display:flex;justify-content:center;gap:5px;flex-wrap:wrap}
.vtag{font-family:'JetBrains Mono',monospace;font-size:.65rem;padding:3px 8px;border-radius:4px;font-weight:600}
.vtag.ok{background:var(--green-light);color:var(--green)}
.vtag.warn{background:var(--amber-light);color:var(--amber)}
.vtag.bad{background:var(--red-light);color:var(--red)}

/* Hero laws */
.hero-laws{display:flex;flex-wrap:wrap;gap:8px;margin-top:32px}
.hero-laws a{
  background:var(--bg-card);border:1px solid var(--line);padding:6px 14px;border-radius:99px;
  font-family:'JetBrains Mono',monospace;font-size:.72rem;color:var(--text-muted);
  text-decoration:none;font-weight:500;transition:all .2s;
}
.hero-laws a:hover{border-color:var(--accent);color:var(--accent)}

/* ============================================
   QUIZ
   ============================================ */
.quiz-section{background:var(--bg-dark);color:#F5F3EE;padding:72px 0;position:relative;overflow:hidden}
.quiz-section::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(ellipse at 20% 30%,rgba(232,97,45,.1) 0%,transparent 50%),
             radial-gradient(ellipse at 80% 70%,rgba(26,135,84,.06) 0%,transparent 50%);
  pointer-events:none;
}
.quiz-inner{position:relative;max-width:900px;margin:0 auto}
.quiz-grid{display:grid;grid-template-columns:.38fr .62fr;gap:36px;align-items:start}
.quiz-left .eyebrow{background:rgba(232,97,45,.12);color:#F59E0B}
.quiz-left h2{color:#F5F3EE;margin-bottom:12px}
.quiz-left p{color:rgba(245,243,238,.45);font-size:.95rem}

.quiz-card{
  background:rgba(255,255,255,.03);border:1px solid rgba(245,243,238,.08);
  border-radius:var(--radius);padding:32px;min-height:360px;display:flex;flex-direction:column;
}
.progress{display:flex;gap:4px;margin-bottom:24px}
.progress-dot{flex:1;height:3px;background:rgba(245,243,238,.08);border-radius:2px;transition:background .3s}
.progress-dot.active{background:var(--accent)}
.progress-dot.done{background:rgba(232,97,45,.35)}
.step-label{font-family:'JetBrains Mono',monospace;font-size:.7rem;text-transform:uppercase;letter-spacing:.14em;color:var(--accent);margin-bottom:12px;font-weight:600}
.step-question{font-family:'Outfit',sans-serif;font-size:1.55rem;font-weight:600;line-height:1.15;color:#F5F3EE;margin-bottom:8px}
.step-hint{color:rgba(245,243,238,.45);font-size:.88rem;margin-bottom:24px}
.options{display:grid;gap:8px;margin-bottom:auto}
.opt{
  background:rgba(255,255,255,.03);border:1px solid rgba(245,243,238,.1);color:#F5F3EE;
  padding:14px 18px;border-radius:var(--radius-sm);text-align:left;cursor:pointer;
  font-family:'DM Sans',sans-serif;font-size:.95rem;font-weight:500;
  transition:all .18s;display:flex;align-items:center;gap:12px;line-height:1.4;
}
.opt:hover{background:rgba(232,97,45,.08);border-color:var(--accent);transform:translateX(3px)}
.opt-key{
  font-family:'JetBrains Mono',monospace;font-size:.68rem;color:var(--accent);
  background:rgba(232,97,45,.12);border:1px solid rgba(232,97,45,.3);
  padding:2px 8px;border-radius:var(--radius-xs);font-weight:600;flex-shrink:0;
}
.opt-text{flex:1}
.opt-sub{color:rgba(245,243,238,.4);font-size:.82rem;margin-top:2px;display:block;font-weight:400}
.nav-buttons{margin-top:20px;display:flex;justify-content:space-between;align-items:center;padding-top:16px;border-top:1px solid rgba(245,243,238,.06)}
.btn-back{background:none;border:none;color:rgba(245,243,238,.45);cursor:pointer;font-family:'JetBrains Mono',monospace;font-size:.82rem;padding:8px 0;font-weight:500;transition:color .2s}
.btn-back:hover{color:var(--accent)}
.btn-back:disabled{opacity:.2;cursor:default}
.step-counter{font-family:'JetBrains Mono',monospace;font-size:.78rem;color:rgba(245,243,238,.35)}
.step-counter b{color:var(--accent)}

/* --- Quiz Result --- */
.result{animation:fadeIn .4s ease}
@keyframes fadeIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.verdict{display:flex;align-items:center;gap:16px;padding:22px;border-radius:var(--radius-sm);margin-bottom:20px}
.verdict.ok{background:rgba(26,135,84,.12);border:1px solid rgba(26,135,84,.4)}
.verdict.caution{background:rgba(199,125,21,.1);border:1px solid rgba(199,125,21,.4)}
.verdict.bad{background:rgba(201,59,43,.1);border:1px solid rgba(201,59,43,.4)}
.verdict-icon{font-size:1.8rem;flex-shrink:0}
.verdict-text{flex:1}
.verdict-cat{font-family:'JetBrains Mono',monospace;font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:rgba(245,243,238,.5);margin-bottom:3px;font-weight:600}
.verdict-title{font-family:'Outfit',sans-serif;font-size:1.3rem;font-weight:600;color:#F5F3EE;line-height:1.15}

/* Report sections */
.report-section{margin-bottom:16px}
.report-label{font-family:'JetBrains Mono',monospace;font-size:.7rem;text-transform:uppercase;letter-spacing:.12em;color:var(--accent);margin-bottom:8px;font-weight:600;padding-bottom:6px;border-bottom:1px solid rgba(245,243,238,.06)}
.issue{padding:14px 16px;border-radius:var(--radius-sm);border-left:3px solid rgba(245,243,238,.1);background:rgba(255,255,255,.02);margin-bottom:6px}
.issue-bad{border-left-color:var(--red);background:rgba(201,59,43,.05)}
.issue-warn{border-left-color:var(--amber);background:rgba(199,125,21,.05)}
.issue-ok{border-left-color:var(--green);background:rgba(26,135,84,.04)}
.issue-head{display:flex;align-items:center;gap:8px;margin-bottom:4px}
.issue-icon{font-size:1rem;flex-shrink:0}
.issue-title{font-weight:600;font-size:.92rem;color:#F5F3EE}
.issue-bad .issue-title{color:#FCA5A5}
.issue-warn .issue-title{color:#FCD34D}
.issue-ok .issue-title{color:#86EFAC}
.issue-desc{font-size:.85rem;color:rgba(245,243,238,.55);line-height:1.5;margin-left:26px}
.issue-desc a{color:#FCD34D}
.issue-fix{margin-top:6px;margin-left:26px;font-size:.84rem;color:rgba(245,243,238,.7);background:rgba(255,255,255,.02);padding:10px 14px;border-radius:var(--radius-xs);line-height:1.4}
.issue-fix a{color:#FCD34D}
.fix-label{font-family:'JetBrains Mono',monospace;font-size:.68rem;color:#86EFAC;font-weight:600;text-transform:uppercase;letter-spacing:.06em}

.reqs-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}
.req{padding:14px 16px;background:rgba(255,255,255,.02);border:1px solid rgba(245,243,238,.06);border-radius:var(--radius-sm);display:flex;align-items:flex-start;gap:10px;font-size:.86rem;color:rgba(245,243,238,.7);line-height:1.4}
.req b{color:#F5F3EE;font-weight:600;display:block;margin-bottom:2px}
.req-icon{font-size:1rem;flex-shrink:0;margin-top:2px}
.req-bad{border-color:rgba(201,59,43,.25);background:rgba(201,59,43,.04)}
.req-ok{border-color:rgba(26,135,84,.2);background:rgba(26,135,84,.03)}
.req-warn{border-color:rgba(199,125,21,.25);background:rgba(199,125,21,.04)}
.fixes-section{background:rgba(26,135,84,.04);border:1px solid rgba(26,135,84,.12);border-radius:var(--radius-sm);padding:16px}
.fixes-section .report-label{color:#86EFAC;border-bottom-color:rgba(134,239,172,.15)}
.fix-item{margin-bottom:8px;padding-bottom:8px;border-bottom:1px solid rgba(245,243,238,.04)}
.fix-item:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}
.fix-do{font-size:.88rem;color:rgba(245,243,238,.8);margin-bottom:3px;font-weight:500}
.fix-do a{color:#FCD34D}
.fix-result{font-size:.84rem;color:#86EFAC;font-weight:500}
.extra-item{font-size:.86rem;color:rgba(245,243,238,.55);padding:6px 0;border-bottom:1px solid rgba(245,243,238,.04);line-height:1.5}
.extra-item:last-child{border-bottom:none}
.extra-item a{color:#FCD34D}
.result-source{font-family:'JetBrains Mono',monospace;font-size:.72rem;color:rgba(245,243,238,.3);text-align:center;margin-bottom:16px;padding:10px;border-top:1px solid rgba(245,243,238,.06)}
.result-source a{color:rgba(245,243,238,.5)}
.restart{background:var(--accent);color:#fff;border:none;padding:12px 24px;border-radius:var(--radius-sm);font-family:'JetBrains Mono',monospace;font-size:.82rem;text-transform:uppercase;letter-spacing:.08em;font-weight:600;cursor:pointer;transition:all .2s;width:100%}
.restart:hover{background:var(--accent-dark)}

/* ============================================
   TABLE
   ============================================ */
.table-section{padding:64px 0;border-bottom:1px solid var(--line)}
.section-head{margin-bottom:28px;display:flex;align-items:end;gap:20px}
.section-num{font-family:'JetBrains Mono',monospace;font-size:.75rem;font-weight:600;color:var(--accent);padding:5px 14px;border:1.5px solid var(--accent);border-radius:99px}
.table-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:var(--radius);background:var(--bg-card);box-shadow:var(--shadow-sm)}
table.compare{width:100%;border-collapse:collapse;font-size:.88rem}
table.compare thead{background:var(--bg-dark);color:#F5F3EE}
table.compare th{padding:14px 12px;text-align:left;font-weight:600;font-size:.9rem;border-right:1px solid rgba(245,243,238,.08)}
table.compare th:last-child{border-right:none}
table.compare td{padding:12px;border-top:1px solid var(--line-soft);border-right:1px solid var(--line-soft);color:var(--text-soft)}
table.compare td:last-child{border-right:none}
table.compare td:first-child{font-weight:600;color:var(--text);background:rgba(232,97,45,.02);font-family:'JetBrains Mono',monospace;font-size:.78rem}
.badge-yes{color:var(--green);font-weight:700}
.badge-no{color:var(--red);font-weight:700}

/* ============================================
   ACCORDIONS
   ============================================ */
.accordion-section{padding:64px 0;border-bottom:1px solid var(--line)}
.accordion{margin-top:20px;display:grid;grid-template-columns:1fr 1fr;gap:10px}
.acc-item{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:var(--bg-card);transition:box-shadow .2s}
.acc-item:hover{box-shadow:var(--shadow)}
.acc-header{
  width:100%;display:flex;align-items:center;gap:14px;padding:18px 22px;
  background:none;border:none;cursor:pointer;text-align:left;
  font-family:'DM Sans',sans-serif;font-size:1.05rem;font-weight:600;
  color:var(--text);transition:color .2s;
}
.acc-header:hover{color:var(--accent)}
.acc-icon{
  width:26px;height:26px;border-radius:50%;border:1.5px solid var(--line);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  transition:all .25s;font-size:14px;color:var(--text-muted);
}
.acc-item.open .acc-icon{background:var(--accent);border-color:var(--accent);color:#fff;transform:rotate(45deg)}
.acc-label{
  font-family:'JetBrains Mono',monospace;font-size:.65rem;text-transform:uppercase;
  letter-spacing:.1em;padding:3px 10px;border-radius:4px;font-weight:700;flex-shrink:0;
}
.acc-label.past{background:var(--red-light);color:var(--red)}
.acc-label.info{background:var(--amber-light);color:var(--amber)}
.acc-label.law{background:var(--green-light);color:var(--green)}
.acc-body{max-height:0;overflow:hidden;transition:max-height .35s ease}
.acc-item.open .acc-body{max-height:3000px}
.acc-content{padding:0 22px 24px;color:var(--text-soft);font-size:.94rem;line-height:1.6}
.acc-content p{margin-bottom:.9em}
.acc-content strong{color:var(--text)}
.acc-content ul{margin:0 0 1em 1.3em}
.acc-content li{margin-bottom:.4em}

/* Callouts */
.callout{background:var(--bg-card);border-left:4px solid var(--amber);padding:18px 22px;border-radius:0 var(--radius-sm) var(--radius-sm) 0;margin:16px 0}
.callout.danger{border-left-color:var(--red);background:var(--red-light)}
.callout.success{border-left-color:var(--green);background:var(--green-light)}
.callout-label{font-family:'JetBrains Mono',monospace;font-size:.68rem;text-transform:uppercase;letter-spacing:.12em;margin-bottom:6px;font-weight:700}
.callout .callout-label{color:var(--amber)}
.callout.danger .callout-label{color:var(--red)}
.callout.success .callout-label{color:var(--green)}
.callout p{margin:0;color:var(--text-soft);font-size:.92rem}

/* ============================================
   REALITY / KONTROLY
   ============================================ */
.reality-section{padding:64px 0;border-bottom:1px solid var(--line)}
.reality-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:24px}
.reality-card{padding:28px;border-radius:var(--radius);border:1px solid var(--line)}
.reality-card.mild{background:var(--bg-card)}
.reality-card.severe{background:var(--red-light);border-color:rgba(201,59,43,.2)}
.reality-card h3{margin-bottom:12px;display:flex;align-items:center;gap:10px;font-family:'DM Sans',sans-serif}
.reality-card h3 .r-icon{font-size:1.3rem}
.reality-card p{color:var(--text-soft);font-size:.92rem;margin-bottom:.8em}

/* ============================================
   FAQ
   ============================================ */
.faq-section{padding:64px 0;border-bottom:1px solid var(--line)}
.faq-grid{margin-top:24px;display:grid;gap:10px}
.faq-item{background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius);padding:24px;transition:box-shadow .2s}
.faq-item:hover{box-shadow:var(--shadow)}
.faq-q{font-family:'Instrument Serif',serif;font-weight:400;font-size:1.15rem;margin-bottom:10px}
.faq-a{color:var(--text-soft);font-size:.92rem;line-height:1.55}
.faq-a p{margin-bottom:.7em}
.faq-a p:last-child{margin-bottom:0}
.faq-a strong{color:var(--text)}
.faq-a ul{margin:6px 0 10px 0}
.faq-a li{margin-bottom:4px}
.faq-tag{
  display:inline-block;font-family:'JetBrains Mono',monospace;font-size:.63rem;
  text-transform:uppercase;letter-spacing:.1em;padding:3px 10px;border-radius:4px;
  font-weight:700;margin-bottom:10px;
}
.faq-tag.ban{background:var(--red-light);color:var(--red)}
.faq-tag.warn{background:var(--amber-light);color:var(--amber)}
.faq-tag.info{background:var(--green-light);color:var(--green)}

/* ============================================
   FOOTER
   ============================================ */
footer{background:var(--bg-dark);color:rgba(245,243,238,.7);padding:56px 0 32px;font-size:.9rem}
footer h4{color:#F5F3EE;font-family:'JetBrains Mono',monospace;font-size:.72rem;text-transform:uppercase;letter-spacing:.14em;margin-bottom:16px;font-weight:700}
.footer-grid{display:grid;grid-template-columns:1fr 1fr;gap:36px;margin-bottom:32px}
footer ul{list-style:none}
footer li{margin-bottom:9px}
footer a{color:rgba(245,243,238,.7);text-decoration:none;border-bottom:1px solid rgba(245,243,238,.15);padding-bottom:1px;font-weight:500;transition:all .2s}
footer a:hover{color:var(--accent);border-bottom-color:var(--accent)}
.footer-bottom{padding-top:24px;border-top:1px solid rgba(245,243,238,.1);font-family:'JetBrains Mono',monospace;font-size:.72rem;color:rgba(245,243,238,.35);display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px}

/* ============================================
   MOBILE RESPONSIVE
   ============================================ */
@media(max-width:900px){
  .accordion{grid-template-columns:1fr}
  .hero-grid{grid-template-columns:1fr;gap:32px}
  .hero-visual{overflow-x:auto;gap:10px;padding-bottom:8px}
  .vcard{min-width:160px;flex-shrink:0}
  .quiz-grid{grid-template-columns:1fr}
  .quiz-left{text-align:center}
  .reality-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .reqs-grid{grid-template-columns:1fr}
}
@media(max-width:720px){
  .container{padding:0 20px}
  .topnav{display:none}
  .mobile-menu{display:block}
  .hero{padding:48px 0 36px}
  .quiz-section{padding:48px 0}
  .quiz-card{padding:22px}
  .step-question{font-size:1.35rem}
  .section-head{flex-direction:column;align-items:flex-start;gap:10px}
  .cta-btn{font-size:1rem;padding:14px 28px}
  .table-section,.accordion-section,.reality-section,.faq-section{padding:48px 0}
  .faq-item{padding:18px}
}
@media(max-width:480px){
  h1{font-size:2.2rem}
  .hero-laws{gap:6px}
  .hero-laws a{font-size:.65rem;padding:5px 10px}
  .preview-card{min-width:220px;padding:14px 16px}
}

/* ============================================
   FAQ AS ACCORDIONS
   ============================================ */
.faq-accordion{margin-top:20px;display:grid;gap:8px}
.faq-acc{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:var(--bg-card);transition:box-shadow .2s}
.faq-acc:hover{box-shadow:var(--shadow)}
.faq-acc-header{
  width:100%;display:flex;align-items:center;gap:14px;padding:18px 22px;
  background:none;border:none;cursor:pointer;text-align:left;
  font-family:'Outfit',sans-serif;font-size:1.05rem;font-weight:600;
  color:var(--text);transition:color .2s;
}
.faq-acc-header:hover{color:var(--accent)}
.faq-acc .acc-icon{
  width:26px;height:26px;border-radius:50%;border:1.5px solid var(--line);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  transition:all .25s;font-size:14px;color:var(--text-muted);
}
.faq-acc.open .acc-icon{background:var(--accent);border-color:var(--accent);color:#fff;transform:rotate(45deg)}
.faq-acc-body{max-height:0;overflow:hidden;transition:max-height .35s ease}
.faq-acc.open .faq-acc-body{max-height:3000px}
.faq-acc-content{padding:0 22px 24px 62px;color:var(--text-soft);font-size:.94rem;line-height:1.6}
.faq-acc-content p{margin-bottom:.8em}
.faq-acc-content p:last-child{margin-bottom:0}
.faq-acc-content strong{color:var(--text)}
.faq-acc-content ul{margin:6px 0 10px 1.2em}
.faq-acc-content li{margin-bottom:4px}

/* ============================================
   HERO SVG BACKGROUND
   ============================================ */
.hero{position:relative;overflow:hidden}
.hero-bg{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.hero-bg svg{position:absolute}
.bg-bike{right:-20px;top:-30px;width:480px;height:480px;opacity:.07}
.bg-scoot{left:28%;bottom:-80px;width:380px;height:380px;transform:rotate(-12deg);opacity:.05}
.bg-wheel{left:-40px;top:30px;width:260px;height:260px;opacity:.06}

/* ============================================
   ACCORDION SVG ICONS
   ============================================ */
.acc-svg{width:20px;height:20px;flex-shrink:0;color:var(--accent);opacity:.7}
.acc-item:hover .acc-svg{opacity:1}

/* ============================================
   TOPIC CARDS — Sekce Na co si dát pozor + FAQ
   ============================================ */
.cards-section{padding:64px 0;border-bottom:1px solid var(--line)}
.section-intro{
  color:var(--text-soft);font-size:1rem;line-height:1.55;
  max-width:60ch;margin:0 0 28px;
}
.topics-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:14px;
}
.topic-card{
  background:var(--bg-card);border:1px solid var(--line);
  border-radius:var(--radius);padding:24px;
  text-align:left;cursor:pointer;font-family:inherit;
  display:flex;flex-direction:column;gap:10px;
  transition:all .2s ease;position:relative;
  width:100%;
}
.topic-card:hover{
  border-color:var(--accent);
  box-shadow:var(--shadow);
  transform:translateY(-2px);
}
.topic-card:focus-visible{
  outline:2px solid var(--accent);outline-offset:2px;
}
.card-header{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:4px}
.card-icon{
  width:40px;height:40px;border-radius:10px;
  background:var(--bg);display:flex;align-items:center;justify-content:center;
  color:var(--accent);flex-shrink:0;
}
.card-icon svg{width:22px;height:22px;color:inherit;opacity:1}
.card-warn .card-icon{background:var(--red-light);color:var(--red)}
.card-info .card-icon{background:var(--amber-light);color:var(--amber)}
.card-label{
  font-family:'JetBrains Mono',monospace;font-size:.65rem;text-transform:uppercase;
  letter-spacing:.1em;padding:3px 10px;border-radius:4px;font-weight:700;
}
.card-label-past{background:var(--red-light);color:var(--red)}
.card-label-info{background:var(--amber-light);color:var(--amber)}
.card-title{
  font-family:'Outfit',sans-serif;font-weight:600;
  font-size:1.05rem;line-height:1.3;color:var(--text);
  margin:0;
}
.card-summary{
  color:var(--text-soft);font-size:.92rem;line-height:1.5;
  margin:0;flex:1;
}
.card-more{
  display:inline-flex;align-items:center;gap:6px;
  color:var(--accent);font-weight:600;font-size:.88rem;
  margin-top:6px;transition:gap .2s;
}
.card-more svg{width:14px;height:14px;transition:transform .2s}
.topic-card:hover .card-more svg{transform:translateX(3px)}

/* Tablet */
@media(max-width:900px){
  .topics-grid{grid-template-columns:repeat(2,1fr)}
}
/* Mobile */
@media(max-width:600px){
  .topics-grid{grid-template-columns:1fr;gap:10px}
  .topic-card{padding:20px}
}

/* ============================================
   MODAL — Detail karty
   ============================================ */
.topic-modal{
  position:fixed;inset:0;
  background:rgba(20,18,15,.6);backdrop-filter:blur(4px);
  display:flex;align-items:center;justify-content:center;
  z-index:1000;padding:24px;
  opacity:0;visibility:hidden;
  transition:opacity .25s ease,visibility .25s ease;
}
.topic-modal.open{opacity:1;visibility:visible}
.modal-card{
  background:var(--bg-card);border-radius:var(--radius);
  max-width:760px;width:100%;
  max-height:90vh;display:flex;flex-direction:column;
  transform:translateY(20px) scale(.98);
  transition:transform .25s ease;
  box-shadow:var(--shadow-lg);overflow:hidden;
}
.topic-modal.open .modal-card{transform:translateY(0) scale(1)}
.modal-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 24px;border-bottom:1px solid var(--line);
  flex-shrink:0;background:var(--bg-card);
}
.modal-header-left{display:flex;align-items:center;gap:12px}
.modal-icon{
  width:38px;height:38px;border-radius:10px;
  background:var(--accent-light);display:flex;align-items:center;justify-content:center;
  color:var(--accent);flex-shrink:0;
}
.modal-icon svg{width:22px;height:22px;color:inherit}
.modal-label{
  font-family:'JetBrains Mono',monospace;font-size:.7rem;text-transform:uppercase;
  letter-spacing:.1em;padding:4px 12px;border-radius:4px;font-weight:700;
}
.modal-label-past{background:var(--red-light);color:var(--red)}
.modal-label-info{background:var(--amber-light);color:var(--amber)}
.modal-close{
  width:36px;height:36px;border-radius:50%;
  background:var(--bg);border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;color:var(--text-soft);transition:all .2s;
  flex-shrink:0;padding:0;
}
.modal-close:hover{background:var(--red-light);color:var(--red);border-color:var(--red)}
.modal-close svg{width:18px;height:18px}
.modal-body{
  padding:24px;overflow-y:auto;flex:1;
}
.modal-title{
  font-family:'Outfit',sans-serif;font-weight:700;
  font-size:1.6rem;line-height:1.2;color:var(--text);
  margin:0 0 18px;letter-spacing:-.02em;
}
.modal-content{
  color:var(--text-soft);font-size:.96rem;line-height:1.65;
}
.modal-content p{margin-bottom:.9em}
.modal-content strong{color:var(--text)}
.modal-content ul{margin:.6em 0 .9em 1.3em}
.modal-content li{margin-bottom:.45em}
.modal-content a{color:var(--accent);font-weight:500}

/* Modal mobile */
@media(max-width:720px){
  .topic-modal{padding:0;align-items:stretch}
  .modal-card{
    max-width:none;max-height:100vh;height:100vh;
    border-radius:0;
  }
  .modal-title{font-size:1.35rem}
  .modal-body{padding:20px}
  .modal-header{padding:16px 20px}
  .modal-content{font-size:.94rem}
}
