@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@400;700;900&family=Crimson+Text:ital,wght@0,400;0,600;1,400&display=swap');

:root {
  --gold:#c9a84c; --gold-light:#f0d080; --gold-dark:#7a5c1e;
  --bg:#0a0a0f; --bg2:#12121a; --bg3:#1c1c28; --bg4:#242436;
  --text:#e8e0cc; --muted:#8a8070; --accent:#4a9eff; --green:#5ac878;
  --red:#e05555; --purple:#9b72cf;
  --border:rgba(201,168,76,0.18); --border2:rgba(201,168,76,0.08);
  --w:rgba(248,231,185,0.9); --u:rgba(180,214,242,0.9);
  --b:rgba(166,159,157,0.9); --r:rgba(235,159,130,0.9); --g:rgba(163,211,164,0.9);
  --c:rgba(200,193,180,0.7);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);font-family:'Crimson Text',Georgia,serif;font-size:17px;min-height:100vh;line-height:1.5}

/* ── TYPOGRAPHY ── */
h1,h2,h3{font-family:'Cinzel',serif;font-weight:700;letter-spacing:.03em}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}

/* ── NAV ── */
nav{position:sticky;top:0;z-index:100;background:rgba(10,10,15,.95);border-bottom:1px solid var(--border);backdrop-filter:blur(10px);padding:.75rem 2rem;display:flex;align-items:center;gap:1.5rem}
.nav-logo{font-family:'Cinzel',serif;font-size:1rem;font-weight:900;color:var(--gold-light);letter-spacing:.06em;text-decoration:none}
.nav-logo:hover{text-decoration:none;color:var(--gold-light);filter:brightness(1.2)}
.nav-sub{font-size:.78rem;color:var(--muted);font-style:italic;margin-left:auto}
.nav-back{font-family:'Cinzel',serif;font-size:.72rem;letter-spacing:.1em;color:var(--muted);border:1px solid var(--border);padding:.3rem .8rem;transition:all .15s}
.nav-back:hover{color:var(--gold-light);border-color:var(--gold);text-decoration:none}

/* ── BUTTONS ── */
.btn{font-family:'Cinzel',serif;font-size:.8rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;border:none;padding:.65rem 1.6rem;cursor:pointer;transition:all .2s;display:inline-block}
.btn-gold{background:linear-gradient(135deg,var(--gold-dark),var(--gold));color:#0a0a0f;clip-path:polygon(8px 0%,100% 0%,calc(100% - 8px) 100%,0% 100%)}
.btn-gold:hover{filter:brightness(1.2);transform:translateY(-1px)}
.btn-ghost{background:transparent;border:1px solid var(--border);color:var(--muted)}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold-light)}
.btn:disabled{opacity:.4;cursor:not-allowed;transform:none!important;filter:none!important}

/* ── HOME PAGE ── */
.home-header{text-align:center;padding:3rem 2rem 2rem;position:relative;border-bottom:1px solid var(--border)}
.home-header::before{content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);width:600px;height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent)}
.home-header h1{font-size:clamp(1.8rem,4vw,3rem);color:var(--gold-light);text-shadow:0 0 60px rgba(201,168,76,.2)}
.home-header p{color:var(--muted);margin-top:.5rem;font-style:italic;font-size:1rem}

.search-bar{display:flex;justify-content:center;gap:.6rem;padding:1.2rem 2rem;border-bottom:1px solid var(--border);flex-wrap:wrap}
.search-bar input{background:var(--bg2);border:1px solid var(--border);color:var(--text);font-family:'Crimson Text',serif;font-size:.95rem;padding:.5rem 1rem;width:280px;outline:none;transition:border-color .15s}
.search-bar input:focus{border-color:var(--gold)}
.search-bar input::placeholder{color:var(--muted)}
.filter-pills{display:flex;gap:.4rem;flex-wrap:wrap;justify-content:center}
.fpill{font-family:'Cinzel',serif;font-size:.65rem;letter-spacing:.08em;text-transform:uppercase;background:transparent;border:1px solid var(--border);color:var(--muted);padding:.28rem .7rem;cursor:pointer;transition:all .15s}
.fpill.on{border-color:var(--gold);color:var(--gold-light);background:rgba(201,168,76,.08)}

.deck-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;padding:1.5rem 2rem;max-width:1400px;margin:0 auto}

