/* ─────────────────────────────────────────────────────────
   MTG Life Counter — Desktop full-screen + Mobile menutized
   ───────────────────────────────────────────────────────── */

/* ── Wrapper ──────────────────────────────────────────────── */
/* Override the landing page hero wrapper constraint (400px default) */
.hero-counter-wrapper.mtg-wrapper{max-width:1000px}
/* Widen subtitle to match the wider counter on desktop */
.landing-hero:has(.mtg-wrapper) .hero-subtitle{max-width:800px}
.mtg-life-counter{position:relative;width:100%;border-radius:16px;overflow:hidden;background:var(--bg-secondary);border:1px solid var(--border-color)}

/* ── Toolbar ──────────────────────────────────────────────── */
.mtg-toolbar{display:flex;align-items:center;justify-content:space-between;padding:0.5rem 0.75rem;background:var(--bg-tertiary);border-bottom:1px solid var(--border-color);gap:0.5rem;flex-wrap:wrap;z-index:10;position:relative}
.mtg-toolbar-left,.mtg-toolbar-right{display:flex;align-items:center;gap:0.375rem}
.mtg-select{padding:0.375rem 0.5rem;border-radius:6px;border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary);font-size:0.8125rem;font-weight:500;cursor:pointer}
.mtg-pcount{display:flex;gap:2px;background:var(--bg-primary);border-radius:6px;border:1px solid var(--border-color);padding:2px}
.pcount-btn{padding:0.25rem 0.625rem;border:none;background:transparent;color:var(--text-secondary);font-size:0.75rem;font-weight:600;cursor:pointer;border-radius:4px;transition:all 0.15s ease}
.pcount-btn.active{background:var(--primary-color);color:white}
.pcount-btn:hover:not(.active){background:var(--bg-hover)}
.mtg-tool-btn{width:34px;height:34px;border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-secondary);border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:0.875rem;transition:all 0.15s ease}
.mtg-tool-btn:hover{background:var(--bg-hover);color:var(--primary-color);border-color:var(--primary-color)}
.mtg-tool-btn-danger:hover{color:#ef4444;border-color:#ef4444}

/* ── Player grid — DESKTOP (big full-screen) ─────────────── */
.mtg-players{display:grid;width:100%;min-height:520px}
.players-2{grid-template-columns:1fr 1fr;grid-template-rows:1fr}
.players-3{grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr}
.players-3 .mtg-player-panel:last-child{grid-column:1 / -1}
.players-4{grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr}

/* ── Player panel ─────────────────────────────────────────── */
.mtg-player-panel{position:relative;display:flex;flex-direction:column;background:var(--panel-bg, #3b82f6);color:var(--panel-text, #fff);overflow:hidden;transition:background 0.3s ease}
/* Rotation only on mobile (applied via JS class, disabled on desktop) */
.mtg-player-panel.rotated{transform:none}
.mtg-player-panel.rotated .panel-extras{transform:none}

/* Main area */
.panel-main{flex:1;display:flex;flex-direction:column;position:relative;min-height:200px}

/* Tap zones (desktop) — invisible overlay areas */
.life-tap-zone{position:absolute;left:0;right:0;z-index:2;cursor:pointer;transition:background 0.1s ease}
.life-tap-plus{top:0;height:40%}
.life-tap-minus{bottom:0;height:40%}
.life-tap-zone:active{background:rgba(255,255,255,0.08)}

/* Center content */
.panel-center{position:relative;z-index:3;display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;padding:1rem;pointer-events:none}
.panel-center > *{pointer-events:auto}

.player-name-input{background:transparent;border:none;border-bottom:1px dashed rgba(255,255,255,0.3);color:inherit;font-size:0.875rem;font-weight:500;text-align:center;padding:0.25rem 0.5rem;width:auto;max-width:160px;outline:none;margin-bottom:0.25rem}
.player-name-input:focus{border-bottom-color:rgba(255,255,255,0.7)}

.life-total{font-size:6rem;font-weight:800;line-height:1;font-variant-numeric:tabular-nums;text-shadow:0 2px 12px rgba(0,0,0,0.2);user-select:none;transition:transform 0.1s ease}

.life-delta-flash{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:2rem;font-weight:700;opacity:0;pointer-events:none;text-shadow:0 2px 8px rgba(0,0,0,0.3);transition:none}
.life-delta-flash.flash-show{animation:deltaFlash 0.6s ease-out forwards}
@keyframes deltaFlash{0%{opacity:1;transform:translate(-50%,-50%) scale(1.2)}100%{opacity:0;transform:translate(-50%,-80%) scale(0.8)}}

/* Life buttons row */
.life-buttons{display:flex;gap:0.25rem;margin-top:0.5rem;z-index:5}
.life-btn{padding:0.375rem 0.625rem;border:1px solid rgba(255,255,255,0.25);background:rgba(255,255,255,0.12);color:inherit;border-radius:6px;font-size:0.8125rem;font-weight:600;cursor:pointer;transition:all 0.15s ease;touch-action:manipulation}
.life-btn:hover{background:rgba(255,255,255,0.25)}
.life-btn:active{transform:scale(0.93)}

/* Extras bar (poison/cmd/color toggles) */
.panel-extras{display:flex;gap:0.25rem;padding:0.375rem;background:rgba(0,0,0,0.15);justify-content:center}
.extras-toggle{display:flex;align-items:center;gap:0.25rem;padding:0.25rem 0.5rem;border:1px solid rgba(255,255,255,0.2);background:rgba(255,255,255,0.1);color:inherit;border-radius:6px;font-size:0.75rem;cursor:pointer;transition:all 0.15s ease}
.extras-toggle:hover{background:rgba(255,255,255,0.2)}
.extras-count{font-weight:700;font-size:0.8125rem}

/* Drawers */
.panel-poison-drawer,.panel-cmd-drawer,.panel-color-drawer{padding:0.5rem 0.75rem;background:rgba(0,0,0,0.2);border-top:1px solid rgba(255,255,255,0.1)}
.drawer-header{font-size:0.75rem;font-weight:600;margin-bottom:0.375rem;opacity:0.8}
.drawer-header i{margin-right:0.25rem}

/* Poison controls */
.poison-controls{display:flex;align-items:center;justify-content:center;gap:0.75rem}
.poison-btn{width:36px;height:36px;border-radius:50%;border:1px solid rgba(255,255,255,0.3);background:rgba(255,255,255,0.1);color:inherit;font-size:1.125rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all 0.15s ease}
.poison-btn:hover{background:rgba(255,255,255,0.25)}
.poison-value{font-size:1.5rem;font-weight:700;min-width:2ch;text-align:center}

/* Commander damage rows */
.cmd-grid{display:flex;flex-direction:column;gap:0.375rem}
.cmd-row{display:flex;align-items:center;gap:0.5rem}
.cmd-opponent{padding:0.2rem 0.5rem;border-radius:4px;font-size:0.75rem;font-weight:600;min-width:60px;text-align:center}
.cmd-btn{width:28px;height:28px;border-radius:50%;border:1px solid rgba(255,255,255,0.3);background:rgba(255,255,255,0.1);color:inherit;font-size:0.875rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center}
.cmd-btn:hover{background:rgba(255,255,255,0.25)}
.cmd-value{font-size:1rem;font-weight:700;min-width:2ch;text-align:center}

/* Color swatches */
.color-swatches{display:flex;flex-wrap:wrap;gap:0.375rem}
.color-swatch{width:32px;height:32px;border-radius:50%;border:2px solid rgba(255,255,255,0.3);cursor:pointer;transition:all 0.15s ease}
.color-swatch:hover{transform:scale(1.15)}
.color-swatch.active{border-color:white;box-shadow:0 0 0 2px rgba(255,255,255,0.5)}

/* ── Eliminated / Warning states ─────────────────────────── */
.mtg-player-panel.life-warning .life-total{animation:lifePulse 1s ease-in-out infinite}
@keyframes lifePulse{0%,100%{opacity:1}50%{opacity:0.5}}
.mtg-player-panel.eliminated-life,.mtg-player-panel.eliminated-poison,.mtg-player-panel.eliminated-cmd{opacity:0.5}
.mtg-player-panel.eliminated-life::after,.mtg-player-panel.eliminated-poison::after,.mtg-player-panel.eliminated-cmd::after{content:'ELIMINATED';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) rotate(-15deg);font-size:2rem;font-weight:900;color:rgba(255,255,255,0.6);text-shadow:0 2px 8px rgba(0,0,0,0.5);z-index:20;pointer-events:none;letter-spacing:0.1em}
.mtg-player-panel.rotated.eliminated-life::after,.mtg-player-panel.rotated.eliminated-poison::after,.mtg-player-panel.rotated.eliminated-cmd::after{transform:translate(-50%,-50%) rotate(165deg)}

/* ── Overlays (coin flip, random) ────────────────────────── */
.mtg-overlay{position:absolute;inset:0;background:rgba(0,0,0,0.8);display:flex;align-items:center;justify-content:center;z-index:100;opacity:0;visibility:hidden;transition:all 0.3s ease;backdrop-filter:blur(4px)}
.mtg-overlay.show{opacity:1;visibility:visible}
.mtg-overlay-content{text-align:center;color:white}

/* Coin */
.coin{width:80px;height:80px;margin:0 auto 1rem;perspective:600px;position:relative}
.coin-face{position:absolute;inset:0;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2rem;backface-visibility:hidden;border:3px solid rgba(255,255,255,0.3)}
.coin-heads{background:linear-gradient(135deg,#f59e0b,#d97706)}
.coin-tails{background:linear-gradient(135deg,#6366f1,#4f46e5);transform:rotateY(180deg)}
.coin.flip-heads{animation:coinFlip 0.6s ease-out forwards}
.coin.flip-tails{animation:coinFlipTails 0.6s ease-out forwards}
@keyframes coinFlip{0%{transform:rotateY(0)}100%{transform:rotateY(720deg)}}
@keyframes coinFlipTails{0%{transform:rotateY(0)}100%{transform:rotateY(900deg)}}
.coin-result-text{font-size:1.5rem;font-weight:700;color:white}

/* Random player */
.random-label{font-size:1rem;color:rgba(255,255,255,0.7);margin-bottom:0.5rem}
.random-name{display:inline-block;padding:0.75rem 2rem;border-radius:12px;font-size:1.5rem;font-weight:700;animation:randomPop 0.4s ease-out}
@keyframes randomPop{0%{transform:scale(0.5);opacity:0}100%{transform:scale(1);opacity:1}}

/* ── History panel ───────────────────────────────────────── */
.mtg-history-panel{position:absolute;top:0;right:0;bottom:0;width:280px;background:var(--bg-primary);border-left:1px solid var(--border-color);z-index:50;transform:translateX(100%);transition:transform 0.3s ease;display:flex;flex-direction:column;overflow-y:auto}
.mtg-history-panel.show{transform:translateX(0)}
.history-header{display:flex;align-items:center;justify-content:space-between;padding:0.75rem 1rem;border-bottom:1px solid var(--border-color)}
.history-header h3{margin:0;font-size:0.9375rem;color:var(--text-primary)}
.history-close{background:none;border:none;color:var(--text-secondary);cursor:pointer;font-size:1rem;padding:0.25rem}
.history-list{flex:1;padding:0.5rem;overflow-y:auto}
.history-row{display:flex;align-items:center;gap:0.5rem;padding:0.375rem 0.5rem;border-bottom:1px solid var(--border-color);font-size:0.8125rem}
.history-icon{color:var(--text-tertiary);width:16px;text-align:center}
.history-name{flex:1;color:var(--text-primary);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.history-delta{font-weight:700;color:var(--primary-color)}
.history-val{color:var(--text-secondary);font-size:0.75rem}
.history-empty{text-align:center;color:var(--text-tertiary);padding:2rem 1rem}

/* ── Format preset cards (landing page) ──────────────────── */
.mtg-format-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;max-width:800px;margin:0 auto}
.format-preset-card{display:flex;flex-direction:column;align-items:center;gap:0.5rem;padding:1.25rem 1rem;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px;cursor:pointer;transition:all 0.2s ease;text-align:center}
.format-preset-card:hover{transform:translateY(-3px);border-color:var(--primary-color);box-shadow:0 8px 24px rgba(43,168,255,0.15)}
.format-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.25rem;color:white;background:var(--preset-color, #3b82f6)}
.format-name{font-size:1rem;font-weight:600;color:var(--text-primary)}
.format-desc{font-size:0.8125rem;color:var(--text-secondary)}

/* ── Fullscreen mode (desktop — BIG) ─────────────────────── */
.mtg-life-counter.is-fullscreen{position:fixed;inset:0;z-index:99999;border-radius:0;border:none;display:flex;flex-direction:column}
.is-fullscreen .mtg-toolbar{flex-shrink:0}
.is-fullscreen .mtg-players{flex:1;min-height:0}
.is-fullscreen .life-total{font-size:10rem}
.is-fullscreen .life-buttons{gap:0.5rem;margin-top:1rem}
.is-fullscreen .life-btn{padding:0.625rem 1rem;font-size:1rem;border-radius:8px}
.is-fullscreen .player-name-input{font-size:1.125rem}
.is-fullscreen .panel-extras{padding:0.5rem}
.is-fullscreen .extras-toggle{padding:0.375rem 0.75rem;font-size:0.875rem}

/* ── DESKTOP large (non-fullscreen but big) ──────────────── */
@media (min-width:1025px){
    .mtg-players{min-height:600px}
    .life-total{font-size:7rem}
}

/* ── TABLET ──────────────────────────────────────────────── */
@media (max-width:1024px) and (min-width:769px){
    .mtg-players{min-height:480px}
    .life-total{font-size:5rem}
    .mtg-format-grid{grid-template-columns:repeat(2,1fr)}
}

/* ─────────────────────────────────────────────────────────
   MOBILE — "Menutized" compact layout
   ───────────────────────────────────────────────────────── */
@media (max-width:768px){
    .mtg-life-counter{border-radius:12px}

    /* Toolbar compacts */
    .mtg-toolbar{padding:0.375rem 0.5rem;gap:0.25rem}
    .mtg-select{font-size:0.75rem;padding:0.25rem 0.375rem}
    .mtg-tool-btn{width:30px;height:30px;font-size:0.75rem}
    .pcount-btn{padding:0.2rem 0.5rem;font-size:0.6875rem}

    /* Stack players vertically — each panel fills half the viewport */
    .mtg-players{display:flex;flex-direction:column;min-height:auto;gap:0}
    .players-2,.players-3,.players-4{display:flex;flex-direction:column}
    .players-2 .mtg-player-panel{flex:1;min-height:40vh}
    .players-3 .mtg-player-panel{flex:1;min-height:28vh}
    .players-4 .mtg-player-panel{flex:1;min-height:22vh}
    .players-3 .mtg-player-panel:last-child{grid-column:auto}

    /* Enable rotation on mobile for across-the-table play */
    .mtg-player-panel.rotated{transform:rotate(180deg)}
    .mtg-player-panel.rotated .panel-extras{transform:rotate(180deg)}

    /* Panel stays vertical on mobile — just more compact */
    .mtg-player-panel{border-radius:0}
    .panel-main{min-height:auto;flex-direction:column;align-items:center}

    /* Hide tap zones on mobile (use buttons instead) */
    .life-tap-zone{display:none}

    /* Center content stays vertical */
    .panel-center{flex-direction:column;gap:0.25rem;padding:0.75rem 0.5rem;align-items:center;flex:1;justify-content:center}

    .player-name-input{font-size:0.8125rem;max-width:120px;text-align:center;margin-bottom:0}

    .life-total{font-size:4rem}

    .life-delta-flash{font-size:1.25rem}

    .life-buttons{gap:4px;margin-top:0.375rem;flex-wrap:nowrap}
    .life-btn{padding:0.3rem 0.625rem;font-size:0.8125rem;border-radius:6px}

    /* Compact extras */
    .panel-extras{padding:0.25rem 0.5rem;gap:4px;justify-content:center}
    .extras-toggle{padding:0.2rem 0.5rem;font-size:0.75rem}
    .extras-count{font-size:0.75rem}

    /* Drawers */
    .panel-poison-drawer,.panel-cmd-drawer,.panel-color-drawer{padding:0.375rem 0.5rem}
    .poison-btn{width:30px;height:30px;font-size:0.875rem}
    .poison-value{font-size:1.125rem}
    .cmd-btn{width:24px;height:24px;font-size:0.75rem}
    .cmd-opponent{font-size:0.6875rem;min-width:50px}
    .color-swatch{width:28px;height:28px}

    /* Eliminated text smaller */
    .mtg-player-panel.eliminated-life::after,.mtg-player-panel.eliminated-poison::after,.mtg-player-panel.eliminated-cmd::after{font-size:1.125rem}

    /* History panel full width on mobile */
    .mtg-history-panel{width:100%}

    /* Format presets */
    .mtg-format-grid{grid-template-columns:repeat(2,1fr);gap:0.75rem}
    .format-preset-card{padding:1rem 0.75rem}
    .format-icon{width:40px;height:40px;font-size:1rem}

    /* Fullscreen on mobile — panels fill screen */
    .is-fullscreen .mtg-players{flex-direction:column}
    .is-fullscreen .life-total{font-size:5rem}
    .is-fullscreen .life-tap-zone{display:none}
    .is-fullscreen .players-2 .mtg-player-panel{min-height:45vh}
}

/* ── Extra-small mobile ──────────────────────────────────── */
@media (max-width:400px){
    .life-total{font-size:2rem}
    .life-btn{padding:0.25rem 0.375rem;font-size:0.6875rem}
    .player-name-input{max-width:70px;font-size:0.75rem}
    .mtg-format-grid{grid-template-columns:1fr 1fr}
}

/* ── Extras bar overflow (scrollable when many toggles) ──── */
.panel-extras{flex-wrap:wrap;gap:0.25rem 0.375rem}

/* ── Generic counter controls (energy, exp, rad, ticket) ── */
.generic-counter-controls{display:flex;align-items:center;justify-content:center;gap:0.75rem}
.generic-counter-value{font-size:1.5rem;font-weight:700;min-width:2ch;text-align:center}

/* ── Ring tempts you ─────────────────────────────────────── */
.ring-levels{display:flex;flex-direction:column;gap:0.25rem}
.ring-level{display:flex;align-items:center;gap:0.5rem;padding:0.375rem 0.5rem;border-radius:6px;cursor:pointer;font-size:0.75rem;opacity:0.5;transition:all 0.15s ease;border:1px solid transparent}
.ring-level:hover{opacity:0.8;background:rgba(255,255,255,0.1)}
.ring-level.ring-active{opacity:1;background:rgba(255,255,255,0.15);border-color:rgba(255,255,255,0.2)}
.ring-pip{font-size:1rem;flex-shrink:0;width:1.25rem;text-align:center}
.ring-text{line-height:1.3}

/* ── State tracker bar (monarch, initiative, day/night, storm) ── */
.mtg-state-tracker{display:flex;flex-wrap:wrap;gap:0.5rem;padding:0.5rem 0.75rem;background:var(--bg-tertiary);border-bottom:1px solid var(--border-color);align-items:center}
.state-row{display:flex;align-items:center;gap:0.375rem;flex-shrink:0}
.state-label{font-size:0.75rem;font-weight:600;color:var(--text-secondary);white-space:nowrap;display:flex;align-items:center;gap:0.25rem}
.state-label i{font-size:0.7rem}
.state-player-btns{display:flex;gap:2px}
.state-player-btn{padding:0.2rem 0.5rem;border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-secondary);border-radius:4px;font-size:0.6875rem;font-weight:600;cursor:pointer;transition:all 0.15s ease;white-space:nowrap}
.state-player-btn:hover{background:var(--bg-hover)}
.state-player-btn.state-active{background:var(--sbg, var(--primary-color));color:var(--stxt, white);border-color:transparent;box-shadow:0 1px 4px rgba(0,0,0,0.2)}
.state-storm-controls{display:flex;align-items:center;gap:0.375rem}
.state-storm-controls .poison-btn{width:24px;height:24px;font-size:0.8rem}
.storm-value{font-size:1rem;font-weight:700;min-width:1.5ch;text-align:center;color:var(--text-primary)}

/* Monarch & Initiative visual badges on player panels */
.mtg-player-panel.has-monarch::before{content:'👑';position:absolute;top:0.5rem;left:0.5rem;font-size:1.5rem;z-index:15;filter:drop-shadow(0 2px 4px rgba(0,0,0,0.3));animation:crownBob 2s ease-in-out infinite}
@keyframes crownBob{0%,100%{transform:translateY(0)}50%{transform:translateY(-3px)}}
.mtg-player-panel.has-initiative::before{content:'⚔️';position:absolute;top:0.5rem;left:0.5rem;font-size:1.5rem;z-index:15;filter:drop-shadow(0 2px 4px rgba(0,0,0,0.3))}
.mtg-player-panel.has-monarch.has-initiative::after{content:'⚔️';position:absolute;top:0.5rem;left:2.5rem;font-size:1.5rem;z-index:15;filter:drop-shadow(0 2px 4px rgba(0,0,0,0.3))}

/* ── Responsive: state tracker ───────────────────────────── */
@media (max-width:600px){
    .mtg-state-tracker{gap:0.375rem;padding:0.375rem 0.5rem}
    .state-row{flex-wrap:nowrap}
    .state-player-btn{padding:0.15rem 0.375rem;font-size:0.625rem}
    .state-label{font-size:0.6875rem}
}
