/* ═══════════════════════════════════════════════════
   SCOUT CLUBS — admin.css
   Painel master /admin: lista de clubes, métricas,
   status banner, revenue panel, modal lock.
   ═══════════════════════════════════════════════════ */
/* ═══ ADMIN PANEL ═══ */
.admin-wrap{max-width:1200px;margin:0 auto;padding:20px}
.admin-login{max-width:400px;margin:80px auto;padding:40px 32px;background:var(--glass);border:1px solid rgba(0,255,135,.15);border-radius:20px;text-align:center}
.admin-login-icon{width:64px;height:64px;border-radius:16px;background:rgba(0,255,135,.08);border:1px solid rgba(0,255,135,.25);display:flex;align-items:center;justify-content:center;margin:0 auto 16px;font-size:28px}
.admin-login h2{font-family:var(--fd);font-size:28px;letter-spacing:4px;color:var(--g1);margin-bottom:8px}
.admin-login p{font-size:12px;color:var(--t2);margin-bottom:24px;letter-spacing:1px}
.admin-header{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid rgba(0,255,135,.08);flex-wrap:wrap}
.admin-header-left{display:flex;align-items:center;gap:14px}
.admin-header-icon{width:44px;height:44px;border-radius:12px;background:rgba(0,255,135,.08);border:1px solid rgba(0,255,135,.2);display:flex;align-items:center;justify-content:center;font-size:20px}
.admin-header-title{font-family:var(--fd);font-size:24px;letter-spacing:3px;color:var(--g1)}
.admin-header-sub{font-size:10px;color:var(--t3);letter-spacing:2px;font-weight:700;margin-top:2px}
.admin-header-right{display:flex;gap:8px;flex-wrap:wrap}

/* Metrics grid */
.metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:28px}
.metric-card{padding:18px;background:var(--glass);border:1px solid rgba(255,255,255,.04);border-radius:14px;position:relative;overflow:hidden;transition:all .2s}
.metric-card.primary{border-color:rgba(0,255,135,.2);background:linear-gradient(135deg,rgba(0,255,135,.05),transparent)}
.metric-card.warn{border-color:rgba(255,179,71,.2)}
.metric-card.danger{border-color:rgba(255,77,106,.15)}
.metric-icon{font-size:18px;margin-bottom:6px}
.metric-val{font-family:var(--fd);font-size:32px;color:var(--t1);line-height:1}
.metric-val.primary{color:var(--g1)}
.metric-val.warn{color:var(--draw)}
.metric-val.danger{color:var(--loss)}
.metric-lbl{font-size:9px;color:var(--t3);letter-spacing:1.5px;font-weight:700;margin-top:6px;text-transform:uppercase}

/* Toolbar */
.admin-toolbar{display:flex;gap:10px;margin-bottom:16px;flex-wrap:wrap;align-items:center}
.admin-search{flex:1;min-width:200px;padding:10px 14px;border:1px solid rgba(0,255,135,.12);background:rgba(255,255,255,.02);color:var(--t1);font-size:13px;border-radius:10px;outline:none;font-family:var(--fb)}
.admin-search:focus{border-color:var(--g1)}
.admin-filter{display:flex;gap:4px;background:var(--bg2);border-radius:10px;padding:3px;border:1px solid rgba(255,255,255,.04)}
.admin-filter button{padding:8px 14px;border-radius:7px;border:none;background:transparent;color:var(--t3);font-size:11px;font-weight:700;cursor:pointer;font-family:var(--fc);text-transform:uppercase;letter-spacing:1px;white-space:nowrap}
.admin-filter button.active{background:rgba(0,255,135,.1);color:var(--g1)}

