.party-page{max-width:960px;margin:0 auto;padding:24px 16px 64px}.party-page:has(.party-shell:not([hidden])){max-width:1400px}.party-card{background:var(--bg-card);border:1px solid var(--border-dim);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow)}.party-card--guide{display:grid;grid-template-columns:auto 1fr;gap:1rem;align-items:center;margin-bottom:18px;text-decoration:none;background:radial-gradient(ellipse at left top,rgba(201,162,39,0.16),transparent 70%),var(--bg-card);border:1px solid var(--gold);transition:transform 0.15s ease,box-shadow 0.15s ease}.party-card--guide:hover{transform:translateY(-1px);box-shadow:0 12px 32px rgba(0,0,0,0.5),0 0 18px rgba(232,196,74,0.2);text-decoration:none}.party-card__guide-icon{flex:0 0 auto;width:64px;height:64px;display:inline-flex;align-items:center;justify-content:center;background:rgba(201,162,39,0.18);border:1px solid var(--gold);border-radius:50%;font-size:1.8rem;color:var(--gold-light)}.party-card__guide-body .party-title{margin:0;font-size:1.25rem}.party-card__guide-body .party-sub{margin:0.35rem 0 0.4rem;display:block}.party-card__guide-cta{display:inline-block;font-family:'Cinzel',serif;font-size:0.85rem;color:var(--gold);letter-spacing:0.04em}.party-card--guide:hover .party-card__guide-cta{color:var(--gold-light)}@media (max-width:600px){.party-card--guide{grid-template-columns:1fr;text-align:center}.party-card__guide-icon{margin:0 auto}}.party-title{font-family:'Cinzel',serif;font-weight:700;font-size:1.8rem;color:var(--gold);margin-bottom:8px}.party-sub{color:var(--text-muted);margin-bottom:24px;display:flex;align-items:center;gap:12px;flex-wrap:wrap}.party-help{margin-top:20px;color:var(--text-dim);font-size:0.95rem}.party-code{font-family:'Cinzel',serif;font-size:1.2rem;letter-spacing:0.08em;color:var(--gold-light);background:var(--bg-deep);padding:4px 12px;border:1px solid var(--border-dim);border-radius:var(--radius);user-select:all}.party-form{display:flex;flex-direction:column;gap:18px}.party-field{display:flex;flex-direction:column;gap:6px}.party-field__label{color:var(--text-muted);font-weight:600;font-size:0.95rem}.party-form input[type="text"]{background:var(--bg-deep);border:1px solid var(--border-dim);border-radius:var(--radius);color:var(--text);padding:10px 12px;font-family:inherit;font-size:1rem}.party-form input[type="text"]:focus{outline:none;border-color:var(--gold)}.party-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;background:var(--bg-card2);border:1px solid var(--border-dim);color:var(--text);padding:10px 16px;font-family:'Cinzel',serif;font-size:0.95rem;font-weight:600;border-radius:var(--radius);cursor:pointer;transition:var(--transition)}.party-btn:hover{border-color:var(--gold);color:var(--gold-light)}.party-btn:disabled{opacity:0.5;cursor:not-allowed}.party-btn--primary{background:var(--gold);border-color:var(--gold);color:var(--text-dark)}.party-btn--primary:hover{background:var(--gold-light);border-color:var(--gold-light);color:var(--text-dark)}.party-btn--ghost{background:transparent}.party-btn--mini{padding:4px 10px;font-size:0.85rem}.party-btn--danger{border-color:var(--red-bright);color:var(--red-bright)}.party-btn--danger:hover{background:var(--red);border-color:var(--red-bright);color:var(--text)}.party-char{background:var(--bg-deep);border:1px dashed var(--border-dim);border-radius:var(--radius);padding:10px 12px;color:var(--text);font-size:0.95rem}.party-char__none{color:var(--text-dim);font-style:italic}.party-char__name{font-weight:600;color:var(--gold-light)}.party-char__meta{color:var(--text-muted);font-size:0.9rem}.party-upload{display:inline-block;margin-top:8px}.party-err{color:var(--red-bright);background:rgba(192,57,43,0.08);border:1px solid var(--red-bright);padding:8px 12px;border-radius:var(--radius);font-size:0.95rem}.party-banner{background:var(--bg-card2);border:1px solid var(--border-dim);border-left-width:4px;border-left-color:var(--gold);padding:12px 16px;border-radius:var(--radius);margin-bottom:16px;color:var(--text)}.party-banner--err{border-left-color:var(--red-bright)}.party-banner--ok{border-left-color:var(--green-bright)}.party-banner--warn{border-left-color:var(--gold-light)}.lobby-header{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:12px;margin-bottom:24px}.lobby-header__actions{display:flex;gap:8px}.lobby-h2,.lobby-h3{font-family:'Cinzel',serif;color:var(--gold);margin-bottom:12px}.lobby-h2{font-size:1.2rem}.lobby-h3{font-size:1rem}.lobby-count{color:var(--text-dim);font-weight:400;font-size:0.9rem;margin-left:6px}.lobby-grid{display:grid;grid-template-columns:1fr 280px;gap:24px}@media (max-width:700px){.lobby-grid{grid-template-columns:1fr}}.lobby-section{background:var(--bg-deep);border:1px solid var(--border-dim);border-radius:var(--radius);padding:14px;margin-bottom:14px}.lobby-action{width:100%}.lobby-hint{color:var(--text-dim);font-size:0.85rem;margin-top:8px;font-style:italic}.member-list{list-style:none;padding:0;margin:0}.member-row{display:flex;align-items:center;gap:10px;padding:12px;background:var(--bg-deep);border:1px solid var(--border-dim);border-radius:var(--radius);margin-bottom:8px}.member-row--me{border-color:var(--gold)}.member-row--offline{opacity:0.55}.member-dot{width:8px;height:8px;border-radius:50%;background:var(--green-bright);box-shadow:0 0 6px var(--green-bright);flex-shrink:0}.member-row--offline .member-dot{background:var(--text-dim);box-shadow:none}.member-name{flex:1;display:flex;flex-direction:column}.member-name__nick{font-weight:600;color:var(--text)}.member-name__role{font-size:0.8rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:0.05em}.member-row--dm .member-name__role{color:var(--gold-light)}.member-actions{display:flex;gap:6px;flex-wrap:wrap}.vote-progress{display:flex;justify-content:space-between;font-size:0.9rem;color:var(--text-muted);margin-bottom:8px}.vote-bar{height:8px;background:var(--bg-card2);border-radius:4px;overflow:hidden;margin-bottom:12px}.vote-bar__fill{height:100%;background:var(--gold);transition:width 0.3s ease}.vote-timer{text-align:center;font-family:'Cinzel',serif;color:var(--gold-light);margin-bottom:12px}.vote-actions{display:flex;gap:8px}.vote-actions .party-btn{flex:1}.lobby-h2--spaced{margin-top:28px}.card-list{display:grid;grid-template-columns:1fr;gap:12px}@media (min-width:900px){.card-list{grid-template-columns:1fr 1fr}}.cs-mp-card{background:var(--bg-deep);border:1px solid var(--border-dim);border-radius:var(--radius);padding:12px;display:flex;flex-direction:column;gap:10px;transition:var(--transition)}.cs-mp-card--mine{border-color:var(--gold)}.cs-mp-card--locked{border-style:dashed}.cs-mp-card--empty{opacity:0.65}.cs-mp-card__head{display:flex;align-items:center;gap:10px}.cs-mp-card__portrait{width:44px;height:44px;flex-shrink:0;border-radius:50%;background:var(--bg-card2) center/cover no-repeat;border:1px solid var(--border-dim);font-size:1.2rem;display:flex;align-items:center;justify-content:center;color:var(--text-dim)}.cs-mp-card__title{flex:1;display:flex;flex-direction:column}.cs-mp-card__name{font-weight:600;color:var(--text);display:flex;align-items:center;gap:8px;flex-wrap:wrap}.cs-mp-card__role{font-size:0.78rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:0.05em}.cs-mp-card__role--dm{color:var(--gold-light)}.cs-mp-card__lock{font-size:0.85rem;color:var(--gold-light)}.cs-mp-card__expand{background:none;border:1px solid var(--border-dim);color:var(--text-muted);border-radius:var(--radius);width:28px;height:28px;cursor:pointer;font-size:1rem;flex-shrink:0}.cs-mp-card__expand:hover{color:var(--gold);border-color:var(--gold)}.cs-mp-card__meta{font-size:0.85rem;color:var(--text-muted)}.cs-mp-card__stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(95px,1fr));gap:8px}.cs-mp-stat{background:var(--bg-card2);border:1px solid var(--border-dim);border-radius:var(--radius);padding:6px 8px;text-align:center;display:flex;flex-direction:column;gap:2px}.cs-mp-stat__label{font-size:0.7rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:0.05em}.cs-mp-stat__value-row{display:flex;align-items:center;justify-content:center;gap:4px}.cs-mp-stat__value{font-family:'Cinzel',serif;color:var(--gold-light);font-size:1.1rem;min-width:24px;text-align:center;user-select:text}.cs-mp-stat__btn{background:var(--bg-deep);border:1px solid var(--border-dim);color:var(--text);width:22px;height:22px;border-radius:4px;cursor:pointer;font-weight:700;line-height:1;padding:0}.cs-mp-stat__btn:hover:not(:disabled){border-color:var(--gold);color:var(--gold-light)}.cs-mp-stat__btn:disabled{opacity:0.3;cursor:not-allowed}.cs-mp-card__details{display:none}.cs-mp-card--open .cs-mp-card__details{display:block}.cs-mp-detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:6px;margin-top:8px}.cs-mp-detail{background:var(--bg-card2);border:1px solid var(--border-dim);border-radius:var(--radius);padding:6px 8px;font-size:0.85rem}.cs-mp-detail__label{display:block;color:var(--text-dim);font-size:0.7rem;text-transform:uppercase;letter-spacing:0.04em;margin-bottom:2px}.cs-mp-detail__value{color:var(--text)}.cs-mp-card__footer{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px;padding-top:8px;border-top:1px solid var(--border-dim);font-size:0.85rem}.cs-mp-card__lock-toggle{display:inline-flex;align-items:center;gap:6px;cursor:pointer;user-select:none;color:var(--text-muted)}.cs-mp-card__lock-toggle input{cursor:pointer}.cs-mp-card__lock-toggle--active{color:var(--gold-light)}.cs-mp-card__open-link{color:var(--text-muted);text-decoration:none;font-size:0.85rem}.cs-mp-card__open-link:hover{color:var(--gold)}.cs-mp-card__hint{color:var(--text-dim);font-style:italic;font-size:0.85rem}.cs-mp-hpbar{height:4px;background:var(--bg-card2);border-radius:2px;overflow:hidden;margin-top:4px}.cs-mp-hpbar__fill{height:100%;background:var(--green-bright);transition:width 0.2s ease}.cs-mp-hpbar__fill--mid{background:var(--gold)}.cs-mp-hpbar__fill--low{background:var(--red-bright)}.combat-wrap{margin-top:24px;background:var(--bg-deep);border:1px solid var(--border-dim);border-radius:var(--radius-lg);padding:16px}.combat-header{display:flex;align-items:center;flex-wrap:wrap;gap:10px;margin-bottom:14px}.combat-header h2{flex:1 1 auto;margin:0}.combat-status-badge{display:inline-block;font-family:'Crimson Text',Georgia,serif;font-size:0.75rem;font-weight:600;text-transform:uppercase;padding:2px 8px;border-radius:10px;letter-spacing:0.05em;margin-left:8px;vertical-align:middle;border:1px solid var(--border-dim)}.combat-status-badge--active{background:rgba(39,174,96,0.15);color:var(--green-bright);border-color:var(--green-bright)}.combat-status-badge--paused{background:rgba(201,162,39,0.15);color:var(--gold-light);border-color:var(--gold-light)}.combat-status-badge--idle{color:var(--text-dim)}.combat-round{font-family:'Cinzel',serif;color:var(--gold-light);font-size:0.95rem}.combat-lifecycle{display:flex;gap:6px;flex-wrap:wrap}.combat-initiative{display:flex;gap:6px;overflow-x:auto;padding:8px;background:var(--bg-card);border:1px solid var(--border-dim);border-radius:var(--radius);margin-bottom:12px;scroll-snap-type:x proximity}.combat-initiative:empty::before{content:"Žádná iniciativa. DM klikne 'Iniciativa náhodně' nebo seřadí ručně.";color:var(--text-dim);font-style:italic;font-size:0.85rem;padding:4px}.init-chip{flex:0 0 auto;padding:6px 10px;border-radius:var(--radius);background:var(--bg-card2);border:1px solid var(--border-dim);font-size:0.85rem;display:flex;align-items:center;gap:6px;scroll-snap-align:start;user-select:none}.init-chip--current{border-color:var(--gold);background:rgba(201,162,39,0.18);box-shadow:0 0 6px rgba(201,162,39,0.3)}.init-chip--enemy{color:var(--red-bright)}.init-chip--dead{opacity:0.4;text-decoration:line-through}.init-chip__value{font-family:'Cinzel',serif;color:var(--gold);font-weight:700}.init-chip[draggable="true"]{cursor:grab}.init-chip.dragging{opacity:0.4}.combat-lines{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}@media (max-width:700px){.combat-lines{grid-template-columns:1fr}}.combat-line{background:var(--bg-card);border:1px solid var(--border-dim);border-radius:var(--radius);padding:10px;min-height:120px}.combat-line--drop-hover{border-color:var(--gold);background:rgba(201,162,39,0.08)}.combat-line__title{font-family:'Cinzel',serif;color:var(--gold);font-size:1rem;margin-bottom:8px}.combat-line__list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}.combat-figure{display:flex;align-items:center;gap:8px;padding:8px 10px;background:var(--bg-card2);border:1px solid var(--border-dim);border-radius:var(--radius);position:relative}.combat-figure--mine{border-color:var(--gold)}.combat-figure--enemy{background:rgba(139,26,26,0.15);border-color:var(--red)}.combat-figure--dead{opacity:0.45}.combat-figure--dead::after{content:"💀 MRTVÝ";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) rotate(-12deg);font-family:'Cinzel',serif;font-weight:700;color:var(--red-bright);background:rgba(0,0,0,0.6);padding:2px 8px;border-radius:var(--radius);font-size:0.85rem;pointer-events:none}.combat-figure__name{flex:1;font-weight:600;color:var(--text)}.combat-figure__hp{font-family:'Cinzel',serif;color:var(--gold-light);font-size:0.9rem}.combat-figure__actions{display:flex;gap:4px}.combat-figure__btn{background:var(--bg-deep);border:1px solid var(--border-dim);color:var(--text);padding:2px 6px;border-radius:4px;cursor:pointer;font-size:0.85rem;line-height:1}.combat-figure__btn:hover:not(:disabled){border-color:var(--gold);color:var(--gold-light)}.combat-figure__btn:disabled{opacity:0.4;cursor:not-allowed}.combat-modules{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:12px}.combat-module{background:var(--bg-card);border:1px solid var(--border-dim);border-radius:var(--radius);padding:0}.combat-module>summary{cursor:pointer;padding:10px 12px;font-family:'Cinzel',serif;color:var(--gold);font-size:0.95rem;user-select:none;list-style:none}.combat-module>summary::-webkit-details-marker{display:none}.combat-module>summary::before{content:"▸ ";transition:transform 0.15s ease;display:inline-block}.combat-module[open]>summary::before{content:"▾ "}.combat-module>*:not(summary){padding:0 12px 12px}.combat-count{display:inline-block;font-family:'Crimson Text',Georgia,serif;font-size:0.75rem;background:var(--bg-deep);border:1px solid var(--border-dim);border-radius:10px;padding:1px 7px;color:var(--text-muted);margin-left:6px;vertical-align:middle}.combat-input{background:var(--bg-deep);border:1px solid var(--border-dim);color:var(--text);padding:6px 10px;border-radius:var(--radius);font-family:inherit;font-size:0.95rem;width:100%}.combat-input:focus{outline:none;border-color:var(--gold)}.combat-input--narrow{width:90px;flex:0 0 auto}.combat-action-form{display:flex;flex-direction:column;gap:8px}.combat-action-row{display:flex;gap:6px}.combat-action-row>*{flex:1}.combat-dice-form{display:flex;flex-direction:column;gap:8px}.combat-dice-row{display:flex;gap:6px}.combat-dice-row>.party-btn{flex:1}.combat-dice-feed{list-style:none;margin:8px 0 0;padding:0;max-height:160px;overflow-y:auto;display:flex;flex-direction:column-reverse;gap:4px}.combat-dice-feed li{font-size:0.85rem;color:var(--text);padding:4px 8px;background:var(--bg-deep);border:1px solid var(--border-dim);border-radius:var(--radius)}.combat-dice-feed li.is-manual{border-style:dashed;opacity:0.85}.combat-dice-feed .dice-by{color:var(--text-muted)}.combat-dice-feed .dice-formula{color:var(--text-dim);font-family:'Cinzel',serif}.combat-dice-feed .dice-total{color:var(--gold-light);font-family:'Cinzel',serif;font-weight:700;margin-left:4px}.combat-queue{display:flex;flex-direction:column;gap:6px}.combat-queue:empty::before{content:"Žádné navrhované akce.";color:var(--text-dim);font-style:italic;font-size:0.85rem}.combat-action-card{background:var(--bg-deep);border:1px solid var(--border-dim);border-radius:var(--radius);padding:8px;font-size:0.9rem;display:flex;flex-direction:column;gap:6px}.combat-action-card__head{display:flex;gap:6px;flex-wrap:wrap;align-items:baseline}.combat-action-card__by{color:var(--text-muted)}.combat-action-card__name{color:var(--gold-light);font-weight:600}.combat-action-card__target{color:var(--text-dim)}.combat-action-card__note{color:var(--text-dim);font-style:italic;font-size:0.85rem}.combat-action-card__row{display:flex;gap:6px;align-items:center;flex-wrap:wrap}.combat-enemy-list{display:flex;flex-direction:column;gap:6px;margin-bottom:8px}.combat-enemy-list:empty::before{content:"Žádní nepřátelé.";color:var(--text-dim);font-style:italic;font-size:0.85rem}.combat-enemy-row{display:flex;gap:6px;margin-bottom:6px}.lobby-log{margin-top:16px;background:var(--bg-deep);border:1px solid var(--border-dim);border-radius:var(--radius-lg);padding:0}.lobby-log>summary{cursor:pointer;padding:12px 16px;font-family:'Cinzel',serif;color:var(--gold);font-size:1.1rem;user-select:none;list-style:none}.lobby-log>summary::-webkit-details-marker{display:none}.lobby-log>summary::before{content:"▸ "}.lobby-log[open]>summary::before{content:"▾ "}.log-feed{margin:0 16px;max-height:280px;overflow-y:auto;display:flex;flex-direction:column;gap:4px;padding:8px 0;border-top:1px solid var(--border-dim)}.log-feed:empty::before{content:"Zatím žádné zprávy.";color:var(--text-dim);font-style:italic;font-size:0.9rem;padding:8px 0}.log-entry{font-size:0.9rem;padding:4px 8px;border-radius:4px;background:var(--bg-card);display:flex;gap:8px;align-items:baseline}.log-entry__time{color:var(--text-dim);font-size:0.75rem;flex-shrink:0;min-width:48px}.log-entry__by{color:var(--gold-light);font-weight:600;flex-shrink:0}.log-entry__text{color:var(--text);flex:1}.log-entry--chat .log-entry__text{color:var(--text)}.log-entry--system .log-entry__text{color:var(--text-muted);font-style:italic}.log-entry--dice .log-entry__text{color:var(--text-muted)}.log-entry--dice .log-entry-total{color:var(--gold-light);font-family:'Cinzel',serif;font-weight:700}.log-entry--combat .log-entry__text{color:var(--gold-light);font-weight:600}.chat-form{display:flex;gap:8px;padding:8px 16px 16px}.chat-input{flex:1;background:var(--bg-deep);border:1px solid var(--border-dim);color:var(--text);padding:8px 12px;border-radius:var(--radius);font-family:inherit;font-size:0.95rem}.chat-input:focus{outline:none;border-color:var(--gold)}@media (max-width:700px){.party-page{padding:16px 10px 48px}.party-card{padding:16px;border-radius:var(--radius)}.party-title{font-size:1.4rem}.lobby-header{flex-direction:column;align-items:stretch}.lobby-header__actions{justify-content:flex-end}.party-btn{padding:12px 16px;min-height:44px}.party-btn--mini{padding:8px 12px;min-height:36px;font-size:0.9rem}.lobby-action{width:100%}.member-row{flex-wrap:wrap}.member-actions{width:100%;justify-content:flex-end;gap:8px}.member-actions .party-btn{flex:1;min-width:0}.cs-mp-card__stats{grid-template-columns:1fr 1fr}.cs-mp-stat__btn{width:32px;height:32px;font-size:1.05rem}.cs-mp-card__footer{flex-direction:column;align-items:stretch}.cs-mp-card__footer .party-btn{width:100%}.combat-figure{flex-wrap:wrap}.combat-figure__name{flex-basis:100%;order:1}.combat-figure__hp{flex-basis:100%;order:2}.combat-figure__actions{width:100%;order:3;gap:6px}.combat-figure__btn{padding:8px 10px;min-height:36px;min-width:36px;font-size:0.95rem}.combat-modules{grid-template-columns:1fr}.init-chip{padding:10px 12px;font-size:0.95rem}.combat-lifecycle{width:100%}.combat-lifecycle .party-btn{flex:1 1 calc(50% - 6px);min-width:0}.combat-action-row{flex-direction:column}.combat-enemy-row{flex-direction:column}.combat-input--narrow{width:100%}.log-feed{max-height:220px}.lobby-log>summary{font-size:1rem;padding:14px 14px;min-height:44px}.chat-form{padding:8px 14px 14px}.chat-input{padding:12px;min-height:44px}.chat-form .party-btn{min-width:56px}}@media (max-width:380px){.cs-mp-card__stats{grid-template-columns:1fr}}.howl-toast-root{position:fixed;bottom:16px;right:16px;z-index:9999;display:flex;flex-direction:column;gap:8px;max-width:calc(100vw - 32px);pointer-events:none}.howl-toast{pointer-events:auto;background:var(--bg-card2);border:1px solid var(--border-dim);border-left-width:4px;border-left-color:var(--gold);color:var(--text);padding:12px 14px;border-radius:var(--radius);box-shadow:0 6px 24px rgba(0,0,0,0.5);display:flex;align-items:center;gap:12px;min-width:240px;max-width:380px;font-size:0.95rem;opacity:0;transform:translateY(8px);transition:opacity 0.2s ease,transform 0.2s ease}.howl-toast--show{opacity:1;transform:translateY(0)}.howl-toast--ok{border-left-color:var(--green-bright)}.howl-toast--warn{border-left-color:var(--gold-light)}.howl-toast--err{border-left-color:var(--red-bright)}.howl-toast__msg{flex:1}.howl-toast__close{background:none;border:none;color:var(--text-dim);cursor:pointer;font-size:1.2rem;line-height:1;padding:0 4px;min-width:28px;min-height:28px}.howl-toast__close:hover{color:var(--gold-light)}@media (max-width:700px){.howl-toast-root{left:16px;right:16px;bottom:12px}.howl-toast{max-width:none}}.howl-spinner{display:inline-block;width:14px;height:14px;border:2px solid var(--text-dim);border-top-color:var(--gold);border-radius:50%;animation:howlSpin 0.8s linear infinite;vertical-align:middle;margin-left:6px}@keyframes howlSpin{to{transform:rotate(360deg)}}.sound-toggle{display:flex;align-items:center;gap:8px;margin-top:8px;font-size:0.9rem;color:var(--text-muted);cursor:pointer;user-select:none}.sound-toggle input{cursor:pointer}.party-shell{display:flex;flex-direction:column;gap:16px;background:var(--bg-card);border:1px solid var(--border-dim);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:16px 16px 24px}.party-shell__header{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;padding-bottom:12px;border-bottom:1px solid var(--border-dim)}.party-shell__brand{display:flex;flex-direction:column;gap:4px}.party-shell__title{font-family:'Cinzel',serif;font-weight:700;font-size:1.6rem;color:var(--gold);margin:0}.party-shell__sub{display:flex;align-items:center;gap:10px;flex-wrap:wrap;color:var(--text-muted);margin:0}.party-shell__actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.party-shell__actions .sound-toggle{margin-top:0}.party-tabs{display:flex;align-items:stretch;gap:4px;padding:4px;background:var(--bg-deep);border:1px solid var(--border-dim);border-radius:var(--radius-lg);position:sticky;top:8px;z-index:30}.party-tabs__list{display:flex;flex:1 1 auto;gap:4px;overflow-x:auto;scrollbar-width:thin;scroll-behavior:smooth}.party-tabs__list::-webkit-scrollbar{height:4px}.party-tabs__list::-webkit-scrollbar-thumb{background:var(--border-dim);border-radius:2px}.party-tab{position:relative;display:inline-flex;align-items:center;gap:8px;background:transparent;border:1px solid transparent;color:var(--text-muted);font-family:inherit;font-size:0.95rem;font-weight:600;padding:8px 14px;border-radius:var(--radius);cursor:pointer;white-space:nowrap;transition:background 0.15s ease,color 0.15s ease,border-color 0.15s ease}.party-tab:hover{color:var(--text);background:rgba(201,162,39,0.08);border-color:var(--border-dim)}.party-tab[aria-selected="true"]{color:var(--gold-light);background:rgba(201,162,39,0.16);border-color:var(--gold);box-shadow:0 1px 0 rgba(201,162,39,0.25) inset}.party-tab__icon{font-size:1.05rem}.party-tab__label{letter-spacing:0.01em}.party-tab__badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 6px;font-size:0.72rem;font-weight:700;color:var(--bg-deep);background:var(--gold-light);border-radius:999px;margin-left:2px}.party-tab__badge[hidden]{display:none}.party-tab__badge--alert{background:var(--red-bright,#d23a3a);color:#fff}.party-tabs__arrow{flex:0 0 auto;background:transparent;border:1px solid var(--border-dim);color:var(--text-muted);font-size:1.4rem;font-weight:700;line-height:1;width:36px;border-radius:var(--radius);cursor:pointer;transition:background 0.15s ease,color 0.15s ease,border-color 0.15s ease}.party-tabs__arrow:hover{color:var(--gold);border-color:var(--gold);background:rgba(201,162,39,0.08)}.party-tabs__arrow:disabled{opacity:0.35;cursor:not-allowed}.party-panels{position:relative;min-height:480px}.party-panel{animation:partyTabFade 0.18s ease}.party-panel[hidden]{display:none!important}@keyframes partyTabFade{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.party-panel--frame{display:flex;flex-direction:column}.party-frame{width:100%;height:calc(100vh - 220px);min-height:600px;border:1px solid var(--border-dim);border-radius:var(--radius);background:var(--bg-deep)}.party-panel--chat .chat-tab{display:flex;flex-direction:column;gap:12px;height:calc(100vh - 220px);min-height:360px}.chat-tab__title{margin:0;flex:0 0 auto}.log-feed--full{flex:1 1 auto;min-height:0;max-height:none;overflow-y:auto}.party-panel--chat .chat-form{flex:0 0 auto}.char-tab__header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap;padding-bottom:12px;margin-bottom:14px;border-bottom:1px solid var(--border-dim)}.char-tab__title-wrap{display:flex;flex-direction:column;gap:4px}.char-tab__title{font-family:'Cinzel',serif;color:var(--gold);font-size:1.4rem;margin:0}.char-tab__sub{margin:0;color:var(--text-muted);font-size:0.9rem}.char-tab__switcher{display:flex;gap:6px;flex-wrap:wrap}.char-pill{background:transparent;border:1px solid var(--border-dim);color:var(--text-muted);border-radius:999px;padding:4px 12px;font-size:0.85rem;cursor:pointer;transition:all 0.15s ease;display:inline-flex;align-items:center;gap:6px}.char-pill:hover{color:var(--gold-light);border-color:var(--gold)}.char-pill[aria-selected="true"]{background:rgba(201,162,39,0.18);color:var(--gold-light);border-color:var(--gold)}.char-pill__dot{width:6px;height:6px;border-radius:50%;background:var(--text-dim)}.char-pill[data-online="1"] .char-pill__dot{background:var(--green-bright,#4caf50)}.char-pill[data-role="dm"]{border-color:var(--gold);color:var(--gold-light)}.char-tab__empty{text-align:center;padding:60px 20px;color:var(--text-dim);font-style:italic}.char-detail{display:grid;grid-template-columns:minmax(260px,320px) 1fr;gap:20px}@media (max-width:900px){.char-detail{grid-template-columns:1fr}}.char-detail__sidebar{display:flex;flex-direction:column;gap:16px}.char-detail__main{display:flex;flex-direction:column;gap:16px}.char-id{background:var(--bg-deep);border:1px solid var(--border-dim);border-radius:var(--radius);padding:16px;display:flex;flex-direction:column;align-items:center;gap:10px;text-align:center}.char-id__portrait{width:144px;height:144px;border-radius:50%;background:var(--bg-card) center/cover no-repeat;border:2px solid var(--gold);display:flex;align-items:center;justify-content:center;font-size:2.2rem;color:var(--text-dim)}.char-id__name{font-family:'Cinzel',serif;font-size:1.3rem;color:var(--gold);margin:0}.char-id__meta{color:var(--text-muted);font-size:0.92rem;display:flex;align-items:center;flex-wrap:wrap;justify-content:center;gap:4px}.char-id__badge{color:var(--gold-light);text-decoration:none}.char-id__badge:hover{color:var(--gold);text-decoration:underline}.char-id__role{display:inline-block;font-size:0.78rem;color:var(--text-dim);border:1px solid var(--border-dim);border-radius:999px;padding:2px 10px;letter-spacing:0.04em}.char-vitals{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.char-vital{background:var(--bg-deep);border:1px solid var(--border-dim);border-radius:var(--radius);padding:10px 12px;display:flex;flex-direction:column;gap:4px}.char-vital__label{font-size:0.78rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.05em}.char-vital__row{display:flex;align-items:center;gap:6px}.char-vital__btn{background:transparent;border:1px solid var(--border-dim);color:var(--text);width:26px;height:26px;border-radius:4px;cursor:pointer;font-weight:700;line-height:1}.char-vital__btn:hover:not(:disabled){background:rgba(201,162,39,0.15);color:var(--gold);border-color:var(--gold)}.char-vital__btn:disabled{opacity:0.4;cursor:not-allowed}.char-vital__value{flex:1 1 auto;text-align:center;font-size:1.25rem;font-weight:700;color:var(--gold-light)}.char-vital__value-edit{flex:1 1 auto;background:transparent;border:1px dashed var(--border-dim);color:var(--gold-light);font-size:1.05rem;font-weight:700;text-align:center;border-radius:4px;padding:2px 4px;width:100%}.char-vital__bar{height:5px;background:rgba(255,255,255,0.06);border-radius:999px;overflow:hidden}.char-vital__bar-fill{height:100%;background:var(--green-bright,#4caf50);transition:width 0.2s ease}.char-vital__bar-fill--mid{background:var(--gold)}.char-vital__bar-fill--low{background:var(--red-bright,#d23a3a)}.char-block{background:var(--bg-deep);border:1px solid var(--border-dim);border-radius:var(--radius);padding:14px 16px}.char-block__title{font-family:'Cinzel',serif;color:var(--gold);font-size:1.05rem;margin:0 0 10px;display:flex;align-items:center;gap:8px}.char-block__title-icon{font-size:1.1rem}.char-rowlist{display:flex;flex-direction:column;gap:4px}.char-row{display:grid;grid-template-columns:1fr auto auto;align-items:center;gap:8px;padding:4px 6px;border-radius:4px}.char-row:hover{background:rgba(255,255,255,0.03)}.char-row__label{color:var(--text);font-size:0.92rem}.char-row__value{color:var(--gold-light);font-weight:700;min-width:28px;text-align:right}.char-row__bonus{display:inline-flex;align-items:center;gap:4px;font-size:0.85rem}.char-row__bonus-val{min-width:22px;text-align:center;color:var(--text-muted)}.char-row__btn{background:transparent;border:1px solid var(--border-dim);color:var(--text);width:22px;height:22px;border-radius:3px;cursor:pointer;font-weight:700;line-height:1;font-size:0.85rem}.char-row__btn:hover:not(:disabled){color:var(--gold);border-color:var(--gold)}.char-row__btn:disabled{opacity:0.35;cursor:not-allowed}.char-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:8px}.char-card-mini{background:var(--bg-card);border:1px solid var(--border-dim);border-radius:var(--radius);padding:10px 12px;display:flex;flex-direction:column;gap:4px}.char-card-mini__name{color:var(--gold-light);font-weight:600;font-size:0.95rem}.char-card-mini__meta{color:var(--text-muted);font-size:0.82rem}.char-card-mini__desc{color:var(--text-dim);font-size:0.82rem;line-height:1.4;max-height:4.4em;overflow:hidden}.char-block__empty{color:var(--text-dim);font-style:italic;font-size:0.9rem;padding:6px 0}.char-detail__perm{font-size:0.82rem;color:var(--text-dim);padding:4px 8px;background:rgba(255,255,255,0.03);border-radius:4px}.char-detail__perm--editable{color:var(--gold-light);background:rgba(201,162,39,0.08)}.cs-mp-card{cursor:pointer}.cs-mp-card__head{position:relative}.cs-mp-card__open-hint{position:absolute;top:8px;right:8px;font-size:0.72rem;color:var(--text-dim);letter-spacing:0.04em;text-transform:uppercase;opacity:0;transition:opacity 0.15s ease;pointer-events:none}.cs-mp-card:hover .cs-mp-card__open-hint{opacity:1}.lobby-hint--inline{font-weight:400;font-style:italic;font-size:0.85rem;color:var(--text-dim);display:inline;margin-left:6px}.member-row{cursor:pointer}.member-row:hover{background:rgba(201,162,39,0.06)}@media (max-width:700px){.party-tab__label{display:none}.party-tab{padding:8px 10px}.party-shell{padding:12px 8px 16px}.party-frame{height:calc(100vh - 280px);min-height:480px}}.combat-race-icon{width:22px;height:22px;object-fit:contain;vertical-align:-5px;margin-right:6px;filter:drop-shadow(0 1px 2px rgba(0,0,0,0.6))}
.combat-race-icon--lg{width:36px;height:36px;vertical-align:-10px;margin-right:8px}
.combat-bestiary-preview{display:flex;align-items:center;gap:6px;margin-top:6px;padding:6px 8px;background:rgba(201,162,39,0.06);border:1px solid rgba(201,162,39,0.25);border-radius:6px;color:var(--gold-light);font-size:0.85rem}
.combat-bestiary-preview:empty{display:none}
.char-tab__switcher{gap:10px;align-items:center}.char-pill{min-height:34px;padding:7px 14px;font-size:1rem;font-weight:700;border-width:2px;background:rgba(0,0,0,0.16);box-shadow:0 0 0 1px rgba(201,162,39,0.08) inset}.char-pill:hover{background:rgba(201,162,39,0.1)}.char-pill[aria-selected="true"]{background:rgba(201,162,39,0.24);box-shadow:0 0 0 2px rgba(201,162,39,0.18),0 8px 18px rgba(0,0,0,0.24)}.char-pill__dot{width:9px;height:9px}.combat-battlefield{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}.combat-side{background:rgba(0,0,0,0.12);border:1px solid var(--border-dim);border-radius:var(--radius);padding:10px}.combat-side__title{font-family:'Cinzel',serif;color:var(--gold-light);font-size:1.05rem;margin:0 0 10px}.combat-side__lines{display:grid;grid-template-columns:1fr 1fr;gap:10px}.combat-line--front{border-color:rgba(201,162,39,0.52)}.combat-line--back{border-style:dashed}.combat-line__list:empty::before{content:"Prázdno";display:block;color:var(--text-dim);font-style:italic;font-size:0.88rem;padding:8px 2px}.combat-start-cta{background:var(--gold)!important;border-color:var(--gold-light)!important;color:var(--text-dark)!important;box-shadow:0 0 0 2px rgba(201,162,39,0.22),0 10px 26px rgba(201,162,39,0.18)!important;opacity:1!important;font-weight:800}.combat-start-cta:hover{filter:brightness(1.08)}@media (max-width:1100px){.combat-battlefield{grid-template-columns:1fr}.combat-side__lines{grid-template-columns:1fr 1fr}}@media (max-width:700px){.char-tab__switcher{width:100%}.char-pill{flex:1 1 calc(50% - 8px);justify-content:center}.combat-side__lines{grid-template-columns:1fr}}
.combat-table-layout{display:grid;grid-template-columns:minmax(0,1fr) 260px;gap:16px;align-items:start}.combat-initiative-panel{background:var(--bg-card);border:1px solid var(--border-dim);border-radius:var(--radius);padding:12px;position:sticky;top:76px}.combat-initiative-panel__title{font-family:'Cinzel',serif;color:var(--gold-light);font-size:1.05rem;margin:0 0 10px;padding-bottom:8px;border-bottom:1px solid var(--border-dim)}.combat-initiative-panel .combat-initiative{display:flex;flex-direction:column;max-height:520px;overflow-y:auto;margin:0;background:transparent;border:0;padding:0}.combat-battlefield{grid-template-columns:repeat(4,minmax(175px,1fr));grid-template-rows:auto 1fr;align-items:stretch}.combat-battlefield .combat-side{display:contents}.combat-battlefield .combat-side__lines{display:contents}.combat-battlefield .combat-side__title{margin:0 0 2px;padding:4px 2px;border-bottom:1px solid var(--border-dim)}.combat-battlefield .combat-side--heroes>.combat-side__title{grid-column:1/3;grid-row:1}.combat-battlefield .combat-side--enemies>.combat-side__title{grid-column:3/5;grid-row:1;text-align:right}.combat-battlefield .combat-side--heroes .combat-line--back{grid-column:1;grid-row:2}.combat-battlefield .combat-side--heroes .combat-line--front{grid-column:2;grid-row:2}.combat-battlefield .combat-side--enemies .combat-line--front{grid-column:3;grid-row:2}.combat-battlefield .combat-side--enemies .combat-line--back{grid-column:4;grid-row:2}.combat-line{min-width:0;min-height:260px}.combat-line__list{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(230px,100%),1fr));align-content:start}.combat-line__list.combat-line__list--drop{outline:2px solid var(--gold);outline-offset:3px;background:rgba(201,162,39,.08)}.combat-figure,.combat-line__item{min-width:0}.combat-figure{align-items:flex-start;background:linear-gradient(180deg,rgba(255,255,255,.035),rgba(0,0,0,.08)),var(--bg-card2);border-left:3px solid rgba(201,162,39,.65)}.combat-avatar{width:34px;height:34px;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--gold);border-radius:var(--radius);background:rgba(201,162,39,.12);color:var(--gold-light);font-size:1.15rem;flex:0 0 auto;box-shadow:inset 0 0 12px rgba(201,162,39,.1)}.combat-figure__body{display:flex;flex-direction:column;gap:3px;min-width:0;flex:1}.combat-figure__meta{color:var(--text-muted);font-size:.78rem}.combat-figure[draggable="true"],.combat-line__item[draggable="true"]{cursor:grab}.combat-line-dragging{opacity:.55}@media (max-width:1200px){.combat-table-layout{grid-template-columns:1fr}.combat-initiative-panel{position:static}.combat-initiative-panel .combat-initiative{display:flex;flex-direction:row;max-height:none;overflow-x:auto}.combat-battlefield{grid-template-columns:repeat(2,minmax(190px,1fr));grid-template-rows:auto auto auto auto}.combat-battlefield .combat-side--heroes>.combat-side__title{grid-column:1/3;grid-row:1;text-align:left}.combat-battlefield .combat-side--heroes .combat-line--back{grid-column:1;grid-row:2}.combat-battlefield .combat-side--heroes .combat-line--front{grid-column:2;grid-row:2}.combat-battlefield .combat-side--enemies>.combat-side__title{grid-column:1/3;grid-row:3;text-align:left;margin-top:6px}.combat-battlefield .combat-side--enemies .combat-line--front{grid-column:1;grid-row:4}.combat-battlefield .combat-side--enemies .combat-line--back{grid-column:2;grid-row:4}}@media (max-width:700px){.combat-battlefield{grid-template-columns:1fr}.combat-battlefield .combat-side--heroes>.combat-side__title,.combat-battlefield .combat-side--enemies>.combat-side__title,.combat-battlefield .combat-side--heroes .combat-line--back,.combat-battlefield .combat-side--heroes .combat-line--front,.combat-battlefield .combat-side--enemies .combat-line--front,.combat-battlefield .combat-side--enemies .combat-line--back{grid-column:1;grid-row:auto}.combat-line{min-height:160px}}

