/* ============================================================
   SER-HMAS — Sistema de Regulação Hospitalar
   Design: Corporate Medical — Navy Blue + Electric Teal
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800&family=JetBrains+Mono:wght@400;500&display=swap');

:root {
  --navy-950: #030f1e; --navy-900: #0a1628; --navy-800: #0d2240;
  --navy-700: #0f2d55; --navy-600: #0a3d7a; --navy-500: #1155a3;
  --navy-400: #2d74c8; --navy-300: #5a9ee0; --navy-200: #a8cef0;
  --navy-100: #d4e8f8; --navy-50: #eef6fd;
  --teal-600: #0d7377; --teal-500: #14a89e; --teal-400: #1ec6b8;
  --teal-300: #5eddd5; --teal-100: #c8f5f2;
  --success: #10b981; --warning: #f59e0b; --danger: #ef4444; --info: #3b82f6;
  --purple: #8b5cf6;
  --bg-main: #f0f4f8; --bg-card: #ffffff; --bg-sidebar: #0a1628;
  --text-main: #1a2332; --text-muted: #64748b; --border: #e2e8f0;
  --radius-sm: 6px; --radius-md: 12px; --radius-lg: 18px; --radius-xl: 24px;
  --shadow-sm: 0 1px 3px rgba(10,22,40,.08), 0 1px 2px rgba(10,22,40,.06);
  --shadow-md: 0 4px 16px rgba(10,22,40,.12), 0 2px 6px rgba(10,22,40,.08);
  --shadow-lg: 0 12px 40px rgba(10,22,40,.16), 0 4px 12px rgba(10,22,40,.10);
  --shadow-glow: 0 0 24px rgba(30,198,184,.25);
  --transition: all .2s cubic-bezier(.4,0,.2,1);
  --transition-slow: all .4s cubic-bezier(.4,0,.2,1);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth}
body{font-family:'Outfit',system-ui,sans-serif;background:var(--bg-main);color:var(--text-main);line-height:1.6;-webkit-font-smoothing:antialiased;min-height:100vh}
a{color:inherit;text-decoration:none}
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:var(--border)}
::-webkit-scrollbar-thumb{background:var(--navy-400);border-radius:3px}

/* ─── LAYOUT ─── */
.app-layout{display:flex;min-height:100vh}
.main-content{flex:1;margin-left:260px;display:flex;flex-direction:column;min-height:100vh;transition:var(--transition-slow)}
.page-content{flex:1;padding:28px;max-width:1400px;width:100%}
.p-0{padding:0!important}

/* ─── SIDEBAR ─── */
.sidebar{width:260px;min-width:260px;background:var(--bg-sidebar);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;transition:var(--transition-slow);overflow-y:auto;overflow-x:hidden}
.sidebar-header{padding:24px 20px;border-bottom:1px solid rgba(255,255,255,.08);background:linear-gradient(180deg,rgba(30,198,184,.12) 0%,transparent 100%)}
.sidebar-logo{display:block;width:100%;max-width:200px;height:auto}
.sidebar-tag{display:inline-block;margin-top:10px;font-size:11px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--teal-400);background:rgba(30,198,184,.15);padding:3px 10px;border-radius:20px}
.sidebar-nav{flex:1;padding:16px 12px}
.nav-group-label{font-size:10px;font-weight:700;letter-spacing:1.8px;text-transform:uppercase;color:rgba(255,255,255,.3);padding:16px 10px 8px}
.nav-item{display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:var(--radius-md);color:rgba(255,255,255,.65);text-decoration:none;font-size:14px;font-weight:500;transition:var(--transition);margin-bottom:2px;position:relative;overflow:hidden}
.nav-item::before{content:'';position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:0;background:var(--teal-400);border-radius:0 3px 3px 0;transition:var(--transition)}
.nav-item:hover{background:rgba(255,255,255,.08);color:#fff}
.nav-item:hover::before,.nav-item.active::before{height:70%}
.nav-item.active{background:linear-gradient(135deg,rgba(30,198,184,.2) 0%,rgba(30,198,184,.08) 100%);color:#fff;border:1px solid rgba(30,198,184,.25)}
.nav-icon{font-size:18px;min-width:22px;text-align:center}
.sidebar-footer{padding:16px 12px 24px;border-top:1px solid rgba(255,255,255,.08)}
.user-chip{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-md);background:rgba(255,255,255,.06);color:rgba(255,255,255,.8);text-decoration:none;font-size:13px;transition:var(--transition);cursor:pointer}
.user-chip:hover{background:rgba(255,255,255,.12);color:#fff}
.avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--teal-500),var(--navy-400));display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;color:#fff;flex-shrink:0}
.badge-perfil{font-size:9px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;padding:2px 7px;border-radius:10px;background:rgba(30,198,184,.2);color:var(--teal-300);border:1px solid rgba(30,198,184,.3);margin-left:auto}
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:99}

/* ─── TOPBAR ─── */
.topbar{height:64px;background:var(--bg-card);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 28px;gap:16px;position:sticky;top:0;z-index:50;box-shadow:var(--shadow-sm)}
.topbar-title{font-size:18px;font-weight:700;color:var(--text-main);flex:1}
.topbar-title span{color:var(--teal-500)}
.btn-menu-toggle{display:none;background:none;border:none;font-size:22px;cursor:pointer;color:var(--text-main);padding:4px;align-items:center}
.topbar-actions{display:flex;align-items:center;gap:8px}
.topbar-icon-btn{width:38px;height:38px;border-radius:var(--radius-md);border:none;background:var(--bg-main);cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;color:var(--text-muted);transition:var(--transition);text-decoration:none}
.topbar-icon-btn:hover{background:var(--navy-100);color:var(--navy-600)}
.topbar-user{display:flex;align-items:center;gap:10px;padding:6px 12px;border-radius:var(--radius-md);cursor:pointer;transition:var(--transition);border:1px solid var(--border)}
.topbar-user:hover{background:var(--bg-main)}
.topbar-user-name{font-size:13px;font-weight:600;color:var(--text-main)}
.topbar-user-role{font-size:11px;color:var(--text-muted)}

/* ─── PAGE HEADER ─── */
.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:28px;flex-wrap:wrap}
.page-header-left{}
.page-title{font-size:24px;font-weight:800;color:var(--text-main);display:flex;align-items:center;gap:10px;line-height:1.2}
.page-title i{color:var(--teal-500);font-size:26px}
.page-subtitle{color:var(--text-muted);font-size:14px;margin-top:4px}
.page-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center}

