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}#root{min-height:100vh}.app-container{max-width:1200px;margin:0 auto;padding:20px}.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;border-bottom:1px solid #e0e0e0;padding-bottom:20px}.header h1{margin:0;font-size:28px;color:#333}.user-info{text-align:right}.user-info p{margin:0;color:#666;font-size:14px}.logout-btn{background:#dc3545;color:#fff;border:none;padding:8px 16px;border-radius:4px;cursor:pointer;font-size:14px;margin-top:10px}.logout-btn:hover{background:#c82333}.loading{display:flex;justify-content:center;align-items:center;min-height:400px;font-size:18px;color:#666}.error{background:#f8d7da;border:1px solid #f5c6cb;color:#721c24;padding:12px;border-radius:4px;margin-bottom:20px}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh}.login-box{text-align:center}.login-box h1{margin-bottom:20px;font-size:32px;color:#333}.login-btn{background:#007bff;color:#fff;border:none;padding:12px 24px;border-radius:4px;cursor:pointer;font-size:16px}.login-btn:hover{background:#0056b3}.apps-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}.app-card{border:1px solid #ddd;border-radius:8px;padding:20px;background:#fff;box-shadow:0 2px 4px #0000001a;transition:transform .2s,box-shadow .2s;cursor:pointer;text-decoration:none;color:inherit;display:block}.app-card:hover{transform:translateY(-4px);box-shadow:0 4px 12px #00000026}.app-icon{font-size:48px;margin-bottom:10px}.app-card h2{margin:10px 0 5px;font-size:20px;color:#333}.app-card p{margin:0;color:#666;font-size:14px}.empty-state{text-align:center;padding:60px 20px;color:#666}.empty-state p{font-size:18px}.admin-section{margin-top:40px;padding-top:30px;border-top:2px solid #e0e0e0}.admin-section h2{margin-bottom:20px;color:#333;font-size:24px}.admin-links{display:flex;gap:10px;margin-bottom:20px}.admin-links .btn{background:#6c757d;color:#fff;border:none;padding:10px 20px;border-radius:4px;cursor:pointer;font-size:15px;transition:all .2s}.admin-links .btn:hover{background:#5a6268}.admin-links .btn.active{background:var(--primary);box-shadow:0 0 0 3px #c84b3133}.admin-card{background:#fff;border:1px solid #ddd;border-radius:8px;padding:24px;box-shadow:0 2px 8px #0000001a}.admin-card h3{margin-top:0;margin-bottom:16px;color:#333;font-size:20px}.admin-card .info{background:#d1ecf1;border:1px solid #bee5eb;color:#0c5460;padding:10px;border-radius:4px;margin-bottom:16px;font-size:14px}.admin-table{width:100%;border-collapse:collapse;margin-top:10px}.admin-table thead{background:#f8f9fa}.admin-table th{padding:12px;text-align:left;font-weight:600;color:#333;border-bottom:2px solid #dee2e6;font-size:14px}.admin-table td{padding:12px;border-bottom:1px solid #dee2e6;vertical-align:middle}.admin-table tbody tr:hover{background:#f8f9fa}.admin-table input,.admin-table select{width:100%;padding:10px 12px;border:1px solid #ced4da;border-radius:4px;font-size:14px;box-sizing:border-box;font-family:inherit}.admin-table input:focus,.admin-table select:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.admin-table .btn{background:#28a745;color:#fff;border:none;padding:8px 16px;border-radius:4px;cursor:pointer;font-size:14px;white-space:nowrap;transition:background .2s}.admin-table .btn:hover{background:#218838}.admin-table .btn-delete{background:#dc3545}.admin-table .btn-delete:hover{background:#c82333}.roles-multi-select{display:flex;flex-wrap:wrap;gap:6px;align-items:center;min-height:38px;padding:6px;border:1px solid #ced4da;border-radius:4px;background:#fff}.roles-multi-select:focus-within{border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.role-tag{background:#007bff;color:#fff;padding:4px 8px;border-radius:3px;font-size:13px;display:flex;align-items:center;gap:6px}.role-tag button{background:none;border:none;color:#fff;cursor:pointer;padding:0;font-size:16px;line-height:1;opacity:.8;transition:opacity .2s}.role-tag button:hover{opacity:1}.role-input-wrapper{display:flex;gap:6px;flex:1;min-width:150px;align-items:center;flex-wrap:wrap}.role-input-wrapper select{flex:0 0 auto;border:1px solid #ced4da;padding:6px;font-size:13px;border-radius:3px;background:#fff;min-width:120px}.role-input-wrapper select:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff1a}.role-input-wrapper input{flex:1;border:1px solid #ced4da;padding:6px;font-size:13px;min-width:100px;border-radius:3px}.role-input-wrapper input:focus{outline:none;box-shadow:none}.role-input-wrapper button{background:#28a745;color:#fff;border:none;padding:4px 10px;border-radius:3px;cursor:pointer;font-size:12px;white-space:nowrap}.role-input-wrapper button:hover{background:#218838}:root{--primary: #C84B31;--primary-dark: #A83A25;--secondary: #2C2C2C;--accent: #D4A574;--light-bg: #FAFAF8;--card-bg: #FFFFFF;--text-primary: #2C2C2C;--text-secondary: #666666;--border: #E8E4DB;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .08);--shadow-md: 0 4px 12px rgba(0, 0, 0, .1);--shadow-lg: 0 12px 24px rgba(0, 0, 0, .12)}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Helvetica Neue,sans-serif;background:var(--light-bg);color:var(--text-primary);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.workspace{min-height:100vh;display:flex;flex-direction:column}.header{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);color:#fff;padding:1.5rem 2rem;box-shadow:var(--shadow-md);border-bottom:3px solid var(--accent);flex-shrink:0}.header-content{max-width:1400px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;gap:2rem}.header-logo{display:flex;align-items:center;gap:1rem}.header-logo img{height:auto;max-height:80px;width:auto}.header h1{font-size:1.75rem;font-weight:600;letter-spacing:-.5px}.header-subtitle{font-size:.85rem;opacity:.95;margin-top:.25rem}.user-menu{display:flex;align-items:center;gap:1.5rem;margin-left:auto}.user-info{text-align:right;font-size:.9rem}.user-role{font-size:.8rem;opacity:.85}.btn-logout{background:#ffffff26;border:1.5px solid rgba(255,255,255,.3);color:#fff;padding:.6rem 1.2rem;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .2s ease}.btn-logout:hover{background:#ffffff40;border-color:#fff6}.btn-logout:active{transform:translateY(1px)}.container{max-width:1400px;margin:0 auto;padding:3rem 2rem;flex:1;width:100%}.apps-section{margin-bottom:3rem}.apps-section h2{margin-bottom:2rem;font-size:1.5rem;font-weight:600;color:var(--text-primary)}.apps-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:2rem;margin-bottom:3rem}.app-card{background:var(--card-bg);border-radius:10px;padding:2rem;border:1px solid var(--border);box-shadow:var(--shadow-sm);transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.app-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--primary);transform:scaleX(0);transform-origin:left;transition:transform .3s ease}.app-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:var(--primary)}.app-card:hover:before{transform:scaleX(1)}.app-icon{width:56px;height:56px;margin-bottom:1.5rem;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:24px;font-weight:700}.app-card h3{margin-bottom:.75rem;font-size:1.25rem;font-weight:600;color:var(--text-primary)}.app-card p{color:var(--text-secondary);margin-bottom:1.5rem;font-size:.95rem;line-height:1.5}.app-link{display:inline-block;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);color:#fff;padding:.75rem 1.5rem;border-radius:6px;text-decoration:none;font-weight:500;transition:all .2s ease;border:none;cursor:pointer;font-size:.95rem}.app-link:hover{transform:translate(4px);box-shadow:var(--shadow-md)}.app-link:active{transform:translate(2px)}.admin-section{background:var(--card-bg);border-radius:10px;padding:2rem;border:2px solid var(--border);box-shadow:var(--shadow-sm)}.admin-section h2{margin-bottom:1.5rem;font-size:1.25rem;font-weight:600;color:var(--primary)}.admin-links{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:2rem}.btn.active{background:var(--primary);color:#fff;font-weight:600}.admin-card{background:var(--light-bg);border-radius:8px;padding:1.5rem;margin-bottom:1.5rem;border:1px solid var(--border)}.admin-card h3{margin-bottom:1rem;font-size:1.1rem;font-weight:600}.admin-table{width:100%;border-collapse:collapse}.admin-table thead{background:var(--light-bg)}.admin-table th{padding:1rem;text-align:left;font-weight:600;border-bottom:2px solid var(--border);color:var(--text-primary)}.admin-table td{padding:1rem;border-bottom:1px solid var(--border)}.admin-table input,.admin-table select{width:100%;padding:.5rem;border:1px solid var(--border);border-radius:4px;font-family:inherit;font-size:.9rem}.admin-table input:focus,.admin-table select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px #c84b311a}.btn-delete{background:#e74c3c;color:#fff}.btn-delete:hover{background:#c0392b}.roles-multi-select{display:flex;flex-wrap:wrap;gap:.5rem;align-items:flex-start;min-height:40px}.role-tag{background:var(--primary);color:#fff;padding:.5rem 1rem;border-radius:20px;font-size:.9rem;display:inline-flex;align-items:center;gap:.5rem}.role-tag button{background:none;border:none;color:#fff;cursor:pointer;font-size:1.2rem;padding:0;margin:0;line-height:1}.role-tag button:hover{opacity:.7}.role-input-wrapper{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap;width:100%}.role-input-wrapper select,.role-input-wrapper input{flex:1;min-width:150px;padding:.5rem;border:1px solid var(--border);border-radius:4px;font-size:.9rem}.role-input-wrapper button{padding:.5rem 1rem}.info{color:var(--primary);font-weight:500;padding:1rem;background:#fff3e0;border-radius:4px;margin-bottom:1rem}.app-iframe-container{flex:1;background:#fff;z-index:100;display:flex;flex-direction:column;overflow:hidden}.app-iframe{flex:1;width:100%;border:none;display:block}.btn{display:inline-block;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);color:#fff;padding:.75rem 1.5rem;border-radius:6px;text-decoration:none;font-weight:500;transition:all .2s ease;border:none;cursor:pointer;font-size:.95rem}.btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.btn:active{transform:translateY(0)}.error{background:#fef1f1;color:#c84b31;padding:1.25rem;border-radius:8px;margin-bottom:2rem;border-left:4px solid #C84B31;font-size:.95rem}.loading-container{display:flex;align-items:center;justify-content:center;min-height:400px;color:var(--text-secondary)}@media (max-width: 768px){.header-content{flex-direction:column;align-items:flex-start}.user-menu{width:100%;margin-left:0;margin-top:1rem}.header h1{font-size:1.5rem}.apps-grid{grid-template-columns:1fr}.container{padding:1.5rem 1rem}}