/* Stacked multiplayer combat lanes and singleplayer-like lower panels. */
.combat-battlefield {
  grid-template-columns: 1fr !important;
  grid-template-rows: none !important;
  gap: 10px !important;
  align-items: stretch !important;
}
.combat-battlefield .combat-side,
.combat-battlefield .combat-side__lines {
  display: contents !important;
}
.combat-battlefield .combat-side__title,
.combat-battlefield .combat-line {
  grid-column: 1 / -1 !important;
  grid-row: auto !important;
}
.combat-battlefield .combat-side--heroes > .combat-side__title {
  order: 1 !important;
  text-align: left !important;
}
.combat-battlefield .combat-side--heroes .combat-line--back {
  order: 2 !important;
}
.combat-battlefield .combat-side--heroes .combat-line--front {
  order: 3 !important;
}
.combat-battlefield .combat-side--enemies > .combat-side__title {
  order: 4 !important;
  text-align: left !important;
  margin-top: 6px !important;
}
.combat-battlefield .combat-side--enemies .combat-line--front {
  order: 5 !important;
}
.combat-battlefield .combat-side--enemies .combat-line--back {
  order: 6 !important;
}
.combat-line {
  min-height: 145px !important;
}
.combat-line__list {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(min(230px, 100%), 1fr)) !important;
  align-content: start !important;
}
.combat-modules {
  display: flex !important;
  flex-direction: column !important;
  gap: 18px !important;
  margin-top: 18px !important;
}
.combat-module {
  width: 100% !important;
  background: var(--bg-card) !important;
  border: 1px solid var(--border-dim) !important;
  border-radius: var(--radius-lg) !important;
  padding: 14px 16px !important;
}
.combat-module > summary {
  padding: 0 0 12px !important;
  margin-bottom: 12px !important;
  border-bottom: 1px solid var(--border-dim) !important;
  font-size: 1.12rem !important;
}
.combat-module > *:not(summary) {
  padding: 0 !important;
}
#modActionPropose { order: 5; }
#modActionQueue { order: 10; }
#modDice { order: 20; }
#modCombatLog { order: 30; }
#modEnemyMgmt { order: 40; }
#modDice .combat-dice-targeted,
#modDice .combat-dice-form {
  border: 1px solid rgba(201, 162, 39, 0.35);
  border-radius: var(--radius);
  background: linear-gradient(100deg, rgba(201, 162, 39, 0.1), rgba(0, 0, 0, 0.16));
  padding: 12px 14px;
}
#modDice .combat-dice-form {
  margin-top: 12px;
  display: grid;
  grid-template-columns: minmax(180px, 1fr) minmax(180px, 1fr) auto;
  gap: 10px;
  align-items: center;
}
#modDice .combat-dice-row {
  display: flex;
  gap: 8px;
}
#modDice .combat-dice-feed {
  max-height: 220px;
  flex-direction: column;
  margin-top: 12px;
}
#modCombatLog .combat-log-feed {
  min-height: 120px;
  max-height: 360px;
  overflow-y: auto;
  border: 1px solid var(--border-dim);
  border-radius: var(--radius);
  background: var(--bg-deep);
  padding: 10px;
}
#modEnemyMgmt .combat-enemy-list {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 10px;
}
@media (max-width: 760px) {
  #modDice .combat-dice-form {
    grid-template-columns: 1fr;
  }
  .combat-dice-targeted__row {
    flex-direction: column;
  }
}

