/* Cislo.info PHP demo — žlutý/černý brand jako Zlaté stránky */

/* === ADSENSE INLINE === */
.ad-inline, .ad-block {
    margin: 28px 0;
    padding: 12px 16px;
    background: #FAFAFA;
    border: 1px dashed #E2E8F0;
    border-radius: 8px;
    text-align: center;
    min-height: 100px;
}
.ad-inline .ad-label, .ad-block .ad-label {
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: #94A3B8;
    margin-bottom: 8px;
    font-weight: 600;
}
.ad-inline ins.adsbygoogle, .ad-block ins.adsbygoogle {
    min-height: 90px;
}
@media (max-width: 640px) {
    .ad-inline, .ad-block { margin: 20px 0; padding: 8px; }
}


:root {
    --yellow: #FACC15;        /* yellow-400 — primary */
    --yellow-light: #FDE047;  /* yellow-300 */
    --slate-900: #0F172A;
    --slate-700: #334155;
    --slate-500: #64748B;
    --slate-300: #CBD5E1;
    --slate-100: #F1F5F9;
    --slate-50:  #F8FAFC;
    --white: #FFFFFF;

    --safe: #10B981;
    --moderate: #3B82F6;
    --risky: #F59E0B;
    --dangerous: #DC2626;
    --useful: #10B981;
    --harassing: #F59E0B;
    --neutral: #6B7280;

    /* aliasy pro nové komponenty (admin, articles, predvolba) */
    --gray-50:  #F8FAFC;
    --gray-100: #F1F5F9;
    --gray-200: #E2E8F0;
    --gray-300: #CBD5E1;
    --gray-500: #64748B;
    --gray-700: #334155;
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Helvetica Neue", Arial, sans-serif;
    color: #1e293b;
    background: #fff;
    margin: 0;
    line-height: 1.5;
    font-size: 15px;
}

h1, h2, h3, h4 {
    color: #1a1a1a;
    font-weight: 700;
    letter-spacing: -0.005em;
    margin: 0;
}

