/* components.css — widgets and cards */

/* Card */
.card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  box-shadow: var(--sh-sm);
  overflow: hidden;
}
.card-pad { padding: var(--sp-6); }
.card-title {
  font-size: var(--fs-md); font-weight: 600;
  display: flex; align-items: center; gap: 10px;
  margin-bottom: var(--sp-2);
}
.card-title .dot {
  width: 8px; height: 8px; border-radius: 50%; background: var(--accent);
}

/* Slide-ish content block */
.slide-body { max-width: var(--content-max); margin: 0 auto; padding: var(--sp-10) var(--sp-8) var(--sp-16); }
.slide-kicker {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-mono); font-size: var(--fs-xs);
  color: var(--accent-dark); text-transform: uppercase; letter-spacing: 0.08em;
  margin-bottom: var(--sp-4);
}
.slide-kicker::before {
  content: ''; width: 24px; height: 1px; background: var(--accent);
}
.slide-title { font-size: var(--fs-3xl); font-weight: 700; margin-bottom: var(--sp-4); letter-spacing: -0.02em; }
.slide-lede { font-size: var(--fs-md); color: var(--text-secondary); max-width: 82ch; margin-bottom: var(--sp-10); }
.slide-h2 { font-size: var(--fs-xl); margin: var(--sp-10) 0 var(--sp-4); }

/* Two-col grid */
.two-col { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-8); }
.three-col { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: var(--sp-6); }
@media (max-width: 960px) {
  .two-col, .three-col { grid-template-columns: 1fr; }
}

/* Callout */
.callout {
  border-left: 3px solid var(--accent);
  background: var(--accent-tint);
  padding: var(--sp-4) var(--sp-5);
  border-radius: 0 var(--r-md) var(--r-md) 0;
  color: var(--text-primary);
  font-size: var(--fs-sm);
}
.callout.amber { border-color: var(--amber); background: var(--amber-light); }
.callout strong { color: var(--accent-dark); }

/* -------------------- QUIZ -------------------- */
.quiz { border: 1px solid var(--border); border-radius: var(--r-lg); background: var(--bg-card); overflow: hidden; }
.quiz-head {
  padding: var(--sp-5) var(--sp-6);
  border-bottom: 1px solid var(--border);
  display: flex; align-items: center; justify-content: space-between;
  background: linear-gradient(to bottom, #FFFFFF, #FBFBF7);
}
.quiz-head .q-meta { display: flex; align-items: center; gap: 10px; font-size: var(--fs-xs); color: var(--text-secondary); }
.quiz-head .q-meta .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--accent); }
.quiz-q { padding: var(--sp-5) var(--sp-6); font-size: var(--fs-md); font-weight: 500; }
.quiz-opts { list-style: none; padding: 0 var(--sp-6) var(--sp-5); margin: 0; display: grid; gap: 10px; }
.quiz-opt {
  display: flex; align-items: center; gap: 12px;
  padding: 12px 14px; border: 1px solid var(--border); border-radius: var(--r-md);
  cursor: pointer; transition: all 140ms ease;
  background: var(--bg-card);
}
.quiz-opt:hover { border-color: var(--accent); background: var(--accent-tint); }
.quiz-opt .marker {
  width: 22px; height: 22px; border-radius: 50%; border: 1.5px solid var(--border-strong);
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
  font-family: var(--font-mono); font-size: 11px; color: var(--text-secondary);
  background: var(--bg-card);
}
.quiz-opt.multi .marker { border-radius: 5px; }
.quiz-opt.selected { border-color: var(--accent); background: var(--accent-tint); }
.quiz-opt.selected .marker { background: var(--accent); border-color: var(--accent); color: white; }
.quiz-opt.correct { border-color: var(--success); background: var(--success-light); }
.quiz-opt.correct .marker { background: var(--success); border-color: var(--success); color: white; }
.quiz-opt.wrong { border-color: var(--danger); background: var(--danger-light); }
.quiz-opt.wrong .marker { background: var(--danger); border-color: var(--danger); color: white; }
.quiz-opt .text { flex: 1; font-size: var(--fs-sm); }
.quiz-foot { padding: var(--sp-4) var(--sp-6); border-top: 1px solid var(--border); display: flex; justify-content: space-between; align-items: center; background: var(--bg-subtle); }
.quiz-feedback { font-size: var(--fs-sm); color: var(--text-secondary); }
.quiz-feedback.ok { color: var(--success); }
.quiz-feedback.err { color: var(--danger); }

