:root{--brand: #0f4c81;--brand-dark: #0b3a63;--brand-light: #e8f0f7;--text: #1f2933;--muted: #6b7a8c;--border: #d4dde5;--bg: #f4f6f9;--danger: #b3261e;--ok: #1d7a3e}*{box-sizing:border-box}body{margin:0;font-family:Segoe UI,Segoe UI Variable Text,Tahoma,Arial,sans-serif;font-size:15px;color:var(--text);background:var(--bg)}h1{font-size:24px;font-weight:600;margin:0}h2{font-size:17px;font-weight:600;margin:0 0 12px}a{color:var(--brand)}.mono{font-family:Consolas,Cascadia Mono,monospace;letter-spacing:.03em}.app{min-height:100vh;display:flex;flex-direction:column}.topbar{display:flex;align-items:center;gap:24px;padding:0 28px;height:56px;background:var(--brand);color:#fff;box-shadow:0 1px 4px #0f4c8159}.brand{color:#fff;font-size:18px;font-weight:700;text-decoration:none;letter-spacing:.02em}.nav{display:flex;gap:8px}.nav-link{color:#ffffffd9;text-decoration:none;padding:6px 12px;border-radius:6px;font-weight:500}.nav-link:hover,.nav-link--active{background:var(--brand-dark);color:#fff}.topbar-spacer{flex:1}.user-label{max-width:280px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#ffffffe6;font-size:14px}.content{flex:1;width:100%;max-width:1100px;margin:0 auto;padding:28px 24px 48px}.page--narrow{max-width:680px}.page-head{display:flex;align-items:center;gap:16px;justify-content:space-between;margin:8px 0 20px}.page-loading,.empty{padding:32px 0;color:var(--muted);text-align:center}.toolbar{display:flex;gap:16px;align-items:flex-end;margin-bottom:16px}.table{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--border);border-radius:8px;overflow:hidden}.table th{background:var(--brand);color:#fff;text-align:left;font-weight:600;padding:10px 14px;font-size:13.5px}.table td{padding:10px 14px;border-top:1px solid var(--border);vertical-align:middle}.table tbody tr:nth-child(2n){background:var(--brand-light)}.table tbody tr:hover{background:#dbe7f2}.badge{display:inline-block;padding:3px 12px;border-radius:999px;font-size:12.5px;font-weight:600;white-space:nowrap}.badge--draft{background:#e4e7eb;color:#3e4c59}.badge--pending_review{background:#fdf3d7;color:#8a6100}.badge--active{background:#dcf2e3;color:var(--ok)}.badge--rejected{background:#fbe2e0;color:var(--danger)}.badge--blocked{background:#3e4c59;color:#fff}.badge--submitted{background:#d7e7f7;color:var(--brand-dark)}.badge--auto_validating{background:#e6e0f5;color:#4b3a86}.badge--pending_host{background:#fdf3d7;color:#8a6100}.badge--pending_security{background:#fce8d4;color:#9a4b00}.badge--approved{background:#dcf2e3;color:var(--ok)}.badge--issued{background:var(--brand);color:#fff}.badge--cancelled{background:#e4e7eb;color:#3e4c59}.badge--expired{background:#eceff3;color:var(--muted)}.badge--used{background:#d7e7f7;color:var(--brand-dark)}.badge--revoked{background:#fbe2e0;color:var(--danger)}.badge--auto_allow{background:#dcf2e3;color:var(--ok)}.badge--manual_allow{background:#fdf3d7;color:#8a6100}.badge--deny{background:#fbe2e0;color:var(--danger)}.card{background:#fff;border:1px solid var(--border);border-radius:8px;padding:24px;margin-bottom:20px}.form .field{margin-bottom:16px}.field{display:block}.field>span{display:block;margin-bottom:5px;font-size:13.5px;font-weight:600;color:var(--brand-dark)}.field>span em{color:var(--danger);font-style:normal}.field input,.field select,.field textarea{width:100%;padding:8px 10px;border:1px solid var(--border);border-radius:6px;font:inherit;color:var(--text);background:#fff}.field input:focus,.field select:focus,.field textarea:focus{outline:2px solid var(--brand);outline-offset:-1px;border-color:var(--brand)}.field--inline{width:240px}.field-error{display:block;margin-top:4px;color:var(--danger);font-size:13px}.form-section{border:1px solid var(--border);border-radius:8px;padding:16px;margin:0 0 16px}.form-section legend{padding:0 6px;font-size:13.5px;font-weight:600;color:var(--muted)}.form-actions{display:flex;gap:12px;margin-top:8px}.btn{display:inline-block;padding:8px 18px;border-radius:6px;border:1px solid transparent;font:inherit;font-weight:600;cursor:pointer;text-decoration:none;text-align:center}.btn:disabled{opacity:.55;cursor:default}.btn--primary{background:var(--brand);color:#fff}.btn--primary:hover:not(:disabled){background:var(--brand-dark)}.btn--danger{background:var(--danger);color:#fff}.btn--danger:hover:not(:disabled){background:#8f1d17}.btn--secondary{background:#fff;color:var(--brand);border-color:var(--border)}.btn--secondary:hover:not(:disabled){background:var(--brand-light)}.btn--small{padding:4px 12px;font-size:13px}.btn--ghost{background:transparent;color:#fff;border-color:#fff9}.btn--ghost:hover{background:var(--brand-dark)}.btn--block{display:block;width:100%}.btn-link{background:none;border:none;padding:0;font:inherit;color:var(--brand);cursor:pointer;text-decoration:underline}.banner{padding:10px 14px;border-radius:6px;margin:12px 0;font-size:14px}.banner--error{background:#fbe2e0;color:var(--danger);border:1px solid #f2b8b5}.form-error{color:var(--danger);font-size:13.5px;margin-bottom:12px}.hint{color:var(--muted);font-size:13.5px;margin:0 0 14px}.field .hint{display:block;margin:4px 0 0;font-size:12.5px}.details{margin:0;display:grid;grid-template-columns:1fr 1fr;gap:14px 24px}.details>div{min-width:0}.details dt{font-size:12.5px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:3px}.details dd{margin:0;overflow-wrap:anywhere}.actions .review-block{margin-top:8px}.login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(160deg,var(--brand) 0%,var(--brand-dark) 100%);padding:24px}.login-card{width:100%;max-width:380px;background:#fff;border-radius:10px;padding:32px 28px;box-shadow:0 12px 40px #0b3a6366}.login-brand{margin:0;text-align:center;color:var(--brand);font-size:26px}.login-subtitle{margin:6px 0 20px;text-align:center;color:var(--muted);font-size:14px}.login-form .field{margin-bottom:14px}.login-form .btn-link{display:block;margin:12px auto 0}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 20px}.form-grid .field{margin-bottom:16px}.field--checkbox{display:flex;align-items:center;gap:8px}.field--checkbox input{width:auto}.field--checkbox>span{margin-bottom:0}.banner--ok{background:#dcf2e3;color:var(--ok);border:1px solid #b3e0c2}.details-wide{grid-column:1 / -1}.history{list-style:none;margin:0;padding:0}.history-step{display:flex;flex-wrap:wrap;gap:4px 12px;align-items:baseline;padding:8px 0 8px 18px;border-left:3px solid var(--border);color:var(--muted)}.history-step--done{border-left-color:var(--brand);color:var(--text)}.history-label{font-weight:600}.history-actor{font-size:13px;color:var(--muted)}.history-comment{flex-basis:100%;font-size:13.5px;color:var(--text)}.qr-card{max-width:360px;margin:0 auto 20px;background:#fff;border:1px solid var(--border);border-radius:12px;padding:24px;text-align:center;box-shadow:0 4px 16px #0f4c811f}.qr-image{display:block;width:100%;max-width:312px;margin:0 auto;background:#fff;image-rendering:pixelated}.qr-plate{margin-top:12px;font-size:24px;font-weight:700;letter-spacing:.08em}.qr-meta{margin-top:4px;color:var(--muted);font-size:14px}.action-row{display:flex;gap:12px;align-items:flex-end;margin-bottom:14px}.action-row .field{flex:1;margin-bottom:0}.action-row .btn{flex-shrink:0}.gate-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(310px,1fr));gap:16px;margin-bottom:8px}.gate-card{background:#fff;border:1px solid var(--border);border-radius:8px;padding:16px 18px}.gate-card-head{display:flex;align-items:center;gap:8px;margin-bottom:12px}.gate-card-name{font-size:16px;font-weight:700;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.gate-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.gate-dot--online{background:var(--ok)}.gate-dot--offline{background:#9aa7b4}.gate-state{font-size:13px;font-weight:600}.gate-state--online{color:var(--ok)}.gate-state--offline{color:var(--muted)}.gate-card-meta{margin:0;display:grid;grid-template-columns:1fr 1fr;gap:10px 16px}.gate-card-meta dt{font-size:11.5px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:2px}.gate-card-meta dd{margin:0}.gate-journal-title{margin-top:24px}.tabs{display:flex;border-bottom:2px solid var(--border);margin-bottom:20px}.tab{flex:1;background:none;border:none;padding:10px 0;font:inherit;font-weight:600;color:var(--muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px}.tab--active{color:var(--brand);border-bottom-color:var(--brand)}