/* Lobby quick chat: desktop side panel, mobile jump button. */
.party-quick-chat {
  position: fixed;
  left: 0;
  bottom: 8.35rem;
  z-index: 8600;
  display: flex;
  align-items: flex-end;
  gap: 8px;
  pointer-events: none;
}
.party-quick-chat[hidden] {
  display: none !important;
}
.party-quick-chat__tab {
  pointer-events: auto;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  min-height: 46px;
  padding: 0.72rem 0.95rem 0.72rem 0.82rem;
  border: 1px solid rgba(201, 162, 39, 0.65);
  border-left: 0;
  border-radius: 0 10px 10px 0;
  background: linear-gradient(135deg, #17130b 0%, #11111f 100%);
  color: var(--gold-light);
  font-family: 'Cinzel', serif;
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  cursor: pointer;
  box-shadow: 4px 4px 18px rgba(0,0,0,0.5), inset 0 0 14px rgba(201,162,39,0.12);
  transition: transform 0.15s ease, box-shadow 0.15s ease, padding-left 0.15s ease;
}
.party-quick-chat__tab:hover {
  transform: translateX(2px);
  padding-left: 1rem;
  box-shadow: 6px 6px 22px rgba(0,0,0,0.58), inset 0 0 18px rgba(201,162,39,0.18), 0 0 14px rgba(201,162,39,0.22);
}
.party-quick-chat__icon {
  font-size: 1.15rem;
  filter: drop-shadow(0 0 6px rgba(201,162,39,0.35));
}
.party-quick-chat__badge {
  min-width: 18px;
  height: 18px;
  padding: 0 6px;
  border-radius: 999px;
  background: var(--red-bright, #d23a3a);
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 0.68rem;
  letter-spacing: 0;
}
.party-quick-chat__badge[hidden] {
  display: none;
}
.party-quick-chat__panel {
  pointer-events: auto;
  width: min(360px, calc(100vw - 72px));
  height: min(470px, calc(100vh - 190px));
  display: flex;
  flex-direction: column;
  background: linear-gradient(180deg, rgba(201,162,39,0.06), transparent 32%), var(--bg-card);
  border: 1px solid rgba(201,162,39,0.55);
  border-radius: var(--radius-lg);
  box-shadow: 0 14px 44px rgba(0,0,0,0.68), 0 0 22px rgba(201,162,39,0.12);
  overflow: hidden;
}
.party-quick-chat__panel[hidden] {
  display: none;
}
.party-quick-chat__head {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.8rem 0.95rem;
  border-bottom: 1px solid var(--border-dim);
}
.party-quick-chat__title {
  margin: 0;
  flex: 1;
  color: var(--gold-light);
  font-family: 'Cinzel', serif;
  font-size: 1rem;
}
.party-quick-chat__close {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  border: 1px solid transparent;
  background: transparent;
  color: var(--text-muted);
  cursor: pointer;
  font-size: 1.15rem;
  line-height: 1;
}
.party-quick-chat__close:hover {
  color: var(--gold-light);
  border-color: var(--gold);
  background: rgba(201,162,39,0.1);
}
.log-feed--quick {
  flex: 1 1 auto;
  min-height: 0;
  max-height: none;
  margin: 0;
  padding: 0.65rem 0.75rem;
  border-top: 0;
}
.chat-form--quick {
  padding: 0.7rem 0.75rem 0.8rem;
  border-top: 1px solid var(--border-dim);
  background: rgba(0,0,0,0.12);
}
.chat-form--quick .party-btn {
  min-width: 48px;
  padding-left: 0.75rem;
  padding-right: 0.75rem;
}

/* More prominent character switcher in party character tab. */
.char-tab__switcher {
  gap: 12px !important;
  align-items: center;
}
.char-pill {
  min-height: 42px !important;
  padding: 8px 16px !important;
  border-width: 2px !important;
  border-color: rgba(201,162,39,0.42) !important;
  background: linear-gradient(180deg, rgba(201,162,39,0.12), rgba(0,0,0,0.12)) !important;
  color: var(--gold-light) !important;
  font-family: 'Cinzel', serif;
  font-weight: 800 !important;
  letter-spacing: 0.02em;
  box-shadow: inset 0 0 0 1px rgba(201,162,39,0.08), 0 8px 18px rgba(0,0,0,0.18);
}
.char-pill:hover {
  border-color: var(--gold-light) !important;
  background: linear-gradient(180deg, rgba(201,162,39,0.2), rgba(0,0,0,0.14)) !important;
  transform: translateY(-1px);
}
.char-pill[aria-selected="true"] {
  background: linear-gradient(180deg, rgba(201,162,39,0.32), rgba(201,162,39,0.12)) !important;
  border-color: var(--gold-light) !important;
  box-shadow: 0 0 0 2px rgba(201,162,39,0.2), 0 10px 24px rgba(0,0,0,0.28) !important;
}
.char-pill__dot {
  width: 10px !important;
  height: 10px !important;
  box-shadow: 0 0 8px currentColor;
}

/* Keep initiative beside lanes on desktop, and avoid clipping while dragging. */
@media (min-width: 901px) {
  .combat-table-layout {
    grid-template-columns: minmax(0, 1fr) 300px !important;
    overflow: visible !important;
  }
  .combat-initiative-panel {
    position: sticky;
    top: 76px;
  }
}
@media (max-width: 900px) {
  .combat-table-layout {
    grid-template-columns: 1fr !important;
  }
  .combat-initiative-panel {
    position: static !important;
  }
}
.combat-wrap,
.combat-table-layout,
.combat-initiative-panel,
.combat-initiative-panel .combat-initiative {
  overflow: visible !important;
}
.combat-initiative-panel .combat-initiative {
  padding: 4px 10px 10px 4px !important;
}
.init-chip.dragging {
  opacity: 0.88 !important;
  z-index: 30;
  box-shadow: 0 10px 26px rgba(0,0,0,0.72), 0 0 0 2px rgba(201,162,39,0.35) !important;
}

@media (max-width: 760px) {
  .party-quick-chat {
    bottom: 7.6rem;
  }
  .party-quick-chat__label {
    display: none;
  }
  .party-quick-chat__tab {
    width: 50px;
    min-height: 48px;
    justify-content: center;
    padding: 0.6rem;
  }
  .party-quick-chat__panel {
    display: none !important;
  }
  .char-tab__switcher {
    width: 100%;
  }
  .char-pill {
    flex: 1 1 calc(50% - 8px);
    justify-content: center;
  }
}

/* Combat controls: closer to the singleplayer DnD surface. */
.combat-line-add-btn,
.combat-figure__btn,
.combat-log-actions .party-btn,
.combat-add-enemy-main {
  border: 1px solid rgba(201,162,39,0.66) !important;
  background: linear-gradient(180deg, rgba(201,162,39,0.14), rgba(0,0,0,0.24)) !important;
  color: var(--gold-light) !important;
  font-family: 'Cinzel', serif !important;
  font-weight: 800 !important;
  letter-spacing: 0.02em;
  box-shadow: inset 0 0 0 1px rgba(201,162,39,0.08), 0 4px 12px rgba(0,0,0,0.28);
}
.combat-line-add-btn:hover,
.combat-figure__btn:hover,
.combat-log-actions .party-btn:hover,
.combat-add-enemy-main:hover {
  border-color: var(--gold-light) !important;
  background: linear-gradient(180deg, rgba(201,162,39,0.25), rgba(0,0,0,0.22)) !important;
  transform: translateY(-1px);
}
.combat-line-add-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 32px;
  margin: 0 0 8px;
  padding: 5px 11px;
  border-radius: var(--radius);
  cursor: pointer;
  font-size: 0.78rem;
}
.combat-figure__btn {
  min-height: 34px;
  min-width: 38px;
  border-radius: var(--radius);
  padding: 5px 10px;
  cursor: pointer;
}
.combat-initiative-actions {
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid var(--border-dim);
}
.combat-add-enemy-main {
  width: 100%;
  justify-content: center;
}
.combat-dice-roller,
#modDice .combat-dice-targeted,
#modDice .combat-dice-form {
  border: 1px solid rgba(201,162,39,0.42) !important;
  border-radius: var(--radius) !important;
  background: radial-gradient(circle at 16% 0, rgba(201,162,39,0.16), transparent 28%), linear-gradient(100deg, rgba(201,162,39,0.10), rgba(0,0,0,0.2)) !important;
  padding: 12px 14px !important;
}
.combat-dice-roller {
  margin-bottom: 12px;
}
.combat-dice-roller__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}
.combat-dice-roller__label {
  color: var(--gold-light);
  font-family: 'Cinzel', serif;
  font-weight: 800;
}
.combat-dice-count {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 5px;
}
.combat-dice-count__btn {
  min-width: 34px;
  min-height: 30px;
  border: 1px solid var(--border-dim);
  border-radius: var(--radius);
  background: rgba(0,0,0,0.22);
  color: var(--text-muted);
  font-family: 'Cinzel', serif;
  cursor: pointer;
}
.combat-dice-count__btn:hover,
.combat-dice-count__btn.is-active {
  color: var(--text-dark);
  border-color: var(--gold-light);
  background: var(--gold);
  font-weight: 800;
}
.combat-dice-roller__hint {
  margin: 8px 0 0 !important;
}
#modDice .combat-dice-form {
  grid-template-columns: minmax(90px, 120px) minmax(180px, 1fr) auto !important;
}
#modDice .combat-dice-form--single {
  display: block !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
}
#modDice .combat-dice-form--single .cs-dice-roller {
  margin: 0;
}
#modDice .combat-dice-form--single #diceLabel,
#modDice .combat-dice-form--single .combat-dice-row {
  display: none !important;
}
.combat-log-actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  margin-bottom: 10px;
}
.combat-log-actions .party-btn:disabled {
  opacity: 0.46;
  cursor: not-allowed;
  transform: none;
}
.combat-line__item--hero {
  list-style: none;
  margin: 8px 0;
  padding: 0;
}
.cb-hero-card--mp {
  max-width: 520px;
  padding: 0.9rem;
  gap: 0.7rem;
  background: linear-gradient(180deg, rgba(39,174,96,0.09), rgba(10,12,22,0.94));
}
.cb-hero-card--mp .cb-hero-card__top {
  align-items: center;
}
.cb-hero-card--mp .cb-hero-card__portrait {
  width: 72px;
  height: 72px;
}
.cb-hero-card--mp .cb-hero-card__identity {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}
.cb-hero-card--mp .cb-hero-card__name {
  font-size: 1.25rem;
}
.cb-hero-card--mp .cb-line-badge {
  align-self: flex-start;
}
.cb-hero-card--mp .cb-hero-card__stats {
  grid-template-columns: repeat(auto-fit, minmax(72px, 1fr));
}
.log-entry__icon {
  width: 1.4rem;
  flex: 0 0 1.4rem;
  text-align: center;
  color: var(--gold-light);
}
@media (max-width: 760px) {
  #modDice .combat-dice-form {
    grid-template-columns: 1fr !important;
  }
  .combat-log-actions {
    justify-content: stretch;
  }
  .combat-log-actions .party-btn {
    flex: 1;
  }
}