.deck-card{background:var(--bg2);border:1px solid var(--border);border-radius:4px;overflow:hidden;cursor:pointer;transition:border-color .2s,transform .2s,box-shadow .2s;display:flex;flex-direction:column}
.deck-card:hover{border-color:var(--gold);transform:translateY(-3px);box-shadow:0 8px 32px rgba(0,0,0,.5)}
.deck-card-img{position:relative;width:100%;aspect-ratio:16/9;background:var(--bg3);overflow:hidden;display:flex;align-items:center;justify-content:center}
.deck-card-img img{width:100%;height:100%;object-fit:cover;object-position:top center}
.deck-card-img .rank-badge{position:absolute;top:8px;left:8px;font-family:'Cinzel',serif;font-size:.65rem;font-weight:700;background:rgba(10,10,15,.85);border:1px solid var(--gold);color:var(--gold-light);padding:.15rem .45rem;border-radius:2px}
.deck-card-img .color-pips{position:absolute;bottom:8px;right:8px;display:flex;gap:3px}
.color-pip{width:16px;height:16px;border-radius:50%;border:1px solid rgba(255,255,255,.3);font-size:9px;display:flex;align-items:center;justify-content:center;font-weight:bold}
.pip-w{background:#f8e7b9;color:#222}
.pip-u{background:#b4d6f2;color:#222}
.pip-b{background:#a69f9d;color:#fff}
.pip-r{background:#eb9f82;color:#222}
.pip-g{background:#a3d3a4;color:#222}
.pip-c{background:#c8c1b4;color:#222}

.deck-card-body{padding:.85rem 1rem;flex:1;display:flex;flex-direction:column;gap:.4rem}
.deck-card-name{font-family:'Cinzel',serif;font-size:.88rem;font-weight:700;color:var(--text);line-height:1.2}
.deck-card-archetype{display:flex;gap:.3rem;flex-wrap:wrap}
.arch-tag{font-family:'Cinzel',serif;font-size:.58rem;letter-spacing:.07em;text-transform:uppercase;padding:.1rem .4rem;border-radius:2px;background:rgba(201,168,76,.1);border:1px solid rgba(201,168,76,.25);color:var(--gold)}
.deck-card-summary{font-size:.82rem;color:var(--muted);line-height:1.4;flex:1}
.deck-card-footer{display:flex;justify-content:space-between;align-items:center;margin-top:.5rem;padding-top:.5rem;border-top:1px solid var(--border2)}
.deck-card-power{font-family:'Cinzel',serif;font-size:.65rem;color:var(--muted);letter-spacing:.05em}
.deck-card-cta{font-family:'Cinzel',serif;font-size:.65rem;letter-spacing:.08em;color:var(--accent)}

/* ── CUSTOM DECK IMPORT ── */
.custom-import-bar{display:flex;justify-content:center;padding:.8rem 2rem;border-bottom:1px solid var(--border);background:rgba(201,168,76,.03)}
.custom-import-btn{font-family:'Cinzel',serif;font-size:.78rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;background:linear-gradient(135deg,var(--gold-dark),var(--gold));color:#0a0a0f;border:none;padding:.6rem 1.6rem;cursor:pointer;clip-path:polygon(8px 0%,100% 0%,calc(100% - 8px) 100%,0% 100%);transition:filter .2s}
.custom-import-btn:hover{filter:brightness(1.15)}

.import-modal{display:none;position:fixed;inset:0;background:rgba(0,0,0,.88);z-index:10000;align-items:center;justify-content:center;padding:1rem}
.import-modal.show{display:flex}
.import-box{background:var(--bg2);border:1px solid var(--gold);border-radius:6px;width:100%;max-width:640px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 60px rgba(0,0,0,.9)}
.import-head{padding:1.2rem 1.4rem;border-bottom:1px solid var(--border)}
.import-head h2{font-family:'Cinzel',serif;font-size:1.1rem;color:var(--gold-light);font-weight:700}
.import-head p{font-size:.84rem;color:var(--muted);margin-top:.3rem;line-height:1.5}
.import-tabs{display:flex;border-bottom:1px solid var(--border)}
.import-tab{font-family:'Cinzel',serif;font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;padding:.7rem 1.4rem;cursor:pointer;color:var(--muted);border-bottom:2px solid transparent;background:none;border-top:none;border-left:none;border-right:none;transition:all .15s;flex:1;text-align:center}
.import-tab.on{color:var(--gold-light);border-bottom-color:var(--gold)}
.import-body{padding:1.2rem 1.4rem;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:.8rem}
.import-label{font-family:'Cinzel',serif;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:.3rem}
.import-input{width:100%;background:var(--bg3);border:1px solid var(--border);color:var(--text);font-family:'Crimson Text',serif;font-size:.95rem;padding:.6rem .9rem;outline:none;transition:border-color .15s;border-radius:2px}
.import-input:focus{border-color:var(--gold)}
.import-textarea{width:100%;height:200px;background:var(--bg3);border:1px solid var(--border);color:var(--text);font-family:monospace;font-size:.8rem;padding:.7rem .9rem;outline:none;transition:border-color .15s;resize:vertical;border-radius:2px;line-height:1.5}
.import-textarea:focus{border-color:var(--gold)}
.import-hint{font-size:.8rem;color:var(--muted);line-height:1.5;font-style:italic}
.import-hint a{color:var(--accent)}
.import-hint code{background:var(--bg3);padding:.1rem .3rem;border-radius:2px;font-size:.75rem;color:var(--text)}
.import-error{background:rgba(224,85,85,.1);border:1px solid rgba(224,85,85,.3);color:#f08080;padding:.6rem .9rem;border-radius:3px;font-size:.85rem;display:none}
.import-actions{padding:1rem 1.4rem;border-top:1px solid var(--border);display:flex;gap:.6rem;justify-content:flex-end}
.import-pane{display:none}.import-pane.on{display:flex;flex-direction:column;gap:.6rem}

/* Deck name input for custom decks */
.import-deck-name{font-family:'Cinzel',serif;font-size:.9rem;color:var(--gold-light)}

/* ── DECK LIST HEADER ── */
.deck-list-header{text-align:center;padding:1.8rem 2rem .4rem}
.deck-list-header h2{font-family:'Cinzel',serif;font-size:clamp(1.1rem,2.5vw,1.6rem);font-weight:700;color:var(--gold-light);letter-spacing:.04em}
.deck-list-header p{font-style:italic;color:var(--muted);font-size:.88rem;margin-top:.35rem}

#homeStatus{text-align:center;padding:2rem;color:var(--muted);font-style:italic;display:none}
.spinner{display:inline-block;width:18px;height:18px;border:2px solid var(--border);border-top-color:var(--gold);border-radius:50%;animation:spin .7s linear infinite;vertical-align:middle;margin-right:.5rem}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── DECK DETAIL PAGE ── */
.deck-hero{position:relative;border-bottom:1px solid var(--border);overflow:hidden;background:var(--bg2)}
.deck-hero-bg{position:absolute;inset:0;background-size:cover;background-position:top center;opacity:.12;filter:blur(8px);transform:scale(1.05)}
.deck-hero-content{position:relative;display:flex;gap:2rem;padding:2rem;max-width:1200px;margin:0 auto;align-items:flex-start;flex-wrap:wrap}
.deck-hero-img{width:200px;flex-shrink:0;border-radius:8px;box-shadow:0 8px 32px rgba(0,0,0,.7);border:1px solid var(--border)}
.deck-hero-img img{width:100%;border-radius:7px;display:block}
.deck-hero-info{flex:1;min-width:240px}
.deck-hero-info h1{font-size:clamp(1.4rem,3vw,2.2rem);color:var(--gold-light);margin-bottom:.4rem}
.deck-hero-meta{display:flex;gap:.6rem;flex-wrap:wrap;margin-bottom:.8rem}
.deck-hero-summary{font-size:1rem;color:var(--text);line-height:1.6;max-width:680px}

/* ── STATS PANELS ── */
.stats-section{max-width:1200px;margin:0 auto;padding:1.5rem 2rem;display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}
@media(max-width:700px){.stats-section{grid-template-columns:1fr}}
.stat-panel{background:var(--bg2);border:1px solid var(--border);border-radius:4px;padding:1.2rem}
.stat-panel h3{font-family:'Cinzel',serif;font-size:.75rem;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid var(--border2)}

/* Mana curve */
.curve-chart{display:flex;align-items:flex-end;gap:6px;height:130px;padding-bottom:0}
.curve-bar-wrap{display:flex;flex-direction:column;align-items:center;justify-content:flex-end;gap:4px;flex:1;height:100%}
.curve-bar{width:100%;background:rgba(155,114,207,.7);border-radius:2px 2px 0 0;transition:height .5s ease;min-height:0;cursor:pointer;position:relative;flex-shrink:0}
.curve-bar:hover{background:var(--purple);opacity:.9}
.curve-bar-count{font-size:.65rem;color:var(--muted);text-align:center}
.curve-bar-cmc{font-family:'Cinzel',serif;font-size:.65rem;color:var(--muted);text-align:center}

/* Color identity */
.color-stats{display:flex;gap:1.2rem;flex-wrap:wrap;justify-content:center}
.color-stat-item{display:flex;flex-direction:column;align-items:center;gap:.3rem;flex:1;min-width:60px}
.color-icon{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.1rem;font-weight:bold;border:2px solid rgba(255,255,255,.15)}
.ci-w{background:radial-gradient(circle,#f8e7b9,#d4b96a);color:#333}
.ci-u{background:radial-gradient(circle,#b4d6f2,#5b9fd4);color:#fff}
.ci-b{background:radial-gradient(circle,#a69f9d,#4a4745);color:#fff}
.ci-r{background:radial-gradient(circle,#eb9f82,#c0522a);color:#fff}
.ci-g{background:radial-gradient(circle,#a3d3a4,#3d8c3f);color:#fff}
.ci-c{background:radial-gradient(circle,#c8c1b4,#8a8276);color:#fff}
.color-pct{font-family:'Cinzel',serif;font-size:1.1rem;font-weight:700;color:var(--text)}
.color-sub{font-size:.68rem;color:var(--muted);text-align:center}
.color-bar-wrap{width:100%;height:4px;background:var(--bg3);border-radius:2px;overflow:hidden}
.color-bar-fill{height:100%;border-radius:2px;transition:width .5s}
.fill-w{background:#d4b96a}.fill-u{background:#5b9fd4}.fill-b{background:#a69f9d}.fill-r{background:#c0522a}.fill-g{background:#3d8c3f}.fill-c{background:#8a8276}

/* Deck type / power badges */
.badge{font-family:'Cinzel',serif;font-size:.62rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:.15rem .55rem;border-radius:2px}
.badge-gold{background:rgba(201,168,76,.15);border:1px solid rgba(201,168,76,.4);color:var(--gold-light)}
.badge-blue{background:rgba(74,158,255,.1);border:1px solid rgba(74,158,255,.3);color:#7bbfff}
.badge-purple{background:rgba(155,114,207,.15);border:1px solid rgba(155,114,207,.4);color:#c49fff}
.badge-green{background:rgba(90,200,120,.1);border:1px solid rgba(90,200,120,.3);color:#7fd49a}
.badge-red{background:rgba(224,85,85,.1);border:1px solid rgba(224,85,85,.3);color:#f08080}

/* Write-up section */
.writeup-section{max-width:1200px;margin:0 auto;padding:0 2rem 1.5rem;display:grid;grid-template-columns:1fr 1fr 1fr;gap:1rem}
@media(max-width:900px){.writeup-section{grid-template-columns:1fr}}
.writeup-card{background:var(--bg2);border:1px solid var(--border);border-radius:4px;padding:1.2rem}
.writeup-card h3{font-family:'Cinzel',serif;font-size:.75rem;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);margin-bottom:.75rem;padding-bottom:.4rem;border-bottom:1px solid var(--border2)}
.writeup-card p{font-size:.9rem;color:var(--text);line-height:1.6}
.writeup-card ul{list-style:none;display:flex;flex-direction:column;gap:.3rem}
.writeup-card ul li{font-size:.88rem;color:var(--text);padding-left:1rem;position:relative;line-height:1.4}
.writeup-card ul li::before{content:'▸';position:absolute;left:0;color:var(--gold)}

/* Deck zone tabs */
.zone-tabs{display:flex;gap:0;border-bottom:1px solid var(--border);max-width:1200px;margin:1.5rem auto 0;padding:0 2rem;overflow-x:auto}
.ztab{font-family:'Cinzel',serif;font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;padding:.5rem 1rem;cursor:pointer;color:var(--muted);border-bottom:2px solid transparent;transition:all .15s;white-space:nowrap;background:none;border-top:none;border-left:none;border-right:none}
.ztab.on{color:var(--gold-light);border-bottom-color:var(--gold)}

/* Proxy builder section */
.proxy-section{max-width:1200px;margin:0 auto;padding:1rem 2rem 3rem}
.proxy-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;margin-bottom:1rem}
.proxy-header h2{font-family:'Cinzel',serif;font-size:1rem;color:var(--gold-light);letter-spacing:.05em}
.pick-bar-deck{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}
.pick-count{font-family:'Cinzel',serif;font-size:.82rem;color:var(--muted)}
.pick-count b{color:var(--green)}
.lang-toggle{font-family:'Cinzel',serif;font-size:.68rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;background:var(--bg3);border:1px solid var(--border);color:var(--text);padding:.32rem .85rem;cursor:pointer;transition:all .2s;border-radius:2px}
.lang-toggle:hover{border-color:var(--gold);color:var(--gold-light)}
.lang-toggle.lang-all{background:rgba(74,158,255,.1);border-color:rgba(74,158,255,.4);color:#7bbfff}

/* Card entries (from existing tool) */
.ce{border:1px solid var(--border);background:var(--bg2);margin-bottom:.4rem;transition:border-color .15s;border-radius:2px}
.ce:hover{border-color:rgba(201,168,76,.3)}
.cs{display:flex;align-items:center;gap:.75rem;padding:.6rem .9rem;cursor:pointer;user-select:none}
.tb{width:4px;height:34px;border-radius:2px;flex-shrink:0}
.tb-ff{background:linear-gradient(180deg,#f0d080,#7c5cbf,#4a9eff)}
.tb-f{background:var(--gold)}.tb-base{background:#222;border:1px solid #333}
.cn{font-family:'Cinzel',serif;font-size:.85rem;font-weight:700;color:var(--text);flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cq{font-size:.75rem;color:var(--muted);margin-left:.25rem}
.pills{display:flex;flex-wrap:wrap;gap:.25rem;flex:2;justify-content:flex-end;min-width:0}
.pill{font-family:'Cinzel',serif;font-size:.6rem;letter-spacing:.06em;padding:.12rem .5rem;border-radius:2px;white-space:nowrap}
.pf{background:rgba(201,168,76,.15);border:1px solid rgba(201,168,76,.5);color:var(--gold-light)}
.ps{background:rgba(74,158,255,.1);border:1px solid rgba(74,158,255,.3);color:#7bbfff}
.pn{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.08);color:var(--muted)}
.chev{color:var(--muted);font-size:.7rem;transition:transform .2s;flex-shrink:0}
.ce.open .chev{transform:rotate(180deg)}
.ce.chosen{border-color:rgba(90,200,120,.4)}.ce.chosen .cn::before{content:'✓ ';color:var(--green)}
.ce.skipped .cn::before{content:'— ';color:var(--muted)}
.panel{display:none;padding:0 .9rem .9rem;border-top:1px solid var(--border)}
.ce.open .panel{display:block}
.pgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.6rem;padding-top:.6rem}
.pc{background:var(--bg3);border:1px solid var(--border);border-radius:3px;overflow:hidden;transition:border-color .15s,transform .15s;cursor:zoom-in;position:relative}
.pc:hover{border-color:var(--gold);transform:translateY(-2px)}
.pc.selected{border-color:var(--green);box-shadow:0 0 0 2px rgba(90,200,120,.5)}
.pc.selected::after{content:'✓';position:absolute;top:5px;right:5px;background:var(--green);color:#06210f;font-family:'Cinzel',serif;font-size:.65rem;font-weight:700;width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;z-index:3}
.piw{position:relative;width:100%;aspect-ratio:63/88;background:var(--bg);display:flex;align-items:center;justify-content:center;overflow:hidden}
.piw img{width:100%;height:100%;object-fit:cover;display:block}
.pil{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:.72rem;font-style:italic}
.fs{position:absolute;inset:0;background:linear-gradient(135deg,transparent 0%,rgba(255,255,255,.05) 30%,rgba(180,120,255,.07) 50%,rgba(100,180,255,.05) 70%,transparent 100%);pointer-events:none}
.pi{padding:.4rem .5rem;border-top:1px solid var(--border)}
.pt{font-family:'Cinzel',serif;font-size:.62rem;font-weight:700;letter-spacing:.07em;color:var(--gold-light);text-transform:uppercase}
.pset{font-size:.7rem;color:var(--muted);margin-top:.1rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ppr{font-family:'Cinzel',serif;font-size:.75rem;color:var(--green);margin-top:.15rem;font-weight:700}
.ppr.np{color:var(--muted);font-weight:400;font-size:.68rem}
.sel-btn{display:block;width:100%;font-family:'Cinzel',serif;font-size:.6rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;border:none;padding:.35rem;cursor:pointer;transition:all .15s;background:rgba(201,168,76,.1);color:var(--gold-light);border-top:1px solid var(--border)}
.sel-btn:hover{background:rgba(201,168,76,.22)}
.sel-btn.is-sel{background:var(--green);color:#06210f}
.skip-btn{display:inline-block;margin-top:.65rem;margin-left:.5rem;font-family:'Cinzel',serif;font-size:.66rem;letter-spacing:.1em;color:var(--muted);background:transparent;border:1px solid var(--border);padding:.22rem .7rem;cursor:pointer;transition:all .15s}
.skip-btn:hover{border-color:var(--muted);color:var(--text)}
.skip-btn.is-skip{border-color:#a55;color:#d88}
.sfl{display:inline-block;margin-top:.65rem;font-family:'Cinzel',serif;font-size:.66rem;letter-spacing:.1em;color:var(--accent);text-decoration:none;border:1px solid rgba(74,158,255,.3);padding:.22rem .7rem;transition:all .15s}
.sfl:hover{background:rgba(74,158,255,.1)}
.npm{color:var(--muted);font-style:italic;font-size:.88rem;padding-top:.4rem}

/* Progress */
.prog-wrap{padding:0 0 .4rem;display:none}
.prog-bar{width:100%;height:3px;background:var(--bg3);border-radius:2px;overflow:hidden}
.prog-fill{height:100%;background:linear-gradient(90deg,var(--gold-dark),var(--gold-light));border-radius:2px;transition:width .3s;width:0%}
#scanStatus{font-style:italic;color:var(--muted);font-size:.85rem;padding:.4rem 0;min-height:1.8rem}

/* Modal */
#modal{display:none;position:fixed;inset:0;background:rgba(0,0,0,.88);z-index:10000;align-items:center;justify-content:center;padding:1rem}
#modal.show{display:flex}
.modal-box{background:var(--bg2);border:1px solid var(--gold);border-radius:6px;max-width:600px;width:100%;max-height:88vh;display:flex;flex-direction:column;box-shadow:0 20px 60px rgba(0,0,0,.9)}
.modal-head{padding:1rem 1.2rem;border-bottom:1px solid var(--border)}
.modal-head h2{font-family:'Cinzel',serif;font-size:1.1rem;color:var(--gold-light)}
.modal-head p{font-size:.82rem;color:var(--muted);margin-top:.25rem;font-style:italic}
.modal-body{padding:1rem 1.2rem;overflow-y:auto}
.modal-body textarea{width:100%;height:260px;background:var(--bg);border:1px solid var(--border);color:var(--text);font-family:monospace;font-size:.78rem;padding:.7rem;border-radius:3px;resize:vertical}
.modal-note{font-size:.78rem;color:var(--muted);margin-bottom:.6rem;line-height:1.5}
.modal-note a{color:var(--accent)}
.modal-actions{padding:1rem 1.2rem;border-top:1px solid var(--border);display:flex;gap:.6rem;flex-wrap:wrap;justify-content:flex-end}
.copied-toast{position:fixed;bottom:30px;left:50%;transform:translateX(-50%);background:var(--green);color:#06210f;font-family:'Cinzel',serif;font-weight:700;padding:.6rem 1.4rem;border-radius:4px;z-index:10001;opacity:0;transition:opacity .3s;pointer-events:none}
.copied-toast.show{opacity:1}

/* Lightbox */
#lb{display:none;position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:9999;align-items:center;justify-content:center;cursor:pointer}
#lb.show{display:flex}
#lb img{max-height:88vh;max-width:92vw;border-radius:8px;box-shadow:0 20px 60px rgba(0,0,0,.9),0 0 0 1px rgba(201,168,76,.3)}

/* Footer */
site-footer{display:block;text-align:center;padding:1.5rem 2rem;color:var(--muted);font-size:.8rem;border-top:1px solid var(--border);font-style:italic}
site-footer a{color:var(--muted)}

/* Responsive */
@media(max-width:600px){
  .deck-grid{grid-template-columns:1fr;padding:1rem}
  .deck-hero-content{flex-direction:column}
  .deck-hero-img{width:140px}
  .stats-section{padding:1rem}
  .writeup-section{grid-template-columns:1fr;padding:0 1rem 1rem}
  .proxy-section{padding:1rem 1rem 2rem}
}
