:root{--gold:#bf8422;--dark:#342411;--ink:#2d2418;--cream:#fff8ec;--shadow:0 18px 45px rgba(74,45,9,.18)}*{box-sizing:border-box}body{margin:0;font-family:Montserrat,sans-serif;color:var(--ink);background:#f4ecdf;background-image:radial-gradient(circle at top,#fff8ea 0,#f4eadb 34%,#eee2d1 100%)}button,input{font:inherit}.hidden{display:none}.hero{min-height:100vh;background:url('/assets/hero-hera-zeus-v2.jpg') center/cover no-repeat;display:flex;align-items:center;justify-content:center;padding:34px;position:relative}.hero:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(0,0,0,.25),rgba(255,244,218,.04),rgba(0,0,0,.28))}.panel{position:relative;width:min(520px,92vw);padding:34px;background:rgba(255,248,237,.93);border:1px solid var(--gold);border-radius:18px;box-shadow:var(--shadow);text-align:center;backdrop-filter:blur(3px)}.temple{font-size:38px;color:var(--gold)}h1,h2,h3{font-family:Cinzel,serif;letter-spacing:.05em;color:#33220e;margin:0}h1{font-size:42px;line-height:1.06}h2{font-size:30px}p{line-height:1.55}.date{font-family:Cinzel,serif;font-size:19px;letter-spacing:.15em;color:#6e4716;margin:18px 0}.name-input{width:100%;padding:14px 16px;border:1px solid rgba(160,105,32,.35);border-radius:9px;background:#fff;color:#5a3a13;text-align:center;margin:10px 0 16px}.name-input:disabled{opacity:1;background:#fff9f0}.btn{border:0;border-radius:8px;padding:13px 30px;cursor:pointer;color:#fff;background:linear-gradient(180deg,#dbac50,#a96d15);box-shadow:0 8px 18px rgba(130,78,12,.26);font-family:Cinzel,serif;font-weight:700;letter-spacing:.06em}.btn.secondary{background:#fff8eb;color:#8c5d18;border:1px solid var(--gold);box-shadow:none}.screen{min-height:100vh;padding:34px 20px;background-image:linear-gradient(rgba(255,249,239,.9),rgba(255,249,239,.92)),url('/assets/hero-hera-zeus-v2.jpg');background-position:center;background-size:cover}.card{width:min(980px,96vw);margin:0 auto 22px;padding:30px;background:rgba(255,248,238,.94);border:1px solid var(--gold);border-radius:18px;box-shadow:var(--shadow)}.center{text-align:center}.option{display:flex;gap:16px;width:min(720px,100%);margin:14px auto;padding:17px 18px;border:1px solid rgba(168,112,30,.3);border-radius:10px;background:rgba(255,255,255,.55);cursor:pointer;text-align:left}.radio{width:22px;height:22px;border:2px solid var(--gold);border-radius:50%;flex:0 0 auto;margin-top:2px}.option.active .radio{background:radial-gradient(circle,#bf8422 45%,transparent 48%)}.option strong{display:block;margin-bottom:4px}.role-layout{width:min(1120px,98vw);margin:0 auto}.intro-text{font-family:Cinzel,serif;text-align:center;font-size:22px;line-height:1.45;margin:0 auto 22px;max-width:920px}.roles-box{max-height:620px;overflow:auto;padding-right:10px}.role-card{display:grid;grid-template-columns:150px 1fr 150px;gap:20px;align-items:center;margin:12px 0;padding:12px;border:1px solid rgba(168,112,30,.28);border-radius:12px;background:rgba(255,250,241,.82);transition:.2s}.role-card.reserved{filter:grayscale(.35);opacity:.67}.role-card.mine{outline:2px solid var(--gold);box-shadow:0 0 0 4px rgba(210,166,78,.18)}.role-card img{width:150px;height:96px;object-fit:cover;border-radius:8px;border:1px solid rgba(173,116,26,.35)}.role-name{font-family:Cinzel,serif;font-size:24px;font-weight:700}.traits{color:#9b681c;font-weight:600;margin:3px 0 5px;font-size:13px}.desc{font-size:14px;line-height:1.35}.status{font-family:Cinzel,serif;text-align:center;color:#7c541a;font-weight:700;border:1px solid rgba(168,112,30,.25);border-radius:8px;padding:10px;background:rgba(255,255,255,.45)}.none-card{display:flex;justify-content:space-between;align-items:center;margin:16px 0 0;padding:18px 22px;border:1px solid rgba(168,112,30,.28);border-radius:12px;background:rgba(255,250,241,.85);cursor:pointer}.none-card strong{display:block;font-size:18px}.roster{width:min(1220px,98vw);margin:18px auto 0;padding:22px;background:rgba(255,248,238,.92);border:1px solid rgba(168,112,30,.35);border-radius:16px}.roster-grid{display:grid;grid-template-columns:repeat(10,1fr);gap:14px}.roster-item{text-align:center;position:relative}.roster-item img{width:70px;height:70px;object-fit:cover;border-radius:50%;border:2px solid var(--gold)}.roster-item.reserved{filter:grayscale(.3);opacity:.65}.lock{position:absolute;right:18%;top:0;background:#fff7e8;border:1px solid var(--gold);border-radius:50%;font-size:14px;width:23px;height:23px;display:flex;align-items:center;justify-content:center}.roster-name{font-family:Cinzel,serif;font-size:14px;margin-top:6px}.success-role{font-size:22px;font-family:Cinzel,serif;color:#8d5e18;font-weight:700}.small{font-size:13px;color:#6b5944}.toast{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);background:#2d2418;color:white;padding:12px 18px;border-radius:10px;box-shadow:var(--shadow)}@media(max-width:760px){.hero{padding:20px;align-items:flex-end}h1{font-size:31px}.screen{padding:18px 10px}.card{padding:22px 14px}.role-card{grid-template-columns:92px 1fr;gap:12px}.role-card img{width:92px;height:82px}.role-card .btn,.role-card .status{grid-column:1/-1}.role-name{font-size:20px}.roster-grid{grid-template-columns:repeat(4,1fr)}.intro-text{font-size:18px}}

/* Úpravy výběru role */
.intro-text{
  font-weight:700;
}

.selected-role-panel{
  margin-bottom:18px;
  width:100%;
  padding:28px 26px;
}

.selected-role-inner{
  display:flex;
  gap:24px;
  align-items:center;
  justify-content:center;
  flex-wrap:wrap;
}

.selected-role-img{
  width:180px;
  height:124px;
  object-fit:cover;
  border-radius:12px;
  border:1px solid rgba(168,112,30,.42);
  box-shadow:0 10px 22px rgba(116,71,12,.12);
}

.selected-role-copy{
  max-width:600px;
}

.selected-role-kicker{
  font-family:Cinzel,serif;
  letter-spacing:.10em;
  color:#8d5e18;
  font-size:17px;
  font-weight:800;
  text-transform:uppercase;
  margin-bottom:4px;
}

.selected-role-actions{
  display:flex;
  gap:14px;
  justify-content:center;
  flex-wrap:wrap;
  margin-top:18px;
}

/* Jednotné zobrazení miniatur bohů – ořízne spodní jmenný štítek z obrázků */
.role-card img{
  height:96px;
  object-fit:cover;
  object-position:center 34%;
}

/* Zvýraznění vlastní role bez uříznutého levého rámečku */
.roles-box{
  padding:2px 12px 2px 4px;
}

.role-card.mine{
  outline:none;
  border:2px solid var(--gold);
  box-shadow:0 0 0 3px rgba(210,166,78,.18), 0 8px 18px rgba(116,71,12,.08);
}

@media(max-width:760px){
  .selected-role-img{
    width:150px;
    height:105px;
  }
  .selected-role-kicker{
    font-size:14px;
  }
}


/* Finální polish – vybraná role */
.selected-role-panel{
  animation:selectedPanelIn .45s ease both;
}

@keyframes selectedPanelIn{
  from{opacity:0; transform:translateY(18px)}
  to{opacity:1; transform:translateY(0)}
}

.role-picked-flash .selected-role-panel{
  box-shadow:0 0 0 4px rgba(214,166,73,.16), 0 18px 42px rgba(123,77,14,.18);
}

.selected-role-img-wrap{
  width:230px;
  height:142px;
  overflow:hidden;
  border-radius:14px;
  border:1px solid rgba(168,112,30,.45);
  box-shadow:0 10px 24px rgba(116,71,12,.14);
  background:#fff8ee;
}

.selected-role-img{
  width:100%;
  height:132%;
  object-fit:cover;
  object-position:center 16%;
  display:block;
}

.selected-role-kicker{
  font-size:20px;
}

.selected-role-copy .success-role{
  font-size:28px;
}

/* Miniatury v seznamu – pevný výřez bez spodního štítku se jménem */
.role-card img{
  height:96px;
  object-fit:cover;
  object-position:center 18%;
}

/* silnější rámeček vybrané role v seznamu */
.role-card.mine{
  border:3px solid var(--gold);
  box-shadow:0 0 0 4px rgba(210,166,78,.22), 0 10px 24px rgba(116,71,12,.12);
}

/* více prostoru uvnitř scrollboxu, aby se rámeček neusekával */
.roles-box{
  padding:6px 16px 6px 8px;
}

/* poslední stránka – ikona role a zlaté částice */
.success-card{
  position:relative;
  overflow:hidden;
}

.success-role-visual{
  width:150px;
  height:150px;
  margin:18px auto 10px;
  border-radius:50%;
  padding:4px;
  background:linear-gradient(145deg,#f8dd95,#ad7418);
  box-shadow:0 0 0 7px rgba(218,174,84,.14), 0 14px 36px rgba(128,80,14,.18);
  animation:roleIconPop .7s ease both;
}

.success-role-visual img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center 18%;
  border-radius:50%;
  display:block;
}

@keyframes roleIconPop{
  0%{opacity:0; transform:scale(.74) translateY(10px)}
  65%{opacity:1; transform:scale(1.05) translateY(0)}
  100%{transform:scale(1)}
}

.success-particles{
  position:absolute;
  inset:0;
  pointer-events:none;
  overflow:hidden;
}

.success-particles span{
  position:absolute;
  left:50%;
  top:50%;
  width:7px;
  height:7px;
  border-radius:50%;
  background:#d9a642;
  box-shadow:0 0 12px rgba(217,166,66,.75);
  animation:goldParticle 2.4s ease-in-out infinite;
  opacity:.75;
}

.success-particles span:nth-child(1){--x:-210px;--y:-90px;animation-delay:0s}
.success-particles span:nth-child(2){--x:180px;--y:-120px;animation-delay:.25s}
.success-particles span:nth-child(3){--x:-120px;--y:110px;animation-delay:.5s}
.success-particles span:nth-child(4){--x:230px;--y:80px;animation-delay:.75s}
.success-particles span:nth-child(5){--x:-20px;--y:-150px;animation-delay:1s}
.success-particles span:nth-child(6){--x:60px;--y:150px;animation-delay:1.25s}

@keyframes goldParticle{
  0%{opacity:0; transform:translate(0,0) scale(.7)}
  25%{opacity:.9}
  100%{opacity:0; transform:translate(var(--x),var(--y)) scale(1.25)}
}

/* administrace */
.admin-stats{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:12px;
  margin:22px 0;
}

.admin-stats div{
  text-align:center;
  border:1px solid rgba(168,112,30,.28);
  border-radius:12px;
  padding:14px;
  background:rgba(255,250,241,.78);
}

.admin-stats strong{
  display:block;
  font-family:Cinzel,serif;
  color:#8d5e18;
  font-size:28px;
}

.admin-stats span{
  font-size:13px;
}

.admin-role-thumb{
  width:58px;
  height:42px;
  object-fit:cover;
  object-position:center 18%;
  border-radius:7px;
  border:1px solid rgba(168,112,30,.35);
}

.admin-release{
  padding:8px 12px;
  font-size:12px;
}

@media(max-width:760px){
  .selected-role-img-wrap{
    width:190px;
    height:120px;
  }
  .selected-role-kicker{
    font-size:15px;
  }
  .selected-role-copy .success-role{
    font-size:24px;
  }
  .admin-stats{
    grid-template-columns:repeat(2,1fr);
  }
  .admin-table{
    font-size:12px;
  }
}


/* Vizuální úprava podle posledního návrhu */
.selected-role-panel{
  padding:34px 38px;
}

.selected-role-inner{
  display:grid;
  grid-template-columns:320px 1fr;
  gap:42px;
  align-items:center;
  justify-content:center;
}

.selected-role-img-wrap{
  width:320px;
  height:230px;
  border-radius:18px;
  overflow:hidden;
  border:2px solid rgba(190,132,34,.65);
  box-shadow:0 14px 34px rgba(116,71,12,.16);
  background:#fff8ee;
}

.selected-role-img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center 18%;
  transform:scale(1.16);
  transform-origin:center 22%;
  display:block;
}

