*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{background:#1a1a2e;color:#e0e0e0;font-family:Georgia,Times New Roman,serif;height:100vh;overflow:hidden}#root{height:100vh}.setup-screen{height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse at center,#1e2a4a,#1a1a2e)}.setup-card{background:#16213e;border:1px solid #334;border-radius:16px;padding:48px 56px;width:420px;text-align:center}.setup-card h1{font-size:2rem;margin-bottom:8px;color:#f0d9b5}.setup-card .subtitle{color:#888;font-size:.9rem;margin-bottom:32px;font-style:italic}.setup-card label{display:block;text-align:left;font-size:.85rem;color:#aaa;margin-bottom:6px}.setup-card input[type=password]{width:100%;background:#0f1b35;border:1px solid #334;border-radius:8px;color:#e0e0e0;padding:10px 14px;font-size:.95rem;margin-bottom:16px;outline:none;transition:border-color .2s}.setup-card input[type=password]:focus{border-color:#4a6fa5}.setup-card .error{color:#f66;font-size:.8rem;margin-bottom:12px;min-height:1.2em}.btn-primary{background:#2d5a9e;border:none;border-radius:8px;color:#fff;cursor:pointer;font-family:Georgia,serif;font-size:1rem;padding:12px 32px;width:100%;transition:background .2s}.btn-primary:hover{background:#3a6fbf}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.saved-game-section{margin-bottom:24px;padding-bottom:24px;border-bottom:1px solid #2a2a4a}.saved-game-hint{margin-top:10px;font-size:.75rem;color:#555}.btn-load-file{background:none;border:1px solid #334;border-radius:8px;color:#888;cursor:pointer;font-family:Georgia,serif;font-size:.8rem;padding:7px 16px;width:100%;margin-bottom:16px;transition:border-color .2s,color .2s}.btn-load-file:hover{border-color:#4a6fa5;color:#ccc}.timer-input{width:100%;background:#0f1b35;border:1px solid #334;border-radius:8px;color:#e0e0e0;padding:8px 12px;font-size:.95rem;font-family:Georgia,serif;margin-top:8px;outline:none;transition:border-color .2s}.timer-input:focus{border-color:#4a6fa5}.difficulty-section{margin-bottom:16px;text-align:left}.difficulty-row{display:flex;gap:8px;margin-top:8px}.difficulty-btn{flex:1;background:#0f1b35;border:1px solid #334;border-radius:8px;color:#888;cursor:pointer;font-family:Georgia,serif;font-size:.82rem;padding:8px 0;transition:border-color .2s,color .2s}.difficulty-btn:hover{border-color:#4a6fa5;color:#ccc}.difficulty-btn.active{border-color:#4a6fa5;color:#f0d9b5;background:#1a2a4a}.game-view{display:flex;height:100vh}.board-area{flex:0 0 60%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px}.board-wrapper{position:relative}.chess-board{display:grid;grid-template-columns:repeat(8,1fr);grid-template-rows:repeat(8,1fr);width:min(54vw,86vh);height:min(54vw,86vh);border:2px solid #444;box-shadow:0 8px 32px #000000b3}.square{display:flex;align-items:center;justify-content:center;position:relative;cursor:default;font-size:clamp(1.4rem,3.2vw,2.8rem);-webkit-user-select:none;user-select:none;transition:filter .1s}.square.light{background:#f0d9b5}.square.dark{background:#b58863}.square.clickable{cursor:pointer}.square.clickable:hover{filter:brightness(1.15)}.square.selected{background:#f88!important;box-shadow:inset 0 0 0 3px #c00}.square.consented-dest{background:#5c5!important;cursor:pointer}.square.consented-dest:after{content:"";position:absolute;width:32%;height:32%;border-radius:50%;background:#00a00080;pointer-events:none}.square.consented-dest.has-piece:after{display:none}.square.consented-dest.has-piece{box-shadow:inset 0 0 0 3px #080}.square.in-check{background:#f44!important}.piece-glyph{pointer-events:none;line-height:1}.piece-white{color:#f5ead0;text-shadow:0 0 3px #000,0 1px 3px #000,-1px 0 2px #000,1px 0 2px #000}.piece-black{color:#1a1020;text-shadow:0 0 3px #d4b896,0 1px 3px #c4a87a,-1px 0 2px #c4a87a,1px 0 2px #c4a87a}.consent-dot{position:absolute;top:3px;right:4px;width:8px;height:8px;border-radius:50%;background:#0f8;pointer-events:none}.board-labels-wrap{display:flex;flex-direction:column;align-items:flex-start}.board-rank-files{display:flex}.rank-labels{display:flex;flex-direction:column;justify-content:space-around;width:18px;height:min(54vw,86vh);font-size:1rem;color:#666;text-align:center;padding:2px 0}.file-labels{display:flex;justify-content:space-around;width:min(54vw,86vh);margin-left:18px;font-size:1rem;color:#666;padding:2px 0}.side-panel{flex:0 0 40%;display:flex;flex-direction:column;background:#13192e;border-left:1px solid #2a2a4a;overflow:hidden}.turn-timer{padding:10px 16px;background:#0f1b35;border-bottom:1px solid #2a2a4a;font-size:1.3rem;font-weight:700;text-align:center;letter-spacing:2px}.turn-timer.normal{color:#0c8}.turn-timer.warning{color:#fa0}.turn-timer.urgent{color:#f44;animation:pulse .6s infinite alternate}.turn-timer.paused{color:#aaa;font-size:.9rem;letter-spacing:0}.turn-timer.other{color:#666;font-size:.9rem;letter-spacing:0}@keyframes pulse{0%{opacity:1}to{opacity:.45}}.timer-sub{font-size:.7rem;color:#666;font-weight:400;letter-spacing:0;margin-top:2px}.piece-status-panel{flex:0 0 auto;border-bottom:1px solid #2a2a4a;background:#0f1b35;max-height:110px;overflow-y:auto}.piece-status-header{padding:4px 12px;font-size:.65rem;color:#444;text-transform:uppercase;letter-spacing:1px;border-bottom:1px solid #1a1a30;position:sticky;top:0;background:#0f1b35}.piece-status-list{display:flex;flex-wrap:wrap;gap:2px;padding:4px 6px}.piece-status-item{display:flex;align-items:center;gap:3px;padding:2px 6px;border-radius:4px;cursor:pointer;font-size:.72rem;color:#aaa;transition:background .15s;position:relative}.piece-status-item:hover{background:#1a2a50}.piece-status-item.selected{background:#1e3a6a;color:#f0d9b5}.piece-status-item.dead{opacity:.3;cursor:default;text-decoration:line-through}.ps-glyph{font-size:.9rem;line-height:1;color:#f5ead0;text-shadow:0 0 2px #000}.ps-name{font-size:.68rem}.ps-square{font-size:.62rem;color:#666}.ps-dot{width:6px;height:6px;border-radius:50%;background:#0f8;flex-shrink:0}.chat-panel{flex:1 1 0;display:flex;flex-direction:column;overflow:hidden}.chat-header{padding:10px 14px;background:#1a2240;border-bottom:1px solid #2a2a4a;font-size:.85rem}.chat-header .piece-name{font-size:1rem;font-weight:700;color:#f0d9b5}.chat-header .piece-meta{color:#888;font-size:.75rem;margin-top:2px}.chat-header .consent-status{color:#0c8;font-size:.75rem;margin-top:4px}.chat-header .consent-status.none{color:#666}.chat-messages{flex:1 1 0;overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:8px}.no-piece-msg{flex:1 1 0;display:flex;align-items:center;justify-content:center;color:#444;font-style:italic;font-size:.85rem;padding:20px;text-align:center}.msg{padding:8px 12px;border-radius:10px;font-size:.85rem;line-height:1.5;max-width:88%;white-space:pre-wrap;word-break:break-word}.msg.user{align-self:flex-end;background:#1e4070;border-radius:12px 12px 2px}.msg.assistant{align-self:flex-start;background:#242444;border-radius:12px 12px 12px 2px}.msg.system-note{align-self:center;background:transparent;color:#555;font-size:.75rem;font-style:italic}.chat-input-area{padding:10px 12px;border-top:1px solid #2a2a4a;display:flex;gap:8px;background:#0f1b35}.chat-input-area input{flex:1;background:#1e2a4a;border:1px solid #334;border-radius:6px;color:#e0e0e0;font-family:Georgia,serif;font-size:.85rem;outline:none;padding:8px 10px;transition:border-color .2s}.chat-input-area input:focus{border-color:#4a6fa5}.chat-input-area input:disabled{opacity:.5}.chat-input-area button{background:#2d5a9e;border:none;border-radius:6px;color:#fff;cursor:pointer;font-family:Georgia,serif;font-size:.85rem;padding:8px 14px;transition:background .2s;white-space:nowrap}.chat-input-area button:hover:not(:disabled){background:#3a6fbf}.chat-input-area button:disabled{opacity:.5;cursor:not-allowed}.event-log{flex:0 0 28%;min-height:100px;border-top:1px solid #2a2a4a;overflow-y:auto;background:#0c1020}.event-log-header{padding:6px 12px;font-size:.7rem;color:#444;text-transform:uppercase;letter-spacing:1px;border-bottom:1px solid #1a1a30;position:sticky;top:0;background:#0c1020;display:flex;align-items:center;justify-content:space-between}.btn-export{background:none;border:1px solid #2a2a40;border-radius:4px;color:#444;cursor:pointer;font-family:Georgia,serif;font-size:.65rem;padding:2px 7px;text-transform:none;letter-spacing:0;transition:border-color .2s,color .2s}.btn-export:hover{border-color:#4a6fa5;color:#aaa}.event-log-entries{padding:4px 0}.event-entry{padding:3px 12px;font-size:.75rem;line-height:1.4;color:#666}.event-entry.capture{color:#c55}.event-entry.broken_promise{color:#c80}.event-entry.check{color:#f90;font-weight:700}.event-entry.promotion{color:#8cf}.event-entry.turn_expired{color:#555;font-style:italic}.event-entry.game_over{color:#f66;font-weight:700}.event-entry.morale{color:#96c;font-style:italic}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000c7;display:flex;align-items:center;justify-content:center;z-index:100}.overlay-card{background:#16213e;border:1px solid #445;border-radius:16px;padding:48px 64px;text-align:center;max-width:420px}.overlay-card h2{font-size:2rem;margin-bottom:12px;color:#f0d9b5}.overlay-card p{color:#aaa;margin-bottom:28px;font-size:.95rem}.btn-secondary{background:transparent;border:1px solid #445;border-radius:8px;color:#aaa;cursor:pointer;font-family:Georgia,serif;font-size:.9rem;padding:10px 24px;transition:all .2s;margin:4px}.btn-secondary:hover{border-color:#667;color:#ccc}.promotion-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:200}.promotion-card{background:#16213e;border:1px solid #445;border-radius:12px;padding:28px 32px;text-align:center}.promotion-card p{margin-bottom:16px;color:#aaa;font-size:.9rem}.promotion-options{display:flex;gap:12px}.promotion-option{font-size:2.8rem;cursor:pointer;padding:8px 12px;border-radius:8px;transition:background .15s;line-height:1}.promotion-option:hover{background:#2a2a4a}.resign-btn{margin:8px 12px 0;background:transparent;border:1px solid #332;border-radius:6px;color:#555;cursor:pointer;font-family:Georgia,serif;font-size:.75rem;padding:4px 10px;transition:all .2s;align-self:flex-start}.resign-btn:hover{border-color:#664;color:#888}@media(max-width:820px){.game-view{flex-direction:column}.board-area{flex:0 0 55%;padding:10px}.chess-board{width:min(90vw,50vh);height:min(90vw,50vh)}.rank-labels{height:min(90vw,50vh)}.file-labels{width:min(90vw,50vh)}.side-panel{flex:1 1 0;border-left:none;border-top:1px solid #2a2a4a}}