a { color: #0F172A; text-decoration: none; }
a:visited { color: #0F172A; }
a:hover { color: #d63384; }

.container {
    max-width: 1100px;
    margin: 0 auto;
    padding: 0 16px;
}

/* HEADER — bílý sticky nad žlutým hero (cislo.info-nove styl) */
.site-header {
    background: #fff;
    padding: 14px 0;
    position: sticky;
    top: 0;
    z-index: 50;
    border-bottom: 1px solid #e2e8f0;
}

.site-header .container {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
}

.logo {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    text-decoration: none;
    color: #0F172A;
    line-height: 1;
}
.logo:visited, .logo:hover { color: #0F172A; text-decoration: none; }
.logo-icon {
    flex-shrink: 0;
    display: block;
}
.logo-wordmark {
    font-size: 22px;
    font-weight: 800;
    letter-spacing: -0.015em;
    color: #0F172A;
    line-height: 1;
}
.logo-info { color: #EAB308; }
@media (max-width: 480px) {
    .logo-wordmark { font-size: 18px; }
    .logo-icon { width: 32px; height: 32px; }
}

.nav { display: flex; gap: 22px; font-size: 14px; }
.nav a {
    color: #475569;
    text-decoration: none;
    font-weight: 500;
}
.nav a:visited { color: #475569; }
.nav a:hover { color: #0F172A; text-decoration: none; }

/* HERO */
.hero {
    background: var(--yellow);
    padding: 40px 0 48px;
    border-bottom: 1px solid rgba(15,23,42,0.08);
}

.hero-inner {
    display: grid;
    grid-template-columns: 1fr;
    gap: 32px;
    align-items: start;
}
@media (min-width: 880px) {
    .hero-inner { grid-template-columns: 2fr 1fr; gap: 48px; }
}

.hero h1 {
    font-size: 32px;
    font-weight: 800;
    color: var(--slate-900);
    margin: 0 0 8px;
    line-height: 1.15;
    letter-spacing: -0.01em;
}
@media (min-width: 720px) {
    .hero h1 { font-size: 38px; }
}

.hero-sub {
    font-size: 16px;
    color: var(--slate-700);
    margin: 0 0 20px;
    max-width: 540px;
}

.hero-search {
    display: flex;
    gap: 8px;
    max-width: 520px;
    background: white;
    padding: 6px;
    border-radius: 10px;
    border: 1px solid rgba(15,23,42,0.1);
}

.hero-search input {
    flex: 1;
    padding: 10px 14px;
    border: none;
    font-size: 16px;
    font-family: inherit;
    background: transparent;
    color: var(--slate-900);
    outline: none;
    min-width: 0;
}

.hero-search input::placeholder { color: var(--slate-500); }

.hero-search button {
    padding: 10px 22px;
    background: var(--slate-900);
    color: white;
    border: none;
    border-radius: 7px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
}
.hero-search button:hover { background: #1e293b; }

.hero-meta {
    margin: 14px 0 0;
    font-size: 13px;
    color: var(--slate-700);
}
.hero-meta strong { color: var(--slate-900); }

/* Hero sidebar */
.hero-aside {
    background: rgba(255,255,255,0.6);
    border: 1px solid rgba(15,23,42,0.1);
    border-radius: 10px;
    padding: 16px 18px;
}
.hero-aside h3 {
    margin: 0 0 10px;
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--slate-700);
}
.hero-aside ul {
    list-style: none;
    padding: 0;
    margin: 0 0 10px;
}
.hero-aside li {
    padding: 6px 0;
    border-bottom: 1px solid rgba(15,23,42,0.08);
    font-size: 14px;
}
.hero-aside li:last-child { border-bottom: none; }
.hero-aside a {
    color: var(--slate-900);
    text-decoration: none;
    line-height: 1.4;
}
.hero-aside a:hover { text-decoration: underline; }
.hero-aside-more {
    display: inline-block;
    margin-top: 6px;
    font-size: 13px;
    font-weight: 500;
    color: var(--slate-900);
    text-decoration: none;
}
.hero-aside-more:hover { text-decoration: underline; }

/* SECTION */
.section {
    padding: 36px 0;
}
.section h2 {
    font-size: 20px;
    font-weight: 700;
    margin: 0;
    color: var(--slate-900);
}

/* NUMBER GRID */
.number-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
    gap: 12px;
}

.number-card {
    background: var(--white);
    border: 1px solid var(--slate-100);
    border-radius: 8px;
    padding: 14px 16px;
    text-decoration: none;
    color: inherit;
    transition: border-color 0.15s;
}
.number-card:hover {
    border-color: var(--slate-300);
}

.number-card-num {
    font-size: 18px;
    font-weight: 700;
    margin-bottom: 6px;
    font-variant-numeric: tabular-nums;
}

.number-card-meta {
    display: flex;
    gap: 8px;
    align-items: center;
    margin-bottom: 8px;
    color: var(--slate-500);
    font-size: 12px;
}

.badge {
    display: inline-block;
    padding: 2px 8px;
    background: var(--slate-100);
    border-radius: 4px;
    font-size: 11px;
    font-weight: 500;
    color: var(--slate-700);
}

.comment-count { color: var(--slate-700); }

/* SCORE COLOR HINT (left border) */
.score-safe { border-left: 4px solid var(--safe); }
.score-moderate { border-left: 4px solid var(--moderate); }
.score-risky { border-left: 4px solid var(--risky); }
.score-dangerous { border-left: 4px solid var(--dangerous); }
.score-unknown { border-left: 4px solid var(--slate-300); }

/* VERDICT TAG — pastelová pill jako na vyhledatcislo.cz */
.verdict-tag {
    display: inline-block;
    padding: 4px 14px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 500;
    text-transform: none;
    letter-spacing: 0;
    border: 1px solid;
    line-height: 1.4;
    white-space: nowrap;
}
.verdict-tag.verdict-useful    { background: #d1fae5; color: #065f46; border-color: #6ee7b7; }
.verdict-tag.verdict-safe      { background: #ecfccb; color: #365314; border-color: #bef264; }
.verdict-tag.verdict-neutral   { background: #dbeafe; color: #1e40af; border-color: #93c5fd; }
.verdict-tag.verdict-harassing { background: #fee2e2; color: #991b1b; border-color: #fca5a5; }
.verdict-tag.verdict-dangerous { background: #DC2626; color: #fff; border-color: #991b1b; }

/* COMMENT LIST */
.comment-list {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.comment-item {
    background: #fff;
    border: 1px solid #ececec;
    border-radius: 8px;
    padding: 14px 16px;
    border-left: 3px solid #ddd;
    box-shadow: 0 1px 2px rgba(0,0,0,0.03);
}

.comment-item.verdict-useful { border-left-color: var(--useful); }
.comment-item.verdict-safe { border-left-color: var(--moderate); }
.comment-item.verdict-neutral { border-left-color: var(--neutral); }
.comment-item.verdict-harassing { border-left-color: var(--harassing); }
.comment-item.verdict-dangerous { border-left-color: var(--dangerous); }

.comment-header {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 6px;
    flex-wrap: wrap;
    font-size: 13px;
}

.comment-phone {
    font-weight: 600;
    color: var(--slate-900);
    text-decoration: none;
    font-variant-numeric: tabular-nums;
}
.comment-phone:hover { text-decoration: underline; }

.comment-time {
    color: var(--slate-500);
    font-size: 13px;
    margin-left: auto;
}

.comment-text {
    margin: 0 0 4px;
    color: var(--slate-700);
    font-size: 14px;
}

.comment-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    color: var(--slate-500);
    font-size: 13px;
}

.helpful { color: var(--safe); }

/* HOW IT WORKS */
.how-it-works {
    background: var(--white);
    border-radius: 16px;
    padding: 48px;
    margin: 40px auto;
}

.steps {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 24px;
}

.step { text-align: center; }
.step-num {
    width: 48px;
    height: 48px;
    background: var(--yellow);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 16px;
    font-size: 22px;
    font-weight: 800;
    color: var(--slate-900);
}
.step h3 { margin: 0 0 8px; font-size: 18px; }
.step p { margin: 0; color: var(--slate-700); font-size: 14px; }

/* DETAIL */
.breadcrumb {
    color: var(--slate-500);
    font-size: 14px;
    margin: 24px 0 16px;
}
.breadcrumb a { color: var(--slate-700); text-decoration: none; }
.breadcrumb a:hover { color: var(--slate-900); text-decoration: underline; }

.detail-hero {
    padding-top: 16px;
    padding-bottom: 24px;
}

.detail-number {
    font-size: clamp(28px, 5vw, 40px);
    font-weight: 800;
    margin: 0 0 12px;
    color: var(--slate-900);
    font-variant-numeric: tabular-nums;
    letter-spacing: -0.01em;
}

.detail-meta {
    display: flex;
    gap: 12px;
    align-items: center;
    flex-wrap: wrap;
    margin-bottom: 32px;
    color: var(--slate-500);
    font-size: 14px;
}

.muted { color: #888; }
.small { font-size: 12px; }

.safety-card {
    background: var(--white);
    border-radius: 8px;
    padding: 20px;
    border: 1px solid var(--slate-100);
    border-left: 4px solid var(--slate-300);
}

.safety-card.score-safe { border-left-color: var(--safe); background: #ECFDF5; }
.safety-card.score-moderate { border-left-color: var(--moderate); background: #EFF6FF; }
.safety-card.score-risky { border-left-color: var(--risky); background: #FFFBEB; }
.safety-card.score-dangerous { border-left-color: var(--dangerous); background: #FEF2F2; }

.safety-empty { text-align: left; }
.safety-icon { font-size: 28px; margin-bottom: 8px; }
.safety-empty h2 { margin: 0 0 4px; font-size: 18px; }

.safety-score-display {
    display: flex;
    align-items: center;
    gap: 14px;
    margin-bottom: 16px;
}
.safety-score-display .safety-icon { font-size: 28px; margin: 0; }
.safety-verdict {
    font-size: 20px;
    font-weight: 700;
    margin-bottom: 4px;
}
.safety-summary { color: var(--slate-700); }

.verdict-bars {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin-top: 16px;
}

.verdict-bar-row {
    display: grid;
    grid-template-columns: 120px 1fr 40px;
    gap: 12px;
    align-items: center;
}

.verdict-bar-label {
    font-size: 14px;
    color: var(--slate-700);
}

.verdict-bar-track {
    background: var(--slate-100);
    height: 8px;
    border-radius: 4px;
    overflow: hidden;
}

.verdict-bar-fill {
    height: 100%;
    transition: width 0.3s;
}
.verdict-bar-fill.verdict-useful { background: var(--useful); }
.verdict-bar-fill.verdict-safe { background: var(--moderate); }
.verdict-bar-fill.verdict-neutral { background: var(--neutral); }
.verdict-bar-fill.verdict-harassing { background: var(--harassing); }
.verdict-bar-fill.verdict-dangerous { background: var(--dangerous); }

.verdict-bar-count {
    text-align: right;
    color: var(--slate-700);
    font-size: 14px;
    font-variant-numeric: tabular-nums;
}

/* FORM */
.comment-form {
    background: var(--white);
    border-radius: 16px;
    padding: 32px;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04);
}

.comment-form label {
    display: block;
    margin-bottom: 16px;
    font-weight: 500;
    color: var(--slate-900);
}

.comment-form textarea,
.comment-form input[type="text"] {
    display: block;
    width: 100%;
    padding: 12px 16px;
    border: 1px solid var(--slate-300);
    border-radius: 8px;
    font-size: 15px;
    font-family: inherit;
    margin-top: 8px;
    background: var(--slate-50);
    transition: border-color 0.15s;
}

.comment-form textarea:focus,
.comment-form input:focus {
    outline: none;
    border-color: var(--slate-900);
    background: var(--white);
}

.verdict-radio {
    border: none;
    padding: 0;
    margin: 0 0 24px;
}

.verdict-radio legend {
    font-weight: 600;
    margin-bottom: 12px;
    color: var(--slate-900);
}

.verdict-options-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: 8px;
}

.verdict-option {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 12px 16px;
    background: var(--slate-50);
    border: 2px solid transparent;
    border-radius: 8px;
    cursor: pointer;
    margin: 0;
    font-weight: 500;
    transition: all 0.15s;
}

.verdict-option:hover { background: var(--slate-100); }
.verdict-option:has(input:checked) {
    border-width: 2px;
    border-style: solid;
    background: var(--white);
}
.verdict-option.verdict-useful:has(input:checked) { border-color: var(--useful); }
.verdict-option.verdict-safe:has(input:checked) { border-color: var(--moderate); }
.verdict-option.verdict-neutral:has(input:checked) { border-color: var(--neutral); }
.verdict-option.verdict-harassing:has(input:checked) { border-color: var(--harassing); }
.verdict-option.verdict-dangerous:has(input:checked) { border-color: var(--dangerous); }

.btn-primary {
    display: inline-block;
    padding: 12px 32px;
    background: var(--slate-900);
    color: var(--white);
    border: none;
    border-radius: 8px;
    font-size: 16px;
    font-weight: 600;
    cursor: pointer;
    text-decoration: none;
    transition: background 0.15s, transform 0.1s;
}

.btn-primary:hover {
    background: #1e293b;
    transform: translateY(-1px);
}

/* EMPTY STATE */
.empty-state {
    text-align: center;
    padding: 60px 20px;
    background: var(--white);
    border-radius: 16px;
}
.empty-state h2 { margin: 0 0 8px; }
.empty-state p { color: var(--slate-700); margin: 0 0 16px; }

/* FOOTER */
.site-footer {
    margin-top: 32px;
    padding: 20px 0 16px;
    background: #2a2a28;
    color: #c8c5b8;
    font-size: 12px;
    line-height: 1.5;
}
.footer-cols {
    display: grid;
    grid-template-columns: 2fr 1fr 1fr 1fr;
    gap: 24px;
}
@media (max-width: 720px) {
    .footer-cols { grid-template-columns: 1fr 1fr; gap: 16px; }
}
.footer-cols strong {
    display: block;
    margin-bottom: 6px;
    color: #fff;
    font-size: 12px;
    font-family: Georgia, serif;
}
.footer-cols ul { list-style: none; padding: 0; margin: 0; }
.footer-cols li { padding: 1px 0; }
.site-footer a { color: #c8c5b8; text-decoration: none; }
.site-footer a:visited { color: #c8c5b8; }
.site-footer a:hover { color: #fde047; text-decoration: underline; }
.footer-hr {
    border: none;
    border-top: 1px solid #444;
    margin: 16px 0 10px;
}
.footer-bottom {
    margin: 0;
    color: #888;
    font-size: 11px;
}

/* MOBILE */
@media (max-width: 640px) {
    .hero { padding: 48px 0; }
    .search-form { flex-direction: column; }
    .nav { display: none; }
    .verdict-bar-row { grid-template-columns: 90px 1fr 30px; gap: 8px; }
    .verdict-bar-label { font-size: 12px; }
    .how-it-works { padding: 24px; }
}

/* ============================================================
   AKTUALITY (články)
   ============================================================ */

.page-header { margin-bottom: 32px; padding-bottom: 16px; border-bottom: 2px solid var(--gray-200); }
.page-header h1 { margin: 0 0 8px; }
.page-sub { color: var(--gray-700); font-size: 18px; margin: 0; }

.category-filter { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 32px; }
.category-filter a {
    padding: 8px 16px;
    border-radius: 999px;
    background: var(--gray-100);
    color: var(--slate-900);
    text-decoration: none;
    font-size: 14px;
    font-weight: 500;
    transition: all 0.15s;
}
.category-filter a:hover { background: var(--gray-200); }
.category-filter a.active { background: var(--slate-900); color: var(--yellow); }

.article-list { display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: 24px; }
.article-card {
    background: white;
    border: 1px solid var(--gray-200);
    border-radius: 16px;
    padding: 24px;
    transition: all 0.2s;
}
.article-card:hover { border-color: var(--yellow); box-shadow: 0 4px 12px rgba(0,0,0,0.06); }
.article-card h2 { margin: 8px 0; font-size: 20px; line-height: 1.3; }
.article-card h2 a { color: var(--slate-900); text-decoration: none; }
.article-card h2 a:hover { color: #ca8a04; }
.article-category {
    display: inline-block;
    padding: 4px 10px;
    background: var(--yellow);
    color: var(--slate-900);
    font-size: 12px;
    font-weight: 600;
    border-radius: 4px;
    text-decoration: none;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}
.article-excerpt { color: var(--gray-700); font-size: 15px; line-height: 1.5; margin: 12px 0; }
.article-meta { color: #6b7280; font-size: 13px; }
.article-meta time, .article-meta span { display: inline-block; }

/* Detail článku */
.article-detail { max-width: 760px; }
.article-header { margin-bottom: 32px; }
.article-header h1 { font-size: 36px; line-height: 1.2; margin: 16px 0 12px; }
.article-lead { font-size: 20px; color: var(--gray-700); line-height: 1.5; }
.article-body {
    font-size: 17px;
    line-height: 1.7;
    color: var(--slate-900);
}
.article-body p { margin: 0 0 16px; }
.number-link {
    display: inline-block;
    padding: 2px 6px;
    background: var(--yellow);
    color: var(--slate-900);
    border-radius: 4px;
    text-decoration: none;
    font-weight: 600;
    font-variant-numeric: tabular-nums;
}
.number-link:hover { background: var(--slate-900); color: var(--yellow); }
.article-mentioned, .article-related {
    margin-top: 48px;
    padding-top: 32px;
    border-top: 2px solid var(--gray-200);
}
.article-related ul { list-style: none; padding: 0; }
.article-related li {
    padding: 12px 0;
    border-bottom: 1px solid var(--gray-100);
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 16px;
}
.article-related li a { color: var(--slate-900); text-decoration: none; font-weight: 500; }
.article-related li a:hover { color: #ca8a04; }
.back-link { margin-top: 32px; }
.back-link a { color: var(--gray-700); text-decoration: none; }

/* ============================================================
   PŘEDVOLBA
   ============================================================ */

.prefix-stats {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 16px;
    margin: 24px 0 40px;
}
.stat-box {
    background: white;
    border: 1px solid var(--gray-200);
    border-radius: 12px;
    padding: 20px;
    text-align: center;
}
.stat-box strong { display: block; font-size: 32px; font-weight: 700; color: var(--slate-900); }
.stat-box span { display: block; color: var(--gray-700); font-size: 14px; margin-top: 4px; }
.stat-box.score-safe strong { color: #10B981; }
.stat-box.score-moderate strong { color: #3B82F6; }
.stat-box.score-risky strong { color: #F59E0B; }
.stat-box.score-dangerous strong { color: #DC2626; }

.verdict-summary { margin: 32px 0; padding: 24px; background: #f9fafb; border-radius: 12px; }
.verdict-summary h2 { margin-top: 0; }
.verdict-summary .verdict-bars { display: flex; flex-direction: column; gap: 8px; }
.verdict-row { display: grid; grid-template-columns: 120px 1fr 50px; gap: 12px; align-items: center; }
.verdict-label { font-size: 14px; font-weight: 500; }
.verdict-count { text-align: right; font-variant-numeric: tabular-nums; color: var(--gray-700); }

/* ============================================================
   ADMIN
   ============================================================ */

.admin-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 32px;
    padding-bottom: 16px;
    border-bottom: 2px solid var(--gray-200);
    gap: 16px;
    flex-wrap: wrap;
}
.admin-header h1 { margin: 0; }
.admin-user { display: flex; align-items: center; gap: 16px; font-size: 14px; }
.nav-admin { background: var(--slate-900); color: var(--yellow); padding: 6px 12px; border-radius: 6px; }

.admin-stats {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: 12px;
    margin-bottom: 32px;
}
.stat-warn strong { color: #DC2626 !important; }

.admin-nav { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin: 32px 0; }
.admin-nav-card {
    display: block;
    padding: 24px;
    background: white;
    border: 2px solid var(--gray-200);
    border-radius: 12px;
    text-decoration: none;
    color: var(--slate-900);
    transition: all 0.15s;
}
.admin-nav-card:hover { border-color: var(--yellow); transform: translateY(-2px); box-shadow: 0 4px 12px rgba(0,0,0,0.05); }
.admin-nav-card h3 { margin: 0 0 4px; }
.admin-nav-card p { margin: 0; color: var(--gray-700); font-size: 14px; }

.admin-table { width: 100%; border-collapse: collapse; margin-top: 16px; }
.admin-table th, .admin-table td {
    padding: 10px 12px;
    text-align: left;
    border-bottom: 1px solid var(--gray-200);
    font-size: 14px;
}
.admin-table th { background: var(--gray-100); font-weight: 600; }
.admin-table tr.row-hidden { opacity: 0.5; background: #fafafa; }
.admin-table tr.row-reported { background: #fef3c7; }
.td-truncate { max-width: 300px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

.status-pill {
    display: inline-block;
    padding: 2px 8px;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}
.status-pill.status-ok { background: #d1fae5; color: #065f46; }
.status-pill.status-reported { background: #fef3c7; color: #92400e; }
.status-pill.status-hidden { background: #e5e7eb; color: #374151; }

/* Filtry / taby */
.filter-tabs { display: flex; gap: 4px; border-bottom: 2px solid var(--gray-200); margin-bottom: 24px; }
.filter-tabs a {
    padding: 10px 20px;
    color: var(--gray-700);
    text-decoration: none;
    border-bottom: 2px solid transparent;
    margin-bottom: -2px;
    font-weight: 500;
}
.filter-tabs a.active { color: var(--slate-900); border-bottom-color: var(--yellow); }

/* Moderation list */
.moderation-list { display: flex; flex-direction: column; gap: 16px; }
.moderation-item {
    border: 1px solid var(--gray-200);
    border-radius: 12px;
    padding: 16px 20px;
    background: white;
}
.moderation-item.is-hidden { opacity: 0.6; background: #fafafa; }
.moderation-header { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; margin-bottom: 12px; }
.moderation-header time { color: #6b7280; font-size: 13px; }
.moderation-text { margin: 0 0 12px; line-height: 1.5; }
.moderation-footer { display: flex; justify-content: space-between; align-items: center; gap: 12px; flex-wrap: wrap; }
.moderation-actions { display: flex; gap: 8px; flex-wrap: wrap; }

/* Form (admin) */
.form { display: flex; flex-direction: column; gap: 16px; max-width: 720px; }
.form label { display: flex; flex-direction: column; gap: 6px; }
.form label > span { font-size: 14px; font-weight: 500; color: var(--slate-900); }
.form input[type="text"],
.form input[type="email"],
.form input[type="password"],
.form textarea {
    padding: 10px 14px;
    border: 1px solid #d1d5db;
    border-radius: 8px;
    font-size: 15px;
    font-family: inherit;
    background: white;
}
.form textarea { resize: vertical; min-height: 80px; }
.form input:focus, .form textarea:focus {
    outline: 2px solid var(--yellow);
    outline-offset: 0;
    border-color: var(--yellow);
}
.form .checkbox { flex-direction: row; align-items: center; gap: 10px; }
.form-actions { display: flex; gap: 12px; align-items: center; margin-top: 8px; }
.form-delete { margin-top: 32px; padding-top: 24px; border-top: 1px solid var(--gray-200); }
.narrow { max-width: 480px; }

/* Buttons */
.btn-primary {
    background: var(--slate-900);
    color: var(--yellow);
    padding: 10px 20px;
    border: none;
    border-radius: 8px;
    font-weight: 600;
    cursor: pointer;
    text-decoration: none;
    display: inline-block;
    font-size: 15px;
}
.btn-primary:hover { background: #1e293b; }
.btn-text {
    background: transparent;
    color: var(--gray-700);
    padding: 8px 12px;
    border: 1px solid #d1d5db;
    border-radius: 6px;
    cursor: pointer;
    font-size: 13px;
    text-decoration: none;
    display: inline-block;
}
.btn-text:hover { background: var(--gray-100); }
.btn-warn {
    background: #fbbf24;
    color: #78350f;
    padding: 6px 12px;
    border: none;
    border-radius: 6px;
    cursor: pointer;
    font-size: 13px;
    font-weight: 500;
}
.btn-warn:hover { background: #f59e0b; }
.btn-danger {
    background: #fee2e2;
    color: #991b1b;
    padding: 6px 12px;
    border: 1px solid #fca5a5;
    border-radius: 6px;
    cursor: pointer;
    font-size: 13px;
    font-weight: 500;
}
.btn-danger:hover { background: #fecaca; }
.btn-small { font-size: 12px; padding: 4px 10px; }

/* Vote buttons na komentářích */
.comment-actions { display: inline-flex; gap: 8px; margin-left: 12px; }
.btn-vote, .btn-report {
    background: transparent;
    border: 1px solid #d1d5db;
    color: var(--gray-700);
    padding: 4px 10px;
    border-radius: 6px;
    font-size: 12px;
    cursor: pointer;
    font-family: inherit;
}
.btn-vote:hover:not(:disabled) { background: #d1fae5; border-color: #10B981; color: #065f46; }
.btn-report:hover:not(:disabled) { background: #fee2e2; border-color: #DC2626; color: #991b1b; }
.btn-vote:disabled, .btn-report:disabled { opacity: 0.5; cursor: not-allowed; }

/* Alerts */
.alert { padding: 12px 16px; border-radius: 8px; margin-bottom: 16px; font-size: 14px; }
.alert-error { background: #fee2e2; color: #991b1b; border: 1px solid #fca5a5; }
.alert-success { background: #d1fae5; color: #065f46; border: 1px solid #6ee7b7; }
.small { font-size: 13px; }

@media (max-width: 640px) {
    .admin-nav { grid-template-columns: 1fr; }
    .verdict-row { grid-template-columns: 100px 1fr 40px; gap: 8px; font-size: 13px; }
    .article-detail { padding-left: 16px; padding-right: 16px; }
    .article-header h1 { font-size: 26px; }
    .admin-table { font-size: 12px; }
    .admin-table th:nth-child(4), .admin-table td:nth-child(4) { display: none; }
}

.section-header {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    margin-bottom: 16px;
    flex-wrap: wrap;
    gap: 8px;
    border-bottom: 1px solid var(--slate-100);
    padding-bottom: 10px;
}
.section-header h2 { margin: 0; font-size: 18px; font-weight: 600; }
.section-link {
    color: var(--slate-700);
    text-decoration: none;
    font-weight: 500;
    font-size: 13px;
}
.section-link:hover { color: var(--slate-900); text-decoration: underline; }

/* Prefix list — kompaktní řádek */
.prefix-list {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}
.prefix-list a {
    display: inline-block;
    padding: 6px 12px;
    background: var(--slate-50);
    border: 1px solid var(--slate-100);
    border-radius: 6px;
    color: var(--slate-700);
    text-decoration: none;
    font-size: 13px;
    font-variant-numeric: tabular-nums;
}
.prefix-list a:hover {
    background: var(--yellow);
    color: var(--slate-900);
    border-color: var(--yellow);
}

/* Article card — zkompaktnit */
.article-card {
    padding: 14px 16px !important;
    border-radius: 8px !important;
}
.article-card h2, .article-card h3 {
    font-size: 16px !important;
    margin: 6px 0 !important;
    line-height: 1.3 !important;
}
.article-card h4 {
    font-size: 14px;
    margin: 6px 0;
    line-height: 1.3;
}
.article-card .article-excerpt {
    font-size: 13px !important;
    margin: 4px 0 !important;
    color: var(--slate-700);
}
.article-card time {
    font-size: 12px;
    color: var(--slate-500);
}
.article-category {
    font-size: 10px !important;
    padding: 2px 6px !important;
    letter-spacing: 0.04em !important;
}
.comment-author { font-size: 12px; color: var(--slate-500); }
.comment-time { font-size: 12px; }

/* ============================================================
   NEW HOMEPAGE — info-orientovaný layout (přepisuje předchozí .hero)
   ============================================================ */

/* (zachováno pro kompatibilitu — používá ho jiná stránka než HP) */
.hero-strip {
    background: #FACC15;
    padding: 36px 0 56px;
    position: relative;
}
.hero-content { max-width: 720px; }

.hero-badge {
    display: inline-block;
    background: white;
    border: 1px solid rgba(15,23,42,0.18);
    color: #1a1a1a;
    padding: 4px 12px;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: 14px;
}

.hero-strip h1 {
    font-size: 30px;
    font-weight: 800;
    color: #0F172A;
    margin: 0 0 12px;
    line-height: 1.15;
    letter-spacing: -0.015em;
}
@media (min-width: 720px) { .hero-strip h1 { font-size: 38px; } }

.hero-hl {
    position: relative;
    display: inline-block;
}
.hero-hl > span {
    position: relative;
    z-index: 1;
}
.hero-hl::after {
    content: '';
    position: absolute;
    left: 0;
    right: 0;
    bottom: 2px;
    height: 10px;
    background: #fde047;
    z-index: 0;
}

.hero-strip-sub {
    font-size: 15px;
    color: #3a3a3a;
    margin: 0 0 18px;
    max-width: 580px;
    line-height: 1.5;
}

.hero-strip-search {
    display: flex;
    gap: 4px;
    max-width: 540px;
    background: white;
    border-radius: 12px;
    padding: 4px;
    border: 2px solid rgba(15,23,42,0.12);
    box-shadow: 0 4px 10px rgba(0,0,0,0.06);
    position: relative;
    z-index: 2;
}
.hero-strip-search input {
    flex: 1;
    padding: 11px 16px;
    border: none;
    border-radius: 8px;
    font-size: 16px;
    font-family: inherit;
    background: transparent;
    min-width: 0;
    color: #1a1a1a;
    outline: none;
}
.hero-strip-search input::placeholder { color: #94a3b8; }
.hero-strip-search button {
    padding: 0 22px;
    height: 40px;
    background: #0F172A;
    color: white;
    border: none;
    border-radius: 8px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    font-family: inherit;
    white-space: nowrap;
}
.hero-strip-search button:hover { background: #1e293b; }

.hero-strip-meta {
    margin: 16px 0 0;
    font-size: 13px;
    color: #3a3a3a;
    position: relative;
    z-index: 2;
}
.hero-strip-meta strong { color: #0F172A; font-weight: 700; }

/* 2-col layout */
.layout-2col {
    display: grid;
    grid-template-columns: 1fr;
    gap: 24px;
    margin: 8px auto 32px;
}
@media (min-width: 880px) {
    .layout-2col {
        grid-template-columns: minmax(0, 1fr) 280px;
        gap: 24px;
    }
}

.layout-main { min-width: 0; }
.layout-side { min-width: 0; }

/* Block — sekční rámec hlavního sloupce */
.block { margin-bottom: 28px; }
.block-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin: 0 0 14px;
    padding: 0 4px 8px;
    border-bottom: 1px solid #ececec;
}
.block-header h2 {
    margin: 0;
    font-size: 17px;
    font-weight: 700;
    color: #0F172A;
    position: relative;
    padding-bottom: 6px;
}
.block-header h2::after {
    content: '';
    position: absolute;
    left: 0;
    bottom: -9px;
    width: 36px;
    height: 3px;
    background: #FACC15;
    border-radius: 2px;
}
.block-meta { font-size: 12px; color: #888; }
.block-link {
    font-size: 13px;
    color: #0F172A;
    font-weight: 600;
}
.block-link:hover { color: #d63384; }

/* Data tabulka — řádky jako bíle karty s lehkým shadow (vyhledatcislo styl) */
.data-table {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0 6px;
    font-size: 13px;
    margin-top: -6px;
}
.data-table thead { display: none; } /* labels jsou vizuální už ze sloupců */
.data-table tbody tr {
    background: #fff;
    box-shadow: 0 1px 2px rgba(0,0,0,0.04);
    transition: box-shadow 0.15s;
}
.data-table tbody tr:hover {
    box-shadow: 0 2px 6px rgba(0,0,0,0.08);
}
.data-table tbody td {
    padding: 12px 14px;
    vertical-align: middle;
    line-height: 1.4;
    border-top: 1px solid #ececec;
    border-bottom: 1px solid #ececec;
}
.data-table tbody td:first-child {
    border-left: 1px solid #ececec;
    border-radius: 8px 0 0 8px;
}
.data-table tbody td:last-child {
    border-right: 1px solid #ececec;
    border-radius: 0 8px 8px 0;
}
.data-table .col-time { white-space: nowrap; color: #999; width: 80px; font-size: 12px; }
.data-table .col-num { white-space: nowrap; width: 130px; }
.data-table .col-num a {
    color: #0F172A;
    text-decoration: none;
    font-variant-numeric: tabular-nums;
    font-weight: 600;
    font-size: 14px;
    border-bottom: 2px solid #fde047;
    padding-bottom: 1px;
}
.data-table .col-num a:visited { color: #0F172A; }
.data-table .col-num a:hover { color: #d63384; border-bottom-color: #d63384; }
.data-table .col-num .muted {
    display: block;
    font-size: 11px;
    color: #999;
    font-weight: normal;
    margin-top: 1px;
}
.data-table .col-verdict { white-space: nowrap; width: 110px; }
.data-table .col-text { color: #2a2a2a; }
.data-table .col-text .muted { color: #888; font-size: 12px; }
.data-table .col-rank { width: 36px; color: #aaa; text-align: center; font-weight: 600; }
.data-table .col-num-r { text-align: right; font-variant-numeric: tabular-nums; white-space: nowrap; width: 70px; }

/* Verdict tečka — drobná barevná značka místo velkých tagů */
.vdot {
    display: inline-block;
    width: 7px;
    height: 7px;
    border-radius: 50%;
    margin-right: 5px;
    vertical-align: 1px;
}
.vdot-useful { background: var(--useful); }
.vdot-safe { background: var(--moderate); }
.vdot-neutral { background: var(--neutral); }
.vdot-harassing { background: var(--harassing); }
.vdot-dangerous { background: var(--dangerous); }

/* Score pill — malé barevné skóre 1-5 */
.score-pill {
    display: inline-block;
    padding: 2px 8px;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 600;
    color: white;
    font-variant-numeric: tabular-nums;
}
.score-pill.score-safe { background: #69b977; }
.score-pill.score-moderate { background: #5b8ec5; }
.score-pill.score-risky { background: #d4923f; }
.score-pill.score-dangerous { background: #c95151; }
.score-pill.score-unknown { background: #aaa; }

/* Aktuality — featured + seznam — sjednocená bíla karta */
.article-feature {
    padding: 16px 18px;
    background: #fff;
    border: 1px solid #ececec;
    border-radius: 8px;
    box-shadow: 0 1px 2px rgba(0,0,0,0.04);
    margin-bottom: 8px;
}
.article-feature h3 {
    margin: 4px 0 6px;
    font-size: 18px;
    font-weight: 700;
    line-height: 1.3;
}
.article-feature h3 a { color: #1a1a1a; text-decoration: none; }
.article-feature h3 a:hover { color: #d63384; }
.article-feature p {
    margin: 0 0 6px;
    color: #444;
    font-size: 13px;
    line-height: 1.55;
}
.kicker {
    display: inline-block;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: #d63384;
    font-weight: 600;
}
.article-rest {
    list-style: none;
    padding: 14px 18px;
    margin: 0;
    background: #fff;
    border: 1px solid #ececec;
    border-radius: 8px;
    box-shadow: 0 1px 2px rgba(0,0,0,0.04);
}
.article-rest li {
    padding: 8px 0;
    border-bottom: 1px solid #f3f3f3;
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: baseline;
    gap: 12px;
    font-size: 13px;
}
.article-rest li:last-child { border-bottom: none; padding-bottom: 0; }
.article-rest li:first-child { padding-top: 0; }
.article-rest li a { color: #1a1a1a; text-decoration: none; }
.article-rest li a:hover { color: #d63384; }
.article-rest .kicker { white-space: nowrap; font-size: 10px; }
.article-rest time { font-size: 11px; color: #999; white-space: nowrap; }

/* Sidebar bloky — bílé karty s shadow */
.aside-block {
    margin-bottom: 16px;
    font-size: 13px;
    background: #fff;
    border: 1px solid #ececec;
    border-radius: 8px;
    padding: 14px 16px;
    box-shadow: 0 1px 2px rgba(0,0,0,0.04);
}
.aside-block h3 {
    margin: 0 0 12px;
    padding: 0 0 8px;
    font-size: 13px;
    font-weight: 700;
    color: #0F172A;
    background: none;
    border-bottom: 1px solid #f3f3f3;
    position: relative;
}
.aside-block h3::after {
    content: '';
    position: absolute;
    left: 0;
    bottom: -1px;
    width: 24px;
    height: 2px;
    background: #FACC15;
}
.aside-list {
    list-style: none;
    padding: 0;
    margin: 0;
}
.aside-list li {
    padding: 6px 0;
    line-height: 1.4;
    border-bottom: 1px solid #f5f5f5;
}
.aside-list li:last-child { border-bottom: none; padding-bottom: 0; }
.aside-list a { color: #d63384; text-decoration: none; }
.aside-list a:hover { text-decoration: underline; }

.aside-dl {
    margin: 0;
    font-size: 13px;
}
.aside-dl dt {
    font-weight: 500;
    margin-top: 8px;
    color: #1a1a1a;
}
.aside-dl dt:first-child { margin-top: 0; }
.aside-dl dt a { color: #d63384; text-decoration: none; }
.aside-dl dt a:hover { text-decoration: underline; }
.aside-dl dd {
    margin: 2px 0 0;
    color: #666;
    font-size: 12px;
    line-height: 1.45;
}

/* Verdict summary v sidebaru — bar chart */
.verdict-summary-list {
    list-style: none;
    padding: 0;
    margin: 0;
}
.verdict-summary-list li {
    display: grid;
    grid-template-columns: 12px 1fr 40px 26px;
    align-items: center;
    gap: 6px;
    padding: 3px 0;
    font-size: 12px;
}
.vsum-label { color: #444; white-space: nowrap; font-size: 11px; }
.vsum-bar {
    display: block;
    background: #ececea;
    height: 5px;
    overflow: hidden;
}
.vsum-bar > span { display: block; height: 100%; background: #777; }
.vsum-cnt { text-align: right; color: #777; font-variant-numeric: tabular-nums; font-size: 11px; }

/* Mobile — sidebar pod main */
@media (max-width: 879px) {
    .layout-2col { gap: 24px; }
    .data-table { font-size: 12px; }
    .data-table .col-text { display: none; }
    .data-table .col-time { width: 60px; }
}

/* ============================================================
   HOMEPAGE — port designu z cislo.info-nove (Next.js)
   ============================================================ */

/* HERO — žluté pozadí s dekoracemi (rotated rounded shapes v rozích) */
.hero-cnove {
    background: #FDE047; /* yellow-300 */
    position: relative;
    overflow: hidden;
    border-bottom: 1px solid rgba(15,23,42,0.08);
}
.hero-cnove::before {
    /* dot pattern */
    content: '';
    position: absolute;
    inset: 0;
    background-image: radial-gradient(rgba(15,23,42,0.08) 1px, transparent 1px);
    background-size: 18px 18px;
    opacity: 0.5;
    pointer-events: none;
}
.hero-deco {
    position: absolute;
    border: 2px solid rgba(15,23,42,0.1);
    pointer-events: none;
}
.hero-deco-tr {
    top: -96px;
    right: -96px;
    width: 256px;
    height: 256px;
    transform: rotate(12deg);
    border-radius: 32px;
    background: rgba(250,204,21,0.4);
}
.hero-deco-bl {
    bottom: -128px;
    left: -80px;
    width: 288px;
    height: 288px;
    transform: rotate(-6deg);
    border-radius: 50%;
    background: rgba(254,240,138,0.5);
}

.hero-cnove-grid {
    position: relative;
    display: grid;
    grid-template-columns: 1fr;
    gap: 32px;
    padding: 48px 16px 56px;
    z-index: 1;
}
@media (min-width: 1000px) {
    .hero-cnove-grid {
        grid-template-columns: 2fr 1fr;
        gap: 48px;
        padding: 64px 16px 72px;
    }
}

.hero-cnove-main { min-width: 0; }

/* Badge s pulsing dot */
.hero-cnove-badge {
    display: inline-flex;
    align-items: center;
    background: white;
    border: 2px solid #0F172A;
    color: #0F172A;
    padding: 5px 14px;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.07em;
    margin-bottom: 18px;
    box-shadow: 0 1px 2px rgba(0,0,0,0.05);
}
.hero-cnove-dot {
    display: inline-block;
    width: 8px;
    height: 8px;
    background: #0F172A;
    border-radius: 50%;
    margin-right: 8px;
    animation: heroPulse 2s infinite;
}
@keyframes heroPulse {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.4; }
}

/* H1 s yellow highlight */
.hero-cnove-h1 {
    font-size: 36px;
    font-weight: 900;
    color: #0F172A;
    line-height: 1.1;
    margin: 0 0 22px;
    letter-spacing: -0.02em;
    max-width: 640px;
}
@media (min-width: 720px) { .hero-cnove-h1 { font-size: 48px; } }
@media (min-width: 1000px) { .hero-cnove-h1 { font-size: 56px; } }

.hero-cnove-hl {
    position: relative;
    display: inline-block;
}
.hero-cnove-hl > span { position: relative; z-index: 1; }
.hero-cnove-hl::after {
    content: '';
    position: absolute;
    left: 0;
    right: 0;
    bottom: 4px;
    height: 12px;
    background: #FACC15;
    z-index: 0;
}

.hero-cnove-sub {
    font-size: 17px;
    color: #1e293b;
    margin: 0 0 28px;
    max-width: 580px;
    line-height: 1.5;
}
@media (min-width: 720px) { .hero-cnove-sub { font-size: 19px; } }
.hero-cnove-sub strong { font-weight: 700; }

/* Search box — bílý wrapper s 2px borderem + shadow */
.hero-cnove-search {
    display: flex;
    align-items: center;
    gap: 0;
    max-width: 560px;
    background: white;
    border: 2px solid rgba(15,23,42,0.1);
    border-radius: 16px;
    padding: 6px 6px 6px 16px;
    box-shadow: 0 8px 16px rgba(0,0,0,0.08);
}
.hero-cnove-search-icon {
    color: #64748B;
    font-size: 20px;
    margin-right: 8px;
}
.hero-cnove-search input {
    flex: 1;
    padding: 12px 4px;
    border: none;
    font-size: 17px;
    font-family: inherit;
    background: transparent;
    color: #0F172A;
    outline: none;
    min-width: 0;
}
.hero-cnove-search input::placeholder { color: #94a3b8; }
.hero-cnove-search button {
    padding: 0 26px;
    height: 44px;
    background: #0F172A;
    color: white;
    border: none;
    border-radius: 10px;
    font-size: 15px;
    font-weight: 600;
    cursor: pointer;
    font-family: inherit;
    white-space: nowrap;
}
.hero-cnove-search button:hover { background: #1e293b; }

.hero-cnove-example {
    margin: 12px 0 0;
    font-size: 12px;
    color: #475569;
}
.hero-cnove-example code {
    background: rgba(255,255,255,0.5);
    padding: 1px 6px;
    border-radius: 3px;
    font-family: ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace;
    font-size: 12px;
}

.hero-cnove-trust {
    display: flex;
    flex-wrap: wrap;
    gap: 8px 24px;
    list-style: none;
    padding: 0;
    margin: 28px 0 0;
    font-size: 14px;
    color: #1e293b;
}
.hero-cnove-trust li::before {
    content: '✓';
    color: #0F172A;
    font-weight: 700;
    margin-right: 6px;
}
.hero-cnove-trust strong { font-weight: 700; }

.hero-cnove-cta-line {
    margin: 22px 0 0;
    font-size: 14px;
    color: #1e293b;
}
.hero-cnove-cta-line a {
    font-weight: 600;
    color: #0F172A;
    text-decoration: underline;
    text-decoration-color: rgba(15,23,42,0.3);
    text-underline-offset: 4px;
}
.hero-cnove-cta-line a:hover { text-decoration-color: #0F172A; }

/* Aside (sidebar v hero) */
.hero-cnove-aside {
    background: white;
    border: 2px solid rgba(15,23,42,0.08);
    border-radius: 16px;
    padding: 18px 20px;
    box-shadow: 0 4px 8px rgba(0,0,0,0.05);
}
.hero-cnove-aside h3 {
    margin: 0 0 12px;
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: #475569;
}
.hero-cnove-aside ul { list-style: none; padding: 0; margin: 0 0 12px; }
.hero-cnove-aside li {
    padding: 8px 0;
    border-bottom: 1px solid #f1f5f9;
}
.hero-cnove-aside li:last-child { border-bottom: none; }
.hero-cnove-aside li .kicker {
    display: block;
    margin-bottom: 2px;
    font-size: 10px;
    color: #d97706;
}
.hero-cnove-aside li a {
    display: block;
    color: #0F172A;
    text-decoration: none;
    font-size: 13px;
    font-weight: 600;
    line-height: 1.35;
    margin-bottom: 2px;
}
.hero-cnove-aside li a:hover { text-decoration: underline; }
.hero-cnove-aside li time { font-size: 11px; color: #94a3b8; }
.hero-cnove-aside-more {
    display: inline-block;
    font-size: 13px;
    font-weight: 600;
    color: #0F172A;
    text-decoration: underline;
    text-underline-offset: 3px;
}

/* ============================================================
   JAK TO FUNGUJE — 3 karty s velkými fadenými čísly
   ============================================================ */
.how-section {
    padding: 64px 0;
    background: white;
}
.how-header {
    text-align: center;
    max-width: 580px;
    margin: 0 auto 40px;
}
.how-header h2 {
    font-size: 28px;
    font-weight: 800;
    color: #0F172A;
    margin: 0 0 8px;
    letter-spacing: -0.01em;
}
@media (min-width: 720px) { .how-header h2 { font-size: 32px; } }
.how-header p {
    color: #64748B;
    font-size: 16px;
    margin: 0;
}

.how-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 16px;
}
@media (min-width: 720px) { .how-grid { grid-template-columns: repeat(3, 1fr); } }

.how-card {
    position: relative;
    background: white;
    border: 1px solid #e2e8f0;
    border-radius: 14px;
    padding: 24px;
    overflow: hidden;
    transition: box-shadow 0.2s;
}
.how-card:hover { box-shadow: 0 4px 12px rgba(0,0,0,0.06); }
.how-bignum {
    position: absolute;
    top: -10px;
    right: 14px;
    font-size: 88px;
    line-height: 1;
    font-weight: 900;
    color: #fef9c3;
    letter-spacing: -0.04em;
    user-select: none;
    pointer-events: none;
}
.how-card:nth-child(2) .how-bignum { color: #fef3c7; }
.how-card:nth-child(3) .how-bignum { color: #d1fae5; }
.how-icon {
    position: relative;
    width: 48px;
    height: 48px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 22px;
    margin-bottom: 14px;
    z-index: 1;
}
.how-icon-yellow { background: #fde047; color: #0F172A; }
.how-icon-amber { background: #fef3c7; color: #b45309; }
.how-icon-emerald { background: #d1fae5; color: #047857; }
.how-card h3 {
    position: relative;
    font-size: 17px;
    font-weight: 700;
    color: #0F172A;
    margin: 0 0 8px;
    z-index: 1;
}
.how-card p {
    position: relative;
    font-size: 14px;
    color: #475569;
    line-height: 1.5;
    margin: 0;
    z-index: 1;
}

/* ============================================================
   DARK SECTION (slate-950) — Hodnocení od komunity + CTA
   ============================================================ */
.dark-section {
    background: #020617; /* slate-950 */
    color: white;
    padding: 64px 0;
}
.dark-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 32px;
    align-items: center;
}
@media (min-width: 880px) { .dark-grid { grid-template-columns: 1fr 1fr; gap: 48px; } }

.dark-text { min-width: 0; }
.dark-badge {
    display: inline-block;
    background: #FACC15;
    color: #0F172A;
    padding: 4px 12px;
    border-radius: 4px;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: 14px;
}
.dark-text h2 {
    font-size: 26px;
    font-weight: 800;
    color: white;
    line-height: 1.2;
    margin: 0 0 16px;
    letter-spacing: -0.01em;
}
@media (min-width: 720px) { .dark-text h2 { font-size: 32px; } }
.dark-text p {
    color: #cbd5e1;
    line-height: 1.6;
    font-size: 15px;
    margin: 0;
}
.t-yellow { color: #FACC15; }
.t-emerald { color: #34d399; }
.t-orange { color: #fb923c; }
.t-red { color: #f87171; }

.dark-features {
    list-style: none;
    padding: 0;
    margin: 22px 0 0;
}
.dark-features li {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 6px 0;
    color: #cbd5e1;
    font-size: 14px;
}
.dark-feature-icon {
    flex: none;
    display: grid;
    place-items: center;
    width: 26px;
    height: 26px;
    background: #FACC15;
    color: #0F172A;
    border-radius: 6px;
    font-weight: 700;
    font-size: 14px;
    margin-top: 1px;
}
.dark-features strong { color: white; font-weight: 600; }

/* Demo karta (uvnitř dark sekce) */
.demo-card {
    background: white;
    color: #0F172A;
    border-radius: 14px;
    padding: 22px 24px;
    box-shadow: 0 10px 30px rgba(0,0,0,0.4);
}
.demo-card-label {
    margin: 0 0 4px;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: #64748B;
}
.demo-card-num {
    margin: 0 0 14px;
    font-size: 24px;
    font-weight: 800;
    color: #0F172A;
    letter-spacing: -0.01em;
    font-variant-numeric: tabular-nums;
}
.demo-card-verdict-block {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    padding: 10px 16px;
    border-radius: 12px;
    border: 2px solid;
    margin-bottom: 12px;
}
.demo-vb-text { font-size: 18px; font-weight: 700; }
.demo-vb-meta {
    border-left: 1px solid currentColor;
    padding-left: 12px;
    font-size: 12px;
    font-weight: 500;
    opacity: 0.75;
}
.demo-vb-safe { background: #d1fae5; border-color: #6ee7b7; color: #065f46; }
.demo-vb-moderate { background: #dbeafe; border-color: #93c5fd; color: #1e40af; }
.demo-vb-risky { background: #fef3c7; border-color: #fbbf24; color: #92400e; }
.demo-vb-dangerous { background: #fee2e2; border-color: #fca5a5; color: #991b1b; }
.demo-vb-unknown { background: #f1f5f9; border-color: #cbd5e1; color: #475569; }

.demo-card-counts {
    display: flex;
    flex-wrap: wrap;
    gap: 8px 16px;
    list-style: none;
    padding: 0;
    margin: 0 0 16px;
    font-size: 12px;
    color: #475569;
}
.demo-card-counts li { display: inline-flex; align-items: center; gap: 6px; }
.demo-card-counts strong { color: #0F172A; font-weight: 700; }
.dot {
    display: inline-block;
    width: 8px;
    height: 8px;
    border-radius: 50%;
}
.dot-useful { background: #10b981; }
.dot-safe { background: #3b82f6; }
.dot-neutral { background: #6b7280; }
.dot-harassing { background: #f59e0b; }
.dot-dangerous { background: #dc2626; }

.demo-card-comments { display: flex; flex-direction: column; gap: 8px; }
.demo-comment {
    border: 1px solid #e2e8f0;
    border-radius: 10px;
    padding: 10px 12px;
    background: white;
}
.demo-comment header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 6px;
    font-size: 11px;
}
.demo-comment time { color: #94a3b8; font-size: 11px; }
.demo-comment p {
    margin: 0;
    font-size: 13px;
    color: #334155;
    line-height: 1.45;
}

/* ============================================================
   ŽIVÁ AKTIVITA — naposledy + žebříček
   ============================================================ */
.live-section { padding: 56px 0 40px; }
.live-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 32px;
}
@media (min-width: 880px) { .live-grid { grid-template-columns: minmax(0, 1fr) 280px; gap: 32px; } }

.live-list { display: flex; flex-direction: column; gap: 8px; }
.live-row {
    display: grid;
    grid-template-columns: 160px 110px 1fr auto;
    gap: 14px;
    align-items: center;
    padding: 12px 16px;
    background: white;
    border: 1px solid #e2e8f0;
    border-radius: 10px;
    transition: border-color 0.15s, box-shadow 0.15s;
}
.live-row:hover {
    border-color: #FACC15;
    box-shadow: 0 2px 6px rgba(0,0,0,0.05);
}
.live-num {
    font-weight: 700;
    color: #0F172A;
    text-decoration: none;
    font-variant-numeric: tabular-nums;
    font-size: 14px;
    border-bottom: 2px solid #fde047;
    padding-bottom: 1px;
    width: fit-content;
}
.live-num:hover { color: #d97706; border-bottom-color: #d97706; }
.live-text {
    font-size: 13px;
    color: #475569;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.live-time {
    font-size: 11px;
    color: #94a3b8;
    white-space: nowrap;
}
@media (max-width: 720px) {
    .live-row { grid-template-columns: 1fr 1fr; }
    .live-text { grid-column: 1 / -1; white-space: normal; }
    .live-time { grid-column: 2; text-align: right; }
}

/* Žebříček */
.rank-list {
    list-style: none;
    padding: 0;
    margin: 0;
    background: white;
    border: 1px solid #e2e8f0;
    border-radius: 10px;
    overflow: hidden;
}
.rank-list li {
    display: grid;
    grid-template-columns: 28px 1fr auto;
    gap: 10px;
    align-items: center;
    padding: 10px 14px;
    border-bottom: 1px solid #f1f5f9;
    font-size: 13px;
}
.rank-list li:last-child { border-bottom: none; }
.rank-list li:nth-child(-n+3) .rank-pos { color: #d97706; font-weight: 800; }
.rank-pos { color: #94a3b8; font-weight: 600; text-align: center; }
.rank-num {
    color: #0F172A;
    font-variant-numeric: tabular-nums;
    text-decoration: none;
    font-weight: 600;
    border-bottom: 2px solid #fde047;
    padding-bottom: 1px;
    width: fit-content;
}
.rank-num:hover { color: #d97706; border-bottom-color: #d97706; }
.rank-cnt { color: #64748B; font-size: 12px; }

/* ============================================================
   AKTUALITY (homepage)
   ============================================================ */
.articles-section { padding: 32px 0 56px; }
.articles-grid-featured {
    display: grid;
    grid-template-columns: 1fr;
    gap: 16px;
}
@media (min-width: 880px) { .articles-grid-featured { grid-template-columns: 2fr 1fr; gap: 20px; } }

.article-feature-big {
    padding: 26px 28px;
    background: white;
    border: 1px solid #e2e8f0;
    border-radius: 14px;
    box-shadow: 0 1px 2px rgba(0,0,0,0.04);
}
.article-feature-big h3 {
    margin: 6px 0 10px;
    font-size: 22px;
    font-weight: 800;
    line-height: 1.25;
    letter-spacing: -0.01em;
}
.article-feature-big h3 a { color: #0F172A; text-decoration: none; }
.article-feature-big h3 a:hover { color: #d97706; }
.article-feature-big p {
    margin: 0 0 10px;
    color: #475569;
    font-size: 14px;
    line-height: 1.55;
}

/* ============================================================
   KNOWLEDGE HUB
   ============================================================ */
.hub-section {
    padding: 56px 0;
    background: #f8fafc;
    border-top: 1px solid #e2e8f0;
    border-bottom: 1px solid #e2e8f0;
}
.hub-header { text-align: center; margin-bottom: 28px; }
.hub-header h2 {
    font-size: 26px;
    font-weight: 800;
    color: #0F172A;
    margin: 0 0 6px;
    letter-spacing: -0.01em;
}
.hub-header p { color: #64748B; margin: 0; font-size: 15px; }

.hub-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 12px;
}
.hub-card {
    background: white;
    border: 1px solid #e2e8f0;
    border-radius: 10px;
    padding: 14px 18px;
    text-decoration: none;
    color: #0F172A;
    transition: all 0.15s;
}
.hub-card:hover {
    border-color: #FACC15;
    box-shadow: 0 2px 6px rgba(0,0,0,0.05);
}
.hub-card strong {
    display: block;
    font-size: 14px;
    font-weight: 700;
    margin-bottom: 2px;
}
.hub-card span {
    display: block;
    font-size: 12px;
    color: #64748B;
}

/* ============================================================
   SITE STATS
   ============================================================ */
.stats-section {
    padding: 48px 0;
    background: white;
}
.stats-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 16px;
    text-align: center;
}
.stats-item {
    padding: 16px 12px;
    border-left: 3px solid #FACC15;
    text-align: left;
}
.stats-item strong {
    display: block;
    font-size: 32px;
    font-weight: 900;
    color: #0F172A;
    line-height: 1;
    letter-spacing: -0.02em;
    font-variant-numeric: tabular-nums;
}
.stats-item span {
    display: block;
    margin-top: 6px;
    color: #64748B;
    font-size: 13px;
}

/* ============================================================
   DARK CTA (split layout)
   ============================================================ */
.dark-section-cta { padding: 56px 0; }
.cta-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 32px;
    align-items: center;
}
@media (min-width: 880px) { .cta-grid { grid-template-columns: 1fr 1fr; gap: 48px; } }

.cta-card {
    background: white;
    color: #0F172A;
    border-radius: 14px;
    padding: 22px 24px;
    box-shadow: 0 10px 30px rgba(0,0,0,0.4);
}
.cta-card h3 {
    font-size: 18px;
    font-weight: 800;
    color: #0F172A;
    margin: 0 0 14px;
}
.cta-form { display: flex; gap: 8px; }
.cta-form input {
    flex: 1;
    padding: 11px 14px;
    border: 1px solid #cbd5e1;
    border-radius: 10px;
    font-size: 15px;
    font-family: inherit;
    color: #0F172A;
}
.cta-form input:focus {
    outline: 2px solid #FACC15;
    outline-offset: 0;
    border-color: #FACC15;
}
.cta-form button {
    padding: 0 18px;
    background: #0F172A;
    color: white;
    border: none;
    border-radius: 10px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    font-family: inherit;
    white-space: nowrap;
}
.cta-form button:hover { background: #1e293b; }
.demo-card-foot {
    margin: 10px 0 0;
    color: #64748B;
    font-size: 12px;
}

/* ============================================================
   FAQ
   ============================================================ */
.faq-section { padding: 48px 0 64px; }
.faq-section .block-header { margin-bottom: 18px; }
.faq-item {
    background: white;
    border: 1px solid #e2e8f0;
    border-radius: 10px;
    margin-bottom: 8px;
    padding: 0;
    overflow: hidden;
}
.faq-item summary {
    cursor: pointer;
    padding: 14px 18px;
    font-weight: 600;
    color: #0F172A;
    list-style: none;
    position: relative;
    padding-right: 40px;
    font-size: 14px;
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after {
    content: '+';
    position: absolute;
    right: 18px;
    top: 50%;
    transform: translateY(-50%);
    font-size: 20px;
    color: #94a3b8;
    font-weight: 400;
}
.faq-item[open] summary::after { content: '−'; color: #d97706; }
.faq-item[open] summary { border-bottom: 1px solid #f1f5f9; }
.faq-item p {
    margin: 0;
    padding: 14px 18px 18px;
    color: #475569;
    font-size: 14px;
    line-height: 1.6;
}
.faq-item summary:hover { background: #fafafa; }

/* ============================================================
   DETAIL ČÍSLA — port designu z cislo.info-nove
   ============================================================ */

.num-hero {
    background: #FDE047;
    position: relative;
    overflow: hidden;
    border-bottom: 1px solid rgba(15,23,42,0.08);
    padding: 32px 0 40px;
}
.num-hero::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image: radial-gradient(rgba(15,23,42,0.06) 1px, transparent 1px);
    background-size: 18px 18px;
    opacity: 0.5;
    pointer-events: none;
}
.num-hero-deco {
    position: absolute;
    top: -80px;
    right: -80px;
    width: 220px;
    height: 220px;
    border: 2px solid rgba(15,23,42,0.1);
    background: rgba(250,204,21,0.4);
    border-radius: 32px;
    transform: rotate(12deg);
    pointer-events: none;
}

.num-hero-grid {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: 1fr;
    gap: 24px;
}
@media (min-width: 880px) {
    .num-hero-grid { grid-template-columns: minmax(0, 1fr) 320px; gap: 32px; }
}

.num-hero-main { min-width: 0; }

.num-breadcrumb {
    font-size: 13px;
    color: #475569;
    margin-bottom: 14px;
    display: flex;
    align-items: center;
    gap: 6px;
    flex-wrap: wrap;
}
.num-breadcrumb a {
    color: #475569;
    text-decoration: none;
    font-weight: 500;
}
.num-breadcrumb a:hover { color: #0F172A; text-decoration: underline; }
.num-breadcrumb span:not(:last-child) { color: #94a3b8; }

.num-hero-title {
    font-size: 38px;
    font-weight: 900;
    color: #0F172A;
    margin: 0 0 14px;
    letter-spacing: -0.02em;
    line-height: 1.1;
    font-variant-numeric: tabular-nums;
}
@media (min-width: 720px) { .num-hero-title { font-size: 48px; } }

.num-hero-meta {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
    margin-bottom: 20px;
}
.num-hero-meta .badge {
    background: white;
    border: 1px solid rgba(15,23,42,0.15);
    color: #0F172A;
    font-weight: 600;
    font-size: 12px;
    padding: 4px 10px;
}
.num-hero-views { color: #475569; font-size: 13px; margin-left: 4px; }

/* Verdict block — barevný, s 2px borderem */
.num-verdict-block {
    display: inline-flex;
    align-items: stretch;
    gap: 0;
    padding: 14px 22px;
    border-radius: 14px;
    border: 2px solid;
    margin-bottom: 14px;
    max-width: 100%;
}
.num-vb-main {
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.num-vb-headline { font-size: 22px; font-weight: 800; line-height: 1.1; }
.num-vb-meta { font-size: 13px; opacity: 0.85; font-weight: 500; }
.num-vb-meta strong { font-weight: 700; }

.num-vb-safe { background: #d1fae5; border-color: #6ee7b7; color: #065f46; }
.num-vb-moderate { background: #dbeafe; border-color: #93c5fd; color: #1e40af; }
.num-vb-risky { background: #fef3c7; border-color: #fbbf24; color: #92400e; }
.num-vb-dangerous { background: #fee2e2; border-color: #fca5a5; color: #991b1b; }
.num-vb-unknown { background: white; border-color: rgba(15,23,42,0.15); color: #475569; }

.num-hero-cta {
    display: inline-block;
    margin-top: 4px;
    color: #0F172A;
    font-weight: 600;
    text-decoration: underline;
    text-decoration-color: rgba(15,23,42,0.3);
    text-underline-offset: 4px;
    font-size: 14px;
}
.num-hero-cta:hover { text-decoration-color: #0F172A; }

/* Verdict panel (right side) */
.num-verdict-panel {
    background: white;
    border: 1px solid rgba(15,23,42,0.08);
    border-radius: 14px;
    padding: 18px 20px;
    box-shadow: 0 4px 8px rgba(0,0,0,0.05);
}
.num-verdict-panel h3 {
    margin: 0 0 14px;
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: #475569;
}
.num-verdict-bars { display: flex; flex-direction: column; gap: 8px; }
.num-vbar {
    display: grid;
    grid-template-columns: 92px 1fr 28px;
    align-items: center;
    gap: 10px;
    font-size: 13px;
}
.num-vbar-label { color: #1e293b; font-weight: 500; font-size: 12px; }
.num-vbar-track {
    height: 8px;
    background: #f1f5f9;
    border-radius: 999px;
    overflow: hidden;
}
.num-vbar-fill {
    height: 100%;
    transition: width 0.3s;
    border-radius: 999px;
}
.num-vbar-fill.verdict-useful { background: #10b981; }
.num-vbar-fill.verdict-safe { background: #3b82f6; }
.num-vbar-fill.verdict-neutral { background: #6b7280; }
.num-vbar-fill.verdict-harassing { background: #f59e0b; }
.num-vbar-fill.verdict-dangerous { background: #dc2626; }
.num-vbar-cnt {
    text-align: right;
    color: #64748B;
    font-size: 12px;
    font-variant-numeric: tabular-nums;
}

/* CONTENT (komentáře + sidebar) */
.num-content { padding: 32px 0 56px; }
.num-content-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 28px;
}
@media (min-width: 880px) {
    .num-content-grid { grid-template-columns: minmax(0, 1fr) 280px; gap: 32px; }
}
.num-comments-main { min-width: 0; }
.num-side { min-width: 0; }

/* Comment card overrides pro detail page */
.num-comments-main .comment-item {
    background: white;
    border: 1px solid #e2e8f0;
    border-radius: 12px;
    padding: 16px 18px;
    border-left: 4px solid #cbd5e1;
}
.num-comments-main .comment-item.verdict-useful { border-left-color: #10b981; }
.num-comments-main .comment-item.verdict-safe { border-left-color: #3b82f6; }
.num-comments-main .comment-item.verdict-neutral { border-left-color: #6b7280; }
.num-comments-main .comment-item.verdict-harassing { border-left-color: #f59e0b; }
.num-comments-main .comment-item.verdict-dangerous { border-left-color: #dc2626; }

.comment-header {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 8px;
    flex-wrap: wrap;
    font-size: 13px;
}
.comment-header .verdict-tag { font-size: 11px; padding: 2px 10px; }
.comment-author { color: #64748B; font-size: 13px; font-weight: 500; }
.comment-time { color: #94a3b8; font-size: 12px; margin-left: auto; }
.comment-text { margin: 0 0 10px; color: #1e293b; font-size: 14px; line-height: 1.55; }
.comment-footer { display: flex; justify-content: space-between; align-items: center; }
.comment-actions { display: flex; gap: 6px; }
.btn-vote, .btn-report {
    background: white;
    border: 1px solid #e2e8f0;
    color: #475569;
    padding: 4px 12px;
    border-radius: 6px;
    font-size: 12px;
    cursor: pointer;
    font-family: inherit;
    transition: all 0.15s;
}
.btn-vote:hover:not(:disabled) { background: #d1fae5; border-color: #10b981; color: #065f46; }
.btn-report:hover:not(:disabled) { background: #fee2e2; border-color: #dc2626; color: #991b1b; }
.btn-vote:disabled, .btn-report:disabled { opacity: 0.5; cursor: not-allowed; }

/* Empty state */
.empty-card {
    background: white;
    border: 2px dashed #e2e8f0;
    border-radius: 14px;
    padding: 32px 24px;
    text-align: center;
    color: #64748B;
}
.empty-card p:first-child { color: #0F172A; font-size: 16px; margin-top: 0; }
.empty-card p { margin: 4px 0 12px; }
.empty-card .btn-cta { margin-top: 8px; }

/* Add comment card */
.add-comment-card {
    background: white;
    border: 1px solid #e2e8f0;
    border-radius: 14px;
    padding: 22px 24px;
    margin-top: 20px;
    box-shadow: 0 1px 2px rgba(0,0,0,0.04);
}
.add-comment-card header h2 {
    margin: 0 0 4px;
    font-size: 18px;
    font-weight: 800;
    color: #0F172A;
}
.add-comment-card header p {
    margin: 0 0 18px;
    color: #64748B;
    font-size: 13px;
}

.comment-form-cnove { display: flex; flex-direction: column; gap: 16px; }
.verdict-radio-grid { border: none; padding: 0; margin: 0; }
.verdict-radio-grid legend {
    font-weight: 600;
    color: #0F172A;
    margin-bottom: 10px;
    font-size: 14px;
}

.vradio-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
    gap: 8px;
}
.vradio {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    cursor: pointer;
    padding: 12px 8px;
    border: 2px solid #e2e8f0;
    border-radius: 10px;
    background: white;
    transition: all 0.15s;
    min-height: 76px;
    gap: 4px;
}
.vradio-label {
    font-size: 14px;
    font-weight: 700;
    color: #0F172A;
    line-height: 1.2;
    display: block;
}
.vradio-hint {
    font-size: 11px;
    font-weight: 500;
    color: #64748B;
    line-height: 1.3;
    display: block;
}
.vradio:has(input:checked) .vradio-label,
.vradio:has(input:checked) .vradio-hint { color: inherit; }
.vradio:hover { border-color: #cbd5e1; }
.vradio input { position: absolute; opacity: 0; pointer-events: none; }
.vradio:has(input:checked) { color: #0F172A; }
.vradio.verdict-useful:has(input:checked) { background: #d1fae5; border-color: #10b981; color: #065f46; }
.vradio.verdict-safe:has(input:checked) { background: #dbeafe; border-color: #3b82f6; color: #1e40af; }
.vradio.verdict-neutral:has(input:checked) { background: #f1f5f9; border-color: #6b7280; }
.vradio.verdict-harassing:has(input:checked) { background: #fef3c7; border-color: #f59e0b; color: #92400e; }
.vradio.verdict-dangerous:has(input:checked) { background: #fee2e2; border-color: #dc2626; color: #991b1b; }

.form-row {
    display: flex;
    flex-direction: column;
    gap: 6px;
    font-size: 14px;
    color: #0F172A;
    font-weight: 500;
}
.form-row > span { color: #1e293b; }
.form-row textarea,
.form-row input[type="text"] {
    padding: 10px 14px;
    border: 1px solid #cbd5e1;
    border-radius: 10px;
    font-family: inherit;
    font-size: 14px;
    color: #0F172A;
    background: white;
    resize: vertical;
}
.form-row textarea:focus,
.form-row input:focus {
    outline: none;
    border-color: #FACC15;
    box-shadow: 0 0 0 3px rgba(250,204,21,0.25);
}

.btn-cta {
    align-self: flex-start;
    background: #0F172A;
    color: white;
    border: none;
    border-radius: 10px;
    padding: 11px 24px;
    font-size: 15px;
    font-weight: 600;
    cursor: pointer;
    font-family: inherit;
    text-decoration: none;
    display: inline-block;
}
.btn-cta:hover { background: #1e293b; }

/* Sidebar info */
.info-dl {
    margin: 0;
    font-size: 13px;
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 4px 12px;
}
.info-dl dt {
    color: #64748B;
    font-size: 12px;
    font-weight: 500;
}
.info-dl dd {
    margin: 0;
    color: #0F172A;
    font-weight: 600;
    text-align: right;
    font-variant-numeric: tabular-nums;
}
.info-dl dd a { color: #0F172A; border-bottom: 2px solid #fde047; padding-bottom: 1px; }
.info-dl dd a:hover { color: #d97706; border-bottom-color: #d97706; }

.aside-tip { background: #fffbeb; border-color: #fde68a; }
.aside-tip h3::after { background: #d97706 !important; }
.aside-tip p { font-size: 13px; color: #78350f; line-height: 1.5; margin: 0; }
.aside-tip a { color: #92400e; font-weight: 600; text-decoration: underline; }

.aside-list li { display: flex; justify-content: space-between; align-items: center; gap: 8px; }

/* ============================================================
   PAGE HERO — sjednocený žlutý strip pro non-home stránky
   ============================================================ */
.page-hero {
    background: #FDE047;
    padding: 28px 0 32px;
    border-bottom: 1px solid rgba(15,23,42,0.08);
    position: relative;
    overflow: hidden;
}
.page-hero::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image: radial-gradient(rgba(15,23,42,0.05) 1px, transparent 1px);
    background-size: 18px 18px;
    opacity: 0.5;
    pointer-events: none;
}
.page-hero > .container { position: relative; z-index: 1; }

.page-hero-h1 {
    font-size: 30px;
    font-weight: 900;
    color: #0F172A;
    margin: 8px 0 6px;
    letter-spacing: -0.02em;
    line-height: 1.15;
}
@media (min-width: 720px) { .page-hero-h1 { font-size: 38px; } }

.page-hero-sub {
    font-size: 16px;
    color: #1e293b;
    margin: 0;
    max-width: 620px;
}

.page-hero-article .article-h1 { max-width: 800px; }
.article-kicker { color: #b45309 !important; }
.article-lead {
    font-size: 17px;
    color: #1e293b;
    margin: 6px 0 12px;
    max-width: 700px;
    line-height: 1.5;
    font-weight: 500;
}
.article-meta-row {
    display: flex;
    gap: 6px;
    align-items: center;
    color: #475569;
    font-size: 13px;
    margin-top: 4px;
}
.article-meta-row time { color: #1e293b; font-weight: 500; }

/* ============================================================
   AKTUALITY — listing
   ============================================================ */
.articles-page { padding: 28px 0 56px; }

.cat-tabs {
    display: flex;
    gap: 4px;
    flex-wrap: wrap;
    margin-bottom: 24px;
    border-bottom: 1px solid #e2e8f0;
    padding-bottom: 0;
}
.cat-tabs a {
    padding: 8px 16px;
    color: #475569;
    text-decoration: none;
    font-weight: 500;
    font-size: 14px;
    border-bottom: 3px solid transparent;
    margin-bottom: -1px;
    transition: all 0.15s;
}
.cat-tabs a:hover { color: #0F172A; }
.cat-tabs a.active {
    color: #0F172A;
    border-bottom-color: #FACC15;
    font-weight: 700;
}
.cat-tabs a span {
    color: #94a3b8;
    font-size: 12px;
    margin-left: 2px;
    font-weight: 500;
}

.article-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: 16px;
    margin-top: 16px;
}

.article-card-cnove {
    background: white;
    border: 1px solid #e2e8f0;
    border-radius: 12px;
    padding: 18px 20px;
    transition: all 0.15s;
}
.article-card-cnove:hover {
    border-color: #FACC15;
    box-shadow: 0 4px 12px rgba(0,0,0,0.05);
}
.article-card-cnove .kicker {
    font-size: 10px;
}
.article-card-cnove h3 {
    margin: 6px 0 8px;
    font-size: 16px;
    font-weight: 700;
    line-height: 1.3;
    letter-spacing: -0.005em;
}
.article-card-cnove h3 a { color: #0F172A; text-decoration: none; }
.article-card-cnove h3 a:hover { color: #d97706; }
.article-card-cnove p {
    margin: 0 0 10px;
    color: #475569;
    font-size: 13px;
    line-height: 1.55;
}

/* ============================================================
   AKTUALITA — detail
   ============================================================ */
.article-detail-cnove { padding: 32px 0 56px; }
.article-detail-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 32px;
}
@media (min-width: 880px) {
    .article-detail-grid { grid-template-columns: minmax(0, 1fr) 280px; gap: 40px; }
}

.article-body-main { min-width: 0; max-width: 720px; }
.article-side { min-width: 0; }

.article-body {
    font-size: 16px;
    line-height: 1.7;
    color: #1e293b;
}
.article-body p { margin: 0 0 16px; }
.article-body strong { color: #0F172A; font-weight: 700; }

.number-link-inline {
    display: inline-block;
    color: #0F172A;
    background: #fef9c3;
    padding: 1px 6px;
    border-radius: 4px;
    text-decoration: none;
    font-weight: 600;
    font-variant-numeric: tabular-nums;
    border-bottom: 2px solid #fde047;
}
.number-link-inline:hover {
    background: #FACC15;
    color: #0F172A;
}

/* Mentioned numbers panel */
.mentioned-numbers {
    margin-top: 32px;
    padding: 18px 22px;
    background: #fffbeb;
    border: 1px solid #fde68a;
    border-radius: 12px;
}
.mentioned-numbers h3 {
    margin: 0 0 14px;
    font-size: 13px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: #78350f;
}
.mentioned-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 6px; }
.mentioned-list li {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 8px 12px;
    background: white;
    border: 1px solid #fde68a;
    border-radius: 8px;
    flex-wrap: wrap;
}
.mn-num {
    color: #0F172A;
    text-decoration: none;
    font-weight: 700;
    border-bottom: 2px solid #fde047;
    padding-bottom: 1px;
    font-variant-numeric: tabular-nums;
}
.mn-num:hover { color: #d97706; }
.mn-cnt { margin-left: auto; color: #92400e; font-size: 12px; }

.back-link { margin-top: 32px; padding-top: 20px; border-top: 1px solid #e2e8f0; }
.back-link a { color: #475569; text-decoration: none; font-size: 14px; }
.back-link a:hover { color: #0F172A; }

/* Related list (sidebar) */
.related-list { list-style: none; padding: 0; margin: 0; }
.related-list li {
    padding: 8px 0;
    border-bottom: 1px solid #f1f5f9;
}
.related-list li:last-child { border-bottom: none; }
.related-list a {
    display: block;
    color: #0F172A;
    text-decoration: none;
    font-weight: 600;
    font-size: 13px;
    line-height: 1.35;
    margin-bottom: 2px;
}
.related-list a:hover { color: #d97706; }
.related-list time { font-size: 11px; color: #94a3b8; }

/* ============================================================
   PŘEDVOLBA
   ============================================================ */
.prefix-page { padding: 24px 0 56px; }

.prefix-stats-cnove {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: 12px;
    margin-bottom: 28px;
}
.prefix-stat {
    background: white;
    border: 1px solid #e2e8f0;
    border-left: 3px solid #FACC15;
    border-radius: 10px;
    padding: 14px 16px;
}
.prefix-stat strong {
    display: block;
    font-size: 26px;
    font-weight: 900;
    color: #0F172A;
    line-height: 1.1;
    letter-spacing: -0.02em;
    font-variant-numeric: tabular-nums;
}
.prefix-stat span {
    display: block;
    margin-top: 4px;
    font-size: 12px;
    color: #64748B;
}
.prefix-stat-score.score-safe strong { color: #10b981; }
.prefix-stat-score.score-moderate strong { color: #3b82f6; }
.prefix-stat-score.score-risky strong { color: #f59e0b; }
.prefix-stat-score.score-dangerous strong { color: #dc2626; }

.prefix-content-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 28px;
}
@media (min-width: 880px) {
    .prefix-content-grid { grid-template-columns: minmax(0, 1fr) 280px; gap: 32px; }
}

/* Live row v předvolbě má víc sloupců */
.prefix-page .live-row {
    grid-template-columns: 160px 110px 1fr auto;
}
@media (max-width: 720px) {
    .prefix-page .live-row { grid-template-columns: 1fr 1fr; }
}


.search-page { padding: 24px 0 56px; }
.search-page code {
    background: #f1f5f9;
    padding: 1px 6px;
    border-radius: 3px;
    font-family: ui-monospace, monospace;
    font-size: 12px;
}
.search-page .live-row {
    grid-template-columns: 160px 120px 1fr auto;
}
@media (max-width: 720px) {
    .search-page .live-row { grid-template-columns: 1fr auto; }
}


/* Honeypot — vizuálně schované pro lidi, viditelné pro boty */
.honeypot {
    position: absolute;
    left: -10000px;
    top: -10000px;
    width: 1px;
    height: 1px;
    opacity: 0;
}

/* Pagination */
.pagination {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 12px;
    margin-top: 24px;
    padding: 16px 0;
}
.pg-btn {
    padding: 8px 16px;
    background: white;
    border: 1px solid #e2e8f0;
    border-radius: 8px;
    color: #0F172A;
    text-decoration: none;
    font-size: 13px;
    font-weight: 500;
    transition: all 0.15s;
}
.pg-btn:hover {
    border-color: #FACC15;
    background: #fffbeb;
}
.pg-info {
    font-size: 13px;
    color: #64748B;
}

/* Admin refresh — sjednocený s novým stylem */
.admin-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 16px;
    margin-bottom: 24px;
    padding-bottom: 14px;
    border-bottom: 1px solid #e2e8f0;
}
.admin-header h1 {
    margin: 0;
    font-size: 22px;
    font-weight: 800;
    color: #0F172A;
    letter-spacing: -0.01em;
}
.admin-user {
    display: flex;
    gap: 12px;
    align-items: center;
    font-size: 13px;
    color: #64748B;
}

.admin-stats {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: 12px;
    margin-bottom: 28px;
}
.admin-stats .stat-box {
    background: white;
    border: 1px solid #e2e8f0;
    border-left: 3px solid #FACC15;
    border-radius: 10px;
    padding: 14px 16px;
    text-align: left;
}
.admin-stats .stat-box.stat-warn { border-left-color: #dc2626; }
.admin-stats .stat-box strong {
    display: block;
    font-size: 24px;
    font-weight: 900;
    color: #0F172A;
    line-height: 1.1;
    font-variant-numeric: tabular-nums;
}
.admin-stats .stat-box span {
    display: block;
    margin-top: 4px;
    color: #64748B;
    font-size: 12px;
}

.admin-nav {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 12px;
    margin: 28px 0;
}
.admin-nav-card {
    background: white;
    border: 1px solid #e2e8f0;
    border-radius: 12px;
    padding: 18px 20px;
    text-decoration: none;
    color: #0F172A;
    transition: all 0.15s;
}
.admin-nav-card:hover {
    border-color: #FACC15;
    box-shadow: 0 4px 12px rgba(0,0,0,0.05);
}
.admin-nav-card h3 {
    margin: 0 0 4px;
    font-size: 16px;
    font-weight: 700;
    color: #0F172A;
}
.admin-nav-card p {
    margin: 0;
    color: #64748B;
    font-size: 13px;
}

.admin-table {
    width: 100%;
    border-collapse: collapse;
    background: white;
    border: 1px solid #e2e8f0;
    border-radius: 10px;
    overflow: hidden;
    margin-top: 12px;
    font-size: 13px;
}
.admin-table th {
    background: #f8fafc;
    text-align: left;
    padding: 8px 12px;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: #475569;
    border-bottom: 1px solid #e2e8f0;
}
.admin-table td {
    padding: 8px 12px;
    border-bottom: 1px solid #f1f5f9;
    vertical-align: top;
}
.admin-table tr:last-child td { border-bottom: none; }
.admin-table tr.row-reported { background: #fffbeb; }
.admin-table tr.row-hidden { opacity: 0.5; background: #fafafa; }

.status-pill {
    display: inline-block;
    padding: 1px 8px;
    border-radius: 999px;
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.status-pill.status-ok { background: #d1fae5; color: #065f46; }
.status-pill.status-reported { background: #fef3c7; color: #92400e; }
.status-pill.status-hidden { background: #f1f5f9; color: #475569; }

/* Filter tabs (admin) */
.filter-tabs {
    display: flex;
    gap: 4px;
    border-bottom: 1px solid #e2e8f0;
    margin-bottom: 18px;
}
.filter-tabs a {
    padding: 8px 16px;
    color: #475569;
    text-decoration: none;
    font-size: 13px;
    font-weight: 500;
    border-bottom: 3px solid transparent;
    margin-bottom: -1px;
}
.filter-tabs a:hover { color: #0F172A; }
.filter-tabs a.active { color: #0F172A; border-bottom-color: #FACC15; font-weight: 700; }

/* Moderation list */
.moderation-list { display: flex; flex-direction: column; gap: 10px; }
.moderation-item {
    background: white;
    border: 1px solid #e2e8f0;
    border-radius: 10px;
    padding: 14px 18px;
}
.moderation-item.is-hidden { opacity: 0.6; }
.moderation-header {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
    margin-bottom: 10px;
    font-size: 13px;
}
.moderation-header time { color: #94a3b8; font-size: 12px; }
.moderation-text {
    margin: 0 0 12px;
    color: #1e293b;
    font-size: 14px;
    line-height: 1.55;
}
.moderation-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px;
}
.moderation-actions { display: flex; gap: 6px; flex-wrap: wrap; }

.btn-warn, .btn-danger, .btn-text {
    padding: 5px 12px;
    border-radius: 6px;
    font-size: 12px;
    font-weight: 500;
    cursor: pointer;
    font-family: inherit;
    text-decoration: none;
    border: 1px solid;
    background: white;
}
.btn-warn { color: #92400e; border-color: #fde68a; background: #fffbeb; }
.btn-warn:hover { background: #fef3c7; }
.btn-danger { color: #991b1b; border-color: #fca5a5; background: #fef2f2; }
.btn-danger:hover { background: #fee2e2; }
.btn-text { color: #475569; border-color: #e2e8f0; }
.btn-text:hover { color: #0F172A; background: #f8fafc; }
.btn-small { padding: 3px 10px; font-size: 11px; }

.btn-primary {
    background: #0F172A;
    color: white;
    border: none;
    padding: 9px 20px;
    border-radius: 8px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    font-family: inherit;
    text-decoration: none;
    display: inline-block;
}
.btn-primary:hover { background: #1e293b; }

/* Form (admin) */
.form { display: flex; flex-direction: column; gap: 14px; max-width: 720px; }
.form label { display: flex; flex-direction: column; gap: 6px; font-size: 13px; color: #1e293b; font-weight: 500; }
.form input[type="text"],
.form input[type="email"],
.form input[type="password"],
.form textarea {
    padding: 9px 12px;
    border: 1px solid #cbd5e1;
    border-radius: 8px;
    font-size: 14px;
    font-family: inherit;
    background: white;
    color: #0F172A;
}
.form input:focus, .form textarea:focus {
    outline: none;
    border-color: #FACC15;
    box-shadow: 0 0 0 3px rgba(250,204,21,0.25);
}
.form .checkbox { flex-direction: row; align-items: center; gap: 8px; }
.form-actions { display: flex; gap: 10px; align-items: center; margin-top: 8px; }
.form-delete { margin-top: 24px; padding-top: 18px; border-top: 1px solid #e2e8f0; }
.narrow { max-width: 460px; }

.alert {
    padding: 10px 14px;
    border-radius: 8px;
    margin-bottom: 14px;
    font-size: 13px;
    border: 1px solid;
}
.alert-error { background: #fef2f2; color: #991b1b; border-color: #fca5a5; }
.alert-success { background: #d1fae5; color: #065f46; border-color: #6ee7b7; }
/* ============================================================
 * Pokračování: nové komponenty pro 1:1 conversion
 * ============================================================ */

/* === Hero variants === */
.hero {
    padding: 56px 0 48px;
}
.hero-yellow {
    background: #FDE047;
    color: #0F172A;
    position: relative;
    overflow: hidden;
}
.hero-yellow::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image: radial-gradient(circle at 1px 1px, rgba(15,23,42,0.12) 1px, transparent 0);
    background-size: 16px 16px;
    opacity: 0.5;
    pointer-events: none;
}
.hero-yellow > .container { position: relative; z-index: 1; }
.hero-yellow .hero-badge { background: #fff; color: #0F172A; border: 2px solid #0F172A; font-weight: 700; }
.hero-yellow .hero-title, .hero-yellow .hero-lead, .hero-yellow .breadcrumb { color: #0F172A; }
.hero-yellow .breadcrumb a { color: #475569; }
.hero-yellow .breadcrumb a:hover { color: #0F172A; }
.hero-dark   { background: #0F172A; color: #F8FAFC; }
.hero-badge {
    display: inline-block; padding: 4px 12px; border-radius: 999px;
    background: #fff; color: #0F172A; font-size: 13px; font-weight: 600;
    margin-bottom: 16px;
}
.hero-badge-red { background: #DC2626; color: #fff; }
.hero-title { font-size: 40px; line-height: 1.15; font-weight: 800; margin: 0 0 12px; max-width: 800px; }
.hero-title-light, .hero-dark .hero-title, .hero-dark h1 { color: #F8FAFC !important; }
.hero-lead { font-size: 18px; max-width: 760px; line-height: 1.55; margin: 0; opacity: 0.92; }
.hero-lead-light { color: #CBD5E1; }
.yellow-highlight {
    background: linear-gradient(120deg, #FACC15 0%, #FACC15 100%);
    background-position: 0 88%;
    background-repeat: no-repeat;
    background-size: 100% 18px;
    padding: 0 4px;
}

/* === Breadcrumb === */
.breadcrumb { font-size: 13px; opacity: 0.8; margin-bottom: 16px; }
.breadcrumb a { color: inherit; text-decoration: underline; }
.breadcrumb-dark { color: #CBD5E1; }
.breadcrumb-dark a { color: #FACC15; }

/* === Article layout === */
.article-layout {
    display: grid; grid-template-columns: minmax(0,1fr) 320px; gap: 48px;
}
@media (max-width: 920px) { .article-layout { grid-template-columns: 1fr; } }
.article-body { max-width: 760px; }
.article-body h2 { margin-top: 32px; font-size: 26px; }
.article-body p, .article-body li { line-height: 1.7; font-size: 16px; }
.article-body .lead { font-size: 18px; color: #334155; }
.article-body .checklist, .article-body .numbered-list { padding-left: 20px; }
.article-body .checklist li { list-style: none; padding-left: 24px; position: relative; margin-bottom: 8px; }
.article-body .checklist li::before { content: '✓'; position: absolute; left: 0; color: #10B981; font-weight: 700; }
.article-body .numbered-list li { margin-bottom: 8px; }
.article-body .numbered-list.compact li { margin-bottom: 4px; font-size: 14px; }
.article-update { color: #64748B; font-size: 13px; margin-top: 32px; padding-top: 16px; border-top: 1px solid #E2E8F0; }
.article-sidebar { display: flex; flex-direction: column; gap: 16px; }
.sidebar-card {
    background: #fff; border: 1px solid #E2E8F0; border-radius: 12px;
    padding: 20px;
}
.sidebar-card h3 { margin: 0 0 12px; font-size: 16px; }
.sidebar-yellow { background: #FEF9C3; border-color: #FACC15; }
.sidebar-red { background: #FEE2E2; border-color: #FCA5A5; }
.sidebar-list { padding: 0; list-style: none; }
.sidebar-list li { padding: 4px 0; }
.sidebar-form { display: flex; gap: 6px; }
.sidebar-form input { flex: 1; padding: 8px; border: 1px solid #CBD5E1; border-radius: 6px; }
.sidebar-form button { padding: 8px 12px; background: #0F172A; color: #fff; border: 0; border-radius: 6px; cursor: pointer; }

/* === Buttons === */
.btn { display: inline-block; padding: 10px 20px; border-radius: 8px; font-weight: 600; cursor: pointer; border: 0; text-decoration: none; }
.btn-yellow { background: #FACC15; color: #0F172A; }
.btn-yellow:hover { background: #EAB308; }
.btn-outline { background: #fff; color: #0F172A; border: 1px solid #CBD5E1; }
.btn-outline:hover { background: #F1F5F9; }
.btn-danger { background: #DC2626; color: #fff; }
.btn-mini { padding: 4px 8px; font-size: 12px; border-radius: 4px; }

/* === Glossary === */
.glossary-grid {
    display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 16px;
}
.glossary-card {
    background: #fff; border: 1px solid #E2E8F0; border-radius: 12px;
    padding: 20px; text-decoration: none; color: inherit;
    transition: all 0.15s;
    display: flex; flex-direction: column; gap: 8px;
}
.glossary-card:hover { border-color: #FACC15; box-shadow: 0 4px 12px rgba(0,0,0,0.06); }
.glossary-term { font-size: 20px; margin: 0; }
.glossary-def { font-size: 14px; color: #475569; line-height: 1.5; flex: 1; }
.glossary-link { color: #0F172A; font-size: 13px; font-weight: 600; }

/* === Scam encyklopedie === */
.scam-grid {
    display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: 16px;
}
.scam-card {
    background: #fff; border: 2px solid #E2E8F0; border-radius: 12px;
    padding: 24px; text-decoration: none; color: inherit;
    display: flex; flex-direction: column; gap: 12px;
    transition: all 0.15s;
}
.scam-card:hover { border-color: #DC2626; }
.scam-card-header { display: flex; gap: 12px; align-items: flex-start; }
.scam-icon { font-size: 24px; }
.scam-title { margin: 0; font-size: 19px; }
.scam-subtitle { color: #475569; font-size: 14px; line-height: 1.5; flex: 1; }
.scam-link { color: #DC2626; font-size: 14px; font-weight: 600; }

/* === Q&A === */
.qa-list { display: flex; flex-direction: column; gap: 12px; }
.qa-card {
    background: #fff; border: 1px solid #E2E8F0; border-radius: 10px;
    padding: 20px; text-decoration: none; color: inherit; display: block;
}
.qa-card:hover { border-color: #FACC15; }
.qa-question { display: flex; gap: 12px; align-items: flex-start; margin: 0 0 8px; font-size: 17px; }
.qa-q-icon, .qa-a-icon {
    display: inline-flex; width: 24px; height: 24px; border-radius: 50%;
    align-items: center; justify-content: center; font-weight: 700; font-size: 12px; flex-shrink: 0;
}
.qa-q-icon { background: #FACC15; color: #0F172A; }
.qa-a-icon { background: #0F172A; color: #fff; }
.qa-answer { display: flex; gap: 12px; align-items: flex-start; color: #475569; font-size: 14px; line-height: 1.55; margin: 0 0 8px; }
.qa-link { color: #0F172A; font-size: 13px; font-weight: 600; }

/* === Žebříček + tables === */
.zebricek-tabs { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 24px; padding-bottom: 8px; border-bottom: 1px solid #E2E8F0; }
.zebricek-tabs .tab {
    padding: 8px 14px; background: #fff; border: 1px solid #E2E8F0; border-radius: 999px;
    text-decoration: none; color: #475569; font-size: 14px; font-weight: 500;
}
.zebricek-tabs .tab-active { background: #0F172A; color: #fff; border-color: #0F172A; }
.zebricek-table { width: 100%; border-collapse: collapse; }
.zebricek-table thead th { text-align: left; padding: 10px; background: #F8FAFC; font-size: 13px; color: #64748B; border-bottom: 1px solid #E2E8F0; }
.zebricek-table tbody td { padding: 10px; border-bottom: 1px solid #F1F5F9; font-size: 14px; }
.zebricek-table .rank { width: 40px; color: #94A3B8; font-weight: 700; }
.zebricek-table .num { text-align: right; font-variant-numeric: tabular-nums; }
.zebricek-table .empty-state { text-align: center; color: #94A3B8; padding: 24px; }
.phone-link { font-weight: 600; color: #0F172A; }

/* === Verdict pills (page-level, may override existing variants) === */
.verdict-pill {
    display: inline-block; padding: 2px 10px; border-radius: 999px;
    font-size: 12px; font-weight: 600;
}
.verdict-safe { background: #D1FAE5; color: #065F46; }
.verdict-moderate { background: #DBEAFE; color: #1E40AF; }
.verdict-risky { background: #FED7AA; color: #9A3412; }
.verdict-dangerous { background: #FEE2E2; color: #991B1B; }
.verdict-unknown { background: #F1F5F9; color: #64748B; }

.verdict-list { padding: 0; list-style: none; display: flex; flex-direction: column; gap: 6px; }

/* === Stats === */
.stats-row { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 12px; margin: 24px 0; }
.stat-box { background: #fff; border: 1px solid #E2E8F0; border-radius: 12px; padding: 20px; text-align: center; }
.stat-box-yellow { background: #FEF9C3; border-color: #FACC15; }
.stat-box-red { background: #FEE2E2; border-color: #FCA5A5; }
.stat-value { font-size: 28px; font-weight: 800; color: #0F172A; line-height: 1.1; }
.stat-label { color: #64748B; font-size: 13px; margin-top: 4px; }

.stats-cols { display: grid; grid-template-columns: 1fr 1fr; gap: 32px; margin-top: 32px; }
@media (max-width: 760px) { .stats-cols { grid-template-columns: 1fr; } }

/* === Verdict bars === */
.verdict-bars { display: flex; flex-direction: column; gap: 8px; margin: 24px 0; }
.verdict-bar-row { display: grid; grid-template-columns: 120px 1fr 100px; gap: 12px; align-items: center; }
.verdict-bar-label { font-size: 14px; }
.verdict-bar-track { height: 14px; background: #F1F5F9; border-radius: 7px; overflow: hidden; }
.verdict-bar-fill { height: 100%; transition: width 0.3s; }
.verdict-bar-value { font-size: 13px; color: #475569; text-align: right; font-variant-numeric: tabular-nums; }

/* === Operátoři / předvolby === */
.op-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 16px; }
.op-card {
    background: #fff; border: 1px solid #E2E8F0; border-radius: 12px;
    padding: 24px; text-decoration: none; color: inherit;
    display: flex; flex-direction: column; gap: 12px;
}
.op-card:hover { border-color: #FACC15; }
.op-name { margin: 0; font-size: 22px; }
.op-desc { color: #475569; font-size: 14px; flex: 1; line-height: 1.5; }
.op-stats { display: flex; gap: 16px; font-size: 13px; color: #64748B; }
.op-link { color: #0F172A; font-weight: 600; font-size: 14px; }
.op-section-title { margin-top: 24px; }

.prefix-grid { display: flex; flex-wrap: wrap; gap: 8px; margin: 12px 0 24px; }
.prefix-chip {
    padding: 8px 14px; background: #fff; border: 1px solid #E2E8F0; border-radius: 999px;
    text-decoration: none; color: #0F172A; font-size: 14px;
    display: flex; gap: 8px; align-items: center;
}
.prefix-chip:hover { border-color: #FACC15; background: #FEF9C3; }
.prefix-chip-hot { border-color: #DC2626; background: #FEE2E2; color: #991B1B; }
.prefix-chip-special { border-color: #10B981; background: #D1FAE5; color: #065F46; }
.prefix-chip-warning { border-color: #F59E0B; background: #FED7AA; color: #9A3412; }
.prefix-num { font-weight: 700; }
.prefix-reports { font-size: 11px; opacity: 0.75; }

/* Risk row */
.risk-low { background: #fff; }
.risk-medium { background: #FEF3C7; }
.risk-high { background: #FEE2E2; }
.risk-badge { padding: 2px 8px; border-radius: 999px; font-size: 11px; font-weight: 600; }
.risk-badge-low { background: #D1FAE5; color: #065F46; }
.risk-badge-medium { background: #FED7AA; color: #9A3412; }
.risk-badge-high { background: #FEE2E2; color: #991B1B; }

/* === Firmy === */
.firma-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 16px; }
.firma-card {
    background: #fff; border: 1px solid #E2E8F0; border-radius: 12px;
    padding: 20px; text-decoration: none; color: inherit;
    display: flex; flex-direction: column; gap: 8px;
}
.firma-card:hover { border-color: #FACC15; }
.firma-name { margin: 0; font-size: 18px; }
.firma-cat { font-size: 12px; color: #64748B; text-transform: uppercase; letter-spacing: 0.5px; }
.firma-desc { color: #475569; font-size: 14px; line-height: 1.5; flex: 1; }
.firma-meta { display: flex; gap: 16px; font-size: 13px; color: #64748B; padding-top: 8px; border-top: 1px solid #F1F5F9; }
.contact-list { padding: 0; list-style: none; font-size: 14px; }
.contact-list li { padding: 6px 0; border-bottom: 1px solid #F1F5F9; }

/* === Recent activity === */
.recent-list { display: flex; flex-direction: column; gap: 12px; }
.recent-item {
    background: #fff; border-left: 3px solid #DC2626; padding: 16px;
    border-radius: 0 8px 8px 0;
}
.recent-head { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; margin-bottom: 8px; }
.recent-text { font-style: italic; color: #475569; margin: 8px 0; line-height: 1.5; }
.recent-meta { font-size: 12px; color: #64748B; }
.featured-comment {
    background: #FEF9C3; border-left: 4px solid #FACC15; padding: 20px;
    margin: 16px 0; font-size: 16px;
}
.featured-comment p { margin: 0 0 12px; line-height: 1.6; }
.featured-comment footer { font-size: 13px; color: #475569; }
.featured-comment .helpful { margin-left: 12px; color: #065F46; font-weight: 600; }

/* === Articles === */
.article-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 16px; }
.article-card {
    background: #fff; border: 1px solid #E2E8F0; border-radius: 12px;
    padding: 20px; text-decoration: none; color: inherit;
    display: flex; flex-direction: column; gap: 8px;
}
.article-card:hover { border-color: #FACC15; }
.article-cat { font-size: 11px; color: #DC2626; text-transform: uppercase; letter-spacing: 0.5px; font-weight: 600; }
.article-card h3 { margin: 0; font-size: 17px; }
.article-card p { font-size: 14px; color: #475569; line-height: 1.5; flex: 1; margin: 0; }

/* === CTA boxes === */
.section-cta-dark { background: #0F172A; color: #F8FAFC; padding: 40px 0; border-radius: 16px; }
.cta-box { text-align: center; padding: 32px; }
.cta-box h2 { margin: 0 0 12px; font-size: 26px; }
.cta-box p { font-size: 16px; opacity: 0.85; margin: 0 0 20px; }
.cta-light { background: #FEF9C3; border: 1px solid #FACC15; border-radius: 16px; }

/* === Case cards === */
.case-card { background: #FFF7ED; border-left: 4px solid #F59E0B; padding: 16px; margin: 12px 0; border-radius: 0 8px 8px 0; }
.case-card h3 { margin: 0 0 8px; font-size: 16px; }
.case-card p { margin: 0; font-size: 14px; color: #475569; }

/* === Tags === */
.tag-list { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 16px; }
.tag { padding: 2px 10px; border-radius: 999px; background: #F1F5F9; color: #475569; font-size: 12px; }

/* === Forms === */
.contact-form, .admin-form { display: flex; flex-direction: column; gap: 16px; max-width: 720px; }
.contact-form label, .admin-form label { display: flex; flex-direction: column; gap: 6px; font-size: 14px; font-weight: 600; color: #334155; }
.contact-form input, .contact-form textarea, .admin-form input, .admin-form textarea, .admin-form select {
    padding: 10px 12px; border: 1px solid #CBD5E1; border-radius: 8px; font-size: 14px; font-family: inherit; font-weight: 400;
}
.admin-form textarea.mono { font-family: 'Courier New', monospace; font-size: 12px; }
.admin-form .form-row { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 12px; }
.admin-form .form-actions { display: flex; gap: 8px; margin-top: 8px; }
.admin-form .checkbox { flex-direction: row; align-items: center; gap: 8px; font-weight: 400; }
.hp { position: absolute; left: -9999px; opacity: 0; pointer-events: none; }
.cislo-dne-nav { display: flex; gap: 16px; margin-top: 16px; font-size: 14px; }
.cislo-dne-nav a { color: #0F172A; text-decoration: underline; }

.search-large { display: flex; gap: 8px; max-width: 500px; margin: 16px 0; }
.search-large input { flex: 1; padding: 14px; border: 2px solid #FACC15; border-radius: 10px; font-size: 16px; }
.search-large button { padding: 14px 24px; }

/* === Filter bar === */
.filter-bar { display: flex; gap: 8px; flex-wrap: wrap; margin: 16px 0; align-items: center; }
.filter-bar input, .filter-bar select { padding: 8px 12px; border: 1px solid #CBD5E1; border-radius: 8px; font-size: 14px; }

/* === Pagination === */
.pagination { display: flex; gap: 4px; justify-content: center; margin: 24px 0; }
.page-link { padding: 6px 10px; border: 1px solid #CBD5E1; border-radius: 6px; text-decoration: none; color: #475569; font-size: 14px; }
.page-link:hover { background: #F1F5F9; }
.page-active { background: #0F172A; color: #fff; border-color: #0F172A; }

/* === Alerts === */
.alert { padding: 12px 16px; border-radius: 8px; margin: 16px 0; }
.alert-success { background: #D1FAE5; color: #065F46; border: 1px solid #6EE7B7; }
.alert-danger { background: #FEE2E2; color: #991B1B; border: 1px solid #FCA5A5; }
.alert-warning { background: #FEF3C7; color: #92400E; border: 1px solid #FCD34D; }
.alert ul { margin: 0; padding-left: 20px; }

/* === Footer paid === */
.footer-paid { padding: 12px 0; font-size: 13px; opacity: 0.7; border-top: 1px solid rgba(255,255,255,0.1); }
.footer-paid a { color: inherit; text-decoration: underline; opacity: 0.85; }

/* === Admin extras === */
.admin-nav { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 12px; margin: 24px 0; }
.admin-nav-card { background: #fff; border: 1px solid #E2E8F0; border-radius: 12px; padding: 20px; text-decoration: none; color: inherit; }
.admin-nav-card:hover { border-color: #FACC15; }
.admin-nav-card h3 { margin: 0 0 8px; font-size: 16px; }
.admin-nav-card p { margin: 0; font-size: 13px; color: #475569; }
.admin-nav-warn { border-color: #F59E0B; background: #FEF3C7; }

.section-title { margin-top: 40px; }
.empty-state { text-align: center; color: #94A3B8; padding: 24px; }
.muted { color: #64748B; font-size: 13px; }

/* ============================================================
 * Detail telefonního čísla — port z cislo.info-nove
 * ============================================================ */

/* === Hero karta === */
.num2-hero {
    background: #FDE047;
    padding: 32px 0 40px;
    position: relative;
    overflow: hidden;
}
.num2-hero::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image: radial-gradient(circle at 1px 1px, rgba(15,23,42,0.12) 1px, transparent 0);
    background-size: 16px 16px;
    opacity: 0.5;
    pointer-events: none;
}
.num2-hero > .container { position: relative; z-index: 1; }
.num2-breadcrumb {
    display: flex; flex-wrap: wrap; align-items: center; gap: 6px;
    font-size: 13px; color: #475569; margin-bottom: 20px;
}
.num2-breadcrumb a { color: #475569; text-decoration: none; }
.num2-breadcrumb a:hover { color: #0F172A; text-decoration: underline; }
.num2-bc-sep { color: #94A3B8; }
.num2-bc-current { font-weight: 600; color: #0F172A; }

.num2-hero-card {
    background: #FACC15;
    border-radius: 20px;
    padding: 32px;
    box-shadow: 0 8px 24px rgba(0,0,0,0.06);
}
@media (max-width: 760px) {
    .num2-hero-card { padding: 20px; }
}
.num2-hero-grid {
    display: grid; grid-template-columns: 280px 1fr; gap: 32px;
    align-items: flex-start;
}
@media (max-width: 760px) {
    .num2-hero-grid { grid-template-columns: 1fr; gap: 20px; }
}

/* SafetyPhoneCard */
.safety-phone-card {
    background: #fff; border-radius: 16px;
    border: 1px solid rgba(0,0,0,0.08); overflow: hidden;
    box-shadow: 0 4px 12px rgba(0,0,0,0.06);
}
.spc-top {
    padding: 20px; text-align: center;
    display: flex; flex-direction: column; align-items: center; gap: 6px;
}
.spc-top.spc-level-safe { background: #D1FAE5; color: #065F46; }
.spc-top.spc-level-moderate { background: #DBEAFE; color: #1E40AF; }
.spc-top.spc-level-risky { background: #FED7AA; color: #9A3412; }
.spc-top.spc-level-dangerous { background: #FEE2E2; color: #991B1B; }
.spc-icon-circle {
    width: 48px; height: 48px; border-radius: 50%;
    background: rgba(255,255,255,0.7);
    display: flex; align-items: center; justify-content: center;
    font-size: 24px;
}
.spc-label { font-size: 18px; font-weight: 700; line-height: 1.1; }
.spc-sample { font-size: 12px; color: #475569; }
.spc-bars { padding: 16px; margin: 0; list-style: none; display: flex; flex-direction: column; gap: 12px; }
.spc-row { display: flex; align-items: center; gap: 8px; font-size: 12px; }
.spc-row-label { flex: 1; color: #475569; font-weight: 500; }
.spc-row-cnt { color: #0F172A; font-weight: 700; font-variant-numeric: tabular-nums; }
.spc-row-pct { color: #94A3B8; font-variant-numeric: tabular-nums; min-width: 35px; text-align: right; }
.spc-bar-track { height: 6px; background: #F1F5F9; border-radius: 3px; overflow: hidden; margin-top: 4px; }
.spc-bar-fill { height: 100%; transition: width 0.3s; }

/* Hero body */
.num2-hero-body { min-width: 0; }
.num2-hero-eyebrow {
    font-size: 12px; text-transform: uppercase; letter-spacing: 0.8px;
    color: #475569; font-weight: 600; margin: 0 0 4px;
}
.num2-hero-eyebrow-sep { color: #94A3B8; margin: 0 4px; }
.num2-hero-title {
    font-size: 48px; font-weight: 800; color: #0F172A;
    margin: 0 0 8px; line-height: 1.05;
    font-variant-numeric: tabular-nums;
}
@media (max-width: 760px) { .num2-hero-title { font-size: 32px; } }
.num2-hero-region { font-size: 14px; color: #334155; margin: 0 0 12px; }

.num2-company-badge {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 6px 14px; background: rgba(255,255,255,0.85);
    border: 1px solid rgba(0,0,0,0.1); border-radius: 999px;
    text-decoration: none; color: #0F172A; font-size: 13px; font-weight: 600;
    margin-bottom: 12px;
}
.num2-company-badge:hover { background: #fff; }
.num2-no-rating { font-size: 14px; color: #334155; margin: 12px 0; }
.btn-dark {
    background: #0F172A; color: #fff; padding: 12px 24px;
    border-radius: 10px; font-weight: 600; display: inline-flex;
    align-items: center; gap: 8px; text-decoration: none; border: 0;
}
.btn-dark:hover { background: #1E293B; }
.num2-hero-cta { font-size: 15px; }
.num2-cta-sub { font-size: 11px; color: #475569; margin: 6px 0 0; }

.num2-locked-banner {
    margin-top: 24px; padding: 14px 16px;
    background: rgba(255,255,255,0.6); border: 1px solid rgba(0,0,0,0.15);
    border-radius: 12px; font-size: 14px; color: #334155;
}

/* SummaryBox */
.num2-summary {
    margin-top: 24px; padding: 16px; background: #fff;
    border-radius: 12px; display: flex; gap: 12px; align-items: flex-start;
    border: 1px solid rgba(0,0,0,0.08);
}
.num2-summary-icon {
    width: 28px; height: 28px; border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    background: #FEF3C7; flex-shrink: 0; font-size: 14px;
}
.num2-summary-safe .num2-summary-icon { background: #D1FAE5; }
.num2-summary-moderate .num2-summary-icon { background: #DBEAFE; }
.num2-summary-risky .num2-summary-icon { background: #FED7AA; }
.num2-summary-dangerous .num2-summary-icon { background: #FEE2E2; }
.num2-summary-eyebrow {
    font-size: 11px; text-transform: uppercase; letter-spacing: 0.8px;
    color: #475569; font-weight: 600; margin: 0;
}
.num2-summary-text { font-size: 14px; color: #1E293B; line-height: 1.55; margin: 4px 0 0; }

.num2-ai-box {
    margin-top: 16px; padding: 16px; background: #fff;
    border-radius: 12px; border: 1px solid rgba(0,0,0,0.08);
}
.num2-ai-eyebrow {
    font-size: 11px; text-transform: uppercase; letter-spacing: 0.8px;
    color: #475569; font-weight: 600; margin: 0 0 10px;
}
.num2-ai-box p { font-size: 14px; line-height: 1.6; color: #1E293B; margin: 0 0 10px; }
.num2-ai-box p:last-child { margin: 0; }

/* === Content layout === */
.num2-content { padding: 32px 0 56px; }
.num2-content-grid {
    display: grid; grid-template-columns: minmax(0,1fr) 320px; gap: 32px;
}
@media (max-width: 920px) { .num2-content-grid { grid-template-columns: 1fr; } }

.num2-main { min-width: 0; }
.num2-aside { display: flex; flex-direction: column; gap: 16px; }

/* Comment form */
.num2-form-card {
    background: #fff; border: 1px solid #E2E8F0; border-radius: 16px;
    padding: 24px; margin-bottom: 24px;
}
.num2-form-card header h2 { margin: 0 0 4px; font-size: 22px; }
.num2-form { display: flex; flex-direction: column; gap: 16px; margin-top: 16px; }
.num2-verdict-pills legend { font-weight: 600; font-size: 14px; margin-bottom: 8px; }
.num2-pill-grid {
    display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: 8px;
}
.num2-pill {
    display: flex; flex-direction: column; gap: 2px;
    padding: 12px 14px; border-radius: 12px; cursor: pointer;
    border: 2px solid; transition: all 0.15s;
}
.num2-pill input { position: absolute; left: -9999px; }
.num2-pill-title { font-weight: 700; font-size: 14px; }
.num2-pill-hint { font-size: 11px; opacity: 0.85; }
.num2-pill-useful { border-color: #6EE7B7; background: #ECFDF5; color: #065F46; }
.num2-pill-useful:hover, .num2-pill-useful:has(input:checked) { background: #10B981; color: #fff; border-color: #047857; }
.num2-pill-safe { border-color: #BEF264; background: #F7FEE7; color: #365314; }
.num2-pill-safe:hover, .num2-pill-safe:has(input:checked) { background: #84CC16; color: #fff; border-color: #4D7C0F; }
.num2-pill-neutral { border-color: #93C5FD; background: #EFF6FF; color: #1E40AF; }
.num2-pill-neutral:hover, .num2-pill-neutral:has(input:checked) { background: #3B82F6; color: #fff; border-color: #1D4ED8; }
.num2-pill-harassing { border-color: #FDBA74; background: #FFF7ED; color: #9A3412; }
.num2-pill-harassing:hover, .num2-pill-harassing:has(input:checked) { background: #F97316; color: #fff; border-color: #C2410C; }
.num2-pill-dangerous { border-color: #FCA5A5; background: #FEF2F2; color: #991B1B; }
.num2-pill-dangerous:hover, .num2-pill-dangerous:has(input:checked) { background: #DC2626; color: #fff; border-color: #991B1B; }

.num2-form-row { display: flex; flex-direction: column; gap: 6px; font-size: 14px; font-weight: 600; }
.num2-form-row textarea, .num2-form-row input[type=text] {
    padding: 10px 12px; border: 1px solid #CBD5E1; border-radius: 8px;
    font-family: inherit; font-size: 14px; font-weight: 400;
}
.num2-submit { align-self: flex-start; padding: 12px 28px; }

/* Comments section */
.num2-comments-section { margin-top: 24px; }
.num2-comments-head { margin-bottom: 12px; }
.num2-comments-head h2 { margin: 0; font-size: 22px; }

.num2-filter-tabs {
    display: flex; flex-wrap: wrap; gap: 16px; margin-bottom: 16px;
    padding-bottom: 8px; border-bottom: 1px solid #E2E8F0;
}
.num2-filter-tab {
    padding: 8px 0; text-decoration: none; color: #64748B;
    font-size: 14px; font-weight: 500; border-bottom: 2px solid transparent;
    margin-bottom: -9px;
}
.num2-filter-tab:hover { color: #0F172A; }
.num2-filter-tab-active { color: #0F172A; font-weight: 700; border-bottom-color: #0F172A; }

.num2-comment-list { display: flex; flex-direction: column; gap: 12px; }
.num2-comment {
    background: #fff; border: 1px solid #E2E8F0; border-radius: 12px;
    border-left: 4px solid; padding: 16px;
}
.num2-comment-useful { border-left-color: #10B981; }
.num2-comment-safe { border-left-color: #84CC16; }
.num2-comment-neutral { border-left-color: #3B82F6; }
.num2-comment-harassing { border-left-color: #F97316; }
.num2-comment-dangerous { border-left-color: #DC2626; }
.num2-comment-head { display: flex; justify-content: space-between; align-items: center; gap: 8px; flex-wrap: wrap; }
.num2-comment-meta { display: flex; gap: 12px; align-items: center; font-size: 12px; color: #64748B; }
.num2-vote {
    background: transparent; border: 1px solid #CBD5E1; padding: 4px 10px;
    border-radius: 999px; cursor: pointer; font-size: 12px; color: #475569;
}
.num2-vote:hover:not(:disabled) { background: #F1F5F9; border-color: #94A3B8; }
.num2-vote:disabled { opacity: 0.5; cursor: not-allowed; }
.num2-comment-text { font-size: 14px; line-height: 1.6; color: #1E293B; margin: 8px 0 6px; white-space: pre-line; }
.num2-comment-author { font-size: 12px; color: #64748B; margin: 0 0 8px; font-style: italic; }
.num2-comment-foot { display: flex; justify-content: flex-end; }
.num2-report {
    background: transparent; border: 0; cursor: pointer;
    font-size: 11px; color: #94A3B8;
}
.num2-report:hover:not(:disabled) { color: #DC2626; }
.num2-report:disabled { opacity: 0.5; cursor: not-allowed; }

/* Empty state */
.num2-empty-state {
    background: linear-gradient(135deg, #ECFDF5 0%, #F0FDF4 100%);
    border: 2px solid #6EE7B7; border-radius: 16px; padding: 32px;
}
.num2-empty-icon {
    width: 56px; height: 56px; border-radius: 50%;
    background: #D1FAE5; display: flex; align-items: center; justify-content: center;
    font-size: 28px; margin-bottom: 12px;
}
.num2-empty-state h3 { margin: 0 0 8px; color: #064E3B; font-size: 20px; }
.num2-empty-state p { color: #064E3B; line-height: 1.5; margin: 0 0 8px; }
.num2-empty-cta {
    background: rgba(255,255,255,0.7); border: 1px solid rgba(110,231,183,0.5);
    border-radius: 12px; padding: 16px; margin-top: 16px;
}
.num2-empty-cta p { font-size: 13px; }

/* Locked card */
.num2-locked-card {
    background: #F8FAFC; border: 2px solid #E2E8F0; border-radius: 16px;
    padding: 32px; text-align: center;
}
.num2-locked-icon {
    width: 56px; height: 56px; border-radius: 50%;
    background: #E2E8F0; display: flex; align-items: center; justify-content: center;
    font-size: 24px; margin: 0 auto 16px;
}
.num2-locked-card h2 { margin: 0 0 8px; }

/* === Sidebar cards === */
.aside-card {
    background: #fff; border: 1px solid #E2E8F0; border-radius: 12px;
    padding: 16px;
}
.aside-card h3 { margin: 0 0 8px; font-size: 14px; }
.aside-card p { font-size: 13px; line-height: 1.5; color: #334155; margin: 0 0 8px; }
.aside-eyebrow {
    font-size: 11px; text-transform: uppercase; letter-spacing: 0.8px;
    color: #64748B; font-weight: 700; margin: 0 0 12px;
}
.aside-tip { background: #FEF9C3; border-color: #FACC15; }
.aside-card-danger { background: #FEF2F2; border-color: #FCA5A5; }

.aside-link-list { padding: 0; list-style: none; display: flex; flex-direction: column; gap: 6px; }
.aside-link-list a {
    display: flex; justify-content: space-between; align-items: center;
    padding: 8px 12px; background: #F8FAFC; border: 1px solid #E2E8F0;
    border-radius: 8px; text-decoration: none; color: #1E293B;
    font-size: 13px; font-weight: 500;
}
.aside-link-list a:hover { background: #fff; border-color: #94A3B8; }

.aside-dl { margin: 0; padding: 0; display: flex; flex-direction: column; gap: 6px; }
.aside-dl > div {
    display: flex; justify-content: space-between; gap: 8px;
    font-size: 13px; padding: 4px 0; border-bottom: 1px solid #F1F5F9;
}
.aside-dl > div:last-child { border-bottom: 0; }
.aside-dl dt { color: #64748B; margin: 0; }
.aside-dl dd { color: #0F172A; margin: 0; font-weight: 600; text-align: right; }

/* Trend chart */
.trend-chart { display: flex; align-items: flex-end; gap: 3px; height: 48px; margin-bottom: 6px; }
.trend-col { flex: 1; display: flex; align-items: flex-end; }
.trend-bar { width: 100%; background: rgba(250,204,21,0.7); border-radius: 2px 2px 0 0; }
.trend-bar-today { background: #FACC15; }
.trend-summary { font-size: 12px; color: #64748B; margin: 4px 0 0; display: flex; justify-content: space-between; }

/* Phone formats */
.phone-formats {
    display: grid; grid-template-columns: 1fr 1fr; gap: 4px;
    padding: 0; list-style: none; margin: 8px 0 0;
}
.phone-formats li {
    font-family: 'Courier New', monospace; font-size: 11px;
    padding: 4px 8px; color: #475569; border-radius: 4px;
    cursor: default;
}
.phone-formats li:hover { background: #FEF3C7; color: #0F172A; }

/* Recent in prefix */
.recent-in-prefix { padding: 0; list-style: none; display: flex; flex-direction: column; gap: 12px; }
.recent-in-prefix > li {
    padding: 8px; border-radius: 8px; transition: background 0.15s;
}
.recent-in-prefix > li:hover { background: #FEF3C7; }
.recent-in-prefix a {
    display: flex; justify-content: space-between; align-items: center;
    text-decoration: none; color: #1E293B; gap: 8px;
}
.rip-num { font-family: 'Courier New', monospace; font-size: 12px; font-weight: 700; }
.rip-text { margin: 4px 0 0; font-size: 12px; color: #475569; line-height: 1.4; }

/* Web mention */
.web-mention {
    display: flex; flex-direction: column; gap: 4px;
    padding: 12px; background: #F8FAFC; border: 1px solid #E2E8F0;
    border-radius: 8px; text-decoration: none; color: inherit;
    margin-bottom: 8px;
}
.web-mention:hover { background: #fff; border-color: #94A3B8; }
.wm-domain { font-size: 11px; text-transform: uppercase; letter-spacing: 0.5px; color: #64748B; font-weight: 600; }
.wm-title { font-size: 13px; color: #0F172A; line-height: 1.4; }
.wm-snippet { font-size: 12px; color: #64748B; line-height: 1.45; }

/* Share buttons */
.num2-share-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 6px; }
.num2-share-btn {
    text-align: center; padding: 8px; background: #F8FAFC;
    border: 1px solid #E2E8F0; border-radius: 6px;
    text-decoration: none; color: #1E293B; font-size: 12px; font-weight: 600;
}
.num2-share-btn:hover { background: #fff; border-color: #94A3B8; }

/* FAQ accordion */
.num2-faq { display: flex; flex-direction: column; gap: 8px; max-width: 800px; }
.num2-faq-item {
    background: #fff; border: 1px solid #E2E8F0; border-radius: 12px;
    padding: 0; overflow: hidden;
}
.num2-faq-item summary {
    padding: 16px 20px; cursor: pointer; font-weight: 600; font-size: 15px;
    list-style: none; position: relative;
}
.num2-faq-item summary::-webkit-details-marker { display: none; }
.num2-faq-item summary::after {
    content: '+'; position: absolute; right: 20px; top: 50%;
    transform: translateY(-50%); font-size: 24px; font-weight: 400; color: #94A3B8;
}
.num2-faq-item[open] summary::after { content: '−'; }
.num2-faq-item[open] summary { border-bottom: 1px solid #E2E8F0; }
.num2-faq-answer { padding: 16px 20px; font-size: 14px; line-height: 1.65; color: #334155; }
.num2-faq-answer p { margin: 0 0 10px; }
.num2-faq-links { padding-left: 20px; margin-top: 8px; }

/* SEO copy */
.num2-seo-copy {
    max-width: 800px; padding: 16px; background: #F8FAFC;
    border-radius: 12px; margin-bottom: 24px;
}
.num2-seo-copy p { margin: 0; font-size: 14px; line-height: 1.65; color: #475569; }

/* === SEO copy block === */
.num2-seo-copy {
    max-width: 760px;
    background: #F8FAFC;
    border-left: 4px solid #FACC15;
    padding: 24px;
    border-radius: 0 12px 12px 0;
    margin: 0 0 32px;
}
.num2-seo-heading {
    font-size: 22px;
    font-weight: 700;
    color: #0F172A;
    margin: 0 0 12px;
    line-height: 1.3;
}
.num2-seo-copy p {
    margin: 0 0 14px;
    font-size: 15px;
    line-height: 1.7;
    color: #334155;
}
.num2-seo-copy p:last-child { margin-bottom: 0; }
.num2-seo-copy strong { color: #0F172A; font-weight: 700; }
.num2-seo-cta {
    padding: 12px 16px;
    background: #fff;
    border: 1px solid #E2E8F0;
    border-radius: 8px;
    margin-top: 16px;
}

/* ============================================================
 * Dark footer dle screenshotu — 3 sloupce VYHLEDÁVÁNÍ / VĚDOMOSTI / O WEBU
 * ============================================================ */
.site-footer-dark {
    background: #0F172A;
    color: #CBD5E1;
    padding: 56px 0 24px;
    margin-top: 48px;
}
.site-footer-dark a { color: #E2E8F0; text-decoration: none; }
.site-footer-dark a:hover { color: #FACC15; text-decoration: underline; }
.footer-cols-3 {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 56px;
    padding-bottom: 32px;
}
@media (max-width: 760px) {
    .footer-cols-3 { grid-template-columns: 1fr; gap: 32px; }
}
.footer-h {
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 1.5px;
    color: #94A3B8;
    display: block;
    margin-bottom: 18px;
    text-transform: uppercase;
}
.site-footer-dark ul { padding: 0; list-style: none; margin: 0; }
.site-footer-dark ul li { padding: 7px 0; font-size: 15px; }
.site-footer-dark .footer-hr { border: 0; border-top: 1px solid #1E293B; margin: 16px 0 12px; }
.site-footer-dark .footer-bottom { font-size: 12px; color: #64748B; }
.site-footer-dark .footer-paid { color: #94A3B8; border-top: 1px solid #1E293B; }

/* ============================================================
 * Detail — nové komponenty pro restored design
 * ============================================================ */

/* Company badge v hero */
.num-company-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 14px;
    background: rgba(255,255,255,0.85);
    border: 1px solid rgba(0,0,0,0.1);
    border-radius: 999px;
    text-decoration: none;
    color: #0F172A;
    font-size: 13px;
    font-weight: 600;
    margin-top: 12px;
    margin-bottom: 4px;
}
.num-company-badge:hover { background: #fff; }

/* Summary box pod CTA */
.num-summary-box {
    margin-top: 18px;
    padding: 14px 16px;
    background: rgba(255, 255, 255, 0.55);
    border-radius: 12px;
    border: 1px solid rgba(0,0,0,0.08);
}
.num-summary-eyebrow {
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.8px;
    color: #475569;
    font-weight: 700;
    margin: 0 0 6px;
}
.num-summary-text {
    font-size: 14px;
    line-height: 1.55;
    color: #1E293B;
    margin: 0;
}

/* Verdict block — locked variant */
.num-vb-locked { background: linear-gradient(135deg, #F1F5F9 0%, #E2E8F0 100%); color: #334155; }

/* Verdict panel summary */
.num-vp-summary {
    margin-top: 10px;
    padding-top: 10px;
    border-top: 1px solid #E2E8F0;
    text-align: center;
    font-size: 13px;
    color: #475569;
    font-variant-numeric: tabular-nums;
}

/* Warning banner pod hero */
.num-warning-banner {
    background: #FEE2E2;
    border-left: 4px solid #DC2626;
    padding: 12px 16px;
    border-radius: 0 8px 8px 0;
    color: #7F1D1D;
    font-size: 14px;
    margin-bottom: 24px;
}

/* Filter tabs */
.comment-filter-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
    margin: 8px 0 20px;
    padding-bottom: 4px;
    border-bottom: 1px solid #E2E8F0;
}
.cft-tab {
    padding: 8px 0;
    text-decoration: none;
    color: #64748B;
    font-size: 14px;
    font-weight: 500;
    border-bottom: 2px solid transparent;
    margin-bottom: -5px;
}
.cft-tab:hover { color: #0F172A; }
.cft-tab-active { color: #0F172A; font-weight: 700; border-bottom-color: #0F172A; }

/* Verdict radio hint */
.vradio-hint {
    display: block;
    font-size: 11px;
    opacity: 0.75;
    margin-top: 2px;
    font-weight: 400;
}

/* SEO copy block */
.num-seo-copy {
    background: #F8FAFC;
    border-left: 4px solid #FACC15;
    padding: 24px 28px;
    border-radius: 0 12px 12px 0;
    margin: 32px 0;
}
.num-seo-copy h2 {
    font-size: 22px;
    margin: 0 0 14px;
    line-height: 1.3;
}
.num-seo-copy p {
    margin: 0 0 14px;
    font-size: 15px;
    line-height: 1.7;
    color: #334155;
}
.num-seo-copy p:last-child { margin-bottom: 0; }
.num-seo-copy strong { color: #0F172A; font-weight: 700; }
.num-seo-cta {
    padding: 12px 16px;
    background: #fff;
    border: 1px solid #E2E8F0;
    border-radius: 8px;
    margin-top: 16px;
}

/* FAQ accordion */
.num-faq-section { margin: 32px 0; }
.num-faq-section h2 { margin-bottom: 16px; }
.num-faq-list { display: flex; flex-direction: column; gap: 8px; }
.num-faq-item {
    background: #fff;
    border: 1px solid #E2E8F0;
    border-radius: 12px;
    overflow: hidden;
}
.num-faq-item summary {
    padding: 16px 22px;
    cursor: pointer;
    font-weight: 600;
    font-size: 15px;
    list-style: none;
    position: relative;
}
.num-faq-item summary::-webkit-details-marker { display: none; }
.num-faq-item summary::after {
    content: '+';
    position: absolute;
    right: 22px;
    top: 50%;
    transform: translateY(-50%);
    font-size: 26px;
    font-weight: 300;
    color: #94A3B8;
}
.num-faq-item[open] summary::after { content: '−'; }
.num-faq-item[open] summary { border-bottom: 1px solid #E2E8F0; }
.num-faq-answer { padding: 16px 22px; font-size: 14px; line-height: 1.7; color: #334155; }
.num-faq-answer p { margin: 0 0 10px; }
.num-faq-links { padding-left: 20px; margin-top: 8px; font-size: 13px; }

/* Cross-articles */
.num-cross-articles { margin: 32px 0; }
.num-cross-articles h2 { margin-bottom: 14px; }
.num-cross-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
    gap: 12px;
}
.num-cross-card {
    background: #fff;
    border: 1px solid #E2E8F0;
    border-radius: 12px;
    padding: 18px;
    text-decoration: none;
    color: inherit;
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.num-cross-card:hover { border-color: #FACC15; box-shadow: 0 4px 12px rgba(0,0,0,0.06); }
.num-cross-card h3 { margin: 0; font-size: 15px; line-height: 1.35; }
.num-cross-card p { margin: 0; font-size: 13px; color: #64748B; line-height: 1.5; }

/* Top prefix grid */
.num-top-prefix { margin: 32px 0; }
.num-top-prefix h2 { margin-bottom: 14px; }
.num-tp-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 8px;
}
.num-tp-card {
    background: #fff;
    border: 1px solid #E2E8F0;
    border-radius: 10px;
    padding: 12px 14px;
    text-decoration: none;
    color: #1E293B;
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.num-tp-card:hover { border-color: #FACC15; }
.num-tp-card-danger { border-color: #FCA5A5; background: #FEF2F2; }
.num-tp-num { font-family: 'Courier New', monospace; font-size: 13px; font-weight: 700; }
.num-tp-cnt { font-size: 11px; color: #64748B; }

/* Share buttons */
.num-share-row { display: grid; grid-template-columns: repeat(3, 1fr); gap: 6px; margin-top: 8px; }
.num-share-btn {
    text-align: center;
    padding: 8px;
    background: #F8FAFC;
    border: 1px solid #E2E8F0;
    border-radius: 6px;
    text-decoration: none;
    color: #1E293B;
    font-size: 12px;
    font-weight: 600;
}
.num-share-btn:hover { background: #fff; border-color: #FACC15; }

/* Aside variants */
.aside-tip { background: #FEF9C3 !important; border-color: #FACC15 !important; }
.aside-block-danger { background: #FEF2F2; border-color: #FCA5A5; }

.aside-list-rich li { padding: 8px 0; border-bottom: 1px solid #F1F5F9; }
.aside-list-rich li:last-child { border-bottom: 0; }
.aside-rich-link {
    display: flex;
    justify-content: space-between;
    align-items: center;
    text-decoration: none;
    color: #1E293B;
    margin-bottom: 4px;
}
.rip-num { font-family: 'Courier New', monospace; font-size: 13px; font-weight: 700; }
.rip-text { margin: 0; font-size: 12px; color: #64748B; line-height: 1.4; }

/* Phone formats list (sidebar) */
.phone-formats {
    padding: 0;
    margin: 8px 0 0;
    list-style: none;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 4px;
}
.phone-formats li {
    font-family: 'Courier New', monospace;
    font-size: 11px;
    padding: 4px 8px;
    color: #475569;
    border-radius: 4px;
    cursor: default;
}
.phone-formats li:hover { background: #FEF3C7; color: #0F172A; }

/* Info source line */
.info-source {
    margin-top: 12px;
    padding-top: 8px;
    border-top: 1px solid #F1F5F9;
    font-size: 11px;
    color: #94A3B8;
    line-height: 1.4;
}
.info-source a { color: #475569; text-decoration: underline; }

/* Trend chart */
.trend-chart {
    display: flex;
    align-items: flex-end;
    gap: 3px;
    height: 48px;
    margin: 8px 0;
}
.trend-col { flex: 1; display: flex; align-items: flex-end; }
.trend-bar { width: 100%; background: rgba(250, 204, 21, 0.7); border-radius: 2px 2px 0 0; }
.trend-bar-today { background: #FACC15; }
.trend-summary {
    font-size: 12px;
    color: #64748B;
    margin: 0;
    display: flex;
    justify-content: space-between;
}

/* Web mention */
.web-mention-link {
    display: flex;
    flex-direction: column;
    gap: 4px;
    padding: 12px;
    background: #F8FAFC;
    border: 1px solid #E2E8F0;
    border-radius: 8px;
    text-decoration: none;
    color: inherit;
    margin-bottom: 8px;
}
.web-mention-link:hover { background: #fff; border-color: #FACC15; }
.wm-domain { font-size: 11px; text-transform: uppercase; letter-spacing: 0.5px; color: #64748B; font-weight: 600; }
.wm-title { font-size: 13px; color: #0F172A; line-height: 1.4; }
.wm-snippet { font-size: 12px; color: #64748B; line-height: 1.45; }

/* ============================================================
 * Předvolba detail — nové styly
 * ============================================================ */
.prefix-hero-meta {
    font-size: 16px;
    color: #1E293B;
    margin: 12px 0;
}
.prefix-op-link { font-weight: 700; text-decoration: underline; color: #0F172A; }
.prefix-warning {
    display: inline-block;
    padding: 6px 14px;
    background: #FEE2E2;
    color: #991B1B;
    border-radius: 8px;
    font-size: 14px;
    margin: 8px 0;
}
.prefix-stats {
    margin-top: 16px;
    font-size: 14px;
    color: #1E293B;
}
.prefix-stats strong { font-variant-numeric: tabular-nums; }
.prefix-tip {
    margin-top: 16px;
    padding: 14px 18px;
    background: #FEF9C3;
    border: 1px solid #FACC15;
    border-radius: 12px;
    font-size: 14px;
    line-height: 1.55;
    color: #422006;
}
.prefix-tip strong { color: #713F12; }

.prefix-list {
    padding: 0;
    margin: 0;
    list-style: none;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 10px;
}
.prefix-list-card {
    display: flex;
    flex-direction: column;
    gap: 8px;
    padding: 14px 16px;
    background: #fff;
    border: 1px solid #E2E8F0;
    border-radius: 10px;
    text-decoration: none;
    color: #1E293B;
    transition: all 0.15s;
}
.prefix-list-card:hover {
    border-color: #FACC15;
    box-shadow: 0 4px 12px rgba(0,0,0,0.06);
}
.prefix-list-num { font-family: 'Courier New', monospace; font-size: 15px; font-weight: 700; }
.prefix-list-meta { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.prefix-list-cnt { font-size: 12px; color: #64748B; }

.empty-card-light {
    background: #F8FAFC;
    border: 1px dashed #CBD5E1;
    border-radius: 12px;
    padding: 32px;
    text-align: center;
}

/* === Homepage hub subheads === */
.hub-subhead {
    margin-top: 40px;
    margin-bottom: 12px;
    font-size: 18px;
    color: #475569;
    font-weight: 700;
}
.hub-subhead:first-of-type { margin-top: 24px; }
.hub-card-danger {
    border-color: #FCA5A5 !important;
    background: linear-gradient(135deg, #FFF7F7 0%, #FFFFFF 100%);
}
.hub-card-danger:hover { border-color: #DC2626 !important; }

/* === International predvolby grid === */
.intl-group-h {
    margin-top: 40px;
    margin-bottom: 16px;
    font-size: 22px;
    border-bottom: 2px solid #E2E8F0;
    padding-bottom: 8px;
}
.intl-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 10px;
    margin-bottom: 24px;
}
.intl-card {
    display: flex;
    gap: 10px;
    align-items: center;
    padding: 12px 14px;
    background: #fff;
    border: 1px solid #E2E8F0;
    border-radius: 10px;
    text-decoration: none;
    color: #1E293B;
    transition: all 0.15s;
}
.intl-card:hover { border-color: #FACC15; background: #FFFCEB; }
.intl-card-risk {
    border-color: #FCA5A5;
    background: linear-gradient(135deg, #FEF2F2 0%, #FFFFFF 100%);
}
.intl-card-risk:hover { border-color: #DC2626; }
.intl-flag {
    font-size: 28px;
    flex-shrink: 0;
}
.intl-info { flex: 1; min-width: 0; }
.intl-code {
    font-family: 'Courier New', monospace;
    font-weight: 700;
    font-size: 14px;
    color: #0F172A;
}
.intl-name {
    font-size: 13px;
    color: #475569;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.intl-warning {
    font-size: 11px;
    color: #DC2626;
    margin-top: 2px;
    font-weight: 600;
}

/* nový list-style layout (jako original Next.js) */
.intl-list {
    list-style: none;
    padding: 0;
    margin: 16px 0 0;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 8px;
}
.intl-list-item a {
    display: flex;
    gap: 12px;
    align-items: flex-start;
    padding: 10px 12px;
    background: #fff;
    border: 1px solid #E2E8F0;
    border-radius: 8px;
    text-decoration: none;
    color: #0F172A;
    transition: background 0.12s, border-color 0.12s;
}
.intl-list-item a:hover { background: #FEFCE8; border-color: #FACC15; }
.intl-list-item-danger a {
    background: rgba(254, 226, 226, 0.4);
    border-color: #FECACA;
}
.intl-list-item-danger a:hover { background: #FEE2E2; border-color: #DC2626; }
.intl-list-item .intl-flag { font-size: 22px; line-height: 1.3; flex-shrink: 0; }
.intl-flag-svg {
    width: 28px;
    height: 21px;
    border-radius: 3px;
    box-shadow: 0 0 0 1px rgba(15, 23, 42, 0.08);
    flex-shrink: 0;
    object-fit: cover;
    margin-top: 2px;
}
.badge-flag {
    width: 18px; height: 14px;
    border-radius: 2px;
    box-shadow: 0 0 0 1px rgba(15,23,42,0.1);
    object-fit: cover;
    display: inline-block;
    vertical-align: -2px;
}
.inline-flag-svg {
    width: 28px; height: 21px;
    border-radius: 3px;
    box-shadow: 0 0 0 1px rgba(15,23,42,0.1);
    object-fit: cover;
    display: inline-block;
    vertical-align: -6px;
    margin-left: 4px;
}
.intl-list-item .intl-row {
    display: flex; align-items: baseline; gap: 8px;
}
.intl-list-item .intl-name { white-space: normal; }
.intl-note {
    margin: 4px 0 0;
    font-size: 12px;
    color: #475569;
    line-height: 1.4;
}

.intl-group-h-warning {
    color: #991B1B;
    border-bottom-color: #FECACA;
}
.intl-group-lead {
    color: #475569;
    margin: 8px 0 0;
    max-width: 720px;
}
.intl-warning-card {
    display: flex;
    gap: 14px;
    align-items: flex-start;
    padding: 16px 18px;
    background: rgba(254, 226, 226, 0.5);
    border: 1px solid #FECACA;
    border-radius: 12px;
    color: #7F1D1D;
    line-height: 1.55;
}
.intl-warning-icon { font-size: 24px; line-height: 1; flex-shrink: 0; color: #DC2626; }
.intl-warning-body { font-size: 14px; }

.intl-cta {
    display: flex; gap: 16px; align-items: flex-start;
    background: #FDE047;
    padding: 24px 28px;
    border-radius: 16px;
}
.intl-cta-icon { font-size: 32px; line-height: 1; flex-shrink: 0; }
.intl-cta-h { margin: 0 0 6px; font-size: 22px; font-weight: 700; color: #0F172A; }
.intl-cta p { margin: 0 0 12px; color: #1E293B; }
.btn-dark {
    display: inline-flex; align-items: center; justify-content: center;
    height: 44px; padding: 0 20px;
    background: #0F172A; color: #fff;
    border-radius: 8px; font-weight: 600; font-size: 14px;
    text-decoration: none;
    transition: background 0.15s;
}
.btn-dark:hover { background: #1E293B; color: #fff; }

/* === Scam hero tags === */
.scam-hero-tags {
    margin-top: 14px;
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}
.scam-tag-dark {
    padding: 3px 10px;
    background: rgba(255,255,255,0.1);
    border: 1px solid rgba(255,255,255,0.2);
    border-radius: 999px;
    font-size: 11px;
    color: #CBD5E1;
}

/* === Scam stats row === */
.scam-stats-row {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 12px;
    margin: 24px 0;
}
.scam-stat {
    background: #FEF2F2;
    border: 1px solid #FCA5A5;
    border-radius: 12px;
    padding: 16px;
    text-align: center;
}
.scam-stat-value {
    font-size: 26px;
    font-weight: 800;
    color: #991B1B;
    line-height: 1.2;
}
.scam-stat-label {
    font-size: 12px;
    color: #7F1D1D;
    margin-top: 4px;
}
.scam-stat-src {
    font-size: 10px;
    color: #94A3B8;
    margin-top: 6px;
    font-style: italic;
}

/* === Scam case card === */
.scam-case-card {
    background: #FFF7ED;
    border-left: 4px solid #F59E0B;
    padding: 16px 18px;
    margin: 12px 0;
    border-radius: 0 8px 8px 0;
}
.scam-case-card h3 { margin: 0 0 6px; font-size: 16px; color: #92400E; }
.scam-case-date { font-size: 12px; color: #B45309; margin: 0 0 6px; font-weight: 600; }
.scam-case-card p { margin: 0; font-size: 14px; color: #475569; line-height: 1.6; }
.scam-case-src { font-size: 11px; color: #94A3B8; margin-top: 8px !important; font-style: italic; }

/* ============================================================
 * Firma detail — port z originálu cislo.info-nove
 * ============================================================ */
.firma-page { padding: 32px 0 56px; }

.firma-breadcrumb {
    display: flex; flex-wrap: wrap; align-items: center; gap: 6px;
    font-size: 13px; color: #475569; margin-bottom: 24px;
}
.firma-breadcrumb a { color: #64748B; text-decoration: none; }
.firma-breadcrumb a:hover { color: #0F172A; text-decoration: underline; }
.bc-sep { color: #CBD5E1; }
.bc-current { font-weight: 600; color: #0F172A; }

.firma-hero {
    background: #FDE047;
    border-radius: 18px;
    padding: 32px;
    box-shadow: 0 4px 14px rgba(15,23,42,0.06);
}
@media (max-width: 720px) { .firma-hero { padding: 22px; } }
.firma-hero-row {
    display: flex; gap: 18px; align-items: flex-start;
}
@media (max-width: 540px) { .firma-hero-row { flex-direction: column; gap: 14px; } }
.firma-icon {
    width: 56px; height: 56px;
    background: #fff;
    border-radius: 14px;
    display: flex; align-items: center; justify-content: center;
    color: #475569;
    box-shadow: 0 2px 6px rgba(0,0,0,0.06);
    flex-shrink: 0;
}
.firma-hero-body { flex: 1; min-width: 0; }
.firma-cat-badge {
    display: inline-block;
    padding: 3px 12px;
    background: #fff;
    color: #0F172A;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 600;
    margin-bottom: 6px;
}
.firma-h1 {
    font-size: 36px;
    font-weight: 800;
    color: #0F172A;
    margin: 6px 0;
    line-height: 1.1;
}
@media (max-width: 540px) { .firma-h1 { font-size: 26px; } }
.firma-lead {
    font-size: 16px;
    color: #1E293B;
    margin: 8px 0 16px;
    line-height: 1.5;
    max-width: 600px;
}
.firma-meta-row {
    display: flex; flex-wrap: wrap; gap: 18px;
    align-items: center;
    font-size: 14px;
    color: #1E293B;
}
.firma-meta-item { display: inline-flex; align-items: center; gap: 4px; }
.firma-meta-link {
    display: inline-flex; align-items: center; gap: 4px;
    color: #0F172A; font-weight: 600; text-decoration: none;
}
.firma-meta-link:hover { text-decoration: underline; }
.firma-ico-link {
    display: inline-flex; align-items: center; gap: 4px;
    color: #475569; font-family: 'Courier New', monospace; font-size: 12px;
    text-decoration: none;
}
.firma-ico-link:hover { color: #0F172A; text-decoration: underline; }

/* Kontakty grid */
.firma-contacts {
    display: grid; grid-template-columns: 1fr 1fr; gap: 12px;
    margin-top: 24px;
}
@media (max-width: 720px) { .firma-contacts { grid-template-columns: 1fr; } }
.firma-contact-card {
    display: flex; gap: 12px; align-items: flex-start;
    background: #fff;
    border: 1px solid #E2E8F0;
    border-radius: 12px;
    padding: 16px 18px;
}
.contact-icon { font-size: 18px; color: #475569; flex-shrink: 0; }
.contact-label {
    font-size: 11px; text-transform: uppercase; letter-spacing: 0.8px;
    color: #94A3B8; font-weight: 700;
}
.contact-value { font-size: 14px; color: #1E293B; margin-top: 2px; line-height: 1.4; word-break: break-word; }
.contact-link { color: #0F172A; text-decoration: none; }
.contact-link:hover { text-decoration: underline; }
.contact-sub { font-size: 12px; color: #64748B; margin-top: 2px; }

.firma-long-desc {
    margin-top: 32px;
    padding: 22px;
    background: #fff;
    border: 1px solid #E2E8F0;
    border-radius: 14px;
}
.firma-section-eyebrow {
    font-size: 11px; text-transform: uppercase; letter-spacing: 0.8px;
    color: #94A3B8; font-weight: 700; margin: 0 0 10px;
}
.firma-long-desc p { font-size: 14px; line-height: 1.65; color: #334155; margin: 0; white-space: pre-line; }

.firma-numbers { margin-top: 36px; }
.firma-section-h {
    font-size: 24px; font-weight: 700;
    color: #0F172A;
    margin: 0 0 18px;
}

.firma-empty {
    border: 1px dashed #CBD5E1;
    background: #F8FAFC;
    border-radius: 14px;
    padding: 32px;
    text-align: center;
    color: #475569;
    font-size: 14px;
}

.firma-numbers-grid {
    display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 10px; padding: 0; list-style: none; margin: 0;
}
.firma-number-card {
    display: flex; flex-direction: column; gap: 8px;
    padding: 14px 16px;
    background: #fff;
    border: 1px solid #E2E8F0;
    border-radius: 10px;
    text-decoration: none;
    color: #1E293B;
    transition: all 0.15s;
}
.firma-number-card:hover { border-color: #FACC15; box-shadow: 0 4px 12px rgba(0,0,0,0.06); }
.firma-number-num { font-family: 'Courier New', monospace; font-size: 15px; font-weight: 700; color: #0F172A; }
.firma-number-meta { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; font-size: 12px; }
.firma-number-cnt { color: #64748B; }

.firma-recommend { margin-top: 56px; }
.firma-recommend-h {
    font-size: 11px; text-transform: uppercase; letter-spacing: 1px;
    color: #94A3B8; font-weight: 700; margin: 0 0 14px;
}
.firma-recommend-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 10px; }
.firma-recommend-card {
    display: flex; flex-direction: column; gap: 4px;
    padding: 16px 18px;
    background: #fff;
    border: 1px solid #E2E8F0;
    border-radius: 10px;
    text-decoration: none;
    color: #1E293B;
    transition: all 0.15s;
}
.firma-recommend-card:hover { border-color: #0F172A; }
.firma-recommend-card strong { color: #0F172A; font-weight: 700; }
.firma-recommend-card span { color: #64748B; font-size: 13px; }


/* ============================================================
 * News box (aside) — port z cislo.info-nove originálu
 * ============================================================ */
.news-box {
    background: #fff;
    border-radius: 16px;
    padding: 18px 18px 14px;
    box-shadow: 0 2px 8px rgba(15,23,42,0.06);
    align-self: flex-start;
}
.news-box-h {
    display: flex; align-items: center; gap: 6px;
    font-size: 11px; font-weight: 700;
    text-transform: uppercase; letter-spacing: 1px;
    color: #475569;
    margin: 0 0 14px;
}
.news-box-h svg { color: #94A3B8; }

.news-item {
    display: flex; flex-direction: column; gap: 6px;
    text-decoration: none;
    color: inherit;
    padding: 10px 0;
    border-bottom: 1px solid #F1F5F9;
}
.news-item:last-of-type { border-bottom: 0; }
.news-item:hover .news-item-title { color: #0F172A; text-decoration: underline; }
.news-item-title {
    font-weight: 700; font-size: 14px; line-height: 1.3;
    color: #1E293B;
}

.cat-pill {
    align-self: flex-start;
    display: inline-block;
    padding: 2px 10px;
    border-radius: 999px;
    font-size: 11px; font-weight: 600;
    border: 1px solid;
}
.cat-pill-scam { background: #FEE2E2; color: #991B1B; border-color: #FCA5A5; }
.cat-pill-tips { background: #FEF3C7; color: #92400E; border-color: #FCD34D; }
.cat-pill-tech { background: #DBEAFE; color: #1E40AF; border-color: #93C5FD; }
.cat-pill-lifestyle { background: #DCFCE7; color: #166534; border-color: #86EFAC; }
.cat-pill-other { background: #F1F5F9; color: #475569; border-color: #CBD5E1; }

.news-box-more {
    display: inline-block;
    margin-top: 10px;
    font-size: 13px; font-weight: 600;
    color: #0F172A;
    text-decoration: none;
}
.news-box-more:hover { text-decoration: underline; }

/* ============================================================
 * Footer redesign — port z cislo.info-nove originálu
 * ============================================================ */
.site-footer-dark { background: #0F172A; color: #CBD5E1; padding: 56px 0 24px; margin-top: 48px; }
.site-footer-dark a { color: #E2E8F0; text-decoration: none; }
.site-footer-dark a:hover { color: #FACC15; text-decoration: underline; }

.footer-grid {
    display: grid;
    grid-template-columns: 2fr 1fr 1fr 1fr;
    gap: 48px;
    padding-bottom: 32px;
}
@media (max-width: 900px) {
    .footer-grid { grid-template-columns: 1fr 1fr; gap: 32px; }
}
@media (max-width: 540px) {
    .footer-grid { grid-template-columns: 1fr; }
}

.footer-brand { display: flex; flex-direction: column; gap: 12px; }
.footer-logo {
    display: inline-flex; align-items: center; gap: 10px;
    text-decoration: none !important;
    font-weight: 700; font-size: 22px;
}
.footer-logo:hover { text-decoration: none !important; }
.footer-logo-icon {
    width: 32px; height: 32px;
    background: #FDE047;
    border-radius: 8px;
    display: flex; align-items: center; justify-content: center;
}
.footer-logo-text { display: inline-flex; gap: 1px; }
.fl-cislo { color: #FDE047; }
.fl-info { color: #E2E8F0; }
.footer-tagline {
    font-size: 14px;
    color: #94A3B8;
    line-height: 1.55;
    margin: 4px 0 0;
    max-width: 320px;
}

.footer-col { display: flex; flex-direction: column; }
.footer-h {
    font-size: 12px; font-weight: 700; letter-spacing: 1.2px;
    color: #94A3B8;
    display: block; margin-bottom: 14px;
    text-transform: uppercase;
}
.site-footer-dark ul { padding: 0; margin: 0; list-style: none; }
.site-footer-dark ul li { padding: 5px 0; font-size: 14px; }

.site-footer-dark .footer-hr {
    border: 0; border-top: 1px solid #1E293B;
    margin: 16px 0 12px;
}
.site-footer-dark .footer-bottom {
    display: flex; justify-content: space-between; align-items: center;
    font-size: 12px; color: #64748B;
    padding-top: 8px;
}
.footer-copyright { color: #94A3B8; }
.footer-admin-link { color: #94A3B8 !important; font-size: 13px; }
.footer-admin-link:hover { color: #FACC15 !important; }
.site-footer-dark .footer-paid {
    padding: 12px 0; font-size: 13px; color: #94A3B8;
    border-top: 1px solid #1E293B;
}