.selected-role-copy{
  max-width:680px;
  text-align:center;
}

.selected-role-kicker{
  font-size:22px;
  letter-spacing:.12em;
  margin-bottom:10px;
}

.selected-role-copy .success-role{
  font-size:38px;
  line-height:1.1;
  margin-bottom:16px;
}

.selected-role-copy p{
  font-size:18px;
  max-width:760px;
  margin-left:auto;
  margin-right:auto;
}

.selected-role-actions{
  margin-top:28px;
}

.selected-role-actions .btn{
  min-width:260px;
}

/* Seznam rolí – jednotné miniatury bez spodních textových štítků */
.role-card img{
  width:150px;
  height:96px;
  object-fit:cover;
  object-position:center 18%;
  transform:scale(1.16);
  transform-origin:center 20%;
  border-radius:8px;
}

/* Přehled božských rolí – kulaté fotky celé zaplněné, bez jmenných štítků */
.roster-item img{
  width:74px;
  height:74px;
  object-fit:cover;
  object-position:center 18%;
  transform:scale(1.22);
  transform-origin:center 20%;
  border-radius:50%;
  border:2px solid var(--gold);
  box-shadow:0 4px 14px rgba(116,71,12,.12);
}

/* Zabrání vizuálnímu vykukování mimo kruh u kulatých miniatur */
.roster-item{
  overflow:visible;
}