/* Club list */
.club-row{display:grid;grid-template-columns:40px 1fr 100px 120px 100px 60px;gap:12px;align-items:center;padding:14px 16px;background:var(--glass);border:1px solid rgba(255,255,255,.03);border-radius:12px;margin-bottom:6px;transition:all .2s}
.club-row:hover{border-color:rgba(0,255,135,.15);background:rgba(0,255,135,.02)}
.club-row-crest{width:36px;height:36px;border-radius:8px;background:rgba(0,255,135,.06);border:1px solid rgba(0,255,135,.15);display:flex;align-items:center;justify-content:center;font-family:var(--fd);font-size:16px;color:var(--g1);overflow:hidden;object-fit:cover}
.club-row-crest img{width:100%;height:100%;object-fit:cover;border-radius:8px}
.club-row-info{min-width:0}
.club-row-name{font-weight:700;color:var(--t1);font-size:14px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.club-row-meta{font-size:10px;color:var(--t3);margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.club-row-status{font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;padding:4px 10px;border-radius:6px;text-align:center;font-family:var(--fc)}
.status-active{background:rgba(0,255,135,.1);color:var(--g1);border:1px solid rgba(0,255,135,.2)}
.status-trial{background:rgba(123,111,255,.1);color:var(--pend);border:1px solid rgba(123,111,255,.2)}
.status-inactive{background:rgba(122,129,148,.1);color:var(--t2);border:1px solid rgba(122,129,148,.2)}
.status-overdue{background:rgba(255,179,71,.1);color:var(--draw);border:1px solid rgba(255,179,71,.25)}
.status-cancelled{background:rgba(255,77,106,.08);color:var(--loss);border:1px solid rgba(255,77,106,.15)}
.club-row-due{font-size:11px;color:var(--t2);text-align:center}
.club-row-due.soon{color:var(--draw);font-weight:700}
.club-row-due.overdue{color:var(--loss);font-weight:700}
.club-row-stats{font-size:10px;color:var(--t3);text-align:center}
.club-row-actions{display:flex;gap:4px;justify-content:flex-end}
.btn-mini{width:30px;height:30px;border-radius:8px;border:1px solid rgba(255,255,255,.04);background:rgba(255,255,255,.02);color:var(--t2);cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;transition:all .2s}
.btn-mini:hover{border-color:var(--g1);color:var(--g1);background:rgba(0,255,135,.04)}
.btn-mini.danger:hover{border-color:var(--loss);color:var(--loss);background:rgba(255,77,106,.04)}

.admin-empty{text-align:center;padding:60px;color:var(--t3);font-size:13px}

/* Club detail modal */
.clubd-tabs{display:flex;gap:4px;background:var(--bg2);border-radius:10px;padding:3px;border:1px solid rgba(255,255,255,.04);margin-bottom:18px}
.clubd-tab{flex:1;padding:10px;border:none;background:transparent;color:var(--t3);font-size:11px;font-weight:700;cursor:pointer;border-radius:7px;font-family:var(--fc);letter-spacing:1px;text-transform:uppercase}
.clubd-tab.active{background:rgba(0,255,135,.1);color:var(--g1)}

.pay-row{display:grid;grid-template-columns:100px 1fr 80px 40px;gap:10px;align-items:center;padding:10px 12px;background:var(--glass);border:1px solid rgba(255,255,255,.03);border-radius:10px;margin-bottom:6px}
.pay-date{font-size:11px;color:var(--t1);font-weight:700}
.pay-notes{font-size:10px;color:var(--t2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pay-amount{font-family:var(--fd);font-size:15px;color:var(--g1);text-align:right}

.fld-group{margin-bottom:16px}
.fld-label{display:block;font-size:10px;color:var(--t2);text-transform:uppercase;letter-spacing:1.5px;font-weight:700;margin-bottom:6px}
.fld-input{width:100%;padding:10px 12px;border:1px solid rgba(0,255,135,.12);background:rgba(255,255,255,.02);color:var(--t1);font-size:13px;border-radius:10px;outline:none;font-family:var(--fb);box-sizing:border-box}
.fld-input:focus{border-color:var(--g1)}
.fld-select{width:100%;padding:10px 12px;border:1px solid rgba(0,255,135,.12);background:rgba(255,255,255,.02);color:var(--t1);font-size:13px;border-radius:10px;outline:none;font-family:var(--fb);cursor:pointer;box-sizing:border-box}
.fld-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}

/* Responsive */
@media(max-width:800px){
.metrics{grid-template-columns:repeat(2,1fr)}
.club-row{grid-template-columns:40px 1fr auto;gap:10px;padding:12px}
.club-row-meta,.club-row-due,.club-row-stats{display:none}
.club-row-mobile-info{font-size:9px;color:var(--t3);margin-top:3px}
.club-row-mobile-info .status-active,.club-row-mobile-info .status-trial,.club-row-mobile-info .status-inactive,.club-row-mobile-info .status-overdue,.club-row-mobile-info .status-cancelled{display:inline-block;margin-right:6px;padding:2px 6px;font-size:8px}
.admin-toolbar{flex-direction:column;align-items:stretch}
.admin-filter{overflow-x:auto}
.fld-row{grid-template-columns:1fr}
}


/* ═══ Status Banner ═══ */
.status-banner{padding:12px 16px;border-radius:12px;margin-bottom:16px;display:flex;align-items:center;gap:12px;font-size:12px;border:1px solid;font-family:var(--fb)}
.status-banner-icon{font-size:18px;flex-shrink:0}
.status-banner-text{flex:1;line-height:1.5}
.status-banner-text strong{font-weight:700;letter-spacing:.5px}
.status-banner.overdue{background:rgba(255,179,71,.08);border-color:rgba(255,179,71,.25);color:var(--draw)}
.status-banner.inactive{background:rgba(122,129,148,.06);border-color:rgba(122,129,148,.2);color:var(--t2)}
.status-banner.trial{background:rgba(123,111,255,.06);border-color:rgba(123,111,255,.2);color:var(--pend)}
.status-banner.cancelled{background:rgba(255,77,106,.06);border-color:rgba(255,77,106,.2);color:var(--loss)}


/* ═══ Revenue Panel ═══ */
.revenue-panel{padding:20px;background:linear-gradient(135deg,rgba(0,255,135,.04),transparent);border:1px solid rgba(0,255,135,.15);border-radius:14px;margin-bottom:20px}
.revenue-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px;gap:12px;flex-wrap:wrap}
.revenue-title{font-family:var(--fc);font-size:12px;font-weight:700;letter-spacing:2px;color:var(--g1)}
.revenue-sub{font-size:10px;color:var(--t3);margin-top:2px}
.revenue-total{text-align:right}
.revenue-total-label{font-size:9px;color:var(--t3);letter-spacing:1.5px;font-weight:700;text-transform:uppercase}
.revenue-total-val{font-family:var(--fd);font-size:26px;color:var(--g1);line-height:1;margin-top:2px}
.revenue-chart{display:flex;gap:8px;align-items:flex-end;height:140px}
.revenue-bar-wrap{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;min-width:0}
.revenue-bar-val{font-family:var(--fd);font-size:11px;color:var(--t2);white-space:nowrap}
.revenue-bar-wrap.current .revenue-bar-val{color:var(--g1);font-weight:700}
.revenue-bar-container{width:100%;height:70px;background:rgba(255,255,255,.02);border-radius:6px 6px 2px 2px;display:flex;align-items:flex-end;overflow:hidden}
.revenue-bar{width:100%;background:linear-gradient(180deg,rgba(0,255,135,.4),rgba(0,255,135,.8));border-radius:6px 6px 2px 2px;transition:height .6s ease;min-height:2px}
.revenue-bar-wrap.current .revenue-bar{background:linear-gradient(180deg,var(--g1),rgba(0,255,135,.7));box-shadow:0 0 12px rgba(0,255,135,.3)}
.revenue-bar-label{font-size:10px;color:var(--t2);font-weight:700;letter-spacing:1px;text-transform:uppercase}
.revenue-bar-wrap.current .revenue-bar-label{color:var(--g1)}
.revenue-bar-count{font-size:9px;color:var(--t3)}
@media(max-width:640px){
.revenue-chart{height:120px;gap:4px}
.revenue-bar-val{font-size:9px}
.revenue-bar-label{font-size:8px;letter-spacing:0}
.revenue-bar-count{font-size:8px}
.revenue-total-val{font-size:20px}
}


/* ═══ Modal body-lock & scroll fix ═══ */
body.modal-open{overflow:hidden !important;position:fixed;width:100%;height:100%}
.modal-bg{overflow-y:auto !important;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}
.modal{max-height:95vh !important;overflow-y:auto !important;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}

