@use 'sass:color'; /* Variáveis */ $primary: #1c38c9; $primary-hover: #152ca0; $danger: #ef4444; $warning: #f59e0b; $success: #10b981; $text-main: #111827; $text-muted: #6b7280; $bg-light: #f9fafb; $border-color: #e5e7eb; /* Utils */ * { box-sizing: border-box; } .custom-scroll::-webkit-scrollbar { width: 6px; height: 6px; } .custom-scroll::-webkit-scrollbar-track { background: transparent; } .custom-scroll::-webkit-scrollbar-thumb { background: #d1d5db; border-radius: 10px; } .custom-scroll::-webkit-scrollbar-thumb:hover { background: #9ca3af; } /* HEADER PRINCIPAL */ .app-header { position: fixed; top: 0; left: 0; width: 100%; z-index: 1000; padding: 14px 0; background: rgba(255, 255, 255, 0.9); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); border-bottom: 1px solid rgba(0,0,0,0.05); transition: all 0.3s ease; &.scrolled { padding: 10px 0; box-shadow: 0 4px 20px rgba(0,0,0,0.03); } } .header-inner { display: flex; align-items: center; justify-content: space-between; gap: 24px; } .logged-header { display: flex; align-items: center; justify-content: space-between; gap: 16px; width: 100%; } .left-logged { display: flex; align-items: center; gap: 16px; } .btn-icon { background: transparent; border: none; width: 40px; height: 40px; border-radius: 50%; display: grid; place-items: center; cursor: pointer; transition: background 0.2s; color: $text-main; &:hover { background: rgba(0,0,0,0.04); } i { font-size: 20px; } } .logo-area { display: flex; align-items: center; gap: 10px; text-decoration: none; color: #111827; .logo-icon { width: 36px; height: 36px; background: conic-gradient(from 210deg, #2f6bff, #7c3aed, #ec4899, #f59e0b, #22c55e, #2f6bff); color: #fff; border-radius: 50%; display: grid; place-items: center; font-size: 18px; box-shadow: 0 6px 14px rgba(47, 107, 255, 0.2); } .logo-text { font-size: 19px; font-weight: 700; letter-spacing: -0.5px; .highlight { background: linear-gradient(90deg, #2f6bff 0%, #7c3aed 55%, #ec4899 100%); -webkit-background-clip: text; background-clip: text; color: transparent; } } } .nav-links { display: flex; align-items: center; justify-content: center; gap: 22px; flex: 1; } .nav-links .nav-link { display: inline-flex; align-items: center; gap: 6px; color: $text-main; text-decoration: none; font-weight: 600; font-size: 14px; transition: color 0.2s; &:hover { color: $primary; } } .header-actions { display: flex; align-items: center; } .btn-login-header { display: inline-flex; align-items: center; gap: 6px; padding: 8px 16px; border-radius: 99px; border: 1px solid rgba(28, 56, 201, 0.18); background: #fff; color: $primary; font-weight: 700; font-size: 13px; text-decoration: none; transition: all 0.2s; &:hover { transform: translateY(-1px); background: rgba(28, 56, 201, 0.04); box-shadow: 0 4px 12px rgba(28, 56, 201, 0.15); } } @media (max-width: 900px) { .nav-links { display: none; } } .logged-actions { display: flex; align-items: center; gap: 12px; margin-left: auto; } @media (min-width: 1200px) { .header-inner.container { max-width: none; width: 100%; padding-left: 28px; padding-right: 28px; } } /* DROPDOWNS */ .notifications-menu, .options-menu { position: relative; } .notifications-dropdown, .options-dropdown { position: absolute; top: calc(100% + 12px); right: -10px; width: 340px; background: #fff; border-radius: 16px; box-shadow: 0 10px 40px rgba(0,0,0,0.1), 0 0 0 1px rgba(0,0,0,0.05); z-index: 1200; transform-origin: top right; animation: slideDown 0.2s cubic-bezier(0.16, 1, 0.3, 1); overflow: hidden; } .options-dropdown { width: 220px; right: 0; padding: 6px; } @keyframes slideDown { from { opacity: 0; transform: translateY(-10px) scale(0.98); } to { opacity: 1; transform: translateY(0) scale(1); } } .user-trigger { display: flex; align-items: center; gap: 8px; padding: 4px; background: #fff; border: 1px solid $border-color; border-radius: 99px; cursor: pointer; transition: all 0.2s; &:hover, &[aria-expanded="true"] { border-color: $primary; box-shadow: 0 0 0 2px rgba(28, 56, 201, 0.1); } .user-avatar { width: 32px; height: 32px; background: $bg-light; border-radius: 50%; display: grid; place-items: center; color: $text-muted; } .chevron { font-size: 10px; color: $text-muted; margin: 0 6px 0 2px; } } .options-item { width: 100%; text-align: left; padding: 10px 12px; background: transparent; border: none; border-radius: 8px; font-size: 13px; font-weight: 500; color: $text-main; display: flex; align-items: center; gap: 10px; cursor: pointer; &:hover { background: $bg-light; } &.danger { color: $danger; &:hover { background: rgba($danger, 0.05); } } } .divider { height: 1px; background: $border-color; margin: 4px 0; } /* NOTIFICAÇÕES */ .btn-bell { position: relative; &.has-unread { color: $primary; background: rgba(28, 56, 201, 0.06); } .badge-pulse { position: absolute; top: 10px; right: 10px; width: 8px; height: 8px; background: $danger; border-radius: 50%; border: 2px solid #fff; box-shadow: 0 0 0 0 rgba($danger, 0.7); animation: pulse 2s infinite; } } @keyframes pulse { 0% { transform: scale(0.95); box-shadow: 0 0 0 0 rgba($danger, 0.7); } 70% { transform: scale(1); box-shadow: 0 0 0 6px rgba($danger, 0); } 100% { transform: scale(0.95); box-shadow: 0 0 0 0 rgba($danger, 0); } } .notifications-head { padding: 16px; border-bottom: 1px solid $border-color; display: flex; justify-content: space-between; align-items: center; .head-title { font-weight: 700; font-size: 14px; display: flex; align-items: center; gap: 6px; } .head-actions { display: inline-flex; align-items: center; gap: 8px; margin-left: 14px; flex-shrink: 0; } .head-btn { border: 1px solid rgba(28, 56, 201, 0.18); background: #fff; color: $primary; font-size: 11px; font-weight: 700; padding: 5px 8px; border-radius: 999px; display: inline-flex; align-items: center; gap: 5px; cursor: pointer; transition: all 0.2s; i { font-size: 12px; } .spinner-border { width: 10px; height: 10px; border-width: 2px; } &:hover:not(:disabled) { background: rgba(28, 56, 201, 0.04); transform: translateY(-1px); box-shadow: 0 4px 12px rgba(28, 56, 201, 0.12); } &:disabled { opacity: 0.55; cursor: default; } } .see-all { font-size: 11px; color: $primary; text-decoration: none; font-weight: 600; white-space: nowrap; } } .notifications-tabs { display: flex; gap: 6px; padding: 10px 16px; border-bottom: 1px solid $border-color; background: #fff; } .notif-tab { border: 1px solid $border-color; background: #f8fafc; color: $text-muted; font-size: 12px; font-weight: 800; padding: 8px 10px; border-radius: 999px; cursor: pointer; transition: all 0.2s; flex: 1; &:hover { background: $bg-light; color: $text-main; } &.active { background: rgba(28, 56, 201, 0.08); border-color: rgba(28, 56, 201, 0.25); color: $primary; } } .notifications-body { max-height: 360px; overflow-y: auto; } .notifications-empty { padding: 32px; text-align: center; color: $text-muted; .empty-icon { font-size: 24px; margin-bottom: 8px; } } .notifications-state { display: flex; align-items: center; gap: 8px; margin: 12px 16px 8px; padding: 8px 10px; border-radius: 10px; border: 1px solid rgba(28, 56, 201, 0.14); background: rgba(28, 56, 201, 0.06); color: #1e3a8a; font-size: 12px; font-weight: 600; line-height: 1.35; i { font-size: 14px; color: $primary; } .spinner-border { width: 14px; height: 14px; border-width: 2px; } &.loading { background: #f8fafc; border-color: #e2e8f0; color: #475569; } &.info { background: #eff6ff; border-color: #bfdbfe; color: #1e3a8a; .notifications-truncate-copy { display: inline-flex; flex-wrap: wrap; align-items: baseline; gap: 4px; font-weight: 600; color: #1e3a8a; strong { padding: 1px 6px; border-radius: 999px; border: 1px solid #93c5fd; background: #dbeafe; color: #1d4ed8; font-weight: 800; line-height: 1.2; } } } &.warn { background: #fff7ed; border-color: #fed7aa; color: #9a3412; i { color: #c2410c; } } } .notification-item { display: flex; gap: 12px; padding: 12px 16px; border-bottom: 1px solid $border-color; cursor: pointer; &:hover { background: $bg-light; } &.unread { background: rgba(28, 56, 201, 0.03); .notif-title { font-weight: 700; } .status-dot { width: 6px; height: 6px; background: $primary; border-radius: 50%; } } .icon-circle { width: 36px; height: 36px; border-radius: 8px; display: grid; place-items: center; background: #f3f4f6; color: $text-muted; font-size: 16px; &.danger { background-color: #fee2e2; color: #dc2626; } &.warn { background-color: #fef3c7; color: #d97706; } } .notif-content { flex: 1; } .notif-header { display: flex; justify-content: space-between; font-size: 13px; margin-bottom: 4px; } .notif-title-line { font-weight: 700; color: $text-main; display: inline-flex; align-items: center; gap: 6px; white-space: nowrap; } .notif-line { font-weight: 800; flex: 0 0 auto; } .notif-sep { color: $text-muted; flex: 0 0 auto; } .notif-client { font-weight: 600; color: $text-muted; max-width: 130px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; display: inline-block; } .notif-desc { margin: 2px 0 6px; font-size: 12px; color: $text-muted; line-height: 1.3; display: flex; align-items: center; gap: 4px; } .notif-verb { font-weight: 600; color: $text-muted; } .notif-date-strong { font-weight: 800; color: $text-main; } .notif-date-strong.warn { color: #d97706; } .notif-date-strong.danger { color: #dc2626; } .notif-meta-lines { display: flex; flex-direction: column; gap: 4px; } .notif-meta-line { display: flex; gap: 6px; font-size: 12px; color: $text-muted; } .meta-label { font-weight: 700; text-transform: uppercase; letter-spacing: 0.4px; } .meta-value { font-weight: 600; color: $text-main; } .notif-restore-btn { margin-left: auto; align-self: center; border: 1px solid rgba(28, 56, 201, 0.2); background: #fff; color: $primary; border-radius: 999px; font-size: 11px; font-weight: 700; padding: 4px 10px; cursor: pointer; transition: all 0.2s; &:hover { background: rgba(28, 56, 201, 0.06); border-color: rgba(28, 56, 201, 0.35); } } } /* MODAIS GERAIS */ .modal-overlay { position: fixed; inset: 0; background: rgba(0,0,0,0.4); backdrop-filter: blur(2px); z-index: 1400; animation: fadeIn 0.2s; } .modal-card { position: fixed; top: 50%; left: 50%; transform: translate(-50%, -50%); width: min(500px, calc(100vw - 32px)); background: #fff; border-radius: 16px; box-shadow: 0 25px 50px -12px rgba(0,0,0,0.25); z-index: 1450; display: flex; flex-direction: column; animation: scaleIn 0.2s cubic-bezier(0.16, 1, 0.3, 1); } @keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } } @keyframes scaleIn { from { opacity: 0; transform: translate(-50%, -48%) scale(0.96); } to { opacity: 1; transform: translate(-50%, -50%) scale(1); } } .modal-header { display: flex; align-items: center; justify-content: space-between; padding: 16px 20px; border-bottom: 1px solid $border-color; h3 { margin: 0; font-size: 16px; font-weight: 600; color: $text-main; } } .close-x { width: 32px; height: 32px; border-radius: 6px; &:hover { background: #f3f4f6; } } .modal-body { padding: 20px; } .modal-actions { padding: 16px 20px; display: flex; justify-content: flex-end; gap: 10px; background: $bg-light; border-radius: 0 0 16px 16px; } .form-field { display: grid; gap: 6px; margin-bottom: 16px; label { font-size: 13px; font-weight: 500; color: $text-main; } input, select { width: 100%; height: 40px; border-radius: 8px; border: 1px solid #d1d5db; padding: 0 12px; font-size: 14px; transition: all 0.2s; &:focus { outline: none; border-color: $primary; box-shadow: 0 0 0 3px rgba(28, 56, 201, 0.1); } } } .field-error { font-size: 12px; color: $danger; margin-top: 2px; } .form-alert { padding: 12px; border-radius: 8px; font-size: 13px; margin-bottom: 16px; &.error { background: #fef2f2; color: #991b1b; border: 1px solid #fecaca; } &.success { background: #ecfdf5; color: #065f46; border: 1px solid #a7f3d0; } ul { margin: 4px 0 0; padding-left: 16px; } } .btn-primary, .btn-secondary, .btn-ghost { height: 38px; padding: 0 16px; border-radius: 8px; font-size: 13px; font-weight: 500; cursor: pointer; transition: all 0.2s; border: none; display: inline-flex; align-items: center; justify-content: center; } .btn-primary { background: $primary; color: #fff; &:hover:not(:disabled) { background: $primary-hover; } &:disabled { opacity: 0.7; cursor: not-allowed; } } .btn-secondary { background: #fff; border: 1px solid $border-color; color: $text-main; &:hover { background: $bg-light; } } .btn-ghost { background: transparent; color: $text-muted; &:hover { background: rgba(0,0,0,0.05); color: $text-main; } } /* ========================================================================== MODAL EDITAR USUÁRIO - LAYOUT FINAL ========================================================================== */ .modal-card.manage-users-modal { width: min(1200px, 95vw); height: min(650px, 90vh); } .manage-body { padding: 0; display: grid; grid-template-columns: 50% 50%; height: 100%; overflow: hidden; } /* Lado Esquerdo */ .manage-left { display: flex; flex-direction: column; border-right: 1px solid $border-color; background: #fff; min-width: 0; } .manage-search { padding: 12px 16px; border-bottom: 1px solid $border-color; .search-input-wrapper { position: relative; i { position: absolute; left: 12px; top: 50%; transform: translateY(-50%); color: $text-muted; } input { width: 100%; height: 36px; padding-left: 36px; padding-right: 12px; border: 1px solid #e5e7eb; border-radius: 8px; background: $bg-light; font-size: 13px; &:focus { background: #fff; border-color: $primary; outline: none; } } } } .manage-table-wrap { flex: 1; overflow-y: auto; position: relative; overflow-x: hidden; } .manage-table { width: 100%; border-collapse: collapse; table-layout: fixed; thead { position: sticky; top: 0; background: #fff; z-index: 10; th { font-size: 11px; text-transform: uppercase; letter-spacing: 0.5px; color: $text-muted; font-weight: 600; padding: 10px 16px; border-bottom: 1px solid $border-color; background: #f9fafb; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; /* Classes de alinhamento no TH */ &.text-center { text-align: center; } &.text-end { text-align: right; } } } tbody tr { border-bottom: 1px solid $border-color; transition: background 0.15s; cursor: pointer; &:hover { background: #f9fafb; } &.selected { background: rgba(28, 56, 201, 0.04); border-left: 3px solid $primary; } td { padding: 12px 16px; vertical-align: middle; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; /* Classes de alinhamento no TD */ &.text-center { text-align: center; overflow: visible; } &.text-end { text-align: right; overflow: visible; } } } } .user-cell { display: flex; align-items: center; gap: 10px; max-width: 100%; .avatar-mini { width: 32px; height: 32px; min-width: 32px; background: $primary; color: #fff; border-radius: 50%; display: grid; place-items: center; font-weight: 600; font-size: 12px; } .user-info { display: flex; flex-direction: column; min-width: 0; .u-name { font-size: 13px; font-weight: 500; color: $text-main; line-height: 1.2; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; } .u-email { font-size: 11px; color: $text-muted; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; } } } .badge-role { display: inline-block; padding: 2px 8px; border-radius: 4px; font-size: 10px; font-weight: 600; text-transform: uppercase; background: #eef2ff; color: $primary; border: 1px solid rgba(28, 56, 201, 0.1); } .status-dot { display: inline-block; width: 8px; height: 8px; border-radius: 50%; background: $success; box-shadow: 0 0 0 2px rgba(16, 185, 129, 0.2); &.off { background: $text-muted; box-shadow: none; opacity: 0.5; } } .actions-group { display: flex; gap: 4px; /* Centraliza os botões quando a célula é text-center */ justify-content: center; .btn-action { width: 28px; height: 28px; border-radius: 6px; border: none; background: transparent; color: $text-muted; display: inline-flex; align-items: center; justify-content: center; transition: all 0.2s; cursor: pointer; &:hover { background: #e5e7eb; color: $text-main; } &.edit:hover { color: $primary; background: rgba(28, 56, 201, 0.1); } &.delete:hover { color: $danger; background: rgba(239, 68, 68, 0.1); } } } .empty-state-list { padding: 40px 20px; text-align: center; color: $text-muted; i { font-size: 24px; opacity: 0.5; display: block; margin-bottom: 8px; } p { font-size: 13px; margin: 0; } } .loading-state { padding: 40px; text-align: center; } .list-footer { padding: 10px 16px; border-top: 1px solid $border-color; display: flex; justify-content: space-between; align-items: center; font-size: 12px; color: $text-muted; background: #fff; .pagination { display: flex; gap: 4px; } .icon-only { width: 28px; height: 28px; padding: 0; } } /* Lado Direito */ .manage-right-wrapper { background: #fff; display: flex; flex-direction: column; height: 100%; overflow-y: auto; } .manage-right { padding: 32px 40px; flex: 1; display: flex; flex-direction: column; } .edit-header-info { display: flex; align-items: center; gap: 16px; margin-bottom: 24px; .avatar-large { width: 56px; height: 56px; background: linear-gradient(135deg, $primary, #4f46e5); color: #fff; font-size: 20px; font-weight: 600; border-radius: 50%; display: grid; place-items: center; box-shadow: 0 4px 10px rgba(79, 70, 229, 0.2); } .info-text h4 { margin: 0; font-size: 18px; color: $text-main; } .info-text span { font-size: 13px; color: $text-muted; } } /* AQUI: Placeholder CORRIGIDO */ .manage-right.placeholder { align-items: center; justify-content: center; text-align: center; height: 100%; padding: 32px; background: #fff; /* Fundo branco explícito */ cursor: default; /* Remove qualquer cursor de loading herdado */ .placeholder-content { max-width: 320px; margin: 0 auto; animation: fadeIn 0.3s ease; .placeholder-icon { font-size: 64px; color: $text-muted; opacity: 0.2; /* Estilo marca d'água */ margin-bottom: 16px; } h3 { font-size: 16px; font-weight: 600; color: $text-main; margin-bottom: 8px; } p { font-size: 14px; color: $text-muted; line-height: 1.5; font-weight: 400; margin: 0; } } } .refined-form { display: flex; flex-direction: column; gap: 16px; .form-row { display: flex; gap: 16px; &.two-col { display: grid; grid-template-columns: 1fr 1fr; } &.align-end { align-items: end; } } } .toggle-wrapper { display: flex; align-items: center; gap: 12px; height: 40px; .toggle-status { font-size: 13px; color: $text-muted; font-weight: 500; &.active { color: $success; } } } .switch { position: relative; display: inline-block; width: 44px; height: 24px; input { opacity: 0; width: 0; height: 0; } .slider { position: absolute; cursor: pointer; inset: 0; background-color: #e5e7eb; transition: .4s; &.round { border-radius: 24px; } &.round:before { border-radius: 50%; } } .slider:before { position: absolute; content: ""; height: 18px; width: 18px; left: 3px; bottom: 3px; background-color: white; transition: .4s; box-shadow: 0 2px 4px rgba(0,0,0,0.2); } input:checked + .slider { background-color: $success; } input:checked + .slider:before { transform: translateX(20px); } } .manage-actions-footer { margin-top: 32px; padding-top: 20px; border-top: 1px solid $border-color; display: flex; justify-content: flex-end; gap: 12px; } .manage-actions-footer .btn-delete-permanent-left { margin-right: auto; } .manage-actions-footer .btn-delete-permanent-left { background: #ef4444; color: #fff; border: 1px solid #dc2626; } .manage-actions-footer .btn-delete-permanent-left:hover:not(:disabled) { background: #dc2626; border-color: #b91c1c; } .manage-actions-footer .btn-delete-permanent-left:disabled { background: #fecaca; border-color: #fecaca; color: #7f1d1d; } @media (max-width: 900px) { .manage-body { grid-template-columns: 1fr; overflow-y: auto; } .manage-left { height: 40%; border-right: none; border-bottom: 1px solid $border-color; } .manage-right-wrapper { height: 60%; } .manage-right { padding: 20px; } .form-row.two-col { grid-template-columns: 1fr; } .manage-table-wrap { overflow-x: auto; } } @media (max-width: 1200px) { .modal-card.manage-users-modal { width: min(980px, 92vw); height: min(600px, 86vh); } .modal-card { width: min(460px, 92vw); } } @media (max-width: 900px) { .modal-card.manage-users-modal { width: min(720px, 92vw); height: min(560px, 86vh); } .modal-card { width: min(420px, 92vw); } } @media (max-width: 640px) { .modal-card.manage-users-modal { width: min(520px, 94vw); height: min(520px, 84vh); } .modal-card { width: min(360px, 94vw); } } /* ========================================================================== AJUSTES PARA NOTEBOOKS / TELAS MENORES (SOLICITADO) ========================================================================== */ /* Adicionado max-width: 1440px e max-height: 800px para pegar notebooks padrão */ @media (max-width: 1440px), (max-height: 800px) { /* Modal Genérico (Novo Usuário) - Compacto */ .modal-card { /* Limita a altura para não sair da tela e habilita scroll interno */ max-height: 95vh; } .modal-header { padding: 12px 16px; h3 { font-size: 15px; } } .modal-body { padding: 16px; /* Essencial para que o conteúdo não estoure o modal quando encolhido */ overflow-y: auto; } .modal-actions { padding: 12px 16px; } /* Compactar formulários */ .form-field { margin-bottom: 12px; label { font-size: 12px; } input, select { height: 36px; font-size: 13px; } } .form-alert { padding: 10px; margin-bottom: 12px; font-size: 12px; } /* Modal de Gestão (Editar Usuário) - MUITO COMPACTO (Solicitado) */ .modal-card.manage-users-modal { /* Reduzido consideravelmente */ height: min(500px, 80vh); width: min(900px, 92vw); } .manage-right { padding: 24px; } .edit-header-info { margin-bottom: 16px; .avatar-large { width: 48px; height: 48px; font-size: 16px; } .info-text h4 { font-size: 16px; } } .refined-form { gap: 12px; } } /* SIDE MENU */ .menu-overlay { position: fixed; inset: 0; background: rgba(0,0,0,0.5); z-index: 1050; } .side-menu { position: fixed; top: 0; left: 0; height: 100vh; width: 260px; background: #fff; box-shadow: 4px 0 20px rgba(0,0,0,0.1); transform: translateX(-100%); transition: transform 0.3s cubic-bezier(0.16, 1, 0.3, 1); z-index: 1100; display: flex; flex-direction: column; &.open { transform: translateX(0); } } .side-menu-header { padding: 20px; display: flex; justify-content: space-between; align-items: center; border-bottom: 1px solid $border-color; } .close-btn { background: transparent; border: none; box-shadow: none; width: 32px; height: 32px; border-radius: 0; display: grid; place-items: center; cursor: pointer; color: $text-main; transition: color 0.2s ease; &:hover { color: $primary; } } .side-logo { display: flex; align-items: center; gap: 10px; text-decoration: none; color: $text-main; font-weight: 700; .side-logo-icon { width: 32px; height: 32px; background: $primary; color: #fff; border-radius: 50%; display: grid; place-items: center; } } .side-menu-body { padding: 16px; display: flex; flex-direction: column; gap: 4px; } .side-item { padding: 10px 12px; border-radius: 8px; color: $text-main; text-decoration: none; font-size: 14px; font-weight: 500; display: flex; align-items: center; gap: 10px; &:hover { background: $bg-light; } &.active { background: rgba(28, 56, 201, 0.08); color: $primary; } } /* ========================================================================== RESPONSIVIDADE MOBILE/TABLET (HEADER, NOTIFICAÇÕES E MODAIS DO TOPO) ========================================================================== */ @media (max-width: 900px) { .app-header { padding: 10px 0; } .header-inner { gap: 12px; } .logged-header { gap: 10px; } .left-logged { gap: 10px; min-width: 0; } .logo-area { min-width: 0; .logo-text { font-size: 16px; white-space: nowrap; } } .logged-actions { gap: 8px; } .notifications-dropdown { right: 0; width: min(360px, calc(100vw - 24px)); max-width: calc(100vw - 24px); } .options-dropdown { right: 0; width: min(260px, calc(100vw - 24px)); } .notifications-head { align-items: flex-start; .head-title { min-width: 0; flex-wrap: wrap; } .head-actions { margin-left: 10px; flex-wrap: wrap; justify-content: flex-end; } } .notifications-body { max-height: min(52vh, 420px); } } @media (max-width: 640px) { .app-header { padding: 8px 0; } .app-header.scrolled { /* Mobile: não muda a altura do header ao rolar (evita "vão" no topo ao voltar) */ padding: 8px 0; } .header-inner { gap: 8px; } .logged-header { gap: 8px; } .btn-icon { width: 36px; height: 36px; i { font-size: 18px; } } .btn-bell .badge-pulse { top: 8px; right: 8px; } .left-logged { gap: 8px; flex: 1 1 auto; } .logo-area { gap: 8px; min-width: 0; .logo-icon { width: 32px; height: 32px; font-size: 16px; } .logo-text { font-size: 14px; line-height: 1; } } .logged-actions { gap: 6px; } .user-trigger { padding: 2px; .user-avatar { width: 30px; height: 30px; } } .notifications-dropdown { position: fixed; top: calc(var(--app-header-offset, 76px) + 8px); left: 8px; right: 8px; width: auto; max-width: none; border-radius: 16px; transform-origin: top center; z-index: 1250; } .options-dropdown { position: fixed; top: calc(var(--app-header-offset, 76px) + 8px); right: 8px; width: min(260px, calc(100vw - 16px)); z-index: 1250; } .notifications-head { padding: 12px; flex-wrap: wrap; gap: 10px; .head-title { width: 100%; justify-content: space-between; gap: 8px; font-size: 13px; } .head-actions { width: 100%; margin-left: 0; justify-content: space-between; gap: 6px; } .head-btn { font-size: 10px; padding: 5px 7px; gap: 4px; } .see-all { margin-left: auto; font-size: 11px; } } .notifications-tabs { padding: 8px 12px; flex-direction: column; gap: 8px; } .notif-tab { width: 100%; padding: 9px 10px; text-align: center; } .notifications-state { margin: 8px 12px 6px; padding: 8px 9px; font-size: 11px; } .notifications-body { max-height: calc(100dvh - 220px); } .notifications-empty { padding: 20px 12px; } .notification-item { gap: 10px; padding: 12px; align-items: flex-start; .notif-content { min-width: 0; } .notif-title-line { white-space: normal; flex-wrap: wrap; row-gap: 2px; } .notif-client { max-width: 100%; } .notif-desc { flex-wrap: wrap; align-items: baseline; } .notif-meta-line { flex-wrap: wrap; row-gap: 2px; } .notif-restore-btn { margin-left: 0; margin-top: 6px; align-self: flex-start; } } .modal-card { width: min(100vw - 12px, 420px); max-height: calc(100dvh - 12px); border-radius: 14px; } .modal-card.manage-users-modal { width: calc(100vw - 12px); height: min(calc(100dvh - 12px), 680px); max-height: calc(100dvh - 12px); border-radius: 14px; } .manage-body { height: 100%; } .manage-left { height: auto; max-height: 38vh; } .manage-right-wrapper { height: auto; min-height: 0; } .manage-right { padding: 14px; } .edit-header-info { gap: 10px; margin-bottom: 14px; .avatar-large { width: 42px; height: 42px; font-size: 14px; } .info-text h4 { font-size: 14px; } .info-text span { font-size: 12px; } } .manage-actions-footer { margin-top: 18px; padding-top: 14px; gap: 8px; .btn-delete-permanent-left { margin-right: 0; } } .list-footer { flex-wrap: wrap; gap: 8px; .pagination { width: 100%; justify-content: center; flex-wrap: wrap; } } .side-menu { width: min(88vw, 320px); } } @media (max-width: 420px) { .logo-area .logo-text { display: none; } .logged-actions { gap: 4px; } .user-trigger { .chevron { display: none; } } .notifications-dropdown { left: 6px; right: 6px; top: calc(var(--app-header-offset, 76px) + 6px); } .options-dropdown { right: 6px; top: calc(var(--app-header-offset, 76px) + 6px); } .notifications-head { .head-actions { justify-content: stretch; } .head-btn { flex: 1 1 100%; justify-content: center; } .see-all { width: 100%; text-align: center; margin-left: 0; padding-top: 2px; } } .notification-item { .icon-circle { width: 32px; height: 32px; font-size: 14px; } .notif-meta-line { gap: 4px; font-size: 11px; } } }