.roster-item img{
  clip-path:circle(50% at 50% 50%);
}

/* Admin náhled také sjednocený */
.admin-role-thumb{
  object-position:center 18%;
  transform:scale(1.12);
  transform-origin:center 20%;
  clip-path:inset(0 round 7px);
}

@media(max-width:900px){
  .selected-role-inner{
    grid-template-columns:1fr;
    gap:22px;
  }
  .selected-role-img-wrap{
    width:min(320px,100%);
    height:220px;
    margin:0 auto;
  }
}

@media(max-width:760px){
  .selected-role-panel{
    padding:24px 16px;
  }
  .selected-role-img-wrap{
    width:240px;
    height:170px;
  }
  .selected-role-kicker{
    font-size:15px;
  }
  .selected-role-copy .success-role{
    font-size:28px;
  }
  .selected-role-copy p{
    font-size:15px;
  }
  .selected-role-actions .btn{
    min-width:0;
    width:100%;
  }
}


/* Oprava spodního přehledu – skutečný ořez uvnitř kolečka */
.roster-thumb{
  width:74px;
  height:74px;
  display:block;
  margin:0 auto;
  border-radius:50%;
  overflow:hidden;
  border:2px solid var(--gold);
  box-shadow:0 4px 14px rgba(116,71,12,.12);
  background:#fff8ee;
}

