:root {
    --er-bg: #06060e;
    --er-card: #0e0e1a;
    --er-elevated: #14142a;
    --er-violet: #7c3aed;
    --er-violet-glow: rgba(124, 58, 237, 0.4);
    --er-gold: #d4a853;
    --er-gold-glow: rgba(212, 168, 83, 0.3);
    --er-text: #fff;
    --er-text2: #9ca3af;
    --er-text3: #6b7280;
    --er-danger: #ef4444;
}

* { margin:0; padding:0; box-sizing:border-box; -webkit-tap-highlight-color:transparent; }
html,body { height:100%; overflow:hidden; }

body {
    font-family:'Poppins',sans-serif;
    background: var(--er-bg);
    color: var(--er-text);
    display:flex; flex-direction:column;
}

.er-animate-in { animation: erSlideUp 0.6s cubic-bezier(0.16, 1, 0.3, 1) forwards; }
@keyframes erSlideUp { from { opacity:0; transform:translateY(30px); } to { opacity:1; transform:translateY(0); } }

/* Loading */
.er-loading { position:fixed; inset:0; background:var(--er-bg); display:flex; flex-direction:column; justify-content:center; align-items:center; z-index:1000; transition:opacity .6s; }
.er-loading img { width:80px; height:80px; border-radius:20px; border:2px solid var(--er-violet); box-shadow:0 0 30px var(--er-violet-glow); animation:erPulse 2s infinite; }
.er-loading-text { margin-top:16px; font-size:.7rem; color:var(--er-text2); letter-spacing:4px; text-transform:uppercase; font-family:'Playfair Display',serif; }
@keyframes erPulse { 0%,100%{transform:scale(1);box-shadow:0 0 20px var(--er-violet-glow)} 50%{transform:scale(1.05);box-shadow:0 0 40px var(--er-violet-glow)} }

