:root{--bg: #0f0f1a;--surface: #1a1a2e;--surface-alt: #16213e;--border: #2a2a4a;--text: #e0e0e0;--text-muted: #8888aa;--color-green: #4caf50;--color-yellow: #ffc107;--color-red: #f44336;--accent: #7c4dff}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:var(--bg);color:var(--text);line-height:1.6}.home,.deck-view{max-width:1100px;margin:0 auto;padding:2rem 1.5rem}.home{text-align:center;padding-top:6rem}.home h1{font-size:2.5rem;margin-bottom:.5rem}.subtitle{color:var(--text-muted);margin-bottom:2rem}.home code{background:var(--surface);padding:.2em .5em;border-radius:4px;font-size:.9em}.home a{color:var(--accent)}.deck-header{margin-bottom:2rem}.deck-header h1{font-size:2rem;margin-bottom:.5rem}.deck-meta{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center;color:var(--text-muted);font-size:.9rem}.badge{background:var(--accent);color:#fff;padding:.15em .6em;border-radius:4px;font-size:.8rem;text-transform:capitalize;font-weight:600}.section{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:1.5rem;margin-bottom:1.5rem}.section h2{font-size:1.1rem;margin-bottom:1rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.score-display{display:flex;flex-direction:column;gap:.5rem}.score-number{font-size:3rem;font-weight:700;line-height:1}.score-bar-track{width:100%;height:8px;background:var(--border);border-radius:4px;overflow:hidden}.score-bar-fill{height:100%;border-radius:4px;transition:width .5s ease}.score-detail{font-size:.85rem;color:var(--text-muted)}.cast-table{width:100%;border-collapse:collapse;font-size:.9rem}.cast-table th,.cast-table td{padding:.5rem .75rem;text-align:left;border-bottom:1px solid var(--border)}.cast-table thead th{color:var(--text-muted);font-weight:600;font-size:.8rem;text-transform:uppercase;letter-spacing:.05em}.cast-table tbody tr:nth-child(2n){background:var(--surface-alt)}.num{text-align:right}.spell-list{display:flex;flex-wrap:wrap;gap:.35rem}.spell-chip{background:var(--surface-alt);padding:.15em .5em;border-radius:3px;font-size:.8rem;white-space:nowrap}.spell-chip small{color:var(--text-muted)}.score-details{font-size:.8rem}.score-details summary{color:var(--text-muted);cursor:pointer;list-style:none;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em}.score-details summary::-webkit-details-marker{display:none}.score-details summary:after{content:" ▼";font-size:.6rem}.score-details[open] summary:after{content:" ▲"}.score-details .score-detail{display:block;margin-top:.4rem}.cast-details>summary{cursor:pointer;list-style:none;margin-bottom:1rem}.cast-details>summary::-webkit-details-marker{display:none}.cast-details>summary .inline-h2{display:inline;font-size:1.1rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.cast-details>summary:after{content:" ▼";color:var(--text-muted);font-size:.7rem;margin-left:.35rem}.cast-details[open]>summary:after{content:" ▲"}.decklist-section{display:flex;align-items:center;justify-content:center;gap:.75rem;background:transparent;border:none;padding:0}.decklist-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.copy-decklist-btn{background:var(--surface);color:var(--text-muted);border:1px solid var(--border);border-radius:6px;padding:.5rem 1rem;font:inherit;font-size:.85rem;cursor:pointer;transition:color .15s,border-color .15s}.copy-decklist-btn:hover{color:var(--text);border-color:var(--text-muted)}.copy-decklist-btn-error{color:var(--color-red);border-color:var(--color-red)}.curve-section{overflow:visible}.curve-layout{display:flex;gap:2rem;align-items:flex-start}.curve-main{flex:1;min-width:0;overflow-x:auto}.curve-main h2,.curve-sidebar h2{font-size:1.1rem;margin-bottom:1rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.curve-sidebar{flex:0 0 200px}.mana-curve{position:relative}.mana-curve-columns{display:flex;align-items:flex-end;gap:4px;padding-bottom:.5rem}.mana-curve-column{display:flex;flex-direction:column;align-items:center;min-width:68px}.mana-curve-stack{position:relative;width:68px}.mana-curve-card{position:absolute;left:0;width:68px;cursor:pointer;transition:transform .15s ease;border-radius:4px;overflow:hidden}.mana-curve-card:hover{transform:scale(1.08);box-shadow:0 4px 12px #0009}.mana-curve-card img{display:block;width:68px;height:auto;border-radius:4px}.mana-curve-label{display:flex;flex-direction:column;align-items:center;margin-top:.35rem}.mana-curve-count{font-size:.75rem;color:var(--text-muted)}.mana-curve-cmc{font-size:.85rem;font-weight:600;color:var(--text)}.card-preview-popup{position:fixed;z-index:9999;pointer-events:none;filter:drop-shadow(0 8px 24px rgba(0,0,0,.7))}.card-preview-popup img{display:block;width:280px;height:auto;border-radius:12px}.card-preview-stats{padding:.4rem .6rem;background:var(--surface);border-radius:0 0 8px 8px}.land-stat{font-size:.78rem;color:var(--text-secondary);line-height:1.4}.dfc-stack{position:relative;padding-top:10px;padding-right:10px;margin-top:-10px;margin-right:-10px}.dfc-stack .dfc-back{position:absolute;top:0;right:0;width:calc(100% - 10px);height:auto;z-index:0;border-radius:inherit}.dfc-stack .dfc-front{position:relative;display:block;width:100%;height:auto;z-index:1;border-radius:inherit}.dfc-stack.dfc-back-on-top .dfc-back{z-index:2}.card-preview-popup .dfc-stack{width:280px}.color-histogram{display:flex;flex-direction:column;gap:.5rem}.color-histogram-bar-wrapper{display:flex;align-items:center;gap:.5rem}.color-histogram-count{font-size:.8rem;color:var(--text-muted);width:24px;text-align:right;flex-shrink:0}.color-histogram-track{flex:1;height:20px;background:var(--surface-alt);border-radius:3px;overflow:hidden}.color-histogram-fill{height:100%;border-radius:3px;transition:width .4s ease}.color-histogram-label{font-size:.75rem;font-weight:600;width:40px;flex-shrink:0}.color-histogram-sources{font-size:.75rem;color:var(--text-muted);white-space:nowrap}.color-histogram-delta{margin-left:.25rem;font-weight:600;font-size:.7rem}.color-histogram-delta.positive{color:var(--color-green)}.color-histogram-delta.negative{color:var(--color-red)}.land-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:.75rem;position:relative}.land-grid-card{position:relative;cursor:pointer;transition:transform .15s ease;border-radius:8px;overflow:hidden}.land-grid-card:hover{transform:scale(1.05);box-shadow:0 4px 16px #00000080}.land-grid-card img{display:block;width:100%;height:auto;border-radius:8px}.land-grid-info{display:flex;justify-content:space-between;padding:.25rem .25rem 0;font-size:.75rem}.land-grid-count{font-weight:600;color:var(--text)}.land-grid-price{color:var(--text-muted)}.loading-text{color:var(--text-muted);text-align:center;font-style:italic}@media(max-width:768px){.curve-layout{flex-direction:column}.curve-sidebar{flex:none;width:100%}.land-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}}@media(max-width:600px){.home,.deck-view{padding:1rem}.score-number{font-size:2rem}.cast-table{font-size:.8rem}.cast-table th,.cast-table td{padding:.35rem .5rem}.mana-curve-column{min-width:52px}.mana-curve-card,.mana-curve-card img,.mana-curve-stack{width:52px}.card-preview-popup img,.card-preview-popup .dfc-stack{width:200px}}.deck-input-page{max-width:1100px;margin:0 auto;padding:2rem 1.5rem}.deck-input-header{text-align:center;margin-bottom:2rem}.deck-input-header h1{font-size:2.5rem;margin-bottom:.5rem}.deck-input-layout{display:flex;flex-direction:column;gap:1.5rem;transition:all .3s ease}.deck-input-layout.has-cards{flex-direction:row;align-items:flex-start}.deck-input-left{flex:1;min-width:0}.deck-input-right{flex:0 0 320px;display:flex;flex-direction:column;gap:.75rem}.deck-input-box{position:relative}.deck-textarea{width:100%;min-height:200px;background:var(--surface);color:var(--text);border:2px solid var(--border);border-radius:8px;padding:1rem;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:.85rem;line-height:1.6;resize:vertical;outline:none;transition:border-color .2s}.deck-textarea:focus{border-color:var(--accent)}.deck-textarea::placeholder{color:var(--text-muted);opacity:.6}.import-banner{position:absolute;bottom:0;left:0;right:0;padding:.5rem 1rem;border-radius:0 0 8px 8px;font-size:.8rem;font-weight:600}.import-banner.importing{background:#7c4dff26;color:var(--accent)}.import-banner.error{background:#f4433626;color:var(--color-red)}.resolve-status{display:flex;align-items:center;gap:.5rem;margin-top:.5rem;font-size:.8rem;color:var(--text-muted)}.resolving-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);animation:pulse 1s ease infinite}@keyframes pulse{0%,to{opacity:.3}50%{opacity:1}}.unresolved-hint{color:var(--color-yellow);cursor:help;text-decoration:underline dotted}.stats-card{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:.75rem 1rem}.stats-row{display:flex;justify-content:space-between;align-items:center;padding:.2rem 0}.stats-label{color:var(--text-muted);font-size:.8rem}.stats-value{font-weight:600;font-size:.9rem}.stats-section-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:.5rem;display:flex;align-items:center;gap:.5rem}.budget-text-wrap{display:flex;align-items:center;font-size:.9rem;color:var(--text);white-space:nowrap}.budget-text-input{width:4.5rem;background:transparent;border:none;border-bottom:1px solid var(--border);color:var(--text);font-size:.9rem;font-family:inherit;text-align:left;padding:0 .1rem;outline:none}.budget-text-input:focus{border-bottom-color:var(--accent)}.budget-panel{display:flex;flex-direction:column;gap:.6rem}.budget-row{display:flex;justify-content:space-between;align-items:center;gap:.75rem}.budget-row-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.budget-more{margin-top:.25rem;border-top:1px solid var(--border);padding-top:.6rem;display:flex;flex-direction:column;gap:.6rem}.budget-more>summary{font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);cursor:pointer;list-style:none;margin-bottom:.4rem}.budget-more>summary::-webkit-details-marker{display:none}.budget-more>summary:after{content:" ▼";font-size:.6rem}.budget-more[open]>summary:after{content:" ▲"}.commander-single{display:flex;align-items:center;gap:.75rem;font-weight:600;font-size:.9rem}.commander-thumb{width:48px;height:auto;border-radius:4px}.commander-options{display:flex;flex-direction:column;gap:.35rem;max-height:240px;overflow-y:auto}.commander-option{display:flex;align-items:center;gap:.5rem;background:var(--surface-alt);border:2px solid transparent;border-radius:6px;padding:.35rem .5rem;cursor:pointer;color:var(--text);font-size:.8rem;text-align:left;transition:border-color .15s}.commander-option:hover{border-color:var(--text-muted)}.commander-option.selected{border-color:var(--accent);background:#7c4dff1a}.commander-thumb-sm{width:36px;height:auto;border-radius:3px}.commander-change-btn{background:none;border:none;color:var(--text-muted);font-size:.75rem;cursor:pointer;padding:.25rem 0;margin-top:.35rem;text-decoration:underline;text-underline-offset:2px}.commander-change-btn:hover{color:var(--text)}.format-select{background:var(--surface-alt);color:var(--text);border:1px solid var(--border);border-radius:4px;padding:.3rem .5rem;font-size:.85rem;outline:none}.format-select:focus{border-color:var(--accent)}.land-count-value{font-weight:600;font-size:.9rem;text-align:right}.mode-toggle{display:flex;gap:0;border-radius:6px;overflow:hidden;border:1px solid var(--border)}.mode-btn{flex:1;padding:.4rem .5rem;background:transparent;border:none;color:var(--text-secondary);font-size:.8rem;cursor:pointer;transition:background .15s,color .15s}.mode-btn.active{background:var(--accent);color:#fff;font-weight:600}.mode-btn:not(.active):hover{background:var(--bg-secondary)}.optimize-error{display:flex;align-items:flex-start;gap:.5rem;padding:.65rem .75rem;background:#f443361f;border:1px solid var(--color-red);border-radius:8px;color:var(--color-red);font-size:.85rem;line-height:1.4}.optimize-error span{flex:1}.optimize-error-dismiss{background:none;border:none;color:var(--color-red);font-size:1.1rem;cursor:pointer;padding:0 .25rem;line-height:1;opacity:.7}.optimize-error-dismiss:hover{opacity:1}.optimize-btn{width:100%;padding:.85rem;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:700;cursor:pointer;transition:opacity .15s,transform .1s;letter-spacing:.02em}.optimize-btn:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.optimize-btn:active:not(:disabled){transform:translateY(0)}.optimize-btn:disabled{opacity:.4;cursor:not-allowed}@media(max-width:768px){.deck-input-layout.has-cards{flex-direction:column}.deck-input-right{flex:none;width:100%}}@media(max-width:600px){.deck-input-page{padding:1rem}.deck-input-header h1{font-size:1.8rem}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:3rem 2.5rem;max-width:400px;width:100%;text-align:center}.login-card h1{font-size:2rem;margin-bottom:.5rem}.login-subtitle{color:var(--text-muted);margin-bottom:2rem}.login-info{color:var(--text-muted);font-size:.9rem;margin-bottom:1.5rem;line-height:1.5}.login-error{color:var(--color-red);font-size:.9rem;margin-bottom:1rem;line-height:1.5}.login-btn{display:inline-block;padding:.75rem 2rem;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;text-decoration:none;cursor:pointer;transition:opacity .15s}.login-btn:hover{opacity:.85}.login-btn-secondary{background:transparent;border:1px solid var(--border);color:var(--text-muted);margin-top:.75rem}.login-btn-secondary:hover{border-color:var(--text-muted)}.app-header{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:.75rem 1.5rem}.app-header-right{display:flex;align-items:center;gap:1rem}.app-header-user{display:flex;align-items:center;gap:.5rem}.app-header-avatar{width:28px;height:28px;border-radius:50%}.app-header-name{color:var(--text-muted);font-size:.85rem}.app-header-logout{color:var(--text-muted);font-size:.8rem;text-decoration:none;margin-left:.5rem;opacity:.7}.app-header-logout:hover{opacity:1}.app-header-home{color:var(--text);font-size:.95rem;font-weight:600;text-decoration:none;letter-spacing:-.01em;opacity:.85}.app-header-home:hover{opacity:1}.badge-upgrade{background:#2d7a3a}.upgrade-diff{display:flex;flex-direction:column;gap:1.25rem}.upgrade-cost-banner{background:var(--surface-alt);border:1px solid var(--border);border-radius:8px;padding:.75rem 1rem;font-size:1.1rem;text-align:center;color:var(--text-secondary)}.upgrade-cost-banner strong{color:var(--accent);font-size:1.2rem}.diff-section{border-radius:8px;padding:.75rem 1rem;border:1px solid var(--border)}.diff-section-title{margin:0 0 .5rem;font-size:.9rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.diff-add{border-color:#2d7a3a}.diff-add .diff-section-title{color:#4caf50}.diff-remove{border-color:#7a2d2d}.diff-remove .diff-section-title{color:#ef5350}.diff-keep .diff-section-title{color:var(--text-muted)}.diff-entries{display:flex;flex-direction:column;gap:.25rem}.diff-entry{display:flex;align-items:center;gap:.5rem;padding:.25rem 0;cursor:default}.diff-count{font-weight:600;min-width:2rem;text-align:right;color:var(--text-secondary)}.diff-name{flex:1}.diff-price{color:var(--text-muted);font-size:.85rem}.feedback-trigger-btn{margin-left:.5rem;background:none;border:1px solid var(--border);color:var(--text-muted);font-size:.8rem;padding:.3rem .75rem;border-radius:6px;cursor:pointer;transition:border-color .15s,color .15s}.feedback-trigger-btn:hover{border-color:var(--text-muted);color:var(--text)}.feedback-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:10000;padding:1rem}.feedback-modal{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:2rem;max-width:480px;width:100%}.feedback-modal h2{font-size:1.2rem;margin-bottom:1rem}.feedback-type-toggle{display:flex;gap:2px;background:var(--surface-alt);border-radius:6px;padding:3px;margin-bottom:1rem}.feedback-type-btn{flex:1;background:none;border:none;color:var(--text-muted);font-size:.85rem;font-weight:600;padding:.5rem;border-radius:4px;cursor:pointer;transition:background .15s,color .15s}.feedback-type-btn:hover{color:var(--text)}.feedback-type-btn.active{background:var(--accent);color:#fff}.feedback-label{display:block;font-size:.8rem;color:var(--text-muted);margin-bottom:.75rem}.feedback-input{display:block;width:100%;margin-top:.35rem;background:var(--surface-alt);color:var(--text);border:1px solid var(--border);border-radius:6px;padding:.5rem .75rem;font-size:.9rem;font-family:inherit;outline:none;transition:border-color .15s}.feedback-input:focus{border-color:var(--accent)}.feedback-textarea{display:block;width:100%;margin-top:.35rem;background:var(--surface-alt);color:var(--text);border:1px solid var(--border);border-radius:6px;padding:.5rem .75rem;font-size:.85rem;font-family:inherit;resize:vertical;outline:none;transition:border-color .15s}.feedback-textarea:focus{border-color:var(--accent)}.feedback-error{color:var(--color-red);font-size:.85rem;margin-bottom:.75rem}.feedback-success{color:var(--color-green);font-size:.9rem;margin-bottom:1.5rem;line-height:1.5}.feedback-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:1rem}.feedback-cancel-btn{background:none;border:1px solid var(--border);color:var(--text-muted);padding:.5rem 1.25rem;border-radius:6px;font-size:.9rem;cursor:pointer;transition:border-color .15s}.feedback-cancel-btn:hover:not(:disabled){border-color:var(--text-muted)}.feedback-submit-btn{background:var(--accent);color:#fff;border:none;padding:.5rem 1.25rem;border-radius:6px;font-size:.9rem;font-weight:600;cursor:pointer;transition:opacity .15s}.feedback-submit-btn:hover:not(:disabled){opacity:.85}.feedback-submit-btn:disabled{opacity:.4;cursor:not-allowed}.error-boundary-fallback{text-align:center;margin-top:4rem;padding:2rem 1.5rem;max-width:600px;margin-left:auto;margin-right:auto}.error-boundary-fallback h1{font-size:2rem;margin-bottom:.5rem}.error-boundary-fallback p{color:var(--text-muted);margin-bottom:1rem}.error-boundary-details{margin-bottom:1rem;text-align:left}.error-boundary-details summary{cursor:pointer;color:var(--text-muted);font-size:.9rem}.error-boundary-details pre{margin-top:.5rem;padding:.75rem;background:var(--surface);border:1px solid var(--border);border-radius:4px;font-size:.85rem;overflow-x:auto;white-space:pre-wrap;word-break:break-word}.error-boundary-actions{display:flex;gap:.75rem;justify-content:center}.error-boundary-btn{padding:.5rem 1.5rem;font-size:1rem;cursor:pointer;background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:4px;text-decoration:none}.error-boundary-btn:hover{background:var(--surface-alt)}.land-grid-card-new{box-shadow:0 0 0 2px #4caf50;border-radius:8px}.land-grid-card-kept{opacity:.85}.land-badge{position:absolute;top:6px;right:6px;padding:1px 6px;border-radius:4px;font-size:.6rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;pointer-events:none}.land-badge-new{background:#2d7a3a;color:#fff}.land-badge-kept{background:#ffffff26;color:var(--text-muted);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.land-grid-card-removed{box-shadow:0 0 0 2px #c62828;border-radius:8px;opacity:.85}.land-badge-removed{background:#c62828;color:#fff}
