#app{width:100%;min-height:100vh;background:var(--background)}.offline-banner{position:fixed;top:0;left:0;right:0;background:var(--status-warning-bg);color:var(--status-warning-text);padding:var(--spacing-sm);text-align:center;font-size:var(--text-sm);font-weight:600;z-index:9999;border-bottom:2px solid var(--status-warning-text)}.offline .offline-banner{animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--primary-black: #1a1a1a;--primary-white: #ffffff;--background: #fafafa;--card-bg: #ffffff;--text-primary: #1a1a1a;--text-secondary: #666666;--text-light: #999999;--border-light: #f0f0f0;--border-medium: #e0e0e0;--status-ok-bg: #e8f5e9;--status-ok-text: #2e7d32;--status-warning-bg: #fff8e1;--status-warning-text: #f57c00;--status-danger-bg: #ffebee;--status-danger-text: #c62828;--role-superadmin: #ffd700;--role-admin: #3498db;--role-user: #95a5a6;--text-xs: .7rem;--text-sm: .85rem;--text-base: .95rem;--text-lg: 1.25rem;--text-xl: 1.5rem;--spacing-xs: 8px;--spacing-sm: 12px;--spacing-md: 16px;--spacing-lg: 20px;--spacing-xl: 24px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .04);--shadow-md: 0 4px 16px rgba(0, 0, 0, .06);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .08);--shadow-card: 0 2px 8px rgba(0, 0, 0, .08);--transition-fast: .2s ease;--transition-normal: .3s cubic-bezier(.4, 0, .2, 1);--transition-slow: .5s ease-out;--tap-scale: .98}html,body{width:100%;height:100%;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Inter,system-ui,sans-serif;font-size:var(--text-base);color:var(--text-primary);background:var(--background);line-height:1.6;letter-spacing:-.01em}body{-webkit-tap-highlight-color:transparent;touch-action:manipulation}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.3;margin-bottom:var(--spacing-sm)}h1{font-size:var(--text-xl)}h2{font-size:var(--text-lg)}h3{font-size:var(--text-base)}p{margin-bottom:var(--spacing-sm)}a{color:var(--primary-black);text-decoration:none;transition:opacity var(--transition-fast)}a:active{opacity:.7}button{font-family:inherit;font-size:var(--text-base);border:none;cursor:pointer;transition:transform var(--transition-fast),opacity var(--transition-fast);-webkit-tap-highlight-color:transparent}button:active{transform:scale(var(--tap-scale))}button:disabled{opacity:.5;cursor:not-allowed}.btn{padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--radius-md);font-weight:600;display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-xs);min-height:48px}.btn-primary{background:var(--primary-black);color:var(--primary-white)}.btn-outline{background:transparent;color:var(--primary-black);border:1.5px solid var(--primary-black)}.btn-outline:hover{background:var(--primary-black);color:var(--primary-white)}.btn-secondary{background:var(--background);color:var(--text-primary);border:1.5px solid var(--border-medium)}.btn-danger{background:var(--status-danger-bg);color:var(--status-danger-text)}.btn-success{background:var(--status-ok-bg);color:var(--status-ok-text)}.btn-block{width:100%}.card{background:var(--card-bg);border-radius:12px;padding:16px;box-shadow:var(--shadow-card);transition:box-shadow var(--transition-normal),transform var(--transition-fast);border:1px solid var(--border-light)}.card:active{transform:scale(.98);box-shadow:var(--shadow-md)}.card-title{font-size:var(--text-lg);font-weight:600;margin-bottom:var(--spacing-sm)}.card-subtitle{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--spacing-xs)}.badge{display:inline-block;padding:4px 10px;border-radius:var(--radius-sm);font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.badge-ok{background:var(--status-ok-bg);color:var(--status-ok-text)}.badge-warning{background:var(--status-warning-bg);color:var(--status-warning-text)}.badge-danger{background:var(--status-danger-bg);color:var(--status-danger-text)}input,textarea,select{font-family:inherit;font-size:var(--text-base);padding:var(--spacing-md);border:2px solid var(--border-light);border-radius:var(--radius-md);background:var(--card-bg);color:var(--text-primary);width:100%;transition:border-color var(--transition-fast)}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--primary-black)}input::placeholder,textarea::placeholder{color:var(--text-light)}label{display:block;font-size:var(--text-sm);font-weight:600;margin-bottom:var(--spacing-xs);color:var(--text-primary)}.form-group{margin-bottom:var(--spacing-md)}input[type=checkbox],input[type=radio]{width:auto;margin-right:var(--spacing-xs);cursor:pointer;min-width:20px;min-height:20px}.spinner{width:40px;height:40px;border:4px solid var(--border-light);border-top-color:var(--primary-black);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-container{display:flex;justify-content:center;align-items:center;min-height:200px}.fab{position:fixed;bottom:80px;right:var(--spacing-md);width:64px;height:64px;border-radius:50%;background:var(--primary-black);color:var(--primary-white);box-shadow:var(--shadow-lg);display:flex;align-items:center;justify-content:center;font-size:28px;z-index:100;transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.fab:active{transform:scale(.95);box-shadow:var(--shadow-md)}.container{padding:var(--spacing-md);max-width:600px;margin:0 auto}.container-full{padding:0;width:100%}.grid{display:grid;gap:var(--spacing-md)}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-xs{gap:var(--spacing-xs)}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.gap-lg{gap:var(--spacing-lg)}.mt-xs{margin-top:var(--spacing-xs)}.mt-sm{margin-top:var(--spacing-sm)}.mt-md{margin-top:var(--spacing-md)}.mt-lg{margin-top:var(--spacing-lg)}.mt-xl{margin-top:var(--spacing-xl)}.mb-xs{margin-bottom:var(--spacing-xs)}.mb-sm{margin-bottom:var(--spacing-sm)}.mb-md{margin-bottom:var(--spacing-md)}.mb-lg{margin-bottom:var(--spacing-lg)}.mb-xl{margin-bottom:var(--spacing-xl)}.p-xs{padding:var(--spacing-xs)}.p-sm{padding:var(--spacing-sm)}.p-md{padding:var(--spacing-md)}.p-lg{padding:var(--spacing-lg)}.p-xl{padding:var(--spacing-xl)}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.text-xs{font-size:var(--text-xs)}.text-sm{font-size:var(--text-sm)}.text-base{font-size:var(--text-base)}.text-lg{font-size:var(--text-lg)}.text-xl{font-size:var(--text-xl)}.text-bold{font-weight:600}.text-normal{font-weight:400}.text-primary{color:var(--text-primary)}.text-secondary{color:var(--text-secondary)}.text-light{color:var(--text-light)}@supports (padding: env(safe-area-inset-top)){.safe-top{padding-top:env(safe-area-inset-top)}.safe-bottom{padding-bottom:env(safe-area-inset-bottom)}}.fade-enter-active,.fade-leave-active{transition:opacity var(--transition-normal)}.fade-enter-from,.fade-leave-to{opacity:0}.slide-up-enter-active,.slide-up-leave-active{transition:transform var(--transition-normal),opacity var(--transition-normal)}.slide-up-enter-from,.slide-up-leave-to{transform:translateY(20px);opacity:0}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--background)}::-webkit-scrollbar-thumb{background:var(--border-medium);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}img{max-width:100%;height:auto;display:block}.no-select{-webkit-user-select:none;user-select:none}