/* Header */
.er-header { position:fixed; top:0; left:0; right:0; z-index:100; padding:calc(56px + var(--tg-safe-area-inset-top, env(safe-area-inset-top, 0px))) 16px 12px; background:rgba(6,6,14,.9); backdrop-filter:blur(12px); border-bottom:1px solid rgba(124,58,237,.15); display:flex; align-items:center; gap:12px; }
.er-back { background:none; border:none; color:var(--er-text); font-size:1.2rem; cursor:pointer; padding:4px; }
.er-header-title { font-family:'Playfair Display',serif; font-size:1rem; font-weight:700; background:linear-gradient(135deg,var(--er-violet),var(--er-gold)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; }
.er-sparks-badge { margin-left:auto; background:linear-gradient(135deg,rgba(124,58,237,.2),rgba(212,168,83,.1)); padding:6px 14px; border-radius:20px; border:1px solid rgba(124,58,237,.3); font-size:.8rem; font-weight:600; color:var(--er-gold); }

/* Main */
.er-main { flex:1; overflow-y:auto; overflow-x:hidden; padding:calc(110px + var(--tg-safe-area-inset-top, env(safe-area-inset-top, 0px))) 14px 80px; display:flex; flex-direction:column; gap:16px; max-width:500px; margin:0 auto; width:100%; }

/* Section Headers */
.er-section-title { font-family:'Playfair Display',serif; font-size:.75rem; font-weight:600; color:var(--er-text2); text-transform:uppercase; letter-spacing:2px; margin-bottom:4px; }

/* Eclipse Grid */
.er-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:10px; }
.er-card { position:relative; border-radius:14px; overflow:hidden; background:var(--er-card); border:2px solid transparent; cursor:pointer; transition:all .3s; aspect-ratio:3/4; }
.er-card:hover { transform:translateY(-2px); box-shadow:0 8px 24px rgba(0,0,0,.4); }
.er-card.selected { border-color:var(--er-violet); box-shadow:0 0 20px var(--er-violet-glow); }
.er-card img { width:100%; height:100%; object-fit:cover; object-position:top center; }
.er-card-overlay { position:absolute; bottom:0; left:0; right:0; padding:6px 8px; background:linear-gradient(to top,rgba(0,0,0,.95) 60%,transparent); }
.er-card-name { font-size:.6rem; font-weight:600; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.er-card-anime { font-size:.5rem; color:var(--er-text3); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.er-card-check { position:absolute; top:6px; right:6px; width:22px; height:22px; border-radius:50%; background:var(--er-violet); display:none; align-items:center; justify-content:center; font-size:.7rem; box-shadow:0 0 10px var(--er-violet-glow); }
.er-card.selected .er-card-check { display:flex; }
.er-card-role { position:absolute; top:6px; left:6px; font-size:.5rem; background:rgba(0,0,0,.7); padding:2px 6px; border-radius:8px; color:var(--er-gold); }
.er-card-count { position:absolute; top:6px; right:6px; font-size:.5rem; font-weight:700; background:rgba(212,168,83,.2); border:1px solid var(--er-gold); padding:2px 6px; border-radius:8px; color:var(--er-gold); }
.er-card.selected .er-card-count { display:none; }

/* Empty State */
.er-empty { text-align:center; padding:40px 20px; color:var(--er-text3); }
.er-empty-icon { font-size:3rem; margin-bottom:12px; }
.er-empty-text { font-size:.85rem; }

/* Search Section */
.er-search-section { background:var(--er-card); border-radius:16px; padding:16px; border:1px solid rgba(124,58,237,.1); }
.er-search-box { display:flex; gap:8px; margin-bottom:12px; }
.er-search-input { flex:1; background:var(--er-elevated); border:1px solid rgba(255,255,255,.08); border-radius:12px; padding:10px 14px; color:var(--er-text); font-size:.85rem; outline:none; font-family:'Poppins',sans-serif; transition:border-color .3s; }
.er-search-input:focus { border-color:var(--er-violet); }
.er-search-input::placeholder { color:var(--er-text3); }

/* Target Results */
.er-results { display:flex; flex-direction:column; gap:8px; max-height:300px; overflow-y:auto; }
.er-result-item { display:flex; align-items:center; gap:10px; padding:8px; background:var(--er-elevated); border-radius:10px; cursor:pointer; border:2px solid transparent; transition:all .2s; }
.er-result-item:hover { border-color:rgba(124,58,237,.3); }
.er-result-item.selected { border-color:var(--er-gold); background:rgba(212,168,83,.08); }
.er-result-img { width:44px; height:44px; border-radius:8px; object-fit:cover; object-position:top; }
.er-result-info { flex:1; min-width:0; }
.er-result-name { font-size:.8rem; font-weight:600; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.er-result-meta { font-size:.65rem; color:var(--er-text3); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.er-result-role { font-size:.6rem; color:var(--er-gold); background:rgba(212,168,83,.15); padding:2px 8px; border-radius:8px; }
.er-results-empty { text-align:center; padding:20px; color:var(--er-text3); font-size:.8rem; }

/* History Modal & Button */
.er-history-list-vertical { display:flex; flex-direction:column; gap:8px; max-height:60vh; overflow-y:auto; padding-right:4px; }
.er-history-item { display:flex; align-items:center; justify-content:space-between; gap:8px; background:var(--er-elevated); padding:10px 12px; border-radius:12px; border:1px solid rgba(255,255,255,.05); text-align:left; }
.er-history-img { width:36px; height:36px; border-radius:8px; object-fit:cover; border:1px solid var(--er-violet); }
.er-history-info { display:flex; flex-direction:column; flex:1; min-width:0; }
.er-history-title { font-size:.65rem; color:var(--er-text2); }
.er-history-name { font-size:.75rem; font-weight:600; color:var(--er-gold); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.er-history-arrow { color:var(--er-text3); font-size:1rem; margin:0 8px; flex-shrink:0; }

.er-history-btn { background:rgba(212,168,83,.15); border:1px solid var(--er-gold); color:var(--er-gold); border-radius:8px; padding:6px 12px; font-size:.7rem; font-weight:600; cursor:pointer; flex-shrink:0; white-space:nowrap; margin-left:auto; font-family:'Poppins',sans-serif; transition:all .2s; }
.er-history-btn:hover { background:rgba(212,168,83,.25); }

/* Rewind Button */
.er-rewind-bar { position:fixed; bottom:0; left:0; right:0; padding:12px 16px; background:rgba(6,6,14,.95); backdrop-filter:blur(12px); border-top:1px solid rgba(124,58,237,.15); z-index:100; display:flex; align-items:center; gap:12px; }
.er-preview-row { display:flex; align-items:center; gap:6px; flex:1; min-width:0; }
.er-preview-thumb { width:36px; height:36px; border-radius:8px; object-fit:cover; border:1px solid var(--er-violet); }
.er-preview-arrow { color:var(--er-gold); font-size:1rem; }
.er-preview-thumb.target { border-color:var(--er-gold); }
.er-rewind-btn { background:linear-gradient(135deg,var(--er-violet),#9333ea); border:none; border-radius:12px; padding:12px 20px; color:#fff; font-weight:700; font-size:.85rem; cursor:pointer; transition:all .3s; white-space:nowrap; font-family:'Poppins',sans-serif; }
.er-rewind-btn:disabled { background:#333; color:#666; cursor:not-allowed; }
.er-rewind-btn:not(:disabled):hover { transform:scale(1.03); box-shadow:0 4px 20px var(--er-violet-glow); }

/* Cost Badge */
.er-cost { font-size:.7rem; color:var(--er-gold); text-align:center; }

/* Success Modal */
.er-modal-overlay { position:fixed; inset:0; background:rgba(0,0,0,.85); z-index:2000; display:none; align-items:center; justify-content:center; padding:20px; backdrop-filter:blur(8px); }
.er-modal-overlay.active { display:flex; }
.er-modal { background:linear-gradient(180deg,#14142a,#0a0a16); border-radius:24px; padding:28px 24px; max-width:380px; width:100%; text-align:center; border:1px solid rgba(124,58,237,.2); box-shadow:0 20px 60px rgba(0,0,0,.6); animation:erModalIn .4s ease; }
@keyframes erModalIn { from{opacity:0;transform:scale(.9) translateY(20px)} to{opacity:1;transform:scale(1) translateY(0)} }
.er-modal h2 { font-family:'Playfair Display',serif; font-size:1.3rem; margin-bottom:16px; background:linear-gradient(135deg,var(--er-violet),var(--er-gold)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; }
.er-modal-img { width:160px; height:200px; border-radius:16px; object-fit:cover; object-position:top; margin:0 auto 12px; border:2px solid var(--er-violet); box-shadow:0 0 30px var(--er-violet-glow); display:block; }
.er-modal-name { font-size:1.1rem; font-weight:700; margin-bottom:4px; }
.er-modal-anime { font-size:.75rem; color:var(--er-text2); margin-bottom:4px; }
.er-modal-role { font-size:.7rem; color:var(--er-gold); margin-bottom:16px; }
.er-modal-close { background:linear-gradient(135deg,var(--er-violet),#9333ea); border:none; border-radius:12px; padding:12px 40px; color:#fff; font-weight:700; font-size:.9rem; cursor:pointer; font-family:'Poppins',sans-serif; transition:transform .2s; }
.er-modal-close:hover { transform:scale(1.05); }

/* Info Banner */
.er-info { background:linear-gradient(135deg,rgba(124,58,237,.1),rgba(212,168,83,.05)); border:1px solid rgba(124,58,237,.2); border-radius:14px; padding:14px 16px; display:flex; align-items:flex-start; gap:10px; }
.er-info-icon { font-size:1.4rem; }
.er-info-text { font-size:.75rem; color:var(--er-text2); line-height:1.5; }
.er-info-text b { color:var(--er-gold); }

/* Toast */
.er-toast { position:fixed; bottom:90px; left:50%; transform:translateX(-50%); background:rgba(0,0,0,.9); color:#fff; padding:10px 24px; border-radius:20px; font-size:.8rem; z-index:9999; opacity:0; transition:opacity .3s; pointer-events:none; border:1px solid rgba(124,58,237,.3); }

/* Bottom Nav */
.bottom-nav { position:fixed; bottom:0; left:0; right:0; display:flex; justify-content:space-around; padding:8px 0 calc(8px + env(safe-area-inset-bottom)); background:rgba(10,10,18,.95); backdrop-filter:blur(10px); border-top:1px solid rgba(255,255,255,.05); z-index:50; }
.nav-item { display:flex; flex-direction:column; align-items:center; gap:2px; cursor:pointer; padding:4px 12px; opacity:.5; transition:opacity .2s; text-decoration:none; color:var(--er-text); }
.nav-item.active { opacity:1; }
.nav-icon { font-size:1.2rem; }
.nav-label { font-size:.55rem; font-weight:500; }

/* Scrollbar */
::-webkit-scrollbar { width:3px; }
::-webkit-scrollbar-track { background:transparent; }
::-webkit-scrollbar-thumb { background:rgba(124,58,237,.3); border-radius:3px; }
