#app-root{min-height:100vh;display:flex;flex-direction:column}:root{--color-bg: #f2f5f8;--color-surface: #ffffff;--color-border: #D9D9D9;--color-primary: #113d6a;--color-primary-h: #135596;--color-accent: #9a7eb9;--color-accent-h: #ae8bd6;--color-danger: #e50000;--color-success: #26b050;--color-warning: #f0ad4e;--color-text: #1d1d1b;--color-text-muted: #6c757d;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--shadow-sm: 0 1px 3px rgba(0,0,0,.08);--shadow-md: 0 4px 12px rgba(0,0,0,.1);--shadow-lg: 0 8px 24px rgba(0,0,0,.12);--font-sans: "Open Sans", Helvetica, Arial, sans-serif;--font-serif: Georgia, "Times New Roman", serif;--transition: .15s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:18px;scroll-behavior:smooth}body{font-family:var(--font-sans);background:var(--color-bg);color:var(--color-text);line-height:1.6;-webkit-font-smoothing:antialiased}a{color:var(--color-accent);text-decoration:none}a:hover{text-decoration:underline}img,svg{display:block;max-width:100%}.container{width:100%;max-width:1100px;margin:0 auto;padding:0 1.5rem}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.5rem;box-shadow:var(--shadow-sm)}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.55rem 1.2rem;border:none;border-radius:var(--radius-md);font-size:.9rem;font-weight:600;cursor:pointer;transition:background var(--transition),opacity var(--transition);text-decoration:none}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--color-primary-h)}.btn-accent{background:var(--color-accent);color:#fff}.btn-accent:hover:not(:disabled){background:var(--color-accent-h)}.btn-outline{background:transparent;color:var(--color-primary);border:1.5px solid var(--color-primary)}.btn-outline:hover:not(:disabled){background:var(--color-primary);color:#fff}.btn-danger{background:var(--color-danger);color:#fff}.btn-danger:hover:not(:disabled){opacity:.85}.btn-sm{padding:.35rem .8rem;font-size:.82rem}.form-group{display:flex;flex-direction:column;gap:.35rem;margin-bottom:1.1rem}.form-group label{font-size:.85rem;font-weight:600;color:var(--color-text)}.form-group label .required{color:var(--color-danger);margin-left:2px}.form-control{width:100%;padding:.55rem .8rem;border:1.5px solid var(--color-border);border-radius:var(--radius-md);font-family:inherit;font-size:.95rem;background:var(--color-surface);color:var(--color-text);transition:border-color var(--transition),box-shadow var(--transition);-webkit-appearance:none;-moz-appearance:none;appearance:none}.form-control:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px #7c6a3e26}.form-control.error{border-color:var(--color-danger)}textarea.form-control{resize:vertical;min-height:100px}.form-error{font-size:.8rem;color:var(--color-danger)}.badge{display:inline-block;padding:.2rem .6rem;border-radius:20px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.badge-draft{background:#fef3c7;color:#92400e;border:1px solid #f5c842}.badge-pending{background:#fef3cd;color:#7a4f00}.badge-approved{background:#d4edda;color:#155724}.badge-rejected{background:#f8d7da;color:#721c24}.badge-active{background:#d4edda;color:#155724}.badge-blocked{background:#f8d7da;color:#721c24}.alert{padding:.8rem 1rem;border-radius:var(--radius-md);font-size:.9rem;margin-bottom:1rem}.alert-error{background:#fdecea;color:var(--color-danger);border:1px solid #f5c6cb}.alert-success{background:#e8f5e9;color:var(--color-success);border:1px solid #c3e6cb}.alert-info{background:#e8f0fe;color:#1a56db;border:1px solid #b3c8fc}.table-wrapper{overflow-x:auto;border-radius:var(--radius-md);border:1px solid var(--color-border)}table{width:100%;border-collapse:collapse}th,td{padding:.75rem 1rem;text-align:left;font-size:.9rem}th{background:var(--color-primary);color:#fff;font-weight:600;font-size:.82rem;text-transform:uppercase;letter-spacing:.05em}tr:nth-child(2n) td{background:#f9f8f6}tr:hover td{background:#f0ede8}td{border-bottom:1px solid var(--color-border);color:var(--color-text)}.spinner{width:36px;height:36px;border:3px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;animation:spin .7s linear infinite;margin:2rem auto}@keyframes spin{to{transform:rotate(360deg)}}.loading-center{display:flex;justify-content:center;padding:3rem}@media (max-width: 640px){.container{padding:0 1rem}.card{padding:1rem}}
