/* /inc/ui.css — společné UI pro všechny nástroje */
:root {
  --bg: #ffffff;
  --fg: #111827;
  --muted: #6b7280;
  --card: #f8fafc;
  --accent: #153ba2;
  --border: #e5e7eb;
  --input: #ffffff;
  --btn: #eef2ff;
  --ok: #166534;
  --warn: #8f0d30;
  --bad: #b71616;
  --radius: 12px;
  --pad2: 18px;
  --shadow: 0 8px 24px rgba(2,6,23,.08);
}
html[data-theme="dark"] {
  --bg: #0b0f14;
  --fg: #d8dee9;
  --muted: #9aa3b2;
  --card: #121822;
  --accent: #6aa3ff;
  --border: #1c2533;
  --input: #0e141d;
  --btn: #162235;
  --ok: #22c55e;
  --warn: #efcb61;
  --bad: #e24848;
}
* {
  box-sizing: border-box;
}

body {
  margin: 0;
  background: var(--bg);
  color: var(--fg);
  font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
}

a {
  color: var(--accent);
  text-decoration: none;
}

a:hover {
  text-decoration: underline;
}

/* Utility */
.hidden {
  display: none !important;
}

.muted {
  color: var(--muted) !important;
}

.text-muted {
  color: var(--muted) !important;
}

.small {
  font-size: 0.875rem;
}

/* Headingy - zajistit správnou barvu v dark theme */
h1, h2, h3, h4, h5, h6 {
  color: var(--fg);
}

/* Zlepšit kontrast muted textu v dark theme */
html[data-theme="dark"] .muted,
html[data-theme="dark"] .text-muted {
  color: #b8c5d1 !important;
}

/* Dark theme opravy pro lepší čitelnost */
html[data-theme="dark"] .taglist a {
  color: var(--fg);
  border-color: var(--border);
}

html[data-theme="dark"] .taglist a:hover {
  color: #fff;
}

html[data-theme="dark"] th {
  color: var(--fg) !important;
}

html[data-theme="dark"] td {
  color: var(--fg);
}

/* Bootstrap komponenty v dark režimu */
html[data-theme="dark"] .form-control,
html[data-theme="dark"] .form-select {
  background-color: var(--input);
  color: var(--fg);
  border-color: var(--border);
}

html[data-theme="dark"] .form-control:focus,
html[data-theme="dark"] .form-select:focus {
  background-color: var(--input);
  color: var(--fg);
  border-color: var(--accent);
  box-shadow: 0 0 0 0.25rem rgba(106, 163, 255, 0.25);
}

html[data-theme="dark"] .form-control::placeholder {
  color: var(--muted);
  opacity: 0.7;
}

html[data-theme="dark"] .btn-outline-secondary {
  color: var(--fg);
  border-color: var(--border);
  background-color: transparent;
}

html[data-theme="dark"] .btn-outline-secondary:hover {
  color: #fff;
  background-color: var(--accent);
  border-color: var(--accent);
}

html[data-theme="dark"] option {
  background-color: var(--card);
  color: var(--fg);
}

html[data-theme="dark"] select option {
  background-color: var(--input);
  color: var(--fg);
}

/* Nástroje - další dark režim opravy */
html[data-theme="dark"] .tool-title a {
  color: var(--fg);
}

html[data-theme="dark"] .tool-title a:hover {
  color: var(--accent);
}

html[data-theme="dark"] .count {
  color: var(--muted);
}

html[data-theme="dark"] .card p {
  color: var(--fg);
}

html[data-theme="dark"] strong {
  color: var(--fg);
}

html[data-theme="dark"] .btn-primary {
  background: var(--accent);
  border-color: var(--accent);
  color: #0b0f14;
}

html[data-theme="dark"] .btn-primary:hover {
  background: var(--accent);
  border-color: var(--accent);
  opacity: 0.9;
}

html[data-theme="dark"] datalist option {
  background-color: var(--card);
  color: var(--fg);
}

/* Tlačítka v dark režimu - lepší hover efekty */
html[data-theme="dark"] .btn:not(.btn-warn):not(.btn-primary) {
  background: var(--btn);
  color: var(--fg);
  border-color: var(--border);
}

