@import"https://fonts.googleapis.com/css2?family=Cinzel:wght@400;600;700&family=Crimson+Pro:ital,wght@0,300;0,400;0,600;1,300;1,400&display=swap";.spinner{border-radius:50%;border-style:solid;border-color:var(--accent) transparent transparent transparent;animation:spinner-rotate .7s linear infinite;flex-shrink:0}.spinner--sm{width:1rem;height:1rem;border-width:2px}.spinner--md{width:1.75rem;height:1.75rem;border-width:3px}.spinner--lg{width:3rem;height:3rem;border-width:4px}@keyframes spinner-rotate{to{transform:rotate(360deg)}}.spinner-center{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;padding:3rem;width:100%}.spinner-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9000;background:#0c0c14a6;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.85rem}.spinner-label{color:var(--text-muted);font-size:.9rem;font-family:var(--font-display);letter-spacing:.04em}.deck-card{display:flex;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden;cursor:pointer;transition:border-color .2s,transform .2s,box-shadow .2s;position:relative}.deck-card--deleting{opacity:.6;pointer-events:none}.deck-card-spinner-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;z-index:10;background:#0c0c1473;border-radius:var(--radius-md)}.import-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:8000;background:#0c0c14bf;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:1rem}.import-modal{position:relative;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:680px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 24px 80px #000000bf}.import-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.1rem 1.5rem;border-bottom:1px solid var(--border);flex-shrink:0}.import-modal-header h2{font-family:var(--font-display);font-size:1rem;letter-spacing:.06em;color:var(--gold)}.import-modal-close{background:none;border:none;color:var(--text-muted);font-size:1rem;cursor:pointer;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .15s,color .15s}.import-modal-close:hover{background:var(--surface2);color:var(--text)}.import-modal-body{display:flex;gap:1.25rem;padding:1.25rem 1.5rem;flex:1;overflow-y:auto;min-height:0}.import-legend-preview{flex-shrink:0;width:110px;display:flex;align-items:flex-start;padding-top:1.65rem}.import-legend-img{width:110px;height:154px;object-fit:cover;border-radius:var(--radius-md);border:2px solid var(--gold);box-shadow:0 0 20px #c9a84c40}.import-legend-placeholder{width:110px;height:154px;background:var(--surface2);border:2px dashed var(--border);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:.7rem;color:var(--text-dim);text-align:center;padding:.5rem}.import-form{flex:1;display:flex;flex-direction:column;gap:.5rem;min-width:0}.import-label{font-size:.72rem;font-family:var(--font-display);letter-spacing:.04em;color:var(--text-muted);text-transform:uppercase}.import-input{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-family:var(--font-body);font-size:.95rem;padding:.5rem .75rem;outline:none;transition:border-color .15s}.import-input:focus{border-color:var(--accent)}.import-textarea{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-family:monospace;font-size:.8rem;line-height:1.5;padding:.65rem .75rem;resize:vertical;min-height:220px;outline:none;transition:border-color .15s}.import-textarea:focus{border-color:var(--accent)}.import-textarea::placeholder{color:var(--text-dim)}.import-errors{background:#e05c5c1a;border:1px solid var(--danger);border-radius:var(--radius-sm);padding:.75rem 1rem;color:var(--danger);font-size:.82rem}.import-errors strong{display:block;margin-bottom:.4rem;font-family:var(--font-display);font-size:.75rem;letter-spacing:.04em}.import-errors ul{margin:0;padding-left:1.2rem;display:flex;flex-direction:column;gap:.2rem}.import-success{background:#4caf7d1f;border:1px solid var(--success);border-radius:var(--radius-sm);padding:.65rem 1rem;color:var(--success);font-size:.85rem;font-family:var(--font-display);letter-spacing:.03em}.import-modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid var(--border);flex-shrink:0}.cdm-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:8500;background:#0c0c14bf;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:1rem}.cdm-modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2rem 2rem 1.5rem;width:100%;max-width:360px;display:flex;flex-direction:column;align-items:center;gap:.75rem;box-shadow:0 24px 80px #000000bf;text-align:center}.cdm-icon{font-size:2rem;line-height:1;margin-bottom:.25rem}.cdm-title{font-family:var(--font-display);font-size:1.05rem;letter-spacing:.06em;color:var(--text);margin:0}.cdm-body{font-size:.9rem;color:var(--text-muted);line-height:1.5;margin:0}.cdm-body strong{color:var(--text);font-style:normal}.cdm-actions{display:flex;gap:.75rem;justify-content:center;margin-top:.5rem;width:100%}.cdm-actions .btn-ghost,.cdm-btn-delete{flex:1}.cdm-btn-delete{background:var(--danger);color:#fff;border:1px solid var(--danger);border-radius:var(--radius-sm);font-family:var(--font-display);font-size:.8rem;font-weight:600;letter-spacing:.06em;padding:.5rem 1.25rem;cursor:pointer;transition:background .15s,box-shadow .15s}.cdm-btn-delete:hover{background:#c94444;box-shadow:0 4px 16px #e05c5c66}.step-nav{display:flex;align-items:center;padding:1rem 2rem;background:var(--surface);border-bottom:1px solid var(--border);overflow-x:auto;gap:0}.step-pill{display:flex;align-items:center;gap:.5rem;padding:.4rem .9rem;border-radius:20px;border:1px solid transparent;background:transparent;cursor:default;transition:all .2s;white-space:nowrap;font-family:var(--font-display);font-size:.7rem;letter-spacing:.08em}.step-num{width:1.4rem;height:1.4rem;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.65rem;font-weight:700}.step-active{border-color:var(--accent-hi);color:var(--accent-hi);background:#a78bfa1a}.step-active .step-num{background:var(--accent-hi);color:var(--bg)}.step-done{color:var(--gold);cursor:pointer}.step-done .step-num{background:var(--gold);color:var(--bg)}.step-done:hover{color:var(--gold-hi);border-color:var(--gold)}.step-future{color:var(--text-dim)}.step-future .step-num{background:var(--surface3);color:var(--text-dim)}.step-accessible{color:var(--success);cursor:pointer;opacity:.8}.step-accessible .step-num{background:var(--success);color:var(--bg)}.step-accessible:hover{opacity:1;border-color:var(--success)}.step-connector{flex:1;height:1px;background:var(--border);min-width:1.5rem;max-width:3rem;transition:background .3s}.step-connector.done{background:var(--gold)}.deck-sidebar{background:var(--surface);border-right:1px solid var(--border);padding:1.5rem 1rem;overflow-y:auto;display:flex;flex-direction:column;gap:1.25rem}.sidebar-title{font-family:var(--font-display);font-size:1rem;letter-spacing:.08em;color:var(--gold);border-bottom:1px solid var(--border);padding-bottom:.75rem}.sidebar-section{border-radius:var(--radius-sm);padding:.25rem;transition:background .15s}.sidebar-section[onClick],.sidebar-section[style*="cursor: pointer"]{border-radius:var(--radius-sm)}.sidebar-section[style*="cursor: pointer"]:hover{background:var(--surface2)}.sidebar-section h3{font-family:var(--font-display);font-size:.65rem;letter-spacing:.15em;text-transform:uppercase;color:var(--text-muted);margin-bottom:.5rem;display:flex;justify-content:space-between;align-items:center}.sidebar-count{font-family:var(--font-body);font-size:.8rem;color:var(--accent-hi)}.sidebar-single-card{display:flex;align-items:center;gap:.5rem;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.4rem .6rem}.sidebar-single-card img{width:32px;height:44px;object-fit:cover;border-radius:3px}.sidebar-single-card span{font-size:.85rem;color:var(--text);font-style:italic}.sidebar-progress{height:4px;background:var(--surface3);border-radius:2px;overflow:hidden;margin-top:.4rem}.sidebar-progress-fill{height:100%;background:linear-gradient(90deg,var(--accent) 0%,var(--accent-hi) 100%);border-radius:2px;transition:width .3s ease}@keyframes popupFadeIn{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}.thumb{position:relative;border-radius:var(--radius-sm);overflow:hidden;aspect-ratio:744 / 1039;cursor:pointer;border:2px solid transparent;transition:transform .2s,border-color .2s,box-shadow .2s;background:var(--surface2)}.thumb-landscape{aspect-ratio:1039 / 744;grid-column:span 2}.thumb:hover{transform:translateY(-3px);border-color:var(--accent);box-shadow:0 6px 20px #7b5ea759}.thumb-selected{border-color:var(--gold)!important;box-shadow:0 0 16px #c9a84c80!important}.thumb-disabled{opacity:.35;cursor:default;transform:none!important}.thumb img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s}.thumb:hover img{transform:scale(1.04)}.thumb-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:.7rem;color:var(--text-dim);padding:.5rem;text-align:center}.thumb-overlay{position:absolute;bottom:0;left:0;right:0;padding:1.5rem .4rem .4rem;background:linear-gradient(to top,rgba(0,0,0,.85) 0%,transparent 100%);display:flex;flex-direction:column;gap:.2rem}.thumb-name{font-size:.68rem;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-family:var(--font-display);letter-spacing:.02em}.thumb-tags{display:flex;gap:.2rem;flex-wrap:wrap}.pip{font-size:.55rem;padding:.1rem .3rem;border-radius:10px;font-weight:700;background:#00000080;color:#fff}.pip-energy{background:#c9a84cb3}.pip-might{background:#e05c5cb3}.pip-power{background:#7b5ea7b3}.thumb-badge{position:absolute;top:.3rem;right:.3rem;background:var(--accent);color:#fff;font-family:var(--font-display);font-size:.6rem;font-weight:700;padding:.15rem .4rem;border-radius:10px;border:1px solid var(--accent-hi)}.thumb-variant{position:absolute;top:.3rem;left:.3rem;background:#c9a84ce6;color:var(--bg);font-family:var(--font-display);font-size:.55rem;font-weight:700;padding:.15rem .35rem;border-radius:8px;border:1px solid var(--gold-hi);text-transform:uppercase;letter-spacing:.05em}.carousel-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:10;background:#0000008c;color:#fff;border:none;border-radius:50%;width:1.6rem;height:1.6rem;font-size:1.2rem;line-height:1;display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0;opacity:.15;transition:opacity .2s,background .2s;pointer-events:auto}.carousel-arrow-left{left:.3rem}.carousel-arrow-right{right:.3rem}.carousel-arrow.carousel-arrow-visible{opacity:.9}.carousel-arrow:hover{background:#000c;opacity:1!important}.carousel-dots{position:absolute;bottom:2.4rem;left:50%;transform:translate(-50%);display:flex;gap:.25rem;pointer-events:none}.carousel-dot{width:.35rem;height:.35rem;border-radius:50%;background:#ffffff73;transition:background .2s}.carousel-dot-active{background:var(--gold, #c9a84c)}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(176px,1fr));gap:.75rem}.step-content{padding:1.25rem 1.5rem;overflow-y:auto;flex:1}.step-with-list{display:grid;grid-template-columns:280px 1fr;gap:1.5rem;padding:1.25rem 1.5rem;flex:1;overflow:hidden}.step-list-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:1rem;overflow-y:auto;display:flex;flex-direction:column;gap:.5rem}.step-list-header{display:flex;justify-content:space-between;align-items:center;font-family:var(--font-display);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);border-bottom:1px solid var(--border);padding-bottom:.5rem;margin-bottom:.25rem}.step-grid-panel{overflow-y:auto;display:flex;flex-direction:column;gap:.75rem}.step-grid-panel .search-input{align-self:stretch;flex:none;width:100%}.step-desc{font-size:.9rem;color:var(--text-muted);font-style:italic;margin-bottom:.75rem;line-height:1.5}.validation-warning{font-size:.8rem;color:var(--danger);background:#e05c5c1a;border:1px solid rgba(224,92,92,.3);border-radius:var(--radius-sm);padding:.4rem .6rem;font-style:italic}.filter-row{display:flex;gap:.75rem;margin-bottom:1rem;align-items:center;flex-wrap:wrap}.filter-row .search-input{flex:1;min-width:180px}.filter-row .filter-select{min-width:150px}.bf-selected{display:flex;gap:.75rem;flex-wrap:wrap;margin-bottom:1rem;min-height:2rem}.bf-chip{display:flex;align-items:center;gap:.5rem;background:var(--surface2);border:1px solid var(--gold);border-radius:var(--radius-sm);padding:.3rem .6rem}.bf-chip img{width:36px;height:26px;object-fit:cover;border-radius:2px}.bf-chip span{font-size:.8rem;color:var(--gold);font-family:var(--font-display);letter-spacing:.04em}.bf-chip button{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:.75rem;padding:0 .1rem;transition:color .15s}.bf-chip button:hover{color:var(--danger)}.count-done{color:var(--success)}.count-error{color:var(--danger)}.type-filter-buttons{display:flex;gap:.4rem;flex-shrink:0}.type-filter-btn{background:var(--surface2);color:var(--text-muted);border:1px solid var(--border);padding:.35rem .75rem;border-radius:var(--radius-sm);font-family:var(--font-display);font-size:.65rem;letter-spacing:.07em;cursor:pointer;transition:all .15s;white-space:nowrap}.type-filter-btn:hover{border-color:var(--accent-hi);color:var(--text)}.type-filter-btn--active{background:var(--accent);color:#fff;border-color:var(--accent-hi);box-shadow:0 0 10px #7b5ea766}.filter-row--domains{flex-wrap:wrap;gap:.35rem;padding-top:0}.domain-filter-btn{font-size:.7rem;font-family:var(--font-display);font-weight:600;letter-spacing:.04em;padding:.2rem .65rem;border-radius:12px;border:1px solid;background:transparent;cursor:pointer;transition:background .15s,color .15s}.domain-filter-btn--active{color:#fff!important}.deck-overview{display:grid;grid-template-columns:300px 1fr;flex:1;min-height:0;overflow:hidden}.overview-side{display:flex;flex-direction:column;gap:1rem;padding:1.25rem;overflow-y:auto;border-right:1px solid var(--border);background:var(--surface)}.overview-hero{display:flex;align-items:center;gap:.85rem;padding-bottom:1rem;border-bottom:1px solid var(--border)}.overview-hero-images{display:flex;flex-direction:column;gap:.4rem;flex-shrink:0}.overview-legend-img{width:56px;height:78px;object-fit:cover;border-radius:var(--radius-sm);border:2px solid var(--gold);box-shadow:0 0 14px #c9a84c4d}.overview-champion-img{width:56px;height:78px;object-fit:cover;border-radius:var(--radius-sm);border:2px solid var(--accent);box-shadow:0 0 10px #7b5ea74d}.overview-hero-text{display:flex;flex-direction:column;gap:.2rem;min-width:0}.overview-deck-name{font-family:var(--font-display);font-size:1rem;letter-spacing:.07em;color:var(--gold);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.overview-legend-name{font-family:var(--font-display);font-size:.7rem;letter-spacing:.05em;color:var(--text-muted);margin:0}.overview-champion-name{font-size:.78rem;color:var(--accent-hi);margin:0}.overview-card-count{font-size:.72rem;color:var(--text-dim);margin:0}.overview-chart-box{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-md);padding:.85rem;display:flex;flex-direction:column;gap:.5rem}.chart-title{font-family:var(--font-display);font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted);border-bottom:1px solid var(--border);padding-bottom:.4rem;margin:0}.chart-empty{font-size:.78rem;color:var(--text-dim);font-style:italic;padding:.75rem 0;text-align:center;margin:0}.pie-layout{display:flex;align-items:center;gap:.75rem}.pie-legend{display:flex;flex-direction:column;gap:.35rem;flex:1;min-width:0}.pie-legend-row{display:flex;align-items:center;gap:.4rem;font-size:.75rem}.pie-legend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.pie-legend-label{color:var(--text);font-family:var(--font-display);font-size:.62rem;letter-spacing:.03em;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pie-legend-value{color:var(--text);font-weight:600;font-size:.72rem;white-space:nowrap}.pie-legend-pct{color:var(--text-muted);font-weight:400;font-size:.67rem}.overview-main{overflow-y:auto;padding:1.25rem}.ov-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(176px,1fr));gap:.75rem}.ov-card-tile{position:relative;border-radius:var(--radius-sm);overflow:hidden;aspect-ratio:744 / 1039;background:var(--surface2);border:2px solid transparent;transition:border-color .2s,transform .2s,box-shadow .2s;cursor:default}.ov-card-tile:hover{transform:translateY(-3px);border-color:var(--border-hi);box-shadow:0 6px 20px #7b5ea74d}.ov-card-img{width:100%;height:100%;object-fit:cover;display:block}.ov-card-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:.7rem;color:var(--text-dim);padding:.5rem;text-align:center}.ov-card-copies{position:absolute;bottom:.4rem;left:50%;transform:translate(-50%);background:#000000bf;color:#fff;font-family:var(--font-display);font-size:.7rem;font-weight:700;padding:.15rem .55rem;border-radius:10px;border:1px solid rgba(255,255,255,.2);letter-spacing:.04em;white-space:nowrap;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.ov-card-champ-badge{position:absolute;top:.3rem;left:.3rem;background:#c9a84ce6;color:var(--bg);font-family:var(--font-display);font-size:.52rem;font-weight:700;padding:.12rem .35rem;border-radius:8px;border:1px solid var(--gold-hi);text-transform:uppercase;letter-spacing:.05em}@media(max-width:1000px){.deck-overview{grid-template-columns:1fr;grid-template-rows:auto 1fr}.overview-side{border-right:none;border-bottom:1px solid var(--border);overflow-y:unset}}.rune-domain-tiles{display:flex;flex-wrap:wrap;gap:.5rem}.rune-domain-tile{flex:1 1 80px;display:flex;flex-direction:column;align-items:center;gap:.1rem;padding:.5rem .5rem .45rem;background:var(--surface2);border:1px solid var(--domain-color, var(--border));border-radius:var(--radius-md);box-shadow:0 0 8px color-mix(in srgb,var(--domain-color, transparent) 20%,transparent);overflow:hidden}.rune-domain-tile-img-wrap{width:100%;height:38px;overflow:hidden;border-radius:calc(var(--radius-md) - 2px) calc(var(--radius-md) - 2px) 0 0;margin:-.5rem -.5rem .35rem;width:calc(100% + 1rem)}.rune-domain-tile-img{width:100%;height:100%;object-fit:cover;object-position:center 18%;display:block}.rune-domain-tile-count{font-family:var(--font-display);font-size:1.4rem;font-weight:700;color:var(--domain-color, var(--text));line-height:1}.rune-domain-tile-name{font-family:var(--font-display);font-size:.6rem;letter-spacing:.08em;text-transform:uppercase;color:var(--domain-color, var(--text-muted))}.rune-domain-tile-label{font-size:.58rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.06em}.ov-sub-panel{margin-bottom:1.5rem}.ov-sub-panel-title{font-family:var(--font-display);font-size:1.2rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);border-bottom:1px solid var(--border);padding-bottom:.4rem;margin:0 0 .75rem}.ov-sub-panel--sideboard{margin-top:2.5rem}.ov-card-grid--small{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.5rem;margin-bottom:0}.ov-card-tile--landscape{aspect-ratio:1039 / 744;grid-column:span 2}.avg-stats-row{display:flex;align-items:center;justify-content:space-around;padding:.5rem 0}.avg-stat{display:flex;flex-direction:column;align-items:center;gap:.25rem}.avg-stat-label{font-size:.7rem;color:var(--text-muted);font-family:var(--font-display);letter-spacing:.04em;text-transform:uppercase}.avg-stat-value{font-size:1.6rem;font-family:var(--font-display);font-weight:700;letter-spacing:.04em}.avg-stat-energy{color:#30d5c8}.avg-stat-power{color:var(--accent-hi)}.avg-stat-divider{width:1px;height:2.5rem;background:var(--border)}.deck-name-display{font-family:var(--font-display);font-size:1rem;letter-spacing:.08em;color:var(--gold)}.build-layout{display:grid;grid-template-columns:260px 1fr;flex:1;min-height:0}.build-main{display:flex;flex-direction:column;overflow:hidden}.build-step-header{padding:1.25rem 1.5rem .75rem;border-bottom:1px solid var(--border)}.build-step-header h2{font-family:var(--font-display);font-size:1.1rem;letter-spacing:.05em;color:var(--text)}@media(max-width:900px){.build-layout{grid-template-columns:1fr}.deck-sidebar{display:none}.step-with-list{grid-template-columns:1fr}}.export-dropdown{position:relative}.export-dropdown-trigger{gap:.3rem}.export-dropdown-menu{position:absolute;top:calc(100% + 6px);right:0;min-width:172px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:0 8px 32px #00000080;z-index:500;overflow:hidden;display:flex;flex-direction:column}.export-dropdown-item{background:none;border:none;color:var(--text);font-family:var(--font-display);font-size:.8rem;letter-spacing:.04em;text-align:left;padding:.65rem 1rem;cursor:pointer;transition:background .15s,color .15s;white-space:nowrap}.export-dropdown-item:hover{background:var(--surface2);color:var(--accent-hi)}.export-dropdown-item+.export-dropdown-item{border-top:1px solid var(--border)}.gallery-layout{display:flex;flex:1;overflow:hidden;height:calc(100vh - 57px)}.gallery-sidebar{width:220px;flex-shrink:0;background:var(--surface);border-right:1px solid var(--border);overflow-y:auto}.gallery-sidebar-inner{padding:1.25rem 1rem;display:flex;flex-direction:column;gap:1.5rem}.gallery-filter-section{display:flex;flex-direction:column;gap:.6rem}.gallery-filter-label{font-family:var(--font-display);font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted)}.gallery-search{width:100%}.gallery-filter-chips{display:flex;flex-wrap:wrap;gap:.4rem}.gallery-chip{font-size:.72rem;padding:.25rem .6rem}.gallery-clear-btn{margin-top:auto;font-size:.8rem;color:var(--text-muted);text-align:center}.gallery-main{flex:1;overflow-y:auto;padding:1.5rem}.gallery-count-badge{font-family:var(--font-display);font-size:.7rem;letter-spacing:.06em;color:var(--text-muted)}.btn-icon{font-size:1.1rem;padding:.3rem .6rem;line-height:1}:root{--bg: #0c0c14;--surface: #13131f;--surface2: #1c1c2e;--surface3: #242438;--border: #2e2e4a;--border-hi: #5a4fcf;--accent: #7b5ea7;--accent-hi: #a78bfa;--gold: #c9a84c;--gold-hi: #f0cc6e;--text: #ddd8f0;--text-muted: #7a7a9a;--text-dim: #4a4a6a;--danger: #e05c5c;--success: #4caf7d;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--font-display: "Cinzel", serif;--font-body: "Crimson Pro", Georgia, serif}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);font-family:var(--font-body);font-size:1rem;line-height:1.5;min-height:100vh}.App{display:flex;flex-direction:column;min-height:100vh}.app-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 2rem;background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100;gap:1rem}.header-left{display:flex;align-items:center;gap:1rem}.header-right{display:flex;align-items:center;gap:.75rem}.app-header h1{font-family:var(--font-display);font-size:1.5rem;font-weight:700;letter-spacing:.15em;color:var(--gold);text-shadow:0 0 24px rgba(201,168,76,.4)}.header-sub{font-family:var(--font-display);font-size:.7rem;letter-spacing:.2em;color:var(--text-muted);text-transform:uppercase}.btn-primary{background:linear-gradient(135deg,var(--accent) 0%,#5a3f8a 100%);color:#fff;border:1px solid var(--accent-hi);padding:.5rem 1.25rem;border-radius:var(--radius-sm);font-family:var(--font-display);font-size:.75rem;letter-spacing:.08em;cursor:pointer;transition:all .2s}.btn-primary:hover{filter:brightness(1.15);transform:translateY(-1px)}.btn-primary:disabled{opacity:.4;cursor:default;transform:none}.btn-ghost{background:transparent;color:var(--text-muted);border:1px solid var(--border);padding:.5rem 1rem;border-radius:var(--radius-sm);font-family:var(--font-display);font-size:.75rem;letter-spacing:.08em;cursor:pointer;transition:all .2s}.btn-ghost:hover{border-color:var(--accent-hi);color:var(--accent-hi)}.btn-finish{background:linear-gradient(135deg,#4caf7d,#2e7d54);border-color:#6ddfaa}.deck-name-input{background:transparent;border:none;border-bottom:1px solid var(--border);color:var(--text);font-family:var(--font-display);font-size:1rem;letter-spacing:.05em;padding:.25rem .5rem;width:240px;transition:border-color .2s}.deck-name-input:focus{outline:none;border-color:var(--accent-hi)}.deck-name-input::placeholder{color:var(--text-dim)}.slot-row{display:flex;align-items:center;gap:.5rem;padding:.3rem .4rem;border-radius:var(--radius-sm);background:var(--surface2);transition:background .15s}.slot-row:hover{background:var(--surface3)}.slot-img{width:28px;height:38px;object-fit:cover;border-radius:3px;flex-shrink:0}.slot-name{flex:1;font-size:.82rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text)}.slot-controls{display:flex;align-items:center;gap:.3rem;flex-shrink:0}.slot-copies{font-family:var(--font-display);font-size:.75rem;color:var(--accent-hi);min-width:1.5rem;text-align:center}.slot-btn{width:1.4rem;height:1.4rem;border-radius:50%;border:1px solid var(--border);background:var(--surface3);color:var(--text);cursor:pointer;font-size:.9rem;line-height:1;display:flex;align-items:center;justify-content:center;transition:all .15s}.slot-btn:hover:not(:disabled){border-color:var(--accent-hi);color:var(--accent-hi)}.slot-btn:disabled{opacity:.3;cursor:default}.browse-main{padding:1.5rem 2rem;display:flex;flex-direction:column;gap:1rem;flex:1}.browse-controls{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap}.card-count{font-size:.8rem;color:var(--text-muted);margin-left:auto}.search-input{flex:1;min-width:180px;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);padding:.5rem .75rem;font-family:var(--font-body);font-size:.9rem;transition:border-color .2s;height:40px;min-height:40px;max-height:40px;line-height:1.2;overflow:hidden;white-space:nowrap;flex-shrink:0}.search-input:focus{outline:none;border-color:var(--accent-hi)}.search-input::placeholder{color:var(--text-dim)}.filter-select{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);padding:.5rem .75rem;font-family:var(--font-body);font-size:.9rem;cursor:pointer;transition:border-color .2s;height:40px;min-height:40px;max-height:40px}.filter-select:focus{outline:none;border-color:var(--accent-hi)}.type-badge,.rarity-badge{padding:.2rem .65rem;border-radius:20px;font-family:var(--font-display);font-size:.65rem;letter-spacing:.08em;text-transform:uppercase;border:1px solid transparent}.type-unit{background:#22c55e26;color:#86efac;border-color:#22c55e4d}.type-spell{background:#a855f726;color:#d8b4fe;border-color:#a855f74d}.type-gear{background:#eab30826;color:#fde047;border-color:#eab3084d}.type-rune{background:#14b8a626;color:#5eead4;border-color:#14b8a64d}.type-battlefield{background:#ec489926;color:#f9a8d4;border-color:#ec48994d}.type-legend{background:#c9a84c26;color:#f0cc6e;border-color:#c9a84c4d}.rarity-common{background:#9ca3af26;color:#d1d5db;border-color:#9ca3af4d}.rarity-uncommon{background:#22c55e26;color:#86efac;border-color:#22c55e4d}.rarity-rare{background:#3b82f626;color:#93c5fd;border-color:#3b82f64d}.rarity-epic{background:#a855f726;color:#d8b4fe;border-color:#a855f74d}.rarity-legendary{background:#c9a84c26;color:#f0cc6e;border-color:#c9a84c4d}.count-done{color:var(--success);font-weight:600}.count-pending{color:var(--accent-hi)}.empty-msg{color:var(--text-dim);font-style:italic;font-size:.85rem;padding:1rem 0;text-align:center}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:200;padding:2rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-box{background:var(--surface);border:1px solid var(--border-hi);border-radius:var(--radius-lg);max-width:700px;width:100%;max-height:90vh;overflow-y:auto;position:relative;display:grid;grid-template-columns:280px 1fr;box-shadow:0 24px 64px #0009}.modal-landscape{grid-template-columns:1fr;max-width:800px}.modal-close{position:absolute;top:.75rem;right:.75rem;background:var(--surface2);border:1px solid var(--border);color:var(--text-muted);width:2rem;height:2rem;border-radius:50%;cursor:pointer;font-size:.8rem;display:flex;align-items:center;justify-content:center;transition:all .2s;z-index:1}.modal-close:hover{border-color:var(--danger);color:var(--danger)}.modal-img{width:100%;display:block;border-radius:var(--radius-lg) 0 0 var(--radius-lg);object-fit:cover}.modal-info{padding:1.5rem;display:flex;flex-direction:column;gap:.75rem}.modal-info h2{font-family:var(--font-display);font-size:1.2rem;letter-spacing:.05em;color:var(--gold)}.modal-badges{display:flex;gap:.5rem;flex-wrap:wrap}.modal-stats{display:flex;gap:.5rem}.stat-box{flex:1;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.4rem .6rem;display:flex;flex-direction:column;align-items:center}.stat-box span{font-size:.65rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);font-family:var(--font-display)}.stat-box strong{font-size:1.2rem;color:var(--text)}.modal-desc{font-size:.9rem;color:var(--text-muted);font-style:italic;line-height:1.6}.modal-meta{font-size:.8rem;color:var(--text-dim)}.fullscreen-center{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;gap:1rem;color:var(--text-muted);font-style:italic}.error-msg{color:var(--danger)}.spinner{width:2.5rem;height:2.5rem;border:3px solid var(--border);border-top-color:var(--accent-hi);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:900px){.build-layout{grid-template-columns:1fr}.deck-sidebar{display:none}.step-with-list,.modal-box{grid-template-columns:1fr}.modal-img{border-radius:var(--radius-lg) var(--radius-lg) 0 0;max-height:280px}}@media(max-width:600px){.app-header{padding:.75rem 1rem}.browse-main,.step-content{padding:1rem}.card-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}.step-nav{padding:.75rem 1rem}.step-label{display:none}}.home-main{padding:2rem;max-width:1200px;margin:0 auto;width:100%}.home-header{display:flex;align-items:baseline;gap:1rem;margin-bottom:1.5rem;border-bottom:1px solid var(--border);padding-bottom:1rem}.home-header h2{font-family:var(--font-display);font-size:1.4rem;letter-spacing:.06em;color:var(--text)}.deck-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.25rem}.deck-card{display:flex;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden;cursor:pointer;transition:border-color .2s,transform .2s,box-shadow .2s}.deck-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 6px 20px #7b5ea733}.deck-card-art{width:90px;flex-shrink:0;background:var(--surface2);overflow:hidden}.deck-card-art img{width:100%;height:100%;object-fit:cover;object-position:center top}.deck-card-art-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:2rem;color:var(--text-dim)}.deck-card-info{padding:.9rem 1rem;display:flex;flex-direction:column;gap:.35rem;flex:1;min-width:0}.deck-card-info h3{font-family:var(--font-display);font-size:.95rem;letter-spacing:.04em;color:var(--gold);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.deck-card-legend{font-size:.82rem;color:var(--text-muted);font-style:italic}.deck-card-domains{display:flex;gap:.35rem;flex-wrap:wrap}.domain-chip{font-family:var(--font-display);font-size:.6rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:.15rem .5rem;border-radius:10px;color:#000;text-shadow:0 0 4px rgba(255,255,255,.6)}.deck-card-counts{display:flex;gap:.5rem;margin-top:.1rem}.deck-card-counts span{font-size:.72rem;color:var(--text-dim);font-family:var(--font-display);letter-spacing:.04em}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;padding:5rem 2rem;text-align:center}.empty-state-title{font-family:var(--font-display);font-size:1.2rem;letter-spacing:.06em;color:var(--text-muted)}.empty-state-sub{font-size:.9rem;color:var(--text-dim);font-style:italic;margin-bottom:.5rem}.count-error{color:var(--danger);font-weight:600}.save-error{font-size:.82rem;color:var(--danger);font-style:italic;max-width:280px;text-align:right}@media(max-width:600px){.home-main{padding:1rem}.deck-list{grid-template-columns:1fr}}.deck-card{position:relative}.deck-card-delete{position:absolute;top:.5rem;right:.5rem;width:2rem;height:2rem;border-radius:50%;background:#0009;border:1px solid var(--border);color:var(--text-muted);cursor:pointer;font-size:.85rem;display:flex;align-items:center;justify-content:center;transition:all .2s;opacity:0}.deck-card:hover .deck-card-delete{opacity:1}.deck-card-delete:hover{background:var(--danger);color:#fff;border-color:var(--danger)}
