/* FNLY Agency Portal v4.0 */
:root {
  --brand:#B76E79; --brand-dim:#9A5A64; --brand-muted:#3D2428; --brand-pale:#251518;
  --accent:#41A10B; --accent-dim:#2d7008; --accent-pale:#162905;
  --bg-deep:#0B0B0F; --bg-dark:#111116; --bg-mid:#17171D; --bg-card:#1C1C23;
  --text-bright:#FAFAF9; --text-mid:#C9A0A6; --text-dim:#7A5059;
  --border:#2E1A1D; --border-bright:#9A5A64;
  --red:#ef4444; --amber:#f59e0b; --blue:#3b82f6; --green:#41A10B;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;background:var(--bg-deep);color:var(--text-bright);min-height:100vh;font-size:14px;line-height:1.5}

/* Layout */
.app{display:flex;min-height:100vh}
.sidebar{width:220px;background:var(--bg-dark);border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;top:0;left:0;height:100vh;z-index:100;overflow-y:auto}
.sidebar-logo{padding:16px;border-bottom:1px solid var(--border);flex-shrink:0}
.sidebar-logo img{height:32px;object-fit:contain;max-width:100%}
.nav-section{font-size:10px;color:var(--text-dim);padding:12px 16px 4px;letter-spacing:1px;text-transform:uppercase;flex-shrink:0}
.nav-item{display:flex;align-items:center;gap:10px;padding:9px 16px;font-size:13px;color:var(--text-mid);cursor:pointer;text-decoration:none;transition:background .12s;border-left:2px solid transparent;flex-shrink:0}
.nav-item:hover{background:var(--brand-pale);color:var(--text-bright)}
.nav-item.active{background:var(--brand-pale);color:var(--text-bright);border-left-color:var(--brand)}
.nav-badge{margin-left:auto;background:var(--brand-muted);color:var(--brand);font-size:10px;padding:2px 7px;border-radius:99px}
.nav-badge-green{background:var(--accent-pale);color:var(--accent)}
.sidebar-spacer{flex:1}
.logout-btn{margin:8px 12px;display:flex;align-items:center;gap:8px;padding:10px 14px;background:var(--brand-pale);border:1px solid var(--brand-muted);border-radius:8px;color:var(--brand);cursor:pointer;text-decoration:none;font-size:13px;font-weight:500;transition:all .15s;flex-shrink:0}
.logout-btn:hover{background:var(--brand-muted);color:var(--text-bright)}
.user-area{padding:12px 16px;border-top:1px solid var(--border);display:flex;align-items:center;gap:10px;flex-shrink:0}
.user-avatar{width:32px;height:32px;border-radius:50%;background:var(--brand-muted);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;color:var(--brand);flex-shrink:0}
.user-name{font-size:13px;color:var(--text-mid)}
.user-role{font-size:11px;color:var(--text-dim)}

/* Main */
.main{margin-left:220px;flex:1;display:flex;flex-direction:column;min-height:100vh}
.topbar{background:var(--bg-dark);border-bottom:1px solid var(--border);padding:12px 24px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:50}
.topbar-title{font-size:15px;font-weight:500;color:var(--text-bright)}
.topbar-right{display:flex;align-items:center;gap:12px}
.page{padding:24px;flex:1}

/* Cards */
.card{background:var(--bg-dark);border:1px solid var(--border);border-radius:10px;padding:20px;margin-bottom:16px}
.card-title{font-size:13px;font-weight:500;color:var(--text-mid);margin-bottom:16px;display:flex;align-items:center;gap:8px}

/* Stats */
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px}
.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:16px}
.stat-num{font-size:24px;font-weight:500}
.stat-label{font-size:11px;color:var(--text-dim);margin-top:4px}

