:root{--primary: #2563eb;--primary-dark: #1d4ed8;--secondary: #64748b;--success: #22c55e;--warning: #f59e0b;--error: #ef4444;--bg: #f8fafc;--bg-card: #ffffff;--border: #e2e8f0;--text: #1e293b;--text-muted: #64748b}*{box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;background-color:var(--bg);color:var(--text);line-height:1.6;margin:0;padding:0}a{color:var(--primary);text-decoration:none}a:hover{text-decoration:underline}.portal-layout{min-height:100vh}.portal-header{background:var(--bg-card);border-bottom:1px solid var(--border);padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center}.portal-logo{font-size:1.25rem;font-weight:600;color:var(--text)}.portal-user{display:flex;align-items:center;gap:1rem}.portal-user-info{text-align:right}.portal-user-email{font-size:.875rem;color:var(--text)}.portal-user-role{font-size:.75rem;color:var(--text-muted);text-transform:capitalize}.portal-content{padding:2rem;max-width:1200px;margin:0 auto}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:.5rem;padding:1.5rem;margin-bottom:1.5rem}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.5rem 1rem;border:none;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-dark)}.btn-secondary{background:var(--secondary);color:#fff}.btn-outline{background:transparent;border:1px solid var(--border);color:var(--text)}.btn-outline:hover:not(:disabled){background:var(--bg)}.btn-sm{padding:.25rem .5rem;font-size:.75rem}.form-group{margin-bottom:1rem}.form-label{display:block;margin-bottom:.5rem;font-weight:500;font-size:.875rem}.form-input{width:100%;padding:.5rem .75rem;border:1px solid var(--border);border-radius:.375rem;font-size:.875rem;transition:border-color .15s}.form-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}.alert{padding:1rem;border-radius:.375rem;margin-bottom:1rem}.alert-error{background:#fee2e2;border:1px solid #fecaca;color:#991b1b}.alert-success{background:#dcfce7;border:1px solid #bbf7d0;color:#166534}.badge{display:inline-flex;align-items:center;padding:.25rem .5rem;border-radius:9999px;font-size:.75rem;font-weight:500}.badge-admin{background:#dbeafe;color:#1e40af}.badge-editor{background:#fef3c7;color:#92400e}.badge-viewer{background:#f1f5f9;color:#475569}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg)}.login-card{width:100%;max-width:400px;padding:2rem;background:var(--bg-card);border-radius:.5rem;box-shadow:0 4px 6px -1px #0000001a}.login-title{text-align:center;margin-bottom:2rem}.login-title h1{font-size:1.5rem;margin-bottom:.5rem}.login-title p{color:var(--text-muted);font-size:.875rem}.dashboard-title{margin-bottom:2rem}.dashboard-title h1{font-size:1.5rem;margin-bottom:.5rem}.dashboard-title p{color:var(--text-muted)}.app-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.app-card{background:var(--bg-card);border:1px solid var(--border);border-radius:.75rem;padding:1.5rem;cursor:pointer;transition:all .2s;display:flex;flex-direction:column}.app-card:hover{border-color:var(--primary);box-shadow:0 4px 12px #2563eb26;transform:translateY(-2px)}.app-card-header{display:flex;align-items:flex-start;gap:1rem;margin-bottom:1rem}.app-icon{width:48px;height:48px;border-radius:.5rem;background:linear-gradient(135deg,var(--primary),var(--primary-dark));display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0}.app-info{flex:1;min-width:0}.app-name{font-size:1.125rem;font-weight:600;margin-bottom:.25rem}.app-description{color:var(--text-muted);font-size:.875rem;line-height:1.4}.app-card-footer{margin-top:auto;padding-top:1rem;border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}.app-role{font-size:.75rem;color:var(--text-muted)}.app-arrow{color:var(--primary);font-size:1.25rem}.spinner{display:inline-block;width:1rem;height:1rem;border:2px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .6s linear infinite}.loading-container{display:flex;justify-content:center;align-items:center;min-height:200px;gap:.5rem;color:var(--text-muted)}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;padding:3rem;color:var(--text-muted)}.empty-state-icon{font-size:3rem;margin-bottom:1rem}.empty-state h3{color:var(--text);margin-bottom:.5rem}.portal-header{background:var(--bg-card);border-bottom:1px solid var(--border);padding:.75rem 1.5rem;display:flex;justify-content:space-between;align-items:center;gap:1rem;position:sticky;top:0;z-index:100}.portal-header-left,.portal-header-right{display:flex;align-items:center;gap:.75rem}.portal-header-center{flex:1;max-width:500px}.portal-logo{display:flex;align-items:center;gap:.5rem;font-size:1.125rem;font-weight:600;color:var(--text);white-space:nowrap}.portal-logo-icon{color:var(--primary)}.portal-search{display:flex;align-items:center;background:var(--bg);border:1px solid var(--border);border-radius:.5rem;padding:.5rem .75rem;transition:all .15s}.portal-search:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}.portal-search .search-icon{font-size:1rem;color:var(--text-muted);margin-right:.5rem}.portal-search input{flex:1;border:none;background:transparent;font-size:.875rem;outline:none;min-width:200px}.portal-search input::placeholder{color:var(--text-muted)}.portal-icon-btn{position:relative;background:transparent;border:none;padding:.5rem;border-radius:.375rem;cursor:pointer;transition:background .15s}.portal-icon-btn:hover{background:var(--bg)}.portal-icon-btn .icon{font-size:1.25rem}.badge-count{position:absolute;top:0;right:0;background:var(--error);color:#fff;font-size:.625rem;font-weight:600;min-width:1rem;height:1rem;display:flex;align-items:center;justify-content:center;border-radius:9999px;padding:0 .25rem}.portal-user-btn{display:flex;align-items:center;gap:.5rem;background:transparent;border:none;padding:.25rem;border-radius:.375rem;cursor:pointer;transition:background .15s}.portal-user-btn:hover{background:var(--bg)}.user-avatar{width:2rem;height:2rem;border-radius:9999px;background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;display:flex;align-items:center;justify-content:center;font-size:.875rem;font-weight:600}.dropdown-arrow{font-size:.75rem;color:var(--text-muted)}.portal-dropdown{position:relative}.dropdown-menu{position:absolute;top:100%;right:0;margin-top:.5rem;background:var(--bg-card);border:1px solid var(--border);border-radius:.5rem;box-shadow:0 10px 25px #0000001a;min-width:200px;z-index:1000;overflow:hidden}.dropdown-header{padding:.75rem 1rem;border-bottom:1px solid var(--border)}.dropdown-header .user-email{font-weight:500;font-size:.875rem}.dropdown-header .user-role{color:var(--text-muted);font-size:.75rem;text-transform:capitalize}.dropdown-divider{border-top:1px solid var(--border);margin:.25rem 0}.dropdown-item{display:flex;align-items:center;gap:.75rem;padding:.625rem 1rem;font-size:.875rem;color:var(--text);cursor:pointer;transition:background .15s;border:none;background:none;width:100%;text-align:left}.dropdown-item:hover{background:var(--bg);text-decoration:none}.dropdown-icon{font-size:1rem;width:1.25rem;text-align:center}.logout-item{color:var(--error)}.dropdown-empty{padding:1.5rem;text-align:center;color:var(--text-muted);font-size:.875rem}.notifications-menu{min-width:300px;max-width:350px}.notification-item{padding:.75rem 1rem;border-bottom:1px solid var(--border)}.notification-item:last-child{border-bottom:none}.notification-item.unread{background:#2563eb0d}.notification-title{font-weight:500;font-size:.875rem;margin-bottom:.25rem}.notification-message{font-size:.75rem;color:var(--text-muted)}.dashboard{padding-bottom:2rem}.dashboard-header{margin-bottom:2rem}.dashboard-header h1{font-size:1.5rem;margin-bottom:.5rem}.dashboard-header p{color:var(--text-muted)}.dashboard-section{margin-bottom:2rem}.section-title{display:flex;align-items:center;gap:.5rem;font-size:1rem;font-weight:600;margin-bottom:1rem;color:var(--text)}.section-icon{font-size:1.25rem}.recent-apps{display:flex;flex-wrap:wrap;gap:.5rem}.recent-app-chip{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--bg-card);border:1px solid var(--border);border-radius:9999px;font-size:.875rem;cursor:pointer;transition:all .15s}.recent-app-chip:hover{border-color:var(--primary);background:#2563eb0d}.chip-icon{font-size:1rem}.chip-name{font-weight:500}.app-card{position:relative}.app-card-content{cursor:pointer}.favorite-btn{position:absolute;top:.75rem;right:.75rem;background:var(--bg);border:1px solid var(--border);border-radius:9999px;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;font-size:1rem;cursor:pointer;transition:all .15s;color:var(--text-muted);z-index:1}.favorite-btn:hover{background:var(--bg-card);border-color:var(--warning);color:var(--warning)}.favorite-btn.active{background:#fef3c7;border-color:var(--warning);color:var(--warning)}@media (max-width: 768px){.portal-header{padding:.75rem 1rem;flex-wrap:wrap}.portal-header-center{order:3;width:100%;max-width:none;margin-top:.75rem}.portal-search input{min-width:0}.portal-content{padding:1rem}.app-grid{grid-template-columns:1fr}}