html[data-theme="dark"] .btn:not(.btn-warn):not(.btn-primary):hover {
  background: var(--accent);
  color: #0b0f14;
  border-color: var(--accent);
  text-decoration: none;
}

html[data-theme="dark"] .btn-warn {
  background: var(--warn);
  border-color: var(--warn);
  color: #0b0f14;
}

html[data-theme="dark"] .btn-warn:hover {
  background: var(--warn);
  color: #0b0f14;
  border-color: var(--warn);
  opacity: 0.85;
  text-decoration: none;
}

/* Header + footer */
.site-header,
.site-footer {
  border-bottom: 1px solid var(--border);
  padding: 10px 14px;
}

.site-footer {
  border-top: 1px solid var(--border);
  border-bottom: 0;
  color: var(--muted);
  text-align: center;
  padding: 24px 14px;
  background: var(--card);
}

.container {
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 20px;
}

.header-bar,
.header-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 56px;
  gap: 20px;
  min-width: 0;
}

.brand {
  flex-shrink: 0;
  min-width: 0;
}

.brand-link {
  font-weight: 700;
  letter-spacing: .2px;
  color: var(--fg);
  white-space: nowrap;
}

.tool-name {
  color: var(--muted);
  font-size: 0.75rem;
  margin-left: 8px;
  font-weight: 500;
}

.header-right {
  margin-left: auto;
  display: flex;
  gap: 8px;
}

/* Navigation */
.site-nav {
  display: flex;
  align-items: center;
  gap: 16px;
  font-size: 0.95rem;
  flex-wrap: nowrap;
  flex: 1;
  justify-content: flex-end;
}

.nav-group {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: nowrap;
  flex-shrink: 0;
}

.nav-group-title {
  color: var(--warn);
  font-size: .8rem;
  font-weight: 600;
  margin-right: 2px;
  white-space: nowrap;
}

.nav-group a {
  color: var(--muted);
  text-decoration: none;
  padding: 6px 10px;
  border-radius: 8px;
  transition: all .15s ease;
  white-space: nowrap;
  font-size: 0.9rem;
}

.nav-group a:hover {
  color: var(--accent);
  background: var(--card);
}

.nav-group a.active {
  background: var(--accent);
  color: #fff;
}

/* Badge "zdarma" v navigaci */
.badge-free {
  display: inline-block;
  background: linear-gradient(135deg, #22c55e 0%, #16a34a 100%);
  color: #fff !important;
  font-size: .65rem;
  font-weight: 700;
  padding: 2px 6px;
  border-radius: 4px;
  margin-left: 4px;
  text-transform: uppercase;
  letter-spacing: .3px;
  vertical-align: middle;
}

/* Hamburger menu toggle - viditelný na mobilu, skrytý na desktopu */
.nav-toggle {
  display: none;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 40px;
  height: 40px;
  padding: 0;
  background: transparent;
  border: 1px solid var(--border);
  border-radius: 8px;
  cursor: pointer;
  z-index: 1001;
}

.nav-toggle .hamburger,
.nav-toggle .hamburger::before,
.nav-toggle .hamburger::after {
  display: block;
  width: 20px;
  height: 2px;
  background: var(--fg);
  border-radius: 2px;
  transition: all 0.3s ease;
}

.nav-toggle .hamburger {
  position: relative;
}

.nav-toggle .hamburger::before,
.nav-toggle .hamburger::after {
  content: '';
  position: absolute;
  left: 0;
}

.nav-toggle .hamburger::before {
  top: -6px;
}

.nav-toggle .hamburger::after {
  top: 6px;
}

/* Hamburger to X animation */
.nav-toggle.active .hamburger {
  background: transparent;
}

.nav-toggle.active .hamburger::before {
  top: 0;
  transform: rotate(45deg);
}

.nav-toggle.active .hamburger::after {
  top: 0;
  transform: rotate(-45deg);
}

/* Mobile navigation */
@media (max-width: 900px) {
  .header-row {
    flex-wrap: nowrap;
  }
  
  .nav-toggle {
    display: flex !important;
    order: 3;
    margin-left: auto;
  }
  
  .site-nav {
    position: fixed;
    top: 0;
    right: -100%;
    width: min(320px, 85vw);
    height: 100vh;
    background: var(--bg);
    flex-direction: column;
    align-items: flex-start;
    justify-content: flex-start;
    padding: 80px 24px 24px;
    gap: 8px;
    box-shadow: -4px 0 20px rgba(0,0,0,0.15);
    transition: right 0.3s ease;
    z-index: 1000;
    overflow-y: auto;
    order: 4;
  }
  
  .site-nav.open {
    right: 0;
  }
  
  .brand {
    order: 1;
  }
  
  .nav-group {
    flex-direction: column;
    align-items: flex-start;
    width: 100%;
    gap: 4px;
    padding-bottom: 16px;
    border-bottom: 1px solid var(--border);
    margin-bottom: 8px;
  }
  
  .nav-group:last-child {
    border-bottom: none;
    padding-bottom: 0;
  }
  
  .nav-group a {
    width: 100%;
    padding: 12px 16px;
    font-size: 1rem;
  }
  
  .nav-group-title {
    padding: 8px 16px 4px;
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.5px;
  }
  
  /* Overlay */
  .nav-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.5);
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.3s ease, visibility 0.3s ease;
    z-index: 999;
  }
  
  .nav-overlay.active {
    opacity: 1;
    visibility: visible;
  }
  
  .header-row {
    position: relative;
  }
}



