:root{--brand: #0f4c81;--brand-dark: #0b3a63;--brand-darker: #082c4b;--brand-light: #e8f0f7;--brand-tint: #f0f5fa;--accent: #2a7de1;--text: #1f2933;--muted: #6b7a8c;--faint: #93a1b0;--border: #dde4ec;--border-strong: #c6d2de;--bg: #eef2f6;--surface: #ffffff;--danger: #b3261e;--danger-bg: #fbe9e7;--ok: #1d7a3e;--ok-bg: #e6f4ea;--warn: #8a6100;--warn-bg: #fdf3d7;--radius: 10px;--radius-sm: 7px;--shadow-sm: 0 1px 2px rgba(15, 42, 75, .06), 0 1px 3px rgba(15, 42, 75, .08);--shadow-md: 0 4px 16px rgba(15, 76, 129, .1);--sidebar-w: 244px}*{box-sizing:border-box}body{margin:0;font-family:Segoe UI,Segoe UI Variable Text,Tahoma,Arial,sans-serif;font-size:15px;line-height:1.45;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased}h1{font-size:23px;font-weight:650;margin:0;letter-spacing:-.01em}h2{font-size:16px;font-weight:650;margin:0 0 14px}a{color:var(--brand)}a:hover{color:var(--brand-dark)}.mono{font-family:Consolas,Cascadia Mono,ui-monospace,monospace;letter-spacing:.02em}.app{min-height:100vh;display:grid;grid-template-columns:var(--sidebar-w) 1fr}.sidebar{position:sticky;top:0;align-self:start;height:100vh;display:flex;flex-direction:column;background:linear-gradient(180deg,var(--brand-dark) 0%,var(--brand-darker) 100%);color:#fff;padding:18px 14px;gap:6px}.sidebar .brand{display:flex;align-items:center;gap:10px;color:#fff;font-size:18px;font-weight:750;text-decoration:none;letter-spacing:.02em;padding:6px 10px 16px}.brand-mark{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:8px;background:#ffffff29;font-size:15px;font-weight:800;flex-shrink:0}.nav{display:flex;flex-direction:column;gap:2px;overflow-y:auto}.nav-link{display:flex;align-items:center;gap:10px;color:#ffffffd1;text-decoration:none;padding:9px 12px;border-radius:8px;font-weight:550;font-size:14.5px;transition:background .12s,color .12s}.nav-link:hover{background:#ffffff1a;color:#fff}.nav-link--active{background:#ffffff29;color:#fff}.nav-ico{width:18px;text-align:center;flex-shrink:0;opacity:.9}.sidebar-foot{margin-top:auto;border-top:1px solid rgba(255,255,255,.14);padding-top:12px;display:flex;flex-direction:column;gap:8px}.user-label{display:block;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#ffffffeb;font-size:13.5px;text-decoration:none;padding:4px 8px}.user-label:hover{color:#fff;text-decoration:underline}.content{min-width:0;padding:26px 32px 56px;max-width:1180px}.page--narrow{max-width:720px}.page-head{display:flex;align-items:center;gap:16px;justify-content:space-between;margin:2px 0 22px}.back-link{display:inline-block;margin-bottom:14px;color:var(--muted);text-decoration:none;font-size:14px}.back-link:hover{color:var(--brand)}.page-loading,.empty{padding:40px 0;color:var(--muted);text-align:center}.empty{background:var(--surface);border:1px dashed var(--border-strong);border-radius:var(--radius)}.toolbar{display:flex;gap:16px;align-items:flex-end;flex-wrap:wrap;margin-bottom:18px}.table{width:100%;border-collapse:collapse;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm)}.table th{background:var(--brand-tint);color:var(--brand-dark);text-align:left;font-weight:650;padding:11px 16px;font-size:12.5px;text-transform:uppercase;letter-spacing:.03em;border-bottom:1px solid var(--border)}.table td{padding:11px 16px;border-top:1px solid var(--border);vertical-align:middle}.table tbody tr{transition:background .1s}.table tbody tr:hover{background:var(--brand-tint)}.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 11px;border-radius:999px;font-size:12.5px;font-weight:600;white-space:nowrap;border:1px solid transparent}.badge:before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor;opacity:.7}.badge--draft{background:#eef1f5;color:#54606e}.badge--pending_review{background:var(--warn-bg);color:var(--warn)}.badge--active{background:var(--ok-bg);color:var(--ok)}.badge--rejected{background:var(--danger-bg);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:var(--warn-bg);color:var(--warn)}.badge--pending_security{background:#fce8d4;color:#9a4b00}.badge--approved{background:var(--ok-bg);color:var(--ok)}.badge--issued{background:var(--brand);color:#fff}.badge--cancelled{background:#eef1f5;color:#54606e}.badge--expired{background:#eceff3;color:var(--muted)}.badge--used{background:#d7e7f7;color:var(--brand-dark)}.badge--revoked{background:var(--danger-bg);color:var(--danger)}.badge--auto_allow{background:var(--ok-bg);color:var(--ok)}.badge--manual_allow{background:var(--warn-bg);color:var(--warn)}.badge--deny{background:var(--danger-bg);color:var(--danger)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:22px 24px;margin-bottom:20px;box-shadow:var(--shadow-sm)}.card-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}.card-head h2{margin:0}.form .field{margin-bottom:16px}.field{display:block}.field>span{display:block;margin-bottom:5px;font-size:13px;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:9px 11px;border:1px solid var(--border-strong);border-radius:var(--radius-sm);font:inherit;color:var(--text);background:var(--surface);transition:border-color .12s,box-shadow .12s}.field input:hover:not(:disabled),.field select:hover:not(:disabled),.field textarea:hover:not(:disabled){border-color:var(--accent)}.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px #2a7de12e}.field input:disabled,.field select:disabled,.field textarea:disabled{background:var(--brand-tint);color:var(--muted);cursor:not-allowed}.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:var(--radius-sm);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;flex-wrap:wrap}.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:9px}.field--checkbox input{width:auto}.field--checkbox>span{margin-bottom:0}.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:9px 18px;border-radius:var(--radius-sm);border:1px solid transparent;font:inherit;font-weight:600;cursor:pointer;text-decoration:none;text-align:center;transition:background .12s,border-color .12s,box-shadow .12s,transform .04s}.btn:active:not(:disabled){transform:translateY(1px)}.btn:focus-visible{outline:none;box-shadow:0 0 0 3px #2a7de152}.btn:disabled{opacity:.5;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:var(--surface);color:var(--brand);border-color:var(--border-strong)}.btn--secondary:hover:not(:disabled){background:var(--brand-light);border-color:var(--brand)}.btn--small{padding:5px 13px;font-size:13px}.btn--ghost{background:#ffffff1a;color:#fff;border-color:#ffffff73}.btn--ghost:hover:not(:disabled){background:#fff3}.btn--block{display:flex;width:100%}.btn-link{background:none;border:none;padding:0;font:inherit;color:var(--brand);cursor:pointer;text-decoration:underline}.btn-link:hover{color:var(--brand-dark)}.banner{padding:11px 15px;border-radius:var(--radius-sm);margin:12px 0;font-size:14px;display:flex;gap:9px;align-items:flex-start}.banner:before{font-weight:700;flex-shrink:0}.banner--error{background:var(--danger-bg);color:var(--danger);border:1px solid #f2b8b5}.banner--error:before{content:"!"}.banner--ok{background:var(--ok-bg);color:var(--ok);border:1px solid #b3e0c2}.banner--ok:before{content:"✓"}.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:16px 28px}.details>div{min-width:0}.details dt{font-size:11.5px;font-weight:650;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:3px}.details dd{margin:0;overflow-wrap:anywhere}.details-wide{grid-column:1 / -1}.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-darker) 100%);padding:24px}.login-card{width:100%;max-width:384px;background:var(--surface);border-radius:14px;padding:34px 30px;box-shadow:0 18px 50px #082c4b73}.login-brand{margin:0;text-align:center;color:var(--brand);font-size:27px}.login-subtitle{margin:6px 0 22px;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}.guest-page{min-height:100vh;display:flex;align-items:flex-start;justify-content:center;padding:32px 16px;background:var(--bg)}.guest-card{width:100%;max-width:460px}.status{font-weight:600;margin:0 0 8px}.status--ok{color:var(--ok)}.status--warn{color:var(--danger)}.history{list-style:none;margin:0;padding:0}.history-step{display:flex;flex-wrap:wrap;gap:4px 12px;align-items:baseline;padding:9px 0 9px 18px;border-left:3px solid var(--border-strong);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:var(--surface);border:1px solid var(--border);border-radius:14px;padding:24px;text-align:center;box-shadow:var(--shadow-md)}.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:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px 18px;box-shadow:var(--shadow-sm)}.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}.role-chips{display:flex;flex-wrap:wrap;gap:6px}.role-chip{display:inline-flex;align-items:center;gap:6px;padding:3px 6px 3px 11px;border-radius:999px;font-size:12.5px;font-weight:600;background:var(--brand-light);color:var(--brand-dark);border:1px solid var(--border)}.role-chip-x{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border:none;border-radius:50%;background:transparent;color:var(--muted);font-size:12px;cursor:pointer;padding:0}.role-chip-x:hover:not(:disabled){background:var(--danger);color:#fff}.role-chip-x:disabled{opacity:.4;cursor:default}.tabs{display:flex;gap:4px;border-bottom:2px solid var(--border);margin-bottom:20px}.tab{background:none;border:none;padding:10px 18px;font:inherit;font-weight:600;color:var(--muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px}.tab:hover{color:var(--brand-dark)}.tab--active{color:var(--brand);border-bottom-color:var(--brand)}@media (max-width: 900px){.app{grid-template-columns:1fr}.sidebar{position:static;height:auto;flex-direction:row;flex-wrap:wrap;align-items:center;padding:10px 16px}.sidebar .brand{padding:0 12px 0 0}.nav{flex-direction:row;flex-wrap:wrap;flex:1}.sidebar-foot{margin:0 0 0 auto;border:none;padding:0;flex-direction:row;align-items:center}.content{padding:20px 18px 40px}.form-grid,.details{grid-template-columns:1fr}}
