:root{--navy:#17233c;--blue:#2457d6;--pale:#f3f6fb;--line:#e2e8f0;--text:#1c2738;--muted:#6b778c;--danger:#c93d4d}
*{box-sizing:border-box}body{margin:0;font-family:Inter,Segoe UI,Arial,sans-serif;color:var(--text);background:var(--pale)}[v-cloak]{display:none!important}
.login-page{min-height:100vh;display:grid;place-items:center;background:linear-gradient(145deg,#13213d,#254d9a)}.login-card{width:min(430px,calc(100% - 32px));padding:42px;background:#fff;border-radius:18px;box-shadow:0 24px 60px #06132d66}.brand-mark{display:inline-block;padding:8px 12px;background:#e8efff;color:var(--blue);font-weight:800;border-radius:8px;letter-spacing:1px}.login-card h1{margin:20px 0 8px;font-size:28px}.muted,.panel-heading p{color:var(--muted)}.login-form{display:grid;gap:10px;margin-top:28px}.login-form label,.form-grid label,.app-modal>form>label{font-weight:600;font-size:14px}.login-form input,.form-grid input,.form-grid select,.app-modal>form input,.filters-grid input,.filters-grid select,.toolbar input,.toolbar select{width:100%;padding:11px 12px;border:1px solid #ccd5e2;border-radius:8px;background:#fff;outline:none}.login-form input:focus,.form-grid input:focus,.form-grid select:focus{border-color:var(--blue);box-shadow:0 0 0 3px #2457d61f}.login-form button,.btn-primary-app{border:0;border-radius:8px;background:var(--blue);color:#fff;padding:11px 18px;font-weight:700}.alert-error{padding:10px 12px;background:#fff0f1;color:#a72c3a;border-radius:8px;margin-top:18px}
.app-page{min-height:100vh}.sidebar{position:fixed;inset:0 auto 0 0;width:245px;background:var(--navy);color:#fff;padding:28px 18px;display:flex;flex-direction:column}.sidebar-brand{padding:0 12px 28px}.sidebar-brand span{display:block;font-weight:800;font-size:24px;letter-spacing:1px}.sidebar-brand small{color:#9aabc9}.sidebar nav{display:grid;gap:6px}.sidebar nav button{padding:12px 14px;border:0;border-radius:8px;background:transparent;color:#b9c5da;text-align:left;font-weight:600}.sidebar nav button:hover,.sidebar nav button.active{background:#ffffff16;color:#fff}.logout-link{margin-top:auto;color:#b9c5da;text-decoration:none;padding:12px}.main-content{margin-left:245px;padding:28px 34px 60px}.topbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:26px}.topbar h1{margin:2px 0;font-size:27px}.topbar small{color:var(--muted)}.session-pill,.tag,.status{display:inline-block;padding:6px 10px;border-radius:999px;background:#e9eef8;color:#42516a;font-size:12px;font-weight:700}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}.stats-grid article{background:#fff;border:1px solid var(--line);border-radius:12px;padding:20px}.stats-grid span{display:block;color:var(--muted);font-size:14px}.stats-grid strong{display:block;font-size:30px;margin-top:9px}.panel{background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:0 5px 20px #1a2d4c0a;overflow:hidden}.narrow-panel{max-width:900px}.panel-heading{padding:22px 24px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--line);gap:18px}.panel-heading h2{margin:0 0 4px;font-size:20px}.panel-heading p{margin:0;font-size:14px}.toolbar,.filters-grid{padding:16px 24px;background:#fafbfd;border-bottom:1px solid var(--line)}.toolbar input{max-width:500px}.toolbar select{max-width:700px}.filters-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.5fr;gap:10px}.app-table{margin:0}.app-table th{padding:13px 16px;background:#fafbfd;color:#637087;font-size:12px;text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--line)}.app-table td{padding:14px 16px;vertical-align:middle;border-color:#edf0f5;font-size:14px}.app-table td small{display:block;color:var(--muted);margin-top:3px;max-width:360px}.actions{white-space:nowrap}.actions button,.btn-link{border:0;background:transparent;color:var(--blue);font-weight:600;padding:5px}.actions button.danger,.danger{color:var(--danger)}.status.ok{background:#e8f7ef;color:#21764b}.status.off{background:#fbeaec;color:#a62f3d}.empty{text-align:center!important;color:var(--muted);padding:36px!important}.empty-block{padding:60px;text-align:center;color:var(--muted)}
.modal-mask{position:fixed;inset:0;background:#0b173099;display:grid;place-items:center;padding:20px;z-index:30}.app-modal{width:min(620px,100%);max-height:calc(100vh - 40px);overflow:auto;background:#fff;border-radius:14px;box-shadow:0 25px 70px #0005}.app-modal.large{width:min(720px,100%)}.app-modal.small{width:min(430px,100%)}.modal-title{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--line)}.modal-title h2{margin:0;font-size:20px}.modal-title button{border:0;background:transparent;font-size:28px;color:var(--muted)}.form-grid,.app-modal>form{padding:22px 24px;display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-grid label{display:grid;gap:7px}.form-grid .full{grid-column:1/-1}.form-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:10px}.form-actions button{padding:10px 16px;border:0;border-radius:8px;font-weight:600}.background-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;padding:24px}.background-grid article{border:1px solid var(--line);border-radius:10px;padding:14px}.background-preview{aspect-ratio:297/210;background:#e9edf3;border-radius:7px;display:grid;place-items:center;overflow:hidden;color:var(--muted)}.background-preview img{width:100%;height:100%;object-fit:cover}.background-grid h3{font-size:15px;margin:13px 0 4px}.background-grid code{font-size:12px}.background-grid input{display:block;width:100%;margin-top:12px;font-size:12px}.btn-danger-outline{width:100%;margin-top:10px;padding:7px;border:1px solid #e3aab0;border-radius:7px;background:#fff;color:var(--danger)}
@media(max-width:1050px){.stats-grid{grid-template-columns:repeat(2,1fr)}.filters-grid{grid-template-columns:1fr 1fr}.background-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:760px){.sidebar{position:static;width:100%;padding:14px}.sidebar-brand{padding:4px 8px 12px}.sidebar nav{grid-template-columns:repeat(2,1fr)}.logout-link{margin-top:10px}.main-content{margin-left:0;padding:20px 14px}.topbar{align-items:flex-start}.session-pill{display:none}.stats-grid{grid-template-columns:1fr 1fr;gap:10px}.panel-heading{align-items:flex-start;flex-direction:column}.filters-grid,.form-grid,.app-modal>form{grid-template-columns:1fr}.form-grid .full{grid-column:auto}.background-grid{grid-template-columns:1fr}.actions{white-space:normal}}
.actions a{color:var(--blue);font-weight:600;padding:5px;text-decoration:none}
.record-id{font-weight:800;color:var(--navy);letter-spacing:.02em}
.heading-actions{display:flex;gap:10px}.btn-secondary-app{display:inline-block;border:1px solid #bdc9dc;border-radius:8px;background:#fff;color:var(--navy);padding:10px 16px;font-weight:700;text-decoration:none}.import-modal{width:min(1050px,100%);max-height:calc(100vh - 30px);display:flex;flex-direction:column;overflow:hidden}.import-body{padding:20px;overflow:auto}.import-steps{display:grid;grid-template-columns:1fr 1fr;gap:18px}.import-steps>div{border:1px solid var(--line);border-radius:10px;padding:18px}.import-steps p{color:var(--muted);font-size:14px}.import-steps select,.import-steps input{display:block;width:100%;padding:10px;margin:10px 0;border:1px solid #ccd5e2;border-radius:8px}.import-summary{display:flex;gap:12px;margin:20px 0 10px}.import-summary span{padding:8px 12px;border-radius:8px;background:#edf1f7}.import-summary .valid{background:#e8f7ef;color:#21764b}.import-summary .invalid{background:#fbeaec;color:#a62f3d}.import-table{max-height:360px;overflow:auto;border:1px solid var(--line);border-radius:8px}
@media(max-width:760px){.import-steps{grid-template-columns:1fr}.heading-actions{flex-wrap:wrap}}
.preview-mask{padding:14px}.preview-modal{width:min(1180px,100%);height:calc(100vh - 28px);display:flex;flex-direction:column;overflow:hidden}.pdf-preview{width:100%;flex:1;border:0;background:#e8edf5}.preview-actions{display:flex;justify-content:flex-end;gap:10px;padding:12px 18px;border-top:1px solid var(--line);background:#fff}.preview-actions button,.preview-actions a{border:0;border-radius:8px;padding:10px 16px;font-weight:700;text-decoration:none}.preview-actions button{background:#e9eef6;color:var(--text)}
