:root{
  --max:1280px; --text:#f2f5f9; --hair:rgba(255,255,255,.10);
  --panel:rgba(14,16,20,.82);
  --cta:#f4c320; --cta-dark:#d6a90e; /* GOLD */
}

@keyframes kenburns {
  0% { transform: scale(1) translate(0, 0); }
  100% { transform: scale(1.05) translate(-1%, 1%); }
}

html {
  box-sizing: border-box;
}
*, *:before, *:after {
  box-sizing: inherit;
}

html,body{margin:0;padding:0;color:var(--text);font:17px/1.6 Inter,system-ui,-apple-system,Segoe UI,Roboto; scroll-behavior: smooth; overflow-x: hidden;}
body { display: flex; flex-direction: column; min-height: 100vh; }
main { 
    flex-grow: 1;
    opacity: 0;
    transform: translateY(10px);
    transition: opacity 0.4s ease-out, transform 0.4s ease-out;
}
body::before{content:"";position:fixed;inset:0;background:linear-gradient(180deg, rgba(8,10,12,.85), rgba(8,10,12,.96)), url('img/bg.jpg') center/cover no-repeat fixed;z-index:-1; animation: kenburns 40s ease-in-out infinite alternate;}
a{color:#ffd772;text-decoration:none}
.wrap {
    max-width: 1500px;
    margin: 0 auto;
    padding: 18px 24px;
}

header .wrap{ position:sticky; top:18px; z-index:10;display:flex;align-items:center;justify-content:space-between;
  background:rgba(12,14,16,.55);backdrop-filter:blur(12px); border-radius:12px;border:1px solid var(--hair); box-shadow: 0 8px 24px rgba(0,0,0,.25); }
.brand-with-tagline { display: flex; flex-direction: column; align-items: flex-start; line-height: 1; }
.brand{font-weight:900;letter-spacing:.2px; color: var(--cta); transition: filter 0.2s ease; font-size: 28px; margin-bottom: 2px;}
.brand:hover{filter: brightness(1.1);}
.tagline { font-size: 14px; color: #e3b640; font-weight: 500; letter-spacing: 0.1px; opacity: 0.8; white-space: nowrap; }
.header-buttons { display: flex; gap: 10px; align-items: center; }

.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    padding: 10px 20px;
    background: transparent;
    color: var(--cta);
    border-radius: 12px;
    font-weight: 700;
    border: 2px solid var(--cta);
    text-align: center;
    box-shadow: none;
    transition: all 0.2s ease-in-out;
    cursor: pointer;
}
.btn:hover {
    background: var(--cta);
    color: #1a1c20;
    transform: translateY(-1px);
}
.btn:active{ transform:translateY(0) scale(.99); }
.btn.active {
    background: var(--cta);
    color: #1a1c20;
    cursor: default;
}
.btn.btn-special { background: var(--cta); color: #1a1c20; }
.btn.btn-special:hover { filter: brightness(1.1); transform: translateY(-2px); }

/* === Galerie triček (základ) === */
.galleryWrap{position:relative; margin:16px 0 12px;}
.gallery-quad{
  display:grid; grid-template-columns:repeat(4,1fr); gap:16px;
  background:rgba(18,20,24,.78); padding:12px; border-radius:14px; border:1px solid var(--hair);
  box-shadow:0 12px 26px rgba(0,0,0,.35);
}

a.tile { text-decoration: none; }
.tile{
  border-radius:14px; overflow:hidden;
  background:linear-gradient(180deg, rgba(25,27,32,.92), rgba(16,18,22,.92));
  border:1px solid rgba(255,255,255,.08);
  box-shadow:0 10px 24px rgba(0,0,0,.28);
  aspect-ratio: 4 / 5;
  display:flex; align-items:center; justify-content:center;
  transition:transform .16s ease, box-shadow .16s ease, border-color .16s ease;
}
.tile img{ width: 100%; height: 100%; object-fit: contain; }
.tile:hover{ transform: translateY(-2px); box-shadow:0 18px 34px rgba(0,0,0,.36), 0 0 0 2px var(--cta); }
.tile:hover img{ transform: scale(1.01); }

.nav4{position:absolute; inset:0; display:flex; align-items:center; justify-content:space-between; pointer-events:none}
.arrow{pointer-events:auto; margin:0 8px; width:36px; height:36px; border-radius:10px; background:rgba(0,0,0,.40); border:1px solid rgba(255,255,255,.12); color:#fff; display:flex; align-items:center; justify-content:center; font-weight:700; cursor:pointer; transition:.15s}
.arrow:hover{background:rgba(0,0,0,.6)}

.bigcta{
    display: flex;
    width: fit-content;
    margin: 24px auto;
    align-items: center;
    justify-content: center;
    background: linear-gradient(180deg, #f6cf54 0%, #e3b640 100%);
    color: #121418;
    border-radius: 12px;
    padding: 13px 24px;
    border: 1px solid #caa126;
    box-shadow: 0 10px 22px rgba(202,161,38,.28);
    font-weight: 900;
    transition: all 0.2s ease-in-out;
}
.bigcta:hover{
    filter: brightness(1.05);
    transform: translateY(-2px);
    box-shadow: 0 14px 28px rgba(202,161,38,.35);
}

.board{background:var(--panel); border:1px solid var(--hair); border-radius:14px; box-shadow:0 12px 30px rgba(0,0,0,.32); padding:22px;}
.chips{display:grid;gap:10px;grid-template-columns:repeat(6,1fr);align-items: stretch; }

.chip{
    position: relative;
    display: flex;
    align-items: center;
    gap: 8px;
    height: 75px;
    padding:12px 14px; border-radius:12px;
    background:rgba(255,255,255,.03); border:1px solid rgba(255,255,255,.10);
    color:#e9ecf1; box-shadow:none; cursor: pointer; transition: all 0.2s ease-in-out;
    min-width: 0;
}

.chip-icon {
    flex-shrink: 0;
    width: 16px;
    height: 16px;
    background-size: contain;
    background-position: center;
    background-repeat: no-repeat;
    transition: background-image 0.2s ease-in-out;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23e9ecf1' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolygon points='5 3 19 12 5 21 5 3'%3E%3C/polygon%3E%3C/svg%3E");
}
.chip:hover .chip-icon { filter: brightness(1.2); }
.chip.playing .chip-icon {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23121418' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolygon points='11 5 6 9 2 9 2 15 6 15 11 19 11 5'%3E%3C/polygon%3E%3Cpath d='M19.07 4.93a10 10 0 0 1 0 14.14M15.54 8.46a5 5 0 0 1 0 7.07'%3E%3C/path%3E%3C/svg%3E");
}

.chip .chip-text {
    flex-grow: 1;
    text-align: center;
    overflow-wrap: break-word;
    word-break: break-word;
}
.chip:hover{ background: rgba(255,255,255,.05); border-color: rgba(255,255,255,.16); transform: translateY(-2px); }
.chip:active{ transform: translateY(0) scale(0.98); }
.chip.playing{ background: linear-gradient(180deg, #f6cf54 0%, #e3b640 100%); color:#121418; border-color:#caa126; box-shadow:0 6px 16px rgba(202,161,38,.22); }

.share-icon {
    width: 20px; height: 20px; margin-left: auto; flex-shrink: 0;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.72'%3E%3C/path%3E%3Cpath d='M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.72-1.72'%3E%3C/path%3E%3C/svg%3E");
    background-size: contain; background-position: center; background-repeat: no-repeat;
    opacity: 0.7; transition: opacity 0.2s ease;
}
.chip:hover .share-icon { opacity: 1; }
.copied-feedback {
    position: absolute; inset: 0; display: flex; align-items: center; justify-content: center;
    background: var(--cta); color: #121418; font-weight: 700; border-radius: 11px;
    opacity: 0; visibility: hidden; transition: all 0.3s ease; transform: scale(0.9);
}
.chip.copied .copied-feedback { opacity: 1; visibility: visible; transform: scale(1); }

.leaderboard-section {
    background: var(--panel);
    border: 1px solid var(--hair);
    border-radius: 14px;
    box-shadow: 0 12px 30px rgba(0, 0, 0, .32);
    padding: 22px;
    margin-top: 24px;
    margin-bottom: 24px;
}
.leaderboard-section h2 {
    font-size: 26px;
    letter-spacing: .3px;
    margin: 0 0 12px 0;
    text-align: center;
    color: var(--cta);
}
#leaderboard { list-style: none; padding: 0; margin: 0; counter-reset: leaderboard-counter; }
#leaderboard li { display: flex; justify-content: space-between; align-items: center; padding: 12px; border-radius: 8px; margin-bottom: 8px; background: rgba(255, 255, 255, .03); font-weight: 500; }
#leaderboard li:before { counter-increment: leaderboard-counter; content: counter(leaderboard-counter) "."; font-weight: 900; color: var(--cta); margin-right: 15px; font-size: 18px; }
.leaderboard-count { font-weight: 700; color: #aab2c0; background: rgba(0,0,0,.2); padding: 4px 8px; border-radius: 6px; font-size: 14px; }

.generator-section {
    background: var(--panel);
    border: 1px solid var(--hair);
    border-radius: 14px;
    box-shadow: 0 12px 30px rgba(0, 0, 0, .32);
    padding: 22px;
    margin-top: 24px;
    text-align: center;
    display: flex;
    flex-direction: column;
    gap: 20px;
}
.generator-section h2 { font-size: 26px; letter-spacing: .3px; margin: 0 0 12px 0; color: var(--cta); }
.meme-output-container { position: relative; width: 100%; max-width: 500px; margin: 0 auto; cursor: grab; }
.meme-output-container:active { cursor: grabbing; }
#meme-canvas { border-radius: 8px; width: 100%; height: auto; background-color: #000; position: relative; z-index: 1; }
.meme-text-overlay { 
    position: absolute; 
    z-index: 2; 
    font-family: Impact, "Arial Black", sans-serif; 
    color: white; 
    text-align: center; 
    text-transform: uppercase; 
    text-shadow: -2px -2px 0 #000, 2px -2px 0 #000, -2px 2px 0 #000, 2px 2px 0 #000; 
    line-height: 1.1; 
    user-select: none; 
    width: 90%;
    cursor: move;
    left: 50%; 
    transform: translateX(-50%);
    transform-origin: center center;
}
#top-text-overlay { top: 5%; }
#bottom-text-overlay { top: 80%; }
.meme-controls { display: flex; flex-direction: column; gap: 15px; max-width: 500px; width: 100%; margin: 0 auto; text-align: left; }
.meme-controls label { font-weight: bold; color: var(--cta); margin-bottom: -10px; }
input[type="range"] { -webkit-appearance: none; appearance: none; width: 100%; height: 10px; background: #333; border-radius: 5px; outline: none; }
input[type="range"]::-webkit-slider-thumb { -webkit-appearance: none; appearance: none; width: 25px; height: 25px; background: var(--cta); cursor: pointer; border-radius: 50%; }
input[type="range"]::-moz-range-thumb { width: 25px; height: 25px; background: var(--cta); cursor: pointer; border-radius: 50%; }
.color-swatches { display: flex; gap: 10px; }
.color-swatch { width: 30px; height: 30px; border-radius: 50%; border: 3px solid transparent; cursor: pointer; }
.color-swatch.active { border-color: var(--cta); }
.meme-backgrounds-container { display: flex; gap: 10px; overflow-x: auto; padding: 10px; background: rgba(0,0,0,.2); border-radius: 8px; }
.meme-thumb { width: 80px; height: 80px; object-fit: cover; border-radius: 6px; cursor: pointer; border: 3px solid transparent; transition: border-color 0.2s ease; }
.meme-thumb:hover { border-color: rgba(255, 255, 255, 0.5); }
.meme-thumb.active { border-color: var(--cta); }
.meme-actions { display: grid; grid-template-columns: 1fr 1fr; gap: 15px; margin-top: 10px; }
.meme-actions .btn { width: 100%; }

/* Uploader (nové) */
.uploader {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
  max-width: 500px;
  margin: 0 auto;
}
.file-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 10px 16px;
  background: linear-gradient(180deg, #f6cf54 0%, #e3b640 100%);
  color: #121418;
  border-radius: 10px;
  border: 1px solid #caa126;
  font-weight: 800;
  cursor: pointer;
}
.dropzone {
  border: 2px dashed rgba(255,255,255,.25);
  border-radius: 10px;
  padding: 12px;
  color: #cbd2df;
  font-size: 14px;
  background: rgba(255,255,255,.04);
}
.dropzone.dragover {
  border-color: var(--cta);
  background: rgba(244,195,32,.08);
  color: #ffe08a;
}

/* Deep-link highlight */
@keyframes karaHighlight {
  0% { box-shadow: 0 0 0 0 rgba(244,195,32,0.0); transform: translateY(0); }
  20% { box-shadow: 0 0 0 4px rgba(244,195,32,0.35); transform: translateY(-2px); }
  50% { box-shadow: 0 0 0 6px rgba(244,195,32,0.22); }
  80% { box-shadow: 0 0 0 4px rgba(244,195,32,0.35); transform: translateY(-2px); }
  100% { box-shadow: 0 0 0 0 rgba(244,195,32,0.0); transform: translateY(0); }
}
.chip.deep-linked {
  position: relative;
  animation: karaHighlight 1.4s ease-in-out 2;
  outline: 2px solid var(--cta);
  outline-offset: -2px;
}
.chip.deep-linked::after {
  content: 'Tapni pro přehrání';
  position: absolute;
  bottom: 6px; left: 50%;
  transform: translateX(-50%);
  background: var(--cta);
  color: #121418;
  font-weight: 800;
  font-size: 12px;
  padding: 4px 8px;
  border-radius: 8px;
  box-shadow: 0 6px 14px rgba(202,161,38,.25);
  white-space: nowrap;
  pointer-events: none;
}

/* =================================================================== */
/* ZDE ZAČÍNÁ FINÁLNÍ RESPONZIVNÍ LOGIKA (Opravená verze 2025-10)     */
/* =================================================================== */

img, video { max-width: 100%; height: auto; display: block; }
html, body { overflow-x: hidden; }

/* --- Desktop a velké tablety --- */
@media (max-width: 1200px) {
  .chips {
    display: grid;
    gap: 10px;
    grid-template-columns: repeat(5, minmax(0, 1fr));
  }
}

@media (max-width: 980px) {
  .chips { grid-template-columns: repeat(4, minmax(0, 1fr)); }
  .gallery-quad {
    display: grid;
    gap: 14px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

/* --- Tablety --- */
@media (max-width: 768px) {
  .chips { grid-template-columns: repeat(3, minmax(0, 1fr)); }

  .character-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
  }
  .character-photo { width: 150px; height: 150px; }
}

/* --- Širší mobily (≤680 px) --- */
@media (max-width: 680px) {
  .chips { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .gallery-quad { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

/* --- Telefony (≤600 px) — slider: 1 tričko + šipky, autoplay --- */
@media (max-width: 600px) {
  .wrap,
  header .wrap,
  .board,
  .galleryWrap,
  .generator-section,
  .leaderboard-section,
  footer {
    max-width: 100% !important;
    width: 100% !important;
    padding-left: 10px !important;
    padding-right: 10px !important;
    margin: 0 auto !important;
    overflow: hidden !important;
  }

  .brand-with-tagline { align-items: center; text-align: center; }
  .brand { font-size: 22px; }
  .tagline { white-space: normal; }

  header .wrap {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
    padding: 10px;
    text-align: center;
  }

  .header-buttons {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 8px !important;
    justify-items: stretch !important;
    align-items: stretch !important;
    width: 100% !important;
    max-width: 100% !important;
  }
  .btn {
    width: 100% !important;
    text-align: center;
    padding: 10px 12px;
    font-size: 14px;
    line-height: 1.2;
    white-space: normal;
    box-sizing: border-box;
  }

  .chips {
    display: grid;
    gap: 8px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .chip {
    min-width: 0;
    width: 100% !important;
    height: auto;
    min-height: 65px;
    word-break: break-word;
  }

  .gallery-quad {
    display: flex !important;
    overflow: hidden !important;
    scroll-behavior: smooth;
    gap: 0 !important;
    padding: 0 !important;
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
  }
  .gallery-quad .tile {
    flex: 0 0 100%;
    border-radius: 0;
    box-shadow: none;
    border: none;
  }
  .nav4 { pointer-events: none; }
  .nav4 .arrow { pointer-events: auto; } /* šipky klikatelné */
}

/* --- Úzké mobily (≤420 px) --- */
@media (max-width: 420px) {
  .header-buttons {
    grid-template-columns: 1fr !important;
    width: 100% !important;
    max-width: 100% !important;
    justify-items: center !important;
  }
  .btn {
    width: 100% !important;
    max-width: 280px !important;
  }

  .chips { grid-template-columns: 1fr; }
  .chip  { width: 100% !important; }

  .brand { font-size: 20px; }
  .wrap, header .wrap { padding-left: 8px; padding-right: 8px; }

  html, body { overflow-x: hidden !important; }
}


/* === POLISH UPDATE FOR GENERATOR === */

/* === Generator (polished) === */
.generator-section {
  background: linear-gradient(180deg, rgba(14,16,20,.92), rgba(14,16,20,.86));
  border: 1px solid var(--hair);
  border-radius: 16px;
  box-shadow: 0 16px 40px rgba(0,0,0,.38);
  padding: 26px;
  margin-top: 28px;
  display: grid;
  grid-template-columns: 1fr;
  gap: 18px;
}

@media (min-width: 980px) {
  .generator-section {
    grid-template-columns: 520px 1fr; /* canvas vlevo, ovládání vpravo */
    align-items: start;
  }
}

.meme-stage {
  background: radial-gradient(1200px 400px at 50% -20%, rgba(244,195,32,.10), transparent 60%) , #0b0d10;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 14px;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.04), 0 12px 30px rgba(0,0,0,.35);
  padding: 18px;
}

.meme-output-container { position: relative; width: 100%; max-width: 480px; margin: 0 auto; cursor: grab; }
#meme-canvas { border-radius: 10px; width: 100%; height: auto; background-color: #000; }

.meme-controls {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
}
@media (min-width: 980px) {
  .meme-controls { grid-template-columns: 1fr 1fr; }
  .meme-controls .full { grid-column: 1 / -1; }
}

.meme-controls label {
  font-weight: 700; color: var(--cta); margin-bottom: -6px; font-size: 14px;
}

.meme-controls input[type="text"] {
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  color: #f2f5f9;
  border-radius: 10px;
  padding: 10px 12px;
}

input[type="range"] { -webkit-appearance: none; appearance: none; width: 100%; height: 10px; background: #2a2e35; border-radius: 999px; outline: none; }
input[type="range"]::-webkit-slider-thumb { -webkit-appearance: none; appearance: none; width: 22px; height: 22px; background: var(--cta); cursor: pointer; border-radius: 50%; border: 2px solid #1d1f24;}
input[type="range"]::-moz-range-thumb { width: 22px; height: 22px; background: var(--cta); cursor: pointer; border-radius: 50%; border: 2px solid #1d1f24;}

.color-swatches { display: flex; gap: 8px; align-items: center; }
.color-swatch { width: 26px; height: 26px; border-radius: 999px; border: 2px solid rgba(255,255,255,.22); cursor: pointer; box-shadow: 0 2px 8px rgba(0,0,0,.25); }
.color-swatch.active { border-color: var(--cta); box-shadow: 0 0 0 3px rgba(244,195,32,.22), 0 2px 8px rgba(0,0,0,.25); }

.meme-actions { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-top: 6px; }
.meme-actions .btn { width: 100%; padding: 12px 16px; border-radius: 10px; }

/* Uploader */
.uploader { display: grid; grid-template-columns: 1fr; gap: 10px; max-width: 520px; }
.file-btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; padding: 10px 16px; background: linear-gradient(180deg, #f6cf54 0%, #e3b640 100%); color: #121418; border-radius: 10px; border: 1px solid #caa126; font-weight: 800; cursor: pointer; }
.dropzone { border: 2px dashed rgba(255,255,255,.25); border-radius: 10px; padding: 12px; color: #cbd2df; font-size: 14px; background: rgba(255,255,255,.04); text-align: center; }
.dropzone.dragover { border-color: var(--cta); background: rgba(244,195,32,.08); color: #ffe08a; }


/* Color picker tweak */
.color-swatches input[type="color"] {
  appearance: none;
  -webkit-appearance: none;
  border-radius: 50%;
  box-shadow: 0 2px 8px rgba(0,0,0,.25);
}
.color-swatches input[type="color"]::-webkit-color-swatch-wrapper { padding: 0; }
.color-swatches input[type="color"]::-webkit-color-swatch { border: 2px solid rgba(255,255,255,.22); border-radius: 50%; }

/* Rotate sliders labels full width */
.meme-controls label { display: block; }


/* =========================================================
   FINAL POLISH OVERRIDES (non-destructive, appended at end)
   - Compact sliders (rotation + font size)
   - Modern text inputs
   - Swatches + color picker styling
   ========================================================= */

/* Modern inputs */
.meme-controls input[type="text"],
.controls .group input[type="text"],
.field input[type="text"]{
  background: linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.04));
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 12px;
  padding: 12px 14px;
  color: #f2f5f9;
  outline: none;
  transition: box-shadow .2s ease, border-color .2s ease, transform .06s ease;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.06), 0 1px 8px rgba(0,0,0,.25);
}
.meme-controls input[type="text"]::placeholder,
.controls .group input[type="text"]::placeholder,
.field input[type="text"]::placeholder{ color:#c9cfdb; opacity:.7; }
.meme-controls input[type="text"]:focus,
.controls .group input[type="text"]:focus,
.field input[type="text"]:focus{
  border-color: var(--cta);
  box-shadow: 0 0 0 3px rgba(244,195,32,.20), inset 0 1px 0 rgba(255,255,255,.06);
  transform: translateY(-1px);
}

/* Swatches and color picker (supports old/new class names) */
.swatches, .color-swatches{ display:flex; gap:10px; align-items:center; flex-wrap:wrap; }
.swatch, .color-swatch{
  width:30px; height:30px; border-radius:50%;
  border:2px solid rgba(255,255,255,.18); cursor:pointer;
  transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease;
  box-shadow: 0 2px 8px rgba(0,0,0,.25);
}
.swatch:hover, .color-swatch:hover{ transform: translateY(-2px); box-shadow:0 6px 14px rgba(0,0,0,.25); }
.swatch.active, .color-swatch.active{ border-color: var(--cta); box-shadow: 0 0 0 3px rgba(244,195,32,.22), 0 6px 14px rgba(0,0,0,.25); }

.color-input, .color-swatches input[type="color"]{
  appearance:none; -webkit-appearance:none;
  width:36px; height:36px; border-radius:50%; border:none; padding:0; cursor:pointer;
  box-shadow:0 2px 8px rgba(0,0,0,.25);
}
.color-input::-webkit-color-swatch-wrapper,
.color-swatches input[type="color"]::-webkit-color-swatch-wrapper{ padding:0; }
.color-input::-webkit-color-swatch,
.color-swatches input[type="color"]::-webkit-color-swatch{ border-radius:50%; border:2px solid rgba(255,255,255,.22); }
.color-input:focus-visible{ outline:3px solid rgba(244,195,32,.25); outline-offset:3px; border-radius:50%; }

/* Compact sliders next to labels */
.meme-controls .range-row,
.controls .group .range-row{
  display:flex; align-items:center; justify-content:flex-start; gap:10px; flex-wrap:wrap;
}
.meme-controls .range-row label,
.controls .group .range-row label{
  flex:0 0 110px; text-align:right; font-weight:600; color:#d6dae2;
}
.meme-controls .range-row input[type="range"],
.controls .group .range-row input[type="range"]{
  flex:0 0 160px; max-width:160px; accent-color: var(--cta);
  height:10px; border-radius:999px; background:#232730;
}
.meme-controls .range-row input[type="range"]::-webkit-slider-thumb,
.controls .group .range-row input[type="range"]::-webkit-slider-thumb{
  width:20px; height:20px; border-radius:50%; background: var(--cta); border:2px solid #1c1f24;
}
.meme-controls .range-row input[type="range"]::-moz-range-thumb,
.controls .group .range-row input[type="range"]::-moz-range-thumb{
  width:20px; height:20px; border-radius:50%; background: var(--cta); border:2px solid #1c1f24;
}

/* Mobile: slider under label, full width */
@media (max-width: 600px){
  .meme-controls .range-row,
  .controls .group .range-row{
    flex-direction: column; align-items: flex-start;
  }
  .meme-controls .range-row label,
  .controls .group .range-row label{
    text-align:left; margin-bottom:4px;
  }
  .meme-controls .range-row input[type="range"],
  .controls .group .range-row input[type="range"]{
    width:100%; max-width:none;
  }
}




/* ===== Compact, tidy controls (drop-in override) ===== */

/* 2-sloupcový layout pro každý group */
.controls .group .row {
  display: grid;
  grid-template-columns: 130px 1fr; /* levý sloupec – popisky, pravý – ovladače */
  column-gap: 14px;
  row-gap: 12px;
  align-items: center;
}

/* full-šířkové věci (text input, swatche) přes oba sloupce */
.controls .group .row .full { grid-column: 1 / -1; }

/* kompaktní „range řádky“ – label vlevo, krátký slider vpravo */
.controls .group .range-row {
  display: grid;
  grid-template-columns: 130px auto;
  align-items: center;
  column-gap: 14px;
}
.controls .group .range-row label {
  text-align: right;
  font-weight: 700;
  color: #d6dae2;
}

/* krátký slider – 140–180 px stačí */
.controls .group .range-row input[type="range"] {
  width: 170px;
  max-width: 170px;
  height: 10px;
  border-radius: 999px;
  background: #232730;
}
.controls .group .range-row input[type="range"]::-webkit-slider-thumb {
  width: 20px; height: 20px; border-radius: 50%;
  background: var(--cta); border: 2px solid #1c1f24;
}
.controls .group .range-row input[type="range"]::-moz-range-thumb {
  width: 20px; height: 20px; border-radius: 50%;
  background: var(--cta); border: 2px solid #1c1f24;
}

/* swatche a color picker se zarovnají do řádku na pravé straně */
.controls .group .swatches { justify-content: flex-start; }

/* mobil – vše pod sebe, slider na 100 % šířky */
@media (max-width: 720px) {
  .controls .group .row,
  .controls .group .range-row {
    grid-template-columns: 1fr;
  }
  .controls .group .range-row label {
    text-align: left;
  }
  .controls .group .range-row input[type="range"] {
    width: 100%;
    max-width: none;
  }
}


/* =============================
   KARA FINAL RANGE OVERRIDES
   ============================= */
input[type="range"]{
  -webkit-appearance:none;appearance:none;
  width:100%; height:12px; border-radius:999px;
  background:#2a2e35; outline:none;
  accent-color:#f4c320;
}
input[type="range"]::-webkit-slider-runnable-track{
  height:12px;border-radius:999px;
  background:linear-gradient(180deg,#3a3f47,#2a2e35);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06);
}
input[type="range"]::-webkit-slider-thumb{
  -webkit-appearance:none;appearance:none;
  width:22px;height:22px;border-radius:50%;
  background:#f4c320;border:2px solid #1d1f24;
  margin-top:-5px; box-shadow:0 2px 8px rgba(0,0,0,.35); cursor:pointer;
}
input[type="range"]::-moz-range-track{
  height:12px;border-radius:999px;
  background:linear-gradient(180deg,#3a3f47,#2a2e35);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06);
}
input[type="range"]::-moz-range-thumb{
  width:22px;height:22px;border-radius:50%;
  background:#f4c320;border:2px solid #1d1f24;
  box-shadow:0 2px 8px rgba(0,0,0,.35); cursor:pointer;
}
input[type="range"]:focus-visible{ outline:3px solid rgba(244,195,32,.25); outline-offset:3px; }




/* === HARD VISIBILITY BOOST v2 === */
.controls .group .range-row{ 
  display:grid; grid-template-columns: 1fr; row-gap:8px; 
}
.controls .group .range-row label{
  display:block; font-weight:900; letter-spacing:.2px;
  color:#ffd772; /* zlatá, vysoký kontrast */
  text-shadow:0 1px 0 rgba(0,0,0,.6);
}
.controls .group .range-row input[type="range"]{
  width:100%; max-width:none; height:14px; border-radius:999px;
  background: linear-gradient(180deg, #444c57, #2b3038);
  box-shadow: inset 0 2px 3px rgba(0,0,0,.35), 0 1px 0 rgba(255,255,255,.06);
}
input[type="range"]::-webkit-slider-thumb{
  width:26px; height:26px; margin-top:-6px;
}
input[type="range"]::-moz-range-thumb{
  width:26px; height:26px;
}
/* oddělovač mezi řádky */
.controls .group .row{ row-gap:16px; }



/* === FINAL SLIDER TWEAK v3 (shorter) === */
.controls .group .range-row {
  display: grid;
  grid-template-columns: 130px 170px; /* popisek + kratší slider */
  align-items: center;
  column-gap: 14px;
}
.controls .group .range-row label {
  text-align: right;
  font-weight: 700;
  color: #ffd772;
}
.controls .group .range-row input[type="range"] {
  width: 170px;
  max-width: 170px;
}
@media (max-width: 720px) {
  .controls .group .range-row {
    grid-template-columns: 1fr;
  }
  .controls .group .range-row label {
    text-align: left;
  }
  .controls .group .range-row input[type="range"] {
    width: 100%;
    max-width: none;
  }
}



/* === FIX v4 – short but clean layout === */
.controls .group .range-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
}
.controls .group .range-row label {
  font-weight: 700;
  color: #ffd772;
  min-width: 110px;
  text-align: left;
}
.controls .group .range-row input[type="range"] {
  flex: 1;
  max-width: 180px;
}
@media (max-width: 720px) {
  .controls .group .range-row {
    flex-direction: column;
    align-items: flex-start;
  }
  .controls .group .range-row input[type="range"] {
    width: 100%;
    max-width: none;
  }
}