/* Sjednocení velikostí tlačítek v lobby (Nahrát .howl soubor / Hrát bez postavy) */
.party-upload{margin-top:0;display:inline-flex;align-items:stretch}
.party-upload .party-btn{display:inline-flex;align-items:center;justify-content:center;line-height:1.2;box-sizing:border-box}
.party-char-actions{align-items:center}
.party-char-actions .party-btn{height:42px;box-sizing:border-box;line-height:1.2}
.party-char-actions .party-upload{height:42px}
.party-char-actions .party-upload .party-btn{height:100%;width:100%}

/* Combat ribbon (parita se single combat cbRibbon) */
.combat-ribbon{
  display:flex;flex-wrap:wrap;gap:1rem;
  background:rgba(13,13,26,.55);
  border:1px solid rgba(201,162,39,.3);
  border-radius:8px;
  padding:.6rem 1rem;
  margin:.4rem 0 .8rem;
  align-items:center;
}
.combat-ribbon[hidden]{display:none}
.combat-ribbon__group{display:flex;align-items:center;gap:.45rem}
.combat-ribbon__label{
  font-family:'Cinzel',serif;color:var(--gold);
  font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;
}
.combat-ribbon__value{
  font-family:'Cinzel',serif;color:var(--gold-light);
  font-size:.95rem;
}
.combat-ribbon__value--turn{color:#fff}
.combat-ribbon__status{
  background:rgba(201,162,39,.10);
  border:1px solid rgba(201,162,39,.4);
  padding:.15rem .55rem;border-radius:999px;
  font-size:.78rem;
}
.combat-initiative-help{
  color:var(--text-muted);font-size:.72rem;
  font-style:italic;margin:.2rem 0 .4rem;text-align:center;
}

/* Autosave info panel — inside #dmActions, shows freshness of the two
   passive backup layers (server-side disk + browser localStorage) plus
   a download button for the local snapshot. */
.lobby-autosave{
  margin-top:14px;padding:10px 12px;border:1px solid var(--border-dim);
  border-radius:var(--radius);background:rgba(201,162,39,.04);
}
.lobby-autosave__title{
  margin:0 0 8px 0;font-family:'Cinzel',serif;font-size:.92rem;
  color:var(--gold-light);letter-spacing:.04em;
}
.lobby-autosave__row{
  display:flex;align-items:center;gap:6px;margin:4px 0;flex-wrap:wrap;
  font-size:.85rem;
}
.lobby-autosave__icon{font-size:.95rem;opacity:.85}
.lobby-autosave__label{color:var(--text-muted);min-width:0}
.lobby-autosave__age{
  color:var(--gold-light);font-variant-numeric:tabular-nums;
  margin-left:auto;
}
.lobby-autosave__age--stale{color:#e9a05a}
.lobby-autosave .party-btn--mini{margin-left:6px}

/* Big-save history list inside the autosave panel. Up to 10 rows; each
   row is a single-line strip with index, timestamp, age, size + Stáhnout. */
.lobby-autosave__bigsaves{
  margin-top:10px;padding-top:10px;
  border-top:1px dashed var(--border-dim);
}
.lobby-autosave__subtitle{
  margin:0 0 6px 0;font-family:'Cinzel',serif;font-size:.85rem;
  color:var(--gold-light);letter-spacing:.03em;
}
.lobby-bigsave-list{
  list-style:none;margin:0;padding:0;
  display:flex;flex-direction:column;gap:4px;
}
.lobby-bigsave-row{
  display:grid;
  grid-template-columns:auto auto 1fr auto auto;
  align-items:center;gap:8px;
  padding:4px 8px;border:1px solid var(--border-dim);
  border-radius:var(--radius);background:var(--bg-deep);
  font-size:.8rem;
}
.lobby-bigsave-row__num{
  font-family:'Cinzel',serif;color:var(--gold);
  font-size:.78rem;min-width:1.5em;
}
.lobby-bigsave-row__time{
  color:var(--text-bright);font-variant-numeric:tabular-nums;
}
.lobby-bigsave-row__age{
  color:var(--text-muted);font-size:.75rem;
}
.lobby-bigsave-row__size{
  color:var(--text-dim);font-size:.72rem;font-variant-numeric:tabular-nums;
}
@media (max-width:560px){
  .lobby-bigsave-row{
    grid-template-columns:auto 1fr auto;
    grid-template-areas:
      "num time btn"
      "num age size";
    gap:2px 8px;
  }
  .lobby-bigsave-row__num{grid-area:num}
  .lobby-bigsave-row__time{grid-area:time}
  .lobby-bigsave-row__age{grid-area:age}
  .lobby-bigsave-row__size{grid-area:size;text-align:right}
  .lobby-bigsave-row .party-btn--mini{grid-area:btn}
}

/* Log filter toggle (Chat tab + quick chat). Two-button segmented control
   that flips a CSS class on the feed parent. Pure CSS hides non-chat
   entries when the "Jen chat" mode is active — no JS re-render needed
   since the feed is rebuilt from state every session:state anyway. */
.chat-tab__header{
  display:flex;align-items:center;gap:12px;flex-wrap:wrap;
  margin-bottom:8px;
}
.chat-tab__header .chat-tab__title{margin:0;flex:1 1 auto}
.log-filter{
  display:inline-flex;gap:0;border:1px solid var(--border-dim);
  border-radius:var(--radius);background:var(--bg-deep);
  padding:2px;
}
.log-filter__btn{
  background:transparent;border:0;cursor:pointer;
  color:var(--text-muted);
  padding:4px 10px;font-size:.82rem;
  border-radius:calc(var(--radius) - 2px);
  font-family:inherit;letter-spacing:.02em;
  transition:background .12s ease,color .12s ease;
}
.log-filter__btn:hover{color:var(--text-bright)}
.log-filter__btn.is-active{
  background:rgba(201,162,39,.15);color:var(--gold-light);
  box-shadow:0 0 0 1px var(--gold) inset;
}
.log-filter--quick{
  margin-left:auto;margin-right:6px;
}
.log-filter--quick .log-filter__btn{padding:2px 6px;font-size:.85rem}

/* The actual filter: when feed has --chat-only, every non-chat entry
   collapses to display:none. Note: this is structural, not visibility,
   so empty groups don't take vertical space. */
.log-feed--chat-only .log-entry:not(.log-entry--chat){display:none}

/* When chat-only is active and there are no chat messages, give the user
   a hint that the filter is on (otherwise an empty feed looks like the
   app is broken). Rendered via the ::before of the empty feed parent. */
.log-feed--chat-only:empty::before,
.log-feed--chat-only:not(:has(.log-entry--chat))::before{
  content:"💬 Žádné chat zprávy. Přepni na „Vše" pro hody kostkou a log akcí.";
  display:block;text-align:center;color:var(--text-dim);
  padding:24px 12px;font-style:italic;font-size:.85rem;
}

/* â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€
   Session timer in header
   â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.session-timer{
  display:inline-block;margin-left:10px;padding:2px 8px;
  font-size:.78rem;color:var(--text-muted);
  background:rgba(201,162,39,.06);border:1px solid var(--border-dim);
  border-radius:999px;font-variant-numeric:tabular-nums;
  letter-spacing:.02em;
}

/* â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€
   DM pinned note bar (above tabs)
   â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.party-pinned{
  display:flex;align-items:flex-start;gap:10px;
  margin:0 0 12px 0;padding:10px 14px;
  background:linear-gradient(90deg,rgba(232,196,74,.10),rgba(232,196,74,.04));
  border:1px solid var(--gold);border-left:4px solid var(--gold);
  border-radius:var(--radius);
  box-shadow:0 2px 12px rgba(0,0,0,.18);
}
.party-pinned__icon{font-size:1.1rem;flex:0 0 auto;color:var(--gold-light);margin-top:1px}
.party-pinned__body{
  flex:1 1 auto;color:var(--text-bright);
  font-size:.92rem;line-height:1.5;
  font-style:italic;letter-spacing:.01em;
  white-space:pre-wrap;word-break:break-word;
}
.party-pinned__edit{flex:0 0 auto;align-self:flex-start}
.party-pinned-add{
  display:block;margin:0 0 12px 0;padding:8px 14px;width:100%;
  background:transparent;border:1px dashed var(--gold);
  border-radius:var(--radius);color:var(--gold-light);
  font-family:inherit;font-size:.88rem;cursor:pointer;
  transition:background .12s ease,border-color .12s ease;
}
.party-pinned-add:hover{
  background:rgba(232,196,74,.08);border-style:solid;
}

/* Textarea inside the modal for editing the pinned note. */
.hoe-modal__input--ta{
  width:100%;min-height:120px;padding:8px 10px;
  background:var(--bg-deep);border:1px solid var(--border-dim);
  border-radius:var(--radius);color:var(--text-bright);
  font-family:inherit;font-size:.92rem;line-height:1.5;
  resize:vertical;
}
.hoe-modal__input--ta:focus{
  border-color:var(--gold);outline:none;
  box-shadow:0 0 0 2px rgba(232,196,74,.18);
}

/* â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€
   Member row accents â€” color, HP warning, idle
   â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.member-row{position:relative;--member-color:var(--gold-light)}
.member-row .member-name__nick{color:var(--member-color)}
.member-row::before{
  content:"";position:absolute;left:0;top:8px;bottom:8px;width:3px;
  background:var(--member-color);border-radius:2px;opacity:.45;
}
.member-row--hp-low{
  border-left-color:#e9a05a !important;
  background:linear-gradient(90deg,rgba(233,160,90,.07),transparent 60%);
}
.member-row--hp-low::after{
  content:"ðŸ©¸";position:absolute;right:8px;top:50%;
  transform:translateY(-50%);font-size:.85rem;
}
.member-row--hp-crit{
  border-left-color:#d44 !important;
  background:linear-gradient(90deg,rgba(220,80,80,.10),transparent 70%);
  animation:hpCritPulse 2s ease-in-out infinite;
}
.member-row--hp-crit::after{content:"ðŸ’€"}
@keyframes hpCritPulse{0%,100%{box-shadow:inset 0 0 0 0 rgba(220,80,80,0)}50%{box-shadow:inset 0 0 0 1px rgba(220,80,80,.4)}}
.member-row--idle .member-dot{background:#6a8aa8 !important;opacity:.7}
.member-row--idle{opacity:.78}
.member-row--idle .member-name__role::after{content:" Â· idle";color:var(--text-dim);font-style:italic}

/* â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€
   Hover preview card
   â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.member-preview{
  position:absolute;z-index:9999;pointer-events:none;
  min-width:200px;max-width:280px;padding:10px 12px;
  background:var(--bg-card);border:1px solid var(--gold);
  border-radius:var(--radius);box-shadow:0 8px 24px rgba(0,0,0,.45);
  font-size:.85rem;color:var(--text-bright);
}
.member-preview__head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:4px}
.member-preview__role{font-size:.75rem;color:var(--text-muted)}
.member-preview__meta{color:var(--text-muted);font-size:.78rem;margin-bottom:6px}
.member-preview__hp{font-variant-numeric:tabular-nums;padding:3px 6px;border-radius:4px;background:var(--bg-deep);display:inline-block}
.member-preview__hp--low{color:#e9a05a}
.member-preview__hp--mid{color:var(--gold-light)}
.member-preview__hp--high{color:#9ec690}
.member-preview__foot{margin-top:6px;font-size:.72rem;color:var(--text-dim)}
@media (hover:none){.member-preview{display:none !important}}

/* â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€
   Chat search + auto-scroll pill + typing indicator
   â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.chat-search{
  flex:0 0 auto;width:160px;padding:4px 10px;
  background:var(--bg-deep);border:1px solid var(--border-dim);
  border-radius:var(--radius);color:var(--text-bright);
  font-family:inherit;font-size:.82rem;
}
.chat-search:focus{border-color:var(--gold);outline:none}
.log-entry--search-hidden{display:none}
.log-feed--searching .log-entry:not(.log-entry--search-hidden){
  background:rgba(232,196,74,.05);
}
.log-feed-wrap{position:relative;flex:1 1 auto;display:flex;min-height:0}
.log-feed-wrap .log-feed{flex:1 1 auto}
.log-feed-wrap--quick{display:flex;flex:1 1 auto;min-height:0}
.log-scroll-pill{
  position:absolute;bottom:8px;left:50%;transform:translateX(-50%);
  padding:5px 14px;background:var(--gold);color:#1a1410;
  border:0;border-radius:999px;cursor:pointer;
  font-family:inherit;font-weight:600;font-size:.78rem;
  box-shadow:0 4px 12px rgba(0,0,0,.4);
  animation:pillBounce .25s ease-out;
}
.log-scroll-pill:hover{background:var(--gold-light)}
@keyframes pillBounce{from{transform:translateX(-50%) translateY(8px);opacity:0}to{transform:translateX(-50%) translateY(0);opacity:1}}
.chat-typing{
  padding:3px 12px;font-size:.75rem;color:var(--text-muted);
  font-style:italic;animation:typingFade .3s ease-in;
  border-bottom:1px solid var(--border-dim);background:rgba(232,196,74,.03);
}
.chat-typing--quick{padding:2px 8px;font-size:.7rem}
@keyframes typingFade{from{opacity:0}to{opacity:1}}

/* Whisper entries: distinct background to set them apart from public chat. */
.log-entry--whisper{
  background:rgba(180,140,200,.07) !important;
  border-left:2px solid #b48cc8 !important;
}

/* â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€
   Quick Dice widget â€” chat sidebar
   â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.quick-dice{
  border-top:1px solid var(--border-dim);
  background:linear-gradient(180deg,rgba(201,162,39,.04),transparent 70%);
}
.quick-dice__summary{
  padding:8px 12px;cursor:pointer;
  font-family:"Cinzel",serif;font-size:.88rem;
  color:var(--gold-light);letter-spacing:.04em;
  list-style:none;
  transition:background .12s ease;
}
.quick-dice__summary::-webkit-details-marker{display:none}
.quick-dice__summary::before{content:"â–¸ ";color:var(--gold);transition:transform .15s}
.quick-dice[open] .quick-dice__summary::before{content:"â–¾ "}
.quick-dice__summary:hover{background:rgba(232,196,74,.06)}
.quick-dice__body{padding:8px 12px 12px;display:flex;flex-direction:column;gap:8px}
.quick-dice__tabs{display:flex;gap:2px;border:1px solid var(--border-dim);border-radius:var(--radius);background:var(--bg-deep);padding:2px}
.quick-dice__tab{
  flex:1 1 0;background:transparent;border:0;cursor:pointer;
  color:var(--text-muted);padding:4px 0;font-size:.75rem;
  border-radius:calc(var(--radius) - 2px);font-family:inherit;
  transition:background .12s,color .12s;letter-spacing:.02em;
}
.quick-dice__tab:hover{color:var(--text-bright)}
.quick-dice__tab.is-active{background:rgba(201,162,39,.15);color:var(--gold-light);box-shadow:0 0 0 1px var(--gold) inset}
.quick-dice__count{display:flex;align-items:center;gap:4px;flex-wrap:wrap}
.quick-dice__count-label{font-size:.75rem;color:var(--text-muted);margin-right:4px}
.quick-dice__count-btn{
  width:26px;height:26px;background:var(--bg-deep);
  border:1px solid var(--border-dim);border-radius:var(--radius);
  color:var(--text-muted);cursor:pointer;font-family:inherit;
  font-size:.82rem;font-weight:600;
  transition:all .12s ease;
}
.quick-dice__count-btn:hover{border-color:var(--gold);color:var(--text-bright)}
.quick-dice__count-btn.is-active{
  background:var(--gold);color:#1a1410;border-color:var(--gold);
  box-shadow:0 0 8px rgba(232,196,74,.4);
}
.quick-dice__panel{display:none;flex-direction:column;gap:6px}
.quick-dice__panel.is-active{display:flex}
.quick-dice__field{display:flex;flex-direction:column;gap:2px;font-size:.78rem;color:var(--text-muted)}
.quick-dice__field--inline{flex-direction:row;align-items:center;gap:8px}
.quick-dice__field--inline span{flex:0 0 auto;min-width:80px}
.quick-dice__select,.quick-dice__num{
  background:var(--bg-deep);border:1px solid var(--border-dim);
  border-radius:var(--radius);color:var(--text-bright);
  padding:4px 8px;font-family:inherit;font-size:.85rem;
}
.quick-dice__select{width:100%}
.quick-dice__num{width:80px;font-variant-numeric:tabular-nums}
.quick-dice__select:focus,.quick-dice__num:focus{border-color:var(--gold);outline:none}
.quick-dice__hint{font-size:.7rem;color:var(--text-dim);font-style:italic;margin:2px 0}
.quick-dice__roll{margin-top:2px}

/* Local dice animation stage (matches charsheet cs-die layout). */
.quick-dice__result{
  margin-top:8px;padding:10px;
  background:radial-gradient(ellipse at center,rgba(232,196,74,.10),transparent 70%),var(--bg-deep);
  border:1px solid var(--border-dim);border-radius:var(--radius);
  display:flex;flex-direction:column;align-items:center;gap:6px;
}
.quick-dice__individual{
  display:flex;gap:6px;flex-wrap:wrap;justify-content:center;min-height:34px;
}
.quick-dice__total{
  display:flex;align-items:baseline;gap:10px;
  font-family:"Cinzel",serif;
}
.quick-dice__total .cs-dice-total-val{
  font-size:1.4rem;color:var(--gold-light);
  font-weight:700;font-variant-numeric:tabular-nums;
}
.quick-dice__verdict{font-size:.85rem;letter-spacing:.04em}
.quick-dice__verdict--ok{color:#9ec690}
.quick-dice__verdict--fail{color:#e08080}

/* â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€
   Mobile DM FAB
   â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.mobile-dm-fab{
  position:fixed;bottom:16px;right:16px;z-index:1500;
  display:flex;flex-direction:column-reverse;align-items:flex-end;gap:8px;
}
.mobile-dm-fab__main{
  width:56px;height:56px;border-radius:50%;
  background:radial-gradient(circle at 35% 30%,var(--gold-light),var(--gold) 70%);
  border:2px solid #1a1410;color:#1a1410;cursor:pointer;
  box-shadow:0 6px 16px rgba(0,0,0,.5);
  display:flex;align-items:center;justify-content:center;
  font-size:1.6rem;transition:transform .15s ease;
}
.mobile-dm-fab__main:hover{transform:scale(1.05)}
.mobile-dm-fab__menu{
  display:flex;flex-direction:column-reverse;gap:6px;
}
.mobile-dm-fab__item{
  background:var(--bg-card);border:1px solid var(--gold);
  border-radius:999px;color:var(--gold-light);
  padding:8px 14px;font-family:inherit;font-size:.85rem;cursor:pointer;
  box-shadow:0 4px 12px rgba(0,0,0,.4);
  white-space:nowrap;
  animation:fabItemSlide .2s ease-out;
}
.mobile-dm-fab__item:hover{background:rgba(232,196,74,.12)}
@keyframes fabItemSlide{from{opacity:0;transform:translateX(8px)}to{opacity:1;transform:translateX(0)}}

/* Chat tab header should stay flex even when search is added. */
.chat-tab{display:flex;flex-direction:column;height:100%;min-height:0}
.chat-tab__header{flex:0 0 auto}
.chat-tab .log-feed-wrap{flex:1 1 auto;min-height:120px}


/* â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€
   [hidden] enforcement â€” author rules with explicit display: tend to
   beat the UA stylesheet's [hidden]{display:none}, so we re-assert it
   for every element class that the lobby JS toggles via .hidden=true.
   Without these the pinned note bar stays visible even when empty, and
   the FAB/menu/quick-dice result panels can't be hidden by JS at all.
   â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.party-pinned[hidden],
.party-pinned-add[hidden],
.party-pinned__edit[hidden],
.mobile-dm-fab[hidden],
.mobile-dm-fab__menu[hidden],
.quick-dice[hidden],
.quick-dice__result[hidden],
.chat-typing[hidden],
.log-scroll-pill[hidden],
.lobby-autosave[hidden],
.lobby-autosave__bigsaves[hidden],
.member-preview[hidden],
.lobby-bigsave-row__num[hidden],
#dropCharBtn[hidden],
#dropCharHint[hidden]{display:none !important}


/* â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€
   Quick-dice in main panel sidebar (was in chat sidebar)
   â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.quick-dice-section{padding:8px 0}
.quick-dice--inline{
  border-top:none;background:transparent;
}
.quick-dice--inline .quick-dice__body{
  padding:4px 0 0;
}

/* Hide the old details/summary affordance â€” we're no longer wrapped in
   a <details> element when in the main panel. */
.quick-dice:not(details) > .quick-dice__summary{display:none}

/* â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€
   Color picker grid (50 swatches)
   â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.color-grid{
  display:grid;grid-template-columns:repeat(10,1fr);gap:6px;
  margin-top:10px;max-width:420px;
}
.color-swatch{
  width:32px;height:32px;border-radius:50%;cursor:pointer;
  border:2px solid transparent;
  transition:transform .12s ease,border-color .12s ease,box-shadow .12s ease;
  position:relative;
}
.color-swatch:hover:not([disabled]){
  transform:scale(1.15);border-color:var(--gold-light);
  box-shadow:0 0 8px rgba(232,196,74,.5);
}
.color-swatch.is-current{
  border-color:var(--gold);
  box-shadow:0 0 0 2px var(--bg-deep),0 0 0 4px var(--gold);
}
.color-swatch.is-used{
  cursor:not-allowed;opacity:.25;filter:saturate(.3);
}
.color-swatch.is-used::after{
  content:"âœ•";position:absolute;left:50%;top:50%;
  transform:translate(-50%,-50%);color:#000;font-weight:700;
  font-size:.75rem;
}

/* Inline color-picker button on member rows */
.member-color-btn{
  width:28px;height:28px;padding:0;border-radius:50%;
  font-size:.85rem;border-width:2px;
}

/* â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€
   Whisper autocomplete + picker
   â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.whisper-suggest{
  position:absolute;bottom:100%;left:0;right:0;margin-bottom:4px;
  background:var(--bg-card);border:1px solid var(--gold);
  border-radius:var(--radius);box-shadow:0 -4px 16px rgba(0,0,0,.4);
  max-height:200px;overflow-y:auto;z-index:50;
  display:flex;flex-direction:column;
}
.whisper-suggest__item{
  display:flex;align-items:center;gap:8px;
  padding:8px 12px;background:transparent;border:0;cursor:pointer;
  color:var(--text-bright);font-family:inherit;font-size:.88rem;
  text-align:left;
  transition:background .1s ease;
}
.whisper-suggest__item:hover{background:rgba(232,196,74,.1)}
.whisper-suggest__dot{
  width:10px;height:10px;border-radius:50%;flex:0 0 auto;
}
.chat-form{position:relative}
.chat-whisper-btn{flex:0 0 auto;padding:6px 10px;font-size:.82rem}
.chat-form--quick .chat-whisper-btn{padding:4px 6px;font-size:.9rem}

/* Modal whisper picker (used when 2+ candidates exist) */
.whisper-picker{display:flex;flex-direction:column;gap:4px;margin-top:8px}
.whisper-picker__item{
  display:flex;align-items:center;gap:8px;
  padding:8px 12px;background:var(--bg-deep);border:1px solid var(--border-dim);
  border-radius:var(--radius);cursor:pointer;color:var(--text-bright);
  font-family:inherit;font-size:.92rem;
  transition:border-color .12s ease,background .12s ease;
}
.whisper-picker__item:hover{border-color:var(--gold);background:rgba(232,196,74,.06)}
.whisper-picker__dot{width:12px;height:12px;border-radius:50%;flex:0 0 auto}

/* Lead paragraph at the top of modal body (used by pinned + color modals) */
.hoe-modal__lead{
  margin:0 0 10px 0;color:var(--text-muted);font-size:.88rem;
}


/* Whisper-suggest [hidden] fix â€” author display:flex was overriding the
   UA stylesheet's [hidden]{display:none}. */
.whisper-suggest[hidden]{display:none !important}

/* Greyed-out roll buttons when DM has disabled player rolls. */
.quick-dice--locked{
  position:relative;
}
.quick-dice--locked::after{
  content:"ðŸš« DM doÄasnÄ› zakÃ¡zal hody";
  position:absolute;top:8px;right:10px;
  font-size:.72rem;color:#e08080;font-style:italic;
  pointer-events:none;
}
.quick-dice__roll--disabled,
.quick-dice__roll[disabled]{
  opacity:.4;cursor:not-allowed;filter:grayscale(.6);
}
.quick-dice--locked .quick-dice__panel,
.quick-dice--locked .quick-dice__count{opacity:.7}

/* Hover-preview redesign â€” richer layout with portrait + multiple rows. */
.member-preview{
  min-width:240px;max-width:320px;padding:12px 14px;
}
.member-preview__head{
  display:flex;align-items:center;gap:10px;
  margin-bottom:8px;padding-bottom:8px;
  border-bottom:1px solid var(--border-dim);
}
.member-preview__portrait{
  width:42px;height:42px;border-radius:50%;
  border:1px solid var(--border-dim);object-fit:cover;
  flex:0 0 auto;
}
.member-preview__id{
  display:flex;flex-direction:column;gap:2px;flex:1 1 auto;min-width:0;
}
.member-preview__id strong{font-size:.96rem;line-height:1.2}
.member-preview__meta{
  color:var(--text-muted);font-size:.78rem;
  margin-bottom:8px;font-style:italic;
}
.member-preview__row{
  display:flex;justify-content:space-between;align-items:center;
  gap:8px;padding:3px 0;font-size:.82rem;
  border-top:1px dashed rgba(255,255,255,.05);
}
.member-preview__row:first-of-type{border-top:0}
.member-preview__lbl{color:var(--text-muted);flex:0 0 auto}
.member-preview__val{
  color:var(--text-bright);font-variant-numeric:tabular-nums;
  font-weight:600;text-align:right;
}
.member-preview__hp .member-preview__val{color:var(--gold-light)}
.member-preview__hp--low .member-preview__val{color:#e9a05a}
.member-preview__hp--mid .member-preview__val{color:#ffd97a}
.member-preview__hp--high .member-preview__val{color:#9ec690}
.member-preview__foot{
  margin-top:8px;padding-top:6px;
  border-top:1px solid var(--border-dim);
  font-size:.72rem;color:var(--text-dim);
}


/* â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€
   Sidebar widening + section reorder
   Current rule:  .lobby-grid { grid-template-columns: 1fr 280px }
   New (desktop):  members : aside = 2 : 1, aside floor 280 px so DM
   tools / dice / autosave still have minimum breathing room.
   â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
@media (min-width: 901px) {
  .lobby-grid{
    grid-template-columns: minmax(0, 2fr) minmax(280px, 1fr) !important;
  }
}

/* Visual reorder of sidebar sections. HTML order (DM â†’ autosave â†’
   vote â†’ dice) â†’ wanted order (DM â†’ dice â†’ autosave â†’ vote).
   flex-direction:column + `order` keys avoid moving DOM. */
.lobby-aside{display:flex;flex-direction:column;gap:0}
.lobby-aside > .lobby-section{margin-bottom:14px}
.lobby-aside #dmActions{order:1}
.lobby-aside .quick-dice-section{order:2}
.lobby-aside #autosaveSection{order:3}
.lobby-aside #voteSection{order:4}
.lobby-aside #voteStartSection{order:5}

/* Autosave section moved out of dmActions â€” give it the same gold
   accent that DM tools have so it reads as a coherent block. */
.lobby-section--autosave{
  border:1px solid var(--border-dim);
  border-radius:var(--radius);
  padding:12px 14px;background:rgba(232,196,74,.03);
}
.lobby-section--autosave .lobby-h3{color:var(--gold-light);margin-top:0}
.lobby-section--autosave .lobby-autosave{
  margin-top:0;border:0;padding:0;background:transparent;
}

/* [hidden] enforcement for the freeze toggle â€” same fix as everywhere
   else, the .party-btn baseline display:inline-flex was beating UA. */
#charsFreezeToggle[hidden],
#autosaveSection[hidden],
#qdTargetRow[hidden]{display:none !important}

/* DM-only Quick Dice player select row. */
.quick-dice__target{
  background:rgba(232,196,74,.05);
  border:1px solid rgba(232,196,74,.18);
  border-radius:var(--radius);
  padding:6px 10px;margin-bottom:4px;
}
.quick-dice__target > span{
  font-weight:600;color:var(--gold-light);font-size:.78rem;
  letter-spacing:.04em;text-transform:uppercase;
}

