@import url(https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Playfair+Display:wght@400;600;700&display=swap);html{-webkit-text-size-adjust:100%;-moz-text-size-adjust:100%;text-size-adjust:100%}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Space Grotesk,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;max-width:100vw;overflow-x:hidden;overscroll-behavior-y:contain;padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left);scroll-behavior:smooth}*{-webkit-tap-highlight-color:transparent}.scroll-container{-webkit-overflow-scrolling:touch}input,select,textarea{font-size:16px}@media (min-width:769px){input,select,textarea{font-size:inherit}}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}::-webkit-scrollbar{height:8px;width:8px}::-webkit-scrollbar-track{background:#ffffff0d}::-webkit-scrollbar-thumb{background:#fff3;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#ffffff4d}@media (max-width:768px){::-webkit-scrollbar{height:4px;width:4px}::-webkit-scrollbar-thumb{background:#ffffff26}}::selection{background:#4ade804d;color:#fff}.clickable,button{cursor:pointer;touch-action:manipulation}:focus-visible{outline:2px solid #4ade8080;outline-offset:2px}:focus:not(:focus-visible){outline:none}@media (max-height:500px) and (orientation:landscape){body{padding-top:0}}.login-container{align-items:center;background:linear-gradient(135deg,#1a1a2e,#16213e 50%,#0f0f23);display:flex;justify-content:center;min-height:100vh;padding:20px}.login-card{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffff08;border:1px solid #ffffff1a;border-radius:20px;box-shadow:0 25px 50px #00000080;max-width:400px;padding:48px;width:100%}.login-header{margin-bottom:40px;text-align:center}.login-icon{display:block;filter:drop-shadow(0 4px 8px rgba(0,0,0,.3));font-size:64px;margin-bottom:16px}.login-header h1{color:#fff;font-family:Playfair Display,serif;font-size:32px;font-weight:700;letter-spacing:1px;margin:0 0 8px}.login-header p{color:#ffffff80;font-size:14px;margin:0}.login-form{display:flex;flex-direction:column;gap:24px}.login-form .form-group{display:flex;flex-direction:column;gap:8px}.login-form label{color:#ffffffb3;font-size:13px;font-weight:500;letter-spacing:.5px}.login-form input{background:#ffffff0d;border:1px solid #ffffff26;border-radius:12px;color:#fff;font-size:15px;padding:16px 18px;transition:all .2s ease}.login-form input:focus{background:#61489b1a;border-color:#61489b;box-shadow:0 0 0 3px #61489b33;outline:none}.login-form input::placeholder{color:#ffffff4d}.login-btn{background:linear-gradient(135deg,#61489b,#7c5cbf);border:none;border-radius:12px;color:#fff;cursor:pointer;font-size:15px;font-weight:600;margin-top:8px;padding:16px 24px;transition:all .3s ease}.login-btn:hover:not(:disabled){box-shadow:0 8px 20px #61489b66;transform:translateY(-2px)}.login-btn:active:not(:disabled){transform:translateY(0)}.login-btn:disabled{cursor:not-allowed;opacity:.6}.login-error{background:#992e2e33;border:1px solid #992e2e66;border-radius:10px;color:#ff6b6b;font-size:14px;padding:14px 18px;text-align:center}@media (max-width:768px){.login-container{padding:16px}.login-card{border-radius:16px;padding:32px 24px}.login-header{margin-bottom:32px}.login-icon{font-size:48px;margin-bottom:12px}.login-header h1{font-size:26px}.login-header p{font-size:13px}.login-form{gap:20px}.login-form input{border-radius:10px;font-size:16px;padding:14px 16px}.login-btn{border-radius:10px;font-size:15px;padding:14px 20px}.login-error{border-radius:8px;font-size:13px;padding:12px 14px}}@media (max-width:400px){.login-card{padding:24px 20px}.login-header h1{font-size:22px}.login-icon{font-size:40px}}.admin-panel{background:#141423fa;border:1px solid #ffffff1a;border-radius:16px;box-shadow:0 20px 40px #0006;margin:0 auto;max-width:700px;padding:24px}.admin-header{align-items:center;border-bottom:1px solid #ffffff1a;display:flex;justify-content:space-between;margin-bottom:24px;padding-bottom:16px}.admin-header h2{color:#fff;font-size:20px;font-weight:600;margin:0}.close-btn{background:#ffffff1a;border:none;border-radius:8px;color:#fff9;cursor:pointer;font-size:18px;height:36px;transition:all .2s;width:36px}.close-btn:hover{background:#ffffff26;color:#fff}.admin-error,.admin-loading{color:#fff9;padding:40px;text-align:center}.admin-error{color:#ff6b6b}.admin-message{border-radius:10px;font-size:14px;margin-bottom:16px;padding:12px 16px;text-align:center}.admin-message.success{background:#79a65b33;border:1px solid #79a65b66;color:#9ed47f}.admin-message.error{background:#992e2e33;border:1px solid #992e2e66;color:#ff6b6b}.admin-actions,.user-form{margin-bottom:20px}.user-form{background:#ffffff08;border:1px solid #ffffff1a;border-radius:12px;padding:20px}.form-row{gap:12px;margin-bottom:16px}.form-row.checkboxes{margin-bottom:0}.user-form input[type=password],.user-form input[type=text]{background:#ffffff0d;border:1px solid #ffffff26;border-radius:8px;color:#fff;flex:1 1;font-size:14px;padding:12px 14px;transition:all .2s}.user-form input[type=password]:focus,.user-form input[type=text]:focus{background:#61489b1a;border-color:#61489b;outline:none}.user-form input::placeholder{color:#fff6}.user-form label{align-items:center;color:#ffffffb3;cursor:pointer;display:flex;font-size:14px;gap:8px}.user-form input[type=checkbox]{accent-color:#61489b;cursor:pointer;height:18px;width:18px}.users-list{display:flex;flex-direction:column;gap:12px}.user-item{align-items:center;background:#ffffff08;border:1px solid #ffffff14;border-radius:12px;display:flex;justify-content:space-between;padding:16px 20px;transition:all .2s}.user-item:hover{background:#ffffff0d;border-color:#ffffff1f}.user-info{display:flex;flex-direction:column;gap:4px}.user-name{align-items:center;color:#fff;display:flex;font-size:15px;font-weight:500;gap:10px}.badge{border-radius:6px;font-size:11px;font-weight:600;letter-spacing:.5px;padding:3px 8px;text-transform:uppercase}.badge.admin{background:#61489b4d;color:#a78bfa}.badge.readonly{background:#eab30833;color:#fbbf24}.user-date{color:#fff6;font-size:12px}.password-edit,.user-controls{align-items:center;display:flex;gap:8px}.password-edit input{background:#ffffff0d;border:1px solid #ffffff26;border-radius:8px;color:#fff;font-size:13px;padding:8px 12px;width:140px}.password-edit input:focus{border-color:#61489b;outline:none}.btn{background:#ffffff1a;border:1px solid #ffffff26;border-radius:8px;color:#fff;font-size:14px;font-weight:500;padding:10px 16px;transition:all .2s}.btn:hover{background:#ffffff26}.btn-small{font-size:15px;padding:8px 12px}.btn-primary{background:linear-gradient(135deg,#61489b,#7c5cbf);border-color:#0000}.btn-primary:hover{box-shadow:0 4px 12px #61489b66}.btn-success{background:linear-gradient(135deg,#22c55e,#16a34a);border-color:#0000}.btn-danger{background:#992e2e4d;border-color:#992e2e66}.btn-danger:hover{background:#992e2e80}.btn-active{background:#61489b66;border-color:#61489b99}.copy-from-select{display:flex;flex:1 1;flex-direction:column;gap:8px}.copy-from-select label{color:#ffffffb3;font-size:13px;font-weight:500}.copy-from-select select{-webkit-appearance:none;appearance:none;background:#ffffff0d;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12'%3E%3Cpath fill='%23999' d='M6 8 1 3h10z'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;border:1px solid #ffffff26;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;padding:12px 14px;transition:all .2s}.copy-from-select select:focus{background-color:#61489b1a;border-color:#61489b;outline:none}.copy-from-select select option{background:#1a1a2e;color:#fff;padding:12px}@media (max-width:768px){.admin-panel{border-radius:12px;margin:12px;max-width:none;padding:16px}.admin-header{margin-bottom:20px;padding-bottom:12px}.admin-header h2{font-size:18px}.close-btn{font-size:16px;height:32px;width:32px}.user-form{border-radius:10px;padding:14px}.form-row{flex-direction:column;gap:10px}.form-row.checkboxes{flex-direction:row;flex-wrap:wrap;gap:16px}.user-form input[type=password],.user-form input[type=text]{font-size:16px;padding:12px;width:100%}.user-form label{font-size:13px}.copy-from-select{width:100%}.copy-from-select select{font-size:16px;padding:12px;width:100%}.users-list{gap:10px}.user-item{align-items:stretch;flex-direction:column;gap:12px;padding:14px 16px}.user-info{width:100%}.user-name{flex-wrap:wrap;font-size:14px;gap:8px}.badge{font-size:10px;padding:2px 6px}.user-date{font-size:11px}.user-controls{flex-wrap:wrap;gap:6px;justify-content:flex-start}.password-edit{flex-wrap:wrap;width:100%}.password-edit input{flex:1 1;font-size:16px;min-width:120px;padding:10px 12px}.btn{font-size:13px;padding:10px 14px}.btn-small{font-size:14px;padding:8px 10px}.admin-message{font-size:13px;padding:10px 14px}}@media (max-width:400px){.admin-panel{margin:8px;padding:12px}.user-form,.user-item{padding:12px}.user-name{font-size:13px}.btn{font-size:12px;padding:8px 12px}}.action-selector{background:#ffffff08;border:1px solid #ffffff14;border-radius:16px;box-sizing:border-box;overflow:visible;padding:16px}.action-cards{grid-gap:8px;box-sizing:border-box;display:grid;gap:8px;grid-template-columns:repeat(2,1fr);margin-bottom:16px;width:100%}.action-card{border:2px solid #0000;border-radius:10px;cursor:pointer;padding:12px 10px;transition:all .2s ease;-webkit-user-select:none;user-select:none}.action-card:hover{box-shadow:0 8px 25px #0000004d;transform:translateY(-2px)}.action-card.selected{border-color:#fff;box-shadow:0 0 20px #ffffff4d}.action-name-input{background:#0000;border:none;border-radius:4px;color:inherit;font-family:inherit;font-size:.85rem;font-weight:600;margin-bottom:8px;padding:4px;text-align:center;transition:background .2s;width:100%}.action-name-input:focus,.action-name-input:hover{background:#00000026;outline:none}.percentage-controls{gap:6px;margin-bottom:8px}.percentage-btn,.percentage-controls{align-items:center;display:flex;justify-content:center}.percentage-btn{background:#0003;border:none;border-radius:4px;color:inherit;cursor:pointer;font-size:1rem;height:24px;transition:all .2s;width:24px}.percentage-btn:hover{background:#00000059;transform:scale(1.1)}.percentage-value{background:#fff;border-radius:4px;color:#1a1a2e;font-size:.9rem;font-weight:700;min-width:36px;padding:4px 8px;text-align:center}.quick-percentages{display:flex;flex-wrap:wrap;gap:3px;justify-content:center}.quick-btn{background:#00000026;border:none;border-radius:3px;color:inherit;cursor:pointer;font-size:.7rem;opacity:.7;padding:3px 6px;transition:all .2s}.quick-btn:hover{background:#00000040;opacity:1}.quick-btn.active{background:#0000004d;font-weight:600;opacity:1}.selection-indicator{align-items:center;background:#ffffff0d;border-radius:8px;color:#fffc;display:flex;font-size:.85rem;gap:10px;padding:10px 12px}.indicator-bar{border-radius:2px;height:20px;width:4px}.selection-indicator strong{color:#fff}.total-indicator{border-radius:6px;font-size:.85rem;margin-top:8px;padding:8px 12px;text-align:center}.total-indicator.valid{background:#4ade8026;color:#4ade80}.total-indicator.invalid{background:#ef444426;color:#ef4444}.total-indicator strong{font-weight:700}@media (max-width:1200px){.action-selector{box-sizing:border-box;max-width:100%!important;padding:12px;width:100%!important}.action-cards{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(2,1fr);width:100%}.action-card{box-sizing:border-box;padding:12px 8px;width:100%}.action-name-input{font-size:.8rem}.percentage-value{font-size:.85rem;min-width:34px}}@media (max-width:768px){.action-selector{border-radius:12px;box-sizing:border-box;max-width:100%!important;padding:10px;width:100%!important}.action-cards{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(2,1fr);margin-bottom:10px;width:100%}.action-card{border-radius:8px;box-sizing:border-box;padding:10px 6px;width:100%}.action-name-input{font-size:.75rem;margin-bottom:6px;padding:2px}.percentage-controls{gap:4px;margin-bottom:6px}.percentage-btn{font-size:.9rem;height:24px;width:24px}.percentage-value{font-size:.85rem;min-width:36px;padding:4px 8px}.quick-percentages{gap:3px}.quick-btn{font-size:.65rem;padding:3px 5px}.selection-indicator{font-size:.8rem;gap:8px;padding:8px 10px}.indicator-bar{height:16px;width:3px}.total-indicator{font-size:.8rem;padding:6px 10px}}@media (max-width:500px){.action-selector{border-radius:10px;box-sizing:border-box;max-width:100%!important;padding:8px;width:100%!important}.action-cards{grid-gap:6px;display:grid;gap:6px;grid-template-columns:repeat(2,1fr);margin-bottom:8px;width:100%}.action-card{border-radius:6px;box-sizing:border-box;padding:10px 6px;width:100%}.action-name-input{font-size:.7rem;margin-bottom:4px;padding:2px}.percentage-controls{gap:4px;margin-bottom:4px}.percentage-btn{font-size:.9rem;height:22px;width:22px}.percentage-value{font-size:.8rem;min-width:32px;padding:3px 6px}.quick-percentages{gap:2px}.quick-btn{font-size:.6rem;padding:2px 4px}.selection-indicator{font-size:.75rem;gap:6px;padding:6px 8px}.indicator-bar{height:14px;width:3px}.total-indicator{font-size:.75rem;padding:5px 8px}}@media (max-width:380px){.action-selector{padding:6px}.action-cards{gap:3px;grid-template-columns:repeat(2,1fr)}.action-card{padding:6px 3px}.action-name-input{font-size:.6rem}.percentage-btn{font-size:.8rem;height:18px;width:18px}.percentage-value{font-size:.7rem;min-width:24px}.quick-btn{font-size:.5rem}}.range-grid-container{display:flex;flex-direction:column;gap:20px;max-width:100%;overflow-x:hidden;position:relative;width:100%}.cell-tooltip{animation:tooltipFadeIn .15s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#141423fa;border:1px solid #ffffff26;border-radius:10px;box-shadow:0 8px 32px #00000080;min-width:140px;padding:10px 14px;pointer-events:none;position:fixed;transform:translate(-50%,-100%) translateY(-12px);z-index:1000}@keyframes tooltipFadeIn{0%{opacity:0;transform:translate(-50%,-100%) translateY(-6px)}to{opacity:1;transform:translate(-50%,-100%) translateY(-12px)}}.cell-tooltip:after{border-left:6px solid #0000;border-right:6px solid #0000;border-top:6px solid #141423fa;bottom:-6px;content:"";left:50%;position:absolute;transform:translateX(-50%)}.tooltip-header{border-bottom:1px solid #ffffff1a;color:#fff;font-size:1rem;font-weight:700;margin-bottom:8px;padding-bottom:8px;text-align:center}.tooltip-content{display:flex;flex-direction:column;gap:6px}.tooltip-row{align-items:center;display:flex;gap:8px}.tooltip-color{border-radius:3px;flex-shrink:0;height:12px;width:12px}.tooltip-name{color:#fffc;flex:1 1;font-size:.85rem}.tooltip-percent{color:#fff;font-size:.9rem;font-weight:600}.tooltip-fold .tooltip-name,.tooltip-fold .tooltip-percent{color:#ffffff80}.range-grid{background:#1a1a2e;border-radius:16px;flex-direction:column;max-width:100%;padding:16px;-webkit-user-select:none;user-select:none}.grid-row,.range-grid{display:flex;gap:3px;width:100%}.grid-cell{align-items:center;aspect-ratio:1;border-radius:6px;cursor:pointer;display:flex;flex:1 1;justify-content:center;max-height:52px;max-width:52px;overflow:hidden;position:relative;transition:all .15s ease}.grid-cell:hover{box-shadow:0 4px 15px #0006;transform:scale(1.08);z-index:10}.grid-cell:active{transform:scale(.95)}.grid-cell.pair{border:2px solid #ffffff26}.hand-label{font-size:1.4rem;font-weight:800;pointer-events:none}.range-stats{align-items:center;background:#ffffff0d;border-radius:12px;display:flex;justify-content:space-between;padding:16px 20px}.total-range{color:#fffc;font-size:1.2rem}.range-value{color:#4ade80;font-size:1.5rem;font-weight:700;margin-left:8px}.action-legend{display:flex;gap:20px}.legend-item{align-items:center;display:flex;gap:8px}.legend-color{border-radius:4px;height:16px;width:16px}.legend-name{color:#ffffffb3;font-size:.9rem}@media (max-width:1024px){.range-grid{gap:2px;padding:10px}.grid-row{gap:2px}.grid-cell{border-radius:4px;max-height:44px;max-width:44px}.hand-label{font-size:clamp(.7rem,2.5vw,1.1rem)}.range-stats{align-items:center;flex-direction:column;gap:12px}.action-legend{flex-wrap:wrap;gap:12px;justify-content:center}}@media (max-width:768px){.range-grid-container{gap:12px;width:100%}.range-grid{border-radius:10px;max-width:100%;padding:6px}.grid-row,.range-grid{gap:2px;width:100%}.grid-cell{border-radius:3px;flex:1 1;max-height:none;max-width:none;min-width:0}.grid-cell:hover{transform:scale(1.03)}.hand-label{font-size:clamp(.5rem,2.2vw,.85rem);font-weight:700}.range-stats{flex-direction:column;gap:8px;padding:10px}.total-range{font-size:.9rem}.range-value{font-size:1.1rem}.action-legend{flex-wrap:wrap;gap:6px;justify-content:center}.legend-item{gap:4px}.legend-color{height:10px;width:10px}.legend-name{font-size:.7rem}.cell-tooltip{font-size:.8rem;min-width:100px;padding:6px 8px}.tooltip-header{font-size:.85rem;margin-bottom:4px;padding-bottom:4px}.tooltip-row{gap:4px}.tooltip-color{height:8px;width:8px}.tooltip-name{font-size:.7rem}.tooltip-percent{font-size:.75rem}}@media (max-width:500px){.range-grid{gap:1px;padding:4px}.grid-row{gap:1px}.grid-cell{border-radius:2px}.grid-cell.pair{border-width:1px}.hand-label{font-size:clamp(.4rem,1.8vw,.6rem)}.range-stats{gap:6px;padding:8px}.total-range{font-size:.85rem}.range-value{font-size:1rem}.legend-item{gap:3px}.legend-color{height:8px;width:8px}.legend-name{font-size:.65rem}}@media (max-width:380px){.range-grid{padding:3px}.hand-label{font-size:clamp(.35rem,1.5vw,.45rem)}.range-stats{padding:6px}.action-legend{gap:4px}.legend-name{font-size:.6rem}}.range-form{background:#ffffff08;border:1px solid #ffffff14;border-radius:16px;display:flex;flex-direction:column;gap:20px;max-width:100%;padding:24px;width:100%}.form-row{align-items:flex-start;display:flex;gap:20px}.form-row .form-group{flex:1 1}.form-row .form-group.flex-2{flex:2 1}.form-group{display:flex;flex-direction:column;gap:10px;width:100%}.stack-group{min-width:200px}.stack-inputs{align-items:center;display:flex;gap:8px}.stack-input{padding:14px 8px!important;text-align:center;width:70px}.stack-input::-webkit-inner-spin-button,.stack-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.stack-input[type=number]{-moz-appearance:textfield}.stack-separator{color:#fff6;font-size:1.2rem}.stack-unit{color:#ffffff80;font-size:.9rem;font-weight:600;margin-left:4px}.form-group label{align-items:center;color:#fff9;display:flex;flex-wrap:wrap;font-size:.9rem;font-weight:500;gap:8px;letter-spacing:.5px;text-transform:uppercase}.vs-count{color:#4ade80;font-size:.8rem;text-transform:none}.select-all-btn{background:#ffffff14;border:1px solid #ffffff26;border-radius:6px;color:#fff9;cursor:pointer;font-size:.7rem;letter-spacing:0;margin-left:auto;padding:4px 10px;text-transform:none;transition:all .2s}.select-all-btn:hover{background:#ffffff1f;color:#fff}.vs-hint{color:#fff6;font-size:.75rem;font-style:italic;margin-top:4px}.form-input{background:#ffffff0f;border:2px solid #ffffff1a;border-radius:10px;color:#fff;font-size:1rem;padding:14px 18px;transition:all .2s}.form-input:focus{background:#4ade8014;border-color:#4ade80;outline:none}.form-input::placeholder{color:#ffffff4d}.position-selector{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(4,1fr);width:100%}.position-btn{background:#ffffff0f;border:2px solid #ffffff1a;border-radius:8px;color:#ffffffb3;cursor:pointer;font-size:.9rem;font-weight:600;padding:10px 16px;text-align:center;transition:all .2s}.position-btn:hover{background:#ffffff1a;border-color:#fff3;color:#fff}.position-btn.active{background:linear-gradient(135deg,#4ade80,#22c55e);border-color:#4ade80;color:#0a0a0a}.positions-row{flex-wrap:wrap}.vs-selector{gap:6px}.vs-btn{font-size:.8rem;padding:8px 12px}.vs-btn.special{background:#8b294233;border-color:#8b294266;color:#f59e9e}.vs-btn.special:hover{background:#8b29424d;border-color:#8b294299;color:#ffc4c4}.vs-btn.special.active{background:linear-gradient(135deg,#8b2942,#a33355);border-color:#8b2942;color:#fff}.vs-selector.multi .vs-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;color:#fff}.vs-selector.multi .vs-btn.special.active{background:linear-gradient(135deg,#f39c12,#e67e22);border-color:#f39c12;color:#fff}.form-textarea{background:#ffffff0f;border:2px solid #ffffff1a;border-radius:10px;color:#fff;font-family:inherit;font-size:1rem;min-height:80px;padding:14px 18px;resize:vertical;transition:all .2s}.form-textarea:focus{background:#4ade8014;border-color:#4ade80;outline:none}.form-textarea::placeholder{color:#ffffff4d}@media (max-width:1024px){.range-form{padding:20px}.form-row{flex-direction:column;gap:16px}.stack-group{min-width:auto;width:100%}.position-selector{gap:6px;grid-template-columns:repeat(4,1fr)}.position-btn{padding:10px 8px}.vs-selector{grid-gap:6px;display:grid;gap:6px;grid-template-columns:repeat(5,1fr);width:100%}.vs-btn{text-align:center}}@media (max-width:768px){.range-form{border-radius:12px;gap:16px;padding:16px}.form-row{flex-direction:column;gap:16px}.form-group{gap:8px}.form-group label{font-size:.8rem}.form-input{border-radius:8px;font-size:.95rem;padding:12px 14px}.position-selector{gap:6px;grid-template-columns:repeat(4,1fr)}.position-btn{font-size:.8rem;padding:10px 8px}.vs-selector{gap:4px}.vs-btn{flex:1 1;font-size:.75rem;min-width:calc(25% - 4px);padding:8px 10px;text-align:center}.vs-hint{font-size:.7rem}.select-all-btn{font-size:.65rem;padding:4px 8px}.stack-group{min-width:auto}.stack-inputs{justify-content:flex-start}.stack-input{padding:12px 6px!important;width:60px}.form-textarea{font-size:.95rem;min-height:60px;padding:12px 14px}}@media (max-width:500px){.range-form{border-radius:10px;gap:12px;padding:10px}.form-group{gap:6px}.form-group label{font-size:.75rem}.form-input{border-radius:6px;font-size:14px;padding:10px 12px}.position-selector{gap:4px;grid-template-columns:repeat(4,1fr)}.position-btn{border-radius:6px;font-size:.75rem;padding:8px 4px}.vs-selector{gap:3px;grid-template-columns:repeat(5,1fr)}.vs-btn{border-radius:6px;font-size:.7rem;padding:6px 4px}.stack-inputs{gap:6px}.stack-input{padding:10px 4px!important;width:55px}.stack-separator{font-size:1rem}.stack-unit{font-size:.8rem}.form-textarea{font-size:14px;min-height:50px;padding:10px 12px}}@media (max-width:380px){.range-form{gap:10px;padding:8px}.form-group label{font-size:.7rem}.position-selector{gap:3px;grid-template-columns:repeat(4,1fr)}.position-btn{font-size:.65rem;padding:6px 2px}.vs-selector{gap:2px;grid-template-columns:repeat(5,1fr)}.vs-btn{font-size:.6rem;padding:5px 2px}.stack-input{width:50px}.select-all-btn{font-size:.6rem;padding:3px 6px}}.range-list{background:#ffffff08;border:1px solid #ffffff14;border-radius:16px;box-sizing:border-box;max-width:100%;overflow:hidden;width:100%}.range-list-header{align-items:center;background:#ffffff08;border-bottom:1px solid #ffffff14;display:flex;justify-content:space-between;padding:20px 24px}.range-list-header h3{color:#ffffffe6;font-size:1rem;font-weight:600;margin:0}.new-range-btn{align-items:center;background:linear-gradient(135deg,#4ade80,#22c55e);border:none;border-radius:8px;color:#0a0a0a;cursor:pointer;display:flex;font-size:.9rem;font-weight:600;gap:6px;padding:10px 18px;transition:all .2s}.new-range-btn:hover{box-shadow:0 4px 15px #4ade8066;transform:translateY(-2px)}.new-range-btn span{font-size:1.2rem;font-weight:700}.range-list-items{max-height:500px;overflow-x:hidden;overflow-y:auto;width:100%}.position-group{border-bottom:1px solid #ffffff0d}.position-group:last-child{border-bottom:none}.group-header{align-items:center;background:#ffffff08;cursor:pointer;display:flex;gap:10px;padding:12px 16px;position:-webkit-sticky;position:sticky;top:0;transition:background .2s;z-index:1}.group-header:hover{background:#ffffff0f}.group-arrow{color:#ffffff80;font-size:.7rem;transition:transform .2s}.group-arrow.collapsed{transform:rotate(-90deg)}.group-name{color:#4ade80;font-size:.95rem;font-weight:600}.group-count{background:#ffffff1a;border-radius:10px;color:#fff9;font-size:.75rem;margin-left:auto;padding:2px 8px}.group-items{background:#0000001a}.range-list-items::-webkit-scrollbar{width:6px}.range-list-items::-webkit-scrollbar-track{background:#0000}.range-list-items::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}.empty-list{align-items:center;color:#fff6;display:flex;flex-direction:column;justify-content:center;padding:48px 24px}.empty-icon{font-size:3rem;margin-bottom:12px;opacity:.5}.empty-list p{font-size:.95rem;margin:0}.range-list-item{border-bottom:1px solid #ffffff08;box-sizing:border-box;cursor:pointer;overflow:hidden;padding:12px 16px 12px 24px;transition:all .2s;width:100%}.range-list-item:hover{background:#ffffff0d}.range-list-item.selected{background:#4ade801a;border-left:3px solid #4ade80}.item-main{align-items:center;display:flex;justify-content:space-between;margin-bottom:6px;min-width:0;width:100%}.item-name{color:#fff;flex:1 1;font-size:1rem;font-weight:600;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.item-tags{align-items:center;display:flex;flex-shrink:0;flex-wrap:wrap;gap:6px}.item-position{background:#ffffff1a;border-radius:6px;color:#fffc;font-size:.8rem;font-weight:600;padding:4px 10px}.item-stack{background:#4ade8026;color:#4ade80}.item-stack,.item-vs-position{border-radius:6px;font-size:.75rem;font-weight:600;padding:4px 10px}.item-vs-position{background:#8b294233;color:#f59e9e}.item-meta{align-items:center;display:flex;justify-content:space-between}.item-date{color:#fff6;font-size:.8rem}.item-actions{display:flex;gap:4px}.clone-btn,.delete-btn{background:#0000;border:none;cursor:pointer;font-size:1rem;opacity:.5;padding:4px 8px;transition:all .2s}.clone-btn:hover,.delete-btn:hover{opacity:1;transform:scale(1.1)}.clone-btn:hover{filter:hue-rotate(90deg)}.item-comment{border-top:1px solid #ffffff0d;color:#ffffff80;font-size:.85rem;font-style:italic;margin-top:8px;overflow:hidden;padding-top:8px;text-overflow:ellipsis;white-space:nowrap}@media (max-width:768px){.range-list{border-radius:12px}.range-list-header{align-items:stretch;flex-direction:column;gap:12px;padding:14px 16px}.range-list-header h3{font-size:.9rem;text-align:center}.new-range-btn{justify-content:center;padding:12px 16px;width:100%}.range-list-items{max-height:350px}.group-header{padding:10px 14px}.group-name{font-size:.85rem}.group-count{font-size:.7rem;padding:2px 6px}.range-list-item{padding:10px 14px}.item-main{align-items:flex-start;flex-direction:column;gap:8px}.item-name{font-size:.9rem}.item-tags{flex-wrap:wrap;width:100%}.item-position,.item-stack,.item-vs-position{font-size:.7rem;padding:3px 8px}.item-meta{flex-direction:row;justify-content:space-between;width:100%}.item-date{font-size:.75rem}.clone-btn,.delete-btn{font-size:1.1rem;padding:6px 10px}.item-comment{font-size:.8rem;margin-top:6px;padding-top:6px}.empty-list{padding:32px 16px}.empty-icon{font-size:2.5rem}.empty-list p{font-size:.85rem}}@media (max-width:500px){.range-list{border-radius:10px}.range-list-header{padding:10px 12px}.new-range-btn,.range-list-header h3{font-size:.85rem}.new-range-btn{padding:10px 14px}.range-list-items{max-height:300px}.group-header{padding:8px 12px}.group-name{font-size:.8rem}.range-list-item{padding:8px 10px}.item-name{font-size:.85rem}.item-position,.item-stack,.item-vs-position{font-size:.65rem;padding:2px 6px}.item-date{font-size:.7rem}.clone-btn,.delete-btn{font-size:.95rem;padding:4px 6px}.item-comment{font-size:.75rem}}@media (max-width:380px){.range-list-header{padding:8px 10px}.new-range-btn{font-size:.8rem;padding:8px 12px}.range-list-item{padding:6px 8px}.item-name{font-size:.8rem}.item-position,.item-stack,.item-vs-position{font-size:.6rem;padding:2px 5px}}.cheat-sheet{background:linear-gradient(135deg,#0f0f23,#1a1a2e 50%,#16213e);color:#fff;min-height:100vh;padding:30px}.cs-header{margin-bottom:30px;text-align:center}.cs-header h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,gold,#ff8c00);-webkit-background-clip:text;background-clip:text;font-family:Playfair Display,Georgia,serif;font-size:2.5rem;font-weight:700;margin:0}.cs-header p{color:#8892b0;font-size:1.1rem;margin-top:8px}.cs-controls{display:flex;flex-direction:column;gap:24px;margin:0 auto 30px;max-width:900px}.cs-control-group{background:#ffffff08;border:1px solid #ffffff14;border-radius:16px;padding:20px}.cs-control-group label{color:#64748b;display:block;font-size:.85rem;font-weight:600;letter-spacing:1.5px;margin-bottom:12px;text-transform:uppercase}.cs-position-buttons{display:flex;flex-wrap:wrap;gap:8px}.cs-pos-btn{background:#ffffff08;border:2px solid #ffffff1a;border-radius:10px;color:#a0aec0;cursor:pointer;font-size:.95rem;font-weight:600;padding:12px 20px;transition:all .2s ease}.cs-pos-btn:hover{background:#ffffff14;border-color:#fff3;color:#fff;transform:translateY(-2px)}.cs-pos-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;box-shadow:0 4px 15px #667eea66;color:#fff}.cs-pos-btn.vs.special{border-color:#ffc1074d;color:#ffc107}.cs-pos-btn.vs.special:hover{border-color:#ffc107}.cs-pos-btn.vs.special.active{background:linear-gradient(135deg,#f39c12,#e67e22);border-color:#f39c12;box-shadow:0 4px 15px #f39c1266;color:#fff}.stack-control{display:flex;flex-direction:column}.cs-stack-input{align-items:center;display:flex;gap:20px;margin-bottom:15px}.cs-stack-input input[type=range]{-webkit-appearance:none;appearance:none;background:#ffffff1a;border-radius:4px;flex:1 1;height:8px;outline:none}.cs-stack-input input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;box-shadow:0 2px 10px #667eea80;cursor:pointer;height:24px;width:24px}.cs-stack-value{align-items:center;background:#0000004d;border:1px solid #ffffff1a;border-radius:10px;display:flex;gap:8px;padding:8px 16px}.cs-stack-value input[type=number]{background:#0000;border:none;color:#fff;font-size:1.2rem;font-weight:700;outline:none;text-align:right;width:60px}.cs-stack-value span{color:#64748b;font-weight:600}.cs-stack-presets{display:flex;flex-wrap:wrap;gap:8px}.cs-stack-preset{background:#ffffff0d;border:1px solid #ffffff1a;border-radius:8px;color:#8892b0;cursor:pointer;font-weight:600;padding:8px 14px;transition:all .2s}.cs-stack-preset:hover{background:#ffffff1a;color:#fff}.cs-stack-preset.active{background:#667eea33;border-color:#667eea;color:#667eea}.cs-matching-ranges{background:#ffffff08;border:1px solid #ffffff14;border-radius:12px;margin:0 auto 20px;max-width:900px;padding:16px}.cs-matching-ranges label{color:#64748b;display:block;font-size:.8rem;margin-bottom:10px}.cs-range-chips{display:flex;flex-wrap:wrap;gap:8px}.cs-range-chip{align-items:flex-start;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:10px;color:#cbd5e1;cursor:pointer;display:flex;flex-direction:column;font-weight:500;padding:10px 16px;transition:all .2s}.cs-range-chip:hover{background:#ffffff1a;border-color:#fff3}.cs-range-chip.active{background:#22c55e26;border-color:#22c55e;color:#22c55e}.chip-stack{color:#64748b;font-size:.75rem;margin-top:2px}.cs-range-display{margin:0 auto;max-width:700px;transition:opacity .3s}.cs-range-display.loading{opacity:.5;pointer-events:none}.cs-no-range{background:#ffffff05;border:2px dashed #ffffff1a;border-radius:20px;padding:60px 20px;text-align:center}.cs-no-range-icon{display:block;font-size:4rem;margin-bottom:16px}.cs-no-range p{color:#94a3b8;font-size:1.3rem;margin:0 0 8px}.cs-no-range span{color:#64748b;font-size:.95rem}.cs-range-info{margin-bottom:24px;text-align:center}.cs-range-info h2{color:#f1f5f9;font-family:Playfair Display,Georgia,serif;font-size:1.8rem;margin:0 0 12px}.cs-range-tags{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-bottom:12px}.cs-tag{border-radius:20px;font-size:.85rem;font-weight:600;padding:6px 14px}.cs-tag.position{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.cs-tag.vs{background:#f39c1233;border:1px solid #f39c124d;color:#f39c12}.cs-tag.stack{background:#22c55e26;border:1px solid #22c55e4d;color:#22c55e}.cs-tag.total{background:#8b5cf626;border:1px solid #8b5cf64d;color:#a78bfa}.cs-comment{background:#ffffff0d;border-left:4px solid #667eea;border-radius:12px;color:#e2e8f0;font-size:1.3rem;font-style:italic;line-height:1.5;margin:16px 0 0;padding:16px 20px;text-align:left}.cs-comment p{margin:0 0 8px}.cs-comment p:last-child{margin-bottom:0}.cs-grid{background:#0000004d;border:1px solid #ffffff14;border-radius:16px;flex-direction:column;max-width:100%;padding:12px}.cs-grid,.cs-grid-row{display:flex;gap:3px;width:100%}.cs-cell{align-items:center;aspect-ratio:1;border-radius:6px;cursor:default;display:flex;flex:1 1;font-size:clamp(.7rem,2.5vw,1.4rem);font-weight:800;justify-content:center;min-width:0;transition:transform .15s}.cs-cell:hover{box-shadow:0 4px 15px #0006;transform:scale(1.1);z-index:10}.cs-cell.pair{border:2px solid #ffd70066}.cs-cell span{pointer-events:none}.cs-legend{background:#ffffff08;border-radius:12px;display:flex;flex-wrap:wrap;gap:16px;justify-content:center;margin-top:20px;padding:16px}.cs-legend-item{align-items:center;color:#94a3b8;display:flex;font-size:.9rem;gap:8px}.cs-legend-color{border-radius:5px;box-shadow:0 2px 4px #0000004d;height:18px;width:18px}@media (max-width:1024px){.cheat-sheet{padding:20px}.cs-controls,.cs-matching-ranges,.cs-range-display{max-width:100%}.cs-grid{gap:2px;padding:8px}.cs-grid-row{gap:2px}.cs-cell{border-radius:4px;font-size:clamp(.6rem,2vw,1.1rem)}.cs-pos-btn{flex:1 1;min-width:calc(20% - 8px);text-align:center}}@media (max-width:768px){.cheat-sheet{min-height:calc(100vh - 120px);padding:12px}.cs-header{margin-bottom:20px}.cs-header h1{font-size:1.5rem}.cs-header p{font-size:.9rem}.cs-controls{gap:16px;margin-bottom:20px}.cs-control-group{border-radius:12px;padding:14px}.cs-control-group label{font-size:.75rem;letter-spacing:1px;margin-bottom:10px}.cs-position-buttons{gap:6px}.cs-pos-btn{border-radius:8px;flex:1 0 auto;font-size:.8rem;min-width:calc(33% - 6px);padding:10px 14px;text-align:center}.cs-stack-input{flex-direction:column;gap:12px}.cs-stack-input input[type=range]{width:100%}.cs-stack-value{justify-content:center;width:100%}.cs-stack-presets{gap:6px}.cs-stack-preset{flex:1 1;font-size:.8rem;padding:8px 12px;text-align:center}.cs-matching-ranges{margin-bottom:16px;padding:12px}.cs-range-chips{gap:6px}.cs-range-chip{flex:1 1;font-size:.85rem;min-width:calc(50% - 6px);padding:8px 12px}.chip-stack{font-size:.7rem}.cs-no-range{border-radius:16px;padding:40px 16px}.cs-no-range-icon{font-size:3rem}.cs-no-range p{font-size:1.1rem}.cs-no-range span{font-size:.85rem}.cs-range-info{margin-bottom:16px}.cs-range-info h2{font-size:1.4rem}.cs-range-tags{gap:6px}.cs-tag{font-size:.75rem;padding:5px 10px}.cs-comment{border-radius:10px;font-size:1rem;margin-top:12px;padding:12px 14px}.cs-grid{border-radius:10px;padding:6px}.cs-grid,.cs-grid-row{gap:2px;width:100%}.cs-cell{border-radius:3px;font-size:clamp(.5rem,2vw,.75rem);font-weight:700}.cs-cell:hover{transform:scale(1.03)}.cs-cell.pair{border-width:1px}.cs-legend{gap:10px;margin-top:16px;padding:12px}.cs-legend-item{font-size:.75rem;gap:6px}.cs-legend-color{border-radius:4px;height:14px;width:14px}}@media (max-width:480px){.cheat-sheet{padding:8px}.cs-header h1{font-size:1.3rem}.cs-pos-btn{font-size:.75rem;min-width:calc(33% - 4px);padding:8px 10px}.cs-cell{font-size:.55rem}.cs-comment{font-size:.9rem;padding:10px 12px}.cs-range-info h2{font-size:1.2rem}}@media (max-width:768px) and (orientation:landscape){.cs-controls{flex-direction:row;flex-wrap:wrap}.cs-control-group{flex:1 1;min-width:280px}.cs-range-display{margin:0 auto;max-width:60%}}.pwa-offline-banner{align-items:center;animation:slideDown .3s ease-out;background:linear-gradient(135deg,#f59e0b,#d97706);box-shadow:0 2px 10px #0000004d;color:#1a1a1a;display:flex;font-size:.9rem;font-weight:600;gap:8px;justify-content:center;left:0;padding:8px 16px;position:fixed;right:0;top:0;z-index:10000}.pwa-offline-icon{animation:pulse 2s infinite;font-size:1.1rem}.pwa-update-prompt{animation:slideUp .3s ease-out;bottom:20px;left:50%;position:fixed;transform:translateX(-50%);z-index:10000}.pwa-update-content{align-items:center;background:linear-gradient(135deg,#1e293b,#0f172a);border:1px solid #6366f14d;border-radius:16px;box-shadow:0 10px 40px #00000080,0 0 20px #6366f133;display:flex;gap:16px;max-width:450px;padding:16px 20px}.pwa-update-icon{animation:spin 2s linear infinite;font-size:2rem}.pwa-update-text{flex:1 1}.pwa-update-text strong{color:#f1f5f9;display:block;font-size:1rem;margin-bottom:4px}.pwa-update-text p{color:#94a3b8;font-size:.85rem;margin:0}.pwa-update-actions{display:flex;gap:8px}.pwa-btn-later{background:#0000;border:1px solid #94a3b84d;border-radius:8px;color:#94a3b8;cursor:pointer;font-size:.9rem;padding:8px 16px;transition:all .2s}.pwa-btn-later:hover{background:#94a3b81a;color:#f1f5f9}.pwa-btn-update{background:linear-gradient(135deg,#6366f1,#4f46e5);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:600;padding:8px 16px;transition:all .2s}.pwa-btn-update:hover{box-shadow:0 4px 15px #6366f166;transform:translateY(-2px)}.pwa-install-prompt{animation:slideUp .3s ease-out;bottom:20px;left:50%;position:fixed;transform:translateX(-50%);z-index:9999}.pwa-install-content{align-items:center;background:linear-gradient(135deg,#1e293b,#0f172a);border:1px solid #10b9814d;border-radius:16px;box-shadow:0 10px 40px #00000080,0 0 20px #10b98133;display:flex;gap:16px;max-width:450px;padding:16px 20px}.pwa-install-icon{font-size:2.5rem}.pwa-install-text{flex:1 1}.pwa-install-text strong{color:#f1f5f9;display:block;font-size:1rem;margin-bottom:4px}.pwa-install-text p{color:#94a3b8;font-size:.85rem;margin:0}.pwa-install-actions{display:flex;gap:8px}.pwa-btn-dismiss{background:#0000;border:1px solid #94a3b84d;border-radius:8px;color:#94a3b8;cursor:pointer;font-size:.9rem;padding:8px 16px;transition:all .2s}.pwa-btn-dismiss:hover{background:#94a3b81a;color:#f1f5f9}.pwa-btn-install{background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:600;padding:8px 16px;transition:all .2s}.pwa-btn-install:hover{box-shadow:0 4px 15px #10b98166;transform:translateY(-2px)}@keyframes slideDown{0%{opacity:0;transform:translateY(-100%)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translate(-50%,100%)}to{opacity:1;transform:translate(-50%)}}@media (max-width:500px){.pwa-install-prompt,.pwa-update-prompt{left:10px;right:10px;transform:none}.pwa-install-content,.pwa-update-content{flex-wrap:wrap;justify-content:center;text-align:center}.pwa-install-actions,.pwa-update-actions{justify-content:center;margin-top:8px;width:100%}}*{box-sizing:border-box}body{background:#0a0a0a;color:#fff;font-family:Space Grotesk,-apple-system,BlinkMacSystemFont,sans-serif;margin:0;padding:0}.app,body{min-height:100vh}.app{background:radial-gradient(ellipse at 20% 20%,#4ade8014 0,#0000 50%),radial-gradient(ellipse at 80% 80%,#8b29421a 0,#0000 50%),linear-gradient(180deg,#0a0a0a,#1a1a2e);max-width:100vw;overflow-x:hidden}.user-bar{background:#00000080;border-bottom:1px solid #ffffff14;justify-content:space-between;padding:12px 24px}.user-bar,.user-info-bar{align-items:center;display:flex}.user-info-bar{gap:12px}.user-welcome{color:#fffc;font-size:14px;font-weight:500}.user-badge{border-radius:6px;font-size:11px;font-weight:600;letter-spacing:.5px;padding:4px 10px;text-transform:uppercase}.user-badge.admin{background:#61489b4d;color:#a78bfa}.user-badge.readonly{background:#eab30833;color:#fbbf24}.user-actions{display:flex;gap:10px}.btn-admin{background:#61489b33;border:1px solid #61489b66;color:#a78bfa;font-size:13px;padding:8px 16px}.btn-admin:hover{background:#61489b4d}.btn-logout{background:#ef444426;border:1px solid #ef44444d;color:#ef4444;font-size:13px;padding:8px 16px}.btn-logout:hover{background:#ef444440}.readonly-notice{align-items:center;background:#eab3081a;border:1px solid #eab3084d;border-radius:8px;color:#fbbf24;display:flex;font-size:13px;font-weight:500;gap:8px;padding:8px 16px}.loading-screen{align-items:center;display:flex;flex-direction:column;gap:16px;justify-content:center;min-height:100vh}.loading-spinner{animation:pulse 1.5s ease-in-out infinite;font-size:64px}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.1)}}.loading-screen p{color:#ffffff80;font-size:14px}.mode-switcher{background:#0006;border-bottom:1px solid #ffffff0f;display:flex;gap:8px;justify-content:center;padding:16px}.mode-btn{background:#ffffff08;border:2px solid #ffffff1a;border-radius:12px;color:#8892b0;cursor:pointer;font-family:inherit;font-size:1rem;font-weight:600;padding:12px 28px;transition:all .25s ease}.mode-btn:hover{background:#ffffff14;border-color:#fff3;color:#fff}.mode-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#0000;box-shadow:0 4px 20px #667eea66;color:#fff}.app-header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0000004d;border-bottom:1px solid #ffffff14;justify-content:space-between;padding:20px 32px;position:-webkit-sticky;position:sticky;top:0;z-index:100}.app-header,.logo{align-items:center;display:flex}.logo{gap:12px}.logo-icon{font-size:2rem}.logo h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#fff,#4ade80);-webkit-background-clip:text;background-clip:text;font-size:1.5rem;font-weight:700;margin:0}.header-actions{display:flex;gap:12px}.btn{border:none;border-radius:10px;cursor:pointer;font-family:inherit;font-size:.95rem;font-weight:600;padding:12px 24px;transition:all .2s ease}.btn:disabled{cursor:not-allowed;opacity:.6}.btn-primary{background:linear-gradient(135deg,#4ade80,#22c55e);color:#0a0a0a}.btn-primary:hover:not(:disabled){box-shadow:0 8px 25px #4ade8066;transform:translateY(-2px)}.btn-secondary{background:#ffffff1a;border:1px solid #ffffff26;color:#fffc}.btn-secondary:hover:not(:disabled){background:#ffffff26;color:#fff}.message{animation:slideIn .3s ease;border-radius:10px;font-weight:500;padding:14px 24px;position:fixed;right:32px;top:90px;z-index:1000}@keyframes slideIn{0%{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}.message-success{background:#4ade8033;border:1px solid #4ade8066;color:#4ade80}.message-error{background:#ef444433;border:1px solid #ef444466;color:#ef4444}.app-main{grid-gap:32px;display:grid;gap:32px;grid-template-columns:320px 1fr;margin:0 auto;max-width:1600px;padding:32px}.sidebar{height:-webkit-fit-content;height:fit-content;overflow:hidden;position:-webkit-sticky;position:sticky;top:100px}.editor,.sidebar{max-width:100%;width:100%}.editor{display:flex;flex-direction:column;gap:24px;overflow-x:hidden}.grid-and-actions{align-items:flex-start;display:flex;gap:24px}.grid-and-actions .grid-wrapper{flex-grow:1;flex-shrink:1;min-width:0}.grid-and-actions .action-selector{flex:0 0 auto;max-width:340px;width:320px}.grid-wrapper{max-width:100%;overflow-x:hidden;position:relative;transition:opacity .2s;width:100%}.grid-wrapper.loading{opacity:.5;pointer-events:none}.grid-wrapper.loading:after{animation:spin 1s linear infinite;border:3px solid #ffffff1a;border-radius:50%;border-top-color:#4ade80;content:"";height:40px;left:50%;margin:-20px 0 0 -20px;position:absolute;top:50%;width:40px}@keyframes spin{to{transform:rotate(1turn)}}@media (max-width:1200px){.app-main{gap:16px;grid-template-columns:1fr;padding:16px}.sidebar{max-width:100%!important;position:static;width:100%!important}.editor{gap:16px}.grid-and-actions{align-items:stretch;flex-direction:column;gap:16px;width:100%}.grid-and-actions .grid-wrapper{max-width:100%;width:100%}.grid-and-actions .action-selector{flex:none;max-width:100%!important;min-width:0!important;width:100%!important}}@media (max-width:768px){.user-bar{flex-direction:column;gap:12px;padding:12px 16px}.user-info-bar{flex-wrap:wrap}.user-actions,.user-info-bar{justify-content:center;width:100%}.user-welcome{font-size:13px}.user-badge{font-size:10px;padding:3px 8px}.btn-admin,.btn-logout{font-size:12px;padding:8px 12px}.mode-switcher{gap:6px;padding:12px}.mode-btn{flex:1 1;font-size:.85rem;padding:10px 16px;text-align:center}.app-header{flex-direction:column;gap:12px;padding:12px 16px}.logo h1{font-size:1.2rem}.logo-icon{font-size:1.5rem}.header-actions{justify-content:center;width:100%}.header-actions .btn{flex:1 1;font-size:.85rem;padding:10px 16px}.readonly-notice{font-size:12px;padding:6px 12px}.message{bottom:20px;font-size:14px;left:16px;padding:12px 16px;right:16px;top:auto}.app-main{gap:12px;padding:10px}.editor{gap:12px}.grid-and-actions{flex-direction:column;gap:12px}.grid-and-actions .grid-wrapper{width:100%}.grid-and-actions .action-selector{flex:none;max-width:100%!important;min-width:0!important;width:100%!important}}@media (max-width:500px){.user-bar{gap:8px;padding:10px 8px}.user-info-bar{gap:8px}.user-actions{gap:6px}.btn-admin,.btn-logout{font-size:11px;padding:6px 10px}.mode-switcher{gap:4px;padding:8px}.mode-btn{font-size:.75rem;padding:8px 10px}.app-header{gap:10px;padding:10px 8px}.logo h1{font-size:1rem}.logo-icon{font-size:1.3rem}.header-actions{gap:6px}.header-actions .btn{font-size:.8rem;padding:8px 12px}.app-main{gap:10px;padding:6px}.editor,.grid-and-actions{gap:10px}}@media (max-width:380px){.user-bar{padding:8px 6px}.user-welcome{font-size:12px}.user-badge{font-size:9px;padding:2px 6px}.btn-admin,.btn-logout{font-size:10px;padding:5px 8px}.mode-btn{font-size:.7rem;padding:6px 8px}.app-header{padding:8px 6px}.logo h1{font-size:.9rem}.header-actions .btn{font-size:.75rem;padding:6px 10px}.app-main{padding:4px}}
/*# sourceMappingURL=main.78900cf3.css.map*/