*,:before,:after{box-sizing:border-box;margin:0;padding:0}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}:root{--bg:#0a0f14;--bg-card:#0f1723d9;--bg-panel:#0f172399;--accent:#22d3ee;--accent-dark:#06b6d4;--accent-glow:#22d3ee66;--red:#f87171;--red-bright:#fca5a5;--text:#e0f2fe;--text-muted:#7dd3fc;--border:#22d3ee26;--border-bright:#22d3ee4d;--shadow:0 20px 50px #000000b3;--glass-bg:#22d3ee14;--glass-border:#22d3ee33;font-size:16px}body{color:var(--text);-webkit-overflow-scrolling:touch;overscroll-behavior-y:contain;touch-action:pan-y pinch-zoom;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:radial-gradient(80% 50% at 50% 0,#06b6d426,#0000 50%),radial-gradient(60% 40% at 20% 100%,#22d3ee14,#0000 50%),radial-gradient(50% 50% at 80% 20%,#0ea5e91a,#0000 50%),#0a0f14;min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Noto Serif SC,sans-serif;position:relative;overflow-x:hidden}.captured-char,.move-round,.turn-banner,.player-tag.active-turn,.btn,.board-wrapper{will-change:auto;backface-visibility:hidden;transform:translateZ(0)}.game-layout,.side-panel,.board-area,.game-info,.move-history,.captured-pieces,.action-buttons{contain:layout}body:before{content:"";pointer-events:none;z-index:1;background:repeating-linear-gradient(0deg,#0000,#0000 2px,#22d3ee05 2px 4px);position:fixed;inset:0}body>*{z-index:2;position:relative}.btn{cursor:pointer;-webkit-user-select:none;user-select:none;border:none;border-radius:12px;justify-content:center;align-items:center;gap:8px;min-height:44px;padding:12px 24px;font-size:15px;font-weight:600;transition:all .2s cubic-bezier(.4,0,.2,1);display:inline-flex;position:relative;overflow:hidden}.btn:before{content:"";opacity:0;background:linear-gradient(135deg,#ffffff1a,#0000);transition:opacity .2s;position:absolute;inset:0}.btn:hover:before{opacity:1}.btn:hover{transform:translateY(-2px)}.btn:active{transform:translateY(0)}@media (hover:none){.btn:hover{transform:none}.btn:hover:before{opacity:0}.btn:active{opacity:.9;transform:scale(.97)}}.btn-primary{background:linear-gradient(135deg,var(--accent-dark),var(--accent));color:#0a0f14;box-shadow:0 4px 20px var(--accent-glow),0 0 0 1px #22d3ee4d;font-weight:700}.btn-primary:hover{box-shadow:0 8px 30px var(--accent-glow),0 0 0 1px #22d3ee80}.btn-secondary{background:var(--glass-bg);color:var(--text);border:1px solid var(--glass-border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.btn-secondary:hover{background:#ffffff14;border-color:#ffffff26}.btn-danger{color:#fff;background:linear-gradient(135deg,#dc2626,#ef4444);box-shadow:0 4px 20px #ef444466}.btn-ghost{color:var(--text-muted);background:0 0;padding:8px 16px;font-size:14px}.btn-ghost:hover{color:var(--text);background:var(--glass-bg)}.full-width{width:100%}.input{background:var(--glass-bg);border:1px solid var(--glass-border);width:100%;color:var(--text);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;outline:none;padding:12px 16px;font-size:15px;transition:all .2s cubic-bezier(.4,0,.2,1)}.input:hover{border-color:#ffffff26}.input:focus{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-glow);background:#22d3ee14}.input::placeholder{color:var(--text-muted);opacity:.6}.home-page{flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:24px;animation:.6s fadeIn;display:flex}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}.home-header{text-align:center;margin-bottom:48px;animation:.8s cubic-bezier(.4,0,.2,1) slideDown}@keyframes slideDown{0%{opacity:0;transform:translate(-50%)translateY(-20px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.home-title{letter-spacing:2px;background:linear-gradient(135deg,#22d3ee 0%,#06b6d4 30%,#0ea5e9 60%,#3b82f6 100%);-webkit-text-fill-color:transparent;filter:drop-shadow(0 0 40px #22d3ee80);-webkit-background-clip:text;background-clip:text;margin-bottom:12px;font-size:3.5rem;font-weight:800}.home-subtitle{color:var(--text-muted);letter-spacing:16px;margin-top:8px;font-family:Noto Serif SC,serif;font-size:1.1rem}.home-card{background:var(--bg-card);border:1px solid var(--glass-border);width:100%;max-width:460px;box-shadow:var(--shadow);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:24px;padding:36px;animation:.5s cubic-bezier(.4,0,.2,1) .2s both scaleIn}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.form-group{margin-bottom:20px}.form-group label{color:var(--text);margin-bottom:8px;font-size:14px;font-weight:600;display:block}.tab-bar{background:var(--glass-bg);border-radius:12px;gap:4px;margin-bottom:24px;padding:4px;display:flex}.tab-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:8px;flex:1;min-height:44px;padding:12px 8px;font-size:14px;font-weight:600;transition:all .2s cubic-bezier(.4,0,.2,1);position:relative}.tab-btn:hover{color:var(--text);background:#ffffff0d}@media (hover:none){.tab-btn:hover{color:var(--text-muted);background:0 0}.tab-btn:active{transform:scale(.95)}}.tab-btn.active{color:var(--accent);background:linear-gradient(135deg,#22d3ee33,#22d3ee1a);box-shadow:0 0 0 1px #22d3ee4d}.tab-content{animation:.3s cubic-bezier(.4,0,.2,1) tabFadeIn}@keyframes tabFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}.hint{color:var(--text-muted);margin-bottom:20px;font-size:14px;line-height:1.5}.radio-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.radio-label{cursor:pointer;-webkit-user-select:none;user-select:none;background:#ffffff08;border:2px solid #ffffff14;border-radius:12px;justify-content:center;align-items:center;gap:8px;min-height:44px;padding:12px 16px;font-size:14px;font-weight:500;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex;position:relative}.radio-label:hover{background:#22d3ee14;border-color:#22d3ee33;transform:translateY(-1px)}@media (hover:none){.radio-label:hover{background:#ffffff08;border-color:#ffffff14;transform:none}.radio-label:active{transform:scale(.97)}}.radio-label input{opacity:0;pointer-events:none;position:absolute}.radio-label input:checked~*{color:var(--text)}.radio-label:has(input:checked){border-color:var(--accent);background:linear-gradient(135deg,#22d3ee33,#22d3ee1a);transform:translateY(-2px);box-shadow:0 0 0 1px #22d3ee4d,0 4px 12px #22d3ee33}.radio-label:has(input:checked) .color-indicator{transform:scale(1.1);box-shadow:0 0 0 3px #22d3ee4d}.level-row{flex-direction:column;gap:10px;display:flex}.level-btn{background:var(--glass-bg);border:1px solid var(--glass-border);color:var(--text-muted);cursor:pointer;text-align:left;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;min-height:44px;padding:14px 18px;font-size:14px;transition:all .2s cubic-bezier(.4,0,.2,1)}.level-btn:hover{border-color:var(--accent);color:var(--text);background:#ffffff14;transform:translate(4px)}@media (hover:none){.level-btn:hover{border-color:var(--glass-border);color:var(--text-muted);background:var(--glass-bg);transform:none}.level-btn:active{transform:scale(.97)}}.level-btn.selected{border-color:var(--accent);color:var(--accent);background:linear-gradient(135deg,#22d3ee33,#22d3ee1a);transform:translate(4px);box-shadow:0 0 0 1px #22d3ee66,0 4px 12px #22d3ee4d}.error-msg{color:#fca5a5;text-align:center;background:#ef44441a;border:1px solid #ef44444d;border-radius:12px;margin-top:20px;padding:12px;font-size:14px}.dot{border-radius:50%;flex-shrink:0;width:14px;height:14px;display:inline-block;box-shadow:0 2px 8px #0000004d}.red-dot{background:linear-gradient(135deg,#f87171,#ef4444);box-shadow:0 2px 8px #f8717180}.black-dot{background:linear-gradient(135deg,#22d3ee,#06b6d4);box-shadow:0 2px 8px #22d3ee80}.red-dot-sm,.black-dot-sm{border-radius:50%;flex-shrink:0;width:16px;height:16px;transition:all .2s cubic-bezier(.4,0,.2,1)}.red-dot-sm{background:linear-gradient(135deg,#f87171,#ef4444);box-shadow:0 2px 6px #f8717166}.black-dot-sm{background:linear-gradient(135deg,#22d3ee,#06b6d4);box-shadow:0 2px 6px #22d3ee66}.player-tag.active-turn .dot{animation:1s ease-in-out infinite dotPulse}@keyframes dotPulse{0%,to{transform:scale(1);box-shadow:0 0 10px #f59e0b99}50%{transform:scale(1.4);box-shadow:0 0 25px #f59e0b,0 0 40px #fb923ccc}}.game-page{justify-content:center;align-items:center;max-width:100vw;min-height:100vh;padding:16px;animation:.5s fadeIn;display:flex;overflow-x:hidden}.game-page.loading{color:var(--text-muted);flex-direction:column;gap:24px}.game-layout{flex-flow:column;justify-content:center;align-items:center;gap:12px;width:100%;max-width:100%;animation:.6s cubic-bezier(.4,0,.2,1) scaleIn;display:flex}.side-panel{flex-direction:column;flex-shrink:0;align-self:flex-start;gap:12px;width:100%;max-width:600px;display:flex}.board-area{flex-shrink:0;justify-content:center;align-self:flex-start;align-items:center;width:100%;max-width:100%;animation:.8s cubic-bezier(.4,0,.2,1) boardSlideIn;display:flex;position:relative;overflow:hidden}@keyframes boardSlideIn{0%{opacity:0;transform:scale(.9)translateY(20px)}to{opacity:1;transform:scale(1)translateY(0)}}.board-wrapper{border-radius:16px;justify-content:center;width:100%;max-width:100%;transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;overflow:hidden;box-shadow:0 20px 60px #000000b3,0 0 0 2px #22d3ee4d,0 0 80px #22d3ee33}.board-wrapper svg{max-width:100%;height:auto}.board-wrapper:hover{transform:translateY(-2px);box-shadow:0 24px 70px #000c,0 0 0 1px #22d3ee80,0 0 100px #22d3ee4d}@media (hover:none){.board-wrapper:hover{transform:none;box-shadow:0 20px 60px #000000b3,0 0 0 2px #22d3ee4d,0 0 80px #22d3ee33}}.reconnect-container{background:var(--bg-card);border:1px solid var(--glass-border);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:24px;flex-direction:column;align-items:center;gap:20px;padding:48px;animation:.5s cubic-bezier(.4,0,.2,1) scaleIn;display:flex;box-shadow:0 20px 60px #00000080}.reconnecting-spinner{border:5px solid #22d3ee33;border-top-color:var(--accent);border-radius:50%;width:64px;height:64px;animation:.8s cubic-bezier(.4,0,.2,1) infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.reconnect-title{color:var(--text);margin:0;font-size:24px;font-weight:700}.reconnect-subtitle{color:var(--text-muted);margin:0;font-size:15px}.game-info{background:var(--bg-card);border:1px solid var(--glass-border);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:12px;flex-direction:column;gap:10px;min-height:180px;padding:14px;display:flex;box-shadow:0 8px 32px #0000004d}.room-code-bar{color:var(--text-muted);text-align:center;background:linear-gradient(135deg,#22d3ee26,#22d3ee14);border:1px solid #22d3ee4d;border-radius:8px;justify-content:center;align-items:center;min-height:38px;padding:8px 10px;font-size:12px;display:flex}.room-code-content{flex-wrap:wrap;justify-content:center;align-items:center;gap:10px;display:flex}.room-code-bar strong{color:var(--accent);letter-spacing:3px;font-size:14px;font-weight:700}.copy-btn{cursor:pointer;color:var(--accent);background:#22d3ee33;border:1px solid #22d3ee66;border-radius:8px;justify-content:center;align-items:center;min-width:36px;min-height:36px;padding:6px 10px;font-size:16px;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex}.copy-btn:hover{background:#22d3ee4d;border-color:#22d3ee99;transform:scale(1.05)}.copy-btn:active{transform:scale(.95)}@media (hover:none){.copy-btn:hover{background:#22d3ee33;border-color:#22d3ee66;transform:none}}.copy-btn.copied{color:#4ade80;background:#22c55e33;border-color:#22c55e66;animation:.3s copySuccess}@keyframes copySuccess{0%,to{transform:scale(1)}50%{transform:scale(1.2)}}.players-row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.player-tag{background:var(--glass-bg);border:1px solid #0000;border-radius:8px;flex:1;align-items:center;gap:6px;min-width:100px;padding:8px 10px;font-size:13px;transition:all .2s;display:flex}.player-tag:hover{border-color:var(--glass-border);background:#ffffff14}.player-tag.you{color:var(--accent);background:linear-gradient(135deg,#22d3ee26,#22d3ee14);border-color:#22d3ee66;font-weight:700}.player-tag.active-turn{border-color:#f59e0b;animation:1s ease-in-out infinite playerTurnPulse}@keyframes playerTurnPulse{0%,to{background:linear-gradient(135deg,#f59e0b33,#fb923c26);transform:scale(1);box-shadow:0 0 0 2px #f59e0b66,0 0 20px #f59e0b4d}50%{background:linear-gradient(135deg,#f59e0b4d,#fb923c40);transform:scale(1.03);box-shadow:0 0 0 4px #f59e0bb3,0 0 40px #f59e0b99}}.vs-divider{color:var(--text-muted);background:var(--glass-bg);border-radius:6px;padding:4px 6px;font-size:11px;font-weight:700}.you-badge{background:linear-gradient(135deg,var(--accent-dark),var(--accent));color:#0a0f14;border-radius:6px;padding:2px 6px;font-size:9px;font-weight:700;box-shadow:0 2px 8px #22d3ee66}.turn-banner{text-align:center;background:linear-gradient(135deg,#22d3ee26,#22d3ee14);border:1px solid #22d3ee4d;border-radius:10px;justify-content:center;align-items:center;min-height:44px;padding:10px;font-size:14px;font-weight:700;transition:all .3s cubic-bezier(.4,0,.2,1);animation:1.5s ease-in-out infinite turnBannerPulse;display:flex}@keyframes turnBannerPulse{0%,to{border-color:#f59e0b66;box-shadow:0 0 #f59e0b00}50%{border-color:#f59e0bcc;box-shadow:0 0 0 6px #f59e0b66,0 0 30px #f59e0b4d}}.turn-banner.waiting{color:var(--text-muted);background:var(--glass-bg);border-color:var(--glass-border);font-size:13px;font-weight:500;animation:none}.turn-banner.in-check{background:linear-gradient(135deg,#ef444433,#dc262626);border-color:#ef444466;animation:1.5s ease-in-out infinite pulseRed}@keyframes pulseRed{0%,to{box-shadow:0 0 #ef444400}50%{box-shadow:0 0 0 8px #ef44444d}}.turn-red{color:#fca5a5;text-shadow:0 0 20px #f8717199}.turn-black{color:#67e8f9;text-shadow:0 0 20px #22d3ee99}.turn-you{color:#fbbf24;text-shadow:0 0 20px #fbbf24cc;font-weight:800}.turn-opponent{color:#94a3b8;text-shadow:0 0 10px #94a3b866;font-weight:600}.check-alert{color:#fca5a5;font-size:14px;animation:.5s shake;display:inline-block}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-4px)}75%{transform:translate(4px)}}.action-buttons{flex-direction:column;gap:8px;min-height:44px;transition:none;display:flex}.captured-pieces{background:var(--bg-card);border:1px solid var(--glass-border);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);scrollbar-width:thin;scrollbar-color:#22d3ee4d transparent;border-radius:10px;flex-wrap:wrap;align-items:center;min-height:40px;max-height:60px;padding:10px 12px;font-size:12px;transition:none;display:flex;overflow:hidden auto;box-shadow:0 4px 16px #0003}.captured-pieces::-webkit-scrollbar{width:4px;height:4px}.captured-pieces::-webkit-scrollbar-thumb{background:#22d3ee4d;border-radius:2px}.captured-label{color:var(--text-muted);flex-shrink:0;align-self:flex-start;margin-right:6px;padding-top:2px;font-size:11px;font-weight:600;line-height:1.2}.captured-content{flex-wrap:wrap;flex:1;align-items:center;gap:2px;display:flex}.captured-char{margin:2px 3px;font-family:Noto Serif SC,serif;font-size:16px;font-weight:600;line-height:1;animation:.3s capturedFadeIn;display:inline-block}@keyframes capturedFadeIn{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}.captured-empty{color:var(--text-muted);opacity:.5;font-size:12px;line-height:1}.captured-pieces.red .captured-char{color:#fca5a5;text-shadow:0 0 10px #f8717166}.captured-pieces.black .captured-char{color:#67e8f9;text-shadow:0 0 10px #22d3ee66}.move-history{background:var(--bg-card);border:1px solid var(--glass-border);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:12px;flex-direction:column;flex:1;min-height:250px;padding:14px;display:flex;box-shadow:0 8px 32px #0000004d}.panel-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:2px;flex-shrink:0;margin-bottom:10px;font-size:11px;font-weight:700}.move-list{scrollbar-width:thin;scrollbar-color:#60a5fa4d transparent;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;flex:1;min-height:180px;max-height:300px;font-size:12px;overflow-y:auto}.move-list::-webkit-scrollbar{width:6px}.move-list::-webkit-scrollbar-track{background:0 0}.move-list::-webkit-scrollbar-thumb{background:#22d3ee4d;border-radius:3px}.move-list::-webkit-scrollbar-thumb:hover{background:#22d3ee80}.no-moves{color:var(--text-muted);text-align:center;padding:20px 0;font-size:12px;font-style:italic}.move-round{border-radius:6px;grid-template-columns:28px 1fr 1fr;align-items:center;gap:6px;margin-bottom:3px;padding:5px 6px;transition:background .2s;animation:.2s moveSlideIn;display:grid}@keyframes moveSlideIn{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}.move-round:hover{background:var(--glass-bg)}.move-num{color:var(--text-muted);font-size:11px;font-weight:600}.move-red{color:#fca5a5;font-family:Noto Serif SC,serif;font-size:12px;font-weight:600}.move-black{color:#67e8f9;font-family:Noto Serif SC,serif;font-size:12px;font-weight:600}.home-btn{align-self:flex-start;margin-top:auto}.modal-overlay{z-index:100;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#0a0e1ad9;justify-content:center;align-items:center;animation:.3s fadeIn;display:flex;position:fixed;inset:0}.modal-box{background:var(--bg-card);border:1px solid var(--glass-border);text-align:center;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:24px;width:90%;max-width:420px;padding:48px;animation:.4s cubic-bezier(.4,0,.2,1) modalSlideUp;box-shadow:0 20px 60px #000000b3,0 0 0 2px #22d3ee4d}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(40px)scale(.95)}to{opacity:1;transform:none}}.modal-emoji{margin-bottom:20px;font-size:64px;animation:.6s .2s bounce}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.modal-title{color:var(--accent);margin-bottom:12px;font-size:28px;font-weight:800}.modal-subtitle{color:var(--text-muted);margin-bottom:32px;font-size:15px;line-height:1.6}.modal-buttons{flex-wrap:wrap;justify-content:center;gap:12px;display:flex}@media (max-width:767px){.game-layout{flex-direction:column;align-items:center}.side-panel{width:100%;max-width:600px}.chat-box.open{width:90%;max-width:400px;bottom:20px;right:5%}}@media (min-width:768px){.game-page{padding:20px}.game-layout{flex-flow:row;justify-content:center;align-items:flex-start;gap:16px;max-width:1400px}.side-panel{flex-shrink:0;gap:14px;width:260px;min-width:240px;max-width:300px}.board-area{flex-shrink:0;order:2;width:auto;max-width:480px}.side-panel:first-child{order:1}.side-panel:last-child{order:3}.game-info{gap:12px;padding:16px}.room-code-bar{padding:9px 12px;font-size:13px}.room-code-bar strong{letter-spacing:3.5px;font-size:15px}.players-row{gap:10px}.player-tag{min-width:100px;padding:9px 11px;font-size:13px}.vs-divider{padding:4px 6px;font-size:11px}.turn-banner{min-height:46px;padding:11px;font-size:14px}.captured-pieces{min-height:42px;max-height:64px;padding:11px 13px;font-size:12px}.captured-label{margin-right:6px;font-size:11px}.captured-char{margin:2px 3px;font-size:16px}.move-history{min-height:280px;padding:16px}.panel-title{margin-bottom:11px;font-size:11px}.move-list{min-height:190px;max-height:320px;font-size:12px}.move-round{grid-template-columns:28px 1fr 1fr;gap:6px;padding:5px 6px}.move-num{font-size:11px}.move-red,.move-black{font-size:12px}.action-buttons{gap:8px}.action-buttons .btn{padding:9px 14px;font-size:13px}}@media (min-width:1024px){.game-page{padding:24px}.game-layout{gap:20px}.side-panel{gap:16px;width:280px;min-width:260px;max-width:320px}.board-area{max-width:540px}.game-info{gap:13px;min-height:200px;padding:18px}.room-code-bar{min-height:42px;padding:10px 12px;font-size:13px}.room-code-bar strong{letter-spacing:4px;font-size:16px}.players-row{gap:12px}.player-tag{min-width:110px;padding:10px 12px;font-size:14px}.vs-divider{padding:5px 8px;font-size:12px}.turn-banner{min-height:48px;padding:13px;font-size:15px}.captured-pieces{min-height:44px;max-height:68px;padding:12px 14px;font-size:13px}.captured-label{margin-right:7px;font-size:12px}.captured-char{margin:2px 3.5px;font-size:17px}.move-history{min-height:300px;padding:18px}.panel-title{margin-bottom:12px;font-size:12px}.move-list{min-height:200px;max-height:340px;font-size:13px}.move-round{grid-template-columns:30px 1fr 1fr;gap:7px;padding:6px 7px}.move-num{font-size:12px}.move-red,.move-black{font-size:13px}.action-buttons .btn{padding:10px 16px;font-size:14px}}@media (min-width:1280px){.game-layout{gap:24px}.side-panel{width:300px;min-width:280px;max-width:340px}.board-area{max-width:640px}.game-info{gap:14px;padding:20px}.players-row{gap:12px}.player-tag{min-width:120px;padding:10px 14px;font-size:14px}.captured-pieces{padding:12px 16px}.captured-char{margin:2px 4px;font-size:18px}.move-history{padding:20px}.move-list{max-height:360px}}@media (max-width:600px){.board-wrapper svg{max-width:100vw;width:100%!important;height:auto!important}.home-page{padding:16px}.home-title{font-size:2.2rem}.home-subtitle{letter-spacing:8px;font-size:.95rem}.home-header{margin-bottom:32px}.home-card{padding:20px}.modal-box{max-width:90%;padding:28px 20px}.modal-emoji{margin-bottom:16px;font-size:48px}.modal-title{font-size:24px}.modal-subtitle{margin-bottom:24px;font-size:14px}.game-page{padding:12px}.btn{padding:10px 18px;font-size:14px}.btn-ghost{padding:7px 14px;font-size:13px}.input{padding:10px 14px;font-size:16px}.form-group label{margin-bottom:6px;font-size:13px}.tab-bar{gap:3px;padding:3px}.tab-btn{padding:10px 6px;font-size:13px}.radio-row{gap:8px}.radio-label{padding:10px 12px;font-size:13px}.level-row{gap:8px}.level-btn{padding:12px 14px;font-size:13px}.reconnect-container{padding:32px 20px}.reconnecting-spinner{border-width:4px;width:52px;height:52px}.reconnect-title{font-size:20px}.reconnect-subtitle{font-size:14px}.voice-controls{padding:10px}.voice-btn{width:38px;height:38px;font-size:18px}.voice-label{font-size:12px}.voice-indicator{font-size:11px}.chat-box.open{width:95%;height:auto;max-height:55vh;bottom:10px;right:2.5%}.chat-content{border-radius:12px}.chat-header{padding:12px 16px;font-size:14px}.chat-messages{gap:10px;padding:12px}.chat-message-text{padding:8px 12px;font-size:13px}.chat-input-form{gap:6px;padding:10px}.chat-input{padding:8px 12px;font-size:16px}.chat-send-btn{width:36px;height:36px;font-size:16px}.chat-toggle{border-radius:20px;padding:10px 16px;font-size:14px}.chat-badge{padding:2px 6px;font-size:11px}}@media (max-width:400px){.home-title{font-size:1.8rem}.home-subtitle{letter-spacing:6px;font-size:.85rem}.home-card{padding:16px}.btn{padding:9px 16px;font-size:13px}.game-page{padding:8px}.game-layout{gap:12px}.modal-box{padding:24px 16px}.modal-emoji{font-size:40px}.modal-title{font-size:20px}.chat-box.open{width:98%;max-height:50vh;right:1%}.side-panel{gap:10px}.game-info{gap:8px;min-height:170px;padding:12px}.captured-pieces{min-height:38px;max-height:56px;padding:9px 10px}.captured-char{margin:2px;font-size:15px}.move-history{min-height:220px;padding:12px}.move-list{min-height:140px;max-height:180px}}@media (max-width:767px) and (orientation:landscape){.game-page{padding:12px}.game-layout{flex-flow:row;justify-content:center;align-items:flex-start;gap:12px}.board-area{flex-shrink:0;order:2;max-width:45vh;max-height:85vh}.side-panel{flex-direction:column;gap:10px;width:220px;min-width:200px;max-width:240px}.side-panel:first-child{order:1}.side-panel:last-child{order:3}.game-info{gap:8px;min-height:auto;padding:12px}.captured-pieces{min-height:36px;max-height:52px;padding:8px 10px}.captured-char{font-size:14px}.move-history{min-height:200px;padding:12px}.move-list{min-height:120px;max-height:150px;font-size:11px}.action-buttons .btn{padding:8px 12px;font-size:12px}.chat-box.open{width:85%;max-height:70vh}}.chat-box{z-index:50;max-width:calc(100vw - 40px);position:fixed;bottom:20px;right:20px}.chat-toggle{background:linear-gradient(135deg,var(--accent-dark),var(--accent));color:#0a0f14;cursor:pointer;box-shadow:0 4px 20px var(--accent-glow);border:none;border-radius:24px;align-items:center;gap:8px;min-height:44px;padding:12px 20px;font-size:15px;font-weight:600;transition:all .2s;display:flex}.chat-toggle:hover{box-shadow:0 6px 30px var(--accent-glow);transform:translateY(-2px)}@media (hover:none){.chat-toggle:hover{transform:none}.chat-toggle:active{transform:scale(.95)}}.chat-badge{color:#fff;background:#ef4444;border-radius:12px;padding:2px 8px;font-size:12px;font-weight:700}.chat-box.open{width:350px;height:500px}.chat-content{background:var(--bg-card);border:1px solid var(--glass-border);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);transform-origin:100% 100%;border-radius:16px;flex-direction:column;height:100%;transition:opacity .2s,transform .2s;display:flex;overflow:hidden;box-shadow:0 20px 60px #000000b3}.chat-box.closed .chat-content{opacity:0;pointer-events:none;transform:scale(.92)translateY(8px)}.chat-box.open .chat-content{opacity:1;transform:scale(1)translateY(0)}.chat-box.closed .chat-toggle{display:flex}.chat-box.open .chat-toggle{display:none}.chat-header{border-bottom:1px solid var(--glass-border);background:linear-gradient(135deg,#22d3ee26,#22d3ee14);justify-content:space-between;align-items:center;padding:16px 20px;font-weight:600;display:flex}.chat-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:4px 8px;font-size:20px;transition:color .2s}.chat-close:hover{color:var(--text)}.chat-messages{scrollbar-width:thin;scrollbar-color:#22d3ee4d transparent;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;flex-direction:column;flex:1;gap:12px;padding:16px;display:flex;overflow-y:auto}.chat-messages::-webkit-scrollbar{width:6px}.chat-messages::-webkit-scrollbar-thumb{background:#22d3ee4d;border-radius:3px}.chat-empty{text-align:center;color:var(--text-muted);padding:40px 20px;font-size:14px;font-style:italic}.chat-message{flex-direction:column;gap:4px;max-width:80%;animation:.3s messageSlideIn;display:flex}@keyframes messageSlideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.chat-message.own{align-self:flex-end;align-items:flex-end}.chat-message.other{align-self:flex-start;align-items:flex-start}.chat-message-sender{color:var(--text-muted);padding:0 8px;font-size:11px;font-weight:600}.chat-message-text{word-wrap:break-word;border-radius:12px;padding:10px 14px;font-size:14px;line-height:1.4}.chat-message.own .chat-message-text{background:linear-gradient(135deg,var(--accent-dark),var(--accent));color:#0a0f14;border-bottom-right-radius:4px}.chat-message.other .chat-message-text{background:var(--glass-bg);color:var(--text);border:1px solid var(--glass-border);border-bottom-left-radius:4px}.chat-message-time{color:var(--text-muted);padding:0 8px;font-size:10px}.chat-input-form{border-top:1px solid var(--glass-border);background:#0003;gap:8px;padding:12px;display:flex}.chat-input{background:var(--glass-bg);border:1px solid var(--glass-border);color:var(--text);border-radius:20px;outline:none;flex:1;padding:10px 14px;font-size:14px;transition:all .2s}.chat-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.chat-send-btn{background:linear-gradient(135deg,var(--accent-dark),var(--accent));color:#0a0f14;cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-size:18px;transition:all .2s;display:flex}.chat-send-btn:hover:not(:disabled){box-shadow:0 4px 20px var(--accent-glow);transform:scale(1.1)}.chat-send-btn:disabled{opacity:.4;cursor:not-allowed}.voice-controls{background:var(--bg-card);border:1px solid var(--glass-border);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:12px;padding:14px;box-shadow:0 4px 16px #0003}.voice-error{color:#fca5a5;text-align:center;background:#ef44441a;border-radius:8px;padding:8px;font-size:13px}.voice-status{align-items:center;gap:12px;display:flex}.voice-buttons{gap:8px;display:flex}.voice-btn{cursor:pointer;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:20px;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex}.voice-btn.muted{color:#fca5a5;background:#ef444433;border:2px solid #ef4444}.voice-btn.muted:hover{background:#ef44444d;transform:scale(1.05)}.voice-btn.active{background:linear-gradient(135deg,var(--accent-dark),var(--accent));color:#0a0f14;box-shadow:0 4px 20px var(--accent-glow)}.voice-btn.active:hover{box-shadow:0 6px 30px var(--accent-glow);transform:scale(1.05)}.voice-info{flex-direction:column;flex:1;gap:4px;display:flex}.voice-label{color:var(--text);font-size:13px;font-weight:600}.voice-indicator{align-items:center;gap:6px;font-size:12px;display:flex}.voice-indicator.connected{color:var(--accent)}.voice-indicator.connecting{color:var(--text-muted);animation:1.5s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.voice-requesting{text-align:center;padding:8px}.voice-retry-btn{color:#fca5a5;cursor:pointer;background:#ef444433;border:1px solid #ef4444;border-radius:8px;margin:8px auto 0;padding:6px 14px;font-size:12px;transition:background .2s;display:block}.voice-retry-btn:hover{background:#ef444459}.chat-toggle.has-unread{animation:.6s infinite alternate chatBounce}@keyframes chatBounce{0%{box-shadow:0 4px 20px var(--accent-glow);transform:translateY(0)}to{box-shadow:0 8px 30px var(--accent-glow);transform:translateY(-4px)}}.install-prompt{z-index:60;animation:.4s cubic-bezier(.4,0,.2,1) slideUp;position:fixed;bottom:80px;left:50%;transform:translate(-50%)}@keyframes slideUp{0%{opacity:0;transform:translate(-50%)translateY(20px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.install-content{background:var(--bg-card);border:1px solid var(--glass-border);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:16px;align-items:center;gap:16px;max-width:90vw;padding:16px 20px;display:flex;box-shadow:0 20px 60px #000000b3}.install-icon{flex-shrink:0;font-size:32px}.install-text{flex:1;min-width:0}.install-text strong{color:var(--text);margin-bottom:4px;font-size:15px;display:block}.install-text p{color:var(--text-muted);margin:0;font-size:13px}.install-buttons{flex-shrink:0;gap:8px;display:flex}.btn-sm{padding:8px 16px;font-size:13px}@media (max-width:600px){.install-prompt{bottom:20px;left:10px;right:10px;transform:none}.install-content{text-align:center;flex-direction:column}.install-buttons{width:100%}.install-buttons button{flex:1}}.divider-text{color:var(--text-muted);text-align:center;align-items:center;gap:.75rem;margin:.85rem 0;font-size:.75rem;display:flex}.divider-text:before,.divider-text:after{content:"";background:#ffffff14;flex:1;height:1px}.tab-online-badge{background:var(--accent);color:#0a0f14;vertical-align:middle;border-radius:999px;justify-content:center;align-items:center;min-width:16px;height:16px;margin-left:5px;padding:0 4px;font-size:.65rem;font-weight:700;line-height:1;display:inline-flex}.recent-section{margin-bottom:.75rem}.recent-section-title{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:.5rem;font-size:.7rem;font-weight:600}.recent-empty{text-align:center;color:var(--text-muted);padding:2rem 1rem;font-size:.9rem}.recent-empty-icon{margin-bottom:.5rem;font-size:2rem}.recent-empty-sub{opacity:.7;margin-top:.25rem;font-size:.8rem}.player-row{background:#ffffff0a;border:1px solid #ffffff0f;border-radius:10px;align-items:center;gap:.75rem;margin-bottom:.4rem;padding:.6rem .75rem;transition:background .15s;display:flex}.player-row.online{background:#22d3ee0a;border-color:#22d3ee33}.player-row-avatar{width:36px;height:36px;color:var(--text-primary);background:#ffffff1a;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:1rem;font-weight:700;display:flex;position:relative}.online-dot{background:#22c55e;border:2px solid #0a0f14;border-radius:50%;width:10px;height:10px;position:absolute;bottom:0;right:0}.player-row-info{flex:1;min-width:0}.player-row-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.9rem;font-weight:600;overflow:hidden}.player-row-sub{color:var(--text-muted);margin-top:1px;font-size:.75rem}.player-row-actions{flex-shrink:0;gap:.4rem;display:flex}.pr-btn{cursor:pointer;border:none;border-radius:8px;padding:.35rem .6rem;font-size:.8rem;font-weight:600;line-height:1;transition:all .15s}.chat-btn{color:var(--text-primary);background:#ffffff14;position:relative}.chat-btn:hover{background:#ffffff26}.invite-btn{background:var(--accent);color:#0a0f14}.invite-btn:hover{filter:brightness(1.1)}.unread-badge{color:#fff;background:#ef4444;border-radius:999px;justify-content:center;align-items:center;min-width:14px;height:14px;padding:0 3px;font-size:.6rem;font-weight:700;line-height:1;display:flex;position:absolute;top:-4px;right:-4px}.lobby-chat-popup{z-index:1000;background:#111820;border:1px solid #22d3ee40;border-radius:14px;flex-direction:column;width:300px;max-height:420px;display:flex;position:fixed;bottom:1.5rem;right:1.5rem;overflow:hidden;box-shadow:0 8px 32px #0009}.lobby-chat-header{background:#22d3ee12;border-bottom:1px solid #22d3ee1f;justify-content:space-between;align-items:center;padding:.65rem 1rem;display:flex}.lobby-chat-peer-name{color:var(--accent);font-size:.9rem;font-weight:700}.lobby-chat-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:0;font-size:.85rem;line-height:1}.lobby-chat-close:hover{color:var(--text-primary)}.lobby-chat-messages{flex-direction:column;flex:1;gap:.4rem;padding:.75rem;display:flex;overflow-y:auto}.lobby-chat-empty{text-align:center;color:var(--text-muted);margin:auto;font-size:.8rem}.lobby-chat-msg{display:flex}.lobby-chat-msg.from-me{justify-content:flex-end}.lobby-chat-msg.from-them{justify-content:flex-start}.lobby-chat-bubble{word-break:break-word;border-radius:12px;max-width:80%;padding:.4rem .7rem;font-size:.85rem;line-height:1.4}.lobby-chat-msg.from-me .lobby-chat-bubble{background:var(--accent);color:#0a0f14;border-bottom-right-radius:3px}.lobby-chat-msg.from-them .lobby-chat-bubble{color:var(--text-primary);background:#ffffff1a;border-bottom-left-radius:3px}.lobby-chat-input-row{border-top:1px solid #ffffff12;gap:.4rem;padding:.6rem;display:flex}.lobby-chat-input{color:var(--text-primary);background:#ffffff12;border:1px solid #ffffff1a;border-radius:8px;outline:none;flex:1;padding:.45rem .7rem;font-size:1rem}.lobby-chat-input:focus{border-color:var(--accent)}.lobby-chat-send-btn{background:var(--accent);color:#0a0f14;cursor:pointer;border:none;border-radius:8px;padding:0 .75rem;font-size:1rem;transition:filter .15s}.lobby-chat-send-btn:disabled{opacity:.4;cursor:not-allowed}.lobby-chat-send-btn:not(:disabled):hover{filter:brightness(1.1)}.invite-notification{z-index:2000;background:#1a2332;border:1px solid #22d3ee66;border-radius:14px;align-items:flex-start;gap:.75rem;width:calc(100vw - 2rem);max-width:360px;padding:1rem 1.25rem;animation:.25s slideDown;display:flex;position:fixed;top:1rem;left:50%;transform:translate(-50%);box-shadow:0 8px 32px #000000b3,0 0 0 1px #22d3ee1a}.invite-icon{flex-shrink:0;font-size:1.5rem;line-height:1}.invite-content{flex:1}.invite-title{text-transform:uppercase;letter-spacing:.06em;color:var(--accent);margin-bottom:.2rem;font-size:.75rem;font-weight:600}.invite-from{color:var(--text-primary);font-size:.9rem}.invite-countdown{color:var(--text-muted);margin-top:.15rem;font-size:.75rem}.invite-actions{flex-direction:column;flex-shrink:0;gap:.4rem;display:flex}.invite-btn{cursor:pointer;white-space:nowrap;border:none;border-radius:8px;padding:.4rem .8rem;font-size:.8rem;font-weight:700;transition:filter .15s}.invite-btn.accept{background:var(--accent);color:#0a0f14}.invite-btn.accept:hover{filter:brightness(1.1)}.invite-btn.decline{color:var(--text-primary);background:#ffffff14}.invite-btn.decline:hover{background:#ffffff24}.game-type-selector{background:#ffffff0a;border-radius:10px;gap:.5rem;margin-bottom:1rem;padding:4px;display:flex}.game-type-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:8px;flex:1;padding:.5rem;font-size:.85rem;font-weight:600;transition:all .2s}.game-type-btn.active{background:var(--accent);color:#0a0f14}.game-type-btn:not(.active):hover{color:var(--text-primary);background:#ffffff12}.caro-page{flex-direction:column;align-items:center;gap:.75rem;min-height:100vh;padding:.75rem 1rem 2rem;display:flex}.caro-header{justify-content:space-between;align-items:center;width:100%;max-width:520px;display:flex}.caro-room-code{color:var(--text-muted);letter-spacing:.05em;font-size:.8rem;font-weight:600}.caro-players{justify-content:space-between;gap:.5rem;width:100%;max-width:520px;display:flex}.caro-player{background:#ffffff08;border:1px solid #ffffff0f;border-radius:8px;flex:1;align-items:center;gap:.45rem;padding:.4rem .75rem;transition:border-color .2s,background .2s;display:flex}.caro-player.active{background:#22d3ee0f;border-color:#22d3ee59}.caro-player-dot{border-radius:50%;flex-shrink:0;width:12px;height:12px}.caro-player-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.82rem;font-weight:600;overflow:hidden}.caro-turn-badge{background:var(--accent);color:#0a0f14;white-space:nowrap;border-radius:4px;margin-left:auto;padding:1px 5px;font-size:.68rem;font-weight:700}.caro-board-wrap{-webkit-overflow-scrolling:touch;cursor:grab;max-width:100%;padding:4px;overflow:auto}.caro-board-wrap:active{cursor:grabbing}.caro-board{background:#5a3e1c;border:2px solid #8a6a3a;border-radius:6px;flex-shrink:0;grid-template-rows:repeat(15,40px);grid-template-columns:repeat(15,40px);gap:1px;display:grid;overflow:hidden}.caro-cell{cursor:pointer;background:#d4a855;justify-content:center;align-items:center;width:40px;height:40px;transition:background .1s;display:flex;position:relative;box-shadow:inset 0 0 0 .5px #0000002e}.caro-cell:hover{background:#e8c070}.caro-cell--last{background:#b8e0f0!important}.caro-cell--win{background:#ffe066!important}.caro-piece{-webkit-user-select:none;user-select:none;filter:drop-shadow(0 1px 2px #00000080);font-size:1.7rem;line-height:1}.caro-piece--red{color:#c0392b}.caro-piece--black{color:#1a1a1a}.caro-actions{align-items:center;gap:.5rem;display:flex}.caro-confirm-text{color:var(--text-muted);font-size:.85rem}.caro-gameover-overlay{z-index:100;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000b3;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.caro-gameover-modal{text-align:center;background:#111820;border:1px solid #22d3ee40;border-radius:16px;width:90%;max-width:320px;padding:2rem 2.5rem;box-shadow:0 8px 40px #0009}.caro-gameover-icon{margin-bottom:.5rem;font-size:3rem}.caro-gameover-title{margin-bottom:.25rem;font-size:1.5rem;font-weight:700}.caro-gameover-reason{color:var(--text-muted);margin-bottom:1rem;font-size:.85rem}.caro-gameover-actions{justify-content:center;gap:.5rem;margin-top:1.25rem;display:flex}.guide-page{max-width:860px;min-height:100vh;margin:0 auto;padding:32px 24px 64px}.guide-breadcrumb{color:var(--text-muted);margin-bottom:16px;font-size:.85rem}.guide-breadcrumb a{color:var(--accent);text-decoration:none}.guide-breadcrumb a:hover{text-decoration:underline}.guide-header{text-align:center;margin-bottom:48px;position:relative}.guide-back-btn{border:1px solid var(--border-bright);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:8px;padding:6px 14px;font-size:.85rem;transition:color .2s,border-color .2s;position:absolute;top:0;left:0}.guide-back-btn:hover{color:var(--accent);border-color:var(--accent)}.guide-header h1{background:linear-gradient(135deg,var(--accent),#60a5fa);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:12px;padding-top:8px;font-size:2.2rem;font-weight:800}.guide-subtitle{color:var(--text-muted);font-size:1rem;line-height:1.6}.guide-content{flex-direction:column;gap:40px;display:flex}.guide-section{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:28px 32px}.guide-section h2{color:var(--accent);border-bottom:1px solid var(--border);margin-bottom:16px;padding-bottom:10px;font-size:1.3rem;font-weight:700}.guide-section p{color:var(--text);font-size:.97rem;line-height:1.75}.guide-section p strong{color:var(--accent)}.guide-section p em{color:var(--red-bright);font-style:normal}.guide-list{flex-direction:column;gap:10px;list-style:none;display:flex}.guide-list li{color:var(--text);padding-left:20px;font-size:.97rem;line-height:1.7;position:relative}.guide-list li:before{content:"›";color:var(--accent);font-weight:700;position:absolute;left:0}.guide-list li strong{color:var(--accent)}.guide-pieces{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;margin-top:4px;display:grid}.guide-piece-card{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:12px;padding:16px}.guide-piece-symbol{color:var(--accent);margin-bottom:8px;font-family:Noto Serif SC,serif;font-size:2rem}.guide-piece-card h3{color:var(--text);margin-bottom:6px;font-size:.95rem;font-weight:700}.guide-piece-card p{color:var(--text-muted);font-size:.88rem;line-height:1.6}.guide-piece-card p strong{color:var(--accent)}.guide-piece-card p em{color:var(--red-bright);font-style:normal}.guide-cta{text-align:center;border-color:var(--border-bright)}.guide-cta h2{border-bottom:none;margin-bottom:8px}.guide-cta p{color:var(--text-muted);margin-bottom:20px}.guide-play-btn{padding:12px 36px;font-size:1.1rem}.guide-links{flex-wrap:wrap;justify-content:center;gap:12px;margin-top:24px;display:flex}.guide-link-btn{border:1px solid var(--border-bright);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:8px;padding:8px 18px;font-size:.85rem;text-decoration:none;transition:color .2s,border-color .2s;display:inline-block}.guide-link-btn:hover{color:var(--accent);border-color:var(--accent)}@media (max-width:600px){.guide-header h1{font-size:1.5rem}.guide-back-btn{margin-bottom:16px;display:inline-block;position:static}.guide-section{padding:20px 16px}.guide-pieces{grid-template-columns:1fr 1fr}}
