:root{--background: #000000;--text-light: #f0f0f0;--text-dark: #a0a0a0;--accent: #4a90e2;--accent-dark: #3a7bc8;--capture-glow-color: #e24a4a;--highlight-selected: rgba(245, 166, 35, .7);--modal-bg: rgba(42, 42, 42, .98);--modal-border: #555;--input-bg: #2a2a2a;--button-bg: #333;--button-hover-bg: #444;--font-family: "Space Mono", monospace;--error-red: #c84a4a;--gdm-bg-color: #000000;--gdm-light-square: #3D3D3D;--gdm-dark-square: #2A2A2A;--gdm-glow-color: #00aaff;--gdm-white-piece-glow: #ffffff}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-family);background-color:var(--gdm-bg-color);color:var(--text-light);display:flex;justify-content:center;align-items:center;height:100dvh;overflow:hidden;transition:background-color .3s ease}.App{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:1rem;width:100%;height:100dvh;max-height:100dvh;overflow:hidden;position:relative;background-color:var(--gdm-bg-color);transition:background-color .3s ease}.header-actions{display:flex;gap:.5rem;position:absolute;top:0;left:0;z-index:10}.icon-btn{background:none;border:none;cursor:pointer;padding:.5rem;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background-color .2s;color:var(--text-light);font-size:24px}.icon-btn:hover{background-color:#ffffff1a}.icon-btn:disabled{color:#555;cursor:not-allowed;background-color:transparent}.game-container{flex-grow:1;width:100%;display:flex;justify-content:center;align-items:flex-start;gap:2rem;padding:3rem 1rem 1rem;min-height:0}.left-panel{display:flex;flex-direction:column;align-items:flex-start;gap:1rem;flex-shrink:0;position:relative;padding-top:48px}@keyframes pulse{0%{box-shadow:0 0 #c84a4ab3}70%{box-shadow:0 0 0 10px #c84a4a00}to{box-shadow:0 0 #c84a4a00}}.error-message{text-align:center;color:var(--error-red)}.error-screen{display:flex;flex-direction:column;justify-content:center;align-items:center;height:100vh;font-size:1.2rem;color:var(--error-red);padding:2rem;text-align:center}.square{display:flex;justify-content:center;align-items:center;position:relative;cursor:pointer;transition:box-shadow .1s ease-out}.piece-layer{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:3}.chess-piece{position:absolute;top:0;left:0;width:12.5%;height:12.5%;display:flex;justify-content:center;align-items:center;text-shadow:0 2px 4px rgba(0,0,0,.4);line-height:1;-webkit-user-select:none;user-select:none;transition:transform .35s cubic-bezier(.4,0,.2,1),text-shadow .3s ease;will-change:transform}.board-container{width:clamp(320px,85vmin,750px);height:clamp(320px,85vmin,750px);position:relative;display:flex;justify-content:center;align-items:center}.chessboard{display:grid;grid-template-columns:repeat(8,1fr);grid-template-rows:repeat(8,1fr);width:100%;height:100%;position:relative;box-shadow:0 0 15px 3px #0af6;border:none;border-radius:0;overflow:visible}.square:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;box-shadow:inset 0 0 0 1px #00aaff40;z-index:1;pointer-events:none}.square.light{background-color:var(--gdm-light-square)}.square.dark{background-color:var(--gdm-dark-square)}.chess-piece.talking,.chess-piece.selected-piece{z-index:6}.square-notation{position:absolute;top:4px;right:6px;color:var(--gdm-glow-color);text-shadow:0 0 2px var(--gdm-glow-color);font-size:clamp(10px,1.5vmin,14px);text-transform:uppercase;z-index:10;font-weight:700;pointer-events:none;opacity:.7;transition:opacity .2s ease-in-out}.chess-piece{font-size:clamp(32px,9vmin,72px)}.chess-piece.white{color:var(--gdm-white-piece-glow);text-shadow:0 0 10px var(--gdm-glow-color),0 0 15px var(--gdm-glow-color),0 0 20px var(--gdm-glow-color)}.chess-piece.black{color:#111;text-shadow:0 0 8px var(--gdm-glow-color),1px 1px 1px transparent,-1px -1px 1px transparent}.square.selected:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;box-shadow:inset 0 0 0 2px #08c;z-index:5;pointer-events:none}.user-talk-glow{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none;z-index:5;transition:box-shadow .05s linear}.animated-orb-glow{position:absolute;top:0;left:0;background:radial-gradient(circle,var(--accent) 15%,transparent 70%);opacity:0;pointer-events:none;z-index:2;transform:translate(-50%,-50%);transition:transform .4s cubic-bezier(.4,0,.2,1),opacity .3s ease,width .2s ease,height .2s ease}.piece-card-placeholder{width:320px;height:clamp(320px,75vmin,700px);flex-shrink:0;border:2px dashed #444;border-radius:16px;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:2rem;text-align:center;color:var(--text-dark);transition:all .2s ease-in-out}.placeholder-content .material-symbols-outlined{font-size:48px;margin-bottom:1rem;opacity:.5}.placeholder-content p{font-size:1rem;line-height:1.5}@media (max-width: 850px) and (orientation: portrait){.header-actions{display:none}.game-container{flex-direction:column;align-items:center;gap:1.5rem;padding:1rem;overflow-y:auto}.left-panel{order:2;width:100%;max-width:400px;gap:0;align-items:center;padding-top:0}.piece-card,.piece-card-placeholder{width:100%;max-width:400px;height:auto;min-height:250px}.board-container,.chessboard{width:100%;max-width:400px;height:auto;order:1;flex-shrink:0}.board-container{height:100vw;max-height:400px}.App{padding:.5rem}}@media (max-height: 550px) and (orientation: landscape){.game-container{flex-direction:row;gap:1.5rem;padding:1rem;overflow:hidden;height:100%;justify-content:center;align-items:flex-start}.left-panel{order:1;width:320px;height:calc(100dvh - 2rem);max-height:500px}.piece-card,.piece-card-placeholder{width:100%;flex-grow:1;min-height:0}.board-container,.chessboard{order:2;width:auto;height:calc(100dvh - 2rem);max-width:none;max-height:500px;aspect-ratio:1/1}}.piece-card{width:100%;max-width:450px;height:auto;min-height:0;background:#2a2a2a;border:2px solid #555;border-radius:16px;overflow:hidden;display:grid;grid-template-rows:auto 1fr;grid-template-columns:100%;box-shadow:0 10px 30px #0006;font-family:var(--font-family);color:var(--text-light);flex-shrink:0;position:relative}@media (min-width: 851px){.piece-card{width:320px;height:clamp(320px,75vmin,700px)}}@media (max-width: 850px){.piece-card{height:100%;border-radius:12px}}.piece-card-image-container{width:100%;aspect-ratio:3 / 4;background-color:#1e1e1e;position:relative;overflow:hidden;border-bottom:2px solid #555;display:block;grid-row:1;grid-column:1;z-index:1}.piece-card-content{padding:1rem 1.5rem;overflow-y:auto;position:relative;grid-row:2;grid-column:1;z-index:5}@media (max-width: 850px),(max-height: 850px){.piece-card{grid-template-rows:100%}.piece-card-image-container{width:100%;height:100%;max-height:none;aspect-ratio:auto;border-bottom:none;background-color:#000;grid-row:1;grid-column:1;z-index:1;transition:z-index 0s linear .2s}.piece-card-image-container.editing-image{z-index:25;transition:none}.piece-card-image-container:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(to bottom,#0009,#0009 15%,#000c 50%,#000000f2 90%,#000);pointer-events:none;z-index:2;transition:opacity .3s ease}.piece-card-image-container.editing-image:after{opacity:0}.piece-card-content{grid-row:1;grid-column:1;z-index:20;height:100%;background:transparent;padding-top:60px}.piece-name{text-shadow:0 2px 8px rgba(0,0,0,.9);color:#fff}.piece-card-section h3,.piece-title{color:#ffffffe6;text-shadow:0 1px 4px rgba(0,0,0,.9)}.piece-card-section p,.voice-prompt-display,.voice-actor-display,.voice-edit-group label{color:#f0f0f0;text-shadow:0 1px 4px rgba(0,0,0,.95)}}.loader,.image-error{padding:2rem;text-align:center;color:var(--text-dark);width:100%;grid-row:1;grid-column:1;align-self:center;justify-self:center;z-index:5}.image-error{color:var(--error-red)}@media (max-width: 850px),(max-height: 850px){.loader{align-self:start;margin-top:40px;z-index:35;width:90%;padding:4px 8px;background:#0009;border-radius:8px}}.image-actions{display:flex;gap:.5rem;opacity:0;transition:opacity .2s ease;grid-row:1;grid-column:1;align-self:end;justify-self:end;margin:.5rem;z-index:30}.generate-image-btn.generate{grid-row:1;grid-column:1;align-self:end;justify-self:center;margin-bottom:1rem;z-index:30;padding:.5rem 1rem;border-radius:8px}@media (max-width: 850px),(max-height: 850px){.image-actions{align-self:start;margin-top:10px;margin-right:25px;opacity:1}.generate-image-btn.generate{z-index:30}}.piece-card:hover .image-actions,.piece-card-image-container.editing-image~.image-actions{opacity:1}.piece-card:hover .image-actions{opacity:1}.piece-image{position:absolute;top:50%;left:50%;transform-origin:center center;width:auto;height:auto;max-width:none;max-height:none;object-fit:fill;-webkit-user-select:none;user-select:none;-webkit-user-drag:none;will-change:transform}.piece-card-image-container.editing-image .piece-image{cursor:grab}.piece-card-image-container.editing-image .piece-image:active{cursor:grabbing}.piece-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.piece-header-main{flex-grow:1}.piece-header-actions{flex-shrink:0;margin-left:1rem}.piece-name{font-size:1.8rem;color:var(--accent);margin:0 0 .25rem;display:flex;align-items:center;gap:.75rem}.piece-symbol{font-size:2.5rem}.piece-title{font-size:1rem;color:var(--text-dark);font-style:italic;margin:0}.piece-card-section{margin-bottom:1rem}.piece-card-section .section-header{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #444;padding-bottom:.25rem;margin-bottom:.5rem}.piece-card-section h3{font-size:1rem;text-transform:uppercase;letter-spacing:1px;color:var(--text-dark);margin:0}.piece-card-section p{font-size:.9rem;line-height:1.5}.generate-image-btn,.edit-image-btn{background-color:#000000b3;color:var(--text-light);border:1px solid var(--text-dark);cursor:pointer;transition:all .2s ease;font-family:var(--font-family);font-size:.9rem;display:flex;align-items:center;justify-content:center}.generate-image-btn.regenerate,.edit-image-btn{width:40px;height:40px;border-radius:50%}.generate-image-btn:hover,.edit-image-btn:hover{background-color:#000000e6;border-color:var(--text-light)}.edit-image-btn.saving{background-color:var(--accent);border-color:var(--accent-dark)}.generate-image-btn .material-symbols-outlined,.edit-image-btn .material-symbols-outlined{font-size:20px}.edit-btn{background:none;border:none;cursor:pointer;color:var(--text-dark);padding:4px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s ease;z-index:25}.edit-btn:hover{background-color:#ffffff1a;color:var(--text-light)}.name-input,.personality-textarea{width:100%;background-color:var(--input-bg);color:var(--text-light);border:1px solid var(--modal-border);border-radius:4px;padding:.5rem;font-family:var(--font-family);font-size:.9rem;resize:vertical;margin-bottom:.5rem;line-height:1.5}.name-input{font-size:1.2rem;padding:.25rem .5rem;margin:0}.save-btn{padding:.5rem 1rem;background-color:var(--accent);color:#fff;border:none;border-radius:4px;cursor:pointer;float:right;font-family:var(--font-family);font-weight:700;transition:background-color .2s}.save-btn:hover{background-color:var(--accent-dark)}.voice-prompt-display{font-style:italic;color:var(--text-dark);margin-bottom:.5rem}.voice-actor-display strong{color:var(--text-light);font-weight:400}.voice-edit-group{margin-bottom:1rem}.voice-edit-group label{display:block;font-size:.8rem;color:var(--text-dark);margin-bottom:.25rem;text-transform:uppercase;letter-spacing:.5px}.voice-select{width:100%;padding:.5rem;background-color:var(--input-bg);color:var(--text-light);border:1px solid var(--modal-border);border-radius:4px;font-family:var(--font-family);font-size:.9rem}@keyframes transient-glow{0%{border-color:var(--accent);box-shadow:0 0 5px var(--accent),0 10px 30px #0006}50%{border-color:var(--accent-dark);box-shadow:0 0 15px var(--accent),0 10px 30px #0006}to{border-color:var(--accent);box-shadow:0 0 5px var(--accent),0 10px 30px #0006}}.piece-card.is-transient{animation:transient-glow 2.5s infinite ease-in-out}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background-color:var(--background);color:var(--text-light);padding:1.5rem 2rem;border-radius:16px;width:90%;max-width:500px;box-shadow:0 4px 20px #00000080;border:1px solid var(--modal-border);max-height:90vh;display:flex;flex-direction:column}@media (max-width: 480px){.modal-content{padding:1rem;width:95%}}.modal-header{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--modal-border);padding-bottom:1rem;margin-bottom:1.5rem;flex-shrink:0}.modal-header h2{margin:0;font-size:1.5rem;color:var(--accent)}.modal-header .close-button{background:none;border:none;font-size:2rem;color:var(--text-dark);cursor:pointer;line-height:1}.modal-body{display:flex;flex-direction:column;gap:1.5rem;overflow-y:auto;padding-right:1rem;margin-right:-1rem}.setting-item{display:flex;justify-content:space-between;align-items:center}.setting-item label{font-size:1rem}.setting-item .style-label{font-size:.8rem;color:var(--text-dark);margin-left:.5rem}.setting-item-group{border-top:1px solid var(--modal-border);padding-top:1.5rem}.setting-item-group h3{margin-bottom:.5rem}.setting-item-group p{color:var(--text-dark);margin-bottom:1rem;font-size:.9rem;line-height:1.5}.setting-item-group p code{background-color:var(--button-bg);padding:2px 5px;border-radius:4px;font-size:.85rem;color:var(--text-light)}.button-group{display:flex;gap:1rem}.button-group button{flex:1;padding:.75rem;background-color:var(--button-bg);color:var(--text-light);border:1px solid var(--modal-border);border-radius:8px;cursor:pointer;transition:background-color .2s;font-family:var(--font-family)}.button-group button:hover{background-color:var(--button-hover-bg)}.prompt-template-textarea{width:100%;background-color:var(--input-bg);color:var(--text-light);border:1px solid var(--modal-border);border-radius:4px;padding:.5rem;font-family:var(--font-family);font-size:.9rem;resize:vertical;line-height:1.5}.switch{position:relative;display:inline-block;width:50px;height:28px}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:#444;-webkit-transition:.4s;transition:.4s}.slider:before{position:absolute;content:"";height:20px;width:20px;left:4px;bottom:4px;background-color:var(--text-light);-webkit-transition:.4s;transition:.4s}input:checked+.slider{background-color:var(--accent)}input:focus+.slider{box-shadow:0 0 1px var(--accent)}input:checked+.slider:before{-webkit-transform:translateX(22px);-ms-transform:translateX(22px);transform:translate(22px)}.slider.round{border-radius:34px}.slider.round:before{border-radius:50%}.color-picker-wrapper{display:flex;align-items:center;gap:.75rem}.color-picker-wrapper span{font-family:Space Mono,monospace;font-size:.9rem;color:var(--text-dark)}input[type=color]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:32px;height:32px;background-color:transparent;border:none;cursor:pointer}input[type=color]::-webkit-color-swatch{border-radius:50%;border:2px solid var(--text-dark)}input[type=color]::-moz-color-swatch{border-radius:50%;border:2px solid var(--text-dark)}.slider-item{flex-direction:column;align-items:flex-start;gap:.5rem}.slider-wrapper{display:flex;align-items:center;width:100%;gap:1rem}.slider-wrapper input[type=range]{flex-grow:1;-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:8px;background:var(--input-bg);outline:none;border-radius:4px;border:1px solid var(--modal-border)}.slider-wrapper input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:20px;height:20px;background:var(--accent);cursor:pointer;border-radius:50%;border:2px solid var(--background)}.slider-wrapper input[type=range]::-moz-range-thumb{width:20px;height:20px;background:var(--accent);cursor:pointer;border-radius:50%;border:2px solid var(--background)}.slider-wrapper span{font-family:Space Mono,monospace;font-size:.9rem;color:var(--text-dark);min-width:50px;text-align:right}.strategy-console{width:100%;max-width:450px;flex-shrink:0;background:#1a1a1a;border:1px solid var(--modal-border);border-radius:16px;display:flex;flex-direction:column;box-shadow:0 10px 30px #0006;overflow:hidden;font-family:var(--font-family);color:var(--text-light)}@media (min-width: 851px){.strategy-console{width:320px;height:clamp(320px,75vmin,700px)}}@media (max-width: 850px) and (orientation: portrait){.strategy-console{height:auto;min-height:300px;flex:1}}.console-header{padding:1rem;background-color:#252525;border-bottom:1px solid var(--modal-border)}.console-header h3{margin:0;font-size:1.2rem;color:var(--accent);text-transform:uppercase;letter-spacing:1px}.console-tabs{display:flex;background-color:#252525;border-bottom:1px solid var(--modal-border)}.tab-btn{flex:1;background:none;border:none;padding:.75rem .5rem;cursor:pointer;color:var(--text-dark);font-family:var(--font-family);font-size:.85rem;text-transform:uppercase;border-bottom:3px solid transparent;transition:all .2s ease}.tab-btn:hover{color:var(--text-light);background-color:#ffffff0d}.tab-btn.active{color:var(--accent);border-bottom-color:var(--accent)}.tab-btn:disabled{color:#444;cursor:not-allowed}.console-body{flex-grow:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:1rem}.console-section{display:flex;flex-direction:column;gap:.5rem}.console-section h4{margin:0;color:var(--text-dark);font-size:.9rem;text-transform:uppercase}.strategy-console pre{background-color:var(--input-bg);padding:.75rem;border-radius:4px;white-space:pre-wrap;word-break:break-word;font-size:.8rem;line-height:1.5;color:#ccc;margin:0;border:1px solid #333;max-height:300px;overflow-y:auto}.image-section{display:flex;justify-content:center;align-items:center;background-color:var(--input-bg);padding:.5rem;border-radius:4px;border:1px solid #333}.image-section img{max-width:100%;height:auto;border:1px solid var(--modal-border)}.image-section p{color:var(--text-dark);font-size:.9rem}.status-text{font-size:.9rem;margin:0;padding:.5rem;border-radius:4px;background-color:var(--input-bg);border:1px solid #333;display:flex;flex-direction:column;gap:.25rem}.status-text.idle{color:var(--text-dark)}.status-text.pending{color:#e2b84a;animation:pulse-text 1.5s infinite ease-in-out}.status-text.ready{color:#4ae28a}.status-text.error{color:var(--error-red)}.injection-status{font-size:.8rem;margin-top:.25rem}.injection-status.queued{color:#e2b84a}.injection-status.sent{color:#4ae28a}.retry-analysis-btn{background-color:#333;color:var(--text-light);border:1px solid var(--error-red);border-radius:4px;padding:.5rem;width:100%;margin-top:.25rem;cursor:pointer;transition:all .2s;font-family:var(--font-family);font-size:.85rem;display:flex;align-items:center;justify-content:center}.retry-analysis-btn:hover{background-color:var(--error-red);color:#fff}@keyframes pulse-text{0%,to{opacity:1}50%{opacity:.5}}/**
 * @license
 * SPDX-License-Identifier: Apache-2.0
*/.terms-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000bf;display:flex;justify-content:center;align-items:center;z-index:2000}.terms-modal-content{background-color:var(--background);color:var(--text-light);padding:1.5rem;border-radius:12px;width:90%;max-width:500px;box-shadow:0 4px 20px #00000080;border:1px solid var(--modal-border);display:flex;flex-direction:column}.terms-modal-header{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--modal-border);padding-bottom:.75rem;margin-bottom:1rem}.terms-modal-header h3{margin:0;font-size:1.2rem;color:var(--accent)}.terms-modal-header .close-button{background:none;border:none;font-size:1.5rem;color:var(--text-dark);cursor:pointer;line-height:1}.terms-modal-body p{line-height:1.6;color:var(--text-light);margin:0;font-size:.95rem}.terms-modal-body a{color:var(--accent);text-decoration:none}.terms-modal-body a:hover{text-decoration:underline}.terms-modal-footer{padding-top:1rem;margin-top:1rem;display:flex;justify-content:flex-end}.terms-modal-footer .ok-btn{padding:.5rem 1.5rem;border:none;border-radius:4px;cursor:pointer;font-family:var(--font-family);font-weight:700;background-color:var(--button-bg);color:var(--text-light);border:1px solid var(--modal-border);transition:background-color .2s}.terms-modal-footer .ok-btn:hover{background-color:var(--button-hover-bg)}