.roster-thumb img{
  width:100%;
  height:132%;
  object-fit:cover;
  object-position:center 8%;
  display:block;
  border:0 !important;
  border-radius:0 !important;
  transform:none !important;
  clip-path:none !important;
  box-shadow:none !important;
}

.roster-item > img{
  display:none;
}

.roster-item.reserved .roster-thumb{
  filter:grayscale(.35);
  opacity:.62;
}

.roster-item.reserved{
  filter:none;
  opacity:1;
}

.lock{
  z-index:2;
}


/* Finální zarovnání obrázků v přehledu a rolovacím seznamu */

/* Spodní přehled božských rolí – větší výřez a posun motivu výš */
.roster-thumb{
  width:78px;
  height:78px;
}

.roster-thumb img{
  width:100%;
  height:140%;
  object-fit:cover;
  object-position:center 0%;
  display:block;
  border:0 !important;
  border-radius:0 !important;
  transform:none !important;
  clip-path:none !important;
  box-shadow:none !important;
}

/* Rolovací seznam bohů – náhledy vycentrované, bez prázdného spodního proužku */
.role-card img{
  width:150px;
  height:110px;
  object-fit:cover;
  object-position:center 10%;
  display:block;
  border-radius:8px;
  transform:none !important;
}

/* Na mobilu zachovat poměr a čistý výřez */
@media(max-width:760px){
  .role-card img{
    width:92px;
    height:92px;
    object-position:center 10%;
  }

  .roster-thumb{
    width:68px;
    height:68px;
  }
}


