/**
 * Ragnar Academy — term.css
 * Superset styles for all cs/slovnik-bjj/*/index.html pages (16 terms).
 * Extrahováno z inline <style> Phase 2 Balík B2 (2026-04-21).
 *
 * Token fallback (:root + scrollbar reset) zůstává inline v každé stránce jako
 * stability layer — tento soubor poskytuje veškeré layout + component CSS.
 */

/* ── Reset ─────────────────────────────────────────────────────────────────── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}

/* ── Design tokens ──────────────────────────────────────────────────────────── */
:root{
  --bg:var(--ra-bg,#0a0a0f);
  --bg-card:var(--ra-surface-100,#111118);
  --bg-card2:var(--ra-surface-200,#16161f);
  --text:var(--ra-text,#ececf2);
  --muted:var(--ra-muted,#9292a3);
  --accent:var(--ra-gold,#c9a84c);
  --accent-dim:var(--ra-gold-dim,rgba(201,168,76,.12));
  --border:var(--ra-border,rgba(255,255,255,.06));
  --r:var(--ra-radius-md,12px);
  /* page-specific tokens (used by badge-cat, danger-box) */
  --cat-position:#3a7bd5;
  --danger:#d53a3a;
  --danger-dim:rgba(213,58,58,0.08);
}

/* ── Base ───────────────────────────────────────────────────────────────────── */
html{scroll-behavior:smooth;}
body{font-family:'Inter',-apple-system,sans-serif;background:var(--bg);color:var(--text);line-height:1.6;overflow-x:hidden;}
a{color:inherit;text-decoration:none;}
::-webkit-scrollbar{width:5px;}::-webkit-scrollbar-thumb{background:#2a2a2a;border-radius:3px;}

/* ── Nav ────────────────────────────────────────────────────────────────────── */
nav{position:sticky;top:0;z-index:100;padding:14px 48px;display:flex;justify-content:space-between;align-items:center;background:rgba(10,10,15,0.92);backdrop-filter:blur(24px);border-bottom:1px solid var(--border);}
.nav-logo{font-size:14px;font-weight:800;letter-spacing:3px;text-transform:uppercase;color:var(--text);}
.nav-logo span{color:var(--accent);}
.nav-back{font-size:12px;color:var(--muted);display:flex;align-items:center;gap:6px;transition:color .3s;}
.nav-back:hover{color:var(--accent);}

/* ── Layout ─────────────────────────────────────────────────────────────────── */
.wrap{max-width:800px;margin:0 auto;padding:48px 48px 80px;}

/* ── Breadcrumb ─────────────────────────────────────────────────────────────── */
.breadcrumb{font-size:11px;color:var(--muted);letter-spacing:1px;margin-bottom:24px;text-transform:uppercase;}
.breadcrumb a{color:var(--muted);transition:color .3s;}
.breadcrumb a:hover{color:var(--accent);}
.breadcrumb span{margin:0 8px;opacity:.4;}

/* ── Term header ────────────────────────────────────────────────────────────── */
.term-header{margin-bottom:32px;}
.term-name{font-size:clamp(36px,6vw,64px);font-weight:900;letter-spacing:-2px;line-height:1;margin-bottom:12px;}
.term-subtitle{font-size:16px;color:var(--muted);margin-bottom:20px;}
.term-also{font-size:16px;color:var(--accent);margin-bottom:10px;font-weight:600;}
.term-jp{font-size:14px;color:var(--muted);margin-bottom:10px;}
.hero-label{font-size:11px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--accent);margin-bottom:10px;}

/* ── Badges ─────────────────────────────────────────────────────────────────── */
.badges{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px;}
.badge{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:700;letter-spacing:.5px;padding:5px 12px;border-radius:6px;}
.badge-leglock{background:rgba(201,168,76,.15);color:var(--accent);}
.badge-legal{background:rgba(58,173,123,.15);color:#3aad7b;}
.badge-restricted{background:rgba(213,137,58,.15);color:#d5893a;}
.badge-illegal{background:rgba(213,58,58,.15);color:#d53a3a;}
.badge-rules{background:rgba(213,58,138,.15);color:#d53a8a;}
.badge-cat{background:rgba(58,123,213,.15);color:var(--cat-position);}

/* ── Pronunciation box ──────────────────────────────────────────────────────── */
.pron-box{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:16px 20px;margin-bottom:32px;display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px;}
.pron-item label{font-size:10px;letter-spacing:1px;text-transform:uppercase;color:var(--muted);display:block;margin-bottom:4px;}
.pron-item span{font-size:15px;font-weight:600;}
.pron-item .phonetic{font-style:italic;color:var(--accent);}

/* ── Definition block ───────────────────────────────────────────────────────── */
.def-block{margin-bottom:32px;}
.def-block h2{font-size:13px;letter-spacing:2px;text-transform:uppercase;color:var(--accent);margin-bottom:12px;font-weight:700;}
.def-block p{font-size:15px;color:var(--muted);line-height:1.8;margin-bottom:12px;}
.def-block p:last-child{margin-bottom:0;}
.def-block strong{color:var(--text);}

/* ── Callout / Warning / Danger ─────────────────────────────────────────────── */
.callout{background:var(--accent-dim);border:1px solid rgba(201,168,76,.2);border-radius:10px;padding:16px 20px;font-size:13px;color:var(--text);line-height:1.7;margin:16px 0;}
.callout strong{color:var(--accent);}
.warning{background:rgba(213,58,58,.08);border:1px solid rgba(213,58,58,.2);border-radius:10px;padding:16px 20px;font-size:13px;color:var(--text);line-height:1.7;margin:16px 0;}
.warning strong{color:#d53a3a;}
.danger-box{background:var(--danger-dim);border:1px solid rgba(213,58,58,.2);border-radius:10px;padding:16px 20px;font-size:13px;color:var(--text);line-height:1.7;margin:16px 0;}
.danger-box strong{color:var(--danger);}
.stalling-note{background:rgba(201,168,76,.06);border:1px solid rgba(201,168,76,.2);border-radius:8px;padding:14px 18px;margin-top:12px;font-size:13px;color:var(--text);}
.stalling-note strong{color:var(--accent);}

/* ── Fact box ───────────────────────────────────────────────────────────────── */
.fact-box{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r);padding:20px 24px;margin-bottom:16px;}
.fact-row{display:flex;gap:12px;margin-bottom:8px;font-size:13px;}
.fact-label{color:var(--muted);min-width:140px;flex-shrink:0;}
.fact-value{color:var(--text);}

/* ── Types grid ─────────────────────────────────────────────────────────────── */
.types-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;margin:16px 0;}
.type-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r);padding:16px 18px;}
.type-card h3{font-size:14px;font-weight:700;margin-bottom:6px;}
.type-card p{font-size:12px;color:var(--muted);line-height:1.6;}
.type-card .tc-level{font-size:10px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:var(--accent);margin-bottom:8px;display:block;}

/* ── Alias grid ─────────────────────────────────────────────────────────────── */
.alias-grid{display:flex;flex-wrap:wrap;gap:8px;margin:16px 0;}
.alias-pill{background:var(--bg-card);border:1px solid rgba(201,168,76,.25);border-radius:20px;padding:6px 14px;font-size:13px;font-weight:600;color:var(--accent);}

/* ── Taxonomy tags ──────────────────────────────────────────────────────────── */
.tax-grid{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px;}
.tax-tag{padding:5px 12px;border-radius:20px;font-size:12px;font-weight:600;cursor:default;}
.tax-tag-synonym{background:rgba(201,168,76,.12);border:1px solid rgba(201,168,76,.25);color:var(--accent);}
.tax-tag-related{background:rgba(255,255,255,.04);border:1px solid var(--border);color:var(--muted);}
.tax-tag-narrower{background:rgba(58,123,213,.12);border:1px solid rgba(58,123,213,.25);color:#6fa3e8;}

/* ── IBJJF table ────────────────────────────────────────────────────────────── */
.ibjjf-table{width:100%;border-collapse:collapse;margin:16px 0;font-size:13px;}
.ibjjf-table th{text-align:left;padding:8px 12px;border-bottom:1px solid var(--border);color:var(--muted);font-size:11px;letter-spacing:.5px;text-transform:uppercase;}
.ibjjf-table td{padding:10px 12px;border-bottom:1px solid rgba(255,255,255,.03);color:var(--muted);}
.ibjjf-table tr:hover td{background:var(--bg-card2);}
.ibjjf-table td:first-child{color:var(--text);font-weight:500;}
.tag-legal{color:#3aad7b;font-weight:600;}
.tag-illegal{color:#d53a3a;font-weight:600;}
.tag-restricted{color:#d5893a;font-weight:600;}
.tag-neutral{color:#6fa3e8;font-weight:600;}

/* ── Criteria list ──────────────────────────────────────────────────────────── */
.criteria-list{list-style:none;padding:0;margin:16px 0;}
.criteria-list li{display:flex;gap:12px;padding:10px 0;border-bottom:1px solid rgba(255,255,255,.04);font-size:14px;color:var(--muted);}
.criteria-list li:last-child{border-bottom:none;}
.criteria-list li strong{color:var(--text);min-width:24px;}

/* ── Diagram ────────────────────────────────────────────────────────────────── */
.diagram{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r);padding:24px;margin:16px 0;font-size:12px;color:var(--muted);}
.diagram h3{font-size:13px;font-weight:700;color:var(--text);margin-bottom:12px;}
.diagram-flow{display:flex;flex-wrap:wrap;gap:0;align-items:center;}
.diagram-step{background:var(--bg-card2);border:1px solid var(--border);border-radius:8px;padding:8px 14px;font-size:12px;font-weight:600;color:var(--text);}
.diagram-arrow{padding:0 8px;color:var(--accent);font-size:16px;}

/* ── Related terms ──────────────────────────────────────────────────────────── */
.related-terms{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px;}
.rel-tag{background:var(--bg-card);border:1px solid var(--border);border-radius:6px;padding:6px 14px;font-size:12px;font-weight:600;transition:all .2s;}
.rel-tag:hover{border-color:var(--accent);color:var(--accent);}

/* ── CTA box ────────────────────────────────────────────────────────────────── */
.cta-box{margin-top:48px;background:linear-gradient(135deg,rgba(201,168,76,.08),rgba(201,168,76,.03));border:1px solid rgba(201,168,76,.2);border-radius:16px;padding:32px 36px;display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;}
.cta-box h3{font-size:18px;font-weight:800;margin-bottom:6px;}
.cta-box p{font-size:13px;color:var(--muted);}
.cta-btn{display:inline-flex;align-items:center;gap:8px;background:var(--accent);color:#0a0a0f;font-weight:800;font-size:13px;letter-spacing:.5px;padding:12px 24px;border-radius:8px;text-transform:uppercase;transition:all .2s;white-space:nowrap;}
.cta-btn:hover{background:#e0bc5a;transform:translateY(-1px);}

/* ── Sources block ──────────────────────────────────────────────────────────── */
.sources-block{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r);padding:20px 24px;margin:32px 0;}
.sources-block h2{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--muted);margin-bottom:14px;font-weight:700;}
.source-list{list-style:none;padding:0;margin:0;}
.source-list li{padding:8px 0;border-bottom:1px solid rgba(255,255,255,.03);font-size:13px;color:var(--muted);display:flex;align-items:flex-start;gap:8px;line-height:1.6;}
.source-list li:last-child{border-bottom:none;}
.source-list li::before{content:"📄";font-size:11px;flex-shrink:0;margin-top:1px;}
.source-list a{color:var(--accent);}
.source-list a:hover{text-decoration:underline;}
.source-vf{display:inline-flex;font-size:10px;color:var(--muted);background:rgba(255,255,255,.04);padding:1px 6px;border-radius:4px;margin-left:4px;border:1px solid var(--border);}

/* ── FAQ ────────────────────────────────────────────────────────────────────── */
.faq-list{margin:12px 0;}
.faq-item{border:1px solid var(--border);border-radius:var(--r);overflow:hidden;margin-bottom:8px;}
.faq-item summary{padding:13px 16px;font-size:14px;font-weight:600;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;transition:background .2s;}
.faq-item summary:hover{background:var(--bg-card2);}
.faq-item summary::after{content:"＋";color:var(--accent);font-size:15px;}
.faq-item[open] summary::after{content:"－";}
.faq-answer{padding:13px 16px 15px;font-size:13px;color:var(--muted);line-height:1.7;border-top:1px solid var(--border);background:var(--bg-card);}
.faq-answer a{color:var(--accent);}

/* ── Ragnar box ─────────────────────────────────────────────────────────────── */
.ragnar-box{background:linear-gradient(135deg,rgba(201,168,76,.08),rgba(201,168,76,.03));border:1px solid rgba(201,168,76,.2);border-radius:var(--r);padding:24px;margin-bottom:16px;position:relative;}
.ragnar-box::before{content:'⚔';position:absolute;top:20px;right:20px;font-size:20px;opacity:.3;}
.ragnar-box h4{font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--accent);margin-bottom:10px;}
.ragnar-box p{font-size:14px;color:var(--text);line-height:1.7;font-style:italic;}

/* ── Footer ─────────────────────────────────────────────────────────────────── */
footer{padding:24px 48px;border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;}
.footer-logo{font-size:12px;font-weight:800;letter-spacing:3px;text-transform:uppercase;}
.footer-logo span{color:var(--accent);}
.footer-links{display:flex;gap:20px;font-size:12px;color:var(--muted);}
.footer-links a:hover{color:var(--accent);}

/* ── Responsive ─────────────────────────────────────────────────────────────── */
@media(max-width:768px){
  nav,.wrap,footer{padding-left:20px;padding-right:20px;}
  .cta-box{padding:24px;}
  .term-name{font-size:42px;}
  .diagram-flow{flex-direction:column;align-items:flex-start;}
  .diagram-arrow{transform:rotate(90deg);}
}


/* ── Video embed — Instagram reels ── */
.ragnar-video-block {
  margin: 2.5rem 0;
  padding: 1.5rem;
  background: #111118;
  border-left: 3px solid #c9a84c;
  border-radius: 6px;
}
.ragnar-video-block .video-label {
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: #c9a84c;
  margin-bottom: 0.75rem;
  display: block;
}
.ragnar-video-block .instagram-media {
  margin: 0 auto !important;
  min-width: unset !important;
}