/* Buttons */
button,
.btn {
  appearance: none;
  border: 1px solid var(--border);
  background: var(--btn);
  color: var(--fg);
  padding: 10px 14px;
  border-radius: 10px;
  cursor: pointer;
  transition: transform .08s ease, background .15s, border-color .15s;
}

.btn:hover {
  transform: translateY(-1px);
  border-color: var(--accent);
}

.btn:active {
  transform: translateY(0);
}

.btn-primary {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
}

.btn-warn {
  background: var(--warn);
  border-color: var(--warn);
  color: #fff;
}

.btn-ghost {
  background: transparent;
  border: 1px solid var(--border);
  color: var(--fg);
  padding: 8px 16px;
  border-radius: var(--radius);
  text-decoration: none;
  transition: all .2s ease;
  font-size: inherit;
}

.btn-ghost:hover {
  background: var(--card);
  border-color: var(--accent);
  color: var(--accent);
}

.btn-small {
  padding: 6px 10px;
  border-radius: 8px;
  font-size: .9rem;
}

.badge {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 999px;
  background: var(--card);
  border: 1px solid var(--border);
  color: var(--muted);
  font-size: .8rem;
}

.user {
  opacity: .8;
  font-size: .9em;
  color: var(--muted);
}

.btn-main {
  background: transparent;
  border: 1px solid var(--border);
  color: var(--fg);
  padding: 8px 16px;
  border-radius: var(--radius);
  text-decoration: none;
  transition: all .2s ease;
  font-size: inherit;
}


/* Cards + layout */
html, body {
  height: auto;
}

body {
  display: block;
  min-height: auto;
}

main {
  min-height: auto;
}

.site-footer {
  margin-top: 40px;
  flex-shrink: 0;
}

.hero {
  padding: 28px 0 10px;
}

h1 {
  font-size: 1.4rem;
  margin: 0 0 12px;
}

.lead {
  color: var(--muted);
  margin: 0 0 18px;
  max-width: 68ch;
}

.form-row {
  display: flex;
  gap: 10px;
  align-items: center;
  flex-wrap: wrap;
}

.input {
  flex: 1;
  min-width: 380px;
  padding: 12px 14px;
  border-radius: 12px;
  border: 1px solid var(--border);
  background: var(--input);
  color: var(--fg);
}

.card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 12px;
  box-shadow: var(--shadow);
  padding: 18px;
  margin: 18px 0;
}

.code {
  background: rgba(127,127,127,.08);
  border: 1px dashed var(--border);
  padding: 12px;
  border-radius: 10px;
  overflow: auto;
}

/* Help blocks */
.help {
  margin-top: 10px;
}

.help > summary {
  cursor: pointer;
  list-style: none;
}

.help > summary::-webkit-details-marker {
  display: none;
}

