:root{
  --paper:#F3F4F8;
  --paper-raised:#FFFFFF;
  --ink:#171821;
  --ink-soft:#6B6D7C;
  --line:#E7E8EF;
  --accent:#5B53F5;
  --accent-dark:#4842D1;
  --accent-soft:#ECEAFE;
  --terracotta:#E0526B;
  --terracotta-soft:#FCE4E8;
  --gold:#D69A2D;
  --gold-soft:#FBF1DD;
  --blue:#2E8FD1;
  --blue-soft:#E3F1FC;
  --sidebar-bg:#13141C;
  --radius:14px;
}
*{box-sizing:border-box;}
body{margin:0;background:var(--paper);color:var(--ink);font-family:'Inter','IBM Plex Sans', sans-serif;-webkit-font-smoothing:antialiased;}
a{color:inherit;}
.app{display:flex;min-height:100vh;}

.sidebar{width:248px;flex-shrink:0;background:var(--sidebar-bg);color:#C9CAD6;padding:26px 16px;display:flex;flex-direction:column;gap:4px;}
.brand{display:flex;align-items:center;gap:10px;margin:0 6px 26px 6px;}
.brand::before{content:'';display:inline-block;width:34px;height:34px;border-radius:10px;background:linear-gradient(135deg,var(--accent),#8B7CFF);flex-shrink:0;}
.brand{font-family:'Inter',sans-serif;font-size:17px;font-weight:700;color:#fff;line-height:1.15;}
.brand span{display:block;font-size:10.5px;font-family:'Inter',sans-serif;color:#7C7E91;font-weight:600;letter-spacing:.08em;margin-top:2px;}

.nav-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;cursor:pointer;font-size:14px;font-weight:500;color:#9A9CAD;transition:background .15s, color .15s;text-decoration:none;}
.nav-item:hover{background:rgba(255,255,255,.06);color:#fff;}
.nav-item.active{background:var(--accent);color:#fff;font-weight:600;}
.nav-icon{width:18px;text-align:center;font-family:'Inter',monospace;font-size:14px;}
.nav-divider{height:1px;background:rgba(255,255,255,.08);margin:14px 8px;}
.sidebar-footer{margin-top:auto;font-size:11px;color:#6E7086;padding:0 8px;line-height:1.5;}

.main{flex:1;padding:36px 44px;max-width:1180px;}
.page-header{margin-bottom:28px;display:flex;justify-content:space-between;align-items:flex-start;}
.page-header h1{font-family:'Inter',sans-serif;font-size:27px;font-weight:800;margin:0 0 6px;letter-spacing:-.01em;}
.page-header p{margin:0;color:var(--ink-soft);font-size:14px;}
.user-chip{font-size:12.5px;color:var(--ink-soft);}
.user-chip a{color:var(--accent);text-decoration:none;margin-left:10px;font-weight:600;}

.grid{display:grid;gap:16px;}
.grid-4{grid-template-columns:repeat(4,1fr);}
@media (max-width:900px){.grid-4{grid-template-columns:repeat(2,1fr);}}

.stat-card{background:var(--paper-raised);border:1px solid var(--line);border-radius:var(--radius);padding:20px 20px 18px;box-shadow:0 1px 2px rgba(20,20,40,.03);}
.stat-icon{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:16px;margin-bottom:14px;background:var(--accent-soft);color:var(--accent);}
.stat-card.warn .stat-icon{background:var(--terracotta-soft);color:var(--terracotta);}
.stat-card.ok .stat-icon{background:var(--blue-soft);color:var(--blue);}
.stat-card .num{font-family:'Inter',sans-serif;font-size:30px;font-weight:800;line-height:1;letter-spacing:-.02em;}
.stat-card .label{font-size:12.5px;color:var(--ink-soft);margin-top:6px;}
.stat-card.warn .num{color:var(--terracotta);}
.stat-card.ok .num{color:var(--accent);}

.panel{background:var(--paper-raised);border:1px solid var(--line);border-radius:var(--radius);padding:22px;margin-bottom:20px;box-shadow:0 1px 2px rgba(20,20,40,.03);}
.panel h2{font-family:'Inter',sans-serif;font-size:17px;font-weight:700;margin:0 0 16px;display:flex;align-items:center;justify-content:space-between;}
.panel h2 small{font-size:11.5px;font-family:'Inter',monospace;color:var(--ink-soft);font-weight:500;background:var(--paper);padding:3px 9px;border-radius:20px;}

.timeline{display:flex;flex-direction:column;gap:0;}
.tl-row{display:grid;grid-template-columns:84px 18px 1fr auto;align-items:center;gap:14px;padding:11px 4px;border-bottom:1px solid var(--line);font-size:13.5px;}
.tl-row:last-child{border-bottom:none;}
.tl-date{font-family:'Inter',monospace;font-size:12px;color:var(--ink-soft);}
.tl-dot{width:8px;height:8px;border-radius:50%;margin:0 auto;}
.tl-dot.ferias{background:var(--accent);}
.tl-dot.experiencia{background:var(--terracotta);}
.tl-dot.aniversario{background:var(--gold);}
.tl-dot.empresa{background:var(--blue);}
.tl-tag{font-size:11px;font-family:'Inter',monospace;padding:3px 9px;border-radius:20px;white-space:nowrap;font-weight:600;}
.tl-tag.urgente{background:var(--terracotta-soft);color:var(--terracotta);}
.tl-tag.normal{background:var(--accent-soft);color:var(--accent);}
.tl-tag.gold{background:var(--gold-soft);color:var(--gold);}
.empty-state{padding:30px 10px;text-align:center;color:var(--ink-soft);font-size:13.5px;}

table{width:100%;border-collapse:collapse;font-size:13.5px;}
th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-soft);font-weight:600;padding:8px 10px;border-bottom:1px solid var(--line);}
td{padding:12px 10px;border-bottom:1px solid var(--line);vertical-align:middle;}
tr:last-child td{border-bottom:none;}
.pill{display:inline-block;padding:4px 11px;border-radius:20px;font-size:11.5px;font-family:'Inter',sans-serif;font-weight:600;}
.pill.vencida{background:var(--terracotta-soft);color:var(--terracotta);}
.pill.proxima{background:var(--gold-soft);color:var(--gold);}
.pill.ok{background:var(--accent-soft);color:var(--accent);}
.row-actions{display:flex;gap:8px;}
.icon-btn{border:1px solid var(--line);background:var(--paper-raised);border-radius:8px;width:30px;height:30px;cursor:pointer;font-size:13px;color:var(--ink-soft);display:flex;align-items:center;justify-content:center;text-decoration:none;}
.icon-btn:hover{border-color:var(--accent);color:var(--accent);}

.btn{background:var(--accent);color:#fff;border:none;border-radius:10px;padding:10px 20px;font-size:13.5px;font-weight:600;cursor:pointer;font-family:'Inter',sans-serif;text-decoration:none;display:inline-block;}
.btn:hover{background:var(--accent-dark);}
.btn.secondary{background:transparent;border:1px solid var(--line);color:var(--ink);}
.btn.secondary:hover{border-color:var(--accent);color:var(--accent);}
.btn.danger{background:var(--terracotta);}
.btn.danger:hover{background:#c43e55;}

.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-bottom:14px;}
label{display:block;font-size:12px;color:var(--ink-soft);margin-bottom:5px;font-weight:600;}
input, select{width:100%;padding:10px 12px;border:1px solid var(--line);border-radius:9px;font-size:13.5px;font-family:'Inter',sans-serif;background:var(--paper);color:var(--ink);}
input:focus, select:focus{outline:2px solid var(--accent);outline-offset:1px;border-color:var(--accent);}

.toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px;}
.empty-big{text-align:center;padding:60px 20px;color:var(--ink-soft);}
.empty-big .big-icon{font-family:'Inter',sans-serif;font-size:38px;color:var(--line);margin-bottom:10px;}
.future-note{border:1px dashed var(--line);border-radius:var(--radius);padding:16px 18px;font-size:13px;color:var(--ink-soft);margin-top:6px;background:var(--paper);}
.alert{padding:11px 14px;border-radius:10px;font-size:13.5px;margin-bottom:16px;font-weight:500;}
.alert.erro{background:var(--terracotta-soft);color:var(--terracotta);}
.alert.sucesso{background:var(--accent-soft);color:var(--accent);}

.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--paper);}
.login-box{background:var(--paper-raised);border:1px solid var(--line);border-radius:18px;padding:36px;width:380px;box-shadow:0 8px 30px rgba(20,20,40,.06);}
.login-box h1{font-family:'Inter',sans-serif;font-size:23px;font-weight:800;margin:0 0 4px;}
.login-box p{color:var(--ink-soft);font-size:13.5px;margin:0 0 24px;}
:focus-visible{outline:2px solid var(--accent);outline-offset:2px;}
