/* ── RESET ──────────────────────────────────────────────── */
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;background:#f5f5f3;color:#1a1a1a;font-size:13px}

/* ── LOGIN ──────────────────────────────────────────────── */
#login-screen{display:flex;align-items:center;justify-content:center;min-height:100vh}
.lcard{background:#fff;border:0.5px solid #e0ddd6;border-radius:12px;padding:32px;width:360px;box-shadow:0 2px 12px rgba(0,0,0,0.06)}
.lcard h1{font-size:20px;font-weight:600;margin-bottom:4px}
.lcard p{font-size:12px;color:#888;margin-bottom:20px}
.lcard label{display:block;font-size:11px;color:#666;margin-bottom:4px;margin-top:14px}
.lcard input{width:100%;border:0.5px solid #ccc;border-radius:7px;padding:9px 12px;font-size:13px;font-family:inherit;background:#fff;color:#1a1a1a;transition:border-color .15s}
.lcard input:focus{outline:none;border-color:#888}
.lcard .field-wrap input{padding-right:42px}
.lcard button.sign-in-btn{width:100%;margin-top:20px;padding:10px;border-radius:7px;border:none;background:#1a1a1a;color:#fff;font-size:13px;cursor:pointer;font-family:inherit;font-weight:500;transition:opacity .15s}
.lcard button.sign-in-btn:hover{opacity:.85}
.lerr{color:#c0392b;font-size:11px;margin-top:8px;display:none}

/* ── FIELD WRAP (eye icon inside input) ─────────────────── */
.field-wrap{position:relative}
.field-wrap input{width:100%;padding-right:42px}
.field-wrap .eye-btn{position:absolute;right:11px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;padding:0;color:#bbb;display:flex;align-items:center;justify-content:center;width:18px;height:18px}
.field-wrap .eye-btn:hover{color:#555}
.field-wrap .eye-btn svg{width:16px;height:16px;display:block;flex-shrink:0}

/* ── APP LAYOUT ─────────────────────────────────────────── */
#app-screen{display:none}
.app{display:flex;min-height:100vh}

/* ── SIDEBAR ────────────────────────────────────────────── */
.sidebar{width:192px;flex-shrink:0;background:#fff;border-right:0.5px solid #e8e6e0;display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow-y:auto}
.logo{padding:14px 15px;border-bottom:0.5px solid #e8e6e0;font-size:14px;font-weight:600}
.logo small{display:block;font-size:10px;color:#aaa;font-weight:400;margin-top:1px}
.nav{padding:10px 7px;flex:1}
.ni{display:flex;align-items:center;gap:7px;padding:7px 10px;border-radius:7px;font-size:12px;cursor:pointer;color:#666;margin-bottom:2px;user-select:none;transition:background .1s}
.ni:hover{background:#f5f5f3;color:#1a1a1a}
.ni.active{background:#f0ede8;color:#1a1a1a;font-weight:500}
.ni-count{margin-left:auto;background:#eee;color:#555;font-size:10px;padding:1px 5px;border-radius:8px}
.ni-count.warn{background:#fcebeb;color:#a32d2d}
.role-box{padding:10px;border-top:0.5px solid #e8e6e0}
.role-box label{display:block;font-size:10px;color:#aaa;margin-bottom:3px}
.role-box select{width:100%;font-size:11px;border:0.5px solid #ddd;border-radius:6px;padding:4px 7px;background:#fff;font-family:inherit;color:#1a1a1a}
#ed-wrap{margin-top:6px;display:none}

/* ── MAIN ───────────────────────────────────────────────── */
.main{flex:1;display:flex;flex-direction:column;min-width:0}
.topbar{background:#fff;border-bottom:0.5px solid #e8e6e0;padding:9px 18px;display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap;position:sticky;top:0;z-index:10}
.tl{display:flex;align-items:center;gap:7px;flex-wrap:wrap;flex:1;min-width:0}
.pt{font-size:13px;font-weight:500;white-space:nowrap}

/* ── FORM ELEMENTS ──────────────────────────────────────── */
input[type=text],input[type=date],input[type=password],input[type=search],select.f{border:0.5px solid #ddd;border-radius:7px;padding:5px 9px;font-size:12px;background:#fff;color:#1a1a1a;font-family:inherit}
input:focus,select:focus{outline:none;border-color:#999}
textarea{border:0.5px solid #ddd;border-radius:7px;padding:7px 10px;font-size:12px;background:#fff;color:#1a1a1a;font-family:inherit;resize:vertical;min-height:54px;width:100%}
textarea:focus{outline:none;border-color:#999}

/* ── BUTTONS ────────────────────────────────────────────── */
.btn{padding:5px 12px;border-radius:7px;border:0.5px solid #ddd;background:#fff;font-size:12px;cursor:pointer;color:#1a1a1a;font-family:inherit;white-space:nowrap;transition:background .1s}
.btn:hover{background:#f5f5f3}
.btn-p{background:#1a1a1a;color:#fff;border-color:transparent}
.btn-p:hover{opacity:.82}
.btn-sm{padding:2px 8px;font-size:11px}
.btn-warn{border-color:#e2c97a;color:#854f0b}.btn-warn:hover{background:#faeeda}
.btn-restore{border-color:#c0dd97;color:#3b6d11}.btn-restore:hover{background:#eaf3de}
.btn-info{border-color:#b5d4f4;color:#185fa5}.btn-info:hover{background:#e6f1fb}

/* ── CONTENT ────────────────────────────────────────────── */
.content{padding:14px 18px}
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:9px;margin-bottom:14px}
.sc{background:#f5f5f3;border-radius:7px;padding:11px 13px}
.sc-label{font-size:10px;color:#888;margin-bottom:2px}
.sc-val{font-size:20px;font-weight:500}

/* ── SECTION / TABLE ────────────────────────────────────── */
.section{background:#fff;border:0.5px solid #e8e6e0;border-radius:11px;overflow:hidden;margin-bottom:14px}
.sec-hdr{padding:10px 15px;border-bottom:0.5px solid #e8e6e0;display:flex;align-items:center;justify-content:space-between}
.sec-title{font-size:12px;font-weight:500}
.tw{overflow-x:auto}
table{width:100%;border-collapse:collapse;table-layout:fixed}
th{font-size:10px;color:#888;text-align:left;padding:8px 13px;font-weight:500;border-bottom:0.5px solid #e8e6e0;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;cursor:pointer;user-select:none}
th:hover{color:#1a1a1a}
th.sorted{color:#1a1a1a}
td{font-size:11px;padding:8px 13px;border-bottom:0.5px solid #f0ede8;color:#1a1a1a;vertical-align:middle}
tr:last-child td{border-bottom:none}
tr:hover td{background:#fafaf8}
.empty-row td{text-align:center;padding:28px;color:#bbb;font-size:12px}

/* ── BADGES ─────────────────────────────────────────────── */
.badge{display:inline-block;padding:2px 6px;border-radius:20px;font-size:10px;font-weight:500;white-space:nowrap}
.b-green{background:#eaf3de;color:#3b6d11}
.b-amber{background:#faeeda;color:#854f0b}
.b-red{background:#fcebeb;color:#a32d2d}
.b-blue{background:#e6f1fb;color:#185fa5}
.b-purple{background:#eeedfe;color:#3c3489}
.b-gray{background:#f1efe8;color:#5f5e5a}
.b-teal{background:#e1f5ee;color:#085041}
.b-coral{background:#faece7;color:#712b13}
.b-pink{background:#fbeaf0;color:#72243e}

/* ── CREDENTIALS / COPY ─────────────────────────────────── */
.copyable{cursor:pointer;border-bottom:1px dashed #ccc;font-family:monospace;font-size:10px;user-select:none}
.copyable:hover{color:#185fa5;border-color:#185fa5}
.pw-dots{cursor:pointer;letter-spacing:2px;color:#bbb;font-size:13px;user-select:none}
.pw-dots:hover{color:#333}
.pw-rev{cursor:pointer;font-family:monospace;font-size:10px;border-bottom:1px dashed #ccc;user-select:none}
.pw-rev:hover{color:#185fa5}
.eye{background:none;border:none;cursor:pointer;color:#bbb;font-size:11px;padding:0 2px;line-height:1;vertical-align:middle}
.eye:hover{color:#333}
.cred-cell{display:flex;flex-direction:column;gap:3px}
.cred-row{display:flex;align-items:center;gap:4px}
.cred-lbl{font-size:9px;color:#bbb;width:16px;flex-shrink:0}
.dash{color:#ccc}

/* ── TOAST ──────────────────────────────────────────────── */
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);background:#1a1a1a;color:#fff;padding:6px 16px;border-radius:20px;font-size:12px;opacity:0;pointer-events:none;transition:opacity .15s;z-index:9999}
.toast.on{opacity:1}

/* ── LOCK BAR ───────────────────────────────────────────── */
.lock-bar{background:#e6f1fb;border-bottom:0.5px solid #b5d4f4;padding:6px 16px;font-size:11px;color:#185fa5;display:flex;align-items:center;gap:8px}
.lock-bar button{padding:2px 8px;border-radius:5px;border:0.5px solid #185fa5;background:transparent;font-size:10px;color:#185fa5;cursor:pointer;font-family:inherit}
.lock-bar button:hover{background:#d0e8f8}

/* ── MODALS ─────────────────────────────────────────────── */
.modal-bg{display:none;position:fixed;inset:0;background:rgba(0,0,0,.32);z-index:100;align-items:flex-start;justify-content:center;padding:30px 10px;overflow-y:auto}
.modal-bg.open{display:flex}
.modal{background:#fff;border-radius:11px;border:0.5px solid #e0ddd6;padding:20px;width:560px;max-width:100%;margin-bottom:30px}
.modal h3{font-size:13px;font-weight:500;margin-bottom:13px}
.fg{margin-bottom:10px}
.fg label{display:block;font-size:10px;color:#888;margin-bottom:3px}
.fg input,.fg select{width:100%;border:0.5px solid #ddd;border-radius:7px;padding:7px 10px;font-size:12px;background:#fff;color:#1a1a1a;font-family:inherit}
.fg input:focus,.fg select:focus{outline:none;border-color:#999}
.fg .field-wrap input{padding-right:42px}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:9px}
.mf{display:flex;gap:7px;justify-content:flex-end;margin-top:14px;padding-top:11px;border-top:0.5px solid #eee}
.sub-hdr{font-size:10px;font-weight:500;color:#aaa;padding:7px 0 5px;border-top:0.5px solid #eee;margin-top:6px}

/* ── SETTINGS ───────────────────────────────────────────── */
.srv-list{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:10px}
.srv-tag{display:flex;align-items:center;gap:5px;padding:4px 9px;border:0.5px solid #ddd;border-radius:7px;font-size:11px;background:#fff}
.arch-note{background:#faeeda;border-bottom:0.5px solid #e8e6e0;padding:6px 14px;font-size:10px;color:#854f0b}
.chk-grid{display:grid;grid-template-columns:1fr 1fr;gap:4px 16px;margin:6px 0 10px}
.chk-row{display:flex;align-items:center;gap:6px;font-size:12px;padding:3px 0;cursor:pointer}
.chk-row input[type=checkbox]{width:13px;height:13px;cursor:pointer;flex-shrink:0}
.ed-card{background:#f8f8f6;border-radius:7px;padding:10px 12px;margin-bottom:8px}
.ic-btn{background:none;border:none;cursor:pointer;color:#bbb;padding:2px 4px;border-radius:3px;font-size:11px;font-family:inherit}
.ic-btn:hover{color:#1a1a1a;background:#eee}
.acc-row{display:flex;gap:8px;margin:8px 0}
.acc-opt{display:flex;align-items:center;gap:5px;padding:6px 12px;border:0.5px solid #ddd;border-radius:7px;font-size:12px;cursor:pointer}
.acc-opt:hover{background:#f5f5f3}
.acc-opt.sel{border-color:#1a1a1a;background:#f0ede8;font-weight:500}
.acc-opt input[type=radio]{width:12px;height:12px}