.help > summary .q {
  display: inline-block;
  width: 22px;
  height: 22px;
  border-radius: 999px;
  background: var(--accent);
  color: #fff;
  text-align: center;
  line-height: 22px;
  font-weight: 700;
  margin-right: 8px;
}

/* Nástroje - společné komponenty */
.pill {
  display: inline-block;
  background: var(--accent);
  color: #fff;
  border-radius: 999px;
  padding: 4px 10px;
  font-size: .78rem;
  margin-right: 6px;
  margin-top: 6px;
  white-space: nowrap;
}

.taglist {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.taglist a {
  border: 1px solid var(--border);
  border-radius: 999px;
  padding: 6px 10px;
  font-size: .85rem;
  background: var(--card);
  text-decoration: none;
}

.taglist a:hover {
  background: var(--accent);
  color: #fff;
  border-color: var(--accent);
}

.taglist a.active {
  background: var(--accent);
  color: #fff;
  border-color: transparent;
}

/* Tabulka nástrojů */
.table-wrap {
  overflow: auto;
}

.tools {
  width: 100%;
  table-layout: auto;
  border-collapse: separate;
  border-spacing: 0 6px;
  font-size: .95rem;
}

.tools th,
.tools td {
  padding: 8px 10px;
  background: var(--card);
  border: 1px solid var(--border);
  vertical-align: top;
}

.tools th {
  background: var(--card);
  text-align: left;
  font-weight: 600;
}

.t-name {
  width: 40%;
}

.t-tags {
  width: auto;
}

.t-actions {
  white-space: nowrap;
  width: 1%;
}

.tags-inline {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

/* Karty nástrojů */
.cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}

@media (max-width: 1200px) {
  .cards {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 680px) {
  .cards {
    grid-template-columns: 1fr;
  }
}

.tool-title {
  font-weight: 800;
  font-size: 1.05rem;
  margin: 0 0 4px;
}

.tool-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 8px;
}

.tool-footer {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 8px;
}

/* View toggle */
.view-toggle {
  display: flex;
  gap: 12px;
  align-items: center;
}

.icon-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: var(--card);
  text-decoration: none;
}

.icon-btn:hover {
  background: var(--accent);
  color: #fff;
  border-color: var(--accent);
}

.icon-btn.active {
  background: var(--accent);
  color: #fff;
  border-color: transparent;
}

.icon {
  width: 20px;
  height: 20px;
}

/* Header pro nástroje */
header.top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 20px;
  margin-top: 20px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--border);
}

header.top h1 {
  margin: 0;
  font-size: 1.6rem;
  font-weight: 700;
}

header.top .view-toggle {
  margin-left: auto;
}

.count {
  font-weight: 600;
  color: var(--muted);
  margin-right: 16px;
}

/* Status badges – globální, bez grid hacků */
.ok {
  color: var(--ok);
}

.warn {
  color: var(--warn);
}

.bad {
  color: var(--bad);
}
.badge-status {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  border-radius: 20px;
  font-size: .85rem;
  font-weight: 500;
  line-height: 1.2;
}

.badge-status.ok {
  background: rgba(34,197,94,.1);
  color: var(--ok);
  border: 1px solid rgba(34,197,94,.2);
}

.badge-status.warn {
  background: rgba(234,179,8,.1);
  color: var(--warn);
  border: 1px solid rgba(234,179,8,.2);
}

.badge-status.bad {
  background: rgba(239,68,68,.1);
  color: var(--bad);
  border: 1px solid rgba(239,68,68,.2);
}

.badge-status.info {
  background: rgba(59,130,246,.1);
  color: #ffffff;
  border: 1px solid rgba(59,130,246,.2);
}

/* Preloader – společné styly */
#preloader{position:fixed;inset:0;z-index:9999}        /* odstraněno pointer-events:none */
.pre{position:fixed;inset:0;background:rgba(0,0,0,.35);backdrop-filter:blur(2px);
     display:flex;align-items:center;justify-content:center;z-index:9999}
