:root{--ww-brand: #667eea;--ww-brand-muted: rgba(102, 126, 234, .1);--ww-brand-ring: rgba(102, 126, 234, .2);--ww-gradient: linear-gradient(135deg, #667eea, #764ba2);--ww-error: #dc2626;--ww-error-muted: rgba(220, 38, 38, .12);--ww-text-primary: #f0f0f5;--ww-text-secondary: #b0b3c0;--ww-text-muted: #7a7e8c;--ww-text-faint: #555866;--ww-bg-page: #1a1a2e;--ww-bg-card: #242440;--ww-bg-elevated: #2e2e4a;--ww-bg-inset: #1e1e34;--ww-border: #3a3a58;--ww-border-light: #2e2e4a;--ww-overlay: rgba(0, 0, 0, .6);--ww-text-2xl: 32px;--ww-text-xl: 20px;--ww-text-lg: 16px;--ww-text-md: 14px;--ww-text-sm: 13px;--ww-text-xs: 12px;--ww-space-xs: 4px;--ww-space-sm: 8px;--ww-space-md: 12px;--ww-space-lg: 16px;--ww-space-xl: 20px;--ww-space-2xl: 24px;--ww-space-3xl: 32px;--ww-radius-xl: 16px;--ww-radius-lg: 12px;--ww-radius-md: 8px;--ww-radius-sm: 6px;--ww-radius-xs: 4px;--ww-radius-full: 9999px;--ww-shadow-sm: 0 1px 3px rgba(0, 0, 0, .2);--ww-shadow-md: 0 4px 12px rgba(0, 0, 0, .25);--ww-shadow-lg: 0 8px 24px rgba(0, 0, 0, .35);--ww-shadow-xl: 0 16px 48px rgba(0, 0, 0, .45);--ww-duration-fast: .15s;--ww-duration-normal: .25s;--ww-ease: ease}@media(prefers-reduced-motion:reduce){:root{--ww-duration-fast: 0ms;--ww-duration-normal: 0ms}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;background:var(--ww-bg-page);color:var(--ww-text-primary);font-size:var(--ww-text-md);line-height:1.5;-webkit-font-smoothing:antialiased}button,input{font-family:inherit}.btn-primary{padding:var(--ww-space-md) var(--ww-space-3xl);border:none;border-radius:var(--ww-radius-md);background:var(--ww-gradient);color:#fff;font-size:var(--ww-text-lg);font-weight:600;cursor:pointer;transition:opacity var(--ww-duration-fast) var(--ww-ease);box-shadow:var(--ww-shadow-sm)}.btn-primary:hover{opacity:.9}.btn-primary:active{opacity:.85}.btn-primary:disabled{background:var(--ww-bg-elevated);color:var(--ww-text-faint);cursor:not-allowed;box-shadow:none;opacity:1}.btn-secondary{padding:var(--ww-space-md) var(--ww-space-2xl);border:1px solid var(--ww-border);border-radius:var(--ww-radius-md);background:var(--ww-bg-elevated);color:var(--ww-text-secondary);font-size:var(--ww-text-lg);font-weight:500;cursor:pointer;transition:all var(--ww-duration-fast) var(--ww-ease)}.btn-secondary:hover,.btn-secondary:active{background:var(--ww-bg-card)}.btn-danger{padding:10px var(--ww-space-xl);border:none;border-radius:var(--ww-radius-md);background:var(--ww-error);color:#fff;font-size:var(--ww-text-md);font-weight:600;cursor:pointer;transition:opacity var(--ww-duration-fast) var(--ww-ease)}.btn-danger:hover{opacity:.9}.btn-danger:active{opacity:.85}.setup-wizard{max-width:480px;margin:0 auto;padding:var(--ww-space-xl)}.wizard-progress{display:flex;justify-content:center;gap:var(--ww-space-lg);margin-bottom:var(--ww-space-3xl)}.progress-dot{width:36px;height:36px;border-radius:var(--ww-radius-full);display:flex;align-items:center;justify-content:center;background:var(--ww-bg-elevated);color:var(--ww-text-muted);font-weight:600;font-size:var(--ww-text-md);transition:all var(--ww-duration-normal) var(--ww-ease)}.progress-dot.active{background:var(--ww-gradient);color:#fff}.app-title{text-align:center;font-size:var(--ww-text-2xl);font-weight:700;margin-bottom:var(--ww-space-sm);color:var(--ww-brand);background:var(--ww-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-img{display:block;width:100%;height:auto;max-width:320px;margin:0 auto var(--ww-space-lg);border-radius:var(--ww-radius-xl);box-shadow:var(--ww-shadow-md)}.app-desc{text-align:center;color:var(--ww-text-muted);font-size:var(--ww-text-md);line-height:1.6;margin-bottom:var(--ww-space-3xl)}.step h2{text-align:center;margin-bottom:var(--ww-space-2xl);font-size:var(--ww-text-xl);font-weight:700}.stepper{display:flex;align-items:center;justify-content:center;gap:var(--ww-space-xl)}.stepper.compact{gap:var(--ww-space-md);margin-bottom:var(--ww-space-lg)}.stepper-btn{width:48px;height:48px;border-radius:var(--ww-radius-full);border:2px solid var(--ww-brand);background:transparent;color:var(--ww-brand);font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--ww-duration-fast) var(--ww-ease)}.stepper-btn:hover:not(:disabled){background:var(--ww-brand-muted)}.stepper-btn:active:not(:disabled){background:var(--ww-brand);color:#fff}.stepper-btn:disabled{border-color:var(--ww-border);color:var(--ww-text-faint);cursor:not-allowed}.stepper-btn.small{width:36px;height:36px;font-size:18px}.stepper-value{font-size:48px;font-weight:700;min-width:60px;text-align:center}.stepper-value.small-value{font-size:18px;font-weight:600;min-width:50px;color:var(--ww-text-secondary)}.hint{text-align:center;color:var(--ww-text-muted);margin-top:var(--ww-space-md);font-size:var(--ww-text-sm)}.name-list{display:flex;flex-direction:column;gap:var(--ww-space-sm)}.name-row{display:flex;align-items:center;gap:var(--ww-space-sm)}.name-row label{min-width:28px;text-align:right;color:var(--ww-text-muted);font-size:var(--ww-text-sm)}.name-row input{flex:1;padding:10px 14px;border:2px solid var(--ww-border);border-radius:var(--ww-radius-md);background:var(--ww-bg-inset);color:var(--ww-text-primary);font-size:var(--ww-text-lg);transition:border-color var(--ww-duration-fast) var(--ww-ease),box-shadow var(--ww-duration-fast) var(--ww-ease)}.name-row input:focus,.add-custom input:focus{outline:none;border-color:var(--ww-brand);box-shadow:0 0 0 3px var(--ww-brand-ring)}.add-player-row{display:flex;align-items:center;gap:var(--ww-space-sm)}.add-player-row .add-spacer{min-width:28px}.add-player-row .add-spacer-end{width:32px;flex-shrink:0}.add-player-btn{flex:1;padding:10px;border:2px dashed var(--ww-border);border-radius:var(--ww-radius-md);background:transparent;color:var(--ww-text-muted);font-size:var(--ww-text-md);font-weight:500;cursor:pointer;transition:all var(--ww-duration-fast) var(--ww-ease)}.add-player-btn:hover{border-color:var(--ww-brand);color:var(--ww-brand)}.add-player-btn:active{border-color:var(--ww-brand);color:var(--ww-brand);background:var(--ww-brand-muted)}.remove-player-btn{width:32px;height:32px;border:none;background:transparent;color:var(--ww-text-muted);font-size:20px;cursor:pointer;border-radius:var(--ww-radius-full);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all var(--ww-duration-fast) var(--ww-ease)}.remove-player-btn:hover{color:var(--ww-error)}.remove-player-btn:active{background:var(--ww-error-muted);color:var(--ww-error)}.role-list{display:flex;flex-direction:column;gap:var(--ww-space-sm);margin-bottom:var(--ww-space-lg)}.role-row{display:flex;align-items:center;justify-content:space-between;padding:var(--ww-space-sm) var(--ww-space-md);background:var(--ww-bg-card);border:1px solid var(--ww-border-light);border-radius:var(--ww-radius-md)}.role-name{display:flex;align-items:center;gap:6px;font-size:var(--ww-text-lg);font-weight:500}.role-controls{display:flex;align-items:center;gap:var(--ww-space-sm)}.role-count{min-width:24px;text-align:center;font-size:18px;font-weight:700}.remove-btn{width:28px;height:28px;border:none;background:var(--ww-error);color:#fff;border-radius:var(--ww-radius-full);font-size:var(--ww-text-lg);cursor:pointer;display:flex;align-items:center;justify-content:center;margin-left:var(--ww-space-xs);transition:opacity var(--ww-duration-fast) var(--ww-ease)}.remove-btn:active{opacity:.8}.add-custom{display:flex;gap:var(--ww-space-sm);margin-bottom:var(--ww-space-xl)}.add-custom input{flex:1;padding:10px 14px;border:2px solid var(--ww-border);border-radius:var(--ww-radius-md);background:var(--ww-bg-inset);color:var(--ww-text-primary);font-size:var(--ww-text-lg);transition:border-color var(--ww-duration-fast) var(--ww-ease),box-shadow var(--ww-duration-fast) var(--ww-ease)}.role-summary{display:flex;justify-content:space-around;padding:var(--ww-space-md);background:var(--ww-bg-inset);border:1px solid var(--ww-border-light);border-radius:var(--ww-radius-md);font-size:var(--ww-text-sm);color:var(--ww-text-secondary)}.role-summary .error{color:var(--ww-error);font-weight:700}.wizard-actions{display:flex;justify-content:center;gap:var(--ww-space-md);margin-top:var(--ww-space-3xl)}.player-card{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:var(--ww-bg-elevated);border:1px solid var(--ww-border-light);border-radius:var(--ww-radius-md);cursor:grab;touch-action:none;user-select:none;min-height:44px;transition:opacity var(--ww-duration-normal) var(--ww-ease),background var(--ww-duration-normal) var(--ww-ease)}.player-card:active{cursor:grabbing}.player-card.dead{opacity:.4;background:var(--ww-bg-inset)}.player-card.dead .player-name{text-decoration:line-through;color:var(--ww-text-muted)}.player-card.overlay{box-shadow:var(--ww-shadow-lg);z-index:1000}.player-name{font-size:var(--ww-text-md);font-weight:500;color:var(--ww-text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.card-actions{display:flex;align-items:center;gap:4px;flex-shrink:0}.death-btn{width:36px;height:36px;border:none;background:transparent;font-size:18px;cursor:pointer;border-radius:var(--ww-radius-full);display:flex;align-items:center;justify-content:center;padding:0;transition:background var(--ww-duration-fast) var(--ww-ease)}.death-btn:hover{background:var(--ww-brand-muted)}.death-btn:active{background:#667eea33}.player-card.potion-target-over{outline:2px solid var(--ww-brand);outline-offset:-2px;background:var(--ww-brand-muted)}.potion-indicator{width:28px;height:28px;border:none;border-radius:var(--ww-radius-full);display:flex;align-items:center;justify-content:center;padding:0;cursor:pointer;transition:background var(--ww-duration-fast) var(--ww-ease)}.potion-indicator.antidote{background:#16a34a33}.potion-indicator.antidote:hover{background:#16a34a59}.potion-indicator.poison{background:#9333ea33}.potion-indicator.poison:hover{background:#9333ea59}.game-board{max-width:600px;margin:0 auto;padding:var(--ww-space-lg)}.board-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--ww-space-xl)}.board-header h1{font-size:var(--ww-text-xl);font-weight:700;margin:0}.header-actions{display:flex;gap:var(--ww-space-sm)}.btn-new-round{padding:var(--ww-space-sm) var(--ww-space-lg);border:1px solid var(--ww-brand);border-radius:var(--ww-radius-md);background:var(--ww-brand-muted);color:var(--ww-brand);font-size:var(--ww-text-md);font-weight:500;cursor:pointer;transition:all var(--ww-duration-fast) var(--ww-ease)}.btn-new-round:hover{background:#667eea2e}.btn-new-round:active{background:var(--ww-brand);color:#fff}.btn-reset{padding:var(--ww-space-sm) var(--ww-space-lg);border:1px solid var(--ww-error);border-radius:var(--ww-radius-md);background:var(--ww-error-muted);color:var(--ww-error);font-size:var(--ww-text-md);font-weight:500;cursor:pointer;transition:all var(--ww-duration-fast) var(--ww-ease)}.btn-reset:hover{background:#dc26262e}.btn-reset:active{background:var(--ww-error);color:#fff}.zones-container{display:flex;flex-direction:column;gap:var(--ww-space-lg)}.role-zone{border:2px solid var(--ww-border);border-radius:var(--ww-radius-lg);padding:var(--ww-space-md);transition:border-color var(--ww-duration-fast) var(--ww-ease),background var(--ww-duration-fast) var(--ww-ease);min-height:60px}.role-zone.over{border-color:var(--ww-brand);background:var(--ww-brand-muted)}.role-zone.full-warning{border-color:var(--ww-error);background:var(--ww-error-muted)}.zone-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--ww-space-sm)}.zone-label{display:flex;align-items:center;gap:6px;font-size:var(--ww-text-lg);font-weight:600;color:var(--ww-text-secondary)}.zone-capacity{font-size:var(--ww-text-sm);color:var(--ww-text-muted)}.zone-capacity.at-cap{color:var(--ww-error);font-weight:700}.zone-players{display:flex;flex-direction:column;gap:var(--ww-space-sm)}.confirm-overlay{position:fixed;inset:0;background:var(--ww-overlay);display:flex;align-items:center;justify-content:center;z-index:2000}.confirm-dialog{background:var(--ww-bg-card);border:1px solid var(--ww-border);border-radius:var(--ww-radius-xl);padding:var(--ww-space-2xl);max-width:320px;width:90%;text-align:center;box-shadow:var(--ww-shadow-xl)}.confirm-dialog p{margin-bottom:var(--ww-space-xl);font-size:var(--ww-text-lg);line-height:1.5;color:var(--ww-text-secondary)}.confirm-actions{display:flex;justify-content:center;gap:var(--ww-space-md)}.witch-potions{display:flex;gap:var(--ww-space-sm);margin-bottom:var(--ww-space-md)}.potion-btn{width:64px;height:64px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:0;border-radius:var(--ww-radius-md);font-size:var(--ww-text-xs, 11px);font-weight:600;cursor:pointer;touch-action:none;user-select:none;transition:all var(--ww-duration-fast) var(--ww-ease)}.potion-btn.potion-overlay{box-shadow:var(--ww-shadow-lg);z-index:1000}.potion-btn.antidote{border:1px solid #16a34a;background:#16a34a26;color:#4ade80}.potion-btn.antidote:hover{background:#16a34a40}.potion-btn.poison{border:1px solid #9333ea;background:#9333ea26;color:#c084fc}.potion-btn.poison:hover{background:#9333ea40}.potion-btn.used{opacity:.4;text-decoration:line-through}.app{min-height:100dvh;padding:var(--ww-space-lg) 0}