/* -------------------- TERMINAL -------------------- */
.terminal {
  background: var(--bg-code);
  color: #E2E8F0;
  border-radius: var(--r-lg);
  border: 1px solid #1E293B;
  overflow: hidden;
  font-family: var(--font-mono);
  font-size: 14px;
  box-shadow: var(--sh-md);
}
.term-head {
  display: flex; align-items: center; gap: 8px;
  padding: 10px 14px; border-bottom: 1px solid #1E293B;
  background: #0B1220;
}
.term-head .dots { display: flex; gap: 6px; }
.term-head .dots span { width: 11px; height: 11px; border-radius: 50%; background: #334155; }
.term-head .dots span:nth-child(1) { background: #EF4444; }
.term-head .dots span:nth-child(2) { background: #F59E0B; }
.term-head .dots span:nth-child(3) { background: #10B981; }
.term-head .title { color: #94A3B8; font-size: 12px; margin-left: 6px; letter-spacing: 0.02em; }
.term-head .tabs { margin-left: auto; display: flex; gap: 4px; }
.term-head .tab {
  padding: 4px 10px; border-radius: 6px; font-size: 11px;
  color: #64748B; background: transparent;
}
.term-head .tab.active { background: #1E293B; color: #E2E8F0; }

.term-body {
  padding: 16px 18px 20px;
  min-height: 240px;
  line-height: 1.6;
  overflow-y: auto;
  max-height: 420px;
}
.term-line { white-space: pre-wrap; word-break: break-word; }
.term-prompt { color: #38BDF8; }
.term-path { color: #A5F3FC; }
.term-cmd { color: #F1F5F9; }
.term-out { color: #CBD5E1; }
.term-dim { color: #64748B; }
.term-ok { color: #4ADE80; }
.term-warn { color: #FBBF24; }
.term-err { color: #F87171; }
.term-kw { color: #C4B5FD; }
.cursor {
  display: inline-block; width: 8px; height: 15px; background: #38BDF8;
  vertical-align: middle; margin-left: 2px; animation: blink 1.1s steps(1) infinite;
}
@keyframes blink { 50% { opacity: 0; } }

.term-input-row { display: flex; align-items: center; gap: 8px; padding: 4px 0; }
.term-input-row input {
  flex: 1; background: transparent; border: 0; outline: 0;
  color: #F1F5F9; font-family: var(--font-mono); font-size: 14px;
}

/* -------------------- OSI STACK -------------------- */
.osi {
  display: grid; gap: 6px;
  font-family: var(--font-sans);
}
.osi-layer {
  display: grid; grid-template-columns: 36px 1fr auto; align-items: center;
  gap: 14px; padding: 14px 18px;
  border: 1px solid var(--border); border-radius: var(--r-md);
  background: var(--bg-card);
  cursor: pointer;
  transition: all 160ms ease;
}
.osi-layer:hover { border-color: var(--accent); box-shadow: var(--sh-sm); }
.osi-layer.active { border-color: var(--accent); background: var(--accent-tint); box-shadow: var(--sh-md); }
.osi-layer .num {
  width: 32px; height: 32px; border-radius: 8px;
  display: grid; place-items: center;
  font-family: var(--font-mono); font-weight: 600; font-size: 13px;
  background: var(--bg-subtle); color: var(--text-secondary);
}
.osi-layer.active .num { background: var(--accent); color: white; }
.osi-layer .name { font-weight: 600; font-size: var(--fs-sm); }
.osi-layer .sub { font-size: var(--fs-xs); color: var(--text-secondary); font-family: var(--font-mono); }
.osi-layer .chev { color: var(--text-muted); transition: transform 200ms; }
.osi-layer.active .chev { transform: rotate(90deg); color: var(--accent); }
.osi-detail {
  padding: 16px 18px; margin-top: -2px;
  border: 1px solid var(--accent-light); border-top: 0;
  border-radius: 0 0 var(--r-md) var(--r-md);
  background: var(--accent-tint);
  font-size: var(--fs-sm); color: var(--text-primary);
  display: grid; gap: 8px;
}
.osi-detail .proto-chips { display: flex; flex-wrap: wrap; gap: 6px; }
.osi-detail .chip {
  font-family: var(--font-mono); font-size: 12px;
  padding: 3px 9px; border-radius: 999px;
  background: white; border: 1px solid var(--accent-light); color: var(--accent-dark);
}

/* -------------------- MATCHING -------------------- */
.matching { display: grid; grid-template-columns: 260px 1fr; gap: var(--sp-6); }
@media (max-width: 860px) { .matching { grid-template-columns: 1fr; } }
.match-bank {
  padding: var(--sp-4);
  border: 1px dashed var(--border-strong);
  border-radius: var(--r-md);
  background: var(--bg-subtle);
  display: flex; flex-wrap: wrap; gap: 8px;
  align-content: flex-start;
  min-height: 160px;
}
.match-bank-label { width: 100%; font-size: var(--fs-xs); color: var(--text-secondary); font-family: var(--font-mono); text-transform: uppercase; letter-spacing: 0.06em; }
.match-pill {
  padding: 8px 12px; border-radius: var(--r-md);
  background: var(--bg-card); border: 1px solid var(--border);
  font-size: var(--fs-sm); cursor: grab; user-select: none;
  box-shadow: var(--sh-sm);
  transition: transform 120ms ease, box-shadow 120ms ease;
}
.match-pill:hover { box-shadow: var(--sh-md); transform: translateY(-1px); }
.match-pill.dragging { opacity: 0.4; }
.match-pill.correct { border-color: var(--success); background: var(--success-light); }
.match-pill.wrong { border-color: var(--danger); background: var(--danger-light); }

.match-targets { display: grid; gap: 10px; }
.match-target {
  display: grid; grid-template-columns: 160px 1fr; gap: 14px;
  align-items: stretch;
  padding: 0; border-radius: var(--r-md);
  overflow: hidden;
  border: 1px solid var(--border);
  background: var(--bg-card);
  min-height: 60px;
}
.match-target .t-label {
  padding: 12px 14px;
  background: var(--bg-subtle);
  font-size: var(--fs-sm); font-weight: 600;
  display: flex; align-items: center;
  border-right: 1px solid var(--border);
}
.match-target .t-drop {
  padding: 10px; display: flex; flex-wrap: wrap; gap: 6px;
  min-height: 48px; align-content: center;
}
.match-target.over { border-color: var(--accent); background: var(--accent-tint); }
.match-target.over .t-drop { background: var(--accent-tint); }

/* -------------------- SQL PLAYGROUND -------------------- */
.sqlp { display: grid; grid-template-columns: 220px 1fr; gap: var(--sp-4); min-height: 460px; }
@media (max-width: 1000px) { .sqlp { grid-template-columns: 1fr; } }
.sql-schema {
  border: 1px solid var(--border); border-radius: var(--r-md);
  background: var(--bg-card); padding: 12px;
  font-size: var(--fs-sm);
  max-height: 460px; overflow-y: auto;
}
.sql-schema .schema-h {
  font-family: var(--font-mono); font-size: 11px;
  color: var(--text-secondary); text-transform: uppercase; letter-spacing: 0.06em;
  margin-bottom: 8px;
}
.sql-table { margin-bottom: 10px; }
.sql-table summary {
  list-style: none; cursor: pointer;
  display: flex; align-items: center; gap: 8px;
  padding: 6px 8px; border-radius: 6px;
  font-weight: 500;
}
.sql-table summary::-webkit-details-marker { display: none; }
.sql-table summary:hover { background: var(--bg-subtle); }
.sql-table summary .ico { color: var(--accent); }
.sql-table summary .cnt { margin-left: auto; font-size: 11px; color: var(--text-muted); font-family: var(--font-mono); }
.sql-cols { list-style: none; padding: 4px 0 8px 28px; margin: 0; font-family: var(--font-mono); font-size: 12px; color: var(--text-secondary); }
.sql-cols li { padding: 2px 0; }
.sql-cols .pk { color: var(--amber); font-weight: 600; }
.sql-cols .fk { color: var(--info); }
.sql-cols .type { color: var(--text-muted); margin-left: 6px; }

.sql-main {
  display: flex; flex-direction: column;
  border: 1px solid var(--border); border-radius: var(--r-md);
  background: var(--bg-card); overflow: hidden;
}
.sql-toolbar {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 12px; border-bottom: 1px solid var(--border);
  background: linear-gradient(to bottom, #FFF, #FBFBF7);
}
.sql-toolbar .task {
  flex: 1; font-size: var(--fs-sm); color: var(--text-secondary);
}
.sql-toolbar .task b { color: var(--text-primary); font-weight: 600; }
.sql-editor {
  padding: 14px 16px;
  font-family: var(--font-mono); font-size: 14px; line-height: 1.65;
  min-height: 140px;
  background: #FDFCF6;
  border-bottom: 1px solid var(--border);
  position: relative;
}
.sql-editor .keyword { color: var(--accent-dark); font-weight: 600; }
.sql-editor .string { color: var(--amber); }
.sql-editor .num { color: var(--info); }
.sql-editor textarea {
  width: 100%; min-height: 120px; resize: vertical;
  border: 0; outline: 0; background: transparent;
  font-family: var(--font-mono); font-size: 14px; line-height: 1.65;
  color: var(--text-primary);
}

.sql-results {
  flex: 1; overflow: auto;
  background: var(--bg-card);
}
.sql-results table { width: 100%; border-collapse: collapse; font-size: 14px; }
.sql-results th, .sql-results td {
  padding: 9px 14px; text-align: left;
  border-bottom: 1px solid var(--border);
  font-family: var(--font-mono);
}
.sql-results th {
  background: var(--bg-subtle); font-weight: 600; color: var(--text-primary);
  font-size: 12px; text-transform: uppercase; letter-spacing: 0.04em; font-family: var(--font-sans);
  position: sticky; top: 0;
}
.sql-results tbody tr:hover { background: var(--bg-subtle); }
.sql-status {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 14px; border-top: 1px solid var(--border); background: var(--bg-subtle);
  font-size: var(--fs-xs); color: var(--text-secondary);
}
.sql-status .badge {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 3px 9px; border-radius: 999px; font-weight: 500;
}
.sql-status .badge.ok { background: var(--success-light); color: #065F46; }
.sql-status .badge.err { background: var(--danger-light); color: #991B1B; }

/* -------------------- IP CALC -------------------- */
.ipcalc {
  border: 1px solid var(--border); border-radius: var(--r-lg);
  background: var(--bg-card);
  padding: var(--sp-6);
}
.ipcalc input {
  width: 100%; padding: 12px 14px;
  font-family: var(--font-mono); font-size: 18px;
  border: 1px solid var(--border-strong); border-radius: var(--r-md);
  outline: 0; transition: border-color 160ms;
  letter-spacing: 0.02em;
}
.ipcalc input:focus { border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-tint); }
.ipcalc .ip-meta {
  margin-top: var(--sp-4);
  display: grid; gap: 8px;
}
.ipcalc .ip-row {
  display: grid; grid-template-columns: 160px 1fr auto;
  gap: 12px; align-items: center;
  padding: 8px 0; border-bottom: 1px dashed var(--border);
  font-size: var(--fs-sm);
}
.ipcalc .ip-row .k { color: var(--text-secondary); font-size: var(--fs-xs); font-family: var(--font-mono); text-transform: uppercase; letter-spacing: 0.04em; }
.ipcalc .ip-row .v { font-family: var(--font-mono); color: var(--text-primary); }
.ipcalc .ip-row .flag {
  padding: 2px 8px; border-radius: 999px; font-size: 11px; font-weight: 500;
}
.ipcalc .flag.ok { background: var(--success-light); color: #065F46; }
.ipcalc .flag.no { background: var(--danger-light); color: #991B1B; }
.ipcalc .flag.info { background: var(--info-light); color: #1E40AF; }
.ipcalc .octets {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px;
  margin-top: var(--sp-4);
}
.ipcalc .octet {
  padding: 10px; border: 1px solid var(--border); border-radius: var(--r-sm);
  text-align: center; background: var(--bg-subtle);
}
.ipcalc .octet .dec { font-family: var(--font-mono); font-size: var(--fs-lg); font-weight: 600; }
.ipcalc .octet .bin { font-family: var(--font-mono); font-size: 11px; color: var(--text-secondary); margin-top: 2px; letter-spacing: 0.04em; }

/* -------------------- PACKET FLOW -------------------- */
.packet-flow {
  border: 1px solid var(--border); border-radius: var(--r-lg);
  background: var(--bg-card);
  padding: var(--sp-6);
}
.pf-stage { position: relative; height: 260px; margin-top: var(--sp-4); }
.pf-stage svg { width: 100%; height: 100%; display: block; }
.pf-controls { display: flex; align-items: center; gap: 10px; margin-top: var(--sp-4); }
.pf-step-label { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--text-secondary); }
.pf-log {
  margin-top: var(--sp-3);
  padding: 10px 14px; border-radius: var(--r-sm);
  background: var(--bg-subtle); font-family: var(--font-mono); font-size: 13px;
  min-height: 44px; color: var(--text-primary);
}
.pf-log .hop-num { color: var(--accent-dark); font-weight: 600; margin-right: 8px; }

/* -------------------- FORM SUBMISSION -------------------- */
.submission {
  border: 1px solid var(--border); border-radius: var(--r-lg);
  background: var(--bg-card); padding: var(--sp-6);
}
.submission .field {
  display: grid; gap: 8px; margin-bottom: var(--sp-5);
}
.submission .field-label {
  font-weight: 600; font-size: var(--fs-sm);
}
.submission .field-hint {
  font-size: var(--fs-xs); color: var(--text-secondary); font-family: var(--font-mono);
}
.submission textarea, .submission input[type="text"] {
  width: 100%; padding: 10px 12px;
  border: 1px solid var(--border-strong); border-radius: var(--r-sm);
  font-family: inherit; font-size: var(--fs-sm);
  outline: 0; transition: border-color 160ms;
  background: var(--bg-card); color: var(--text-primary);
}
.submission textarea {
  min-height: 64px; resize: vertical; font-family: var(--font-mono); font-size: 13px;
}
.submission textarea:focus, .submission input[type="text"]:focus {
  border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-tint);
}
.submission-actions {
  display: flex; gap: 8px; align-items: center;
  padding-top: var(--sp-4); border-top: 1px solid var(--border);
}
.submission-status {
  flex: 1; font-size: var(--fs-sm); color: var(--text-secondary);
}
.submission-status.ok { color: var(--success); }
.submission-status.err { color: var(--danger); }

/* -------------------- SQL TASK FEEDBACK -------------------- */
.sql-task-feedback {
  padding: 10px 14px; margin-top: 10px; border-radius: var(--r-sm);
  font-size: var(--fs-sm);
  background: var(--bg-subtle); color: var(--text-secondary);
}
.sql-task-feedback.ok { background: var(--success-light); color: #065F46; }
.sql-task-feedback.err { background: var(--danger-light); color: #991B1B; }
.sql-task-feedback.warn { background: var(--amber-light); color: #92400E; }

/* -------------------- TERM TOOLTIP (Wikipedia / Glosář) -------------------- */
.term {
  position: relative;
  display: inline-block;
  color: var(--accent-dark);
  border-bottom: 1px dotted var(--accent);
  cursor: help;
  padding: 0 2px;
  border-radius: 3px;
}
.term:hover, .term:focus { background: var(--accent-tint); outline: 0; }
.term .tip {
  display: none;
  position: absolute;
  top: calc(100% + 8px); left: -6px;
  background: var(--bg-card);
  border: 1px solid var(--border-strong);
  box-shadow: var(--sh-md);
  border-radius: var(--r-md);
  padding: 4px;
  z-index: 30;
  min-width: 180px;
}
.term:hover .tip, .term:focus-within .tip { display: block; }
.term .tip a {
  display: flex; align-items: center; gap: 10px;
  padding: 9px 12px;
  border-radius: var(--r-sm);
  color: var(--text-primary);
  font-size: var(--fs-sm);
  text-decoration: none;
}
.term .tip a:hover {
  background: var(--accent-tint);
  color: var(--accent-dark);
  text-decoration: none;
}
.term .tip a .i {
  width: 22px; height: 22px;
  display: grid; place-items: center;
  flex-shrink: 0;
  border-radius: 4px;
  background: var(--bg-subtle);
  font-family: var(--font-mono); font-size: 11px; font-weight: 700;
  color: var(--text-secondary);
}
.term .tip a:hover .i { background: var(--accent); color: white; }

/* Card s termínem nesmí ořezávat tooltip, když je termín aktivní */
.card:has(.term:hover),
.card:has(.term:focus-within) { overflow: visible; }

/* -------------------- GLOSÁŘ KARTIČKY -------------------- */
.glos-list {
  display: grid; gap: var(--sp-3);
}
.glos-term {
  padding: var(--sp-4) var(--sp-5);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: var(--bg-card);
  scroll-margin-top: 80px;
}
.glos-term:target {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-tint);
}
.glos-term h3 {
  font-size: var(--fs-md);
  margin-bottom: 4px;
  color: var(--text-primary);
}
.glos-term h3 .alt {
  color: var(--text-secondary);
  font-weight: 400;
  font-size: var(--fs-sm);
  margin-left: 6px;
}
.glos-term p {
  color: var(--text-secondary);
  font-size: var(--fs-sm);
  line-height: 1.55;
  margin-bottom: var(--sp-3);
}
.glos-links {
  display: flex; flex-wrap: wrap; gap: 8px;
}
.glos-lnk {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 5px 10px;
  border-radius: var(--r-sm);
  background: var(--bg-subtle);
  border: 1px solid var(--border);
  font-size: var(--fs-xs);
  color: var(--accent-dark);
  font-family: var(--font-mono);
  text-decoration: none;
}
.glos-lnk:hover {
  background: var(--accent-tint);
  border-color: var(--accent-light);
  text-decoration: none;
}
.glos-lnk.ext { color: var(--info); }
.glos-sort-switch {
  display: inline-flex;
  border: 1px solid var(--border); border-radius: var(--r-sm);
  overflow: hidden;
  margin-bottom: var(--sp-5);
}
.glos-sort-switch button {
  padding: 6px 14px;
  font-size: var(--fs-xs);
  color: var(--text-secondary);
  font-family: var(--font-mono);
  background: var(--bg-card);
  cursor: pointer;
  border: 0;
}
.glos-sort-switch button.on {
  background: var(--accent);
  color: white;
}
