:root{--dm-bg:#0a0908;--dm-surface:#111010;--dm-card:#1a1816;--dm-card-alt:#201e1b;--dm-border:#2d2a26;--dm-border-strong:#3d3930;--dm-text:#e8e0d0;--dm-muted:#a79b87;--dm-dim:#5b544c;--dm-gold:#c9a84c;--dm-gold-strong:#e8c96a;--dm-blood:#8b1a1a;--dm-blood-strong:#c0392b;--dm-ember:#d4612a;--dm-frost:#4a90b8;--dm-green:#4a8b4a;--dm-shadow:0 24px 80px rgba(0,0,0,.42)}
.initiative-shell{max-width:98%;margin:0 auto;padding:0 0 2rem}
.initiative-app{position:relative;background:var(--dm-bg);color:var(--dm-text);border:1px solid rgba(201,168,76,.14);border-radius:1.5rem;overflow:hidden;box-shadow:var(--dm-shadow)}
.initiative-app::before{content:"";position:absolute;inset:0;pointer-events:none;opacity:.26;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='220' height='220'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.72' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='220' height='220' filter='url(%23n)' opacity='0.15'/%3E%3C/svg%3E") repeat}
.initiative-app>*{position:relative;z-index:1}
.initiative-hero{padding:1.25rem 1.75rem;border-bottom:1px solid var(--dm-border);background:linear-gradient(180deg,rgba(32,30,27,.97),rgba(17,16,16,.97));display:flex;flex-direction:column;gap:0.4rem;align-items:flex-start}
.initiative-url-btn{font-size:.82rem;color:var(--dm-muted);background:rgba(255,255,255,.04);border:1px solid var(--dm-border-strong);border-radius:.5rem;padding:.3rem .65rem;display:inline-flex;align-items:center;gap:.35rem;transition:border-color .15s,color .15s,background-color .15s}
.initiative-url-btn:hover,.initiative-url-btn:focus{border-color:var(--dm-gold);color:var(--dm-gold);background:rgba(201,168,76,.07)}
.initiative-url-btn:disabled{opacity:.45;cursor:default;pointer-events:none}
.initiative-hero h1{margin:0;font-family:Georgia,serif;font-size:2rem;letter-spacing:.04em;color:var(--dm-gold)}
.initiative-hero-details{font-size:.85rem;color:var(--dm-muted);display:flex;gap:1.5rem;align-items:center}
.initiative-status{display:flex;gap:.75rem;flex-wrap:wrap;font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;margin-top:auto}
.initiative-badge{padding:.4rem .75rem;border:1px solid var(--dm-border-strong);border-radius:999px;background:rgba(255,255,255,.03);display:inline-flex;gap:.45rem;align-items:center}
.initiative-grid{display:grid;grid-template-columns:420px minmax(0,1fr) 340px;min-height:780px}
.initiative-panel{padding:1.25rem;border-right:1px solid var(--dm-border);display:flex;flex-direction:column}
.initiative-panel:last-child{border-right:none}
.initiative-card{background:linear-gradient(180deg,rgba(26,24,22,.98),rgba(17,16,16,.98));border:1px solid var(--dm-border);border-radius:1rem;padding:1rem;margin-bottom:1rem;box-shadow:inset 0 1px 0 rgba(255,255,255,.02)}
.initiative-card h2,.panel-title,.section-title{font-size:.74rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--dm-gold);margin:0 0 .85rem}
.form-label-sm,.helper-text-label{font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--dm-dim);margin-bottom:.35rem}
.helper-copy,.helper-text{color:var(--dm-muted);font-size:.92rem}
.form-control,.form-select{background:var(--dm-card-alt);border:1px solid var(--dm-border-strong);color:var(--dm-text)}
.form-control:focus,.form-select:focus{background:var(--dm-card-alt);border-color:var(--dm-gold);color:var(--dm-text);box-shadow:0 0 0 .2rem rgba(201,168,76,.12)}
.form-control::placeholder{color:#7a7060}
.code-box{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:1.1rem;letter-spacing:.1rem;background:var(--dm-card);border:1px solid var(--dm-border-strong);padding:.4rem .6rem;border-radius:.6rem;color:var(--dm-gold-strong);display:inline-block}
.presence-dot{width:.72rem;height:.72rem;border-radius:50%;display:inline-block;background:var(--dm-blood-strong)}
.presence-dot.live{background:var(--dm-green);box-shadow:0 0 0 .18rem rgba(74,139,74,.16)}
.btn-toolbar-wrap{display:flex;gap:.5rem;flex-wrap:wrap}
.btn-primary{background:var(--dm-gold);border-color:var(--dm-gold);color:#100d07}
.btn-primary:hover,.btn-primary:focus{background:var(--dm-gold-strong);border-color:var(--dm-gold-strong);color:#100d07}
.btn-success{background:linear-gradient(135deg,var(--dm-blood) 0%,#5a1010 100%);border-color:var(--dm-blood-strong)}
.btn-success:hover,.btn-success:focus{background:linear-gradient(135deg,var(--dm-blood-strong) 0%,var(--dm-blood) 100%);border-color:var(--dm-blood-strong)}
.btn-outline-light{color:var(--dm-text);border-color:var(--dm-border-strong)}
.btn-outline-light:hover,.btn-outline-light:focus,.die-btn:hover,.die-btn:focus,.die-btn.selected{background:rgba(201,168,76,.1);border-color:var(--dm-gold);color:var(--dm-gold)}
.btn-outline-warning{color:var(--dm-ember);border-color:rgba(212,97,42,.45)}
.btn-outline-warning:hover,.btn-outline-warning:focus{background:rgba(212,97,42,.1);border-color:var(--dm-ember);color:#ffb48f}
.btn-outline-danger{color:#ffaea3;border-color:rgba(192,57,43,.4)}
.btn-outline-danger:hover,.btn-outline-danger:focus{background:rgba(192,57,43,.12);border-color:var(--dm-blood-strong)}
.panel-header-row,.roll-head,.summary-grid,.combatant-head,.combatant-footer,.player-entry{display:flex;justify-content:space-between;gap:.75rem;align-items:center}
.round-badge,.type-pill{font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;padding:.24rem .65rem;border-radius:999px;border:1px solid rgba(255,255,255,.06)}
.round-badge{color:var(--dm-text);background:var(--dm-blood);display:inline-block;vertical-align:middle}
.type-pill.player{background:rgba(74,144,184,.14);color:#8fc3df}
.type-pill.monster{background:rgba(192,57,43,.14);color:#ffb2aa}
.initiative-list,.player-roster,.roll-log{display:flex;flex-direction:column;gap:.6rem}
.combatant{position:relative;background:var(--dm-card);border:1px solid var(--dm-border);border-left:4px solid var(--dm-frost);border-radius:.9rem;padding:.85rem .9rem;overflow:hidden}
.combatant.monster{border-left-color:var(--dm-blood-strong)}
.combatant.active{border-color:var(--dm-gold);background:var(--dm-card-alt);box-shadow:0 0 0 1px rgba(201,168,76,.3),0 0 18px rgba(201,168,76,.12)}
.combatant.active::before{content:"▶";position:absolute;left:.5rem;top:.65rem;font-size:.7rem;color:var(--dm-gold)}
.combatant-mod-hint{display:block;font-size:.65rem;color:var(--dm-muted);letter-spacing:.04em;line-height:1.2}
.combatant-main{padding-left:.8rem;min-width:0}
.combatant-name{font-size:1rem;font-weight:600;color:var(--dm-text)}
.combatant-meta,.player-entry-status{font-size:.78rem;color:var(--dm-muted);letter-spacing:.04em}
.stat-badges{display:flex;gap:.45rem;flex-wrap:wrap;margin-top:.55rem}
.stat-badge{padding:.28rem .55rem;border-radius:999px;background:rgba(255,255,255,.04);border:1px solid var(--dm-border-strong);font-size:.72rem;color:var(--dm-text)}
.hp-track{height:.4rem;background:#2b2724;border-radius:999px;overflow:hidden;margin-top:.75rem}
.hp-bar{height:100%}
.combatant-actions{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:.75rem}
.player-entry{align-items:center;padding:.65rem .75rem;border:1px solid var(--dm-border);border-radius:.8rem;background:rgba(255,255,255,.02)}
.player-entry-name{font-weight:600;color:var(--dm-text)}
.player-entry-role{font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:#8fc3df}
.player-entry-status.connected{color:#9fdf9f}
.player-entry-status.disconnected{color:#c8b7a1}
.empty-state{padding:1rem;border:1px dashed var(--dm-border-strong);border-radius:.8rem;color:var(--dm-muted);text-align:center}
.roll-log{max-height:32rem;overflow:auto;padding-right:.1rem}
.roll-entry{background:var(--dm-card);border:1px solid var(--dm-border);padding:.5rem .75rem;border-radius:.85rem;font-size:0.95rem}
.roll-entry small{color:var(--dm-dim);margin-left:0.5rem}
.roll-entry strong{color:var(--dm-gold-strong)}
.roll-entry .crit{color:var(--dm-green);font-weight:bold;display:inline-flex;align-items:center;gap:0.25rem}
.roll-entry .fumble{color:#ff9f92}
.dice-type-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.45rem;margin-bottom:.75rem}
.die-btn{background:var(--dm-card-alt);border:1px solid var(--dm-border-strong);color:var(--dm-muted);border-radius:.55rem;padding:.7rem .4rem;font-weight:700;letter-spacing:.06em}
.dice-row{display:grid;grid-template-columns:90px minmax(0,1fr);gap:.6rem;margin-bottom:.65rem}
.dice-lock-row{display:flex;justify-content:space-between;gap:.75rem;align-items:center;margin-bottom:.75rem}
.adv-row{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:.75rem}
.adv-check{display:flex;gap:.45rem;align-items:center;color:var(--dm-muted);font-size:.84rem}
.summary-grid{gap:.5rem;flex-wrap:wrap;margin-top:.8rem}
.summary-card{flex:1 1 46%;background:rgba(255,255,255,.03);border:1px solid var(--dm-border);border-radius:.8rem;padding:.7rem .8rem}
.summary-card strong{display:block;color:var(--dm-gold-strong);font-size:1.05rem}
.summary-card span{font-size:.72rem;color:var(--dm-dim);letter-spacing:.12em;text-transform:uppercase}
.session-join[hidden]{display:none!important}

@media (max-width:1360px){.initiative-grid{grid-template-columns:380px 1fr 320px}}
@media (max-width:1180px){.initiative-grid{grid-template-columns:1fr}.initiative-panel{border-right:none;border-bottom:1px solid var(--dm-border)}.initiative-panel:last-child{border-bottom:none}}
@media (max-width:560px){.dice-type-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.dice-row{grid-template-columns:1fr}.summary-card{flex-basis:100%}}

.dice-lock-toggle{min-width:7.5rem;text-align:center}
.roller-pill{border-radius:.55rem;padding:.36rem .75rem}
.type-pill.npc{background:rgba(110,168,254,.12);color:#bfd7ff}
.type-pill.environment{background:rgba(74,139,74,.16);color:#b6e2b6}
.combatant.npc{border-left-color:#6ea8fe}
.combatant.environment{border-left-color:#4a8b4a}
.lock-explainer{font-size:.8rem;color:var(--dm-dim);margin-bottom:.75rem;padding:.45rem .6rem;border:1px dashed var(--dm-border-strong);border-radius:.65rem}
.saved-session-list{display:flex;flex-direction:column;gap:.55rem}
.saved-session-link{display:flex;flex-direction:column;gap:.15rem;padding:.75rem .8rem;border:1px solid var(--dm-border);border-radius:.8rem;background:rgba(255,255,255,.02);color:var(--dm-text);text-decoration:none}
.saved-session-link:hover{border-color:var(--dm-gold);color:var(--dm-gold)}
.billing-recommendations{padding-left:1.1rem;margin:0;color:var(--dm-muted)}
.billing-recommendations li+li{margin-top:.45rem}
.roll-action-btn{border-radius:.55rem}
.turn-pill{font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;padding:.25rem .55rem;border-radius:.45rem;border:1px solid rgba(201,168,76,.35);color:var(--dm-gold)}

.initiative-hero-line{display:flex;align-items:center;justify-content:space-between;gap:1rem;width:100%;flex-wrap:wrap}
.initiative-hero-details{flex-wrap:wrap;gap:.9rem;white-space:nowrap}
.combatant-row{display:grid;grid-template-columns:64px minmax(0,1.6fr) minmax(90px,.8fr) 72px;gap:.75rem;align-items:center}
.combatant-cell-init{font-size:1.3rem;font-weight:700;color:var(--dm-gold-strong);text-align:center}
.combatant-cell-hp{font-size:.9rem;color:var(--dm-text);justify-self:end;display:flex;flex-direction:column;align-items:flex-end;gap:.15rem}
.ac-badge{font-size:.72rem;letter-spacing:.06em;color:var(--dm-muted);background:rgba(255,255,255,.06);border:1px solid var(--dm-border);border-radius:.35rem;padding:.1rem .35rem}
.stat-edit-label{display:inline-flex;align-items:center;gap:.3rem;font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;color:var(--dm-muted)}
.stat-input{width:4rem;background:rgba(255,255,255,.08);border:1px solid var(--dm-border);border-radius:.35rem;color:var(--dm-text);font-size:.8rem;padding:.2rem .35rem;text-align:center}
.stat-input:focus{outline:none;border-color:var(--dm-gold);background:rgba(232,201,106,.08)}
.player-lock-btn{font-size:.8rem;line-height:1;padding:.2rem .4rem}
.combatant-cell-turn{justify-self:end}
.combatant-subline{display:flex;align-items:center;gap:.35rem;font-size:.75rem;letter-spacing:.08em;text-transform:uppercase;color:var(--dm-muted)}
.drag-hint{font-size:.7rem;color:var(--dm-dim);margin-right:auto;text-transform:uppercase;letter-spacing:.08em}
.combatant[draggable="true"]{cursor:grab}
.combatant.dragging{opacity:.45}
.combatant.drag-target{border-color:var(--dm-gold-strong);box-shadow:0 0 0 1px rgba(232,201,106,.5)}
@media (max-width:760px){.combatant-row{grid-template-columns:48px minmax(0,1fr) auto;grid-template-areas:"init name turn" "hp hp hp"}.combatant-cell-init{grid-area:init}.combatant-cell-name{grid-area:name}.combatant-cell-turn{grid-area:turn}.combatant-cell-hp{grid-area:hp;justify-self:start}}

.subscription-options{display:flex;flex-direction:column;gap:.75rem}
.subscription-option{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:.75rem;padding:.75rem .9rem;border:1px solid var(--dm-border);border-radius:.9rem;background:rgba(255,255,255,.02);cursor:pointer}
.subscription-option strong{color:var(--dm-gold)}
.subscription-option input{margin:0}
.dice-lock-row{justify-content:flex-end}
.dice-lock-toggle{min-width:2.5rem;font-size:1rem;font-weight:700}

.round-header-pill{font-size:.76rem;letter-spacing:.12em;text-transform:uppercase;color:var(--dm-muted);display:inline-flex;align-items:center;gap:.4rem}
.round-header-pill strong{color:var(--dm-gold-strong);font-size:1rem}
.subscription-panel{border:1px solid var(--dm-border);border-radius:.9rem;background:rgba(255,255,255,.02)}
.subscription-summary{list-style:none;display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.85rem .95rem;cursor:pointer;font-size:.74rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--dm-gold)}
.subscription-summary::-webkit-details-marker{display:none}
.subscription-summary-actions{display:inline-flex;align-items:center;gap:.5rem;letter-spacing:normal;text-transform:none}
.subscription-body{padding:0 .95rem .95rem}
