*{box-sizing:border-box;margin:0;padding:0}body{color:#eee;-webkit-text-size-adjust:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#111;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:16px}a{color:#2563eb;text-decoration:none}a:hover{text-decoration:underline}nav{background:#1a1a1a;border-bottom:1px solid #333;padding:12px 16px}.nav-inner{justify-content:space-between;align-items:center;max-width:900px;margin:0 auto;display:flex}.nav-brand{color:#2563eb;font-size:20px;font-weight:700;text-decoration:none}.nav-brand:hover{text-decoration:none}.nav-right{align-items:center;gap:16px;font-size:14px;display:flex}.nav-credits{color:#f59e0b;font-weight:600}.nav-link{color:#aaa;text-decoration:none}.nav-link:hover{color:#eee;text-decoration:none}.nav-user{color:#888;font-size:13px}.nav-logout-btn{color:#aaa;cursor:pointer;background:0 0;border:none;padding:0;font-family:inherit;font-size:14px}.nav-logout-btn:hover{color:#eee}.container{max-width:900px;margin:0 auto;padding:16px}button,.btn{cursor:pointer;border:none;border-radius:8px;padding:10px 20px;font-family:inherit;font-size:16px;font-weight:600}.btn-primary{color:#fff;background:#2563eb}.btn-primary:hover{background:#1d4ed8}.btn-primary:disabled{color:#888;cursor:default;background:#333}.btn-danger{color:#fff;background:#dc2626}.btn-danger:hover{background:#b91c1c}.btn-sm{padding:6px 14px;font-size:14px}input[type=text],input[type=email],input[type=password],input[type=number],select,textarea{color:#eee;background:#222;border:1px solid #444;border-radius:6px;width:100%;padding:10px 12px;font-family:inherit;font-size:16px}input:focus,select:focus,textarea:focus{border-color:#2563eb;outline:none}label{color:#aaa;margin-bottom:4px;font-size:14px;display:block}.card{background:#1a1a1a;border-radius:8px;padding:16px}.section-title{color:#888;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;font-size:13px}.page{padding:16px 0}.page h1{margin-bottom:16px;font-size:24px}.loading{justify-content:center;align-items:center;min-height:200px;display:flex}.loading-spinner{border:3px solid #333;border-top-color:#2563eb;border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.error-message{color:#ef4444;margin-top:8px;font-size:14px}.success-message{color:#22c55e;margin-top:8px;font-size:14px}
