*,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:#3b82f680;--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:#3b82f680;--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }/*
! tailwindcss v3.4.17 | MIT License | https://tailwindcss.com
*/*,:after,:before{border:0 solid #e5e7eb;box-sizing:border-box}:after,:before{--tw-content:""}:host,html{-webkit-text-size-adjust:100%;font-feature-settings:normal;-webkit-tap-highlight-color:transparent;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-variation-settings:normal;line-height:1.5;tab-size:4}body{line-height:inherit}hr{border-top-width:1px;color:inherit;height:0}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-feature-settings:normal;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:1em;font-variation-settings:normal}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:initial}sub{bottom:-.25em}sup{top:-.5em}table{border-collapse:collapse;border-color:inherit;text-indent:0}button,input,optgroup,select,textarea{font-feature-settings:inherit;color:inherit;font-family:inherit;font-size:100%;font-variation-settings:inherit;font-weight:inherit;letter-spacing:inherit;line-height:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:initial;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:initial}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::placeholder,textarea::placeholder{color:#9ca3af;opacity:1}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{height:auto;max-width:100%}[hidden]:where(:not([hidden=until-found])){display:none}.visible{visibility:visible}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.inset-0{inset:0}.z-50{z-index:50}.m-0{margin:0}.mx-auto{margin-left:auto;margin-right:auto}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mt-2{margin-top:.5rem}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.grid{display:grid}.hidden{display:none}.h-4{height:1rem}.h-8{height:2rem}.min-h-screen{min-height:100vh}.w-4{width:1rem}.w-8{width:2rem}.w-full{width:100%}.max-w-lg{max-width:32rem}.max-w-md{max-width:28rem}.flex-1{flex:1 1}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.animate-spin{animation:spin 1s linear infinite}.resize{resize:both}.flex-col{flex-direction:column}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-5{gap:1.25rem}.break-all{word-break:break-all}.rounded{border-radius:.25rem}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.border{border-width:1px}.bg-gray-50{--tw-bg-opacity:1;background-color:#f9fafb;background-color:rgb(249 250 251/var(--tw-bg-opacity,1))}.bg-red-50{--tw-bg-opacity:1;background-color:#fef2f2;background-color:rgb(254 242 242/var(--tw-bg-opacity,1))}.bg-white{--tw-bg-opacity:1;background-color:#fff;background-color:rgb(255 255 255/var(--tw-bg-opacity,1))}.bg-yellow-50{--tw-bg-opacity:1;background-color:#fefce8;background-color:rgb(254 252 232/var(--tw-bg-opacity,1))}.p-4{padding:1rem}.p-6{padding:1.5rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.py-2{padding-bottom:.5rem;padding-top:.5rem}.py-3{padding-bottom:.75rem;padding-top:.75rem}.py-4{padding-bottom:1rem;padding-top:1rem}.py-5{padding-bottom:1.25rem;padding-top:1.25rem}.text-center{text-align:center}.text-2xl{font-size:1.5rem;line-height:2rem}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-4xl{font-size:2.25rem;line-height:2.5rem}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-semibold{font-weight:600}.text-gray-600{--tw-text-opacity:1;color:#4b5563;color:rgb(75 85 99/var(--tw-text-opacity,1))}.text-red-600{--tw-text-opacity:1;color:#dc2626;color:rgb(220 38 38/var(--tw-text-opacity,1))}.text-yellow-600{--tw-text-opacity:1;color:#ca8a04;color:rgb(202 138 4/var(--tw-text-opacity,1))}.shadow{--tw-shadow:0 1px 3px 0 #0000001a,0 1px 2px -1px #0000001a;--tw-shadow-colored:0 1px 3px 0 var(--tw-shadow-color),0 1px 2px -1px var(--tw-shadow-color)}.shadow,.shadow-lg{box-shadow:0 0 #0000,0 0 #0000,var(--tw-shadow);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.shadow-lg{--tw-shadow:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;--tw-shadow-colored:0 10px 15px -3px var(--tw-shadow-color),0 4px 6px -4px var(--tw-shadow-color)}.outline{outline-style:solid}.drop-shadow{--tw-drop-shadow:drop-shadow(0 1px 2px #0000001a) drop-shadow(0 1px 1px #0000000f)}.drop-shadow,.invert{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.invert{--tw-invert:invert(100%)}.sepia{--tw-sepia:sepia(100%)}.filter,.sepia{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition{transition-duration:.15s;transition-property:color,background-color,border-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-text-decoration-color,-webkit-backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter,-webkit-text-decoration-color,-webkit-backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-all{transition-duration:.15s;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1)}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.focus\:outline-none:focus{outline:2px solid #0000;outline-offset:2px}@media (min-width:640px){.sm\:mb-4{margin-bottom:1rem}.sm\:mb-6{margin-bottom:1.5rem}.sm\:mb-8{margin-bottom:2rem}.sm\:gap-4{gap:1rem}.sm\:p-10{padding:2.5rem}.sm\:p-6{padding:1.5rem}.sm\:p-8{padding:2rem}.sm\:px-5{padding-left:1.25rem;padding-right:1.25rem}.sm\:px-6{padding-left:1.5rem;padding-right:1.5rem}.sm\:py-4{padding-bottom:1rem;padding-top:1rem}.sm\:py-6{padding-bottom:1.5rem;padding-top:1.5rem}.sm\:text-3xl{font-size:1.875rem;line-height:2.25rem}.sm\:text-4xl{font-size:2.25rem;line-height:2.5rem}.sm\:text-5xl{font-size:3rem;line-height:1}.sm\:text-base{font-size:1rem;line-height:1.5rem}.sm\:text-sm{font-size:.875rem;line-height:1.25rem}.sm\:text-xl{font-size:1.25rem;line-height:1.75rem}}.card-preview-overlay{pointer-events:none;position:fixed;z-index:200}.card-preview-overlay.open{pointer-events:auto}.card-preview-overlay.desktop{background:#0000;inset:0}.card-preview-content.desktop{animation:fadeInScale .2s ease-out;filter:drop-shadow(0 10px 25px rgba(0,0,0,.3));pointer-events:auto;position:absolute}.card-preview-content.desktop .card-preview-card{transform-origin:bottom center}@keyframes fadeInScale{0%{opacity:0;transform:translate(-50%,calc(-100% - 10px)) scale(.9)}to{opacity:1;transform:translate(-50%,calc(-100% - 10px)) scale(1)}}.card-preview-overlay.mobile{align-items:flex-end;background:#0000;display:flex;inset:0;justify-content:center}.card-preview-backdrop{animation:fadeIn .3s ease-out;background:#00000080;inset:0;position:absolute}.card-preview-content.mobile{--tw-bg-opacity:1;--tw-shadow:0 25px 50px -12px #00000040;--tw-shadow-colored:0 25px 50px -12px var(--tw-shadow-color);animation:slideUp .3s ease-out;background-color:#fff;background-color:rgb(255 255 255/var(--tw-bg-opacity,1));border-top-left-radius:1rem;border-top-right-radius:1rem;box-shadow:0 0 #0000,0 0 #0000,var(--tw-shadow);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow);display:flex;flex-direction:column;gap:1rem;max-height:70vh;max-width:500px;padding:1rem;pointer-events:auto;position:relative;width:100%}.card-preview-handle{--tw-bg-opacity:1;background-color:#d1d5db;background-color:rgb(209 213 219/var(--tw-bg-opacity,1));border-radius:9999px;height:4px;margin-bottom:.5rem;margin-left:auto;margin-right:auto;width:40px}.card-preview-card{align-items:center;display:flex;justify-content:center}.card-preview-close-btn{--tw-bg-opacity:1;--tw-text-opacity:1;background-color:#e5e7eb;background-color:rgb(229 231 235/var(--tw-bg-opacity,1));border-radius:.5rem;color:#1f2937;color:rgb(31 41 55/var(--tw-text-opacity,1));font-weight:600;padding-bottom:.75rem;padding-top:.75rem;transition-duration:.15s;transition-property:color,background-color,border-color,fill,stroke,-webkit-text-decoration-color;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,-webkit-text-decoration-color;transition-timing-function:cubic-bezier(.4,0,.2,1);width:100%}.card-preview-close-btn:hover{--tw-bg-opacity:1;background-color:#d1d5db;background-color:rgb(209 213 219/var(--tw-bg-opacity,1))}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@media (min-width:641px){.card-preview-overlay.mobile{display:none}}@media (max-width:640px){.card-preview-overlay.desktop{display:none}.card-preview-content.mobile{max-height:80vh;padding:.75rem}}.card-preview-modal-backdrop{align-items:center;animation:backdropFadeIn .2s ease-out;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#000000b3;display:flex;inset:0;justify-content:center;padding:1rem;position:fixed;z-index:10002}@keyframes backdropFadeIn{0%{opacity:0}to{opacity:1}}.card-preview-modal-content{--tw-shadow:0 25px 50px -12px #00000040;--tw-shadow-colored:0 25px 50px -12px var(--tw-shadow-color);animation:modalSlideIn .3s ease-out;background:linear-gradient(145deg,#2c1810,#1a0f08);border:3px solid #c9a961;border-radius:8px;box-shadow:0 0 #0000,0 0 #0000,var(--tw-shadow);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow);box-shadow:0 0 40px #c9a9614d,inset 0 1px 0 #c9a96133;max-height:75vh;max-width:450px;overflow:hidden;overflow-y:auto;padding:1.25rem;position:relative;width:90vw}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.9) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.preview-close-btn{align-items:center;background:#c9a96126;border:1px solid #c9a961;border-radius:9999px;color:#c9a961;cursor:pointer;display:flex;font-size:1.1rem;font-weight:700;height:1.75rem;justify-content:center;position:absolute;right:.5rem;top:.5rem;transition:all .2s ease;width:1.75rem;z-index:10}.preview-close-btn:hover{background:#c9a9614d;transform:scale(1.1)}.preview-close-btn:active{transform:scale(.95)}.preview-card-icon{align-items:center;color:#f4d68a;display:flex;filter:drop-shadow(0 2px 8px rgba(244,214,138,.6));justify-content:center;margin-bottom:.75rem}.preview-card-header{border-bottom:2px solid #c9a9614d;margin-bottom:.75rem;padding-bottom:.5rem}.preview-card-name{color:#f4e4c1;font-family:Georgia,serif;font-size:1.25rem;font-weight:700;letter-spacing:.5px;line-height:1.75rem;margin-bottom:.25rem;text-align:center;text-shadow:0 2px 4px #000c}.preview-card-rarity{align-items:center;display:flex;font-size:1rem;font-weight:600;justify-content:center;line-height:1.5rem;text-transform:uppercase}.preview-rarity-text{text-shadow:0 1px 2px #0009}.preview-card-description{background:#c9a9611a;border:1px solid #c9a96140;border-radius:.25rem;margin-bottom:.75rem;padding:.625rem}.preview-card-description p{color:#d4c5a9;font-size:.875rem;line-height:1.25rem;line-height:1.625;text-shadow:0 1px 2px #0009}.preview-card-effects{margin-bottom:.75rem}.effects-title{color:#f4e4c1;font-family:Georgia,serif;font-size:.875rem;font-weight:700;line-height:1.25rem;margin-bottom:.5rem;text-shadow:0 2px 4px #000c}.preview-effect-item{background:#c9a96114;border:1px solid #c9a96140;border-radius:.25rem;margin-bottom:.5rem;padding:.625rem}.preview-effect-item:last-child{margin-bottom:0}.effect-type{color:#c9a961;font-weight:700;letter-spacing:.5px;margin-bottom:.375rem;text-transform:uppercase}.effect-description,.effect-type{font-size:.75rem;line-height:1rem;text-shadow:0 1px 2px #0009}.effect-description{color:#d4c5a9;line-height:1.625;margin-bottom:.25rem}.effect-duration,.effect-target{color:#b5a68d;font-size:11px;font-style:italic;margin-top:.25rem}.preview-card-meta{background:#c9a96114;border:1px solid #c9a96140;border-radius:.25rem;margin-bottom:.75rem;padding:.5rem}.preview-meta-row{align-items:center;display:flex;gap:.5rem;padding:.375rem .5rem}.preview-meta-row:not(:last-child){border-bottom:1px solid #c9a96126}.side-effect-row{background:#dc35451a}.cooldown-row{background:#ffc10714}.meta-icon{color:#c9a961;flex-shrink:0}.meta-label{color:#c9a961;font-weight:600;min-width:70px}.meta-label,.meta-value{font-size:.75rem;line-height:1rem}.meta-value{color:#d4c5a9;flex:1 1}.meta-value strong{color:#dc3545;font-weight:900}.meta-value.ready{color:#4caf50;font-weight:600}.cooldown-icon{color:#ffc107;font-size:.875rem;line-height:1.25rem}.cooldown-icon.ready{color:#4caf50}.preview-card-actions{border-top:1px solid #c9a9614d;display:flex;gap:.5rem;justify-content:center;padding-top:.5rem}.preview-action-btn{border:2px solid;border-radius:.25rem;cursor:pointer;font-family:Georgia,serif;font-size:.875rem;font-weight:600;line-height:1.25rem;padding:.5rem 1.25rem;transition-duration:.2s;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1)}.preview-action-btn:hover{box-shadow:0 2px 8px #c9a9614d;transform:translateY(-1px)}.preview-action-btn:active{transform:translateY(0)}.play-btn{background:linear-gradient(135deg,#4a7c59,#2d5a3a);border-color:#5a8c6a;color:#f4e4c1}.play-btn:hover{background:linear-gradient(135deg,#5a8c69,#3d6a4a)}.cancel-btn,.close-btn{background:#c9a96126;border-color:#c9a961;color:#f4e4c1}.cancel-btn:hover,.close-btn:hover{background:#c9a96140}@media (max-width:640px){.card-preview-modal-content{max-height:85vh;padding:.875rem}.preview-card-name{font-size:1.125rem;line-height:1.75rem}.preview-card-rarity{font-size:.875rem;line-height:1.25rem}.effects-title{font-size:.75rem;line-height:1rem;margin-bottom:.375rem}.preview-effect-item{margin-bottom:.375rem;padding:.5rem}.effect-type{font-size:11px;margin-bottom:.25rem}.effect-description,.effect-duration,.effect-target{font-size:10px}.preview-card-actions{flex-direction:column;gap:.5rem}.preview-action-btn{font-size:.75rem;line-height:1rem;padding:.375rem 1rem;width:100%}.meta-label{min-width:55px}.meta-label,.meta-value{font-size:10px}.preview-card-description{margin-bottom:.5rem;padding:.5rem}.preview-card-description p{font-size:.75rem;line-height:1rem}}@media (min-width:641px) and (max-width:1024px){.card-preview-modal-content{max-width:400px;padding:1rem}}.card-preview-modal-content::-webkit-scrollbar{width:8px}.card-preview-modal-content::-webkit-scrollbar-track{background:#0000004d;border-radius:4px}.card-preview-modal-content::-webkit-scrollbar-thumb{background:#c9a961;border-radius:4px}.card-preview-modal-content::-webkit-scrollbar-thumb:hover{background:#d4b972}.card{--tw-bg-opacity:1;--tw-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;--tw-shadow-colored:0 4px 6px -1px var(--tw-shadow-color),0 2px 4px -2px var(--tw-shadow-color);background-color:#fff;background-color:rgb(255 255 255/var(--tw-bg-opacity,1));border:3px solid #0000;border-radius:.5rem;box-shadow:0 0 #0000,0 0 #0000,var(--tw-shadow);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow);max-width:220px;min-width:180px;overflow:hidden;transition-duration:.2s;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1)}.card,.card.mini{position:relative}.card.mini{align-items:center;background:linear-gradient(135deg,#fff,#f8f4eb);border:2px solid #d4c4a8;border-left:4px solid #0000;border-radius:.25rem;box-shadow:0 2px 6px #00000040,inset 0 1px 0 #fff9;display:flex;flex-direction:row;max-height:64px;min-height:54px;padding:8px;transition:all .2s ease;width:100%}.card.mini.clickable:hover:not(.disabled){background:linear-gradient(135deg,#fff,#fffbf5);border-color:#e0d4ba;box-shadow:0 4px 10px #00000059,0 0 20px #c9a96126,inset 0 1px 0 #fffc;transform:translateY(-2px)}.card.mini.selected{background:linear-gradient(135deg,#f8ecd1,#f0e1bc);border:2px solid #9b7f42;border-left:4px solid #8b6f3a;box-shadow:0 2px 8px #8b6f3a4d,inset 0 1px 0 #ffffff4d}.card.mini.selected:after{animation:checkmarkFadeIn .3s ease-out;background:#ffffff80;border:2px solid #4a7c59;border-radius:50%;bottom:6px;box-shadow:0 2px 6px #4a7c594d;color:#4a7c59;content:"✓";font-size:16px;font-weight:700;height:28px;pointer-events:none;position:absolute;right:60px;width:28px;z-index:1}.card-mini-icon,.card.mini.selected:after{align-items:center;display:flex;justify-content:center}.card-mini-icon{background:radial-gradient(circle at 30% 30%,#c9a96140,#0000 70%),linear-gradient(135deg,#3d2817,#2c1810);border:2.5px solid #c9a961bf;border-radius:.25rem;box-shadow:inset 0 3px 6px #0009,inset 0 -2px 4px #c9a96140,0 3px 8px #0006,0 0 12px #c9a96126;flex-shrink:0;height:44px;margin-right:8px;padding:4px;transition:all .2s ease;width:44px}.card-mini-icon:hover{border-color:#c9a961f2;box-shadow:inset 0 3px 6px #0009,inset 0 -2px 4px #c9a96159,0 4px 10px #00000080,0 0 16px #c9a9614d;transform:scale(1.03)}.card-mini-icon .card-image-icon{font-size:1.875rem;line-height:2.25rem}.card-mini-icon img{filter:drop-shadow(0 0 4px rgba(201,169,97,.6)) drop-shadow(0 2px 6px rgba(0,0,0,.8)) brightness(1.08);transition:filter .2s ease}.card-mini-icon:hover img{filter:drop-shadow(0 0 6px rgba(201,169,97,.8)) drop-shadow(0 2px 6px rgba(0,0,0,.8)) brightness(1.12)}.card-mini-icon svg{color:#f4d68a;filter:drop-shadow(0 0 3px rgba(244,214,138,.5)) drop-shadow(0 2px 4px rgba(0,0,0,.9));transition:filter .2s ease}.card-mini-icon:hover svg{filter:drop-shadow(0 0 5px rgba(244,214,138,.7)) drop-shadow(0 2px 4px rgba(0,0,0,.9))}.card-mini-content{display:flex;flex:1 1;flex-direction:column;gap:2px;overflow:hidden}.card.mini .card-name{--tw-text-opacity:1;-webkit-line-clamp:2;-webkit-box-orient:vertical;color:#1f2937;color:rgb(31 41 55/var(--tw-text-opacity,1));display:-webkit-box;font-size:.75rem;font-weight:700;line-height:1rem;line-height:1.25;overflow:hidden;text-overflow:ellipsis}.card.mini .card-rarity{font-size:.75rem;font-weight:600;letter-spacing:.025em;line-height:1rem;text-transform:uppercase}.card.row{align-items:stretch;background:linear-gradient(135deg,#f4e4c1,#e8d8b8);border:2px solid #8b7355;border-left:4px solid #0000;border-radius:4px;box-shadow:0 2px 4px #0000004d,inset 0 1px 0 #ffffff4d;display:flex;flex-direction:row;max-width:100%;min-height:0;min-height:auto;min-width:100%;padding:8px;position:relative;transition:all .2s ease;width:100%}.card-row-icon{align-items:center;background:linear-gradient(135deg,#3d2817,#2c1810);border:2px solid #c9a961;border-radius:.25rem;box-shadow:inset 0 2px 4px #0006;display:flex;flex-shrink:0;height:50px;justify-content:center;margin-right:10px;width:50px}.card-row-icon .card-image-icon{filter:drop-shadow(0 2px 2px rgba(0,0,0,.6));font-size:1.875rem;line-height:2.25rem}.card-row-icon img{filter:drop-shadow(0 2px 4px rgba(0,0,0,.6)) brightness(1.15)}.card-row-icon svg{color:#f4d68a;filter:drop-shadow(0 2px 4px rgba(0,0,0,.8))}.card-row-content{display:flex;flex:1 1;flex-direction:column;gap:2px;justify-content:center}.card-row-header{align-items:center;display:flex;gap:8px;justify-content:space-between}.card.row .card-name{color:#2c1810;flex:1 1;font-family:Georgia,serif;font-size:.875rem;font-weight:700;line-height:1.25rem;text-shadow:0 1px 1px #ffffff80}.card.row .card-rarity{flex-shrink:0;font-size:.75rem;font-weight:600;letter-spacing:.025em;line-height:1rem;text-shadow:0 1px 1px #0000004d;text-transform:uppercase}.card-row-description{word-wrap:break-word;color:#4a3829;font-size:.75rem;line-height:1rem;line-height:1.25;overflow-wrap:break-word;text-shadow:0 1px 0 #ffffff4d}.card.row.selected{background:linear-gradient(135deg,#f8ecd1,#f0e1bc);border:2px solid #9b7f42;border-left:4px solid #8b6f3a;box-shadow:0 3px 10px #8b6f3a4d,inset 0 1px 0 #ffffff4d;position:relative}.card.row.selected:after{align-items:center;animation:checkmarkFadeIn .3s ease-out;background:#ffffff80;border:3px solid #4a7c59;border-radius:50%;bottom:8px;box-shadow:0 4px 12px #4a7c594d;color:#4a7c59;content:"✓";display:flex;font-size:32px;font-weight:700;height:60px;justify-content:center;pointer-events:none;position:absolute;right:10px;width:60px;z-index:1}.card.row:hover:not(.disabled):not(.selected){background:linear-gradient(135deg,#f8e8c8,#ecdcbc);box-shadow:0 3px 8px #0006,inset 0 1px 0 #fff6;transform:translateX(2px)}.card.row.selected:hover:not(.disabled){background:linear-gradient(135deg,#fbf0d6,#f4e4c1);border:2px solid #a68855;border-left:4px solid #8b6f3a;box-shadow:0 4px 15px #8b6f3a66,inset 0 1px 0 #fff6;transform:translateX(2px)}.card.row.selected:hover:after{background:#ffffffa6;box-shadow:0 5px 15px #4a7c5966}.card.row:active:not(.disabled):not(.selected){background:linear-gradient(135deg,#f0ddb8,#e4d1ac);box-shadow:0 2px 6px #0000004d,inset 0 1px 0 #fff6;transform:translateX(1px) scale(.99)}.card.row.selected:active:not(.disabled){background:linear-gradient(135deg,#f0e1bc,#e8d8b8);border:2px solid #9b7f42;border-left:4px solid #8b6f3a;box-shadow:0 2px 8px #8b6f3a4d,inset 0 1px 0 #fff3;transform:translateX(1px)}.card.clickable{cursor:pointer}.card.clickable:hover:not(.disabled){--tw-translate-y:-0.25rem;--tw-shadow:0 20px 25px -5px #0000001a,0 8px 10px -6px #0000001a;--tw-shadow-colored:0 20px 25px -5px var(--tw-shadow-color),0 8px 10px -6px var(--tw-shadow-color);transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.card.clickable:hover:not(.disabled),.card.selected{box-shadow:0 0 #0000,0 0 #0000,var(--tw-shadow);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.card.selected{--tw-shadow:0 25px 50px -12px #00000040;--tw-shadow-colored:0 25px 50px -12px var(--tw-shadow-color);background:linear-gradient(180deg,#fef3e1,#f4e4c1);border:3px solid #c9a961}.card.disabled{opacity:.5}.card.mini.disabled{cursor:pointer}.card.mini.disabled:hover{box-shadow:0 3px 8px #0000004d,inset 0 1px 0 #ffffff40;transform:translateY(-1px)}.card.row.disabled{cursor:not-allowed}.card-header{--tw-gradient-from:#f9fafb var(--tw-gradient-from-position);--tw-gradient-to:#f9fafb00 var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to);--tw-gradient-to:#f3f4f6 var(--tw-gradient-to-position);align-items:flex-start;background-image:linear-gradient(to right,var(--tw-gradient-stops));display:flex;justify-content:space-between;padding:.75rem}.card-name{--tw-text-opacity:1;color:#1f2937;color:rgb(31 41 55/var(--tw-text-opacity,1));flex:1 1;font-size:.875rem;font-weight:700;line-height:1.25rem}.card-rarity{font-size:.75rem;font-weight:600;letter-spacing:.025em;line-height:1rem;margin-left:.5rem;text-transform:uppercase}.card-image-container{--tw-bg-opacity:1;background-color:#f9fafb;background-color:rgb(249 250 251/var(--tw-bg-opacity,1));min-height:120px;padding:1rem}.card-image-container,.card-image-placeholder{align-items:center;display:flex;justify-content:center}.card-image-placeholder{aspect-ratio:1/1;background:linear-gradient(135deg,#3d2817,#2c1810);border-color:#8b7355cc;border-radius:.375rem;border-width:4px;box-shadow:inset 0 2px 8px #00000080;width:100%}.card-image-icon{font-size:3.75rem;line-height:1}.card-image-placeholder svg{color:#f4d68a;filter:drop-shadow(0 2px 4px rgba(0,0,0,.8))}.card-image{border-radius:.375rem;filter:drop-shadow(0 4px 8px rgba(0,0,0,.3)) brightness(1.1);max-height:100%;max-width:100%;object-fit:contain}.compact-card-image{filter:drop-shadow(0 1px 2px rgba(0,0,0,.2))}.compact-card-image,.preview-card-image{border-radius:.25rem;max-height:100%;max-width:100%}.preview-card-image{filter:drop-shadow(0 2px 4px rgba(0,0,0,.15));object-fit:contain}.card-description{--tw-bg-opacity:1;background-color:#fff;background-color:rgb(255 255 255/var(--tw-bg-opacity,1));min-height:80px;padding:.75rem}.card-description p{--tw-text-opacity:1;color:#374151;color:rgb(55 65 81/var(--tw-text-opacity,1));font-size:.75rem;line-height:1rem;line-height:1.625}.card-selection-modal .card .card-image-container{min-height:60px;padding:.5rem}.card-selection-modal .card .card-image-icon{font-size:2.25rem;line-height:2.5rem}.card-selection-modal .card .card-description{max-height:100px;min-height:0;overflow-y:auto;padding:.5rem}.card-selection-modal .card .card-description p{font-size:.75rem;line-height:1rem;line-height:1.375}@media (max-width:640px){.card{max-width:160px;min-width:140px}.card.row.selected:after{border:2px solid #4a7c59;bottom:6px;font-size:24px;height:45px;right:8px;width:45px}.card.mini.selected:after{bottom:4px;font-size:14px;height:24px;right:50px;width:24px}.card-image-container{min-height:80px}.card-image-icon{font-size:2.25rem;line-height:2.5rem}.card-description{min-height:60px}.card.mini{max-height:58px;min-height:48px;padding:6px;width:100%}.card-mini-icon{border:2px solid #c9a961b3;box-shadow:inset 0 2px 4px #0009,inset 0 -1px 3px #c9a96133,0 2px 6px #00000059,0 0 10px #c9a9611f;height:38px;margin-right:6px;padding:3px;width:38px}.card-mini-icon:hover{transform:scale(1.02)}.card-mini-icon .card-image-icon{font-size:1.5rem;line-height:2rem}.card-mini-icon img{filter:drop-shadow(0 0 3px rgba(201,169,97,.5)) drop-shadow(0 1px 4px rgba(0,0,0,.7)) brightness(1.06)}.card-mini-icon:hover img{filter:drop-shadow(0 0 4px rgba(201,169,97,.7)) drop-shadow(0 1px 4px rgba(0,0,0,.7)) brightness(1.1)}.card-mini-icon svg{filter:drop-shadow(0 0 2px rgba(244,214,138,.4)) drop-shadow(0 1px 3px rgba(0,0,0,.85))}}.card-side-effect,.card-side-effect-full{align-items:center;background:#4a382914;border-left:3px solid #d4a574;border-radius:0 2px 2px 0;border-top:1px solid #8b73554d;display:flex;gap:.5rem;margin-top:4px;padding:4px 6px}.card-side-effect .side-effect-text,.card-side-effect-full .side-effect-text{word-wrap:break-word;color:#4a3829;flex:1 1;font-size:.75rem;font-weight:500;line-height:1rem;line-height:1.4;overflow-wrap:break-word;text-shadow:0 1px 0 #ffffff4d}.card-side-effect .side-effect-text strong,.card-side-effect-full .side-effect-text strong{color:#2c1810;font-weight:900}.card-side-effect .side-effect-icon,.card-side-effect-full .side-effect-icon{color:#8b5a2b;filter:drop-shadow(0 1px 1px rgba(0,0,0,.4));flex-shrink:0}.card-mini-side-effect{align-items:center;display:inline-flex;margin-top:2px}.card.row .card-side-effect{margin-bottom:2px;margin-top:4px}.side-effect-icon{display:inline-block;line-height:1}.card-mini-cooldown{display:inline-flex;font-size:.7rem;font-weight:600;margin-top:2px}.card-cooldown-info,.card-mini-cooldown{align-items:center;color:#6b7280;gap:.25rem}.card-cooldown-info{display:flex;font-size:.75rem;font-weight:500;margin-top:.25rem}.card-cooldown-full{align-items:center;background:#6b72801a;border:1px solid #6b728033;border-radius:.25rem;color:#6b7280;display:flex;font-size:.8rem;font-weight:600;gap:.5rem;justify-content:center;margin-top:.5rem;padding:.5rem}@keyframes checkmarkFadeIn{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}.timer-display.timer-active{box-shadow:0 0 8px #c9a96126,inset 0 1px 0 #ffffff26,0 4px 6px #0000004d;transform:scale(1)}@media (max-width:640px){.timer-display{padding:4px 8px}.timer-value{font-size:18px}.timer-display.timer-inactive .timer-value{font-size:14px}.timer-increment{font-size:9px;padding:1px 4px}.timeout-label{font-size:13px;letter-spacing:1px}}@media (min-width:641px) and (max-width:1024px){.timer-value{font-size:20px}.timer-display.timer-inactive .timer-value{font-size:16px}.timeout-label{font-size:14px;letter-spacing:1.2px}}@media (min-width:1025px){.timer-display{padding:8px 14px}.timer-value{font-size:26px}.timer-display.timer-inactive .timer-value{font-size:18px}.timeout-label{font-size:16px;letter-spacing:1.5px}}.card-selection-overlay{align-items:center;animation:fadeIn .3s ease-out;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#000000b3;display:flex;inset:0;justify-content:center;position:fixed;z-index:50}.card-selection-modal{--tw-shadow:0 25px 50px -12px #00000040;--tw-shadow-colored:0 25px 50px -12px var(--tw-shadow-color);animation:modalZoom .3s ease-out;background:linear-gradient(145deg,#2c1810,#1a0f08);border:3px solid #c9a961;border-radius:8px;box-shadow:0 0 #0000,0 0 #0000,var(--tw-shadow);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow);box-shadow:0 0 40px #c9a9614d,inset 0 1px 0 #c9a96133;display:flex;flex-direction:column;max-height:70vh;max-width:700px;overflow:hidden;position:relative;width:90%}.card-selection-header{align-items:center;background:linear-gradient(180deg,#3d2817 0,#2c1810);border-bottom:1px solid #c9a9614d;display:flex;flex-shrink:0;flex-wrap:nowrap;gap:16px;justify-content:space-between;padding:1rem;position:relative}.card-selection-header h2{color:#f4e4c1;font-family:Georgia,serif;font-size:1.25rem;font-weight:700;letter-spacing:.5px;line-height:1.75rem;margin:0;text-shadow:0 2px 4px #000c}.selection-instructions{color:#d4c5a9;font-size:.75rem;line-height:1rem;margin-bottom:0;text-align:center;text-shadow:0 1px 2px #0009;width:100%}.floating-toggle-button{--tw-shadow:0 20px 25px -5px #0000001a,0 8px 10px -6px #0000001a;--tw-shadow-colored:0 20px 25px -5px var(--tw-shadow-color),0 8px 10px -6px var(--tw-shadow-color);background:linear-gradient(145deg,#3d2817,#2c1810);border:2px solid #c9a961;border-radius:.25rem;box-shadow:0 0 #0000,0 0 #0000,var(--tw-shadow);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow);color:#f4e4c1;font-size:.875rem;font-weight:600;line-height:1.25rem;padding:.5rem 1rem;position:fixed;right:1rem;top:1rem;transition-duration:.2s;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);z-index:100}.floating-toggle-button:hover{--tw-scale-x:1.1;--tw-scale-y:1.1;box-shadow:0 0 20px #c9a96180;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.card-selection-list{background:repeating-linear-gradient(0deg,#c9a96108,#c9a96108 1px,#0000 0,#0000 40px),linear-gradient(180deg,#1a0f08,#2c1810);display:flex;flex:1 1;flex-direction:column;gap:.5rem;min-height:0;overflow-y:auto;padding:.625rem}.card-selection-list::-webkit-scrollbar{width:8px}.card-selection-list::-webkit-scrollbar-track{background:#0000004d}.card-selection-list::-webkit-scrollbar-thumb{background:#c9a961;border-radius:4px}.card-selection-list::-webkit-scrollbar-thumb:hover{background:#d4b972}.selected-new-card{background:linear-gradient(180deg,#2c1810,#1a0f08);border-bottom:1px solid #c9a9614d;flex-shrink:0;padding:.625rem}.selected-new-card h3{color:#f4e4c1;font-family:Georgia,serif;font-size:.875rem;font-weight:700;line-height:1.25rem;margin-bottom:.375rem;text-shadow:0 1px 2px #0009}.discard-selection{background:repeating-linear-gradient(0deg,#c9a96108,#c9a96108 1px,#0000 0,#0000 40px),linear-gradient(180deg,#1a0f08,#2c1810);flex:1 1;min-height:0;overflow-y:auto;padding:.625rem}.discard-selection h3{color:#f4e4c1;font-family:Georgia,serif;font-size:.875rem;font-weight:700;line-height:1.25rem;margin-bottom:.5rem;text-shadow:0 1px 2px #0009}.current-hand-cards{flex-wrap:wrap}.card-selection-actions,.current-hand-cards{display:flex;gap:.5rem;justify-content:center}.card-selection-actions{background:linear-gradient(0deg,#3d2817 0,#2c1810);border-top:2px solid #c9a961;flex-shrink:0;padding:.625rem}.back-button{--tw-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;--tw-shadow-colored:0 4px 6px -1px var(--tw-shadow-color),0 2px 4px -2px var(--tw-shadow-color);background:linear-gradient(135deg,#6b5b4e,#4a3f35);border:2px solid #8b7b6e;border-radius:.25rem;box-shadow:0 0 #0000,0 0 #0000,var(--tw-shadow);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow);color:#f4e4c1;font-family:Georgia,serif;font-size:.875rem;font-weight:700;letter-spacing:.5px;line-height:1.25rem;padding:.375rem 1rem;text-shadow:0 1px 2px #000c;transition-duration:.2s;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1)}.back-button:hover{--tw-translate-y:-0.25rem;border-color:#9b8b7e;box-shadow:0 4px 12px #6b5b4e66;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.confirm-button{--tw-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;--tw-shadow-colored:0 4px 6px -1px var(--tw-shadow-color),0 2px 4px -2px var(--tw-shadow-color);background:linear-gradient(135deg,#4a7c59,#2d5a3a);border:2px solid #5a8c6a;border-radius:.25rem;box-shadow:0 0 #0000,0 0 #0000,var(--tw-shadow);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow);color:#f4e4c1;font-family:Georgia,serif;font-size:.875rem;font-weight:700;letter-spacing:.5px;line-height:1.25rem;padding:.375rem 1.25rem;text-shadow:0 1px 2px #000c;transition-duration:.2s;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1)}.confirm-button:not(:disabled):hover{--tw-translate-y:-0.25rem;border-color:#6a9c7a;box-shadow:0 4px 12px #5a8c6a66;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.confirm-button:disabled{cursor:not-allowed;filter:grayscale(50%);opacity:.4}.skip-button{--tw-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;--tw-shadow-colored:0 4px 6px -1px var(--tw-shadow-color),0 2px 4px -2px var(--tw-shadow-color);background:linear-gradient(135deg,#7a5c4a,#5a3f2f);border:2px solid #9a7c6a;border-radius:.25rem;box-shadow:0 0 #0000,0 0 #0000,var(--tw-shadow);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow);color:#f4e4c1;font-family:Georgia,serif;font-size:.875rem;font-weight:700;letter-spacing:.5px;line-height:1.25rem;padding:.375rem 1rem;text-shadow:0 1px 2px #000c;transition-duration:.2s;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1)}.skip-button:hover{--tw-translate-y:-0.25rem;border-color:#aa8c7a;box-shadow:0 4px 12px #7a5c4a66;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.confirmed-text{color:#f4e4c1;font-family:Georgia,serif;font-size:.875rem;font-weight:500;line-height:1.25rem;padding:.375rem 1rem;text-shadow:0 1px 2px #000c}.waiting-overlay{align-items:center;background:#1a0f08f2;display:flex;flex-direction:column;inset:0;justify-content:center;position:absolute}.waiting-spinner{animation:spin 1s linear infinite;border:4px solid #c9a96133;border-radius:9999px;border-top-color:#c9a961;height:4rem;width:4rem}.waiting-overlay p{color:#f4e4c1;font-family:Georgia,serif;font-size:1.125rem;font-weight:500;line-height:1.75rem;margin-top:1rem;text-shadow:0 2px 4px #000c}@keyframes modalZoom{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.card-selection-timer-container{align-items:center;display:flex;flex-shrink:0}.card-selection-header .timer-display.timer-active{animation:none;box-shadow:0 0 5px #c9a9611f,inset 0 1px 0 #ffffff1a,0 2px 4px #0003;transform:scale(1)}@media (max-width:640px){.card-selection-modal{max-height:85vh;width:95%}.card-selection-header{flex-wrap:wrap;gap:12px;padding:.75rem}.card-selection-header h2{font-size:1rem;line-height:1.5rem}.selection-instructions{font-size:.75rem;line-height:1rem}.card-selection-list{gap:.5rem;max-height:calc(85vh - 200px);min-height:300px;padding:.5rem}.selected-new-card{padding:.5rem}.selected-new-card h3{font-size:.75rem;line-height:1rem}.discard-selection{padding:.5rem}.discard-selection h3{font-size:.75rem;line-height:1rem}.card-selection-actions{gap:.375rem;padding:.5rem}.back-button{padding:.25rem .75rem}.back-button,.confirm-button{font-size:.75rem;line-height:1rem}.confirm-button{padding:.375rem 1rem}.confirmed-text,.skip-button{font-size:.75rem;line-height:1rem;padding:.25rem .75rem}.floating-toggle-button{font-size:.75rem;line-height:1rem;padding:.375rem .75rem;right:.75rem;top:.75rem}}.promotion-modal-overlay{align-items:center;background-color:#000000b3;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.promotion-modal{background:#fff;border-radius:12px;box-shadow:0 8px 32px #0000004d;max-width:500px;padding:32px;width:90%}.promotion-modal h3{color:#333;font-size:24px;margin:0 0 8px;text-align:center}.promotion-instruction{color:#666;font-size:14px;margin:0 0 24px;text-align:center}.promotion-options{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(4,1fr)}.promotion-option{align-items:center;background:#f5f5f5;border:2px solid #ddd;border-radius:8px;cursor:pointer;display:flex;flex-direction:column;gap:8px;padding:20px 16px;transition:all .2s ease}.promotion-option:hover{background:#e8f4f8;border-color:#3b82f6;box-shadow:0 4px 12px #3b82f633;transform:translateY(-2px)}.promotion-option:active{transform:translateY(0)}.promotion-piece{filter:drop-shadow(0 2px 4px rgba(0,0,0,.2));height:64px;object-fit:contain;width:64px}.promotion-label{color:#555;font-size:14px;font-weight:600}@media (max-width:600px){.promotion-modal{padding:24px}.promotion-options{grid-template-columns:repeat(2,1fr)}.promotion-option{padding:16px 12px}.promotion-piece{height:48px;width:48px}}.player-info-bar{backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:linear-gradient(135deg,#f4e4c1f2,#e8d8b8f2);border:none;border-radius:0;box-shadow:none;overflow:hidden;padding:0;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1);width:100%}.player-info-bar.opponent-bar,.player-info-bar.player-bar{margin:0}.player-info-bar.active-turn{animation:activePulse 2s cubic-bezier(.4,0,.6,1) infinite;background:linear-gradient(135deg,#f4ecd1fa,#ecdcb8fa);border-color:#c9a96199;box-shadow:0 0 0 2px #c9a96133,0 10px 15px -3px #c9a96126,0 4px 6px -2px #0000000d,inset 0 1px 0 #ffffff80}.info-main-content{padding:10px 14px;position:relative;z-index:10}.info-row{gap:12px;justify-content:space-between;min-height:28px}.info-row,.info-section{align-items:center;display:flex}.info-section{gap:8px}.info-player-section{align-items:center;display:flex;gap:6px;min-width:120px}.info-icon{color:#2c1810;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2));font-size:1.5rem;line-height:2rem}.info-player-name{color:#2c1810;font-size:.875rem;font-weight:700;letter-spacing:.025em;line-height:1.25rem}.info-timer-section,.timer-display{align-items:center;display:flex}.timer-display{background:linear-gradient(135deg,#2a2a2ae6,#1f1f1fe6);border:1px solid #ffffff1a;border-radius:10px;box-shadow:inset 0 1px 0 #ffffff1a,0 2px 4px #0003;gap:.375rem;padding:6px 12px;transition:all .3s ease}.timer-display.timer-active{animation:timerActivePulse 2s cubic-bezier(.4,0,.6,1) infinite;background:linear-gradient(135deg,#141414f2,#0a0a0af2);border:2px solid #c9a96199;box-shadow:0 0 15px #c9a9614d,inset 0 1px 0 #ffffff26,0 4px 6px #0000004d;transform:scale(1.05)}.timer-display.timer-inactive{background:linear-gradient(135deg,#f0f0f0d9,#dcdcdcd9);border:1px solid #64646480;box-shadow:0 1px 3px #0000001a;opacity:1;transform:scale(1)}.timer-display.timer-inactive .timer-value{color:#4b5563}.timer-value{color:#fff;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:22px;font-weight:700;letter-spacing:.05em;transition:all .3s ease}.timer-increment{align-items:center;background:#4a9eff33;border-radius:12px;color:#4a9eff;display:flex;font-size:10px;font-weight:600;gap:.125rem;padding:2px 6px}.timer-status{background:#9ca3af4d;border-radius:4px;color:#9ca3af;font-size:.75rem;font-style:italic;line-height:1rem;padding:2px 6px}.timer-display.timer-waiting{border-color:#9ca3af4d;opacity:.7}.timer-display.timer-waiting .timer-value{color:#9ca3af}.timer-display.timer-active.time-safe{border-color:#4ade8080}.timer-display.timer-active.time-safe .timer-value{color:#4ade80}.timer-display.timer-active.time-warning{background:linear-gradient(135deg,#43382af2,#31291ff2);border-color:#fb923c80}.timer-display.timer-active.time-warning .timer-value{color:#fb923c}.timer-display.timer-active.time-critical{animation:criticalPulse 1s ease-in-out infinite;background:linear-gradient(135deg,#432a2afa,#311f1ffa);border-color:#ef444499}.timer-display.timer-active.time-critical .timer-value{animation:criticalBlink 1s ease-in-out infinite;color:#f87171}@keyframes activePulse{0%,to{box-shadow:0 0 0 2px #c9a96133,0 10px 15px -3px #c9a96126,0 4px 6px -2px #0000000d}50%{box-shadow:0 0 0 4px #c9a96140,0 10px 15px -3px #c9a96133,0 4px 6px -2px #0000000d}}@keyframes timerActivePulse{0%,to{border-color:#c9a96199;box-shadow:0 0 15px #c9a9614d,inset 0 1px 0 #ffffff26,0 4px 6px #0000004d}50%{border-color:#c9a961cc;box-shadow:0 0 20px #c9a96180,inset 0 1px 0 #fff3,0 6px 8px #0006}}@keyframes criticalPulse{0%,to{border-color:#ef444480}50%{border-color:#ef4444cc}}@keyframes criticalBlink{0%,to{opacity:1}50%{opacity:.7}}@media (max-width:640px){.player-info-bar{border-radius:0}.info-main-content{padding:8px 10px}.info-row{gap:8px}.info-player-section{min-width:80px}.info-icon{font-size:1.25rem;line-height:1.75rem}.info-player-name{font-size:.75rem;line-height:1rem}.timer-display{padding:4px 8px}.timer-value{font-size:18px}.timer-display.timer-inactive .timer-value{font-size:14px}.timer-increment{font-size:9px;padding:1px 4px}.timeout-label{font-size:13px;letter-spacing:1px}}@media (min-width:641px) and (max-width:1024px){.info-main-content{padding:10px 12px}.info-icon{font-size:1.25rem;line-height:1.75rem}.timer-value{font-size:20px}.timer-display.timer-inactive .timer-value{font-size:16px}.timeout-label{font-size:14px;letter-spacing:1.2px}}@media (min-width:1025px){.player-info-bar{border-radius:0}.info-main-content{padding:12px 16px}.info-row{gap:16px}.info-icon{font-size:1.875rem;line-height:2.25rem}.info-player-name{font-size:1rem;line-height:1.5rem}.timer-display{padding:8px 14px}.timer-value{font-size:26px}.timer-display.timer-inactive .timer-value{font-size:18px}.timeout-label{font-size:16px;letter-spacing:1.5px}}.timer-display.time-expired{animation:timeout-pulse 1.5s ease-in-out infinite!important;background:linear-gradient(135deg,#7f1d1df2,#991b1bf2)!important;border:2px solid #dc2626e6!important;opacity:1!important;transform:scale(1)!important}.timer-display.timeout-state{align-items:center;display:flex;justify-content:center;padding:8px 16px}.timeout-label{color:#fecaca!important;font-size:16px;font-weight:800;letter-spacing:1.5px;text-shadow:0 1px 2px #00000080;text-transform:uppercase}@keyframes timeout-pulse{0%,to{border-color:#dc2626e6;box-shadow:0 0 15px #dc262680}50%{border-color:#ef4444;box-shadow:0 0 25px #dc2626cc}}.game-info-bar{backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:linear-gradient(135deg,#3d2817f2,#2c1810f2);border:none;border-radius:0;margin:0;overflow:hidden;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1);width:100%}.game-info-content{align-items:center;display:flex;gap:.75rem;justify-content:space-between;padding:10px 16px}.game-info-resign-button{align-items:center;background:linear-gradient(135deg,#8b4513d9,#652c0cd9);border:1px solid #8b451399;border-radius:6px;box-shadow:0 2px 4px #0000004d;color:#f4e4c1;cursor:pointer;display:flex;font-size:13px;font-weight:600;gap:.375rem;padding:6px 12px;text-shadow:0 1px 2px #00000080;transition:all .2s ease}.game-info-resign-button:hover{background:linear-gradient(135deg,#a0522de6,#783714e6);border-color:#a0522db3;box-shadow:0 4px 6px #0006;transform:translateY(-1px)}.game-info-resign-button:active{box-shadow:0 2px 4px #0000004d;transform:translateY(0)}.game-info-resign-button .resign-icon{font-size:14px;line-height:1}.game-info-resign-button .resign-label{letter-spacing:.025em}.turn-badge{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:linear-gradient(135deg,#c9a9614d,#8b73554d);border:1px solid #c9a96180;border-radius:20px;display:flex;gap:.5rem;padding:6px 12px}.turn-badge-label{color:#c9a961;font-size:.75rem;font-weight:600;letter-spacing:.1em;line-height:1rem;text-transform:uppercase}.turn-badge-number{text-shadow:0 1px 2px #00000080}.game-status-message,.turn-badge-number{color:#f4e4c1;font-size:1rem;font-weight:700;line-height:1.5rem}.game-status-message{letter-spacing:.025em;text-shadow:0 2px 4px #00000080}.game-info-bar.check-active{animation:checkPulse 1.5s ease-in-out infinite;background:linear-gradient(135deg,#5a1a1af2,#7f1d1df2)}.game-info-bar.check-active .game-status-message{color:#fee2e2;font-weight:700}.game-outcome-actions{align-items:center;display:flex;gap:.5rem}.outcome-action-button{border:2px solid;border-radius:.25rem;box-shadow:0 2px 4px #0006;cursor:pointer;font-family:Georgia,serif;font-size:.75rem;font-weight:700;line-height:1rem;padding:.5rem 1rem;transition-duration:.2s;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);white-space:nowrap}.outcome-action-button:hover{box-shadow:0 4px 6px #0006;transform:translateY(-1px)}.outcome-action-button:active{box-shadow:0 2px 4px #0000004d;transform:translateY(0)}.outcome-action-button.primary{background:linear-gradient(135deg,#f4e4c1,#e8d8b8);border-color:#8b7355;color:#2c1810;text-shadow:0 1px 0 #ffffff80}.outcome-action-button.primary:hover{background:linear-gradient(135deg,#f8e8c8,#ecdcbc)}.outcome-action-button.secondary{background:linear-gradient(135deg,#3d2817,#2c1810);border-color:#c9a961;color:#f4e4c1}.outcome-action-button.secondary:hover{background:linear-gradient(135deg,#4d3827,#3c2820)}.game-info-bar.game-ended-victory{animation:victoryPulse 2s ease-in-out infinite;background:linear-gradient(135deg,#2d5a3af2,#1a3d25f2)}.game-info-bar.game-ended-defeat{background:linear-gradient(135deg,#5a1a1af2,#7f1d1df2)}.game-info-bar.game-ended-stalemate{background:linear-gradient(135deg,#3d2817f2,#2c1810f2)}@media (max-width:640px){.game-info-content{gap:.5rem;padding:6px 10px}.turn-badge{gap:1.5;padding:4px 8px}.turn-badge-label{font-size:.75rem;line-height:1rem}.game-status-message,.turn-badge-number{font-size:.875rem;line-height:1.25rem}.game-status-message{font-weight:700}.game-info-resign-button{font-size:11px;gap:1;padding:4px 8px}.game-info-resign-button .resign-icon{font-size:12px}.game-info-resign-button .resign-label{display:none}.game-outcome-actions{gap:.375rem}.outcome-action-button{font-size:.75rem;font-size:10px;line-height:1rem;padding:.25rem .5rem}}@media (min-width:641px) and (max-width:1024px){.game-info-content{padding:8px 14px}.game-info-resign-button{font-size:12px;padding:5px 10px}.game-info-resign-button .resign-icon{font-size:13px}.outcome-action-button{font-size:11px;padding:.375rem .75rem}}@media (min-width:1025px){.game-info-content{gap:1rem;padding:12px 18px}.turn-badge{padding:8px 14px}.turn-badge-label{font-size:.875rem;line-height:1.25rem}.game-status-message,.turn-badge-number{font-size:1.125rem;line-height:1.75rem}.game-status-message{font-weight:700}.game-info-resign-button{font-size:14px;gap:2;padding:7px 14px}.game-info-resign-button .resign-icon{font-size:15px}.outcome-action-button{font-size:.875rem;line-height:1.25rem;padding:.5rem 1.25rem}}.game-info-bar.sacrifice-active{background:linear-gradient(135deg,#5a1a1af2,#7f1d1df2)}.card-indicator{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:linear-gradient(135deg,#c9a9614d,#8b73554d);border:1px solid #c9a96180;border-radius:20px;display:flex;gap:.5rem;padding:6px 12px}.card-indicator-label{color:#c9a961;font-size:.75rem;font-weight:600;letter-spacing:.1em;line-height:1rem;text-transform:uppercase}.card-indicator-name{color:#f4e4c1;font-size:.875rem;font-weight:700;line-height:1.25rem;text-shadow:0 1px 2px #00000080}.sacrifice-selection{align-items:center;display:flex;flex:1 1;gap:.5rem}.sacrifice-icon{color:#fee2e2;filter:drop-shadow(0 1px 2px rgba(0,0,0,.5))}.sacrifice-text{color:#fee2e2;font-family:Georgia,serif;font-size:.875rem;font-weight:600;line-height:1.25rem}.sacrifice-progress{color:#fbbf24;font-weight:700;margin-left:.25rem}.sacrifice-actions,.sacrifice-cancel-btn{align-items:center;display:flex}.sacrifice-cancel-btn{background:linear-gradient(135deg,#7f1d1d,#991b1b);border:2px solid #dc2626;border-radius:6px;box-shadow:0 2px 4px #0000004d;color:#f4e4c1;cursor:pointer;font-family:Georgia,serif;font-size:13px;font-weight:600;gap:.375rem;padding:6px 12px;text-shadow:0 1px 2px #00000080;transition:all .2s ease}.sacrifice-cancel-btn:hover{background:linear-gradient(135deg,#991b1b,#b91c1c);box-shadow:0 4px 6px #0006;transform:translateY(-1px)}.sacrifice-cancel-btn:active{box-shadow:0 2px 4px #0000004d;transform:translateY(0)}@media (max-width:640px){.card-indicator{gap:1.5;padding:4px 8px}.card-indicator-label,.card-indicator-name{font-size:.75rem;line-height:1rem}.sacrifice-icon{height:14px;width:14px}.sacrifice-progress,.sacrifice-text{font-size:.75rem;line-height:1rem}.sacrifice-cancel-btn{font-size:11px;gap:1;padding:4px 8px}.sacrifice-cancel-btn svg{height:14px;width:14px}.sacrifice-cancel-btn span{display:none}}@media (min-width:641px) and (max-width:1024px){.card-indicator{padding:5px 10px}.card-indicator-label{font-size:.75rem;line-height:1rem}.card-indicator-name{font-size:.875rem;line-height:1.25rem}.sacrifice-icon{height:16px;width:16px}.sacrifice-text{font-size:.875rem;line-height:1.25rem}.sacrifice-cancel-btn{font-size:12px;padding:5px 10px}}@media (min-width:1025px){.card-indicator{padding:7px 14px}.card-indicator-label{font-size:.875rem;line-height:1.25rem}.card-indicator-name{font-size:1rem;line-height:1.5rem}.sacrifice-icon{height:20px;width:20px}.sacrifice-text{font-size:1rem;line-height:1.5rem}.sacrifice-cancel-btn{font-size:14px;padding:7px 14px}}.game-info-bar.targeting-active{background:linear-gradient(135deg,#6d28d9f2,#9333eaf2)}.targeting-selection{align-items:center;display:flex;flex:1 1;gap:.5rem}.targeting-icon{color:#e9d5ff;filter:drop-shadow(0 1px 2px rgba(0,0,0,.5))}.targeting-text{color:#f3e8ff;font-family:Georgia,serif;font-size:.875rem;font-weight:600;line-height:1.25rem}.targeting-progress{color:#fbbf24;font-weight:700;margin-left:.25rem}.targeting-actions,.targeting-cancel-btn{align-items:center;display:flex}.targeting-cancel-btn{background:linear-gradient(135deg,#7f1d1d,#991b1b);border:2px solid #dc2626;border-radius:6px;box-shadow:0 2px 4px #0000004d;color:#f4e4c1;cursor:pointer;font-family:Georgia,serif;font-size:13px;font-weight:600;gap:.375rem;padding:6px 12px;text-shadow:0 1px 2px #00000080;transition:all .2s ease}.targeting-cancel-btn:hover{background:linear-gradient(135deg,#991b1b,#b91c1c);box-shadow:0 4px 6px #0006;transform:translateY(-1px)}.targeting-cancel-btn:active{box-shadow:0 2px 4px #0000004d;transform:translateY(0)}@media (max-width:640px){.targeting-icon{height:14px;width:14px}.targeting-progress,.targeting-text{font-size:.75rem;line-height:1rem}.targeting-cancel-btn{font-size:11px;gap:1;padding:4px 8px}.targeting-cancel-btn svg{height:14px;width:14px}.targeting-cancel-btn span{display:none}}@media (min-width:641px) and (max-width:1024px){.targeting-icon{height:16px;width:16px}.targeting-text{font-size:.875rem;line-height:1.25rem}.targeting-cancel-btn{font-size:12px;padding:5px 10px}}@media (min-width:1025px){.targeting-icon{height:20px;width:20px}.targeting-text{font-size:1rem;line-height:1.5rem}.targeting-cancel-btn{font-size:14px;padding:7px 14px}}.compact-card{align-items:center;background:linear-gradient(135deg,#f4e4c1,#e8d8b8);border-radius:.25rem;box-shadow:0 3px 6px #00000040,0 1px 3px #00000026;cursor:pointer;display:flex;overflow:visible;position:relative;transform:translateZ(0);transition:all .2s ease;width:100%}.compact-card.clickable:hover{box-shadow:0 6px 12px #0000004d,0 2px 4px #0003;transform:translateY(-2px) translateZ(0);z-index:10}.compact-card.clickable:active{box-shadow:0 2px 4px #0000004d;transform:translateY(0)}.compact-card.disabled{filter:grayscale(20%);opacity:.7}.compact-card.disabled:hover{box-shadow:0 4px 8px #00000047,0 1px 3px #0000002e;transform:translateY(-1px) translateZ(0)}.playable-glow{animation:glowPulse 3s ease-in-out infinite;border:1px solid;border-radius:inherit;inset:0;opacity:.15;pointer-events:none;position:absolute}@keyframes glowPulse{0%,to{opacity:.1}50%{opacity:.2}}.compact-card-icon{align-items:center;background:#0000;border-radius:0 6px 6px 0;display:flex;flex-shrink:0;height:36px;justify-content:center;overflow:hidden;padding:3px;transition:all .2s ease;width:36px}.compact-card-icon:hover{transform:scale(1.05)}.card-icon-symbol{color:#2c1810;filter:drop-shadow(0 1px 1px rgba(255,255,255,.5))}.compact-card-image{filter:brightness(0) saturate(100%) invert(13%) sepia(55%) saturate(35%) hue-rotate(340deg) drop-shadow(0 1px 1px rgba(255,255,255,.5));object-fit:contain;transition:filter .2s ease}.compact-card-icon:hover .compact-card-image{filter:brightness(0) saturate(100%) invert(13%) sepia(55%) saturate(35%) hue-rotate(340deg) drop-shadow(0 1px 2px rgba(255,255,255,.6))}.compact-card-content{align-items:center;display:flex;flex:1 1;overflow:hidden}.compact-card-name{color:#2c1810;font-family:Georgia,serif;font-weight:700;line-height:1.25;overflow:hidden;text-overflow:ellipsis;text-shadow:0 1px 1px #ffffff80;white-space:nowrap;width:100%}.compact-card-side-effect{align-items:center;background:#ffffffe6;border:1px solid #8b735533;border-radius:50%;box-shadow:0 2px 4px #00000026,0 1px 2px #0000001a,inset 0 1px 0 #ffffff80;display:flex;flex-shrink:0;justify-content:center;padding:3px}@media (max-width:640px){.compact-card{align-items:center;flex-direction:column;gap:.375rem;height:auto;min-height:56px;padding:.375rem}.compact-card-icon{border-radius:4px;flex-shrink:0;height:24px;padding:2px;width:24px}.compact-card-content{padding:0;text-align:center;width:100%}.card-icon-symbol{font-size:1rem}.compact-card-name{font-size:.75rem;line-height:1.3;overflow:visible;text-overflow:clip;white-space:normal}.compact-card-side-effect{position:absolute;right:4px;top:4px;z-index:2}}@media (min-width:641px) and (max-width:1024px){.compact-card{gap:.375rem;height:36px;padding:.25rem .5rem .25rem 0}.compact-card-icon{border-radius:0 5px 5px 0;flex-shrink:0;height:34px;padding:2.5px;width:34px}.card-icon-symbol{font-size:1.125rem}.compact-card-name{font-size:.75rem}.compact-card-preview-btn{height:36px;width:36px}}@media (min-width:1025px){.compact-card{gap:.375rem;height:38px;padding:.25rem .75rem .25rem 0}.compact-card-icon{flex-shrink:0;height:36px;padding:3px;width:36px}.card-icon-symbol{font-size:1.25rem}.compact-card-name{font-size:.8rem}.compact-card-preview-btn{height:38px;width:38px}}.compact-card-preview-tooltip{--tw-shadow:0 25px 50px -12px #00000040;--tw-shadow-colored:0 25px 50px -12px var(--tw-shadow-color);animation:tooltipFadeIn .2s ease-out;background:linear-gradient(135deg,#f4e4c1,#e8d8b8);border:3px solid #c9a961;border-radius:.5rem;bottom:calc(100% + 8px);box-shadow:0 0 #0000,0 0 #0000,var(--tw-shadow);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow);box-shadow:0 8px 24px #0009,inset 0 1px 0 #ffffff4d;left:50%;max-width:350px;min-width:280px;padding:.75rem;pointer-events:none;position:absolute;transform:translateX(-50%);z-index:100}.compact-card-preview-tooltip:after{border:8px solid #0000;border-top-color:#c9a961;content:"";left:50%;position:absolute;top:100%;transform:translateX(-50%)}@keyframes tooltipFadeIn{0%{opacity:0;transform:translateX(-50%) translateY(-4px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}.preview-header{align-items:flex-start;border-bottom:2px solid #8b73554d;display:flex;justify-content:space-between;margin-bottom:.5rem;padding-bottom:.5rem}.preview-title{color:#2c1810;font-family:Georgia,serif;font-size:.875rem;font-weight:700;line-height:1.25rem;text-shadow:0 1px 1px #ffffff80}.preview-rarity{font-size:.75rem;font-weight:600;line-height:1rem;text-shadow:0 1px 1px #0003;text-transform:uppercase}.preview-description{color:#4a3829;font-size:.75rem;line-height:1rem;line-height:1.625;margin-bottom:.5rem}.preview-effect{margin-bottom:.25rem}.preview-effect strong{color:#2c1810;font-weight:700;text-transform:capitalize}.preview-metadata{border-top:1px solid #8b735533;color:#6b5845;font-size:.75rem;font-style:italic;line-height:1rem;padding-top:.5rem}@media (max-width:1024px){.compact-card-preview-tooltip{display:none}}.compact-card.on-cooldown{filter:grayscale(20%);opacity:.6;overflow:hidden}.compact-card.on-cooldown:hover{box-shadow:0 4px 8px #00000047,0 1px 3px #0000002e;opacity:.65;transform:translateY(-1px) translateZ(0)}.compact-card-cooldown-overlay{align-items:center;background:#00000080;display:flex;flex-direction:column;inset:0;justify-content:center;pointer-events:none;position:absolute;z-index:5}.cooldown-lock-icon{color:#fff;filter:drop-shadow(0 2px 4px rgba(0,0,0,.8));margin-bottom:2px}.cooldown-turns-badge{align-items:center;background:#ffffffe6;border-radius:9999px;box-shadow:0 2px 4px #0006;color:#2c1810;display:flex;font-size:.75rem;font-weight:700;height:22px;justify-content:center;width:22px}.preview-cooldown-warning{background:#ffc10733;border:1px solid #ffc10766;border-radius:.25rem;color:#856404;font-size:.75rem;font-weight:600;line-height:1rem;margin-top:.5rem;padding:.5rem;text-align:center}@media (max-width:640px){.cooldown-lock-icon{height:16px;width:16px}.cooldown-turns-badge{font-size:.65rem;height:18px;width:18px}}@media (min-width:641px) and (max-width:1024px){.cooldown-lock-icon{height:18px;width:18px}.cooldown-turns-badge{font-size:.7rem;height:20px;width:20px}}.inline-card-display{background:linear-gradient(135deg,#f4e4c1,#e8d8b8);border:none;box-shadow:inset 0 1px 0 #ffffff4d;box-sizing:border-box;overflow:hidden;padding:.375rem .5rem;width:100%}.inline-card-display.player-cards{border-bottom:1px solid #8b735533}.inline-card-display.opponent-cards{border-top:1px solid #8b735533;opacity:.95}.card-scroll-container{display:flex;gap:.5rem;overflow:hidden;padding:0}.card-scroll-container>*{flex:1 1;max-width:100%;min-width:0}.card-empty-slot{align-items:center;background:#d4c5a940;border:2px dashed #8b735559;border-radius:.25rem;box-shadow:inset 0 2px 4px #00000026,inset 0 1px 2px #0000001a;display:flex;justify-content:center;opacity:.5;transition:opacity .2s ease}.card-empty-slot:hover{opacity:.7}.empty-slot-icon{filter:grayscale(100%);opacity:.6}.empty-slot-text{color:#8b7355;font-family:Georgia,serif;font-size:.75rem;font-weight:600;line-height:1rem;margin-left:.25rem;opacity:.8}@media (max-width:640px){.inline-card-display{padding:.25rem .375rem}.card-scroll-container{gap:.375rem}.card-empty-slot{align-items:center;flex-direction:column;gap:.375rem;height:auto;justify-content:center;min-height:56px;padding:.375rem}.empty-slot-icon{font-size:.875rem}.empty-slot-text{font-size:.75rem;line-height:1.3}}@media (min-width:641px) and (max-width:1024px){.inline-card-display{padding:.5rem .75rem}.card-scroll-container{gap:.5rem}.card-empty-slot{gap:.375rem;height:36px;padding:.375rem .625rem}.empty-slot-icon{font-size:1rem}}@media (min-width:1025px){.inline-card-display{padding:.5rem 1rem}.card-scroll-container{gap:.625rem}.card-empty-slot{gap:.5rem;height:38px;padding:.5rem .75rem}.empty-slot-icon{font-size:1.125rem}}.debug-card-selector{left:10px;position:fixed;top:10px;z-index:10000}.debug-toggle-button{background:linear-gradient(135deg,#3d2817,#2c1810);border:1px solid #c9a961;border-radius:4px;box-shadow:0 2px 6px #00000080;color:#f4e4c1;cursor:pointer;font-family:Georgia,serif;font-size:10px;font-weight:700;opacity:.7;padding:4px 8px;text-shadow:0 1px 2px #000c;transition:all .2s ease}.debug-toggle-button:hover{background:linear-gradient(135deg,#4d3827,#3c2820);box-shadow:0 4px 10px #c9a96166;opacity:1;transform:translateY(-1px)}.debug-modal-overlay{align-items:center;animation:fadeIn .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000d9;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:9999}.debug-modal-content{animation:slideIn .3s ease;background:linear-gradient(145deg,#2c1810,#1a0f08);border:3px solid #c9a961;border-radius:8px;box-shadow:0 0 40px #c9a9614d,inset 0 1px 0 #c9a96133;max-height:90vh;max-width:1200px;overflow-y:auto;padding:30px;width:90%}.debug-modal-header{border-bottom:2px solid #c9a961;margin-bottom:25px;padding-bottom:20px;position:relative}.debug-modal-header h2{color:#c9a961;font-family:Georgia,serif;font-size:28px;margin:0 0 10px;text-align:center;text-shadow:0 2px 4px #000c}.debug-warning{background:#c9a96133;border:1px solid #c9a961;border-radius:6px;color:#f4e4c1;font-size:14px;margin:10px 0;padding:10px}.debug-hand-status,.debug-warning{font-family:Georgia,serif;font-weight:700;text-align:center;text-shadow:0 1px 2px #0009}.debug-hand-status{color:#d4c5a9;font-size:16px;margin:10px 0 0}.debug-side-effect-selector{align-items:center;background:#c9a9611a;border:1px solid #c9a9614d;border-radius:8px;display:flex;gap:15px;justify-content:center;margin:20px 0;padding:15px 20px}.debug-side-effect-selector label{color:#c9a961;font-family:Georgia,serif;font-size:16px;font-weight:700;text-shadow:0 1px 2px #000c}.debug-side-effect-dropdown{background:linear-gradient(135deg,#f4e4c1,#e8d8b8);border:2px solid #c9a961;border-radius:6px;box-shadow:0 2px 4px #0000004d;color:#2c1810;cursor:pointer;font-family:Georgia,serif;font-size:14px;font-weight:700;min-width:250px;padding:8px 15px;transition:all .2s ease}.debug-side-effect-dropdown:hover{background:linear-gradient(135deg,#f8e8c8,#ecdcbc);box-shadow:0 4px 8px #c9a96166;transform:translateY(-1px)}.debug-side-effect-dropdown:focus{border-color:#d4b972;box-shadow:0 0 0 3px #c9a9614d;outline:none}.debug-close-button{background:#0000;border:none;color:#c9a961;cursor:pointer;font-size:32px;height:40px;line-height:40px;padding:0;position:absolute;right:0;top:0;transition:transform .2s ease;width:40px}.debug-close-button:hover{color:#d4b972;transform:rotate(90deg)}.debug-message{animation:slideDown .3s ease;border-radius:8px;font-weight:700;margin-bottom:20px;padding:12px 20px;text-align:center}.debug-message-success{background:#4a7c5933;border:2px solid #4a7c59;color:#6a9c7a;font-family:Georgia,serif}.debug-message-error{background:#8b451333;border:2px solid #8b4513;color:#c9a961;font-family:Georgia,serif}.debug-cards-container{display:flex;flex-direction:column;gap:30px}.debug-rarity-section{background:#c9a9610d;border:1px solid #c9a96133;border-radius:8px;padding:20px}.debug-rarity-title{border-radius:6px;display:inline-block;font-family:Georgia,serif;font-size:20px;font-weight:700;margin:0 0 15px;padding:10px 15px;text-shadow:0 1px 2px #000c}.debug-rarity-title.rarity-common{background:#8b735533;border:2px solid #8b7355;color:#8b7355}.debug-rarity-title.rarity-uncommon{background:#70809033;border:2px solid #708090;color:#708090}.debug-rarity-title.rarity-rare{background:#4169a033;border:2px solid #4169a0;color:#4169a0}.debug-rarity-title.rarity-legendary{background:#c9a96133;border:2px solid #c9a961;color:#c9a961}.debug-cards-grid{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.debug-card{background:linear-gradient(135deg,#f4e4c1,#e8d8b8);border:2px solid #0000;border-radius:6px;box-shadow:0 2px 4px #0000004d,inset 0 1px 0 #ffffff4d;display:flex;flex-direction:column;gap:10px;padding:15px;transition:all .2s ease}.debug-card:hover{background:linear-gradient(135deg,#f8e8c8,#ecdcbc);box-shadow:0 6px 16px #0006;transform:translateY(-4px)}.debug-card.rarity-common{border-color:#8b7355}.debug-card.rarity-uncommon{border-color:#708090}.debug-card.rarity-rare{border-color:#4169a0}.debug-card.rarity-legendary{border-color:#c9a961;box-shadow:0 0 20px #c9a9614d}.debug-card.recently-added{animation:highlightCard 1s ease}@keyframes highlightCard{0%,to{box-shadow:0 0 0 #4a7c5900}50%{box-shadow:0 0 30px #4a7c59cc}}.debug-card-header{align-items:start;display:flex;gap:10px;justify-content:space-between}.debug-card-header h4{color:#2c1810;flex:1 1;font-family:Georgia,serif;font-size:16px;margin:0;text-shadow:0 1px 1px #ffffff80}.debug-card-rarity{border-radius:4px;font-family:Georgia,serif;font-size:11px;font-weight:700;padding:4px 8px;text-transform:uppercase;white-space:nowrap}.debug-card-rarity.rarity-common{background:#8b7355;color:#f4e4c1}.debug-card-rarity.rarity-uncommon{background:#708090;color:#f4e4c1}.debug-card-rarity.rarity-rare{background:#4169a0;color:#f4e4c1}.debug-card-rarity.rarity-legendary{background:#c9a961;color:#2c1810}.debug-card-description{color:#4a3829;flex:1 1;font-size:13px;line-height:1.4;margin:0;text-shadow:0 1px 0 #ffffff4d}.debug-add-button{background:linear-gradient(135deg,#4a7c59,#2d5a3a);border:2px solid #5a8c6a;border-radius:4px;color:#f4e4c1;cursor:pointer;font-family:Georgia,serif;font-size:13px;font-weight:700;padding:10px 15px;text-shadow:0 1px 2px #000c;transition:all .2s ease}.debug-add-button:hover:not(:disabled){border-color:#6a9c7a;box-shadow:0 4px 12px #5a8c6a66;transform:scale(1.05)}.debug-add-button:disabled{background:linear-gradient(135deg,#6b5845,#4a3829);border-color:#8b7355;cursor:not-allowed;opacity:.5}.debug-modal-content::-webkit-scrollbar{width:10px}.debug-modal-content::-webkit-scrollbar-track{background:#0000004d;border-radius:5px}.debug-modal-content::-webkit-scrollbar-thumb{background:#c9a961;border-radius:5px}.debug-modal-content::-webkit-scrollbar-thumb:hover{background:#d4b972}.debug-freeze-params{background:#87ceeb1a;border:2px solid #87ceeb4d;border-radius:8px;display:flex;flex-wrap:wrap;gap:15px;margin-top:15px;padding:15px}.debug-param-group{display:flex;flex:1 1;flex-direction:column;gap:8px;min-width:150px}.debug-param-group label{color:#87ceeb;text-shadow:0 1px 2px #000c}.debug-param-dropdown,.debug-param-group label{font-family:Georgia,serif;font-size:14px;font-weight:700}.debug-param-dropdown{background:linear-gradient(135deg,#f4e4c1,#e8d8b8);border:2px solid #87ceeb;border-radius:6px;box-shadow:0 2px 4px #0000004d;color:#2c1810;cursor:pointer;padding:8px 12px;transition:all .2s ease}.debug-param-dropdown:hover{background:linear-gradient(135deg,#f8e8c8,#ecdcbc);box-shadow:0 4px 8px #87ceeb66;transform:translateY(-1px)}.debug-param-dropdown:focus{border-color:#4682b4;box-shadow:0 0 0 3px #87ceeb4d;outline:none}.effect-badge{align-items:center;animation:effectBadgePulse 2.5s ease-in-out infinite;border:2.5px solid;border-radius:9999px;box-shadow:0 0 0 1px #0006,0 2px 4px #00000080,inset 0 1px 0 #fff3;display:flex;font-family:Georgia,serif;font-weight:700;gap:.125rem;justify-content:center;min-height:18px;min-width:18px;padding:2px 4px;position:absolute;transform-origin:center center;z-index:20}.effect-badge-top-left{left:3px;top:3px}.effect-badge-top-right{right:3px;top:3px}.effect-badge-bottom-left{bottom:3px;left:3px}.effect-badge-bottom-right{bottom:3px;right:3px}.effect-badge-icon{align-items:center;color:#f4e4c1;display:flex;filter:drop-shadow(0 1px 1px rgba(0,0,0,.3));font-size:11px;justify-content:center;line-height:1;text-shadow:0 1px 2px #000c,0 0 3px #00000080}.effect-badge-count{color:#f4e4c1;font-size:10px;font-weight:700;line-height:1;min-width:10px;text-align:center;text-shadow:0 1px 2px #000000e6,0 0 2px #0009}@keyframes effectBadgePulse{0%,to{box-shadow:0 0 0 1px #0006,0 2px 4px #00000080,inset 0 1px 0 #fff3;transform:scale(1)}50%{box-shadow:0 0 0 1px #00000080,0 2px 6px #0009,0 0 8px #c9a96166,inset 0 1px 0 #ffffff4d;transform:scale(1.05)}}@media (max-width:640px){.effect-badge-mobile{align-items:center;animation:none;background:#0000;border:none;box-shadow:none;display:flex;font-family:Arial,sans-serif;font-size:15px;font-weight:900;justify-content:center;line-height:1;padding:0;pointer-events:none;position:absolute;z-index:20}.effect-badge-mobile.effect-badge-top-left{left:0;top:0}.effect-badge-mobile.effect-badge-top-right{right:0;top:0}.effect-badge-mobile.effect-badge-bottom-left{bottom:0;left:0}.effect-badge-mobile.effect-badge-bottom-right{bottom:0;right:0}.effect-badge-mobile-count{color:#fff;font-weight:900;text-shadow:-2px -2px 0 #000,2px -2px 0 #000,-2px 2px 0 #000,2px 2px 0 #000,-2.5px 0 0 #000,2.5px 0 0 #000,0 -2.5px 0 #000,0 2.5px 0 #000,-1px -2px 0 #000,1px -2px 0 #000,-1px 2px 0 #000,1px 2px 0 #000,-2px -1px 0 #000,2px -1px 0 #000,-2px 1px 0 #000,2px 1px 0 #000,0 0 5px #000000e6;text-shadow:-2px -2px 0 var(--outline-color,#000),2px -2px 0 var(--outline-color,#000),-2px 2px 0 var(--outline-color,#000),2px 2px 0 var(--outline-color,#000),-2.5px 0 0 var(--outline-color,#000),2.5px 0 0 var(--outline-color,#000),0 -2.5px 0 var(--outline-color,#000),0 2.5px 0 var(--outline-color,#000),-1px -2px 0 var(--outline-color,#000),1px -2px 0 var(--outline-color,#000),-1px 2px 0 var(--outline-color,#000),1px 2px 0 var(--outline-color,#000),-2px -1px 0 var(--outline-color,#000),2px -1px 0 var(--outline-color,#000),-2px 1px 0 var(--outline-color,#000),2px 1px 0 var(--outline-color,#000),0 0 5px #000000e6}.effect-badge-mobile:hover{transform:none}.effect-badge:not(.effect-badge-mobile){display:none}}@media (min-width:640px){.effect-badge{min-height:20px;min-width:20px;padding:2px 4px}.effect-badge-icon{font-size:12px}.effect-badge-count{font-size:11px}.effect-badge-top-left,.effect-badge-top-right{top:4px}.effect-badge-bottom-left,.effect-badge-bottom-right{bottom:4px}.effect-badge-bottom-left,.effect-badge-top-left{left:4px}.effect-badge-bottom-right,.effect-badge-top-right{right:4px}}@media (min-width:1024px){.effect-badge{border-width:3px;min-height:24px;min-width:24px;padding:3px 5px}.effect-badge-icon{font-size:14px}.effect-badge-count{font-size:12px}.effect-badge-top-left,.effect-badge-top-right{top:5px}.effect-badge-bottom-left,.effect-badge-bottom-right{bottom:5px}.effect-badge-bottom-left,.effect-badge-top-left{left:5px}.effect-badge-bottom-right,.effect-badge-top-right{right:5px}}.effect-badge:hover{animation:none;box-shadow:0 0 0 2px #0009,0 3px 8px #000000b3,0 0 12px #c9a96199,inset 0 1px 0 #fff6;cursor:help;transform:scale(1.2)!important;z-index:25}.modal-overlay{align-items:center;animation:fadeIn .2s ease-out;background-color:#000000b3;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.resign-modal{animation:slideIn .3s ease-out;background-color:#2c2416;border:2px solid #8b7355;border-radius:8px;box-shadow:0 8px 24px #00000080;max-width:400px;padding:24px;width:90%}@keyframes slideIn{0%{opacity:0;transform:translateY(-50px)}to{opacity:1;transform:translateY(0)}}.resign-modal h2{color:#f0e6d2;font-size:24px;font-weight:600;margin:0 0 16px}.resign-modal p{color:#d4c5a9;font-size:16px;line-height:1.5;margin:0 0 12px}.warning-text{color:#ff6b6b;font-size:14px;font-weight:500;margin-bottom:20px}.modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:24px}.cancel-button,.confirm-resign-button{border:none;border-radius:4px;cursor:pointer;font-size:16px;font-weight:500;padding:10px 20px;transition:all .2s}.cancel-button{background-color:#6c757d;color:#fff}.cancel-button:hover{background-color:#5a6268;box-shadow:0 4px 6px #0000004d;transform:translateY(-1px)}.confirm-resign-button{background-color:#dc3545;color:#fff}.confirm-resign-button:hover{background-color:#c82333;box-shadow:0 4px 6px #0000004d;transform:translateY(-1px)}.cancel-button:active,.confirm-resign-button:active{box-shadow:0 2px 4px #0003;transform:translateY(0)}.chess-game-container{background:linear-gradient(145deg,#1a0f08,#2c1810 50%,#1a0f08);font-family:Georgia,serif;gap:0;min-height:100vh;overflow-x:hidden;overflow-y:auto;width:100vw}.chess-game,.chess-game-container{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:0}.chess-game{margin:0;width:100%}.board-width-container{box-sizing:border-box;margin:0;max-width:100vw;width:100vw}@media (min-width:640px){.board-width-container{margin:0 auto;max-width:min(calc(100vw - 1rem),calc(100vh - 150px));width:min(calc(100vw - 1rem),calc(100vh - 150px))}}@media (min-width:1024px){.board-width-container{margin:0 auto;max-width:min(900px,90vw,calc(100vh - 180px));width:min(900px,90vw,calc(100vh - 180px))}}.player-section{border-left:3px solid #c9a961;border-right:3px solid #c9a961;box-shadow:0 0 0 8px #3d2817,0 0 0 10px #c9a961;display:flex;flex-direction:column;gap:8px;overflow:visible}.player-section-top{border-top:3px solid #c9a961;border-top-left-radius:4px;border-top-right-radius:4px;box-shadow:0 0 0 8px #3d2817,0 0 0 10px #c9a961,0 8px 16px #0006;margin-bottom:.25rem;margin-top:0}.player-section-bottom{border-bottom:3px solid #c9a961;border-bottom-left-radius:4px;border-bottom-right-radius:4px;box-shadow:0 0 0 8px #3d2817,0 0 0 10px #c9a961,0 -8px 16px #0006;margin-top:.25rem}@media (max-width:640px){.player-section{border-left-width:2px;border-right-width:2px;box-shadow:0 0 0 4px #3d2817,0 0 0 6px #c9a961}.player-section-top{border-top-width:2px;box-shadow:0 0 0 4px #3d2817,0 0 0 6px #c9a961,0 4px 8px #0000004d}.player-section-bottom{border-bottom-width:2px;box-shadow:0 0 0 4px #3d2817,0 0 0 6px #c9a961,0 -4px 8px #0000004d}}@media (min-width:640px){.player-section{border-left-width:4px;border-right-width:4px;box-shadow:0 0 0 8px #3d2817,0 0 0 11px #c9a961}.player-section-top{border-top-width:4px;box-shadow:0 0 0 8px #3d2817,0 0 0 11px #c9a961,0 8px 20px #00000080}.player-section-bottom{border-bottom-width:4px;box-shadow:0 0 0 8px #3d2817,0 0 0 11px #c9a961,0 -8px 20px #00000080}}@media (min-width:1024px){.player-section{border-left-width:5px;border-right-width:5px;box-shadow:0 0 0 10px #3d2817,0 0 0 14px #c9a961}.player-section-top{border-top-width:5px;box-shadow:0 0 0 10px #3d2817,0 0 0 14px #c9a961,0 10px 25px #0009}.player-section-bottom{border-bottom-width:5px;box-shadow:0 0 0 10px #3d2817,0 0 0 14px #c9a961,0 -10px 25px #0009}}.chess-board{aspect-ratio:1/1;border:3px solid #c9a961;border-radius:4px;box-shadow:0 0 0 8px #3d2817,0 0 0 10px #c9a961,0 20px 40px #0009;box-sizing:border-box;display:grid;flex-shrink:0;grid-template-columns:repeat(8,1fr);grid-template-rows:repeat(8,1fr);margin:0;max-width:100vw;width:100vw}@media (max-width:640px){.chess-board{border:2px solid #c9a961;box-shadow:0 0 0 4px #3d2817,0 0 0 6px #c9a961,0 10px 20px #00000080;max-height:calc(100vh - 130px);width:100vw}.chess-game-container{padding:0}}@media (min-width:640px){.chess-board{border:4px solid #c9a961;box-shadow:0 0 0 8px #3d2817,0 0 0 11px #c9a961,0 20px 40px #000000b3;margin:.25rem auto;max-height:min(calc(100vw - 1rem),calc(100vh - 150px));width:min(calc(100vw - 1rem),calc(100vh - 150px))}}@media (min-width:1024px){.chess-board{border:5px solid #c9a961;box-shadow:0 0 0 10px #3d2817,0 0 0 14px #c9a961,0 25px 50px #000c;margin:.5rem auto;max-height:min(900px,90vw,calc(100vh - 180px));width:min(900px,90vw,calc(100vh - 180px))}}.chess-square{align-items:center;cursor:pointer;display:flex;justify-content:center;position:relative;-webkit-user-select:none;user-select:none}.chess-square.light{background-color:#f0d9b5}.chess-square.dark{background-color:#b58863}.chess-square:hover{filter:brightness(1.1)}.chess-square.selected{background-color:#f7ec74!important;box-shadow:inset 0 0 0 2px #f7e83b}@media (min-width:640px){.chess-square.selected{box-shadow:inset 0 0 0 3px #f7e83b}}.chess-square.highlight-move{background-color:#ffeb9c!important}.chess-square.highlight-card{background-color:#a78bfa99!important;box-shadow:inset 0 0 10px #8b5cf666}.chess-square.highlight-sacrifice{background-color:#ef444480!important;box-shadow:inset 0 0 15px #dc262699}.chess-square.highlight-summon{background-color:#86efac99!important;box-shadow:inset 0 0 10px #4ade8080}.chess-square.valid-move{background-color:#90ee90!important}.chess-square.valid-move:hover{background-color:#7fdd7f!important}.chess-piece{align-items:center;cursor:grab;display:flex;height:calc(min(100vw, 100vh - 100px)/8*.85);justify-content:center;touch-action:none;width:calc(min(100vw, 100vh - 100px)/8*.85);z-index:10}.piece-image{filter:drop-shadow(1px 1px 2px rgba(0,0,0,.5));height:100%;object-fit:contain;pointer-events:none;-webkit-user-select:none;user-select:none;width:100%}@media (min-width:640px){.chess-piece{height:calc(min(100vw - 32px, 100vh - 140px)/8*.85);width:calc(min(100vw - 32px, 100vh - 140px)/8*.85)}}@media (min-width:1024px){.chess-piece{height:calc(min(800px, 90vw, 100vh - 160px)/8*.85);width:calc(min(800px, 90vw, 100vh - 160px)/8*.85)}}.chess-piece:hover{transform:scale(1.1)}.chess-piece.white{color:#fff;text-shadow:-1px -1px 0 #000,1px -1px 0 #000,-1px 1px 0 #000,1px 1px 0 #000,0 0 3px #000c}.chess-piece.black{color:#2c2c2c;text-shadow:-1px -1px 0 #fff,1px -1px 0 #fff,-1px 1px 0 #fff,1px 1px 0 #fff,0 0 2px #fffc}.move-indicator{background-color:#00640099;border-radius:9999px;height:calc(min(100vw, 100vh - 100px)/8*.28);position:absolute;width:calc(min(100vw, 100vh - 100px)/8*.28);z-index:0}@media (min-width:640px){.move-indicator{height:calc(min(100vw - 32px, 100vh - 140px)/8*.28);width:calc(min(100vw - 32px, 100vh - 140px)/8*.28)}}@media (min-width:1024px){.move-indicator{height:calc(min(800px, 90vw, 100vh - 160px)/8*.28);width:calc(min(800px, 90vw, 100vh - 160px)/8*.28)}}.chess-square.card-target{animation:cardTargetPulse 1.5s ease-in-out infinite;background-color:#9333ea80!important;box-shadow:inset 0 0 20px #9333ea99;cursor:crosshair}.chess-square.restricted-square{cursor:not-allowed;position:relative}.chess-square.restricted-square:after{content:"";pointer-events:none}.chess-square.first-target-selected{animation:firstTargetPulse 1s ease-in-out infinite;background-color:#3b82f6b3!important;border:3px solid #3b82f6;box-shadow:inset 0 0 25px #3b82f6cc}@keyframes cardTargetPulse{0%,to{box-shadow:inset 0 0 20px #9333ea99}50%{box-shadow:inset 0 0 30px #9333eae6}}@keyframes firstTargetPulse{0%,to{box-shadow:inset 0 0 25px #3b82f6cc}50%{box-shadow:inset 0 0 35px #3b82f6}}.square-coordinate{bottom:0;color:#0006;font-size:calc(min(100vw, 100vh - 100px)/8*.12);font-weight:700;padding-bottom:0;padding-right:.125rem;position:absolute;right:0;z-index:0}@media (min-width:640px){.square-coordinate{font-size:calc(min(100vw - 32px, 100vh - 140px)/8*.12)}}@media (min-width:1024px){.square-coordinate{font-size:calc(min(800px, 90vw, 100vh - 160px)/8*.12)}}.chess-square.dark .square-coordinate{color:#fff9}.chess-square.drag-over{background-color:#87ceeb!important;box-shadow:inset 0 0 0 2px #4682b4}@media (min-width:640px){.chess-square.drag-over{box-shadow:inset 0 0 0 3px #4682b4}}.chess-piece.dragging{cursor:grabbing;opacity:.5}.chess-piece.drag-overlay{cursor:grabbing;height:calc(min(100vw, 100vh - 100px)/8*.95);pointer-events:none;width:calc(min(100vw, 100vh - 100px)/8*.95);z-index:9999}@media (min-width:640px){.chess-piece.drag-overlay{height:calc(min(100vw - 32px, 100vh - 140px)/8*.95);width:calc(min(100vw - 32px, 100vh - 140px)/8*.95)}}@media (min-width:1024px){.chess-piece.drag-overlay{height:calc(min(800px, 90vw, 100vh - 160px)/8*.95);width:calc(min(800px, 90vw, 100vh - 160px)/8*.95)}}.chess-square.valid-move.drag-over{animation:dragPulse .5s infinite;background-color:#32cd32!important;box-shadow:inset 0 0 0 2px #228b22}@media (min-width:640px){.chess-square.valid-move.drag-over{box-shadow:inset 0 0 0 3px #228b22}}@keyframes dragPulse{0%{box-shadow:inset 0 0 0 2px #228b22}50%{box-shadow:inset 0 0 0 4px #32cd32}to{box-shadow:inset 0 0 0 2px #228b22}}@media (min-width:640px){@keyframes dragPulse{0%{box-shadow:inset 0 0 0 3px #228b22}50%{box-shadow:inset 0 0 0 5px #32cd32}to{box-shadow:inset 0 0 0 3px #228b22}}}.chess-piece[data-disabled=true]{cursor:not-allowed;opacity:.7}@keyframes pieceCapture{0%{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.2)}to{opacity:0;transform:scale(0)}}.chess-piece.captured{animation:pieceCapture .3s ease-in-out}.game-info p strong{transition-duration:.3s;transition-property:color,background-color,border-color,fill,stroke,-webkit-text-decoration-color;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,-webkit-text-decoration-color;transition-timing-function:cubic-bezier(.4,0,.2,1)}.your-turn{--tw-text-opacity:1;color:#16a34a;color:rgb(22 163 74/var(--tw-text-opacity,1));text-shadow:0 0 5px #4caf504d}.opponent-turn{--tw-text-opacity:1;color:#ea580c;color:rgb(234 88 12/var(--tw-text-opacity,1))}.status-check{animation:pulse 1s infinite;color:#dc2626;color:rgb(220 38 38/var(--tw-text-opacity,1))}.status-check,.status-checkmate{--tw-text-opacity:1;font-weight:700}.status-checkmate{color:#b91c1c;color:rgb(185 28 28/var(--tw-text-opacity,1))}.status-win{--tw-text-opacity:1;color:#16a34a;color:rgb(22 163 74/var(--tw-text-opacity,1));font-weight:700}@keyframes pulse{0%{opacity:1}50%{opacity:.7}to{opacity:1}}.chess-square.king-in-check{animation:checkPulse 1.5s ease-in-out infinite;background-color:#ef44444d!important;box-shadow:inset 0 0 15px #ef444466}@keyframes checkPulse{0%,to{box-shadow:inset 0 0 15px #ef444466}50%{box-shadow:inset 0 0 25px #ef444499}}.chess-square.checkmate-king{animation:checkmatePulse 1.5s ease-in-out infinite;background-color:#dc2626!important;box-shadow:inset 0 0 30px #dc2626cc,0 0 20px #dc262699;z-index:5}.chess-square.checkmate-king .chess-piece{animation:pieceShake .5s ease-in-out;filter:brightness(1.2)}.chess-square.victory-king{animation:victoryPulse 1.5s ease-in-out infinite;background-color:#16a34a!important;box-shadow:inset 0 0 30px #16a34acc,0 0 20px #16a34a99;z-index:5}.chess-square.victory-king .chess-piece{animation:victoryBounce 1s ease-in-out;filter:brightness(1.3) drop-shadow(0 0 10px rgba(255,215,0,.8))}@keyframes checkmatePulse{0%,to{box-shadow:inset 0 0 30px #dc2626cc,0 0 20px #dc262699}50%{box-shadow:inset 0 0 40px #dc2626,0 0 30px #dc2626e6}}@keyframes victoryPulse{0%,to{box-shadow:inset 0 0 30px #16a34acc,0 0 20px #ffd70099}50%{box-shadow:inset 0 0 40px #16a34a,0 0 30px #ffd700e6}}@keyframes pieceShake{0%,to{transform:translateX(0)}10%,30%,50%,70%,90%{transform:translateX(-3px)}20%,40%,60%,80%{transform:translateX(3px)}}@keyframes victoryBounce{0%,to{transform:translateY(0) scale(1)}25%{transform:translateY(-10px) scale(1.1)}50%{transform:translateY(0) scale(1)}75%{transform:translateY(-5px) scale(1.05)}}.skip-turn-popup{align-items:center;animation:skipPopupFadeIn .3s ease-out forwards,skipPopupFadeOut .5s ease-in 2s forwards;display:flex;inset:0;justify-content:center;pointer-events:none;position:fixed;z-index:50}.skip-turn-content{align-items:center;background:linear-gradient(145deg,#3d2817fa,#2c1810fa);border:3px solid #c9a961;border-radius:12px;box-shadow:0 0 0 4px #3d2817,0 0 0 6px #c9a961,0 10px 40px #000c,0 0 60px #c9a9614d;display:flex;flex-direction:column;gap:.75rem;padding:1.5rem 2rem;pointer-events:auto}.skip-turn-icon{align-items:flex-end;animation:skipIconBounce .6s ease-in-out;display:flex;filter:drop-shadow(0 4px 8px rgba(0,0,0,.5));gap:.5rem}.skip-popup-z{color:#c9a961;font-family:Georgia,serif;font-style:italic;font-weight:700;text-shadow:0 2px 4px #0009}.skip-popup-z:first-child{font-size:32px;opacity:.75;transform:translateY(4px) rotate(-8deg)}.skip-popup-z:nth-child(2){font-size:44px;opacity:.9;transform:translateY(-4px) rotate(-4deg)}.skip-popup-z:nth-child(3){font-size:56px;opacity:1;transform:translateY(-8px) rotate(0deg)}.skip-turn-message{color:#f4e4c1;font-family:Georgia,serif;font-size:1.25rem;font-weight:700;letter-spacing:.5px;line-height:1.75rem;text-align:center;text-shadow:2px 2px 4px #000c,0 0 12px #c9a96166}@media (max-width:640px){.skip-turn-content{gap:.5rem;padding:1rem 1.5rem}.skip-popup-z:first-child{font-size:20px}.skip-popup-z:nth-child(2){font-size:28px}.skip-popup-z:nth-child(3){font-size:36px}.skip-turn-message{font-size:1rem;line-height:1.5rem}}@keyframes skipPopupFadeIn{0%{opacity:0;transform:scale(.95) translateY(-10px) rotate(-2deg)}to{opacity:1;transform:scale(1) translateY(0) rotate(0deg)}}.chess-square.sacrifice-candidate{animation:sacrificeCandidatePulse 1.5s ease-in-out infinite;background-color:#ffa50066!important;box-shadow:inset 0 0 20px #ffa50099;cursor:pointer}.chess-square.sacrifice-selected{animation:sacrificeSelectedPulse 1s ease-in-out infinite;background-color:#ef444499!important;border:3px solid #ef4444;box-shadow:inset 0 0 30px #ef4444e6;cursor:pointer}@keyframes sacrificeCandidatePulse{0%,to{box-shadow:inset 0 0 20px #ffa50099}50%{box-shadow:inset 0 0 30px #ffa500e6}}@keyframes sacrificeSelectedPulse{0%,to{border-color:#ef4444;box-shadow:inset 0 0 30px #ef4444e6}50%{border-color:#ff5252;box-shadow:inset 0 0 40px #ef4444}}@keyframes skipPopupFadeOut{0%{opacity:1;transform:scale(1) rotate(0deg)}to{opacity:0;transform:scale(.95) rotate(1deg)}}@keyframes skipIconBounce{0%,to{transform:translateY(0)}25%{transform:translateY(-10px)}50%{transform:translateY(0)}75%{transform:translateY(-5px)}}.connection-banner{align-items:center;animation:slideDown .3s ease-out;box-shadow:0 2px 8px #0003;display:flex;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;justify-content:center;left:0;padding:12px 20px;position:fixed;right:0;top:0;z-index:9999}@keyframes slideDown{0%{transform:translateY(-100%)}to{transform:translateY(0)}}.connection-banner-icon{font-size:24px;margin-right:12px}.connection-banner-content{display:flex;flex-direction:column;gap:2px}.connection-banner-content strong{font-size:14px;font-weight:600}.connection-banner-content span{font-size:12px;opacity:.9}.connection-banner.disconnected{background-color:#dc3545;color:#fff}.connection-banner.reconnecting{background-color:#0d6efd;color:#fff}.connection-banner.reconnecting .connection-banner-icon{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.connection-banner.opponent-disconnected{background-color:#fd7e14;color:#fff}@media (max-width:768px){.connection-banner{padding:10px 16px}.connection-banner-icon{font-size:20px;margin-right:10px}.connection-banner-content strong{font-size:13px}.connection-banner-content span{font-size:11px}}
/*# sourceMappingURL=main.1f9a5b95.css.map*/