/* ─── CARDS ─── */
.card{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm);overflow:hidden;transition:var(--transition)}
.card:hover{box-shadow:var(--shadow-md)}
.card-header{padding:20px 24px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.card-title{font-size:16px;font-weight:700;color:var(--text-main);display:flex;align-items:center;gap:8px}
.card-subtitle{font-size:12px;color:var(--text-muted)}
.card-header-actions{display:flex;align-items:center;gap:8px}
.card-body{padding:24px}
.card-footer{padding:16px 24px;border-top:1px solid var(--border);background:var(--bg-main)}
.charts-row{display:grid;grid-template-columns:1fr 360px;gap:18px}
.chart-card-lg,.chart-card-sm{min-width:0}
.chart-container{position:relative;height:280px}
.chart-container-sm{height:200px}
.chart-legend{display:flex;flex-direction:column;gap:6px;margin-top:12px}
.legend-item{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-main)}
.legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}

/* ─── STAT CARDS ─── */
.stats-grid{display:grid;gap:18px;margin-bottom:24px}
.stats-grid-4{grid-template-columns:repeat(4,1fr)}
.stats-grid-6{grid-template-columns:repeat(6,1fr)}
.stat-card{border-radius:var(--radius-lg);padding:22px 24px;border:1px solid var(--border);box-shadow:var(--shadow-sm);position:relative;overflow:hidden;transition:var(--transition);background:var(--bg-card)}
.stat-card::after{content:'';position:absolute;top:0;right:0;width:80px;height:80px;background:radial-gradient(circle,currentColor 0%,transparent 70%);opacity:.06;border-radius:50%;transform:translate(20px,-20px)}
.stat-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.stat-card-body{display:flex;align-items:center;gap:16px}
.stat-card-icon{width:52px;height:52px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0}
.stat-card-value{font-size:30px;font-weight:800;line-height:1;display:block}
.stat-card-label{font-size:12px;font-weight:500;color:var(--text-muted);display:block;margin-top:3px}
.stat-card-primary .stat-card-icon{background:var(--navy-100);color:var(--navy-600)}
.stat-card-primary .stat-card-value{color:var(--navy-600)}
.stat-card-success .stat-card-icon{background:#d1fae5;color:#065f46}
.stat-card-success .stat-card-value{color:#065f46}
.stat-card-warning .stat-card-icon{background:#fef3c7;color:#92400e}
.stat-card-warning .stat-card-value{color:#92400e}
.stat-card-danger .stat-card-icon{background:#fee2e2;color:#991b1b}
.stat-card-danger .stat-card-value{color:#991b1b}
.stat-card-info .stat-card-icon{background:var(--navy-50);color:var(--info)}
.stat-card-info .stat-card-value{color:var(--info)}
.stat-card-teal .stat-card-icon{background:var(--teal-100);color:var(--teal-600)}
.stat-card-teal .stat-card-value{color:var(--teal-600)}

/* ─── STATS MINI ROW ─── */
.stats-row{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:20px}
.stat-mini{display:flex;align-items:center;gap:12px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:12px 16px;flex:1;min-width:140px;box-shadow:var(--shadow-sm)}
.stat-mini-icon{width:40px;height:40px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.stat-mini-primary{background:var(--navy-100);color:var(--navy-600)}
.stat-mini-success{background:#d1fae5;color:#065f46}
.stat-mini-warning{background:#fef3c7;color:#92400e}
.stat-mini-danger{background:#fee2e2;color:#991b1b}
.stat-mini-info{background:var(--navy-50);color:var(--info)}
.stat-mini-value{font-size:20px;font-weight:800;display:block;color:var(--text-main);line-height:1}
.stat-mini-label{font-size:11px;color:var(--text-muted);font-weight:500}

/* ─── BUTTONS ─── */
.btn{display:inline-flex;align-items:center;gap:8px;padding:9px 18px;border-radius:var(--radius-md);font-size:14px;font-weight:600;font-family:inherit;border:none;cursor:pointer;transition:var(--transition);text-decoration:none;white-space:nowrap;line-height:1.4}
.btn:disabled{opacity:.55;cursor:not-allowed}
.btn-lg{padding:12px 24px;font-size:15px}
.btn-sm{padding:6px 12px;font-size:12px}
.btn-primary{background:linear-gradient(135deg,var(--navy-600) 0%,var(--navy-500) 100%);color:#fff;box-shadow:0 2px 8px rgba(10,61,122,.3)}
.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 14px rgba(10,61,122,.4)}
.btn-teal{background:linear-gradient(135deg,var(--teal-600) 0%,var(--teal-400) 100%);color:#fff;box-shadow:0 2px 8px rgba(14,168,158,.3)}
.btn-teal:hover:not(:disabled){transform:translateY(-1px);box-shadow:var(--shadow-glow)}
.btn-success{background:linear-gradient(135deg,#059669 0%,#10b981 100%);color:#fff;box-shadow:0 2px 8px rgba(5,150,105,.3)}
.btn-success:hover:not(:disabled){transform:translateY(-1px)}
.btn-danger{background:linear-gradient(135deg,#dc2626 0%,#ef4444 100%);color:#fff;box-shadow:0 2px 8px rgba(220,38,38,.3)}
.btn-danger:hover:not(:disabled){transform:translateY(-1px)}
.btn-secondary{background:var(--bg-main);color:var(--text-main);border:1px solid var(--border)}
.btn-secondary:hover:not(:disabled){background:var(--border)}
.btn-ghost{background:transparent;color:var(--text-muted);border:1px solid var(--border)}
.btn-ghost:hover:not(:disabled){background:var(--bg-main);color:var(--text-main)}
.btn-warning-ghost{background:transparent;color:var(--warning);border:1px solid rgba(245,158,11,.3)}
.btn-warning-ghost:hover:not(:disabled){background:rgba(245,158,11,.08)}
.btn-success-ghost{background:transparent;color:var(--success);border:1px solid rgba(16,185,129,.3)}
.btn-success-ghost:hover:not(:disabled){background:rgba(16,185,129,.08)}
.btn-icon{width:36px;height:36px;padding:0;justify-content:center;border-radius:var(--radius-md)}
.btn-icon.btn-ghost{color:var(--text-muted)}
.btn-icon.btn-ghost:hover{background:var(--navy-50);color:var(--navy-600)}
.inline-form{display:inline}

/* ─── FORMS ─── */
.form-container{max-width:860px}
.form-container-sm{max-width:600px}
.form-section{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:20px;overflow:hidden;box-shadow:var(--shadow-sm)}
.form-section-header{display:flex;align-items:center;gap:14px;padding:20px 24px;border-bottom:1px solid var(--border);background:linear-gradient(135deg,var(--bg-main),var(--bg-card))}
.form-section-icon{width:44px;height:44px;border-radius:var(--radius-md);background:var(--navy-100);color:var(--navy-600);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.form-section-title{font-size:15px;font-weight:700;color:var(--text-main)}
.form-section-desc{font-size:12px;color:var(--text-muted);margin-top:2px}
.form-grid{display:grid;gap:18px;padding:24px}
.form-grid-1{grid-template-columns:1fr}
.form-grid-2{grid-template-columns:repeat(2,1fr)}
.form-grid-3{grid-template-columns:repeat(3,1fr)}
.form-group{display:flex;flex-direction:column;gap:6px}
.form-group-full{grid-column:1/-1}
.form-group-actions{justify-content:flex-end}
.form-label{font-size:13px;font-weight:600;color:var(--text-main)}
.form-label.required::after{content:' *';color:var(--danger)}
.form-control{width:100%;padding:10px 14px;border:1px solid var(--border);border-radius:var(--radius-md);font-size:14px;font-family:inherit;color:var(--text-main);background:var(--bg-card);transition:var(--transition);outline:none;appearance:none}
.form-control:focus{border-color:var(--navy-400);box-shadow:0 0 0 3px rgba(45,116,200,.12)}
.form-control.is-invalid{border-color:var(--danger);box-shadow:0 0 0 3px rgba(239,68,68,.12)}
.form-control-readonly{background:var(--bg-main);color:var(--text-muted);cursor:default}
.form-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24'%3E%3Cpath stroke='%2364748b' stroke-width='2' d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;background-size:16px;padding-right:36px}
.form-textarea{resize:vertical;min-height:80px;line-height:1.6}
.form-hint{font-size:12px;color:var(--text-muted)}
.form-error{font-size:12px;color:var(--danger);min-height:16px}
.input-wrapper{position:relative;display:flex;align-items:center}
.input-wrapper .form-control{padding-left:40px}
.input-icon{position:absolute;left:13px;color:var(--text-muted);font-size:16px;pointer-events:none;z-index:1}
.input-toggle-pw{position:absolute;right:12px;background:none;border:none;cursor:pointer;color:var(--text-muted);font-size:16px;display:flex;padding:4px;transition:var(--transition)}
.input-toggle-pw:hover{color:var(--text-main)}
.textarea-wrapper{position:relative}
.textarea-counter{position:absolute;bottom:8px;right:12px;font-size:11px;color:var(--text-muted)}
.form-control-sm{height:34px;padding:5px 10px;font-size:13px}
.form-actions{padding:20px 24px;background:var(--bg-main);border-radius:0 0 var(--radius-lg) var(--radius-lg);border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:10px}
.filter-bar{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px 20px;margin-bottom:20px;box-shadow:var(--shadow-sm)}
.filter-form{display:flex;gap:10px;flex-wrap:wrap;align-items:flex-end}
.filter-group{flex:1;min-width:160px;max-width:260px}
.filter-search{max-width:280px}
.filter-select{min-width:140px}
.filter-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;align-items:end}
.filter-grid-5{grid-template-columns:repeat(5,1fr)}
.btn-group-filter{display:flex;gap:8px}
.w-full{width:100%}

/* ─── TABLES ─── */
.table-responsive{overflow-x:auto;-webkit-overflow-scrolling:touch}
.data-table{width:100%;border-collapse:collapse;font-size:14px}
.data-table thead th{background:var(--bg-main);padding:12px 20px;text-align:left;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--text-muted);border-bottom:2px solid var(--border);white-space:nowrap}
.data-table tbody td{padding:14px 20px;border-bottom:1px solid var(--border);color:var(--text-main);vertical-align:middle}
.data-table tbody tr{transition:var(--transition)}
.data-table tbody tr:hover{background:var(--bg-main)}
.data-table tbody tr:last-child td{border-bottom:none}
.data-table-compact thead th{padding:10px 16px}
.data-table-compact tbody td{padding:11px 16px}
.row-inactive td{opacity:.6}
.row-inactive td:first-child{opacity:1}
.text-right{text-align:right}
.text-nowrap{white-space:nowrap}
.text-truncate,.text-truncate,.max-w-200{overflow:hidden;white-space:nowrap;text-overflow:ellipsis;max-width:200px}
.max-w-150{max-width:150px}
.text-monospace{font-family:'JetBrains Mono',monospace;font-size:12px}
.text-link{color:var(--navy-500);text-decoration:underline;text-underline-offset:2px}
.text-link:hover{color:var(--navy-600)}
.action-buttons{display:flex;gap:4px;justify-content:flex-end}

/* ─── USER CELL ─── */
.user-cell{display:flex;align-items:center;gap:10px}
.user-cell-compact{display:flex;align-items:center;gap:8px}
.user-cell-info{display:flex;flex-direction:column;gap:2px}
.user-name{font-weight:600;font-size:14px}
.user-avatar{border-radius:50%;background:linear-gradient(135deg,var(--teal-500),var(--navy-400));display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;flex-shrink:0;text-transform:uppercase}
.user-avatar-xs{width:28px;height:28px;font-size:11px}
.user-avatar-sm{width:34px;height:34px;font-size:13px}
.user-avatar-lg{width:52px;height:52px;font-size:20px}
.user-profile-display{display:flex;align-items:center;gap:14px;padding:16px 24px;background:var(--bg-main);border-bottom:1px solid var(--border)}

/* ─── BADGES ─── */
.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:20px;font-size:12px;font-weight:600;white-space:nowrap}
.badge-lg{padding:5px 14px;font-size:13px}
.badge-xs{padding:2px 7px;font-size:11px}
.badge-primary{background:var(--navy-100);color:var(--navy-600)}
.badge-success{background:#d1fae5;color:#065f46}
.badge-warning{background:#fef3c7;color:#92400e}
.badge-danger{background:#fee2e2;color:#991b1b}
.badge-secondary{background:var(--bg-main);color:var(--text-muted);border:1px solid var(--border)}
.badge-info{background:#dbeafe;color:#1d4ed8}
.badge-purple{background:#ede9fe;color:#5b21b6}
.ml-2{margin-left:8px}

/* Evolução do NIR no TIMED — alerta piscando quando sem evolução há 24h+ */
.badge-blink{animation:badgeBlink 1.1s steps(2,start) infinite}
@keyframes badgeBlink{50%{opacity:.25}}
@media (prefers-reduced-motion: reduce){.badge-blink{animation:none}}
.timed-evolucao{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.timed-status{display:inline-flex;align-items:center}

/* ─── ALERTS ─── */
.alert{display:flex;align-items:center;gap:10px;padding:14px 18px;border-radius:var(--radius-md);margin-bottom:20px;font-size:14px;animation:slideDown .3s ease}
.alert-dismissible{position:relative;padding-right:44px}
.alert-close{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;font-size:16px;opacity:.6;display:flex;padding:4px;transition:var(--transition)}
.alert-close:hover{opacity:1}
.alert-success{background:#d1fae5;color:#065f46;border:1px solid #6ee7b7}
.alert-danger{background:#fee2e2;color:#991b1b;border:1px solid #fca5a5}
.alert-warning{background:#fef3c7;color:#92400e;border:1px solid #fde68a}
.alert-info{background:var(--navy-50);color:var(--navy-600);border:1px solid var(--navy-200)}

/* ─── PAGINATION ─── */
.pagination-wrapper{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-top:1px solid var(--border);flex-wrap:wrap;gap:10px}
.pagination-info{font-size:13px;color:var(--text-muted)}
.pagination{display:flex;align-items:center;gap:4px}
.pagination-btn{display:inline-flex;align-items:center;justify-content:center;min-width:36px;height:36px;padding:0 8px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;text-decoration:none;color:var(--text-muted);border:1px solid var(--border);transition:var(--transition)}
.pagination-btn:hover{border-color:var(--navy-400);color:var(--navy-500)}
.pagination-btn.active{background:var(--navy-600);color:#fff;border-color:var(--navy-600)}

/* ─── MODAL ─── */
.modal-overlay{position:fixed;inset:0;background:rgba(10,22,40,.65);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:999;padding:20px}
.modal-box{background:var(--bg-card);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);width:100%;max-height:90vh;overflow-y:auto;animation:scaleIn .2s ease}
.modal-sm{max-width:400px;text-align:center;padding:32px 24px}
.modal-md{max-width:560px}
.modal-icon{font-size:48px;margin-bottom:16px}
.modal-icon-warning{color:var(--warning)}
.modal-icon-danger{color:var(--danger)}
.modal-title{font-size:16px;font-weight:700;color:var(--text-main);margin-bottom:20px}
.modal-header{padding:20px 24px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.modal-header .modal-title{margin-bottom:0;font-size:18px}
.modal-body{padding:24px}
.modal-actions{display:flex;gap:10px;justify-content:center}
.modal-close{width:32px;height:32px;border-radius:50%;border:none;background:var(--bg-main);cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;color:var(--text-muted);transition:var(--transition)}
.modal-close:hover{background:#fee2e2;color:var(--danger)}
@keyframes scaleIn{from{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}

/* ─── EMPTY STATE ─── */
.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 24px;text-align:center}
.empty-state-icon{width:80px;height:80px;border-radius:50%;background:var(--bg-main);display:flex;align-items:center;justify-content:center;font-size:36px;color:var(--text-muted);margin-bottom:20px}
.empty-state h3{font-size:18px;font-weight:700;color:var(--text-main);margin-bottom:8px}
.empty-state p{font-size:14px;color:var(--text-muted);margin-bottom:24px}

/* ─── TOOLTIPS ─── */
.tooltip-trigger{position:relative}
.tooltip-trigger::after{content:attr(data-tooltip);position:absolute;bottom:calc(100% + 6px);left:50%;transform:translateX(-50%);background:var(--text-main);color:#fff;font-size:12px;padding:4px 10px;border-radius:6px;white-space:nowrap;opacity:0;pointer-events:none;transition:var(--transition);z-index:100}
.tooltip-trigger:hover::after{opacity:1}

/* ─── FORMS — EXTRA ─── */
.info-banner{display:flex;gap:14px;background:linear-gradient(135deg,var(--navy-50),#fff);border:1px solid var(--navy-200);border-radius:var(--radius-md);padding:18px 24px;margin:0 0 8px}
.info-banner-icon{font-size:28px;color:var(--navy-500);flex-shrink:0;margin-top:2px}
.info-banner-content strong{font-size:14px;font-weight:700;color:var(--navy-700);display:block;margin-bottom:4px}
.info-banner-content p{font-size:13px;color:var(--text-muted);line-height:1.6}
.security-tips{display:flex;gap:12px;background:#f8fafc;border:1px solid var(--border);border-radius:var(--radius-md);padding:16px;margin-bottom:16px}
.security-tips i{font-size:20px;color:var(--warning);flex-shrink:0;margin-top:2px}
.security-tips strong{font-size:13px;font-weight:700;display:block;margin-bottom:6px}
.security-tips ul{list-style:disc;padding-left:18px;font-size:13px;color:var(--text-muted);line-height:1.8}

/* ─── PERFIL CARDS ─── */
.perfil-cards{display:flex;flex-direction:column;gap:10px;padding:0 24px}
.perfil-card{display:flex;align-items:center;gap:14px;padding:14px 16px;border:2px solid var(--border);border-radius:var(--radius-md);cursor:pointer;transition:var(--transition);background:var(--bg-card)}
.perfil-card:hover{border-color:var(--navy-300);background:var(--bg-main)}
.perfil-card.selected{border-color:var(--navy-500);background:var(--navy-50)}
.perfil-card input[type=radio]{display:none}
.perfil-card-icon{width:40px;height:40px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.perfil-card-danger .perfil-card-icon{background:#fee2e2;color:#991b1b}
.perfil-card-primary .perfil-card-icon{background:var(--navy-100);color:var(--navy-600)}
.perfil-card-secondary .perfil-card-icon{background:var(--bg-main);color:var(--text-muted)}
.perfil-card-content{flex:1;display:flex;flex-direction:column}
.perfil-card-content strong{font-size:14px;font-weight:700;color:var(--text-main)}
.perfil-card-content span{font-size:12px;color:var(--text-muted);margin-top:2px}
.perfil-card-check{font-size:20px;color:var(--navy-500);opacity:0;transition:var(--transition)}
.perfil-card.selected .perfil-card-check{opacity:1}
.mt-4{margin-top:16px}

/* ─── TOGGLE ─── */
.toggle-wrapper{display:flex;align-items:center;gap:10px}
.toggle{position:relative;display:inline-flex;align-items:center;cursor:pointer}
.toggle input{display:none}
.toggle-track{width:44px;height:24px;border-radius:12px;background:var(--border);transition:var(--transition);flex-shrink:0}
.toggle input:checked ~ .toggle-track{background:var(--success)}
.toggle-thumb{position:absolute;left:3px;top:3px;width:18px;height:18px;border-radius:50%;background:#fff;box-shadow:var(--shadow-sm);transition:var(--transition)}
.toggle input:checked ~ .toggle-track .toggle-thumb{transform:translateX(20px)}
.toggle-label{font-size:14px;color:var(--text-main)}

/* ─── PASSWORD STRENGTH ─── */
.pw-strength-wrap{margin-top:8px;display:flex;align-items:center;gap:10px}
.pw-strength-bar{flex:1;height:4px;background:var(--border);border-radius:2px;overflow:hidden}
.pw-strength-fill{height:100%;border-radius:2px;transition:var(--transition-slow)}
.pw-strength-label{font-size:12px;font-weight:600;white-space:nowrap}
.pw-requirements{display:flex;gap:8px;flex-wrap:wrap;margin-top:6px}
.pw-req{font-size:12px;color:var(--text-muted);display:flex;align-items:center;gap:4px;transition:var(--transition)}
.pw-req.met{color:var(--success)}
.field-required .form-label::after{content:' *';color:var(--danger)}

/* ─── PROFILE PAGE ─── */
.profile-layout{display:grid;grid-template-columns:280px 1fr;gap:24px;align-items:start}
.profile-sidebar{}
.profile-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px 20px;text-align:center;box-shadow:var(--shadow-sm)}
.profile-avatar-wrap{position:relative;display:inline-block;margin-bottom:16px}
.profile-avatar{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,var(--teal-500),var(--navy-400));display:flex;align-items:center;justify-content:center;font-size:32px;font-weight:800;color:#fff;margin:0 auto}
.profile-avatar-ring{position:absolute;inset:-4px;border-radius:50%;border:2px solid var(--teal-400);animation:pulse-ring 2s ease-in-out infinite}
@keyframes pulse-ring{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.05)}}
.profile-name{font-size:18px;font-weight:800;color:var(--text-main);margin-bottom:4px}
.profile-email{font-size:13px;color:var(--text-muted);word-break:break-all}
.profile-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:4px;margin:20px -4px;border-top:1px solid var(--border);padding-top:16px}
.profile-stat{text-align:center;padding:8px 4px}
.profile-stat-value{display:block;font-size:16px;font-weight:800;color:var(--text-main)}
.profile-stat-label{display:block;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-top:2px}
.profile-lgpd-info{display:flex;align-items:center;gap:8px;background:var(--bg-main);border:1px solid var(--border);border-radius:var(--radius-md);padding:10px 12px;text-align:left;font-size:12px;color:var(--text-muted);margin-top:14px}
.profile-lgpd-info i{color:var(--success);font-size:16px;flex-shrink:0}
.profile-quick-actions{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;margin-top:14px;box-shadow:var(--shadow-sm)}
.profile-quick-btn{display:flex;align-items:center;gap:10px;width:100%;padding:14px 16px;background:none;border:none;border-bottom:1px solid var(--border);font-family:inherit;font-size:14px;font-weight:500;color:var(--text-muted);cursor:pointer;transition:var(--transition);text-align:left}
.profile-quick-btn:last-child{border-bottom:none}
.profile-quick-btn:hover{background:var(--bg-main);color:var(--text-main)}
.profile-quick-btn.active{background:var(--navy-50);color:var(--navy-600);font-weight:600;border-left:3px solid var(--navy-500)}
.d-block{display:block}

/* ─── ACTIVITY ─── */
.activity-list{padding:8px 0}
.activity-item{display:flex;align-items:flex-start;gap:14px;padding:14px 24px;border-bottom:1px solid var(--border);transition:var(--transition)}
.activity-item:last-child{border-bottom:none}
.activity-item:hover{background:var(--bg-main)}
.activity-icon{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}
.activity-icon-success{background:#d1fae5;color:#065f46}
.activity-icon-primary{background:var(--navy-100);color:var(--navy-600)}
.activity-icon-danger{background:#fee2e2;color:#991b1b}
.activity-info{display:flex;flex-direction:column;gap:2px;flex:1}
.activity-action{font-size:14px;font-weight:600;color:var(--text-main)}
.activity-time{font-size:12px;color:var(--text-muted)}

/* ─── AUDIT LOG ─── */
.lgpd-notice-bar{display:flex;align-items:center;gap:12px;background:linear-gradient(135deg,#ede9fe,#f5f3ff);border:1px solid #c4b5fd;border-radius:var(--radius-md);padding:12px 18px;margin-bottom:20px;font-size:13px;color:#4c1d95}
.lgpd-notice-bar i{font-size:18px;color:#7c3aed;flex-shrink:0}
.log-timestamp{display:block;line-height:1.4}
.user-cell-compact{display:flex;align-items:center;gap:8px}
.log-details-toggle{color:var(--navy-500);cursor:pointer;font-size:13px;display:inline-flex;align-items:center;gap:4px;text-decoration:underline;text-underline-offset:2px}
.log-details-toggle:hover{color:var(--navy-600)}
.log-details-pre{font-family:'JetBrains Mono',monospace;font-size:12px;line-height:1.6;color:var(--text-main);background:var(--bg-main);padding:16px;border-radius:var(--radius-md);max-height:400px;overflow-y:auto;white-space:pre-wrap;word-break:break-all}

/* ─── REPORTS ─── */
.filter-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;align-items:end}

/* ─── LOGIN PAGE ─── */
.login-bg{min-height:100vh;background:linear-gradient(135deg,var(--navy-950) 0%,var(--navy-800) 50%,var(--navy-700) 100%);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;padding:20px}
.login-bg::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E")}
.login-orb{position:absolute;border-radius:50%;filter:blur(80px);opacity:.15;animation:float 8s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0) scale(1)}50%{transform:translateY(-30px) scale(1.05)}}
.login-card{background:rgba(255,255,255,.04);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-xl);padding:40px;width:100%;max-width:420px;position:relative;z-index:1;box-shadow:0 24px 80px rgba(0,0,0,.4);animation:fadeInUp .6s ease}
.login-logo{display:block;max-width:220px;margin:0 auto 8px}
.login-system-name{text-align:center;color:var(--teal-400);font-size:22px;font-weight:800;letter-spacing:-.5px;margin-bottom:6px}
.login-subtitle{text-align:center;color:rgba(255,255,255,.5);font-size:13px;margin-bottom:32px}
.login-card .form-label{color:rgba(255,255,255,.8)}
.login-card .form-control{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.15);color:#fff}
.login-card .form-control:focus{border-color:var(--teal-400);box-shadow:0 0 0 3px rgba(30,198,184,.2)}
.login-card .form-control::placeholder{color:rgba(255,255,255,.3)}
.login-card .input-icon{color:rgba(255,255,255,.4)}
.btn-login{width:100%;background:linear-gradient(135deg,var(--teal-600),var(--teal-400));color:#fff;padding:13px;font-size:15px;font-weight:700;border:none;border-radius:var(--radius-md);cursor:pointer;transition:var(--transition);position:relative;overflow:hidden;font-family:inherit}
.btn-login::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.15) 50%,transparent 100%);transform:translateX(-100%);transition:transform .5s ease}
.btn-login:hover{transform:translateY(-2px);box-shadow:var(--shadow-glow)}
.btn-login:hover::after{transform:translateX(100%)}

/* ─── LGPD PAGE ─── */
.lgpd-card{max-width:700px;margin:40px auto;animation:fadeInUp .5s ease}
.lgpd-content{font-size:14px;line-height:1.8;color:var(--text-main);max-height:400px;overflow-y:auto;padding:20px;background:var(--bg-main);border-radius:var(--radius-md);border:1px solid var(--border)}
.lgpd-content h3{font-size:15px;font-weight:700;margin:16px 0 8px;color:var(--navy-700)}
.lgpd-content p{margin-bottom:10px}
.lgpd-content ul{padding-left:20px;margin-bottom:10px}

/* ─── ANIMATIONS ─── */
@keyframes fadeInUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
@keyframes slideDown{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}
@keyframes pulse-dot{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}
@keyframes spin{to{transform:rotate(360deg)}}
.animate-in{animation:fadeInUp .5s ease both}
.status-dot{font-size:8px!important;line-height:1}
.loading-shimmer{background:linear-gradient(90deg,#f0f4f8 25%,#e8f0f7 50%,#f0f4f8 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-md)}

/* ─── UTILS ─── */
.flex{display:flex}.flex-center{display:flex;align-items:center;justify-content:center}
.items-center{align-items:center}.justify-between{justify-content:space-between}
.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}
.mt-2{margin-top:8px}.mt-4{margin-top:16px}.mb-4{margin-bottom:20px}.mb-6{margin-bottom:28px}
.text-muted{color:var(--text-muted)}.text-sm{font-size:13px}.text-xs{font-size:11px}
.font-bold{font-weight:700}
.text-center{text-align:center}.w-full{width:100%}
.divider{border:none;border-top:1px solid var(--border);margin:20px 0}
.d-none{display:none!important}

/* ─── RESPONSIVE ─── */
@media(max-width:1280px){
  .stats-grid-4{grid-template-columns:repeat(2,1fr)}
  .charts-row{grid-template-columns:1fr}
}
@media(max-width:1024px){
  .form-grid-2,.form-grid-3{grid-template-columns:1fr 1fr}
  .profile-layout{grid-template-columns:1fr}
  .filter-grid-5{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:768px){
  .sidebar{transform:translateX(-100%);z-index:200}
  .sidebar.open{transform:translateX(0);box-shadow:var(--shadow-lg)}
  .sidebar-overlay{display:block}
  .main-content{margin-left:0}
  .btn-menu-toggle{display:flex}
  .page-content{padding:16px}
  .topbar{padding:0 16px}
  .page-header{gap:12px}
  .page-actions{width:100%}
  .page-title{font-size:20px}
  .stats-grid-4,.stats-grid-6{grid-template-columns:repeat(2,1fr)}
  .data-table{font-size:13px}
  .data-table thead th,.data-table tbody td{padding:10px 14px}
  .form-grid-2,.form-grid-3{grid-template-columns:1fr}
  .charts-row{grid-template-columns:1fr}
  .filter-grid,.filter-grid-5{grid-template-columns:1fr 1fr}
  .profile-layout{grid-template-columns:1fr}
  .form-actions{flex-wrap:wrap}
  .stats-row{gap:10px}
  .stat-mini{min-width:calc(50% - 5px)}
}
@media(max-width:480px){
  .stats-grid-4{grid-template-columns:1fr}
  .filter-grid,.filter-grid-5{grid-template-columns:1fr}
  .action-buttons{gap:2px}
  .btn-group-filter{flex-direction:column}
  .page-actions .btn{flex:1;justify-content:center}
}

/* ════════════════════════════════════════════════════════════
   v2 — MOVIMENTO, POLISH & CARD DE PACIENTE  (aditivo)
   ════════════════════════════════════════════════════════════ */

/* ── Micro-interações (não ocultam conteúdo) ── */
.form-section{transition:box-shadow .3s ease,border-color .3s ease}
.form-section:focus-within{box-shadow:var(--shadow-md);border-color:var(--navy-200)}
.form-section-header{position:relative}
.form-section-header::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:linear-gradient(var(--teal-400),var(--navy-500));opacity:0;transition:opacity .3s ease}
.form-section:focus-within .form-section-header::before{opacity:1}
.form-section:focus-within .form-section-icon{background:var(--teal-100);color:var(--teal-600)}
.input-wrapper:focus-within .input-icon{color:var(--navy-500)}
.card{transition:var(--transition),transform .25s ease}
.card:hover{transform:translateY(-2px)}
.nav-item{transition:var(--transition),transform .2s ease}
.nav-item:hover{transform:translateX(3px)}
.stat-card:hover{transform:translateY(-4px)}

/* ── Botões com brilho que varre ── */
.btn-primary,.btn-teal,.btn-success,.btn-danger{position:relative;overflow:hidden}
.btn-primary::after,.btn-teal::after,.btn-success::after,.btn-danger::after{content:'';position:absolute;inset:0;background:linear-gradient(100deg,transparent 20%,rgba(255,255,255,.22) 50%,transparent 80%);transform:translateX(-130%);transition:transform .6s cubic-bezier(.4,0,.2,1);pointer-events:none}
.btn-primary:hover:not(:disabled)::after,.btn-teal:hover:not(:disabled)::after,.btn-success:hover:not(:disabled)::after,.btn-danger:hover:not(:disabled)::after{transform:translateX(130%)}

/* ── Entrada orquestrada (respeita prefers-reduced-motion) ── */
@media (prefers-reduced-motion: no-preference){
  .page-header{animation:fadeInUp .5s cubic-bezier(.4,0,.2,1) both}
  .form-section{animation:fadeInUp .55s cubic-bezier(.4,0,.2,1) both}
  .form-section:nth-child(2){animation-delay:.06s}
  .form-section:nth-child(3){animation-delay:.12s}
  .form-section:nth-child(4){animation-delay:.18s}
  .form-section:nth-child(5){animation-delay:.24s}
  .form-section:nth-child(6){animation-delay:.30s}
  .card{animation:fadeInUp .55s cubic-bezier(.4,0,.2,1) both}
  .stats-grid>*,.stats-row>*{animation:fadeInUp .5s cubic-bezier(.4,0,.2,1) both}
  .stats-grid>*:nth-child(2),.stats-row>*:nth-child(2){animation-delay:.07s}
  .stats-grid>*:nth-child(3),.stats-row>*:nth-child(3){animation-delay:.14s}
  .stats-grid>*:nth-child(4),.stats-row>*:nth-child(4){animation-delay:.21s}
  .stats-grid>*:nth-child(5),.stats-row>*:nth-child(5){animation-delay:.28s}
  .stats-grid>*:nth-child(6),.stats-row>*:nth-child(6){animation-delay:.35s}
}

/* ── Busca por BAM ── */
.input-wrapper-action{position:relative}
.input-wrapper-action .form-control{padding-right:52px}
.btn-bam-buscar{position:absolute;right:6px;top:50%;transform:translateY(-50%);width:38px;height:38px;border:none;border-radius:var(--radius-sm);cursor:pointer;background:linear-gradient(135deg,var(--teal-600),var(--teal-400));color:#fff;display:flex;align-items:center;justify-content:center;font-size:17px;box-shadow:0 2px 8px rgba(14,168,158,.32);transition:var(--transition)}
.btn-bam-buscar:hover:not(:disabled){box-shadow:var(--shadow-glow);transform:translateY(-50%) scale(1.05)}
.btn-bam-buscar:active:not(:disabled){transform:translateY(-50%) scale(.96)}
.btn-bam-buscar:disabled{opacity:.7;cursor:default}
.btn-bam-buscar .spin{animation:spin .7s linear infinite}
.bam-hint{display:block;margin-top:7px;font-size:12px;color:var(--text-muted);min-height:1.1em;transition:color .2s ease}
.bam-hint.is-loading{color:var(--navy-500)}
.bam-hint.is-success{color:var(--teal-600);font-weight:600}
.bam-hint.is-error{color:var(--danger);font-weight:600}

/* ── Card de paciente (censo Vitai) ── */
.patient-card{position:relative;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin-bottom:20px;overflow:hidden;display:none}
.patient-card.is-visible{display:block}
@media (prefers-reduced-motion: no-preference){
  .patient-card.is-visible{animation:pcReveal .55s cubic-bezier(.34,1.4,.5,1) both}
  .patient-card.is-pulse{animation:pcReveal .55s cubic-bezier(.34,1.4,.5,1) both,pcGlow 1.6s ease .35s}
}
@keyframes pcReveal{from{opacity:0;transform:translateY(16px) scale(.985)}to{opacity:1;transform:none}}
@keyframes pcGlow{0%,100%{box-shadow:var(--shadow-sm)}45%{box-shadow:0 0 0 3px rgba(30,198,184,.30),0 14px 44px rgba(30,198,184,.28)}}
.patient-card-head{display:flex;align-items:center;gap:18px;padding:22px 24px;background:linear-gradient(120deg,var(--navy-900),var(--navy-700));color:#fff;position:relative;overflow:hidden}
.patient-card-head::after{content:'';position:absolute;top:-45%;right:-4%;width:240px;height:240px;background:radial-gradient(circle,var(--teal-400),transparent 64%);opacity:.22;pointer-events:none}
.patient-avatar{position:relative;width:62px;height:62px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:800;letter-spacing:.02em;color:#fff;background:linear-gradient(135deg,var(--teal-500),var(--teal-600));box-shadow:0 0 0 3px rgba(255,255,255,.16),0 8px 20px rgba(0,0,0,.25);z-index:1}
.patient-avatar-dot{position:absolute;right:1px;bottom:1px;width:14px;height:14px;border-radius:50%;background:var(--success);border:2px solid var(--navy-900);animation:pulse-ring 2s ease-in-out infinite}
.patient-headline{flex:1;min-width:0;z-index:1}
.patient-name{font-size:19px;font-weight:700;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.patient-chips{display:flex;flex-wrap:wrap;gap:7px;margin-top:9px}
.patient-chip{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:600;padding:4px 11px;border-radius:999px;background:rgba(255,255,255,.13);color:#fff;border:1px solid rgba(255,255,255,.10)}
.patient-chip i{font-size:13px;opacity:.9}
.patient-chip-teal{background:rgba(30,198,184,.20);color:var(--teal-100);border-color:rgba(30,198,184,.30)}
.patient-card-seal{display:inline-flex;align-items:center;gap:6px;font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--teal-300);align-self:flex-start;z-index:1;white-space:nowrap}
.patient-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border)}
.patient-field{background:var(--bg-card);padding:14px 18px;display:flex;flex-direction:column;gap:3px;min-width:0}
.patient-field-label{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted)}
.patient-field-value{font-size:14px;font-weight:600;color:var(--text-main);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.patient-field-value.is-mono{font-family:'JetBrains Mono',monospace;font-size:13px;letter-spacing:-.02em}
.patient-field-value.is-empty{color:var(--text-muted);font-weight:500}
@media (prefers-reduced-motion: no-preference){
  .patient-card.is-visible .patient-field{animation:fadeInUp .4s ease both}
  .patient-card.is-visible .patient-field:nth-child(1){animation-delay:.14s}
  .patient-card.is-visible .patient-field:nth-child(2){animation-delay:.20s}
  .patient-card.is-visible .patient-field:nth-child(3){animation-delay:.26s}
  .patient-card.is-visible .patient-field:nth-child(4){animation-delay:.32s}
  .patient-card.is-visible .patient-field:nth-child(5){animation-delay:.38s}
  .patient-card.is-visible .patient-field:nth-child(6){animation-delay:.44s}
}
@media(max-width:1024px){.patient-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.patient-card-head{flex-wrap:wrap;gap:14px}.patient-grid{grid-template-columns:1fr}}

/* ============================================================
   UPGRADE 2026-06-10 — Tabelas modernas + ícones animados
   ============================================================ */

/* ── Container com rolagem horizontal suave ── */
.table-wrap{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:var(--radius-lg)}
.table-wrap::-webkit-scrollbar{height:8px}
.table-wrap::-webkit-scrollbar-thumb{background:var(--navy-300);border-radius:4px}

/* ── Tabela base (Registros, Ambulâncias) e harmonização com .data-table ── */
.table-wrap > table,
.data-table{width:100%;border-collapse:separate;border-spacing:0;font-size:14px;min-width:720px}

/* Cabeçalho com gradiente e cantos arredondados */
.table-wrap > table thead th,
.data-table thead th{
  background:linear-gradient(180deg,#f8fbfe 0%,#eaf1f8 100%);
  padding:14px 18px;text-align:left;
  font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.7px;
  color:var(--navy-500);border-bottom:2px solid var(--border);white-space:nowrap;
}
.table-wrap > table thead th:first-child,
.data-table thead th:first-child{border-top-left-radius:14px}
.table-wrap > table thead th:last-child,
.data-table thead th:last-child{border-top-right-radius:14px}

/* Células */
.table-wrap > table tbody td,
.data-table tbody td{
  padding:14px 18px;border-bottom:1px solid var(--border);
  color:var(--text-main);vertical-align:middle;background:var(--bg-card);
}

/* Zebra + hover com tinta teal e barra de acento à esquerda */
.table-wrap > table tbody tr,
.data-table tbody tr{transition:var(--transition);position:relative}
.table-wrap > table tbody tr:nth-child(even) td,
.data-table tbody tr:nth-child(even) td{background:#fbfdff}
.table-wrap > table tbody tr:hover td,
.data-table tbody tr:hover td{background:rgba(30,198,184,.09)}
.table-wrap > table tbody tr:hover td:first-child,
.data-table tbody tr:hover td:first-child{box-shadow:inset 3px 0 0 0 var(--teal-400)}
.table-wrap > table tbody tr:last-child td,
.data-table tbody tr:last-child td{border-bottom:none}

/* Entrada escalonada das linhas */
@keyframes rowIn{from{opacity:0;transform:translateY(7px)}to{opacity:1;transform:none}}
.table-wrap > table tbody tr,
.data-table tbody tr{animation:rowIn .45s ease both}
.table-wrap > table tbody tr:nth-child(1),.data-table tbody tr:nth-child(1){animation-delay:.03s}
.table-wrap > table tbody tr:nth-child(2),.data-table tbody tr:nth-child(2){animation-delay:.07s}
.table-wrap > table tbody tr:nth-child(3),.data-table tbody tr:nth-child(3){animation-delay:.11s}
.table-wrap > table tbody tr:nth-child(4),.data-table tbody tr:nth-child(4){animation-delay:.15s}
.table-wrap > table tbody tr:nth-child(5),.data-table tbody tr:nth-child(5){animation-delay:.19s}
.table-wrap > table tbody tr:nth-child(6),.data-table tbody tr:nth-child(6){animation-delay:.23s}
.table-wrap > table tbody tr:nth-child(7),.data-table tbody tr:nth-child(7){animation-delay:.27s}
.table-wrap > table tbody tr:nth-child(8),.data-table tbody tr:nth-child(8){animation-delay:.31s}
.table-wrap > table tbody tr:nth-child(n+9),.data-table tbody tr:nth-child(n+9){animation-delay:.34s}

/* Cabeçalho do card */
.card > .card-header{border-bottom:1px solid var(--border)}

/* ============================================================
   ÍCONES ANIMADOS EM LOOPING (estilo "animado e vivo")
   ============================================================ */
@keyframes iconFloat{0%,100%{transform:translateY(0) scale(1)}50%{transform:translateY(-5px) scale(1.09)}}
@keyframes iconRing{0%{box-shadow:0 0 0 0 currentColor;opacity:.35}70%{box-shadow:0 0 0 13px currentColor;opacity:0}100%{box-shadow:0 0 0 13px currentColor;opacity:0}}
@keyframes iconSway{0%,100%{transform:rotate(0) scale(1)}25%{transform:rotate(-7deg)}50%{transform:rotate(0) scale(1.12)}75%{transform:rotate(7deg)}}
@keyframes iconWrite{0%,100%{transform:rotate(0)}50%{transform:rotate(-16deg)}}
@keyframes iconWobble{0%,100%{transform:rotate(0)}20%{transform:rotate(-10deg)}40%{transform:rotate(8deg)}60%{transform:rotate(-5deg)}80%{transform:rotate(3deg)}}

/* Ícones dos cards de estatística — flutuam + anel pulsante, escalonados */
.stat-card-icon{animation:iconFloat 2.8s ease-in-out infinite;position:relative}
.stat-card-icon::after{content:'';position:absolute;inset:0;border-radius:inherit;pointer-events:none;animation:iconRing 2.8s ease-out infinite}
.stat-card-primary .stat-card-icon,.stat-card-primary .stat-card-icon::after{animation-delay:0s}
.stat-card-warning .stat-card-icon,.stat-card-warning .stat-card-icon::after{animation-delay:.35s}
.stat-card-success .stat-card-icon,.stat-card-success .stat-card-icon::after{animation-delay:.7s}
.stat-card-info .stat-card-icon,.stat-card-info .stat-card-icon::after,
.stat-card-teal .stat-card-icon,.stat-card-teal .stat-card-icon::after{animation-delay:1.05s}
.stat-card-danger .stat-card-icon,.stat-card-danger .stat-card-icon::after{animation-delay:.5s}

/* Ícones de título (seções e páginas) — balançam suavemente */
.card-title i.ph,.page-title i.ph{display:inline-block;transform-origin:center;animation:iconSway 3.4s ease-in-out infinite}
.page-title i.ph{color:var(--teal-500)}

/* Ícones de ação na linha (lápis escreve, lixeira balança) */
.btn-icon .ph{display:inline-block;will-change:transform}
.btn-icon .ph-pencil-simple,.btn-icon .ph-pencil{transform-origin:bottom left;animation:iconWrite 2.4s ease-in-out infinite}
.btn-icon .ph-trash{transform-origin:top center;animation:iconWobble 2.8s ease-in-out infinite}
.btn-icon:hover{transform:translateY(-2px) scale(1.08)}
.btn-icon:hover .ph{animation-duration:.5s}

/* Ícone do "vazio" (empty-state) pulsa levemente */
.empty-state-icon i.ph{display:inline-block;animation:iconFloat 3s ease-in-out infinite}

/* Respeita usuários que preferem menos movimento */
@media (prefers-reduced-motion: reduce){
  .table-wrap > table tbody tr,.data-table tbody tr,
  .stat-card-icon,.stat-card-icon::after,
  .card-title i.ph,.page-title i.ph,
  .btn-icon .ph,.empty-state-icon i.ph{animation:none!important}
}

/* ============================================================
   LOGIN — luzes verde e azul animadas atrás do card
   ============================================================ */
.login-lights{position:absolute;inset:0;overflow:hidden;z-index:0;pointer-events:none}
.login-light{position:absolute;border-radius:50%;filter:blur(72px);opacity:.55;mix-blend-mode:screen;will-change:transform}
.login-light.lg{width:460px;height:460px}
.login-light.md{width:330px;height:330px}
.login-light.sm{width:230px;height:230px}
.ll-green{background:radial-gradient(circle at 35% 35%,#3ef0a3 0%,#0bab64 55%,transparent 72%)}
.ll-blue{background:radial-gradient(circle at 35% 35%,#5aa6ff 0%,#1155a3 55%,transparent 72%)}
.ll-cyan{background:radial-gradient(circle at 35% 35%,#34e8d4 0%,#0d7377 55%,transparent 72%)}
.login-light.p1{top:-120px;left:-80px;animation:llDrift1 14s ease-in-out infinite}
.login-light.p2{bottom:-150px;right:-90px;animation:llDrift2 17s ease-in-out infinite}
.login-light.p3{top:26%;right:6%;animation:llDrift3 12s ease-in-out infinite}
.login-light.p4{bottom:10%;left:4%;animation:llDrift4 19s ease-in-out infinite}
@keyframes llDrift1{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(130px,90px) scale(1.18)}}
@keyframes llDrift2{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(-110px,-70px) scale(1.22)}}
@keyframes llDrift3{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(-90px,70px) scale(1.12)}}
@keyframes llDrift4{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(80px,-60px) scale(1.2)}}

/* Ícones de input — posicionamento e legibilidade sobre o card escuro */
.login-card .input-group{position:relative}
.login-card .input-group .form-control{padding-left:42px}
.login-card #senha{padding-right:42px}
.login-card .input-icon{top:50%;transform:translateY(-50%);color:rgba(255,255,255,.55);font-size:17px;z-index:2}
.login-card .btn-toggle-pass{top:50%;transform:translateY(-50%)}
.login-card .btn-toggle-pass:hover{color:#fff!important}

@media (prefers-reduced-motion: reduce){.login-light{animation:none!important}}