.pre.hidden{display:none !important;visibility:hidden !important;opacity:0 !important;pointer-events:none !important}
.pre .box{width:min(560px,92vw);background:var(--card);border:1px solid var(--border);border-radius:16px;padding:18px;box-shadow:var(--shadow)}
.pre .row{display:flex;align-items:center;gap:10px}
.pre .spinner{width:28px;height:28px;border-radius:50%;border:3px solid var(--border);border-top-color:var(--accent);animation:spin .9s linear infinite}
.pre .steps{margin:10px 0 0 18px;max-height:220px;overflow:auto;color:var(--muted)}
.pre .progress{width:100%;height:8px;border-radius:999px;background:rgba(127,127,127,.15);overflow:hidden;margin:12px 0 0}
.pre .progress>i{display:block;height:100%;width:0;background:var(--accent);transition:width .25s}

/* Animace — jedna definice bez duplicit */
@keyframes spin{to{transform:rotate(360deg)}}

/* ===== Modály (SimpleShop) ===== */

dialog#buy-ai,dialog#buy-link,dialog#buy-bundle{padding:0;border:0}
dialog#buy-ai::backdrop,dialog#buy-link::backdrop,dialog#buy-bundle::backdrop{background:rgba(0,0,0,.6)}
dialog#buy-ai > .card,dialog#buy-link > .card,dialog#buy-bundle > .card{width:min(1100px,96vw);max-width:none}
dialog#buy-ai iframe,dialog#buy-link iframe,dialog#buy-bundle iframe{display:block;width:100%;min-height:880px;border:0;border-radius:12px;background:#ffffff}

/* SimpleShop formuláře vždy světlé */
dialog#buy-ai [data-SimpleShopForm],
dialog#buy-link [data-SimpleShopForm],
dialog#buy-bundle [data-SimpleShopForm] {
  background: #ffffff !important;
  color: #111827 !important;
}

dialog#buy-ai [data-SimpleShopForm] a,
dialog#buy-link [data-SimpleShopForm] a,
dialog#buy-bundle [data-SimpleShopForm] a {
  color: #1d4ed8 !important;
}

/* Modaly vždy světlé - nezávisle na tématu */
dialog#buy-ai > .card,
dialog#buy-link > .card,
dialog#buy-bundle > .card {
  background: #ffffff !important;
  color: #111827 !important;
  border-color: #e5e7eb !important;
}

dialog#buy-ai > .card .header-row,
dialog#buy-link > .card .header-row,
dialog#buy-bundle > .card .header-row {
  background: #f8fafc !important;
  border-bottom-color: #e5e7eb !important;
}

dialog#buy-ai > .card h3,
dialog#buy-link > .card h3,
dialog#buy-bundle > .card h3 {
  color: #111827 !important;
}

dialog#buy-ai > .card .btn,
dialog#buy-link > .card .btn,
dialog#buy-bundle > .card .btn {
  background: #eef2ff !important;
  color: #111827 !important;
  border-color: #e5e7eb !important;
}

dialog#buy-ai > .card .btn:hover,
dialog#buy-link > .card .btn:hover,
dialog#buy-bundle > .card .btn:hover {
  background: #dbeafe !important;
  border-color: #1d4ed8 !important;
}

/* Všechny texty a elementy v modalu vždy světlé */
dialog#buy-ai > .card *,
dialog#buy-link > .card *,
dialog#buy-bundle > .card * {
  color: #111827 !important;
}

/* Inputy a formulářové elementy vždy světlé */
dialog#buy-ai > .card input,
dialog#buy-ai > .card select,
dialog#buy-ai > .card textarea,
dialog#buy-link > .card input,
dialog#buy-link > .card select,
dialog#buy-link > .card textarea,
dialog#buy-bundle > .card input,
dialog#buy-bundle > .card select,
dialog#buy-bundle > .card textarea {
  background: #ffffff !important;
  color: #111827 !important;
  border-color: #e5e7eb !important;
}





/* Mobile breakpoint */
@media (max-width: 480px) {
  .container {
    padding: 0 12px;
  }
  
  .site-header {
    padding: 8px 12px;
  }
  
  .header-row {
    height: 48px;
  }
  
  .brand-link {
    font-size: 0.9rem;
  }
  

}

@media(max-width:768px){
  dialog#buy-ai > .card,dialog#buy-link > .card,dialog#buy-bundle > .card{width:100vw;border-radius:0}
  dialog#buy-ai,dialog#buy-link,dialog#buy-bundle{margin:0}
}