/* =========================================
   OPRAVA ROLOVACÍHO SEZNAMU – OŘEZ OBRÁZKŮ BEZ PŘETÉKÁNÍ
   ========================================= */

/* wrapper drží pevný rozměr v levém sloupci */
.role-thumb{
    width:150px !important;
    height:96px !important;
    display:block !important;
    overflow:hidden !important;
    border-radius:8px !important;
    border:1px solid rgba(173,116,26,.35) !important;
    background:#fff8ee !important;
}

/* obrázek se zvětší jen uvnitř wrapperu, takže nepřekryje text */
.role-thumb img{
    width:100% !important;
    height:132% !important;
    object-fit:cover !important;
    object-position:center 0% !important;
    transform:none !important;
    border:0 !important;
    border-radius:0 !important;
    display:block !important;
    box-shadow:none !important;
    clip-path:none !important;
}

/* staré přímé obrázky v role-card necháme schované, pokud by se někde objevily */
.role-card > img{
    display:none !important;
}

/* mobil */
@media(max-width:760px){
    .role-thumb{
        width:92px !important;
        height:82px !important;
    }

    .role-thumb img{
        height:132% !important;
        object-position:center 0% !important;
    }
}


/* =========================================
   OPRAVA IKONY BOHA NA POSLEDNÍ STRÁNCE
   ========================================= */

/* kruhový medailon zůstává stejný */
.success-role-visual{
    overflow:hidden !important;
}

/* obrázek se ořízne uvnitř kruhu tak, aby nebyl vidět spodní štítek se jménem */
.success-role-visual img{
    width:100% !important;
    height:135% !important;
    object-fit:cover !important;
    object-position:center top !important;
    transform:none !important;
    border-radius:50% !important;
    display:block !important;
}


/* =========================================
   MOBILNÍ OPRAVA VIEWPORTU
   ========================================= */

html {
  min-height: 100%;
  min-height: -webkit-fill-available;
}

body {
  min-height: 100%;
  margin: 0;
  overflow-x: hidden;
}

#app {
  min-height: 100vh;
  min-height: 100svh;
}

.hero,
.screen {
  min-height: 100vh;
  min-height: 100svh;
  min-height: 100dvh;
  height: auto;
}

.hero {
  align-items: center;
  justify-content: center;
  padding: max(16px, env(safe-area-inset-top)) 14px max(16px, env(safe-area-inset-bottom));
}

.panel {
  width: min(92vw, 520px);
  max-height: none;
}

@media (max-width: 760px) {
  .hero {
    min-height: 100vh;
    min-height: 100svh;
    min-height: 100dvh;
    align-items: center !important;
    justify-content: center;
    padding: max(14px, env(safe-area-inset-top)) 12px max(14px, env(safe-area-inset-bottom));
  }

  .screen {
    min-height: 100vh;
    min-height: 100svh;
    min-height: 100dvh;
    padding: 16px 10px;
  }

  .panel {
    padding: 24px 18px;
    border-radius: 16px;
  }

  h1 {
    font-size: 28px;
    line-height: 1.12;
  }

  h2 {
    font-size: 24px;
    line-height: 1.18;
  }

  .temple {
    font-size: 30px;
  }

  .date {
    font-size: 16px;
  }
}
