.chess-square-light{background:#f0f0f0}.chess-square-dark{background:#666}.chess-square-selected{box-shadow:inset 0 0 0 3px #2196f3}.chess-square-valid-move:after{content:"";position:absolute;width:25%;height:25%;background:#2196f380;border-radius:50%;pointer-events:none}.chess-square-valid-capture:after{content:"";position:absolute;width:90%;height:90%;border:3px solid rgba(244,67,54,.7);pointer-events:none}.chess-difficulty-easy{background:#4caf50;color:#fff}.chess-difficulty-medium{background:#ff9800;color:#fff}.chess-difficulty-hard{background:#f44336;color:#fff}.chess-card{background:#f5f5f5;padding:15px;border-radius:8px;border:1px solid #ddd}.chess-card-label{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#666;margin-bottom:8px}.chess-status-victory{background:#4caf50;color:#fff}.chess-status-defeat{background:#f44336;color:#fff}.chess-status-draw{background:#ff9800;color:#fff}.chess-hints-panel{background:#e3f2fd;padding:15px;border-radius:8px;font-family:monospace;font-size:13px;line-height:1.6}.chess-hints-label{font-family:inherit;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#1976d2;margin-bottom:8px}.chess-hint-item{background:#fff;padding:10px;margin:5px 0;border-radius:4px;cursor:pointer;border:2px solid transparent;transition:all .2s;width:100%;text-align:left;font-size:13px}.chess-hint-item:hover{background:#f5f5f5;border-color:#2196f3;transform:translate(5px)}.kakuro-grid{display:grid;background:#2c2c2c;border:3px solid #2c2c2c;border-radius:4px;aspect-ratio:1;width:100%;position:relative}.kakuro-grid.size-6{grid-template-columns:repeat(6,1fr);grid-template-rows:repeat(6,1fr)}.kakuro-grid.size-8{grid-template-columns:repeat(8,1fr);grid-template-rows:repeat(8,1fr)}.kakuro-grid.size-10{grid-template-columns:repeat(10,1fr);grid-template-rows:repeat(10,1fr)}.kakuro-cell{display:flex;justify-content:center;align-items:center;font-size:20px;font-weight:600;color:#2c2c2c;position:relative;border:1px solid #ddd}.kakuro-grid.size-8 .kakuro-cell{font-size:18px}.kakuro-grid.size-10 .kakuro-cell{font-size:14px}.kakuro-cell.blocked{background:#52595c;cursor:default}.kakuro-cell.clue{background:#52595c;cursor:default;overflow:hidden}.kakuro-clue-diagonal{position:absolute;top:0;left:0;width:141.4%;height:1px;background:#888;transform-origin:top left;transform:rotate(45deg);z-index:1}.kakuro-clue-down{position:absolute;top:40%;left:4px;font-size:11px;font-weight:600;color:#fff;z-index:2;line-height:1}.kakuro-clue-right{position:absolute;bottom:10%;right:4px;font-size:11px;font-weight:600;color:#fff;z-index:2;line-height:1}.kakuro-grid.size-10 .kakuro-clue-down,.kakuro-grid.size-10 .kakuro-clue-right{font-size:9px}.kakuro-cell.fillable{background:#fff;cursor:pointer;transition:background-color .15s;-webkit-user-select:none;user-select:none}.kakuro-cell.fillable:hover{background:#f5f5f5}.kakuro-cell.selected{background:#bbdefb!important}.kakuro-cell.run-highlight{background:#e3f2fd}.kakuro-cell.same-value{background:#90caf9!important}.kakuro-cell.error{background:#ffcdd2!important;color:#c62828}.kakuro-cell.correct-flash{background:#c8e6c9!important}.kakuro-number-pad{display:grid;grid-template-columns:repeat(6,1fr);gap:6px}.kakuro-num-btn{padding:10px 8px;font-size:18px;font-weight:500;background:#fff;border:1px solid #ddd;border-radius:6px;cursor:pointer;transition:all .15s;font-family:inherit}.kakuro-num-btn:hover{background:#e8e8e8}.kakuro-num-btn:active{background:#d8d8d8}.kakuro-num-btn.clear,.kakuro-num-btn.undo{background:#2c2c2c;color:#fff}.kakuro-num-btn.clear:hover,.kakuro-num-btn.undo:hover{background:#444}@media(max-width:480px){.kakuro-clue-down,.kakuro-clue-right{font-size:9px}.kakuro-grid.size-8 .kakuro-cell{font-size:15px}.kakuro-grid.size-10 .kakuro-cell{font-size:13px}}.sudoku-grid{display:grid;background:#2c2c2c;border:3px solid #2c2c2c;border-radius:4px;aspect-ratio:1;width:100%;position:relative}.sudoku-grid.size-4{grid-template-columns:repeat(4,1fr);grid-template-rows:repeat(4,1fr)}.sudoku-grid.size-6{grid-template-columns:repeat(6,1fr);grid-template-rows:repeat(6,1fr)}.sudoku-grid.size-9{grid-template-columns:repeat(9,1fr);grid-template-rows:repeat(9,1fr)}.sudoku-cell{background:#fff;display:flex;justify-content:center;align-items:center;font-size:24px;font-weight:600;color:#2c2c2c;cursor:pointer;transition:background-color .15s;position:relative;border:1px solid #ddd;-webkit-user-select:none;user-select:none}.sudoku-grid.size-6 .sudoku-cell{font-size:20px}.sudoku-grid.size-9 .sudoku-cell{font-size:18px}.sudoku-cell.given{background:#f0f0f0;color:#2c2c2c;cursor:default}.sudoku-cell.selected{background:#bbdefb!important}.sudoku-cell.highlighted{background:#f1f8fe}.sudoku-cell.same-value{background:#90caf9!important}.sudoku-cell.error{background:#ffcdd2;color:#c62828}.sudoku-cell.correct-flash{background:#c8e6c9}.sudoku-grid.size-4 .sudoku-cell:nth-child(4n+2){border-right:2px solid #2c2c2c}.sudoku-grid.size-4 .sudoku-cell:nth-child(n+5):nth-child(-n+8){border-bottom:2px solid #2c2c2c}.sudoku-grid.size-6 .sudoku-cell:nth-child(6n+3){border-right:2px solid #2c2c2c}.sudoku-grid.size-6 .sudoku-cell:nth-child(n+7):nth-child(-n+12){border-bottom:2px solid #2c2c2c}.sudoku-grid.size-6 .sudoku-cell:nth-child(n+19):nth-child(-n+24){border-bottom:2px solid #2c2c2c}.sudoku-grid.size-9 .sudoku-cell:nth-child(9n+3),.sudoku-grid.size-9 .sudoku-cell:nth-child(9n+6){border-right:2px solid #2c2c2c}.sudoku-grid.size-9 .sudoku-cell:nth-child(n+19):nth-child(-n+27){border-bottom:2px solid #2c2c2c}.sudoku-grid.size-9 .sudoku-cell:nth-child(n+46):nth-child(-n+54){border-bottom:2px solid #2c2c2c}.sudoku-number-pad{display:grid;gap:6px}.sudoku-number-pad.size-4{grid-template-columns:repeat(6,1fr)}.sudoku-number-pad.size-6{grid-template-columns:repeat(4,1fr)}.sudoku-number-pad.size-9{grid-template-columns:repeat(6,1fr)}.sudoku-num-btn{padding:10px 8px;font-size:18px;font-weight:500;background:#fff;border:1px solid #ddd;border-radius:6px;cursor:pointer;transition:all .15s;font-family:inherit}.sudoku-num-btn:hover{background:#e8e8e8}.sudoku-num-btn:active{background:#d8d8d8}.sudoku-num-btn.clear,.sudoku-num-btn.undo{background:#2c2c2c;color:#fff}.sudoku-num-btn.clear:hover,.sudoku-num-btn.undo:hover{background:#444}.sudoku-custom-grid{display:grid;background:#2c2c2c;border:2px solid #2c2c2c;border-radius:4px;width:270px;height:270px}.sudoku-custom-grid.size-4{grid-template-columns:repeat(4,1fr);grid-template-rows:repeat(4,1fr)}.sudoku-custom-grid.size-6{grid-template-columns:repeat(6,1fr);grid-template-rows:repeat(6,1fr)}.sudoku-custom-grid.size-9{grid-template-columns:repeat(9,1fr);grid-template-rows:repeat(9,1fr)}.sudoku-custom-cell{background:#fff;display:flex;justify-content:center;align-items:center;font-size:16px;font-weight:600;color:#2c2c2c;cursor:pointer;border:1px solid #ddd;transition:background-color .1s;-webkit-user-select:none;user-select:none}.sudoku-custom-grid.size-4 .sudoku-custom-cell{font-size:20px}.sudoku-custom-grid.size-6 .sudoku-custom-cell{font-size:18px}.sudoku-custom-cell:hover{background:#f0f0f0}.sudoku-custom-cell.selected{background:#bbdefb}.sudoku-custom-cell.conflict{background:#ffcdd2;color:#c62828;animation:sudoku-shake .3s ease-in-out}@keyframes sudoku-shake{0%,to{transform:translate(0)}25%{transform:translate(-4px)}75%{transform:translate(4px)}}.sudoku-custom-grid.size-4 .sudoku-custom-cell:nth-child(4n+2){border-right:2px solid #2c2c2c}.sudoku-custom-grid.size-4 .sudoku-custom-cell:nth-child(n+5):nth-child(-n+8){border-bottom:2px solid #2c2c2c}.sudoku-custom-grid.size-6 .sudoku-custom-cell:nth-child(6n+3){border-right:2px solid #2c2c2c}.sudoku-custom-grid.size-6 .sudoku-custom-cell:nth-child(n+7):nth-child(-n+12){border-bottom:2px solid #2c2c2c}.sudoku-custom-grid.size-6 .sudoku-custom-cell:nth-child(n+19):nth-child(-n+24){border-bottom:2px solid #2c2c2c}.sudoku-custom-grid.size-9 .sudoku-custom-cell:nth-child(9n+3),.sudoku-custom-grid.size-9 .sudoku-custom-cell:nth-child(9n+6){border-right:2px solid #2c2c2c}.sudoku-custom-grid.size-9 .sudoku-custom-cell:nth-child(n+19):nth-child(-n+27){border-bottom:2px solid #2c2c2c}.sudoku-custom-grid.size-9 .sudoku-custom-cell:nth-child(n+46):nth-child(-n+54){border-bottom:2px solid #2c2c2c}.ig-app{--ig-bg-primary: #0a0a0a;--ig-bg-secondary: #141414;--ig-bg-tertiary: #1a1a1a;--ig-text-primary: #ffffff;--ig-text-secondary: #a0a0a0;--ig-text-muted: #666666;--ig-border: #2a2a2a;--ig-border-light: #333333;--ig-gradient: linear-gradient(45deg, #f09433 0%, #e6683c 25%, #dc2743 50%, #cc2366 75%, #bc1888 100%);--ig-shadow-glow: 0 0 40px rgba(225, 48, 108, .15);min-height:100dvh;background:var(--ig-bg-primary);color:var(--ig-text-primary);font-family:Plus Jakarta Sans,-apple-system,BlinkMacSystemFont,sans-serif}.ig-header{padding:16px 24px;border-bottom:1px solid var(--ig-border);background:var(--ig-bg-primary);position:sticky;top:0;z-index:100}.ig-header-content{max-width:1400px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.ig-back-btn{display:flex;align-items:center;gap:8px;background:none;border:none;color:var(--ig-text-secondary);font-size:14px;font-weight:500;cursor:pointer;padding:6px 10px;border-radius:8px;transition:color .15s,background .15s;font-family:inherit}.ig-back-btn:hover{color:var(--ig-text-primary);background:var(--ig-bg-tertiary)}.ig-logo{display:flex;align-items:center;gap:10px}.ig-logo-icon{width:32px;height:32px;background:var(--ig-gradient);border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.ig-logo-icon svg{width:18px;height:18px;fill:#fff}.ig-logo-text{font-size:16px;font-weight:700;letter-spacing:-.3px}.ig-logo-text span{background:var(--ig-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.ig-controls{display:flex;align-items:center;gap:10px}.ig-upload-btn{display:flex;align-items:center;gap:8px;padding:9px 18px;background:var(--ig-gradient);color:#fff;border:none;border-radius:50px;font-family:inherit;font-size:13px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.ig-upload-btn:hover{transform:translateY(-1px);box-shadow:var(--ig-shadow-glow)}.ig-upload-btn svg{width:16px;height:16px}.ig-clear-btn{padding:9px 14px;background:var(--ig-bg-tertiary);color:var(--ig-text-secondary);border:1px solid var(--ig-border);border-radius:50px;font-family:inherit;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s}.ig-clear-btn:hover{background:var(--ig-bg-secondary);color:var(--ig-text-primary);border-color:var(--ig-border-light)}.ig-main{max-width:1400px;margin:0 auto;padding:24px;display:grid;grid-template-columns:1fr 1fr;gap:24px}@media(max-width:900px){.ig-main{grid-template-columns:1fr;padding:16px;gap:16px}}.ig-preview-section{background:var(--ig-bg-secondary);border-radius:16px;border:1px solid var(--ig-border);overflow:hidden}.ig-preview-header{padding:14px 18px;border-bottom:1px solid var(--ig-border);display:flex;align-items:center;justify-content:space-between}.ig-preview-title{display:flex;align-items:center;gap:10px}.ig-preview-title h2{font-size:14px;font-weight:600}.ig-device-badge{display:flex;align-items:center;gap:5px;padding:3px 9px;background:var(--ig-bg-tertiary);border-radius:50px;font-size:11px;color:var(--ig-text-secondary)}.ig-device-badge svg{width:12px;height:12px}.ig-grid-info{font-size:12px;color:var(--ig-text-muted)}.ig-profile-mock{padding:18px}.ig-profile-header{display:flex;align-items:center;gap:14px;margin-bottom:14px;padding-bottom:14px;border-bottom:1px solid var(--ig-border)}.ig-avatar{width:56px;height:56px;border-radius:50%;background:var(--ig-gradient);padding:3px;flex-shrink:0}.ig-avatar-inner{width:100%;height:100%;background:var(--ig-bg-secondary);border-radius:50%;display:flex;align-items:center;justify-content:center}.ig-avatar-inner svg{width:24px;height:24px;fill:var(--ig-text-muted)}.ig-profile-username{font-size:15px;font-weight:600;margin-bottom:4px}.ig-profile-stats{display:flex;gap:14px;font-size:11px;color:var(--ig-text-secondary)}.ig-profile-stats span strong{color:var(--ig-text-primary);font-weight:600}.ig-photo-grid{display:grid;gap:2px}.ig-photo-grid.cols-3{grid-template-columns:repeat(3,1fr)}.ig-photo-grid.cols-4{grid-template-columns:repeat(4,1fr)}.ig-grid-item{aspect-ratio:1;background:var(--ig-bg-tertiary);position:relative;overflow:hidden;cursor:grab;transition:opacity .2s}.ig-grid-item:hover{opacity:.85}.ig-grid-item:active{cursor:grabbing}.ig-grid-item img{width:100%;height:100%;object-fit:cover;display:block;pointer-events:none;-webkit-user-select:none;user-select:none}.ig-remove-btn{position:absolute;top:5px;right:5px;width:22px;height:22px;background:#000000b3;border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s;padding:0}.ig-grid-item:hover .ig-remove-btn{opacity:1}.ig-remove-btn svg{width:12px;height:12px;stroke:#fff}.ig-grid-item{touch-action:none;user-select:none;-webkit-user-select:none}.ig-grid-item.dragging{opacity:.4}.ig-grid-item.drag-over{outline:2px solid #60a5fa;outline-offset:-2px;opacity:.7}.ig-empty-state{padding:48px 20px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:12px}.ig-empty-icon{width:64px;height:64px;background:var(--ig-bg-tertiary);border-radius:50%;display:flex;align-items:center;justify-content:center}.ig-empty-icon svg{width:28px;height:28px;stroke:var(--ig-text-muted)}.ig-empty-state h3{font-size:15px;font-weight:600}.ig-empty-state p{font-size:13px;color:var(--ig-text-secondary);max-width:220px;line-height:1.5}.ig-reorder-hint{display:flex;align-items:center;gap:8px;padding:10px 14px;background:var(--ig-bg-tertiary);border-radius:8px;margin-top:10px;font-size:12px;color:var(--ig-text-secondary)}.ig-reorder-hint svg{width:16px;height:16px;fill:var(--ig-text-muted);flex-shrink:0}.ig-drag-overlay{position:fixed;inset:0;background:#0a0a0af2;display:flex;align-items:center;justify-content:center;z-index:500}.ig-drag-content{text-align:center;padding:56px;border:2px dashed var(--ig-border-light);border-radius:16px;background:var(--ig-bg-secondary)}.ig-drag-content svg{width:56px;height:56px;stroke:var(--ig-text-secondary);margin-bottom:16px}.ig-drag-content h3{font-size:18px;font-weight:600;margin-bottom:6px}.ig-drag-content p{font-size:13px;color:var(--ig-text-secondary)}.cp-app{min-height:100%;background:#f5f5f5;font-family:inherit;color:#1a1a1a;padding-bottom:80px}.cp-header{background:#1a1a1a;color:#fff;padding:14px 20px;display:flex;align-items:center;gap:16px;position:sticky;top:0;z-index:50}.cp-back-btn{display:flex;align-items:center;gap:6px;background:transparent;border:none;color:#ffffffb3;font-size:.875rem;cursor:pointer;padding:4px 0;transition:color .15s;flex-shrink:0}.cp-back-btn:hover{color:#fff}.cp-header-title{font-size:1rem;font-weight:600;margin:0}.cp-main{max-width:1200px;margin:0 auto;padding:24px 20px;display:grid;grid-template-columns:1fr;gap:24px}@media(min-width:900px){.cp-main{grid-template-columns:minmax(300px,380px) 1fr;align-items:start}}.cp-upload-section{background:#fff;border-radius:16px;box-shadow:0 1px 4px #00000014}.cp-drop-zone{padding:48px 32px;text-align:center;border:2px dashed #ddd;border-radius:16px;margin:16px;cursor:pointer;transition:all .2s}.cp-drop-zone:hover,.cp-drop-zone--over{border-color:#1a1a1a;background:#f8f8f8}.cp-drop-icon{width:52px;height:52px;margin:0 auto 16px;opacity:.35;display:block}.cp-drop-text{font-size:.95rem;color:#555;margin-bottom:6px}.cp-drop-hint{font-size:.8rem;color:#aaa}.cp-preview-wrapper{position:relative;margin:16px;border-radius:12px;overflow:hidden;background:#f0f0f0}.cp-preview-img{width:100%;height:auto;max-height:340px;object-fit:contain;display:block}.cp-change-btn{position:absolute;top:10px;right:10px;background:#000000a6;color:#fff;border:none;padding:6px 14px;border-radius:7px;font-size:.8rem;cursor:pointer;transition:background .2s}.cp-change-btn:hover{background:#000000d9}.cp-remove-btn{position:absolute;top:10px;left:10px;background:#00000080;color:#fff;border:none;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s}.cp-remove-btn:hover{background:#000000bf}.cp-base-section{padding:16px 20px;border-top:1px solid #eee;background:#fafafa;border-bottom-left-radius:16px;border-bottom-right-radius:16px}.cp-base-header{display:flex;align-items:baseline;gap:8px;flex-wrap:wrap;margin-bottom:12px}.cp-base-title{font-size:.875rem;font-weight:600;color:#333}.cp-base-hint{font-size:.75rem;color:#999}.cp-base-list{display:flex;flex-direction:column;gap:8px;margin-bottom:10px}.cp-base-item{display:flex;align-items:center;gap:8px;background:#fff;padding:6px 10px;border-radius:8px;border:1px solid #ddd;transition:border-color .2s}.cp-base-item:hover{border-color:#bbb}.cp-picker-btn{width:36px;height:36px;border-radius:6px;border:2px solid #ddd;cursor:pointer;flex-shrink:0;position:relative;overflow:hidden;transition:border-color .2s}.cp-picker-btn:hover{border-color:#1a1a1a}.cp-picker-input{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%}.cp-hex-input{flex:1;padding:6px 10px;border:1px solid #ddd;border-radius:6px;font-family:SF Mono,Monaco,Courier New,monospace;font-size:.82rem;font-weight:500;text-transform:uppercase;transition:border-color .2s;min-width:0}.cp-hex-input:focus{outline:none;border-color:#1a1a1a;box-shadow:0 0 0 2px #1a1a1a1a}.cp-remove-color-btn{background:transparent;border:1px solid #eee;border-radius:6px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#bbb;transition:all .2s;flex-shrink:0}.cp-remove-color-btn:hover{border-color:#f44;color:#f44;background:#fff5f5}.cp-add-color-btn{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;padding:9px;border:1.5px dashed #ddd;border-radius:8px;background:transparent;font-size:.82rem;color:#777;cursor:pointer;transition:all .2s}.cp-add-color-btn:hover:not(:disabled){border-color:#1a1a1a;border-style:solid;color:#1a1a1a;background:#fff}.cp-add-color-btn:disabled{opacity:.5;cursor:not-allowed}.cp-controls{padding:16px 20px;border-top:1px solid #eee;border-bottom-left-radius:16px;border-bottom-right-radius:16px}.cp-control-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.cp-control-label{font-size:.875rem;color:#555}.cp-select{position:relative;min-width:110px}.cp-select-trigger{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:7px 11px;background:#fff;border:1px solid #ddd;border-radius:8px;font-size:.875rem;cursor:pointer;transition:all .2s;-webkit-user-select:none;user-select:none;width:100%}.cp-select-trigger:hover{border-color:#bbb}.cp-select--open .cp-select-trigger{border-color:#1a1a1a;box-shadow:0 0 0 2px #1a1a1a1a}.cp-select-dropdown{position:absolute;top:calc(100% + 6px);left:0;right:0;background:#fff;border:1px solid #ddd;border-radius:8px;box-shadow:0 4px 16px #0000001f;z-index:100;overflow:hidden}.cp-select-option{padding:9px 12px;font-size:.875rem;cursor:pointer;transition:background .15s}.cp-select-option:hover{background:#f5f5f5}.cp-select-option--selected{background:#1a1a1a;color:#fff}.cp-select-option--selected:hover{background:#333}.cp-generate-btn{width:100%;padding:12px;background:#1a1a1a;color:#fff;border:none;border-radius:10px;font-size:.9rem;font-weight:500;cursor:pointer;transition:background .2s,transform .15s}.cp-generate-btn:hover{background:#333;transform:translateY(-1px)}.cp-palette-section{background:#fff;border-radius:16px;box-shadow:0 1px 4px #00000014;padding:20px;min-height:300px}.cp-palette-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;flex-wrap:wrap;gap:10px}.cp-palette-title{font-size:1rem;font-weight:600}.cp-palette-actions{display:flex;align-items:center;gap:8px}.cp-action-btn{display:flex;align-items:center;gap:5px;padding:7px 12px;border:1px solid #ddd;border-radius:8px;background:transparent;font-size:.8rem;cursor:pointer;transition:all .2s;color:#555}.cp-action-btn:hover{border-color:#1a1a1a;color:#1a1a1a;background:#f8f8f8}.cp-loading{padding:40px 20px;text-align:center}.cp-progress-bar{width:100%;max-width:260px;height:6px;background:#eee;border-radius:10px;margin:0 auto 14px;overflow:hidden}.cp-progress-fill{height:100%;border-radius:10px;background:linear-gradient(90deg,#1a1a1a,#555,#1a1a1a);background-size:200% 100%;animation:cp-shimmer 1.4s infinite linear;width:100%}@keyframes cp-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.cp-loading-text{font-size:.85rem;color:#888}.cp-empty{padding:60px 20px;text-align:center;color:#bbb}.cp-empty-icon{width:60px;height:60px;margin:0 auto 16px;opacity:.25;display:block}.cp-empty p{font-size:.875rem;line-height:1.5;max-width:260px;margin:0 auto}.cp-palette-grid{display:grid;gap:12px;margin-bottom:28px}.cp-color-card{display:flex;align-items:stretch;background:#fafafa;border-radius:12px;overflow:hidden;height:120px;transition:transform .2s,box-shadow .2s}.cp-color-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000017}.cp-color-main{display:flex;align-items:stretch;flex:1;min-width:0}.cp-color-swatch{width:76px;flex-shrink:0;cursor:pointer;position:relative;transition:transform .15s}.cp-color-swatch:hover{transform:scale(1.04);z-index:1}.cp-color-swatch:before{content:"Copy";position:absolute;inset:0;background:#000000b3;color:#fff;font-size:.7rem;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s}.cp-color-swatch:hover:before{opacity:1}.cp-color-info{padding:10px 12px;display:flex;flex-direction:column;justify-content:center;gap:2px;flex:1;min-width:0}.cp-color-hex{font-family:SF Mono,Monaco,Courier New,monospace;font-size:.875rem;font-weight:600}.cp-color-rgb{font-size:.72rem;color:#999}.cp-color-pct{font-size:.68rem;color:#bbb}.cp-variations{display:flex;max-width:0;overflow:hidden;opacity:0;transition:max-width .3s ease,opacity .3s ease}.cp-color-card--expanded .cp-variations{max-width:400px;opacity:1}.cp-var-group{display:flex;height:100%}.cp-var-swatch{width:40px;flex-shrink:0;cursor:pointer;position:relative;transition:transform .15s}.cp-var-swatch:hover{transform:scaleX(1.25);z-index:2}.cp-var-swatch:after{content:attr(data-hex);position:absolute;top:100%;left:50%;transform:translate(-50%) translateY(-8px);background:#1a1a1a;color:#fff;padding:3px 7px;border-radius:4px;font-size:.68rem;font-family:SF Mono,Monaco,Courier New,monospace;white-space:nowrap;opacity:0;pointer-events:none;transition:all .15s;z-index:10}.cp-var-swatch:hover:after{opacity:1;transform:translate(-50%) translateY(4px)}.cp-harmony{border-top:1px solid #eee;padding-top:20px}.cp-harmony-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;margin-bottom:14px}.cp-harmony-title{font-size:.875rem;font-weight:600;color:#444}.cp-harmony-controls{display:flex;align-items:center;gap:8px}.cp-harmony-label{font-size:.75rem;color:#999}.cp-hselect{position:relative;min-width:90px}.cp-hselect-trigger{display:flex;align-items:center;justify-content:space-between;gap:6px;padding:5px 8px;background:#fff;border:1px solid #ddd;border-radius:6px;font-size:.75rem;font-family:SF Mono,Monaco,Courier New,monospace;cursor:pointer;transition:all .2s;-webkit-user-select:none;user-select:none}.cp-hselect-trigger:hover{border-color:#bbb}.cp-hselect--open .cp-hselect-trigger{border-color:#1a1a1a}.cp-hselect-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:#fff;border:1px solid #ddd;border-radius:6px;box-shadow:0 4px 12px #0000001a;z-index:100;overflow:hidden;max-height:180px;overflow-y:auto}.cp-hselect-option{display:flex;align-items:center;gap:6px;padding:7px 9px;font-size:.75rem;font-family:SF Mono,Monaco,Courier New,monospace;cursor:pointer;transition:background .15s}.cp-hselect-option:hover{background:#f5f5f5}.cp-hselect-option--selected{background:#1a1a1a;color:#fff}.cp-hselect-option--selected:hover{background:#333}.cp-hselect-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.cp-shuffle-btn{display:flex;align-items:center;justify-content:center;padding:5px 9px;border:1px solid #ddd;border-radius:6px;background:transparent;cursor:pointer;transition:all .2s;color:#666}.cp-shuffle-btn:hover{border-color:#1a1a1a;background:#f5f5f5;color:#1a1a1a}.cp-harmony-grid{display:flex;gap:10px;flex-wrap:wrap}.cp-harmony-group{flex:1;min-width:130px;background:#fafafa;border-radius:10px;padding:10px}.cp-harmony-group-label{font-size:.7rem;color:#999;text-transform:uppercase;letter-spacing:.4px;margin-bottom:8px}.cp-harmony-swatches{display:flex;height:36px;border-radius:6px;overflow:visible}.cp-harmony-swatch{flex:1;cursor:pointer;position:relative;transition:transform .15s}.cp-harmony-swatch:first-child{border-top-left-radius:6px;border-bottom-left-radius:6px}.cp-harmony-swatch:last-child{border-top-right-radius:6px;border-bottom-right-radius:6px}.cp-harmony-swatch:hover{transform:scaleY(1.15);z-index:1}.cp-harmony-swatch:after{content:attr(data-hex);position:absolute;top:100%;left:50%;transform:translate(-50%) translateY(-8px);background:#1a1a1a;color:#fff;padding:3px 7px;border-radius:4px;font-size:.68rem;font-family:SF Mono,Monaco,Courier New,monospace;white-space:nowrap;opacity:0;pointer-events:none;transition:all .15s;z-index:10}.cp-harmony-swatch:hover:after{opacity:1;transform:translate(-50%) translateY(4px)}.cp-modal-overlay{position:fixed;inset:0;background:#0000007a;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.cp-modal{background:#fff;border-radius:16px;max-width:480px;width:100%;max-height:80vh;overflow:auto}.cp-modal-header{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid #eee}.cp-modal-title{font-size:1rem;font-weight:600}.cp-modal-close{background:none;border:none;cursor:pointer;color:#aaa;display:flex;align-items:center;padding:2px;transition:color .2s}.cp-modal-close:hover{color:#333}.cp-modal-body{padding:20px 22px}.cp-export-option{padding:14px;border:1px solid #eee;border-radius:10px;margin-bottom:10px;cursor:pointer;transition:all .2s}.cp-export-option:hover{border-color:#bbb;background:#fafafa}.cp-export-option--selected{border-color:#1a1a1a;background:#f5f5f5}.cp-export-option-title{font-size:.875rem;font-weight:500;margin-bottom:3px}.cp-export-option-desc{font-size:.78rem;color:#999}.cp-export-preview{background:#f5f5f5;border-radius:8px;padding:14px;margin-top:14px;font-family:SF Mono,Monaco,Courier New,monospace;font-size:.75rem;white-space:pre-wrap;word-break:break-all;max-height:180px;overflow:auto;color:#333}.cp-export-copy-btn{width:100%;margin-top:12px;padding:13px;background:#1a1a1a;color:#fff;border:none;border-radius:10px;font-size:.9rem;font-weight:500;cursor:pointer;transition:background .2s}.cp-export-copy-btn:hover{background:#333}.cp-toast{position:fixed;bottom:90px;left:50%;transform:translate(-50%) translateY(20px);background:#1a1a1a;color:#fff;padding:12px 24px;border-radius:10px;font-size:.875rem;opacity:0;pointer-events:none;transition:all .25s ease;z-index:2000;white-space:nowrap}.cp-toast--show{opacity:1;transform:translate(-50%) translateY(0)}@media(max-width:600px){.cp-main{padding:16px;gap:16px}.cp-color-card{height:auto;min-height:80px;flex-direction:column}.cp-color-main{width:100%}.cp-color-swatch{width:80px;min-height:80px}.cp-variations{flex-direction:column;max-width:none;max-height:0;opacity:0;transition:max-height .3s ease,opacity .3s ease;overflow:hidden}.cp-color-card--expanded .cp-variations{max-width:none;max-height:200px;opacity:1}.cp-var-group{width:100%;height:44px}.cp-var-swatch{flex:1;width:auto}.cp-harmony-group{min-width:100%}}.ss-grid{display:grid;grid-template-columns:repeat(9,1fr);grid-template-rows:repeat(9,1fr);background:#2c2c2c;border:3px solid #2c2c2c;border-radius:4px;aspect-ratio:1;width:100%}.ss-cell{background:#fff;display:flex;justify-content:center;align-items:center;font-size:18px;font-weight:600;color:#2c2c2c;cursor:pointer;transition:background-color .15s;border:1px solid #ddd;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.ss-cell.given{background:#f0f0f0;color:#2c2c2c;font-weight:700;cursor:default}.ss-cell.solved{color:#2c2c2c;font-weight:600;cursor:default}.ss-cell.selected{background:#bbdefb!important}.ss-cell.highlighted{background:#f1f8fe}.ss-cell.same-value{background:#90caf9!important}.ss-cell.conflict{background:#ffcdd2;color:#c62828}.ss-number-pad{display:grid;grid-template-columns:repeat(5,1fr);gap:6px}.ss-num-btn{padding:10px 8px;font-size:18px;font-weight:500;background:#fff;border:1px solid #ddd;border-radius:6px;cursor:pointer;transition:all .15s;font-family:inherit;text-align:center}.ss-num-btn:hover{background:#e8e8e8}.ss-num-btn:active{background:#d8d8d8}.ss-num-btn.clear{background:#2c2c2c;color:#fff}.ss-num-btn.clear:hover{background:#444}.ss-grid .ss-cell:nth-child(9n+3),.ss-grid .ss-cell:nth-child(9n+6){border-right:2px solid #2c2c2c}.ss-grid .ss-cell:nth-child(n+19):nth-child(-n+27){border-bottom:2px solid #2c2c2c}.ss-grid .ss-cell:nth-child(n+46):nth-child(-n+54){border-bottom:2px solid #2c2c2c}@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-scroll-snap-strictness:proximity;--tw-space-y-reverse:0;--tw-border-style:solid;--tw-leading:initial;--tw-font-weight:initial;--tw-tracking:initial;--tw-ordinal:initial;--tw-slashed-zero:initial;--tw-numeric-figure:initial;--tw-numeric-spacing:initial;--tw-numeric-fraction:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-backdrop-blur:initial;--tw-backdrop-brightness:initial;--tw-backdrop-contrast:initial;--tw-backdrop-grayscale:initial;--tw-backdrop-hue-rotate:initial;--tw-backdrop-invert:initial;--tw-backdrop-opacity:initial;--tw-backdrop-saturate:initial;--tw-backdrop-sepia:initial;--tw-duration:initial;--tw-scale-x:1;--tw-scale-y:1;--tw-scale-z:1;--tw-animation-delay:0s;--tw-animation-direction:normal;--tw-animation-duration:initial;--tw-animation-fill-mode:none;--tw-animation-iteration-count:1;--tw-enter-blur:0;--tw-enter-opacity:1;--tw-enter-rotate:0;--tw-enter-scale:1;--tw-enter-translate-x:0;--tw-enter-translate-y:0;--tw-exit-blur:0;--tw-exit-opacity:1;--tw-exit-rotate:0;--tw-exit-scale:1;--tw-exit-translate-x:0;--tw-exit-translate-y:0}}}@layer theme{:root,:host{--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--color-emerald-600:oklch(59.6% .145 163.225);--color-black:#000;--color-white:#fff;--spacing:.25rem;--container-xs:20rem;--container-sm:24rem;--container-lg:32rem;--container-3xl:48rem;--text-xs:.75rem;--text-xs--line-height:calc(1 / .75);--text-sm:.875rem;--text-sm--line-height:calc(1.25 / .875);--text-base:1rem;--text-base--line-height: 1.5 ;--text-lg:1.125rem;--text-lg--line-height:calc(1.75 / 1.125);--text-xl:1.25rem;--text-xl--line-height:calc(1.75 / 1.25);--text-2xl:1.5rem;--text-2xl--line-height:calc(2 / 1.5);--text-3xl:1.875rem;--text-3xl--line-height: 1.2 ;--text-4xl:2.25rem;--text-4xl--line-height:calc(2.5 / 2.25);--text-5xl:3rem;--text-5xl--line-height:1;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--font-weight-extrabold:800;--tracking-tight:-.025em;--tracking-normal:0em;--tracking-wide:.025em;--tracking-wider:.05em;--tracking-widest:.1em;--leading-tight:1.25;--leading-snug:1.375;--leading-relaxed:1.625;--animate-spin:spin 1s linear infinite;--blur-xl:24px;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:"Plus Jakarta Sans", ui-sans-serif, system-ui, sans-serif;--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}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;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}*{border-color:var(--border);outline-color:var(--ring)}@supports (color:color-mix(in lab,red,red)){*{outline-color:color-mix(in oklab,var(--ring) 50%,transparent)}}body{background-color:var(--background);color:var(--foreground)}}@layer components;@layer utilities{.pointer-events-none{pointer-events:none}.invisible{visibility:hidden}.visible{visibility:visible}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.inset-0{inset:calc(var(--spacing) * 0)}.end{inset-inline-end:var(--spacing)}.right-0{right:calc(var(--spacing) * 0)}.right-4{right:calc(var(--spacing) * 4)}.bottom-0{bottom:calc(var(--spacing) * 0)}.bottom-20{bottom:calc(var(--spacing) * 20)}.left-0{left:calc(var(--spacing) * 0)}.left-4{left:calc(var(--spacing) * 4)}.z-0{z-index:0}.z-10{z-index:10}.z-50{z-index:50}.-mx-5{margin-inline:calc(var(--spacing) * -5)}.mx-auto{margin-inline:auto}.mt-0\.5{margin-top:calc(var(--spacing) * .5)}.mt-1{margin-top:calc(var(--spacing) * 1)}.mt-1\.5{margin-top:calc(var(--spacing) * 1.5)}.mt-2{margin-top:calc(var(--spacing) * 2)}.mr-1{margin-right:calc(var(--spacing) * 1)}.mr-1\.5{margin-right:calc(var(--spacing) * 1.5)}.mb-0\.5{margin-bottom:calc(var(--spacing) * .5)}.mb-1{margin-bottom:calc(var(--spacing) * 1)}.mb-1\.5{margin-bottom:calc(var(--spacing) * 1.5)}.mb-2{margin-bottom:calc(var(--spacing) * 2)}.mb-3{margin-bottom:calc(var(--spacing) * 3)}.mb-4{margin-bottom:calc(var(--spacing) * 4)}.mb-6{margin-bottom:calc(var(--spacing) * 6)}.mb-8{margin-bottom:calc(var(--spacing) * 8)}.mb-10{margin-bottom:calc(var(--spacing) * 10)}.ml-1\.5{margin-left:calc(var(--spacing) * 1.5)}.ml-2{margin-left:calc(var(--spacing) * 2)}.line-clamp-2{-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.no-scrollbar{-ms-overflow-style:none;scrollbar-width:none}.no-scrollbar::-webkit-scrollbar{display:none}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.h-6{height:calc(var(--spacing) * 6)}.h-8{height:calc(var(--spacing) * 8)}.h-9{height:calc(var(--spacing) * 9)}.h-12{height:calc(var(--spacing) * 12)}.h-14{height:calc(var(--spacing) * 14)}.h-\[82\%\]{height:82%}.h-\[env\(safe-area-inset-bottom\)\]{height:env(safe-area-inset-bottom)}.h-full{height:100%}.max-h-36{max-height:calc(var(--spacing) * 36)}.min-h-\[calc\(100dvh-5rem\)\]{min-height:calc(100dvh - 5rem)}.min-h-dvh{min-height:100dvh}.w-6{width:calc(var(--spacing) * 6)}.w-8{width:calc(var(--spacing) * 8)}.w-9{width:calc(var(--spacing) * 9)}.w-12{width:calc(var(--spacing) * 12)}.w-14{width:calc(var(--spacing) * 14)}.w-60{width:calc(var(--spacing) * 60)}.w-\[18px\]{width:18px}.w-\[82\%\]{width:82%}.w-full{width:100%}.max-w-3xl{max-width:var(--container-3xl)}.max-w-\[500px\]{max-width:500px}.max-w-lg{max-width:var(--container-lg)}.max-w-sm{max-width:var(--container-sm)}.max-w-xs{max-width:var(--container-xs)}.min-w-0{min-width:calc(var(--spacing) * 0)}.flex-1{flex:1}.shrink-0{flex-shrink:0}.animate-spin{animation:var(--animate-spin)}.cursor-not-allowed{cursor:not-allowed}.cursor-pointer{cursor:pointer}.snap-x{scroll-snap-type:x var(--tw-scroll-snap-strictness)}.snap-mandatory{--tw-scroll-snap-strictness:mandatory}.snap-start{scroll-snap-align:start}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-stretch{align-items:stretch}.justify-around{justify-content:space-around}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.justify-start{justify-content:flex-start}.gap-0{gap:calc(var(--spacing) * 0)}.gap-0\.5{gap:calc(var(--spacing) * .5)}.gap-1\.5{gap:calc(var(--spacing) * 1.5)}.gap-2{gap:calc(var(--spacing) * 2)}.gap-3{gap:calc(var(--spacing) * 3)}.gap-4{gap:calc(var(--spacing) * 4)}:where(.space-y-0\.5>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * .5) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * .5) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-1>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 1) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 1) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-3>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 3) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 3) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-4>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 4) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 4) * calc(1 - var(--tw-space-y-reverse)))}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.rounded{border-radius:.25rem}.rounded-2xl{border-radius:calc(var(--radius) + 8px)}.rounded-full{border-radius:3.40282e38px}.rounded-lg{border-radius:var(--radius)}.rounded-md{border-radius:calc(var(--radius) - 2px)}.rounded-xl{border-radius:calc(var(--radius) + 4px)}.border{border-style:var(--tw-border-style);border-width:1px}.border-0{border-style:var(--tw-border-style);border-width:0}.border-2{border-style:var(--tw-border-style);border-width:2px}.border-t{border-top-style:var(--tw-border-style);border-top-width:1px}.border-r{border-right-style:var(--tw-border-style);border-right-width:1px}.border-b{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.border-dashed{--tw-border-style:dashed;border-style:dashed}.border-\[\#2c2c2c\]{border-color:#2c2c2c}.border-\[\#bbdefb\]{border-color:#bbdefb}.border-\[\#ddd\]{border-color:#ddd}.border-\[\#e0e0e0\]{border-color:#e0e0e0}.border-\[\#eee\]{border-color:#eee}.border-\[\#ffcdd2\]{border-color:#ffcdd2}.border-border{border-color:var(--border)}.border-foreground\/80{border-color:var(--foreground)}@supports (color:color-mix(in lab,red,red)){.border-foreground\/80{border-color:color-mix(in oklab,var(--foreground) 80%,transparent)}}.border-primary{border-color:var(--primary)}.border-t-transparent{border-top-color:#0000}.bg-\[\#00b4d8\]{background-color:#00b4d8}.bg-\[\#2c2c2c\]{background-color:#2c2c2c}.bg-\[\#4caf50\]{background-color:#4caf50}.bg-\[\#999\]{background-color:#999}.bg-\[\#e3f2fd\]{background-color:#e3f2fd}.bg-\[\#e53935\]{background-color:#e53935}.bg-\[\#f5f5f5\]{background-color:#f5f5f5}.bg-\[\#f44336\]{background-color:#f44336}.bg-\[\#ff9800\]{background-color:#ff9800}.bg-\[\#ffebee\]{background-color:#ffebee}.bg-background{background-color:var(--background)}.bg-black\/50{background-color:#00000080}@supports (color:color-mix(in lab,red,red)){.bg-black\/50{background-color:color-mix(in oklab,var(--color-black) 50%,transparent)}}.bg-card,.bg-card\/80{background-color:var(--card)}@supports (color:color-mix(in lab,red,red)){.bg-card\/80{background-color:color-mix(in oklab,var(--card) 80%,transparent)}}.bg-muted,.bg-muted\/30{background-color:var(--muted)}@supports (color:color-mix(in lab,red,red)){.bg-muted\/30{background-color:color-mix(in oklab,var(--muted) 30%,transparent)}}.bg-white{background-color:var(--color-white)}.p-1{padding:calc(var(--spacing) * 1)}.p-3{padding:calc(var(--spacing) * 3)}.p-4{padding:calc(var(--spacing) * 4)}.p-5{padding:calc(var(--spacing) * 5)}.p-6{padding:calc(var(--spacing) * 6)}.px-1{padding-inline:calc(var(--spacing) * 1)}.px-2{padding-inline:calc(var(--spacing) * 2)}.px-2\.5{padding-inline:calc(var(--spacing) * 2.5)}.px-3{padding-inline:calc(var(--spacing) * 3)}.px-4{padding-inline:calc(var(--spacing) * 4)}.px-5{padding-inline:calc(var(--spacing) * 5)}.py-0\.5{padding-block:calc(var(--spacing) * .5)}.py-1\.5{padding-block:calc(var(--spacing) * 1.5)}.py-2{padding-block:calc(var(--spacing) * 2)}.py-2\.5{padding-block:calc(var(--spacing) * 2.5)}.py-3{padding-block:calc(var(--spacing) * 3)}.py-4{padding-block:calc(var(--spacing) * 4)}.py-16{padding-block:calc(var(--spacing) * 16)}.py-20{padding-block:calc(var(--spacing) * 20)}.pt-4{padding-top:calc(var(--spacing) * 4)}.pt-10{padding-top:calc(var(--spacing) * 10)}.pt-12{padding-top:calc(var(--spacing) * 12)}.pt-14{padding-top:calc(var(--spacing) * 14)}.pr-1{padding-right:calc(var(--spacing) * 1)}.pb-2{padding-bottom:calc(var(--spacing) * 2)}.pb-4{padding-bottom:calc(var(--spacing) * 4)}.pb-8{padding-bottom:calc(var(--spacing) * 8)}.pb-20{padding-bottom:calc(var(--spacing) * 20)}.pl-4{padding-left:calc(var(--spacing) * 4)}.text-center{text-align:center}.font-mono{font-family:var(--font-mono)}.font-sans{font-family:Plus Jakarta Sans,ui-sans-serif,system-ui,sans-serif}.text-2xl{font-size:var(--text-2xl);line-height:var(--tw-leading,var(--text-2xl--line-height))}.text-3xl{font-size:var(--text-3xl);line-height:var(--tw-leading,var(--text-3xl--line-height))}.text-4xl{font-size:var(--text-4xl);line-height:var(--tw-leading,var(--text-4xl--line-height))}.text-5xl{font-size:var(--text-5xl);line-height:var(--tw-leading,var(--text-5xl--line-height))}.text-base{font-size:var(--text-base);line-height:var(--tw-leading,var(--text-base--line-height))}.text-lg{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xl{font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.text-\[10px\]{font-size:10px}.text-\[11px\]{font-size:11px}.text-\[12px\]{font-size:12px}.leading-none{--tw-leading:1;line-height:1}.leading-relaxed{--tw-leading:var(--leading-relaxed);line-height:var(--leading-relaxed)}.leading-snug{--tw-leading:var(--leading-snug);line-height:var(--leading-snug)}.leading-tight{--tw-leading:var(--leading-tight);line-height:var(--leading-tight)}.font-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.font-extrabold{--tw-font-weight:var(--font-weight-extrabold);font-weight:var(--font-weight-extrabold)}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.tracking-normal{--tw-tracking:var(--tracking-normal);letter-spacing:var(--tracking-normal)}.tracking-tight{--tw-tracking:var(--tracking-tight);letter-spacing:var(--tracking-tight)}.tracking-wide{--tw-tracking:var(--tracking-wide);letter-spacing:var(--tracking-wide)}.tracking-wider{--tw-tracking:var(--tracking-wider);letter-spacing:var(--tracking-wider)}.tracking-widest{--tw-tracking:var(--tracking-widest);letter-spacing:var(--tracking-widest)}.text-\[\#2c2c2c\]{color:#2c2c2c}.text-\[\#444\]{color:#444}.text-\[\#666\]{color:#666}.text-\[\#888\]{color:#888}.text-\[\#999\]{color:#999}.text-\[\#1565c0\]{color:#1565c0}.text-\[\#c62828\]{color:#c62828}.text-emerald-600{color:var(--color-emerald-600)}.text-foreground{color:var(--foreground)}.text-muted-foreground{color:var(--muted-foreground)}.text-primary{color:var(--primary)}.text-white{color:var(--color-white)}.text-white\/60{color:#fff9}@supports (color:color-mix(in lab,red,red)){.text-white\/60{color:color-mix(in oklab,var(--color-white) 60%,transparent)}}.capitalize{text-transform:capitalize}.normal-case{text-transform:none}.uppercase{text-transform:uppercase}.tabular-nums{--tw-numeric-spacing:tabular-nums;font-variant-numeric:var(--tw-ordinal,) var(--tw-slashed-zero,) var(--tw-numeric-figure,) var(--tw-numeric-spacing,) var(--tw-numeric-fraction,)}.opacity-60{opacity:.6}.shadow-lg{--tw-shadow:0 10px 15px -3px var(--tw-shadow-color,#0000001a), 0 4px 6px -4px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-sm{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a), 0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-xl{--tw-shadow:0 20px 25px -5px var(--tw-shadow-color,#0000001a), 0 8px 10px -6px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.backdrop-blur-xl{--tw-backdrop-blur:blur(var(--blur-xl));-webkit-backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,)}.transition-all{transition-property:all;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-transform{transition-property:transform,translate,scale,rotate;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.duration-200{--tw-duration:.2s;transition-duration:.2s}.outline-none{--tw-outline-style:none;outline-style:none}.select-none{-webkit-user-select:none;user-select:none}@media(hover:hover){.group-hover\:scale-110:is(:where(.group):hover *){--tw-scale-x:110%;--tw-scale-y:110%;--tw-scale-z:110%;scale:var(--tw-scale-x) var(--tw-scale-y)}}.last\:border-r-0:last-child{border-right-style:var(--tw-border-style);border-right-width:0}@media(hover:hover){.hover\:border-primary\/30:hover{border-color:var(--primary)}@supports (color:color-mix(in lab,red,red)){.hover\:border-primary\/30:hover{border-color:color-mix(in oklab,var(--primary) 30%,transparent)}}.hover\:bg-\[\#1c1c1c\]:hover{background-color:#1c1c1c}.hover\:bg-\[\#444\]:hover{background-color:#444}.hover\:bg-\[\#c62828\]:hover{background-color:#c62828}.hover\:bg-\[\#d32f2f\]:hover{background-color:#d32f2f}.hover\:bg-\[\#e8e8e8\]:hover{background-color:#e8e8e8}.hover\:bg-\[\#f5f5f5\]:hover{background-color:#f5f5f5}.hover\:bg-\[\#f57c00\]:hover{background-color:#f57c00}.hover\:bg-white\/10:hover{background-color:#ffffff1a}@supports (color:color-mix(in lab,red,red)){.hover\:bg-white\/10:hover{background-color:color-mix(in oklab,var(--color-white) 10%,transparent)}}.hover\:text-\[\#333\]:hover{color:#333}.hover\:text-foreground:hover{color:var(--foreground)}.hover\:text-white:hover{color:var(--color-white)}.hover\:shadow-md:hover{--tw-shadow:0 4px 6px -1px var(--tw-shadow-color,#0000001a), 0 2px 4px -2px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.hover\:shadow-sm:hover{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a), 0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}}.active\:scale-95:active{--tw-scale-x:95%;--tw-scale-y:95%;--tw-scale-z:95%;scale:var(--tw-scale-x) var(--tw-scale-y)}.active\:scale-\[0\.97\]:active{scale:.97}.active\:scale-\[0\.98\]:active{scale:.98}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-40:disabled{opacity:.4}@media(min-width:40rem){.sm\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}}@media(min-width:48rem){.md\:flex{display:flex}.md\:w-\[260px\]{width:260px}.md\:max-w-3xl{max-width:var(--container-3xl)}.md\:max-w-\[520px\]{max-width:520px}.md\:flex-1{flex:1}.md\:shrink-0{flex-shrink:0}.md\:flex-row{flex-direction:row}.md\:items-center{align-items:center}.md\:items-start{align-items:flex-start}.md\:justify-center{justify-content:center}.md\:justify-start{justify-content:flex-start}.md\:overflow-hidden{overflow:hidden}.md\:rounded-xl{border-radius:calc(var(--radius) + 4px)}.md\:bg-\[\#f0f0f0\]{background-color:#f0f0f0}.md\:bg-white{background-color:var(--color-white)}.md\:p-5{padding:calc(var(--spacing) * 5)}.md\:p-6{padding:calc(var(--spacing) * 6)}.md\:px-4{padding-inline:calc(var(--spacing) * 4)}.md\:py-6{padding-block:calc(var(--spacing) * 6)}.md\:pt-5{padding-top:calc(var(--spacing) * 5)}.md\:pt-8{padding-top:calc(var(--spacing) * 8)}.md\:pb-12{padding-bottom:calc(var(--spacing) * 12)}.md\:pl-0{padding-left:calc(var(--spacing) * 0)}.md\:shadow-lg{--tw-shadow:0 10px 15px -3px var(--tw-shadow-color,#0000001a), 0 4px 6px -4px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}}.dark\:bg-card:is(.dark *){background-color:var(--card)}.dark\:text-foreground:is(.dark *){color:var(--foreground)}}@property --tw-animation-delay{syntax:"*";inherits:false;initial-value:0s}@property --tw-animation-direction{syntax:"*";inherits:false;initial-value:normal}@property --tw-animation-duration{syntax:"*";inherits:false}@property --tw-animation-fill-mode{syntax:"*";inherits:false;initial-value:none}@property --tw-animation-iteration-count{syntax:"*";inherits:false;initial-value:1}@property --tw-enter-blur{syntax:"*";inherits:false;initial-value:0}@property --tw-enter-opacity{syntax:"*";inherits:false;initial-value:1}@property --tw-enter-rotate{syntax:"*";inherits:false;initial-value:0}@property --tw-enter-scale{syntax:"*";inherits:false;initial-value:1}@property --tw-enter-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-enter-translate-y{syntax:"*";inherits:false;initial-value:0}@property --tw-exit-blur{syntax:"*";inherits:false;initial-value:0}@property --tw-exit-opacity{syntax:"*";inherits:false;initial-value:1}@property --tw-exit-rotate{syntax:"*";inherits:false;initial-value:0}@property --tw-exit-scale{syntax:"*";inherits:false;initial-value:1}@property --tw-exit-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-exit-translate-y{syntax:"*";inherits:false;initial-value:0}:root{--radius:.625rem;--background:oklch(100% 0 0);--foreground:oklch(14.5% 0 0);--card:oklch(100% 0 0);--card-foreground:oklch(14.5% 0 0);--popover:oklch(100% 0 0);--popover-foreground:oklch(14.5% 0 0);--primary:oklch(20.5% 0 0);--primary-foreground:oklch(98.5% 0 0);--secondary:oklch(97% 0 0);--secondary-foreground:oklch(20.5% 0 0);--muted:oklch(97% 0 0);--muted-foreground:oklch(55.6% 0 0);--accent:oklch(97% 0 0);--accent-foreground:oklch(20.5% 0 0);--destructive:oklch(57.7% .245 27.325);--destructive-foreground:oklch(98.5% .002 247);--border:oklch(92.2% 0 0);--input:oklch(92.2% 0 0);--ring:oklch(70.8% 0 0);--chart-1:oklch(64.6% .222 41.116);--chart-2:oklch(60% .118 184.704);--chart-3:oklch(39.8% .07 227.392);--chart-4:oklch(82.8% .189 84.429);--chart-5:oklch(76.9% .188 70.08);--sidebar:oklch(98.5% 0 0);--sidebar-foreground:oklch(14.5% 0 0);--sidebar-primary:oklch(20.5% 0 0);--sidebar-primary-foreground:oklch(98.5% 0 0);--sidebar-accent:oklch(97% 0 0);--sidebar-accent-foreground:oklch(20.5% 0 0);--sidebar-border:oklch(92.2% 0 0);--sidebar-ring:oklch(70.8% 0 0)}.dark{--background:oklch(14.5% 0 0);--foreground:oklch(98.5% 0 0);--card:oklch(20.5% 0 0);--card-foreground:oklch(98.5% 0 0);--popover:oklch(20.5% 0 0);--popover-foreground:oklch(98.5% 0 0);--primary:oklch(92.2% 0 0);--primary-foreground:oklch(20.5% 0 0);--secondary:oklch(26.9% 0 0);--secondary-foreground:oklch(98.5% 0 0);--muted:oklch(26.9% 0 0);--muted-foreground:oklch(70.8% 0 0);--accent:oklch(26.9% 0 0);--accent-foreground:oklch(98.5% 0 0);--destructive:oklch(70.4% .191 22.216);--destructive-foreground:oklch(98.5% .002 247);--border:oklch(100% 0 0/.1);--input:oklch(100% 0 0/.15);--ring:oklch(55.6% 0 0);--chart-1:oklch(48.8% .243 264.376);--chart-2:oklch(69.6% .17 162.48);--chart-3:oklch(76.9% .188 70.08);--chart-4:oklch(62.7% .265 303.9);--chart-5:oklch(64.5% .246 16.439);--sidebar:oklch(20.5% 0 0);--sidebar-foreground:oklch(98.5% 0 0);--sidebar-primary:oklch(48.8% .243 264.376);--sidebar-primary-foreground:oklch(98.5% 0 0);--sidebar-accent:oklch(26.9% 0 0);--sidebar-accent-foreground:oklch(98.5% 0 0);--sidebar-border:oklch(100% 0 0/.1);--sidebar-ring:oklch(55.6% 0 0)}*{border-color:var(--border)}body{background:var(--background);color:var(--foreground);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100dvh;margin:0;font-family:Plus Jakarta Sans,ui-sans-serif,system-ui,sans-serif}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.page-enter{animation:.3s ease-out fadeIn}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--muted-foreground);border-radius:999px}.prose h1{margin-bottom:.75rem;font-size:1.75rem;font-weight:800}.prose h2{margin-top:1.5rem;margin-bottom:.5rem;font-size:1.35rem;font-weight:700}.prose h3{margin-top:1.25rem;margin-bottom:.5rem;font-size:1.1rem;font-weight:600}.prose p{margin-bottom:1rem;line-height:1.7}.prose ul{margin-bottom:1rem;padding-left:1.5rem;list-style:outside}.prose ol{margin-bottom:1rem;padding-left:1.5rem;list-style:decimal}.prose li{margin-bottom:.25rem}.prose code{background:var(--muted);border-radius:.25rem;padding:.15rem .4rem;font-size:.875em}.prose pre{background:var(--muted);border-radius:var(--radius);margin-bottom:1rem;padding:1rem;overflow-x:auto}.prose pre code{background:0 0;padding:0}.prose a{color:var(--primary);text-decoration:underline}.prose blockquote{border-left:3px solid var(--primary);color:var(--muted-foreground);margin-bottom:1rem;padding-left:1rem;font-style:italic}.prose img{border-radius:var(--radius);max-width:100%;margin-bottom:1rem}.no-scrollbar{-ms-overflow-style:none;scrollbar-width:none}.no-scrollbar::-webkit-scrollbar{display:none}@property --tw-scroll-snap-strictness{syntax:"*";inherits:false;initial-value:proximity}@property --tw-space-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-tracking{syntax:"*";inherits:false}@property --tw-ordinal{syntax:"*";inherits:false}@property --tw-slashed-zero{syntax:"*";inherits:false}@property --tw-numeric-figure{syntax:"*";inherits:false}@property --tw-numeric-spacing{syntax:"*";inherits:false}@property --tw-numeric-fraction{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-backdrop-blur{syntax:"*";inherits:false}@property --tw-backdrop-brightness{syntax:"*";inherits:false}@property --tw-backdrop-contrast{syntax:"*";inherits:false}@property --tw-backdrop-grayscale{syntax:"*";inherits:false}@property --tw-backdrop-hue-rotate{syntax:"*";inherits:false}@property --tw-backdrop-invert{syntax:"*";inherits:false}@property --tw-backdrop-opacity{syntax:"*";inherits:false}@property --tw-backdrop-saturate{syntax:"*";inherits:false}@property --tw-backdrop-sepia{syntax:"*";inherits:false}@property --tw-duration{syntax:"*";inherits:false}@property --tw-scale-x{syntax:"*";inherits:false;initial-value:1}@property --tw-scale-y{syntax:"*";inherits:false;initial-value:1}@property --tw-scale-z{syntax:"*";inherits:false;initial-value:1}@keyframes spin{to{transform:rotate(360deg)}}