/* Forms */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-group{display:flex;flex-direction:column;gap:5px}
.form-group.full{grid-column:1/-1}
label{font-size:11px;color:var(--text-dim)}
input,select,textarea{background:var(--bg-mid);border:1px solid var(--border);border-radius:7px;color:var(--text-bright);padding:8px 12px;font-size:13px;width:100%;transition:border-color .15s;font-family:inherit}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--brand-dim)}
input::placeholder{color:var(--text-dim)}
select option{background:var(--bg-mid)}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:7px;font-size:13px;font-weight:500;cursor:pointer;border:1px solid transparent;transition:opacity .15s;text-decoration:none}
.btn:hover{opacity:.85}
.btn-primary{background:var(--brand-muted);color:var(--text-bright);border-color:var(--brand-dim)}
.btn-success{background:var(--accent-pale);color:#86efac;border-color:var(--accent-dim)}
.btn-danger{background:#450a0a;color:#fca5a5;border-color:#dc2626}
.btn-ghost{background:transparent;color:var(--text-dim);border-color:var(--border)}
.btn-sm{padding:4px 10px;font-size:11px;border-radius:5px}
.btn-row{display:flex;gap:8px;justify-content:flex-end;margin-top:16px}

/* Platform blocks */
.platform-block{background:var(--bg-mid);border:1px solid var(--border);border-radius:10px;padding:14px;margin-bottom:10px}
.platform-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.platform-title{font-size:12px;font-weight:500;color:var(--text-mid);display:flex;align-items:center;gap:8px}
.platform-grid{display:grid;grid-template-columns:130px 1fr 1fr;gap:8px;align-items:end}
.platform-main-row{display:flex;align-items:center;gap:8px;margin-top:8px}
.platform-main-row input[type=radio]{width:auto;height:auto;padding:0}
.platform-main-badge{font-size:10px;padding:2px 8px;border-radius:99px;background:var(--brand-muted);color:var(--brand)}
.add-platform-btn{display:flex;align-items:center;gap:6px;padding:10px 14px;border:1px dashed var(--border-bright);border-radius:10px;color:var(--brand);font-size:12px;cursor:pointer;background:transparent;width:100%;margin-top:8px;transition:all .15s}
.add-platform-btn:hover{background:var(--brand-pale);border-style:solid}
.remove-platform-btn{background:none;border:none;color:var(--text-dim);cursor:pointer;font-size:16px;padding:4px 8px;border-radius:4px}
.remove-platform-btn:hover{color:var(--red);background:#450a0a}

/* Platform list (read-only) */
.platform-list-item{display:grid;grid-template-columns:90px 1fr 1fr;gap:8px;align-items:center;padding:8px 10px;background:var(--bg-mid);border:1px solid var(--border);border-radius:7px;margin-bottom:6px;font-size:12px}
.platform-list-item.main{border-color:var(--brand-dim);background:var(--brand-pale)}
.plat-name{font-weight:500;color:var(--text-bright);display:flex;align-items:center;gap:4px}
.plat-username{color:var(--text-mid)}
.plat-url{color:var(--text-dim);font-size:11px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* Table */
table{width:100%;border-collapse:collapse;font-size:12px}
th{text-align:left;padding:8px 10px;color:var(--text-dim);border-bottom:1px solid var(--border);font-weight:400}
td{padding:10px;border-bottom:1px solid var(--border);color:var(--text-mid);vertical-align:middle}
tr:last-child td{border-bottom:none}
tr:hover td{background:var(--brand-pale)}
.td-main{font-size:13px;color:var(--text-bright)}
.td-sub{font-size:11px;color:var(--text-dim);margin-top:2px}

/* Pills */
.pill{font-size:10px;padding:3px 10px;border-radius:99px;white-space:nowrap}
.pill-pending{background:#78350f;color:#fcd34d}
.pill-in-review{background:#1e3a5f;color:#93c5fd}
.pill-approved{background:var(--accent-pale);color:#86efac;border:1px solid var(--accent-dim)}
.pill-denied{background:#450a0a;color:#fca5a5}
.pill-signed{background:#1e3a5f;color:#93c5fd}
.pill-offboarded{background:var(--bg-card);color:var(--text-dim)}

/* Status bar */
.status-bar{background:var(--brand-pale);border:1px solid var(--border);border-radius:8px;padding:10px 14px;display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.status-dot{width:6px;height:6px;border-radius:50%;background:var(--brand);flex-shrink:0}
.step-badge{font-size:11px;padding:3px 10px;border-radius:99px;background:var(--brand-muted);color:var(--brand)}

/* Modal */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.75);z-index:1000;align-items:center;justify-content:center}
.modal-overlay.open{display:flex}
.modal{background:var(--bg-dark);border:1px solid var(--border);border-radius:12px;padding:24px;width:520px;max-width:92vw;max-height:88vh;overflow-y:auto}
.modal-title{font-size:15px;font-weight:500;color:var(--text-bright);margin-bottom:20px}
.modal-footer{display:flex;gap:8px;justify-content:flex-end;margin-top:20px;border-top:1px solid var(--border);padding-top:16px}

/* Alert */
.alert{padding:10px 14px;border-radius:7px;font-size:12px;margin-bottom:12px}
.alert-error{background:#450a0a;color:#fca5a5;border:1px solid #dc2626}
.alert-success{background:var(--accent-pale);color:#86efac;border:1px solid var(--accent-dim)}

/* Admin grid */
.admin-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.admin-card{background:var(--bg-dark);border:1px solid var(--border);border-radius:10px;padding:16px}
.admin-card-title{font-size:13px;font-weight:500;color:var(--text-mid);margin-bottom:14px;display:flex;align-items:center;gap:6px}

/* Tab bar */
.tab-bar{display:flex;gap:4px;background:var(--bg-mid);border:1px solid var(--border);border-radius:8px;padding:4px;margin-bottom:16px}
.tab-btn{flex:1;padding:7px 12px;border-radius:5px;font-size:12px;cursor:pointer;color:var(--text-dim);background:transparent;border:none;transition:all .15s}
.tab-btn.active{background:var(--brand-muted);color:var(--text-bright)}

/* Settings */
.setting-row{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.setting-label{font-size:11px;color:var(--text-dim);width:110px;flex-shrink:0}
.color-row{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.color-label{font-size:11px;color:var(--text-dim);width:100px}
.color-swatch{width:24px;height:24px;border-radius:5px;border:1px solid var(--border);cursor:pointer;flex-shrink:0}
.color-hex{font-size:11px;color:var(--text-mid);font-family:monospace}
input[type=color]{width:0;height:0;opacity:0;position:absolute}

/* Toggle */
.toggle{width:36px;height:20px;background:var(--bg-mid);border-radius:99px;position:relative;cursor:pointer;border:1px solid var(--border);transition:background .2s;flex-shrink:0}
.toggle.on{background:var(--accent-dim);border-color:var(--accent)}
.toggle-knob{width:14px;height:14px;background:var(--text-bright);border-radius:50%;position:absolute;top:2px;left:2px;transition:left .2s}
.toggle.on .toggle-knob{left:18px}

/* Disk bar */
.disk-bar-wrap{background:var(--bg-mid);border-radius:99px;height:8px;overflow:hidden;margin-top:4px}
.disk-bar{height:100%;background:var(--brand);border-radius:99px;transition:width .5s}

/* Logo upload */
.logo-upload-area{border:1px dashed var(--border-bright);border-radius:8px;padding:16px;text-align:center;cursor:pointer;margin-bottom:12px;transition:border-color .15s}
.logo-upload-area:hover{border-color:var(--brand)}

/* Denial banner */
.denial-banner{background:#450a0a;border:1px solid #dc2626;border-radius:8px;padding:12px 16px;margin-bottom:16px;font-size:13px;color:#fca5a5}

/* Notes */
.note-item{background:var(--bg-mid);border:1px solid var(--border);border-radius:7px;padding:10px 14px;margin-bottom:8px}
.note-meta{font-size:10px;color:var(--text-dim);margin-bottom:4px}
.note-text{font-size:12px;color:var(--text-mid)}

/* Scrollbar */
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:var(--bg-deep)}
::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}

/* Helpers */
.hidden{display:none!important}
.mt-8{margin-top:8px}
.mt-16{margin-top:16px}
.flex{display:flex}
.items-center{align-items:center}
.gap-8{gap:8px}

@media(max-width:768px){
  .sidebar{width:100%;height:auto;position:relative}
  .main{margin-left:0}
  .stat-grid{grid-template-columns:repeat(2,1fr)}
  .form-grid,.admin-grid,.platform-grid{grid-template-columns:1fr}
}

/* v5.0 Additions */
.pill-bl-agency { background:#1e3a5f; color:#93c5fd; }
.pill-bl-social { background:var(--brand-muted); color:var(--brand); }
.pill-tm { background:var(--accent-pale); color:#86efac; }
.tm-badge { display:inline-flex; align-items:center; gap:4px; font-size:10px; padding:2px 8px; border-radius:99px; background:var(--bg-mid); color:var(--text-dim); border:1px solid var(--border); }
.tm-badge.mine { background:var(--accent-pale); color:#86efac; border-color:var(--accent-dim); }
.assignment-card { background:var(--bg-card); border:1px solid var(--amber); border-radius:8px; padding:12px 14px; margin-bottom:8px; }
.read-only-banner { background:var(--bg-mid); border:1px solid var(--border); border-radius:7px; padding:8px 12px; font-size:11px; color:var(--text-dim); margin-bottom:12px; display:flex; align-items:center; gap:6px; }
