:root{color:#21351d;font-synthesis:none;text-rendering:geometricprecision;background:#f4fbf1;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}html,body,#root{min-width:320px;min-height:100%;margin:0}body{background:linear-gradient(#ffffffd6,#f6fcefe6),url(../assets/board-bg.png) 50%/cover fixed;overflow-x:hidden}button,input,textarea,select{font:inherit}.app-shell{color:#21351d;min-height:100svh;padding:14px}.topbar,.game-layout{width:min(1160px,100%);margin:0 auto}.topbar{justify-content:space-between;align-items:center;gap:14px;margin-bottom:12px;display:flex}.brand-block{align-items:center;gap:0;min-width:0;display:flex}.brand-block h1{color:#1d3c26;letter-spacing:0;margin:0;font-size:clamp(34px,6vw,62px);font-weight:950;line-height:.9}.brand-block p{display:none}.topbar-actions{flex:none;gap:8px;display:flex}.mode-tabs{background:#ffffffdb;border:1px solid #5c79373d;border-radius:8px;display:inline-flex;overflow:hidden;box-shadow:0 10px 24px #2f481e1f}.mode-button{color:#365422;cursor:pointer;background:0 0;border:0;min-height:38px;padding:0 13px;font-size:12px;font-weight:950}.mode-button.active{color:#fff;background:#6c8a3d}.icon-button{color:#2e4c24;cursor:pointer;background:#ffffffe0;border:1px solid #5c79373d;border-radius:8px;flex:none;place-items:center;width:46px;height:46px;display:inline-grid;box-shadow:0 10px 24px #2f481e24}.icon-button:hover{background:#fff;border-color:#5c793770}.game-layout{grid-template-columns:minmax(148px,188px) minmax(310px,520px) minmax(144px,178px);align-items:start;gap:14px;display:grid}.score-rail,.next-rail{gap:10px;display:grid}.stat-card,.next-card,.battle-card,.online-card,.rotation-card,.submit-card,.control-strip{background:#ffffffdb;border:1px solid #879e524d;border-radius:8px;box-shadow:0 12px 28px #354b1f1c}.stat-card{grid-template-columns:auto 1fr;align-items:center;gap:4px 8px;padding:12px;display:grid}.stat-card span{color:#6c8a3d;display:inline-grid}.stat-card small{color:#66784d;letter-spacing:0;font-size:11px;font-weight:950}.stat-card strong{color:#d38c18;text-overflow:ellipsis;grid-column:1/-1;min-width:0;font-size:clamp(25px,4vw,36px);font-weight:950;line-height:.96;overflow:hidden}.board-column{min-width:0}.play-controls{grid-template-columns:repeat(5,minmax(0,1fr)) auto;align-items:center;gap:7px;margin-bottom:10px;display:grid}.control-button{color:#2f4f25;cursor:pointer;background:#ffffffe6;border:1px solid #6c8a3d57;border-radius:8px;justify-content:center;align-items:center;gap:5px;min-width:0;min-height:42px;font-size:12px;font-weight:950;display:inline-flex;box-shadow:0 10px 22px #354b1f1a}.control-button:hover{background:#fff;border-color:#6c8a3d8f}.control-button:disabled{cursor:not-allowed;opacity:.48}.control-button.primary{color:#fff;background:#6c8a3d;border-color:#6c8a3d}.angle-pill{color:#52683d;white-space:nowrap;background:#ffffffc7;border:1px solid #6c8a3d3d;border-radius:8px;justify-content:center;align-items:center;min-height:42px;padding:0 10px;font-size:12px;font-weight:950;display:inline-flex}.board-shell{aspect-ratio:520/760;background:#f9fdf59e;border:1px solid #ffffffc2;border-radius:8px;width:100%;min-height:0;max-height:calc(100svh - 168px);position:relative;overflow:hidden;box-shadow:0 22px 56px #34572a33,inset 0 0 0 1px #6f94432e}.game-canvas{cursor:crosshair;touch-action:none;width:100%;height:100%;display:block}.match-intro-overlay,.turn-overlay,.ready-overlay{z-index:2;position:absolute}.match-intro-overlay,.turn-overlay{pointer-events:none}.match-intro-overlay{color:#fff;text-align:center;text-shadow:0 2px 14px #121f0e7a;background:#1a2d1661;place-content:center;justify-items:center;gap:5px;display:grid;inset:0}.match-intro-overlay small{font-size:13px;font-weight:950}.match-intro-overlay strong{font-size:74px;font-weight:950;line-height:.92}.match-intro-overlay span{font-size:20px;font-weight:950}.ready-overlay{color:#243d1e;text-align:center;background:#f8fcf4b8;place-content:center;justify-items:center;gap:8px;padding:22px;display:grid;inset:0}.ready-overlay small{color:#6c8a3d;font-size:13px;font-weight:950}.ready-overlay strong{font-size:24px;font-weight:950}.ready-overlay span{color:#536940;font-size:13px;font-weight:850}.ready-overlay button{color:#fff;min-width:148px;min-height:42px;font:inherit;cursor:pointer;background:#365422;border:0;border-radius:8px;font-weight:950}.ready-overlay button:disabled{cursor:not-allowed;opacity:.58}.board-timer{z-index:5;color:#25421f;pointer-events:none;background:#ffffffd1;border:1px solid #6c8a3d47;border-radius:50%;place-items:center;min-width:38px;height:38px;font-size:18px;font-weight:950;display:grid;position:absolute;top:14px;right:14px;box-shadow:0 10px 24px #243b181f}.board-timer.urgent{color:#b52323;border-color:#b523235c}.result-overlay{z-index:7;color:#20381e;text-align:center;pointer-events:none;background:#f8fcf48a;place-content:center;justify-items:center;gap:7px;display:grid;position:absolute;inset:0}.result-overlay strong{color:#25421f;text-shadow:0 2px #ffffffe6;font-size:56px;font-weight:950;line-height:.95}.result-overlay.lose strong{color:#8d2b2b}.result-overlay span{color:#425b32;background:#ffffffc7;border:1px solid #6c8a3d38;border-radius:8px;padding:5px 10px;font-size:13px;font-weight:950}.turn-overlay{color:#26421f;background:#ffffffd6;border:1px solid #6c8a3d47;border-radius:8px;justify-items:center;min-width:168px;padding:8px 12px;display:grid;top:16px;left:50%;transform:translate(-50%);box-shadow:0 12px 26px #243b1829}.turn-overlay.rival{color:#31546a;border-color:#2a669742}.turn-overlay strong{font-size:15px;font-weight:950}.turn-overlay span{font-size:11px;font-weight:850}.board-status-text{z-index:5;color:#2f4e29;text-align:center;text-shadow:0 1px #ffffffe0,0 2px 8px #ffffffe6;pointer-events:none;font-size:13px;font-weight:950;position:absolute;top:14px;left:0;right:0}.control-strip{color:#435d32;align-items:center;gap:8px;min-height:42px;margin-top:10px;padding:8px 11px;font-size:13px;font-weight:850;display:flex}.control-strip svg{color:#6c8a3d;flex:none}.next-card,.battle-card,.online-card,.rotation-card,.submit-card{padding:12px}.next-card,.battle-card{text-align:center;justify-items:center;gap:7px;display:grid}.next-card small,.battle-card small,.rotation-card small{color:#66784d;font-size:11px;font-weight:950}.next-card strong{color:#20381e;text-overflow:ellipsis;white-space:nowrap;width:100%;min-width:0;font-size:20px;font-weight:950;line-height:1;overflow:hidden}.next-card em{color:#66784d;text-overflow:ellipsis;white-space:nowrap;width:100%;min-width:0;font-size:12px;font-style:normal;font-weight:850;overflow:hidden}.battle-card strong{color:#20381e;font-size:19px;font-weight:950;line-height:1}.battle-card span{color:#66784d;font-size:12px;font-weight:850}.online-card{gap:8px;display:grid}.online-card strong{color:#20381e;letter-spacing:1px;font-size:24px;font-weight:950;line-height:1}.online-card p{color:#5e6f4a;margin:0;font-size:12px;font-weight:800}.online-card input{box-sizing:border-box;color:#213817;width:100%;min-width:0;font:inherit;text-transform:uppercase;background:#ffffffeb;border:1px solid #a6b7848f;border-radius:8px;padding:8px 9px;font-size:13px;font-weight:900}.online-card button{color:#fff;width:100%;font:inherit;cursor:pointer;background:#365422;border:0;border-radius:8px;padding:8px 9px;font-size:13px;font-weight:900}.opponent-box{background:#f8fcf2c7;border:1px solid #a6b78466;border-radius:8px;gap:3px;padding:8px;display:grid}.opponent-box small{color:#6c8a3d;font-size:10px;font-weight:950}.opponent-box b{color:#20381e;text-overflow:ellipsis;white-space:nowrap;min-width:0;font-size:14px;font-weight:950;overflow:hidden}.opponent-box span{color:#66784d;overflow-wrap:anywhere;font-size:12px;font-weight:800}.next-preview{background:radial-gradient(circle at 50% 54%, color-mix(in srgb, var(--preview-color,#8a5c2b) 18%, transparent), transparent 58%), #f9fdf5e6;border:1px solid #6c8a3d33;border-radius:8px;place-items:center;width:100%;min-height:74px;display:grid}.next-waiting{color:#6c8a3d;background:#f9fdf5e6;border:1px dashed #6c8a3d57;border-radius:8px;place-items:center;width:100%;min-height:74px;display:grid}.next-preview-art{width:min(160px,96%);height:auto;max-height:104px;display:block}.rotation-card{gap:10px;display:grid}.rotation-card>div{color:#5f7c37;justify-content:space-between;align-items:center;gap:8px;display:flex}.rotation-card strong{color:#314924;font-size:12px;font-weight:950}.rotation-card input{accent-color:#6c8a3d;width:100%}.submit-card{gap:8px;display:grid}.submit-card form{gap:6px;display:grid}.ranking-head{justify-content:space-between;align-items:center;gap:8px;display:flex}.ranking-head small{color:#66784d;font-size:11px;font-weight:950}.ranking-head span{color:#6c8a3d;font-size:10px;font-weight:950}.submit-card input{box-sizing:border-box;color:#213817;width:100%;min-width:0;font:inherit;background:#ffffffeb;border:1px solid #a6b7848f;border-radius:8px;padding:8px 9px;font-size:13px;font-weight:800}.submit-card button{color:#fff;width:100%;font:inherit;cursor:pointer;background:#365422;border:0;border-radius:8px;padding:8px 9px;font-size:13px;font-weight:900}.submit-card button:disabled{cursor:wait;opacity:.72}.submit-card p{color:#5e6f4a;margin:0;font-size:12px;font-weight:800}.submit-card small{color:#b84932;font-size:12px;font-weight:850}.panel-title{color:#365422;align-items:center;gap:6px;font-size:13px;font-weight:950;display:inline-flex}.modal-backdrop{z-index:20;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#14261a3d;place-items:center;padding:16px;display:grid;position:fixed;inset:0}.leaderboard-modal,.rankin-modal,.online-lobby-modal{color:#20321c;background:#fffffff0;border:1px solid #a6b7847a;border-radius:8px;grid-template-rows:auto minmax(0,1fr);width:min(420px,100%);max-height:min(620px,100svh - 32px);display:grid;overflow:hidden;box-shadow:0 24px 70px #1a30203d}.rankin-modal{grid-template-rows:auto auto}.online-lobby-modal{width:min(520px,100%)}.leaderboard-modal header,.rankin-modal header,.online-lobby-modal header{border-bottom:1px solid #a6b78457;justify-content:space-between;align-items:center;gap:12px;padding:14px;display:flex}.leaderboard-modal header p,.rankin-modal header p,.online-lobby-modal header p{color:#5e6f4a;margin:4px 0 0;font-size:12px;font-weight:800}.online-lobby-body{gap:10px;padding:12px;display:grid;overflow-y:auto}.lobby-section{background:#f9fdf5b8;border:1px solid #a6b78457;border-radius:8px;gap:8px;padding:10px;display:grid}.lobby-section input,.lobby-section textarea{color:#213817;width:100%;min-width:0;font:inherit;background:#ffffffeb;border:1px solid #a6b7848f;border-radius:8px;padding:8px 9px;font-size:13px;font-weight:800}.lobby-section textarea{resize:vertical;min-height:62px}.lobby-actions,.join-row{grid-template-columns:1fr 1fr;gap:8px;display:grid}.lobby-section button{color:#fff;width:100%;font:inherit;cursor:pointer;background:#365422;border:0;border-radius:8px;padding:8px 9px;font-size:13px;font-weight:900}.lobby-section button:disabled,.lobby-section input:disabled,.lobby-section textarea:disabled{cursor:not-allowed;opacity:.58}.match-count{color:#263b1eb8;margin:0;font-size:12px;font-weight:900}.lobby-action-hint{color:#506743;background:#ffffffb8;border:1px solid #a6b78452;border-radius:8px;margin:0;padding:7px 8px;font-size:11px;font-weight:850;line-height:1.35}.lobby-action-hint.locked{color:#5f4b22;background:#fff7d9;border-color:#be902e6b}.playing-match-list{gap:3px;display:grid}.playing-match-list small{color:#4f6840;text-overflow:ellipsis;white-space:nowrap;font-size:11px;font-weight:850;overflow:hidden}.avatar-picker{grid-template-columns:repeat(5,minmax(0,1fr));gap:6px;display:grid}.lobby-section .avatar-option{background:#ffffffe6;border:1px solid #a6b78480;place-items:center;min-width:0;height:48px;padding:2px;display:grid}.lobby-section .avatar-option.active{background:#f2f8df;border-color:#365422;box-shadow:inset 0 0 0 2px #3654222e}.avatar-preview,.waiting-room-avatar{background:0 0;border:0;width:42px;height:42px}.degu-face-icon{border:1px solid color-mix(in srgb, var(--avatar-color,#8a5c2b) 42%, #36542252);background:#fff7ea;border-radius:50%;place-items:center;display:grid;overflow:hidden;box-shadow:0 1px #ffffffe6,inset 0 -4px 12px #263b1e14}.degu-face-icon img{object-fit:cover;pointer-events:none;-webkit-user-select:none;user-select:none;width:100%;height:100%;display:block}.waiting-room-list{gap:5px;display:grid}.waiting-room-row{background:#ffffffbd;border:1px solid #a6b78452;border-radius:8px;grid-template-columns:44px minmax(0,1fr) 54px;align-items:center;gap:7px;padding:5px;display:grid}.waiting-room-row strong,.waiting-room-row small{text-overflow:ellipsis;white-space:nowrap;min-width:0;display:block;overflow:hidden}.waiting-room-row strong{color:#263b1e;font-size:12px;font-weight:950}.waiting-room-row small{color:#5d704a;font-size:10px;font-weight:800}.lobby-section .waiting-room-row button{min-height:34px;padding:6px;font-size:12px}.room-summary{color:#5e6f4a;gap:4px;font-size:12px;font-weight:800;display:grid}.room-summary b{color:#20381e;letter-spacing:1px;font-size:22px}.lobby-section .room-leave-button{color:#365422;background:#fff;border:1px solid #36542247;margin-top:2px}.room-summary p{overflow-wrap:anywhere;margin:0}.battle-ranking-list{gap:3px;display:grid}.battle-ranking-list p{color:#5e6f4a;margin:0;font-size:12px;font-weight:800}.battle-ranking-row{color:#20321c;grid-template-columns:24px minmax(0,1fr) auto;align-items:center;gap:8px;min-height:30px;font-size:12px;font-weight:850;display:grid}.battle-ranking-row b{color:#d38c18}.battle-ranking-row span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.battle-ranking-row small{color:#647553;grid-column:2/-1;margin-top:-5px;font-size:10px;font-weight:800}.rankin-modal form{gap:10px;padding:14px;display:grid}.rankin-note{color:#5e6f4a;margin:0;font-size:12px;font-weight:800}.rankin-actions{grid-template-columns:1fr 1fr;gap:8px;display:grid}.rankin-modal input{box-sizing:border-box;color:#213817;width:100%;min-width:0;font:inherit;background:#ffffffeb;border:1px solid #a6b7848f;border-radius:8px;padding:8px 9px;font-size:13px;font-weight:800}.rankin-modal input:disabled{color:#66715b;cursor:not-allowed;opacity:.74;background:#ffffff94}.rankin-modal button[type=submit],.rankin-modal button.secondary{width:100%;font:inherit;cursor:pointer;border:0;border-radius:8px;padding:8px 9px;font-size:13px;font-weight:900}.rankin-modal button[type=submit]{color:#fff;background:#365422}.rankin-modal button.secondary{color:#365422;background:#ffffffeb;border:1px solid #a6b7848f}.rankin-modal button[type=submit]:disabled{cursor:not-allowed;opacity:.62;background:#7b906e}.rankin-modal button.secondary:disabled{cursor:not-allowed;opacity:.62}.rankin-modal small{color:#b84932;font-size:12px;font-weight:850}.leaderboard-list{min-height:180px;padding:8px;overflow-y:auto}.leaderboard-row{border-bottom:1px solid #879e5238;grid-template-columns:38px minmax(0,1fr) auto;align-items:center;gap:8px;min-height:36px;padding:7px 6px;font-size:13px;display:grid}.leaderboard-row b{color:#d38c18;font-size:14px;font-weight:950}.leaderboard-row span{color:#20321c;text-overflow:ellipsis;white-space:nowrap;min-width:0;font-weight:900;overflow:hidden}.leaderboard-row strong{color:#365422;font-size:13px;font-weight:950}.leaderboard-empty{color:#5e6f4a;text-align:center;margin:24px 0;font-size:13px;font-weight:800}@media (width<=920px){.app-shell{padding:10px}.game-layout{grid-template-columns:minmax(0,1fr)}.score-rail{grid-template-columns:repeat(4,minmax(0,1fr))}.next-rail{grid-template-columns:1fr 1fr}.submit-card{grid-column:1/-1}.board-shell{width:min(100%,430px);max-height:none;margin:0 auto}.stat-card{padding:9px}.stat-card strong{font-size:clamp(19px,5vw,30px)}}@media (width<=560px){.app-shell{padding:6px 6px 0}.topbar{grid-template-columns:1fr auto;gap:4px 6px;margin-bottom:4px;display:grid}.mode-tabs{grid-column:1/-1;width:100%}.mode-button{flex:1 1 0}.brand-block{gap:0}.brand-block h1{font-size:24px;line-height:.95}.brand-block p{display:none}.icon-button{width:32px;height:32px}.score-rail{order:1;grid-template-columns:repeat(4,minmax(0,1fr));gap:4px}.stat-card{gap:2px 4px;min-height:46px;padding:5px}.stat-card span{display:none}.stat-card small{font-size:8px}.stat-card strong{font-size:18px;line-height:1}.next-rail{order:2;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:5px}.board-column{order:3}.play-controls{grid-template-columns:repeat(6,minmax(0,1fr));gap:4px;margin-bottom:5px}.control-button{min-height:32px;padding:6px}.control-button span,.angle-pill{display:none}.next-card,.submit-card{min-height:58px;padding:6px}.submit-card{grid-column:1/-1;gap:6px}.submit-card input{height:30px}.next-card{text-align:left;grid-template-rows:auto auto auto;grid-template-columns:58px minmax(0,1fr);justify-items:start;gap:1px 6px}.next-card small,.next-card strong,.next-card em{grid-column:2}.next-card strong{font-size:14px;line-height:1.05}.next-card em{font-size:9px;line-height:1.05}.next-preview,.next-waiting{grid-area:1/1/4;min-height:44px}.next-preview-art{width:min(96px,96%);max-height:58px}.battle-card{align-content:center;gap:2px;min-height:58px;padding:6px}.battle-card strong{font-size:14px;line-height:1.05}.battle-card span{font-size:9px;line-height:1.1}.online-card{grid-column:1/-1;grid-template-columns:minmax(0,1fr) auto 72px;align-items:center;gap:3px 6px;padding:6px}.online-card .ranking-head{grid-area:1/1/auto/3;min-width:0}.online-card .ranking-head span{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.online-card strong{grid-area:2/1;font-size:15px;line-height:1}.online-card p,.online-card button{font-size:10px}.online-card>p{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.online-card>p:first-of-type{text-align:right;grid-area:2/2;justify-self:end}.online-card>p:nth-of-type(2){grid-area:4/1/auto/3}.online-card button{grid-area:1/3/5;align-self:stretch;min-height:54px;padding:4px}.online-card .opponent-box{grid-area:3/1/auto/3;grid-template-columns:auto minmax(0,.7fr) minmax(0,1.3fr);align-items:center;gap:4px;padding:4px 6px;display:grid}.online-card .opponent-box small,.online-card .opponent-box b,.online-card .opponent-box span{text-overflow:ellipsis;white-space:nowrap;min-width:0;font-size:9px;line-height:1.05;overflow:hidden}.board-shell{width:min(100%,314px)}.turn-overlay{justify-items:start;min-width:0;max-width:calc(100% - 16px);padding:5px 8px;top:8px;left:8px;transform:none}.turn-overlay strong{font-size:12px}.turn-overlay span{font-size:10px}.board-status-text{font-size:12px;top:8px}.board-timer{min-width:32px;height:32px;font-size:15px;top:8px;right:8px}.result-overlay strong{font-size:44px}.result-overlay span{font-size:12px}.control-strip{min-height:30px;margin-top:5px;padding:5px 8px;font-size:11px}.app-shell.is-online.is-playing .topbar{grid-template-columns:minmax(0,1fr) auto;align-items:center}.app-shell.is-online.is-playing .brand-block h1{font-size:18px}.app-shell.is-online.is-playing .mode-tabs{display:none}.app-shell.is-online.is-playing .topbar-actions{gap:4px}.app-shell.is-online.is-playing .icon-button{width:30px;height:30px}.app-shell.is-online.is-playing .score-rail{gap:3px}.app-shell.is-online.is-playing .stat-card{min-height:34px;padding:4px}.app-shell.is-online.is-playing .stat-card small{font-size:7px}.app-shell.is-online.is-playing .stat-card strong{font-size:15px}.app-shell.is-online.is-playing .next-rail{gap:4px}.app-shell.is-online.is-playing .next-card,.app-shell.is-online.is-playing .battle-card{min-height:50px;padding:5px}.app-shell.is-online.is-playing .next-card{grid-template-columns:50px minmax(0,1fr)}.app-shell.is-online.is-playing .next-preview,.app-shell.is-online.is-playing .next-waiting{min-height:38px}.app-shell.is-online.is-playing .next-preview-art{max-height:50px}.app-shell.is-online.is-playing .next-card strong,.app-shell.is-online.is-playing .battle-card strong{font-size:13px}.app-shell.is-online.is-playing .next-card em,.app-shell.is-online.is-playing .battle-card span{font-size:8px}.app-shell.is-online.is-playing .online-card{grid-template-columns:minmax(0,1fr) auto 58px;padding:5px}.app-shell.is-online.is-playing .online-card .ranking-head{gap:4px}.app-shell.is-online.is-playing .online-card strong{letter-spacing:0;font-size:13px}.app-shell.is-online.is-playing .online-card>p:nth-of-type(2){display:none}.app-shell.is-online.is-playing .online-card button{min-height:44px}.app-shell.is-online.is-playing .online-card .opponent-box{padding:3px 5px}.app-shell.is-online.is-playing .play-controls{margin-top:2px}}@media (width<=560px) and (height<=780px){.app-shell{padding-bottom:0}.board-shell{width:min(100%,291px)}.next-card,.submit-card{min-height:52px;padding:6px 8px}.next-card strong{font-size:16px}.next-card em{font-size:10px}}
