*{margin:0;padding:0;box-sizing:border-box}body{font-family:Arial,Microsoft YaHei,sans-serif;background:linear-gradient(135deg,#1a1d2e,#2d1b3d);color:#fff;min-height:100vh;padding-top:70px;overflow-x:hidden;overflow-y:auto}.main-container{display:grid;grid-template-columns:100px 1fr;grid-template-rows:auto 1fr;height:calc(100vh - 70px);gap:0;transition:grid-template-columns .3s ease}.main-container.sidebar-collapsed{grid-template-columns:0 1fr}.spreads-toolbar{grid-column:1 / -1;grid-row:1;display:flex;flex-direction:row;align-items:center;gap:8px;padding:1px 12px;background:#0003;border-bottom:1px solid rgba(217,27,122,.3);border-right:none;overflow-x:auto;overflow-y:hidden;min-width:0;position:relative}.spreads-toolbar::-webkit-scrollbar{height:6px}.spreads-toolbar::-webkit-scrollbar-track{background:#ffffff1a;border-radius:3px}.spreads-toolbar::-webkit-scrollbar-thumb{background:#d91b7a80;border-radius:3px}.spreads-toolbar::-webkit-scrollbar-thumb:hover{background:#d91b7ab3}.spreads-row{display:flex;align-items:center;gap:10px;overflow:visible;flex:1 0 auto;min-width:0}.spread-cache-tray{display:flex;align-items:center;gap:6px;min-width:auto;flex-shrink:0}.spread-cache-pill{padding:4px 12px;border-radius:999px;border:1px solid rgba(255,255,255,.3);background:#ffffff14;color:#fff;font-size:12px;cursor:pointer;transition:all .2s ease;white-space:nowrap}.spread-cache-pill:hover{border-color:#d91b7a;color:#d91b7a}.spread-cache-empty{font-size:12px;color:#ffffff80;white-space:nowrap}.reset-spreads-btn{padding:6px 14px;border-radius:999px;border:1px solid rgba(255,255,255,.3);background:transparent;color:#fff;cursor:pointer;font-size:12px;transition:all .2s ease;white-space:nowrap}.reset-spreads-btn:hover{border-color:#d91b7a;color:#d91b7a;box-shadow:0 0 10px #d91b7a4d}.spread-item.dragging{opacity:.6}.spread-label{white-space:nowrap;color:#fff}.spreads-empty-state{font-size:13px;color:#fff9}.spread-item{display:inline-flex;align-items:center;gap:6px;padding:3px 14px;background:#d91b7a33;border:1px solid rgba(217,27,122,.4);border-radius:16px;cursor:move;transition:all .3s ease;white-space:nowrap;scroll-snap-align:start;font-size:13px;color:#fff;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.spread-item.dragging{cursor:move;opacity:.5}.spread-item.drag-over{position:relative}.spread-item.drag-over:before{content:"";position:absolute;top:50%;transform:translateY(-50%);width:3px;height:24px;background:#d91b7a;border-radius:2px;pointer-events:none;z-index:100;box-shadow:0 0 6px #d91b7acc;animation:indicator-pulse .8s infinite}.spread-item.drop-before:before{left:-6px}.spread-item.drop-after:before{right:-6px;left:auto}@keyframes indicator-pulse{0%,to{opacity:1;box-shadow:0 0 6px #d91b7acc}50%{opacity:.7;box-shadow:0 0 10px #d91b7a}}.spread-item:hover{background:#d91b7a66;transform:translateY(-2px)}.spread-item.active{background:#d91b7a99;border-color:#d91b7a;box-shadow:0 0 15px #d91b7a80}.spread-item.fully-filled{background:#64b4e64d;border-color:#64b4e6b3}.spread-item.fully-filled.active{background:#64b4e680;border-color:#64b4e6;box-shadow:0 0 15px #64b4e680}.deck-selector-column{grid-column:1;grid-row:2;display:flex;flex-direction:column;gap:10px;padding:20px 8px;background:#0000004d;border-right:1px solid rgba(217,27,122,.3);overflow-y:auto;overflow-x:hidden;transition:transform .3s ease,opacity .3s ease;position:relative}@media(min-width:769px){.deck-selector-column.collapsed{transform:translate(-100px);opacity:0;pointer-events:none}}.column-collapse-handle{position:fixed;left:100px;top:50%;transform:translateY(-50%);width:20px;height:60px;background:#d91b7a4d;border:1px solid rgba(217,27,122,.5);border-left:none;border-radius:0 8px 8px 0;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:left .3s ease,background .3s ease,width .3s ease;z-index:100}.deck-selector-column.collapsed+.column-collapse-handle{left:0}.column-collapse-handle:hover{background:#d91b7a80;width:24px}.collapse-icon{font-size:14px;color:#fff;transition:transform .3s ease;-webkit-user-select:none;user-select:none}.deck-selector-column.collapsed+.column-collapse-handle .collapse-icon{transform:rotate(180deg)}.deck-type-btn{padding:10px 12px;background:#4a55684d;border:1px solid rgba(217,27,122,.3);border-radius:6px;color:#fff;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:500;letter-spacing:.5px;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;white-space:nowrap}.deck-type-btn:hover{background:#d91b7a4d;transform:translateY(-2px)}.deck-type-btn.active{background:#d91b7a99;border-color:#d91b7a;box-shadow:0 0 15px #d91b7a80}.main-area{grid-column:2;grid-row:2;position:relative;background:#0000001a;overflow:hidden}.deck-pile{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:var(--card-width);height:var(--card-height);cursor:pointer;transition:transform .2s ease-out;z-index:10;-webkit-user-select:none;user-select:none}.deck-pile:hover{transform:translate(-50%,-50%) scale(1.05)}.deck-pile.shuffling .deck-card{animation:shuffleCardAnimation .8s ease-in-out}.deck-pile.shuffling .deck-card:nth-child(1){animation:shuffleCard1 .8s ease-in-out}.deck-pile.shuffling .deck-card:nth-child(2){animation:shuffleCard2 .8s ease-in-out}.deck-pile.shuffling .deck-card:nth-child(3){animation:shuffleCard3 .8s ease-in-out}.deck-pile.shuffling .deck-card:nth-child(4){animation:shuffleCard4 .8s ease-in-out}.deck-pile.shuffling .deck-card:nth-child(5){animation:shuffleCard5 .8s ease-in-out}.deck-pile.shuffling .deck-card:nth-child(6){animation:shuffleCard6 .8s ease-in-out}.deck-pile.shuffling .deck-card:nth-child(7){animation:shuffleCard7 .8s ease-in-out}.deck-pile.shuffling .deck-card:nth-child(8){animation:shuffleCard8 .8s ease-in-out}.deck-pile.shuffling .deck-card:nth-child(9){animation:shuffleCard9 .8s ease-in-out}.deck-pile.shuffling .deck-card:nth-child(10){animation:shuffleCard10 .8s ease-in-out}@keyframes shuffleCard1{0%{transform:translate(0) rotate(0)}25%{transform:translate(-65px) rotate(-10deg)}50%{transform:translate(-25px) rotate(-3deg)}75%{transform:translate(-50px) rotate(-7deg)}to{transform:translate(0) rotate(0)}}@keyframes shuffleCard2{0%{transform:translate(0) rotate(0)}25%{transform:translate(55px) rotate(9deg)}50%{transform:translate(20px) rotate(2deg)}75%{transform:translate(45px) rotate(6deg)}to{transform:translate(0) rotate(0)}}@keyframes shuffleCard3{0%{transform:translate(0) rotate(0)}25%{transform:translate(-70px) rotate(-11deg)}50%{transform:translate(-30px) rotate(-4deg)}75%{transform:translate(-55px) rotate(-8deg)}to{transform:translate(0) rotate(0)}}@keyframes shuffleCard4{0%{transform:translate(0) rotate(0)}25%{transform:translate(60px) rotate(10deg)}50%{transform:translate(25px) rotate(3deg)}75%{transform:translate(50px) rotate(7deg)}to{transform:translate(0) rotate(0)}}@keyframes shuffleCard5{0%{transform:translate(0) rotate(0)}25%{transform:translate(-58px) rotate(-9deg)}50%{transform:translate(-22px) rotate(-2deg)}75%{transform:translate(-48px) rotate(-6deg)}to{transform:translate(0) rotate(0)}}@keyframes shuffleCard6{0%{transform:translate(0) rotate(0)}25%{transform:translate(52px) rotate(8deg)}50%{transform:translate(18px) rotate(2deg)}75%{transform:translate(42px) rotate(5deg)}to{transform:translate(0) rotate(0)}}@keyframes shuffleCard7{0%{transform:translate(0) rotate(0)}25%{transform:translate(-62px) rotate(-10deg)}50%{transform:translate(-28px) rotate(-3deg)}75%{transform:translate(-52px) rotate(-7deg)}to{transform:translate(0) rotate(0)}}@keyframes shuffleCard8{0%{transform:translate(0) rotate(0)}25%{transform:translate(57px) rotate(9deg)}50%{transform:translate(23px) rotate(3deg)}75%{transform:translate(47px) rotate(6deg)}to{transform:translate(0) rotate(0)}}@keyframes shuffleCard9{0%{transform:translate(0) rotate(0)}25%{transform:translate(-68px) rotate(-11deg)}50%{transform:translate(-32px) rotate(-4deg)}75%{transform:translate(-58px) rotate(-8deg)}to{transform:translate(0) rotate(0)}}@keyframes shuffleCard10{0%{transform:translate(0) rotate(0)}25%{transform:translate(63px) rotate(10deg)}50%{transform:translate(27px) rotate(3deg)}75%{transform:translate(53px) rotate(7deg)}to{transform:translate(0) rotate(0)}}@keyframes shuffleCardAnimation{0%{transform:translate(0) rotate(0)}20%{transform:translate(-50px) rotate(-5deg)}40%{transform:translate(60px) rotate(5deg)}60%{transform:translate(-45px) rotate(-3deg)}80%{transform:translate(40px) rotate(3deg)}to{transform:translate(0) rotate(0)}}.deck-card.entering{animation:cardEnterAnimation .5s ease-out forwards}@keyframes cardEnterAnimation{0%{transform:translateY(-300px) rotate(0) scale(.8);opacity:0}50%{transform:translateY(-50px) rotate(0) scale(1.02);opacity:.8}80%{transform:translateY(5px) rotate(0) scale(1);opacity:1}to{transform:translate(0) rotate(0) scale(1);opacity:1}}.deck-card{position:absolute;width:var(--card-width);height:var(--card-height);border-radius:6px;background:#2a2d3a;background-image:url("data:image/svg+xml,%3Csvg width='18' height='31' xmlns='http://www.w3.org/2000/svg'%3E%3Cdefs%3E%3Cpattern id='tinydots' width='0.8' height='0.8' patternUnits='userSpaceOnUse'%3E%3Ccircle cx='0.4' cy='0.4' r='0.15' fill='%23ffffff' opacity='0.3'/%3E%3C/pattern%3E%3Cpattern id='crosshatch' width='1' height='1' patternUnits='userSpaceOnUse'%3E%3Cpath d='M0 0 L1 1 M1 0 L0 1' stroke='%23ffffff' stroke-width='0.08' opacity='0.15'/%3E%3C/pattern%3E%3C/defs%3E%3Cg%3E%3Cpath d='M9 0 L18 15.5 L9 31 L0 15.5 Z' fill='url(%23crosshatch)'/%3E%3Cpath d='M9 0 L18 15.5 L9 31 L0 15.5 Z' fill='url(%23tinydots)'/%3E%3Cpath d='M9 0 L18 15.5 L9 31 L0 15.5 Z' fill='none' stroke='%23ffffff' stroke-width='0.3' opacity='0.4'/%3E%3Cpath d='M9 0 L18 15.5 L9 31 L0 15.5 Z' fill='none' stroke='%23d91b7a' stroke-width='0.6'/%3E%3C/g%3E%3C/svg%3E");background-size:15px 26px;border:2px solid #d91b7a;box-shadow:0 3px 6px #0000004d;pointer-events:none}.deck-card:nth-child(1){transform:translate(0);z-index:10}.deck-card:nth-child(2){transform:translate(1px,1px);z-index:9}.deck-card:nth-child(3){transform:translate(2px,2px);z-index:8}.deck-card:nth-child(4){transform:translate(3px,3px);z-index:7}.deck-card:nth-child(5){transform:translate(4px,4px);z-index:6}.deck-card:nth-child(6){transform:translate(5px,5px);z-index:5}.deck-card:nth-child(7){transform:translate(6px,6px);z-index:4}.deck-card:nth-child(8){transform:translate(7px,7px);z-index:3}.deck-card:nth-child(9){transform:translate(8px,8px);z-index:2}.deck-card:nth-child(10){transform:translate(9px,9px);z-index:1}.deck-base-hit{position:absolute;bottom:-15px;left:-5px;width:calc(100% + 10px);height:30px;cursor:grab;pointer-events:auto}.deck-right-hit{position:absolute;top:0;right:-10px;width:15px;height:100%;cursor:grab;pointer-events:auto;z-index:11}.deck-pile-label{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#ffffffe6;font-size:16px;font-weight:700;text-align:center;z-index:10;pointer-events:none;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;text-shadow:0 2px 4px rgba(0,0,0,.5)}.card{width:var(--card-width);height:var(--card-height);border-radius:6px;position:absolute;cursor:grab;transition:box-shadow .3s ease;box-shadow:0 8px 20px #00000080;transform-style:preserve-3d;will-change:transform,left,top;-webkit-user-select:none;user-select:none}.card,.deck-pile,.slot-drag-handle{touch-action:none}.card:active{cursor:grabbing}.card:hover{transform:scale(1.05);box-shadow:0 15px 40px #d91b7a66;z-index:1000!important}.card.revealed .card-front{transform:rotateY(0)}.card.revealed .card-back{transform:rotateY(180deg)}.card:not(.revealed) .card-front{transform:rotateY(180deg)}.card:not(.revealed) .card-back{transform:rotateY(0)}.card-front,.card-back{width:100%;height:100%;position:absolute;backface-visibility:hidden;border-radius:8px;transition:transform .6s}.card-front{background:#fff;display:flex;align-items:center;justify-content:center;border:3px solid #d91b7a;overflow:hidden;transform:rotateY(180deg)}.card-front img{width:104%;height:104%;object-fit:cover;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.card-back{transform:rotateY(0);background:#2a2d3a;background-image:url("data:image/svg+xml,%3Csvg width='18' height='31' xmlns='http://www.w3.org/2000/svg'%3E%3Cdefs%3E%3Cpattern id='tinydots' width='0.8' height='0.8' patternUnits='userSpaceOnUse'%3E%3Ccircle cx='0.4' cy='0.4' r='0.15' fill='%23ffffff' opacity='0.3'/%3E%3C/pattern%3E%3Cpattern id='crosshatch' width='1' height='1' patternUnits='userSpaceOnUse'%3E%3Cpath d='M0 0 L1 1 M1 0 L0 1' stroke='%23ffffff' stroke-width='0.08' opacity='0.15'/%3E%3C/pattern%3E%3C/defs%3E%3Cg%3E%3Cpath d='M9 0 L18 15.5 L9 31 L0 15.5 Z' fill='url(%23crosshatch)'/%3E%3Cpath d='M9 0 L18 15.5 L9 31 L0 15.5 Z' fill='url(%23tinydots)'/%3E%3Cpath d='M9 0 L18 15.5 L9 31 L0 15.5 Z' fill='none' stroke='%23ffffff' stroke-width='0.3' opacity='0.4'/%3E%3Cpath d='M9 0 L18 15.5 L9 31 L0 15.5 Z' fill='none' stroke='%23d91b7a' stroke-width='0.6'/%3E%3C/g%3E%3C/svg%3E");background-size:18px 31px;border:2px solid #d91b7a}.spread-slots{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}.spread-slots.active{display:block}.spread-slots.optimized-layout{display:flex;justify-content:center;align-items:center}.spread-slots.optimized-layout,.spread-slots.celtic-layout{padding-top:var(--spread-top-offset);padding-bottom:calc(var(--spread-top-offset) + 20px);box-sizing:border-box}.card.over-deck{opacity:.7;transform:scale(1.1)!important}.spread-slots.single-layout{display:flex;justify-content:center;align-items:center}.spread-slots.horizontal-layout{display:flex;justify-content:center;align-items:center;gap:var(--card-gap)}.spread-slots.pyramid-layout{display:grid;grid-template-columns:repeat(3,calc(var(--card-width) + 8px));grid-template-rows:repeat(2,calc(var(--card-height) + 8px));gap:var(--card-gap);justify-content:center;align-content:center}.spread-slots.cross-layout{display:grid;grid-template-columns:repeat(3,calc(var(--card-width) + 8px));grid-template-rows:repeat(3,calc(var(--card-height) + 8px));gap:var(--card-gap);justify-content:center;align-content:center}.spread-slots.spirit-layout{display:grid;grid-template-columns:repeat(3,calc(var(--card-width) + 8px));grid-template-rows:repeat(2,calc(var(--card-height) + 8px));gap:var(--card-gap);justify-content:center;align-content:center}.spread-slots.tree-layout,.spread-slots.nine-grid-layout{display:grid;grid-template-columns:repeat(3,calc(var(--card-width) + 8px));grid-template-rows:repeat(3,calc(var(--card-height) + 8px));gap:var(--card-gap);justify-content:center;align-content:center}.spread-slots.celtic-layout{display:flex;justify-content:center;align-items:center;--cross-to-staff-gap: 48px;--rotated-card-width: 140px;--rotated-card-height: 100px}.celtic-cross-section{display:grid;grid-template-columns:var(--card-width) var(--card-width) var(--card-width);grid-template-rows:var(--card-height) var(--card-height) var(--card-height);gap:var(--card-gap);position:relative;align-items:center;justify-items:center}.celtic-staff-section{display:flex;flex-direction:column;justify-content:center;align-items:center;gap:var(--card-gap);margin-left:var(--cross-to-staff-gap)}.celtic-slot{position:relative;width:var(--card-width);height:var(--card-height)}.celtic-slot.rotated{width:var(--rotated-card-width);height:var(--rotated-card-height)}.celtic-slot[data-position="1"]{grid-column:2;grid-row:2;z-index:2}.celtic-slot[data-position="2"]{grid-column:2;grid-row:2;width:var(--rotated-card-width);height:var(--rotated-card-height);z-index:1}.celtic-slot[data-position="3"]{grid-column:2;grid-row:1}.celtic-slot[data-position="4"]{grid-column:2;grid-row:3}.celtic-slot[data-position="5"]{grid-column:3;grid-row:2}.celtic-slot[data-position="6"]{grid-column:1;grid-row:2}.optimized-layout .slot,.single-layout .slot,.horizontal-layout .slot,.pyramid-layout .slot,.cross-layout .slot,.spirit-layout .slot,.tree-layout .slot,.nine-grid-layout .slot,.celtic-layout .slot{position:relative;left:auto!important;top:auto!important}.pyramid-slot[data-position="1"]{grid-column:1;grid-row:2}.pyramid-slot[data-position="2"]{grid-column:2;grid-row:2}.pyramid-slot[data-position="3"]{grid-column:3;grid-row:2}.pyramid-slot[data-position="4"]{grid-column:2;grid-row:1}.cross-slot[data-position="1"]{grid-column:2;grid-row:2}.cross-slot[data-position="2"]{grid-column:1;grid-row:2}.cross-slot[data-position="3"]{grid-column:3;grid-row:2}.cross-slot[data-position="4"]{grid-column:2;grid-row:1}.cross-slot[data-position="5"]{grid-column:2;grid-row:3}.spirit-slot[data-position="1"]{grid-column:1;grid-row:1}.spirit-slot[data-position="2"]{grid-column:3;grid-row:1}.spirit-slot[data-position="3"]{grid-column:1;grid-row:2}.spirit-slot[data-position="4"]{grid-column:3;grid-row:2}.spirit-slot[data-position="5"]{grid-column:2;grid-row:1}.spirit-slot[data-position="6"]{grid-column:2;grid-row:2}.tree-slot[data-position="1"]{grid-column:1;grid-row:1}.tree-slot[data-position="2"]{grid-column:1;grid-row:2}.tree-slot[data-position="3"]{grid-column:3;grid-row:1}.tree-slot[data-position="4"]{grid-column:3;grid-row:2}.tree-slot[data-position="5"]{grid-column:2;grid-row:2}.tree-slot[data-position="6"]{grid-column:2;grid-row:1}.tree-slot[data-position="7"]{grid-column:2;grid-row:3}@media(max-width:1200px){.spread-slots.optimized-layout,.spread-slots.celtic-layout{--card-gap: 20px}.spread-slots.celtic-layout{--cross-to-staff-gap: 36px}}@media(max-width:900px){.spread-slots.optimized-layout,.spread-slots.celtic-layout{--card-gap: 16px;--card-width: 85px;--card-height: 145px}.spread-slots.celtic-layout{--cross-to-staff-gap: 28px;--rotated-card-width: 126px;--rotated-card-height: 90px}}.slot{position:absolute;width:calc(var(--card-width) + var(--slot-border-gap));height:calc(var(--card-height) + var(--slot-border-gap));border:2px dashed rgba(217,27,122,.4);border-radius:8px;background:#d91b7a1a;display:flex;align-items:center;justify-content:center;pointer-events:none;transition:all .3s ease;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.slot[data-angle="90"]{width:calc(var(--card-height) + var(--slot-border-gap));height:calc(var(--card-width) + var(--slot-border-gap))}.slot.filled{border-color:#d91b7acc;background:#d91b7a33}.slot.highlight{border-color:#ffd700e6;background:#ffd70026;box-shadow:0 0 12px #ffd70066}.slot-label{color:#fffc;font-size:14px;font-weight:700;text-align:center;padding:5px;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;pointer-events:none}.slot.creating .slot-label{position:absolute;bottom:-24px;left:50%;transform:translate(-50%);white-space:nowrap;background:#d91b7a99;padding:2px 8px;border-radius:10px;font-size:12px}.card-counter{position:absolute;bottom:45px;right:max(8px,2vw);background:#d91b7ae6;color:#fff;padding:5px 12px;border-radius:16px;font-size:12px;font-weight:500;box-shadow:0 3px 10px #0000004d;z-index:1000;white-space:nowrap;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.controls{position:fixed;bottom:40px;left:6px;width:88px;display:flex;flex-direction:column;gap:5px;z-index:1000;padding:0;pointer-events:auto}.controls>*{pointer-events:auto}.control-btn,.create-spread-btn,.save-spread-btn,.finish-create-btn,.customize-btn{display:inline-flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:6px 8px;min-width:48px;height:48px;background:#d91b7a80;border:1px solid rgba(217,27,122,.4);color:#fff;border-radius:10px;cursor:pointer;font-size:10px;transition:all .3s ease;white-space:nowrap;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;box-shadow:0 2px 8px #0003}.btn-icon{font-size:14px;line-height:1}.btn-text{font-size:9px;font-weight:500;line-height:1;white-space:nowrap}.control-btn:hover,.create-spread-btn:hover,.save-spread-btn:hover,.finish-create-btn:hover,.customize-btn:hover{background:#d91b7ab3;border-color:#d91b7a;transform:translateY(-2px);box-shadow:0 4px 12px #d91b7a66}.control-btn:active,.create-spread-btn:active,.save-spread-btn:active,.finish-create-btn:active,.customize-btn:active{transform:translateY(0)}.control-btn:disabled{opacity:.5;cursor:not-allowed}.control-btn.reversals-toggle{background:#64646466!important;border-color:#96969666!important}.control-btn.reversals-toggle.active{background:#9333ea99!important;border-color:#9333eacc!important}.control-btn.reversals-toggle.active:hover{background:#9333eacc!important;box-shadow:0 0 15px #9333ea66}.control-btn.reversals-toggle:hover:not(.active){background:#64646499!important;border-color:#96969699!important}.card.reversed.revealed .card-front{transform:rotateY(0) rotate(180deg)}.card.reversed:not(.revealed) .card-front{transform:rotateY(180deg) rotate(180deg)}.spread-container{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.spread-info-box{display:none;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#d91b7a26;border:2px solid rgba(217,27,122,.6);border-radius:16px;padding:30px 40px;color:#d91b7ae6;text-align:center;font-size:16px;font-weight:500;z-index:500;max-width:90%;box-shadow:0 8px 32px #d91b7a4d;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.spread-info-box.show{display:block}@media(max-width:1200px){.spread-info-box{font-size:14px;padding:25px 35px}}.customization-box{position:absolute;bottom:80px;left:50%;transform:translate(-50%);background:#1a1a2ef2;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);border:2px solid rgba(217,27,122,.6);border-radius:12px;padding:20px 30px;display:none;flex-direction:column;gap:15px;z-index:2000;min-width:400px;max-width:90%;max-height:80vh;overflow-y:auto;overscroll-behavior:contain;box-shadow:0 8px 32px #d91b7a4d}.customization-box.show{display:flex}.customization-title{color:#d91b7ae6;font-size:16px;font-weight:600;text-align:center;margin-bottom:5px;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}@media(max-width:768px){.customization-box{position:fixed;top:50%;bottom:auto;transform:translate(-50%,-50%);width:calc(100% - 32px);min-width:unset;padding:18px 20px}}.customization-input-group{display:flex;flex-direction:column;gap:8px}.customization-label{color:#fffc;font-size:13px;margin-bottom:4px}.customization-input{background:#ffffff1a;border:1px solid rgba(217,27,122,.4);border-radius:8px;padding:10px 15px;color:#fff;font-size:14px;transition:all .3s ease}.customization-input:focus{outline:none;border-color:#d91b7acc;background:#ffffff26}.customization-buttons{display:flex;gap:10px;justify-content:center;margin-top:5px}.customization-btn{padding:8px 20px;border:none;border-radius:8px;cursor:pointer;font-size:14px;transition:all .3s ease;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.customization-btn.apply{background:#d91b7acc;color:#fff}.customization-btn.apply:hover{background:#d91b7a}.customization-btn.cancel{background:#ffffff1a;color:#fffc}.customization-btn.cancel:hover{background:#fff3}.customize-btn{padding:8px 16px;background:#d91b7a99;border:1px solid rgba(217,27,122,.4);color:#fff;border-radius:20px;cursor:pointer;font-size:14px;transition:all .3s ease;white-space:nowrap;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.customize-btn:hover{background:#d91b7acc;border-color:#d91b7a;transform:translateY(-2px);box-shadow:0 0 15px #d91b7a66}.loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#d91b7a;font-size:20px;z-index:2000;display:none}.loading:after{content:"";display:inline-block;width:20px;height:20px;border:3px solid rgba(217,27,122,.3);border-top-color:#d91b7a;border-radius:50%;animation:spin .8s linear infinite;margin-left:10px;vertical-align:middle}@keyframes spin{to{transform:rotate(360deg)}}:root{--card-width: clamp(70px, 18vw, 100px);--card-height: clamp(120px, 30vw, 171px);--card-gap: clamp(12px, 3vw, 24px);--slot-border-gap: 8px;--spread-top-offset: clamp(40px, 7vh, 100px);--spread-creation-padding: clamp(12px, 2vw, 24px);--controls-stack-gap: 12px}@media(min-width:769px){.spreads-toolbar{position:relative;grid-column:2;grid-row:1;left:auto;top:auto;width:auto;height:auto;display:flex;flex-direction:row}.control-btn,.create-spread-btn,.save-spread-btn,.finish-create-btn,.customize-btn{display:inline-flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:6px 8px;min-width:48px;height:48px;background:#d91b7a80;border:1px solid rgba(217,27,122,.4);color:#fff;border-radius:10px;cursor:pointer;font-size:10px;transition:all .3s ease;white-space:nowrap;box-shadow:0 2px 8px #0003}.btn-icon{font-size:16px;line-height:1;display:block}.btn-text{font-size:9px;font-weight:500;line-height:1;display:block}}.spreads-toolbar-toggle,.spreads-toolbar-backdrop{display:none}.spreads-toolbar{scroll-padding-left:16px}.spread-cache-tray{min-height:32px}.spread-cache-pill{font-size:12px}.ping-layer{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none;z-index:1100}.ping-marker{position:absolute;width:64px;height:64px;border-radius:999px;transform:translate(-50%,-50%);display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;opacity:0;animation:pingPulse 2.5s ease-out forwards}.ping-marker__label{position:absolute;top:70px;left:50%;transform:translate(-50%);font-size:12px;font-weight:600;text-shadow:0 2px 6px rgba(0,0,0,.5);white-space:nowrap}.ping-marker--default{background:#3b82f659;border:2px solid rgba(59,130,246,.9)}.ping-marker--info{background:#0ea5e959;border:2px solid rgba(14,165,233,.9)}.ping-marker--warning{background:#fbbf2459;border:2px solid rgba(251,191,36,.9)}.ping-marker--success{background:#10b98159;border:2px solid rgba(16,185,129,.9)}.ping-marker--fade{opacity:0}@keyframes pingPulse{0%{opacity:.9;transform:translate(-50%,-50%) scale(.6)}60%{opacity:.8;transform:translate(-50%,-50%) scale(1)}to{opacity:0;transform:translate(-50%,-50%) scale(1.3)}}.spread-slots.optimized-layout,.spread-slots.celtic-layout{padding-top:var(--spread-top-offset);padding-bottom:calc(var(--spread-top-offset) + 20px)}@media(max-width:768px){.spread-slots.optimized-layout,.spread-slots.celtic-layout{padding-top:calc(var(--spread-top-offset) * .5);padding-bottom:calc(var(--spread-top-offset) * .7)}}@media(max-width:768px){:root{--card-width: clamp(50px, 22vw, 75px);--card-height: clamp(86px, 37vw, 128px);--card-gap: clamp(8px, 2vw, 16px);--slot-border-gap: 4px}body{padding-top:70px}.main-container{display:flex;flex-direction:column;height:calc(100vh - 70px);gap:0}.deck-selector-column{position:fixed;bottom:100px;right:10px;z-index:25;display:flex;flex-direction:column;align-items:stretch;width:auto;min-width:80px;height:auto;overflow:hidden;background:#000000d9;border:1px solid rgba(217,27,122,.5);border-radius:8px;padding:0;gap:0;transform:none!important;transition:all .2s ease}.deck-selector-column.collapsed .deck-type-btn:not(.active){display:none}.deck-selector-column.collapsed{border-radius:20px;min-width:70px}.column-collapse-handle{display:none!important}.deck-type-btn{width:100%;padding:8px 14px;font-size:11px;text-align:center;border-radius:0;border:none;border-bottom:1px solid rgba(217,27,122,.2)}.deck-type-btn:last-child{border-bottom:none}.deck-type-btn.active{background:#d91b7a4d}.deck-selector-column.collapsed .deck-type-btn.active{border-radius:20px;border-bottom:none}.deck-pile-label{font-size:12px;line-height:1.2}.deck-hint{font-size:6px;margin-top:3px;line-height:1.1;opacity:.8}.spreads-toolbar{position:fixed;top:70px;left:0;right:0;display:flex;flex-direction:row;align-items:center;overflow-x:auto;overflow-y:hidden;padding:6px 10px;gap:8px;background:#0009;border-bottom:1px solid rgba(217,27,122,.3);min-height:42px;-webkit-overflow-scrolling:touch;z-index:30;touch-action:pan-x}.spreads-toolbar .spread-item,.spreads-toolbar .spread-item-wrapper{touch-action:pan-x}.spreads-toolbar .spreads-row{display:flex;flex-direction:row;gap:8px;flex-wrap:nowrap;align-items:center}.spreads-toolbar .reset-spreads-btn{flex-shrink:0;white-space:nowrap;padding:4px 10px;font-size:11px}.spread-hint-btn,.spread-hide-btn,.spreads-toolbar-toggle{display:none!important}.spreads-toolbar-backdrop{display:none}.spreads-row{flex:1 0 auto;min-width:50px}.spread-cache-tray{flex-shrink:0;justify-content:flex-start}.main-area{flex:1;min-height:60vh;margin-top:42px}.controls{position:fixed;bottom:55px;left:6px;transform:none;width:auto;padding:0;gap:4px;flex-direction:column;flex-wrap:nowrap;justify-content:flex-start;align-items:flex-start;background:transparent;-webkit-backdrop-filter:none;backdrop-filter:none;border-radius:0;z-index:25}.control-btn,.save-spread-btn,.finish-create-btn,.customize-btn,.create-spread-btn{width:36px;min-width:36px;height:36px;padding:2px;flex-direction:column;gap:1px;border-radius:6px}.btn-icon{font-size:14px}.btn-text{font-size:6px}.spread-item{padding:5px 12px;font-size:12px}}@media(max-width:480px){:root{--card-width: clamp(45px, 20vw, 65px);--card-height: clamp(77px, 34vw, 111px);--spread-top-offset: clamp(32px, 6vh, 80px)}.deck-selector-column{bottom:90px;right:8px;min-width:70px}.deck-type-btn{font-size:10px;padding:6px 10px}.spread-cache-pill{font-size:10px;padding:3px 8px}.spreads-toolbar{min-height:38px;padding:5px 8px;gap:6px}.main-area{margin-top:38px}.controls{bottom:50px;left:4px}.control-btn,.save-spread-btn,.finish-create-btn,.customize-btn,.create-spread-btn{width:32px;min-width:32px;height:32px;padding:2px}.btn-icon{font-size:12px}.btn-text{font-size:5px}.spread-item{padding:4px 10px;font-size:11px}.deck-pile-label{font-size:10px}}@media(max-width:360px){:root{--card-width: clamp(40px, 18vw, 55px);--card-height: clamp(68px, 31vw, 94px);--card-gap: clamp(6px, 2vw, 12px)}.deck-selector-column{bottom:80px;right:6px;min-width:60px}.deck-type-btn{font-size:9px;padding:5px 8px}.spreads-toolbar{min-height:34px;padding:4px 6px;gap:5px}.main-area{margin-top:34px}.controls{bottom:45px;left:3px;gap:3px}.control-btn,.save-spread-btn,.finish-create-btn,.customize-btn,.create-spread-btn{width:28px;min-width:28px;height:28px;padding:2px}.btn-icon{font-size:10px}.btn-text{font-size:4px}.spread-item{padding:3px 8px;font-size:10px}.spread-cache-pill{font-size:9px;padding:2px 6px}.reset-spreads-btn{font-size:9px;padding:3px 8px}.deck-pile-label{font-size:9px}}.spread-item.saved{background:#4caf5033;border-color:#4caf5066}.spread-item.saved:hover{background:#4caf5066}.spread-item-wrapper{display:flex;align-items:center;gap:8px;position:relative;flex-shrink:0}.spread-hint-btn{width:18px;height:18px;border-radius:50%;background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff;font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;flex-shrink:0}.spread-hint-btn:hover{background:#d91b7a80;border-color:#d91b7a}.spread-delete-btn{width:18px;height:18px;border-radius:50%;background:#f443364d;border:1px solid rgba(244,67,54,.5);color:#fff;font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;flex-shrink:0;padding:0}.spread-delete-btn:hover{background:#f4433680}.spread-favorite-btn{width:18px;height:18px;border-radius:50%;background:#ffc1074d;border:1px solid rgba(255,193,7,.5);color:#ffc107;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;flex-shrink:0;padding:0;line-height:1}.spread-favorite-btn:hover{background:#ffc10780;transform:scale(1.1)}.spread-item.saved.pinned{border-color:#ffc10799;box-shadow:0 0 8px #ffc1074d}.spread-item.saved.recent:after{content:"🔥";margin-left:4px;font-size:12px}.spread-hide-btn{width:18px;height:18px;border-radius:50%;background:#9e9e9e4d;border:1px solid rgba(158,158,158,.5);color:#fff;font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;flex-shrink:0;padding:0;line-height:1}.spread-hide-btn:hover{background:#9e9e9e80;transform:scale(1.1)}.save-spread-btn:disabled{opacity:.5;cursor:not-allowed}.create-spread-btn.active{background:#d91b7ae6;box-shadow:0 0 10px #d91b7a80}.main-area.creating-spread{cursor:crosshair}.main-area.creating-spread .deck-pile{pointer-events:none;opacity:.5}.slot.creating{border-color:#ff9800cc;box-shadow:0 0 10px #ff980080;position:absolute}.slot.creating:hover{border-color:#ff9800;box-shadow:0 0 15px #ff9800b3}.slot-delete-btn{position:absolute;top:-5px;right:-5px;width:18px;height:18px;border-radius:50%;background:#00000073;border:1px solid rgba(217,27,122,.5);color:#fff;font-size:12px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;z-index:10;padding:0;line-height:1;box-shadow:0 2px 6px #00000059}.slot-delete-btn:hover{background:#d91b7ad9;border-color:#d91b7ae6;transform:scale(1.08)}.slot-drag-handle{position:absolute;bottom:-10px;left:50%;transform:translate(-50%);width:28px;height:14px;border-radius:8px;background:#00000059;border:1px solid rgba(255,255,255,.35);color:#fffc;font-size:9px;cursor:grab;display:flex;align-items:center;justify-content:center;transition:all .2s ease;z-index:10;-webkit-user-select:none;user-select:none;line-height:1}.slot-drag-handle:active{cursor:grabbing;background:#d91b7a99}.slot-drag-handle:hover{background:#d91b7a66;border-color:#d91b7a99}.hint-modal{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:2000;align-items:center;justify-content:center}.hint-modal.show{display:flex}.hint-modal-content{background:#1a1a2ef2;border:1px solid rgba(217,27,122,.3);border-radius:12px;width:90%;max-width:500px;max-height:80vh;overflow-y:auto;overscroll-behavior:contain}.hint-modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid rgba(255,255,255,.1)}.hint-modal-header h3{margin:0;font-size:18px;color:#fff}.hint-modal-close{background:none;border:none;color:#fff;font-size:28px;cursor:pointer;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;transition:color .3s ease}.hint-modal-close:hover{color:var(--primary-color)}.hint-modal-body{padding:20px;color:var(--text-secondary);line-height:1.6}.hint-modal-body h4{color:#fff;margin-top:16px;margin-bottom:8px}.hint-modal-body ul{margin:8px 0;padding-left:20px}.hint-modal-body li{margin:4px 0}.manage-spreads-modal{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:2000;align-items:center;justify-content:center}.manage-spreads-modal.show{display:flex}.manage-spreads-content{background:#1a1a2ef2;border:1px solid rgba(217,27,122,.3);border-radius:12px;width:90%;max-width:800px;max-height:80vh;display:flex;flex-direction:column;overflow-y:auto;overscroll-behavior:contain}.manage-spreads-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid rgba(255,255,255,.1)}.manage-spreads-header h3{margin:0;font-size:18px;color:#fff}.manage-spreads-close{background:none;border:none;color:#fff;font-size:28px;cursor:pointer;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;transition:color .3s ease}.manage-spreads-close:hover{color:var(--primary-color)}.manage-spreads-tabs{display:flex;gap:10px;padding:15px 20px;border-bottom:1px solid rgba(255,255,255,.1)}.manage-tab{padding:8px 16px;background:#4a55684d;border:1px solid rgba(217,27,122,.3);border-radius:8px;color:#fff;cursor:pointer;font-size:13px;font-weight:500;transition:all .3s ease}.manage-tab:hover{background:#4a556880}.manage-tab.active{background:#d91b7a66;border-color:#d91b7a99}.manage-spreads-body{padding:20px;overflow-y:auto;flex:1}.manage-spread-item{display:flex;align-items:center;gap:10px;padding:12px;margin-bottom:10px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;transition:all .3s ease}.manage-spread-item:hover{background:#ffffff1a;border-color:#d91b7a4d}.manage-spread-name{flex:1;color:#fff;font-size:14px}.manage-spread-actions{display:flex;gap:8px}.manage-spread-action-btn{padding:6px 12px;background:#4a55684d;border:1px solid rgba(217,27,122,.3);border-radius:6px;color:#fff;cursor:pointer;font-size:12px;transition:all .3s ease}.manage-spread-action-btn:hover{background:#4a556880}.manage-spread-action-btn.rename{background:#2196f333;border-color:#2196f366}.manage-spread-action-btn.rename:hover{background:#2196f366}.manage-spread-action-btn.hide{background:#9e9e9e33;border-color:#9e9e9e66}.manage-spread-action-btn.hide:hover{background:#9e9e9e66}.manage-spread-action-btn.delete{background:#f4433633;border-color:#f4433666}.manage-spread-action-btn.delete:hover{background:#f4433666}.mobile-edit-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;z-index:9998;pointer-events:auto}.mobile-edit-overlay.active{display:block}body.spread-edit-mode .spreads-toolbar{z-index:10000;position:relative}.mobile-trash-zone{display:none;position:fixed;bottom:20px;left:50%;transform:translate(-50%);width:calc(100% - 40px);max-width:300px;height:80px;border:3px dashed rgba(255,255,255,.6);border-radius:16px;background:#f4433626;z-index:10001;align-items:center;justify-content:center;transition:all .2s ease}.mobile-trash-zone.active{display:flex}.mobile-trash-zone.drag-over{background:#f4433666;border-color:#f44336;transform:translate(-50%) scale(1.05)}.mobile-trash-icon{font-size:36px;opacity:.8;transition:transform .2s ease}.mobile-trash-zone.drag-over .mobile-trash-icon{transform:scale(1.2)}body.spread-edit-mode .spread-item{cursor:grab;animation:wiggle .3s ease-in-out infinite}body.spread-edit-mode .spread-item.dragging{cursor:grabbing;animation:none;opacity:.8;transform:scale(1.05);z-index:10002}@keyframes wiggle{0%,to{transform:rotate(-1deg)}50%{transform:rotate(1deg)}}body.spread-edit-mode .spread-item.drop-before:before,body.spread-edit-mode .spread-item.drop-after:before{content:"";position:absolute;top:50%;transform:translateY(-50%);width:4px;height:28px;background:#d91b7a;border-radius:2px;z-index:100;box-shadow:0 0 8px #d91b7ae6}body.spread-edit-mode .spread-item.drop-before:before{left:-8px}body.spread-edit-mode .spread-item.drop-after:before{right:-8px;left:auto}
