:root{--color-primary: #dc2626;--color-primary-dark: #991b1b;--color-primary-light: #ef4444;--color-primary-lighter: #fca5a5;--color-bg: #ffffff;--color-bg-secondary: #f8f9fa;--color-bg-tertiary: #f1f3f5;--color-text: #1a1a1a;--color-text-secondary: #64748b;--color-border: #e2e8f0;--color-success: #10b981;--color-error: #ef4444;--color-warning: #f59e0b;--shadow-sm: 0 1px 3px 0 rgba(0, 0, 0, .08);--shadow-md: 0 4px 12px 0 rgba(0, 0, 0, .1);--shadow-lg: 0 10px 25px -5px rgba(0, 0, 0, .12);--shadow-xl: 0 20px 40px -10px rgba(0, 0, 0, .15);--radius-sm: .5rem;--radius-md: .75rem;--radius-lg: 1rem;--radius-xl: 1.5rem;--transition: all .2s cubic-bezier(.4, 0, .2, 1)}@media(prefers-color-scheme:dark){:root{--color-bg: #0f1419;--color-bg-secondary: #1a1f2e;--color-bg-tertiary: #252b3b;--color-text: #f8f9fa;--color-text-secondary: #94a3b8;--color-border: #2d3748;--shadow-sm: 0 1px 3px 0 rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px 0 rgba(0, 0, 0, .4);--shadow-lg: 0 10px 25px -5px rgba(0, 0, 0, .5);--shadow-xl: 0 20px 40px -10px rgba(0, 0, 0, .6)}}*{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth}body{font-family:-apple-system,BlinkMacSystemFont,Inter,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--color-bg);color:var(--color-text);line-height:1.6;min-height:100vh}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:var(--color-bg-secondary)}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-md)}::-webkit-scrollbar-thumb:hover{background:var(--color-text-secondary)}button{font-family:inherit;cursor:pointer;border:none;outline:none;background:none;transition:var(--transition)}button:active{transform:translateY(1px)}input,textarea,select{font-family:inherit;outline:none;transition:var(--transition)}.btn-primary{background-color:var(--color-primary);color:#fff;padding:.875rem 1.75rem;border-radius:var(--radius-md);font-weight:600;font-size:.9375rem;letter-spacing:.01em;box-shadow:0 2px 8px #dc262633;transition:var(--transition)}.btn-primary:hover{background-color:var(--color-primary-dark);box-shadow:0 4px 12px #dc26264d;transform:translateY(-1px)}.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.btn-secondary{background-color:var(--color-bg-secondary);color:var(--color-text);padding:.875rem 1.75rem;border-radius:var(--radius-md);border:1.5px solid var(--color-border);font-weight:600;font-size:.9375rem;transition:var(--transition)}.btn-secondary:hover{background-color:var(--color-bg-tertiary);border-color:var(--color-text-secondary);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.btn-edit{background-color:transparent;color:var(--color-text-secondary);padding:.5rem .75rem;border-radius:var(--radius-sm);border:1px solid var(--color-border);font-size:.875rem;cursor:pointer;transition:var(--transition)}.btn-edit:hover{background-color:var(--color-bg-secondary);color:var(--color-primary);border-color:var(--color-primary-lighter)}.btn-save{background-color:var(--color-success);color:#fff;padding:.5rem .75rem;border-radius:var(--radius-sm);font-size:.875rem;font-weight:600;cursor:pointer}.btn-save:hover{background-color:#059669}.btn-cancel{background-color:var(--color-error);color:#fff;padding:.5rem .75rem;border-radius:var(--radius-sm);font-size:.875rem;font-weight:600;cursor:pointer}.btn-cancel:hover{background-color:#dc2626}.action-buttons{display:flex;gap:.5rem;align-items:center}.input-field{width:100%;padding:.875rem 1rem;border:1.5px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-bg);color:var(--color-text);font-size:.9375rem;transition:var(--transition)}.input-field:hover{border-color:var(--color-text-secondary)}.input-field:focus{border-color:var(--color-primary);box-shadow:0 0 0 4px #dc262614;background-color:var(--color-bg)}.edit-input{padding:.5rem;border:1.5px solid var(--color-primary-lighter);border-radius:var(--radius-sm);background-color:var(--color-bg);color:var(--color-text);font-size:.9375rem;width:100%}.edit-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #dc26261f}.card{background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:2rem;box-shadow:var(--shadow-md);transition:var(--transition)}.card:hover{box-shadow:var(--shadow-lg)}@media(max-width:1024px){html{font-size:15px}}@media(max-width:768px){html{font-size:14px}.btn-primary,.btn-secondary{padding:.75rem 1.5rem;font-size:.875rem}}@media(max-width:640px){.card{padding:1.5rem}}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem 1.5rem;background:linear-gradient(135deg,var(--color-bg) 0%,var(--color-bg-secondary) 100%);position:relative;overflow:hidden}.auth-container:before{content:"";position:absolute;top:-50%;right:-20%;width:600px;height:600px;background:radial-gradient(circle,rgba(220,38,38,.06) 0%,transparent 70%);pointer-events:none}.auth-container:after{content:"";position:absolute;bottom:-30%;left:-10%;width:500px;height:500px;background:radial-gradient(circle,rgba(220,38,38,.04) 0%,transparent 70%);pointer-events:none}.auth-card{background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:3rem 2.5rem;max-width:460px;width:100%;box-shadow:var(--shadow-xl);position:relative;z-index:1;animation:fadeSlideUp .4s ease-out}@keyframes fadeSlideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.auth-header{text-align:center;margin-bottom:2.5rem}.auth-logo{width:64px;height:64px;background:linear-gradient(135deg,var(--color-primary-light) 0%,var(--color-primary) 100%);border-radius:var(--radius-lg);margin:0 auto 1.5rem;display:flex;align-items:center;justify-content:center;font-size:2rem;color:#fff;font-weight:700;box-shadow:0 8px 20px #dc262640}.auth-header h1{font-size:2rem;font-weight:800;color:var(--color-text);margin-bottom:.625rem;letter-spacing:-.03em}.auth-header p{font-size:.9375rem;color:var(--color-text-secondary);line-height:1.5}.auth-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.625rem}.form-group label{font-size:.9375rem;font-weight:600;color:var(--color-text);letter-spacing:.005em}.auth-message{padding:1rem 1.125rem;border-radius:var(--radius-md);margin-bottom:1rem;font-size:.9375rem;font-weight:500;animation:slideIn .3s ease-out}.auth-message.success{background-color:#10b9811f;color:var(--color-success);border:1.5px solid rgba(16,185,129,.3)}.auth-message.error{background-color:#ef44441f;color:var(--color-error);border:1.5px solid rgba(239,68,68,.3)}.first-admin-section{margin-top:2rem;padding-top:2rem;border-top:1px solid var(--color-border)}.first-admin-section h2{font-size:1.375rem;font-weight:700;color:var(--color-text);margin-bottom:.75rem;letter-spacing:-.01em}.first-admin-section p{font-size:.9375rem;color:var(--color-text-secondary);margin-bottom:1.5rem;line-height:1.6}.loading-spinner{width:20px;height:20px;border:2.5px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;display:inline-block;margin-right:.5rem;vertical-align:middle}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:640px){.auth-container{padding:1.5rem 1rem}.auth-container:before,.auth-container:after{display:none}.auth-card{padding:2rem 1.5rem;border-radius:var(--radius-lg)}.auth-logo{width:56px;height:56px;font-size:1.75rem}.auth-header h1{font-size:1.625rem}.auth-header p{font-size:.875rem}.first-admin-section h2{font-size:1.25rem}.first-admin-section p{font-size:.875rem}}@media(max-width:480px){.auth-card{padding:1.75rem 1.25rem}.auth-header{margin-bottom:2rem}.auth-form{gap:1.25rem}}@media(hover:none)and (pointer:coarse){.input-field{min-height:48px;font-size:16px}.btn-primary{min-height:48px}}.dashboard-container{min-height:100vh;background:linear-gradient(135deg,var(--color-bg) 0%,var(--color-bg-secondary) 100%);padding:2rem 1.5rem}.dashboard-header{max-width:1280px;margin:0 auto 2.5rem;display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}.dashboard-header h1{font-size:2.25rem;font-weight:700;color:var(--color-text);letter-spacing:-.03em}.dashboard-welcome{color:var(--color-text-secondary);font-size:1rem;margin-top:.5rem}.apps-grid{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}.app-card{background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:2rem;box-shadow:var(--shadow-md);display:flex;flex-direction:column;gap:1.25rem;transition:var(--transition);cursor:pointer}.app-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-xl);border-color:var(--color-primary-lighter)}.app-card:active{transform:translateY(-2px)}.app-icon{width:56px;height:56px;background:linear-gradient(135deg,var(--color-primary-lighter) 0%,var(--color-primary-light) 100%);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:1.75rem;box-shadow:0 4px 12px #dc262626;transition:var(--transition)}.app-card:hover .app-icon{transform:scale(1.05);box-shadow:0 6px 16px #dc262640}.app-info h3{font-size:1.375rem;font-weight:700;color:var(--color-text);margin-bottom:.625rem;letter-spacing:-.01em}.app-info p{font-size:.9375rem;color:var(--color-text-secondary);line-height:1.6}.app-connect{margin-top:auto;padding-top:1rem;border-top:1px solid var(--color-border);display:flex;justify-content:space-between;align-items:center}.app-connect .btn-primary{width:100%}.empty-state{text-align:center;padding:4rem 2rem;max-width:600px;margin:0 auto}.empty-state-icon{font-size:4rem;margin-bottom:1.5rem;opacity:.5}.empty-state h2{font-size:1.875rem;font-weight:700;color:var(--color-text);margin-bottom:1rem}.empty-state p{font-size:1.0625rem;color:var(--color-text-secondary);line-height:1.6}@media(max-width:768px){.dashboard-container{padding:1.5rem 1rem}.dashboard-header{margin-bottom:2rem}.dashboard-header h1{font-size:1.75rem}.dashboard-welcome{font-size:.9375rem}.apps-grid{grid-template-columns:1fr;gap:1.25rem}.app-card{padding:1.5rem}.empty-state{padding:3rem 1.5rem}.empty-state h2{font-size:1.5rem}}@media(max-width:640px){.app-icon{width:48px;height:48px;font-size:1.5rem}.app-info h3{font-size:1.25rem}.app-info p{font-size:.875rem}.empty-state-icon{font-size:3rem}.empty-state h2{font-size:1.375rem}.empty-state p{font-size:1rem}}@media(hover:none)and (pointer:coarse){.app-card{min-height:200px}.app-connect .btn-primary{min-height:48px}}.admin-container{min-height:100vh;background:linear-gradient(135deg,var(--color-bg) 0%,var(--color-bg-secondary) 100%);display:flex}.admin-sidebar{width:280px;background-color:var(--color-bg);border-right:1px solid var(--color-border);padding:2rem 1.5rem;box-shadow:var(--shadow-sm);overflow-y:auto}.admin-content{flex:1;padding:2rem 2.5rem;overflow-y:auto;max-width:1400px;margin:0 auto;width:100%}.admin-header{margin-bottom:2.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--color-border)}.admin-header h1{font-size:2.25rem;font-weight:700;color:var(--color-text);margin-bottom:.75rem;letter-spacing:-.02em}.admin-header p{color:var(--color-text-secondary);font-size:.9375rem;line-height:1.5}.sidebar-nav{list-style:none;display:flex;flex-direction:column;gap:.5rem}.sidebar-nav button{width:100%;padding:.875rem 1.25rem;text-align:left;border-radius:var(--radius-md);color:var(--color-text);font-weight:600;font-size:.9375rem;transition:var(--transition);display:flex;align-items:center;gap:.75rem}.sidebar-nav button:hover{background-color:var(--color-bg-secondary);transform:translate(4px)}.sidebar-nav button.active{background-color:var(--color-primary);color:#fff;box-shadow:0 4px 12px #dc262640}.admin-section{background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:2rem;box-shadow:var(--shadow-md);margin-bottom:2rem;transition:var(--transition)}.admin-section:hover{box-shadow:var(--shadow-lg)}.admin-section h2{font-size:1.625rem;font-weight:700;color:var(--color-text);margin-bottom:1.75rem;letter-spacing:-.01em;display:flex;align-items:center;gap:.75rem}.admin-table{width:100%;border-collapse:separate;border-spacing:0;overflow:hidden;border-radius:var(--radius-md)}.admin-table th,.admin-table td{padding:1.125rem 1.25rem;text-align:left;border-bottom:1px solid var(--color-border)}.admin-table th{font-weight:700;color:var(--color-text-secondary);font-size:.8125rem;text-transform:uppercase;letter-spacing:.08em;background-color:var(--color-bg-secondary)}.admin-table td{color:var(--color-text);font-size:.9375rem}.admin-table tbody tr{transition:var(--transition)}.admin-table tbody tr:hover{background-color:var(--color-bg-secondary)}.admin-table tbody tr:last-child td{border-bottom:none}.role-badge{display:inline-block;padding:.375rem .875rem;border-radius:var(--radius-md);font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;transition:var(--transition)}.role-badge.role-admin{background-color:var(--color-primary-lighter);color:var(--color-primary-dark);box-shadow:0 2px 6px #dc262626}.role-badge.role-user{background-color:var(--color-bg-tertiary);color:var(--color-text-secondary);box-shadow:0 2px 6px #0000000d}.message{padding:1.125rem 1.25rem;border-radius:var(--radius-md);margin-bottom:1.25rem;font-size:.9375rem;font-weight:500;display:flex;align-items:center;gap:.75rem;box-shadow:var(--shadow-sm);animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.message.success{background-color:#10b9811f;color:var(--color-success);border:1.5px solid rgba(16,185,129,.3)}.message.error{background-color:#ef44441f;color:var(--color-error);border:1.5px solid rgba(239,68,68,.3)}@media(max-width:1024px){.admin-container{flex-direction:column}.admin-sidebar{width:100%;border-right:none;border-bottom:1px solid var(--color-border);padding:1.5rem}.sidebar-nav{flex-direction:row;overflow-x:auto;padding-bottom:.5rem}.sidebar-nav button{white-space:nowrap;min-width:auto}.sidebar-nav button:hover{transform:translateY(-2px)}.admin-content{padding:2rem 1.5rem}}@media(max-width:768px){.admin-header h1{font-size:1.875rem}.admin-header p{font-size:.875rem}.admin-table{display:block;overflow-x:auto;white-space:nowrap}.admin-table th,.admin-table td{padding:.875rem 1rem;font-size:.875rem}}@media(max-width:640px){.admin-content{padding:1.5rem 1rem}.admin-section{padding:1.5rem}.admin-section h2{font-size:1.375rem}.message{font-size:.875rem;padding:1rem}.role-badge{font-size:.6875rem;padding:.3125rem .75rem}.admin-table th,.admin-table td{padding:.75rem .875rem;font-size:.8125rem}}@media(hover:none)and (pointer:coarse){.sidebar-nav button,.btn-primary,.btn-secondary,.btn-edit,.btn-save,.btn-cancel{min-height:44px;min-width:44px}}.oauth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem 1.5rem;background:linear-gradient(135deg,var(--color-bg) 0%,var(--color-bg-secondary) 100%)}.oauth-card{background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:2.5rem 2rem;max-width:520px;width:100%;box-shadow:var(--shadow-xl);animation:fadeSlideUp .4s ease-out}.oauth-header{text-align:center;margin-bottom:2.5rem;padding-bottom:2rem;border-bottom:1px solid var(--color-border)}.oauth-icon{width:72px;height:72px;background:linear-gradient(135deg,var(--color-primary-lighter) 0%,var(--color-primary-light) 100%);border-radius:var(--radius-lg);margin:0 auto 1.25rem;display:flex;align-items:center;justify-content:center;font-size:2.25rem;box-shadow:0 8px 20px #dc262633}.oauth-header h1{font-size:1.625rem;font-weight:700;color:var(--color-text);margin-bottom:.5rem;letter-spacing:-.02em}.oauth-app-name{font-size:1.125rem;font-weight:700;color:var(--color-primary);margin-bottom:.75rem}.oauth-header p{font-size:.9375rem;color:var(--color-text-secondary);line-height:1.6}.oauth-info{background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:1.5rem;margin-bottom:2rem}.oauth-info h3{font-size:1rem;font-weight:700;color:var(--color-text);margin-bottom:1.25rem;letter-spacing:-.01em}.oauth-permissions{display:flex;flex-direction:column;gap:1rem}.oauth-permission{display:flex;align-items:flex-start;gap:.875rem}.permission-icon{width:24px;height:24px;background-color:#10b98126;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--color-success);font-weight:700;font-size:.875rem}.oauth-permission p{font-size:.9375rem;color:var(--color-text);line-height:1.5}.oauth-user-info{background-color:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:1.25rem;margin-bottom:2rem;display:flex;align-items:center;gap:1rem}.oauth-avatar{width:48px;height:48px;background:linear-gradient(135deg,var(--color-primary-light) 0%,var(--color-primary) 100%);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:1.125rem;box-shadow:0 4px 12px #dc262633}.oauth-user-details h4{font-size:1rem;font-weight:700;color:var(--color-text);margin-bottom:.25rem}.oauth-user-details p{font-size:.875rem;color:var(--color-text-secondary)}.oauth-actions{display:flex;gap:1rem;margin-top:2rem}.oauth-actions button{flex:1}.oauth-error,.oauth-loading{text-align:center;padding:2rem}.oauth-error h2,.oauth-loading h2{font-size:1.5rem;font-weight:700;color:var(--color-text);margin-bottom:1rem;letter-spacing:-.01em}.oauth-error p,.oauth-loading p{font-size:1rem;color:var(--color-text-secondary);line-height:1.6;margin-bottom:1.5rem}.oauth-error-icon{font-size:3.5rem;margin-bottom:1.5rem;opacity:.6}@media(max-width:640px){.oauth-container{padding:1.5rem 1rem}.oauth-card{padding:2rem 1.5rem;border-radius:var(--radius-lg)}.oauth-icon{width:64px;height:64px;font-size:2rem}.oauth-header h1{font-size:1.375rem}.oauth-app-name{font-size:1rem}.oauth-header p{font-size:.875rem}.oauth-info{padding:1.25rem}.oauth-info h3{font-size:.9375rem}.oauth-permission p{font-size:.875rem}.oauth-actions{flex-direction:column-reverse}.oauth-actions button{width:100%}}@media(max-width:480px){.oauth-card{padding:1.75rem 1.25rem}.oauth-header{margin-bottom:2rem;padding-bottom:1.5rem}.oauth-user-info{flex-direction:column;text-align:center}.oauth-avatar{width:56px;height:56px;font-size:1.25rem}}@media(hover:none)and (pointer:coarse){.oauth-actions button{min-height:48px}}:root{--color-primary: #dc2626;--color-primary-dark: #991b1b;--color-primary-light: #ef4444;--color-primary-lighter: #fca5a5;--color-bg: #ffffff;--color-bg-secondary: #f9fafb;--color-bg-tertiary: #f3f4f6;--color-text: #1f2937;--color-text-secondary: #6b7280;--color-text-tertiary: #9ca3af;--color-border: #e5e7eb;--color-border-light: #f3f4f6;--color-success: #10b981;--color-warning: #f59e0b;--color-error: #ef4444;--color-info: #3b82f6;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1)}@media(prefers-color-scheme:dark){:root{--color-bg: #111827;--color-bg-secondary: #1f2937;--color-bg-tertiary: #374151;--color-text: #f9fafb;--color-text-secondary: #d1d5db;--color-text-tertiary: #9ca3af;--color-border: #374151;--color-border-light: #4b5563}}*{margin:0;padding:0;box-sizing:border-box}html,body{width:100%;height:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--color-bg);color:var(--color-text);transition:background-color .3s,color .3s}#root{width:100%;height:100%}h1{font-size:2rem;font-weight:700;line-height:1.2;margin-bottom:var(--spacing-lg)}h2{font-size:1.5rem;font-weight:700;line-height:1.3;margin-bottom:var(--spacing-md)}h3{font-size:1.25rem;font-weight:600;line-height:1.4;margin-bottom:var(--spacing-md)}p{line-height:1.6;margin-bottom:var(--spacing-md)}a{color:var(--color-primary);text-decoration:none;transition:color .2s}a:hover{color:var(--color-primary-dark)}.btn{display:inline-flex;align-items:center;justify-content:center;padding:var(--spacing-sm) var(--spacing-lg);font-size:1rem;font-weight:500;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all .2s;text-decoration:none;white-space:nowrap}.btn:active{transform:scale(.98)}.btn-primary{background-color:var(--color-primary);color:#fff}.btn-primary:hover{background-color:var(--color-primary-dark)}.btn-primary:disabled{background-color:var(--color-text-tertiary);cursor:not-allowed}.btn-secondary{background-color:var(--color-bg-secondary);color:var(--color-text);border:1px solid var(--color-border)}.btn-secondary:hover{background-color:var(--color-bg-tertiary)}.btn-outline{background-color:transparent;color:var(--color-primary);border:2px solid var(--color-primary)}.btn-outline:hover{background-color:var(--color-primary);color:#fff}.btn-small{padding:var(--spacing-xs) var(--spacing-md);font-size:.875rem}input,textarea,select{width:100%;padding:var(--spacing-sm) var(--spacing-md);font-size:1rem;border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-bg);color:var(--color-text);transition:border-color .2s}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #dc26261a}label{display:block;margin-bottom:var(--spacing-sm);font-weight:500;color:var(--color-text)}.form-group{margin-bottom:var(--spacing-lg)}.error-message{color:var(--color-error);font-size:.875rem;margin-top:var(--spacing-xs)}.success-message{color:var(--color-success);font-size:.875rem;margin-top:var(--spacing-xs)}.card{background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);transition:all .2s}.card:hover{box-shadow:var(--shadow-md)}.container{max-width:1200px;margin:0 auto;padding:0 var(--spacing-lg)}.grid{display:grid;gap:var(--spacing-lg)}.grid-cols-1{grid-template-columns:1fr}.grid-cols-2{grid-template-columns:repeat(2,1fr)}.grid-cols-3{grid-template-columns:repeat(3,1fr)}@media(max-width:768px){.grid-cols-2,.grid-cols-3{grid-template-columns:1fr}}.flex{display:flex}.flex-center{display:flex;align-items:center;justify-content:center}.flex-between{display:flex;align-items:center;justify-content:space-between}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.gap-lg{gap:var(--spacing-lg)}.mt-lg{margin-top:var(--spacing-lg)}.mb-lg{margin-bottom:var(--spacing-lg)}.text-center{text-align:center}.text-secondary{color:var(--color-text-secondary)}.text-sm{font-size:.875rem}.font-bold{font-weight:700}.opacity-50{opacity:.5}
