﻿/* ── PALETA NEUTRO CÁLIDO — Optimizada para uso diario intensivo ── */
:root{
  /* Acento: ámbar/dorado cálido — evoca cuero, papel, derecho clásico */
  --acc:#B45309;--acc-d:#92400E;--acc-bg:rgba(180,83,9,.09);--acc-bg2:rgba(180,83,9,.04);
  /* Sidebar: marrón casi negro — cálido, no frío como el negro puro */
  --sb:#1C1917;--sb2:#292524;--sbt:rgba(255,255,255,.58);--sba:rgba(255,255,255,.06);
  /* Fondos: crema muy suave — no blanco puro, reduce fatiga ocular */
  --bg:#FAFAF8;--srf:#FFFFFF;--srf2:#F5F3F0;--brd:#E7E5E4;--brd2:#EDE9E5;
  /* Textos: marrón oscuro cálido — más descansado que el negro puro */
  --tx:#1C1917;--tx2:#57534E;--tx3:#A8A29E;
  /* Estados: colores cálidos y bien contrastados */
  --g:rgba(21,128,61,.1);--gc:#14532D;--gcb:#16A34A;
  --b:rgba(180,83,9,.1);--bc:#92400E;--bcb:#B45309;
  --y:rgba(202,138,4,.1);--yc:#78350F;--ycb:#CA8A04;
  --r:rgba(220,38,38,.1);--rc:#991B1B;--rcb:#DC2626;
  --p:rgba(124,58,237,.1);--pc:#4C1D95;--pcb:#7C3AED;
  --gr:rgba(120,113,108,.12);--grc:#78716C;
  --rad:10px;--rads:7px;
  --sh:0 1px 2px rgba(0,0,0,.04),0 1px 3px rgba(0,0,0,.03);
  --shm:0 4px 12px rgba(0,0,0,.07);--shl:0 16px 48px rgba(0,0,0,.12);
  --tr:.15s ease;
  --font:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
}

/* ── DARK MODE CÁLIDO — Marrón oscuro, nunca negro frío ── */
html.dark{
  /* Acento más luminoso sobre fondo oscuro */
  --acc:#D97706;--acc-d:#B45309;--acc-bg:rgba(217,119,6,.12);--acc-bg2:rgba(217,119,6,.06);
  /* Sidebar aún más oscuro que el fondo */
  --sb:#0C0A09;--sb2:#1C1917;--sbt:rgba(255,255,255,.55);--sba:rgba(255,255,255,.06);
  /* Fondos: oscuro cálido — marrón carbón, nunca azul frío */
  --bg:#1C1917;--srf:#292524;--srf2:#1C1917;--brd:#44403C;--brd2:#292524;
  /* Textos: blanco roto cálido */
  --tx:#FAF9F7;--tx2:#A8A29E;--tx3:#57534E;
  /* Estados adaptados al fondo cálido oscuro */
  --g:rgba(21,128,61,.14);--gc:#4ADE80;--gcb:#16A34A;
  --b:rgba(217,119,6,.14);--bc:#FCD34D;--bcb:#D97706;
  --y:rgba(202,138,4,.14);--yc:#FDE68A;--ycb:#CA8A04;
  --r:rgba(220,38,38,.14);--rc:#FCA5A5;--rcb:#DC2626;
  --p:rgba(124,58,237,.14);--pc:#C4B5FD;--pcb:#7C3AED;
  --gr:rgba(120,113,108,.16);--grc:#A8A29E;
  --sh:0 1px 2px rgba(0,0,0,.35),0 1px 3px rgba(0,0,0,.25);
  --shm:0 4px 12px rgba(0,0,0,.45);--shl:0 16px 48px rgba(0,0,0,.55);
}

/* ══════════════════════════════════════════════════════════════
   PALETAS DE COLOR — 4 opciones profesionales
   ══════════════════════════════════════════════════════════════ */

/* ── PALETA 1: MINIMAL — Blanco & Negro suave ── */
:root[data-palette="mono"]{
  --acc:#374151;--acc-d:#1F2937;--acc-bg:rgba(55,65,81,.08);--acc-bg2:rgba(55,65,81,.04);
  --sb:#111827;--sb2:#1F2937;--sbt:rgba(255,255,255,.58);--sba:rgba(255,255,255,.06);
  --bg:#FAFAFA;--srf:#FFFFFF;--srf2:#F3F4F6;--brd:#E5E7EB;--brd2:#F3F4F6;
  --tx:#111827;--tx2:#4B5563;--tx3:#9CA3AF;
  --g:rgba(16,185,129,.1);--gc:#065F46;--gcb:#059669;
  --b:rgba(55,65,81,.1);--bc:#374151;--bcb:#374151;
  --y:rgba(234,179,8,.1);--yc:#78350F;--ycb:#D97706;
  --r:rgba(239,68,68,.1);--rc:#991B1B;--rcb:#DC2626;
  --p:rgba(139,92,246,.1);--pc:#4C1D95;--pcb:#7C3AED;
  --gr:rgba(156,163,175,.12);--grc:#6B7280;
  --sh:0 1px 2px rgba(0,0,0,.04),0 1px 3px rgba(0,0,0,.03);
  --shm:0 4px 12px rgba(0,0,0,.07);--shl:0 16px 48px rgba(0,0,0,.10);
}
html.dark[data-palette="mono"]{
  --acc:#9CA3AF;--acc-d:#6B7280;--acc-bg:rgba(156,163,175,.12);--acc-bg2:rgba(156,163,175,.06);
  --sb:#0A0A0A;--sb2:#171717;--sbt:rgba(255,255,255,.55);--sba:rgba(255,255,255,.06);
  --bg:#171717;--srf:#262626;--srf2:#171717;--brd:#404040;--brd2:#262626;
  --tx:#F5F5F5;--tx2:#A3A3A3;--tx3:#525252;
  --g:rgba(16,185,129,.14);--gc:#4ADE80;--gcb:#22C55E;
  --b:rgba(156,163,175,.14);--bc:#D4D4D4;--bcb:#9CA3AF;
  --sh:0 1px 2px rgba(0,0,0,.4),0 1px 3px rgba(0,0,0,.3);
  --shm:0 4px 12px rgba(0,0,0,.5);--shl:0 16px 48px rgba(0,0,0,.6);
}

/* ── PALETA 2: BLUE — Azul jurídico profesional ── */
:root[data-palette="blue"]{
  --acc:#2563EB;--acc-d:#1D4ED8;--acc-bg:rgba(37,99,235,.09);--acc-bg2:rgba(37,99,235,.04);
  --sb:#0F172A;--sb2:#1E293B;--sbt:rgba(255,255,255,.60);--sba:rgba(255,255,255,.06);
  --bg:#F8FAFF;--srf:#FFFFFF;--srf2:#EEF2FF;--brd:#DBEAFE;--brd2:#E0E7FF;
  --tx:#0F172A;--tx2:#334155;--tx3:#94A3B8;
  --g:rgba(16,185,129,.1);--gc:#065F46;--gcb:#059669;
  --b:rgba(37,99,235,.1);--bc:#1D4ED8;--bcb:#2563EB;
  --y:rgba(245,158,11,.1);--yc:#78350F;--ycb:#D97706;
  --r:rgba(239,68,68,.1);--rc:#991B1B;--rcb:#DC2626;
  --p:rgba(139,92,246,.1);--pc:#4C1D95;--pcb:#7C3AED;
  --gr:rgba(148,163,184,.12);--grc:#64748B;
  --sh:0 1px 2px rgba(15,23,42,.04),0 1px 3px rgba(15,23,42,.03);
  --shm:0 4px 12px rgba(15,23,42,.08);--shl:0 16px 48px rgba(15,23,42,.12);
}
html.dark[data-palette="blue"]{
  --acc:#60A5FA;--acc-d:#3B82F6;--acc-bg:rgba(96,165,250,.12);--acc-bg2:rgba(96,165,250,.06);
  --sb:#020617;--sb2:#0F172A;--sbt:rgba(255,255,255,.55);--sba:rgba(255,255,255,.06);
  --bg:#0F172A;--srf:#1E293B;--srf2:#0F172A;--brd:#334155;--brd2:#1E293B;
  --tx:#F1F5F9;--tx2:#94A3B8;--tx3:#475569;
  --g:rgba(16,185,129,.14);--gc:#4ADE80;--gcb:#22C55E;
  --b:rgba(96,165,250,.14);--bc:#BFDBFE;--bcb:#60A5FA;
  --sh:0 1px 2px rgba(0,0,0,.4),0 1px 3px rgba(0,0,0,.3);
  --shm:0 4px 12px rgba(0,0,0,.5);--shl:0 16px 48px rgba(0,0,0,.6);
}

/* ── PALETA 3: AMBER — (por defecto, hereda :root y html.dark) ── */
/* No requiere definición adicional */

/* ── PALETA 4: GREEN — Verde judicial sofisticado ── */
:root[data-palette="green"]{
  --acc:#16A34A;--acc-d:#15803D;--acc-bg:rgba(22,163,74,.09);--acc-bg2:rgba(22,163,74,.04);
  --sb:#14532D;--sb2:#166534;--sbt:rgba(255,255,255,.60);--sba:rgba(255,255,255,.07);
  --bg:#F6FEF9;--srf:#FFFFFF;--srf2:#DCFCE7;--brd:#BBF7D0;--brd2:#D1FAE5;
  --tx:#1A2E1F;--tx2:#374737;--tx3:#6B9070;
  --g:rgba(22,163,74,.12);--gc:#14532D;--gcb:#16A34A;
  --b:rgba(22,163,74,.1);--bc:#166534;--bcb:#15803D;
  --y:rgba(202,138,4,.1);--yc:#78350F;--ycb:#CA8A04;
  --r:rgba(220,38,38,.1);--rc:#991B1B;--rcb:#DC2626;
  --p:rgba(124,58,237,.1);--pc:#4C1D95;--pcb:#7C3AED;
  --gr:rgba(107,144,112,.12);--grc:#6B9070;
  --sh:0 1px 2px rgba(20,83,45,.04),0 1px 3px rgba(20,83,45,.03);
  --shm:0 4px 12px rgba(20,83,45,.08);--shl:0 16px 48px rgba(20,83,45,.12);
}
html.dark[data-palette="green"]{
  --acc:#4ADE80;--acc-d:#22C55E;--acc-bg:rgba(74,222,128,.12);--acc-bg2:rgba(74,222,128,.06);
  --sb:#052E16;--sb2:#14532D;--sbt:rgba(255,255,255,.55);--sba:rgba(255,255,255,.07);
  --bg:#052E16;--srf:#14532D;--srf2:#052E16;--brd:#166534;--brd2:#14532D;
  --tx:#F0FDF4;--tx2:#86EFAC;--tx3:#4ADE80;
  --g:rgba(74,222,128,.14);--gc:#BBF7D0;--gcb:#4ADE80;
  --b:rgba(74,222,128,.12);--bc:#D1FAE5;--bcb:#4ADE80;
  --sh:0 1px 2px rgba(0,0,0,.4),0 1px 3px rgba(0,0,0,.3);
  --shm:0 4px 12px rgba(0,0,0,.5);--shl:0 16px 48px rgba(0,0,0,.6);
}

/* ── PALETA 1: NOTION — Blanco Notion ── */
:root[data-palette="notion"]{
  --bg:#ffffff;--srf:#ffffff;--srf2:#f7f7f5;--brd:#e8e8e6;--brd2:#f0f0ee;
  --sb:#191919;--sb2:#2e2e2e;--sbt:rgba(255,255,255,.65);--sba:rgba(255,255,255,.07);
  --tx:#1a1a1a;--tx2:#5a5a5a;--tx3:#999999;
  --acc:#4a3d9a;--acc-d:#3a2d80;--acc-bg:rgba(74,61,154,.08);--acc-bg2:rgba(74,61,154,.04);
  --g:rgba(26,102,64,.08);--gc:#1a4d30;--gcb:#2d7a50;
  --b:rgba(74,61,154,.08);--bc:#3a2d80;--bcb:#4a3d9a;
  --y:rgba(122,79,0,.08);--yc:#6a4200;--ycb:#c8860a;
  --r:rgba(140,61,16,.08);--rc:#7a3010;--rcb:#c85020;
  --p:rgba(74,61,154,.08);--pc:#3a2d80;--pcb:#6a5dba;
  --gr:rgba(90,90,90,.10);--grc:#666666;
  --sh:0 1px 2px rgba(0,0,0,.04);--shm:0 4px 12px rgba(0,0,0,.06);--shl:0 16px 48px rgba(0,0,0,.10);
}
html.dark[data-palette="notion"]{
  --bg:#111111;--srf:#1a1a1a;--srf2:#111111;--brd:#2e2e2e;--brd2:#1e1e1e;
  --sb:#0a0a0a;--sb2:#161616;--sbt:rgba(255,255,255,.55);--sba:rgba(255,255,255,.06);
  --tx:#e8e8e8;--tx2:#999999;--tx3:#555555;
  --acc:#7a6dda;--acc-d:#6a5dca;--acc-bg:rgba(122,109,218,.12);--acc-bg2:rgba(122,109,218,.06);
  --g:rgba(45,122,80,.14);--gc:#5dba8a;--gcb:#3a8a60;
  --b:rgba(122,109,218,.12);--bc:#a090e8;--bcb:#7a6dda;
  --y:rgba(200,134,10,.12);--yc:#f0b840;--ycb:#c8860a;
  --r:rgba(200,80,32,.12);--rc:#f08050;--rcb:#c85020;
  --p:rgba(122,109,218,.12);--pc:#b0a8f0;--pcb:#8a7de8;
  --gr:rgba(120,120,120,.14);--grc:#aaaaaa;
  --sh:0 1px 2px rgba(0,0,0,.30);--shm:0 4px 12px rgba(0,0,0,.40);--shl:0 16px 48px rgba(0,0,0,.50);
}

/* ── PALETA 2: PIEDRA — Piedra cálida ── */
:root[data-palette="piedra"]{
  --bg:#faf8f4;--srf:#faf8f4;--srf2:#f2ede6;--brd:#e0d8cc;--brd2:#ebe4da;
  --sb:#2a2520;--sb2:#3a3028;--sbt:rgba(255,255,255,.60);--sba:rgba(255,255,255,.06);
  --tx:#2a1e14;--tx2:#6a5a4a;--tx3:#a89880;
  --acc:#6b4226;--acc-d:#552f18;--acc-bg:rgba(107,66,38,.08);--acc-bg2:rgba(107,66,38,.04);
  --g:rgba(42,80,52,.08);--gc:#1e4028;--gcb:#2e6040;
  --b:rgba(107,66,38,.08);--bc:#552f18;--bcb:#6b4226;
  --y:rgba(106,74,0,.08);--yc:#5a3e00;--ycb:#b07a10;
  --r:rgba(122,56,32,.08);--rc:#6a2010;--rcb:#b04020;
  --p:rgba(74,48,112,.08);--pc:#3a2060;--pcb:#6040a0;
  --gr:rgba(90,80,70,.10);--grc:#786860;
  --sh:0 1px 2px rgba(0,0,0,.04);--shm:0 4px 12px rgba(0,0,0,.07);--shl:0 16px 48px rgba(0,0,0,.12);
}
html.dark[data-palette="piedra"]{
  --bg:#1e1810;--srf:#2a2218;--srf2:#1e1810;--brd:#3a3028;--brd2:#2a2218;
  --sb:#120e08;--sb2:#1e1810;--sbt:rgba(255,255,255,.55);--sba:rgba(255,255,255,.06);
  --tx:#f0e8d8;--tx2:#b09880;--tx3:#6a5840;
  --acc:#c08050;--acc-d:#a86838;--acc-bg:rgba(192,128,80,.12);--acc-bg2:rgba(192,128,80,.06);
  --g:rgba(46,96,64,.14);--gc:#70b888;--gcb:#3a7850;
  --b:rgba(192,128,80,.12);--bc:#e0b088;--bcb:#c08050;
  --y:rgba(176,122,16,.12);--yc:#f0c840;--ycb:#b07a10;
  --r:rgba(176,64,32,.12);--rc:#f09060;--rcb:#b04020;
  --p:rgba(96,64,160,.12);--pc:#c0a8e8;--pcb:#9070c8;
  --gr:rgba(120,104,88,.14);--grc:#c0a888;
  --sh:0 1px 2px rgba(0,0,0,.35);--shm:0 4px 12px rgba(0,0,0,.45);--shl:0 16px 48px rgba(0,0,0,.55);
}

/* ── PALETA 3: NIEBLA — Gris niebla ── */
:root[data-palette="niebla"]{
  --bg:#f4f5f7;--srf:#ffffff;--srf2:#eceef2;--brd:#dde0e8;--brd2:#e8eaee;
  --sb:#1e2128;--sb2:#2c3040;--sbt:rgba(255,255,255,.60);--sba:rgba(255,255,255,.06);
  --tx:#1a1e28;--tx2:#505870;--tx3:#8890a0;
  --acc:#3040a0;--acc-d:#203080;--acc-bg:rgba(48,64,160,.08);--acc-bg2:rgba(48,64,160,.04);
  --g:rgba(30,77,48,.08);--gc:#1a3828;--gcb:#286848;
  --b:rgba(48,64,160,.08);--bc:#203080;--bcb:#3040a0;
  --y:rgba(90,72,0,.08);--yc:#4a3800;--ycb:#a08010;
  --r:rgba(106,32,48,.08);--rc:#581828;--rcb:#a03040;
  --p:rgba(80,50,120,.08);--pc:#402860;--pcb:#706098;
  --gr:rgba(80,88,110,.10);--grc:#606880;
  --sh:0 1px 2px rgba(0,0,0,.04);--shm:0 4px 12px rgba(0,0,0,.06);--shl:0 16px 48px rgba(0,0,0,.10);
}
html.dark[data-palette="niebla"]{
  --bg:#181b22;--srf:#1e2230;--srf2:#181b22;--brd:#2c3248;--brd2:#1e2230;
  --sb:#0e1018;--sb2:#161a28;--sbt:rgba(255,255,255,.55);--sba:rgba(255,255,255,.06);
  --tx:#dde0ea;--tx2:#8890a8;--tx3:#485060;
  --acc:#6070d0;--acc-d:#5060c0;--acc-bg:rgba(96,112,208,.12);--acc-bg2:rgba(96,112,208,.06);
  --g:rgba(40,104,72,.14);--gc:#60b080;--gcb:#308858;
  --b:rgba(96,112,208,.12);--bc:#a0b0e8;--bcb:#6070d0;
  --y:rgba(160,128,16,.12);--yc:#e8c840;--ycb:#a08010;
  --r:rgba(160,48,64,.12);--rc:#e87888;--rcb:#a03040;
  --p:rgba(112,96,152,.12);--pc:#c0b0e0;--pcb:#9080c0;
  --gr:rgba(96,104,128,.14);--grc:#a8b0c0;
  --sh:0 1px 2px rgba(0,0,0,.35);--shm:0 4px 12px rgba(0,0,0,.45);--shl:0 16px 48px rgba(0,0,0,.55);
}

*{margin:0;padding:0;box-sizing:border-box}
html,body{height:100%;font-family:var(--font);background:var(--bg);color:var(--tx);font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-thumb{background:var(--brd);border-radius:3px}
.hidden{display:none!important}
button,input,select,textarea{font-family:var(--font)}

/* ── AUTH SCREEN ─────────────────────────────── */
#screen-auth{display:flex;height:100vh;width:100vw;overflow:hidden}
.auth-left{flex:0 0 44%;background:var(--sb);display:flex;flex-direction:column;justify-content:center;align-items:flex-start;padding:56px 52px;position:relative;overflow:hidden}
.auth-left::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 80% 80% at 100% 0%,rgba(180,83,9,.18),transparent),radial-gradient(ellipse 60% 60% at 0% 100%,rgba(120,53,15,.12),transparent)}
.auth-logo{position:relative;z-index:1;margin-bottom:40px}
.auth-logo .name{font-size:2.8rem;font-weight:700;color:#fff;letter-spacing:-.01em;line-height:1}
.auth-logo .name span{color:var(--acc)}
.auth-logo .sub{font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.3);margin-top:6px}
.auth-tagline{position:relative;z-index:1;font-size:1.05rem;color:rgba(255,255,255,.55);line-height:1.75;max-width:300px;font-style:italic}
.auth-tagline em{color:var(--acc);font-style:normal}
.auth-deco{position:absolute;bottom:30px;left:52px;right:52px;border-top:1px solid rgba(255,255,255,.07);padding-top:20px;font-size:.72rem;color:rgba(255,255,255,.2);letter-spacing:.04em;z-index:1}

/* CEO block en login */
.auth-ceo{
  display:flex;align-items:center;gap:12px;
  margin-top:32px;padding:14px 16px;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.08);
  border-radius:12px;
  position:relative;z-index:1;
  max-width:300px;
}
.auth-ceo-av{
  width:40px;height:40px;border-radius:50%;flex-shrink:0;
  background:var(--acc-bg);border:2px solid var(--acc);
  display:flex;align-items:center;justify-content:center;
  font-size:.82rem;font-weight:700;color:var(--acc);
  letter-spacing:.02em;
}
.auth-ceo-info{flex:1;min-width:0}
.auth-ceo-name{
  font-size:.9rem;font-weight:700;color:#fff;
  letter-spacing:.01em;
}
.auth-ceo-role{
  font-size:.72rem;color:rgba(255,255,255,.45);
  margin-top:2px;line-height:1.4;
}
.auth-ceo-link{
  color:var(--acc);text-decoration:none;font-weight:600;
  transition:opacity .15s ease;
}
.auth-ceo-link:hover{opacity:.8}
.auth-right{flex:1;display:flex;align-items:center;justify-content:center;padding:40px}
.auth-card{width:100%;max-width:420px}
.auth-tabs{display:flex;gap:0;background:var(--srf2);border:1px solid var(--brd);border-radius:var(--rad);padding:3px;margin-bottom:22px}
.auth-tab{flex:1;padding:8px;text-align:center;border-radius:7px;cursor:pointer;font-size:.87rem;color:var(--tx2);border:none;background:transparent;transition:all var(--tr)}
.auth-tab.active{background:var(--srf);color:var(--tx);font-weight:600;box-shadow:var(--sh)}
.auth-title{font-size:1.45rem;font-weight:600;color:var(--tx);margin-bottom:5px}
.auth-title small{display:block;font-family:var(--font);font-size:.83rem;font-weight:400;color:var(--tx3);margin-top:2px}
.form-group{margin-bottom:14px}
.form-group label{display:block;font-size:.8rem;font-weight:600;color:var(--tx2);margin-bottom:5px;letter-spacing:.02em}
.form-inp{width:100%;border:1.5px solid var(--brd);border-radius:var(--rads);padding:9px 12px;font-size:.93rem;color:var(--tx);background:var(--srf);outline:none;transition:border-color var(--tr)}
.form-inp:focus{border-color:var(--acc)}
.form-inp::placeholder{color:var(--tx3)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-hint{font-size:.75rem;color:var(--tx3);margin-top:4px}
.form-err{font-size:.78rem;color:var(--rcb);margin-top:5px;display:none}
.form-err.show{display:block}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8.5px 16px;border-radius:var(--rads);font-size:.89rem;font-weight:600;cursor:pointer;border:none;transition:all var(--tr);white-space:nowrap;text-decoration:none;line-height:1.4}
.btn svg{width:14px;height:14px;stroke-width:2;flex-shrink:0}
.btn-primary{background:var(--acc);color:#fff}.btn-primary:hover{background:var(--acc-d)}
.btn-full{width:100%;padding:11px 16px;font-size:.96rem}
.btn-secondary{background:transparent;color:var(--tx2);border:1px solid var(--brd)}.btn-secondary:hover{background:var(--srf2);color:var(--tx)}
.btn-ghost{background:transparent;color:var(--tx2);padding:6px 9px}.btn-ghost:hover{background:var(--srf2);color:var(--tx)}
.btn-danger{background:var(--r);color:var(--rc);border:1px solid rgba(239,68,68,.2)}.btn-danger:hover{background:rgba(239,68,68,.2)}
.btn-sm{padding:5px 11px;font-size:.8rem}.btn-sm svg{width:12px;height:12px}
.btn-icon{padding:6px;border-radius:var(--rads)}.btn-icon svg{width:15px;height:15px;stroke-width:1.8}
.divider{display:flex;align-items:center;gap:10px;margin:16px 0;font-size:.78rem;color:var(--tx3)}
.divider::before,.divider::after{content:'';flex:1;height:1px;background:var(--brd)}

/* ── INVITE SCREEN ───────────────────────────── */
#screen-invite{display:flex;height:100vh;width:100vw;align-items:center;justify-content:center;background:var(--bg)}
.invite-card{background:var(--srf);border:1px solid var(--brd);border-radius:16px;padding:44px 40px;max-width:460px;width:100%;text-align:center;box-shadow:var(--shl)}
.invite-icon{width:64px;height:64px;background:var(--acc-bg);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 20px;font-size:1.8rem}
.invite-card h2{font-size:1.5rem;font-weight:600;margin-bottom:6px}
.invite-card p{color:var(--tx2);font-size:.93rem;margin-bottom:24px;line-height:1.6}
.invite-firm{color:var(--acc);font-style:italic;font-size:1.1rem}

/* ── ONBOARDING ──────────────────────────────── */
#screen-onboarding{display:flex;height:100vh;width:100vw;align-items:center;justify-content:center;background:var(--bg)}
.onboard-card{background:var(--srf);border:1px solid var(--brd);border-radius:16px;padding:44px 40px;max-width:520px;width:100%;box-shadow:var(--shl)}
.onboard-logo{text-align:center;margin-bottom:28px}
.onboard-logo .name{font-size:1.8rem;font-weight:700;color:var(--tx)}
.onboard-logo .name span{color:var(--acc)}
.onboard-logo small{font-size:.75rem;letter-spacing:.14em;text-transform:uppercase;color:var(--tx3)}
.onboard-opts{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:22px 0}
.onboard-opt{border:2px solid var(--brd);border-radius:var(--rad);padding:22px 18px;text-align:center;cursor:pointer;transition:all var(--tr)}
.onboard-opt:hover,.onboard-opt.selected{border-color:var(--acc);background:var(--acc-bg2)}
.onboard-opt .ico{font-size:2rem;margin-bottom:8px}
.onboard-opt h3{font-size:.97rem;color:var(--tx)}
.onboard-opt p{font-size:.77rem;color:var(--tx3);margin-top:3px}

/* ── APP LAYOUT ──────────────────────────────── */
#screen-app{display:flex;height:100vh;width:100vw;overflow:hidden}
#sidebar{width:250px;background:var(--sb);display:flex;flex-direction:column;flex-shrink:0;height:100vh;overflow-y:auto;overflow-x:hidden;z-index:100}
.s-logo{padding:20px 18px 16px;border-bottom:1px solid rgba(255,255,255,.06)}
.s-logo .appname{font-size:1.2rem;font-weight:700;color:#fff;display:flex;align-items:center;gap:8px;letter-spacing:-.01em}
.s-logo .appname span{color:var(--acc)}
.s-logo .firmname{font-size:.72rem;color:rgba(255,255,255,.3);letter-spacing:.06em;text-transform:uppercase;margin-top:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.s-sec{padding:16px 18px 4px;font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.18);font-weight:700}
.nav-item{display:flex;align-items:center;gap:9px;padding:8.5px 12px;color:var(--sbt);cursor:pointer;transition:all var(--tr);font-size:.88rem;margin:1px 8px;border-radius:var(--rads);position:relative;border:none;background:transparent;width:calc(100% - 16px);text-align:left}
.nav-item:hover{background:var(--sba);color:#fff}
.nav-item.active{background:var(--acc-bg);color:var(--acc);font-weight:600}
.nav-item.active::before{content:'';position:absolute;left:-12px;top:50%;transform:translateY(-50%);width:3px;height:55%;background:var(--acc);border-radius:0 3px 3px 0}
.ni{width:15px;height:15px;stroke-width:1.8;flex-shrink:0}
.nbadge{margin-left:auto;background:var(--acc);color:#fff;font-size:.62rem;font-weight:700;padding:1px 6px;border-radius:10px;min-width:18px;text-align:center}
.s-space{flex:1}
.s-user{padding:12px 16px;border-top:1px solid rgba(255,255,255,.07);display:flex;align-items:center;gap:9px;cursor:pointer}
.s-user:hover .u-menu{display:block}
.u-av{width:32px;height:32px;border-radius:50%;background:var(--acc-bg);border:1.5px solid var(--acc);display:flex;align-items:center;justify-content:center;font-size:.82rem;color:var(--acc);flex-shrink:0;text-transform:uppercase}
.u-info{flex:1;min-width:0}
.u-name{font-size:.83rem;color:#fff;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.u-role{font-size:.67rem;color:rgba(255,255,255,.3)}
.u-act{position:relative}
.u-btn{background:none;border:none;color:rgba(255,255,255,.3);cursor:pointer;padding:4px}
.u-btn:hover{color:#fff}
.u-btn svg{width:13px;height:13px}
.u-menu{display:none;position:absolute;bottom:40px;right:0;background:var(--sb2);border:1px solid rgba(255,255,255,.1);border-radius:var(--rad);min-width:170px;box-shadow:var(--shl);overflow:hidden;z-index:200}
.u-menu-item{display:flex;align-items:center;gap:8px;padding:9px 14px;color:var(--sbt);cursor:pointer;font-size:.85rem;transition:background var(--tr);border:none;background:transparent;width:100%;text-align:left}
.u-menu-item:hover{background:rgba(255,255,255,.07);color:#fff}
.u-menu-item svg{width:13px;height:13px;stroke-width:1.8;flex-shrink:0}
.u-menu-sep{height:1px;background:rgba(255,255,255,.07);margin:4px 0}
.u-menu-item.danger{color:var(--rcb)}.u-menu-item.danger:hover{background:rgba(239,68,68,.1)}

/* ── MAIN ────────────────────────────────────── */
#main-content{flex:1;overflow-y:auto;display:flex;flex-direction:column;min-height:0}
.topbar{display:flex;align-items:center;padding:12px 24px;background:var(--srf);border-bottom:1px solid var(--brd);gap:12px;flex-shrink:0;position:sticky;top:0;z-index:50}
.topbar-info{flex:1}
.tb-title{font-size:1.05rem;font-weight:600;color:var(--tx)}
.breadcrumb{display:flex;align-items:center;gap:5px;font-size:.78rem;color:var(--tx3);margin-top:1px}
.breadcrumb .cr{color:var(--acc);cursor:pointer}.breadcrumb .cr:hover{text-decoration:underline}
.page{padding:22px 24px;flex:1}
.page-hdr{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:18px;gap:12px;flex-wrap:wrap}
.ph-l .title{font-size:1.25rem;font-weight:600}
.ph-l .sub{font-size:.8rem;color:var(--tx3);margin-top:2px}
.ph-r{display:flex;gap:8px;align-items:center;flex-wrap:wrap}

/* ── STATS ───────────────────────────────────── */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(165px,1fr));gap:13px;margin-bottom:20px}
.stat{background:var(--srf);border:1px solid var(--brd);border-radius:var(--rad);padding:15px 17px;display:flex;align-items:center;gap:11px;box-shadow:var(--sh);cursor:pointer;transition:all var(--tr)}
.stat:hover{box-shadow:var(--shm);transform:translateY(-1px)}
.stat-ico{width:40px;height:40px;border-radius:var(--rads);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.stat-ico svg{width:17px;height:17px;stroke-width:1.9}
.siv{font-size:1.6rem;font-weight:600;line-height:1;color:var(--tx)}
.sil{font-size:.76rem;color:var(--tx2);margin-top:2px}
.ico-g{background:var(--g);color:var(--gcb)}.ico-b{background:var(--b);color:var(--bcb)}.ico-y{background:var(--y);color:var(--ycb)}.ico-r{background:var(--r);color:var(--rcb)}.ico-p{background:var(--p);color:var(--pcb)}.ico-acc{background:var(--acc-bg);color:var(--acc)}

/* ── CARDS & TABLES ──────────────────────────── */
.card{background:var(--srf);border:1px solid var(--brd);border-radius:var(--rad);box-shadow:var(--sh);overflow:hidden}
.card-hdr{display:flex;align-items:center;justify-content:space-between;padding:13px 17px;border-bottom:1px solid var(--brd2)}
.card-title{font-size:.92rem;font-weight:600;display:flex;align-items:center;gap:7px;color:var(--tx)}
.card-title svg{width:14px;height:14px;color:var(--acc)}
.card-body{padding:14px 17px}
.card-a{font-size:.78rem;color:var(--acc);cursor:pointer;border:none;background:none;padding:0;font-family:inherit;transition:opacity var(--tr)}
.card-a:hover{opacity:.75}
.tbl{width:100%;border-collapse:collapse}
.tbl th{text-align:left;padding:8px 13px;font-size:.7rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--tx3);border-bottom:2px solid var(--brd);background:var(--srf2);white-space:nowrap}
.tbl td{padding:9.5px 13px;font-size:.88rem;border-bottom:1px solid var(--brd2);vertical-align:middle}
.tbl tr:last-child td{border-bottom:none}
.tbl tbody tr:hover td{background:var(--acc-bg2);cursor:pointer}
.tr-link td{cursor:pointer}
.ra{display:flex;gap:3px;opacity:0;transition:opacity var(--tr)}
tr:hover .ra{opacity:1}

/* ── BADGES ──────────────────────────────────── */
.badge{display:inline-flex;align-items:center;gap:3px;padding:2px 8px;border-radius:20px;font-size:.71rem;font-weight:700;white-space:nowrap;letter-spacing:.01em}
.dot{width:5px;height:5px;border-radius:50%;background:currentColor;display:inline-block;flex-shrink:0}
.b-activo{background:var(--g);color:var(--gc)}.b-archivado{background:var(--y);color:var(--yc)}.b-cerrado{background:var(--r);color:var(--rc)}
.b-pend{background:var(--y);color:var(--yc)}.b-prog{background:var(--b);color:var(--bc)}.b-real{background:var(--g);color:var(--gc)}.b-anul{background:var(--gr);color:var(--grc)}.b-parc{background:var(--acc-bg);color:var(--acc)}
.b-alta{background:var(--r);color:var(--rc)}.b-media{background:var(--y);color:var(--yc)}.b-baja{background:var(--g);color:var(--gc)}
.b-audiencia{background:var(--p);color:var(--pc)}.b-venc{background:var(--r);color:var(--rc)}.b-reunion{background:var(--b);color:var(--bc)}.b-present{background:var(--y);color:var(--yc)}.b-otro{background:var(--gr);color:var(--grc)}.b-licencia{background:var(--g);color:var(--gc)}.b-vencimiento{background:var(--r);color:var(--rc)}.b-presentacion{background:var(--y);color:var(--yc)}
.b-socio{background:var(--acc-bg);color:var(--acc)}.b-asociado{background:var(--b);color:var(--bc)}.b-colaborador{background:var(--gr);color:var(--grc)}

/* ── FILTERS ─────────────────────────────────── */
.filters{display:flex;align-items:center;gap:9px;margin-bottom:14px;flex-wrap:wrap}
.fsel,.finp{border:1.5px solid var(--brd);border-radius:var(--rads);padding:6px 11px;font-size:.87rem;color:var(--tx);background:var(--srf);outline:none;transition:border-color var(--tr);font-family:inherit}
.fsel:focus,.finp:focus{border-color:var(--acc)}
.sw{position:relative;display:inline-flex;align-items:center}
.sw svg{position:absolute;left:9px;width:13px;height:13px;color:var(--tx3);pointer-events:none;stroke-width:2}
.sinp{border:1.5px solid var(--brd);border-radius:var(--rads);padding:6px 11px 6px 30px;font-size:.87rem;color:var(--tx);background:var(--srf);outline:none;width:220px;font-family:inherit;transition:border-color var(--tr)}
.sinp:focus{border-color:var(--acc)}
.f-sp{flex:1}

/* ── KANBAN ──────────────────────────────────── */
.kanban{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;align-items:start}
.kcol{background:var(--srf2);border:1px solid var(--brd);border-radius:var(--rad);display:flex;flex-direction:column;min-height:120px}
.kcol-hdr{padding:11px 14px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--brd)}
.kcol-hdr h3{font-size:.78rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase}
.kcol-cnt{font-size:.7rem;color:var(--tx3);background:var(--brd2);padding:1px 7px;border-radius:10px;font-weight:600}
.kcol-body{padding:10px;display:flex;flex-direction:column;gap:8px;flex:1}
.kcard{background:var(--srf);border:1px solid var(--brd);border-radius:var(--rads);padding:12px 13px;cursor:pointer;transition:all var(--tr)}
.kcard:hover{box-shadow:var(--shm);transform:translateY(-1px)}
.kcard-title{font-size:.87rem;font-weight:600;color:var(--tx);line-height:1.4;margin-bottom:7px}
.kcard-meta{display:flex;flex-wrap:wrap;gap:5px;align-items:center}
.kcard-exp{font-size:.72rem;color:var(--tx3);font-style:italic;margin-top:4px;display:flex;align-items:center;gap:4px}
.kcard-exp svg{width:11px;height:11px;color:var(--acc)}
.kcard-due{font-size:.72rem;padding:2px 7px;border-radius:10px;font-weight:600;margin-top:4px;display:inline-flex;align-items:center;gap:3px}
.due-ok{background:var(--g);color:var(--gc)}.due-near{background:var(--y);color:var(--yc)}.due-over{background:var(--r);color:var(--rc)}
.kcard-asig{width:22px;height:22px;border-radius:50%;background:var(--acc-bg);border:1.5px solid var(--acc);display:flex;align-items:center;justify-content:center;font-size:.65rem;color:var(--acc);font-weight:700;text-transform:uppercase;cursor:help}

/* ── CALENDAR ────────────────────────────────── */
.cal-wrap{display:grid;grid-template-columns:1fr 300px;gap:18px;align-items:start}
.cal-nav{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.cal-nav h2{font-size:1.05rem;font-weight:600;flex:1;text-align:center;text-transform:capitalize}
.cal-grid{background:var(--srf);border:1px solid var(--brd);border-radius:var(--rad);overflow:hidden;box-shadow:var(--sh)}
.cal-day-lbl{padding:8px;text-align:center;font-size:.7rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--tx3);background:var(--srf2);border-bottom:2px solid var(--brd)}
.cal-cells{display:grid;grid-template-columns:repeat(7,minmax(0,1fr))}
.cal-cell{min-height:88px;border-right:1px solid var(--brd2);border-bottom:1px solid var(--brd2);padding:5px;cursor:pointer;transition:background var(--tr);position:relative}
.cal-cell:nth-child(7n){border-right:none}
.cal-cell:hover{background:var(--acc-bg2)}
.cal-cell.other-month .cn{color:var(--tx3);opacity:.5}
.cal-cell.today{background:var(--acc-bg2)}
.cal-cell.today .cn{background:var(--acc);color:#fff;border-radius:50%;width:22px;height:22px;display:flex;align-items:center;justify-content:center;font-weight:700}
.cal-cell.selected{background:var(--b);border:2px solid var(--bcb)}
.cn{font-size:.8rem;font-weight:500;color:var(--tx);margin-bottom:3px;width:22px;height:22px;display:flex;align-items:center;justify-content:center}
.cal-evt{font-size:.68rem;padding:2px 5px;border-radius:3px;margin-bottom:2px;cursor:pointer;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;font-weight:500;line-height:1.4}
.evt-audiencia{background:rgba(139,92,246,.15);color:#6D28D9}
.evt-vencimiento{background:rgba(220,38,38,.15);color:#B91C1C}
.evt-reunion{background:rgba(37,99,235,.17);color:#1D4ED8}
.evt-presentacion{background:rgba(217,119,6,.16);color:#92400E}
.evt-licencia{background:rgba(20,184,166,.17);color:#0F766E}
.evt-otro{background:rgba(120,113,108,.15);color:#57534E}
html.dark .evt-audiencia{background:rgba(139,92,246,.22);color:#C4B5FD}
html.dark .evt-vencimiento{background:rgba(220,38,38,.22);color:#FCA5A5}
html.dark .evt-reunion{background:rgba(37,99,235,.22);color:#93C5FD}
html.dark .evt-presentacion{background:rgba(217,119,6,.22);color:#FCD34D}
html.dark .evt-licencia{background:rgba(20,184,166,.22);color:#5EEAD4}
html.dark .evt-otro{background:rgba(120,113,108,.20);color:#A8A29E}
.evt-honorario-cobro{background:var(--y);color:var(--yc);font-weight:600}
.evt-honorario-pago{background:var(--r);color:var(--rc);font-weight:600}
html.dark .evt-honorario-cobro{background:rgba(202,138,4,.22);color:var(--yc)}
html.dark .evt-honorario-pago{background:rgba(220,38,38,.22);color:var(--rc)}
/* Notion */
[data-palette="notion"] .evt-audiencia{background:#e8e3ff;color:#4a3d9a}
[data-palette="notion"] .evt-vencimiento{background:#fef0c7;color:#7a4f00}
[data-palette="notion"] .evt-reunion{background:#dff0e8;color:#1a6640}
[data-palette="notion"] .evt-presentacion{background:#fde8d8;color:#8c3d10}
[data-palette="notion"] .evt-otro{background:#e8f0fe;color:#1a4480}
html.dark[data-palette="notion"] .evt-audiencia{background:#2e2860;color:#c0b8f8}
html.dark[data-palette="notion"] .evt-vencimiento{background:#3a2e08;color:#f0c840}
html.dark[data-palette="notion"] .evt-reunion{background:#1a3828;color:#80c8a0}
html.dark[data-palette="notion"] .evt-presentacion{background:#3a1e0e;color:#f0a070}
html.dark[data-palette="notion"] .evt-otro{background:#0e1e3a;color:#80a8f0}
/* Piedra */
[data-palette="piedra"] .evt-audiencia{background:#e0d4f0;color:#4a3070}
[data-palette="piedra"] .evt-vencimiento{background:#f0e8c8;color:#6a4a00}
[data-palette="piedra"] .evt-reunion{background:#d4e8d8;color:#2a5034}
[data-palette="piedra"] .evt-presentacion{background:#f0ddd4;color:#7a3820}
[data-palette="piedra"] .evt-otro{background:#d8e8f0;color:#1a4060}
html.dark[data-palette="piedra"] .evt-audiencia{background:#2a1e40;color:#c0a8f0}
html.dark[data-palette="piedra"] .evt-vencimiento{background:#302008;color:#f0c840}
html.dark[data-palette="piedra"] .evt-reunion{background:#182818;color:#88c8a0}
html.dark[data-palette="piedra"] .evt-presentacion{background:#381808;color:#f0a878}
html.dark[data-palette="piedra"] .evt-otro{background:#0e1e28;color:#80b8d8}
/* Niebla */
[data-palette="niebla"] .evt-audiencia{background:#dde0f5;color:#2e3580}
[data-palette="niebla"] .evt-vencimiento{background:#f0ecd8;color:#5a4800}
[data-palette="niebla"] .evt-reunion{background:#d8eee0;color:#1e4d30}
[data-palette="niebla"] .evt-presentacion{background:#f0dde0;color:#6a2030}
[data-palette="niebla"] .evt-otro{background:#dce8f0;color:#1a3850}
html.dark[data-palette="niebla"] .evt-audiencia{background:#1a1e40;color:#a8b0f0}
html.dark[data-palette="niebla"] .evt-vencimiento{background:#281e00;color:#e8c840}
html.dark[data-palette="niebla"] .evt-reunion{background:#101e18;color:#70b888}
html.dark[data-palette="niebla"] .evt-presentacion{background:#300810;color:#e87888}
html.dark[data-palette="niebla"] .evt-otro{background:#081420;color:#70a8c8}
.more-evts{font-size:.66rem;color:var(--acc);cursor:pointer;padding:0 3px;font-weight:600}
.more-evts:hover{text-decoration:underline}
.upcoming{display:flex;flex-direction:column;gap:10px}
.up-item{background:var(--srf);border:1px solid var(--brd);border-radius:var(--rad);padding:12px 14px;cursor:pointer;transition:all var(--tr)}
.up-item:hover{box-shadow:var(--shm)}
.up-date{font-size:.74rem;color:var(--tx3);margin-bottom:4px;display:flex;align-items:center;gap:5px}
.up-date svg{width:11px;height:11px;color:var(--acc)}
.up-title{font-size:.9rem;font-weight:600;color:var(--tx);margin-bottom:4px}
.up-exp{font-size:.77rem;color:var(--tx2);font-style:italic}

/* ── CALENDARIO MEJORADO: VISTAS / PANEL DÍA / TARJETA ─── */
.cal-view-tabs{display:flex;gap:2px;background:var(--srf2);border:1px solid var(--brd);border-radius:var(--rads);padding:3px;flex-shrink:0}
.cvt{padding:5px 14px;font-size:.78rem;font-weight:600;border:none;border-radius:5px;cursor:pointer;color:var(--tx2);background:transparent;transition:all var(--tr);font-family:inherit}
.cvt.active{background:var(--srf);color:var(--acc);box-shadow:var(--sh)}
.cal-nav-bar{display:flex;align-items:center;gap:8px;margin-bottom:14px;flex-wrap:wrap}
.cdf-inp{border:1.5px solid var(--brd);border-radius:var(--rads);padding:4px 8px;font-size:.76rem;font-family:inherit;color:var(--tx);background:var(--srf);outline:none;transition:border-color var(--tr)}
.cdf-inp:focus{border-color:var(--acc)}
/* Panel de día (drawer) */
.day-panel-bg{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:800;backdrop-filter:blur(2px)}
.day-panel{position:fixed;top:0;right:0;bottom:0;width:400px;max-width:96vw;background:var(--srf);border-left:1px solid var(--brd);z-index:801;display:flex;flex-direction:column;box-shadow:var(--shl);transform:translateX(105%);transition:transform .22s cubic-bezier(.4,0,.2,1)}
.day-panel.open{transform:translateX(0)}
.dp-hdr{padding:16px 18px;border-bottom:1px solid var(--brd);display:flex;align-items:center;gap:8px;flex-shrink:0;background:var(--srf2)}
.dp-date-lbl{flex:1}
.dp-dname{font-size:.98rem;font-weight:700;color:var(--tx);text-transform:capitalize}
.dp-dfull{font-size:.75rem;color:var(--tx3);margin-top:1px}
.dp-body{flex:1;overflow-y:auto;padding:14px}
.dp-empty{text-align:center;padding:36px 16px;color:var(--tx3);font-size:.87rem}
.dp-evt{background:var(--srf);border:1.5px solid var(--brd);border-radius:var(--rad);padding:11px 14px 11px 18px;margin-bottom:9px;cursor:pointer;transition:all var(--tr);position:relative;overflow:hidden}
.dp-evt::before{content:'';position:absolute;left:0;top:0;bottom:0;width:4px}
.dp-evt.type-audiencia::before{background:var(--pcb)}
.dp-evt.type-vencimiento::before{background:var(--rcb)}
.dp-evt.type-reunion::before{background:var(--bcb)}
.dp-evt.type-presentacion::before{background:var(--ycb)}
.dp-evt.type-otro::before{background:var(--grc)}
.dp-evt.type-licencia::before{background:var(--gcb)}
.dp-evt:hover{box-shadow:var(--shm);border-color:var(--acc)}
.dp-evt-time{font-size:.72rem;color:var(--tx3);margin-bottom:3px;display:flex;align-items:center;gap:5px}
.dp-evt-title{font-size:.9rem;font-weight:600;color:var(--tx);margin-bottom:4px}
.dp-evt-meta{font-size:.75rem;color:var(--tx2);margin-top:2px}
/* Tarjeta de trabajo (event card) */
.evc-typebar{height:4px;border-radius:var(--rad) var(--rad) 0 0}
.evc-typebar.type-audiencia{background:linear-gradient(90deg,var(--pcb),var(--p))}
.evc-typebar.type-vencimiento{background:linear-gradient(90deg,var(--rcb),var(--r))}
.evc-typebar.type-reunion{background:linear-gradient(90deg,var(--bcb),var(--b))}
.evc-typebar.type-presentacion{background:linear-gradient(90deg,var(--ycb),var(--y))}
.evc-typebar.type-otro{background:linear-gradient(90deg,var(--grc),var(--gr))}
.evc-fields{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:12px}
.evc-field{background:var(--srf2);border-radius:var(--rads);padding:9px 12px}
.evc-field.full{grid-column:1/-1}
.evc-lbl{font-size:.65rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--tx3);margin-bottom:3px}
.evc-val{font-size:.87rem;color:var(--tx);font-weight:500}
.evc-actions{display:flex;gap:8px;margin-top:14px;padding-top:12px;border-top:1px solid var(--brd2)}
/* Tarjeta de trabajo — Tarea */
.tkc-priobar{height:4px;border-radius:var(--rad) var(--rad) 0 0}
.tkc-priobar.prio-alta{background:linear-gradient(90deg,var(--rcb),var(--r))}
.tkc-priobar.prio-media{background:linear-gradient(90deg,var(--ycb),var(--y))}
.tkc-priobar.prio-baja{background:linear-gradient(90deg,var(--gcb),var(--g))}
.tkc-fields{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:12px}
.tkc-field{background:var(--srf2);border-radius:var(--rads);padding:9px 12px}
.tkc-field.full{grid-column:1/-1}
.tkc-lbl{font-size:.65rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--tx3);margin-bottom:3px}
.tkc-val{font-size:.87rem;color:var(--tx);font-weight:500}
.tkc-status-btns{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:14px}
.tkc-sbtn{padding:5px 12px;font-size:.78rem;font-weight:600;border-radius:var(--rads);border:1.5px solid var(--brd);background:transparent;cursor:pointer;color:var(--tx2);transition:all var(--tr);font-family:inherit}
.tkc-sbtn:hover{border-color:var(--acc);color:var(--acc)}
.tkc-sbtn.active{border-color:var(--acc);background:var(--acc);color:#fff}
.tkc-actions{display:flex;gap:8px;padding-top:12px;border-top:1px solid var(--brd2)}
/* ── TAREAS EN CALENDARIO ─── */
.cal-tarea{font-size:.68rem;padding:2px 5px;border-radius:3px;margin-bottom:2px;cursor:pointer;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;font-weight:500;line-height:1.4}
.cal-tarea.tarea-start{border-radius:3px 0 0 3px}
.cal-tarea.tarea-mid{border-radius:0;overflow:hidden;color:transparent!important;font-size:.4rem}
.cal-tarea.tarea-end{border-radius:0 3px 3px 0;overflow:hidden;color:transparent!important;font-size:.4rem}
.cal-tarea.prio-alta{background:rgba(220,38,38,.18);color:var(--rc)}
.cal-tarea.prio-media{background:rgba(202,138,4,.18);color:var(--yc)}
.cal-tarea.prio-baja{background:rgba(21,128,61,.18);color:var(--gc)}
html.dark .cal-tarea.prio-alta{background:rgba(220,38,38,.28)}
html.dark .cal-tarea.prio-media{background:rgba(202,138,4,.28)}
html.dark .cal-tarea.prio-baja{background:rgba(21,128,61,.28)}
/* Vista semana */
.cal-week-outer{overflow-x:auto}
.cal-week-grid{display:grid;grid-template-columns:repeat(7,minmax(100px,1fr));background:var(--srf);border:1px solid var(--brd);border-radius:var(--rad);overflow:hidden}
.cwg-hdr-day{background:var(--srf2);border-bottom:2px solid var(--brd);border-right:1px solid var(--brd2);padding:8px 6px;text-align:center;cursor:pointer;transition:background var(--tr)}
.cwg-hdr-day:hover{background:var(--acc-bg2)}
.cwg-hdr-day:last-child{border-right:none}
.cwg-day-name{font-size:.66rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--tx3)}
.cwg-day-num{font-size:1rem;font-weight:600;color:var(--tx);margin-top:2px;line-height:1}
.cwg-day-num.is-today{background:var(--acc);color:#fff;border-radius:50%;width:28px;height:28px;display:flex;align-items:center;justify-content:center;margin:2px auto 0}
.cwg-day-col{border-right:1px solid var(--brd2);padding:6px 4px;min-height:100px;cursor:pointer;transition:background var(--tr);vertical-align:top}
.cwg-day-col:hover{background:var(--acc-bg2)}
.cwg-day-col.today-col{background:var(--acc-bg2)}
.cwg-day-col:last-child{border-right:none}
/* Vista día (timeline) */
.cal-daytl-wrap{background:var(--srf);border:1px solid var(--brd);border-radius:var(--rad);overflow:hidden}
.cal-daytl-hdr{background:var(--srf2);border-bottom:2px solid var(--brd);padding:12px 16px;display:flex;align-items:center;gap:8px}
.cal-daytl-title{font-size:.95rem;font-weight:700;color:var(--tx);flex:1;text-transform:capitalize}
.cal-daytl-slot{display:grid;grid-template-columns:52px 1fr;border-bottom:1px solid var(--brd2)}
.cal-daytl-slot:last-child{border-bottom:none}
.cal-daytl-time{font-size:.68rem;color:var(--tx3);text-align:right;padding:8px 8px 0;font-weight:500}
.cal-daytl-content{padding:4px 8px;cursor:pointer;transition:background var(--tr);border-left:1px solid var(--brd2);min-height:44px;display:flex;flex-direction:column;justify-content:center}
.cal-daytl-content:hover{background:var(--acc-bg2)}
.cal-daytl-content.has-events{background:var(--acc-bg2)}
.cal-daytl-allday{background:var(--acc-bg2);border-bottom:2px solid var(--brd);padding:6px 12px 6px 60px;font-size:.76rem;color:var(--tx2)}

/* ── EXPEDIENTE DETAIL ───────────────────────── */
.exp-detail-grid{display:grid;grid-template-columns:1fr 340px;gap:18px;align-items:start}
.exp-detail-main{display:flex;flex-direction:column;gap:16px}
.exp-info-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.ei-item{display:flex;flex-direction:column;gap:2px}
.ei-label{font-size:.7rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--tx3)}
.ei-val{font-size:.9rem;color:var(--tx)}
.tabs-container{border-bottom:2px solid var(--brd);display:flex;gap:0;margin-bottom:16px}
.tab-btn{padding:9px 16px;font-size:.86rem;color:var(--tx2);cursor:pointer;border:none;background:transparent;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all var(--tr);font-family:inherit;font-weight:500}
.tab-btn.active{color:var(--acc);border-bottom-color:var(--acc);font-weight:600}
.tab-btn:hover:not(.active){color:var(--tx)}
.tab-panel{display:none}.tab-panel.active{display:block}
.activity-log{display:flex;flex-direction:column;gap:0}
.al-item{display:flex;gap:12px;padding:10px 0;border-bottom:1px solid var(--brd2);position:relative}
.al-item:last-child{border-bottom:none}
.al-dot{width:8px;height:8px;border-radius:50%;background:var(--acc);flex-shrink:0;margin-top:5px}
.al-content{flex:1}
.al-action{font-size:.87rem;color:var(--tx)}
.al-meta{font-size:.74rem;color:var(--tx3);margin-top:2px}
.note-form{margin-top:10px}
.note-form textarea{width:100%;border:1.5px solid var(--brd);border-radius:var(--rads);padding:9px 12px;font-size:.88rem;font-family:inherit;resize:vertical;min-height:80px;outline:none;color:var(--tx)}
.note-form textarea:focus{border-color:var(--acc)}

/* ── CLIENTES ────────────────────────────────── */
.client-card{display:flex;align-items:center;gap:12px;padding:13px 16px;border-bottom:1px solid var(--brd2);cursor:pointer;transition:background var(--tr)}
.client-card:hover{background:var(--acc-bg2)}
.cc-av{width:38px;height:38px;border-radius:50%;background:var(--acc-bg);border:1.5px solid var(--acc);display:flex;align-items:center;justify-content:center;font-size:.88rem;color:var(--acc);font-weight:600;flex-shrink:0;text-transform:uppercase}
.cc-info{flex:1}
.cc-name{font-size:.92rem;font-weight:600;color:var(--tx)}
.cc-sub{font-size:.77rem;color:var(--tx3)}

/* ── DOCS ────────────────────────────────────── */
.doc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(185px,1fr));gap:13px;padding:14px 17px}
.doc-item{border:1.5px solid var(--brd);border-radius:var(--rad);padding:14px 13px;cursor:pointer;transition:all var(--tr);display:flex;flex-direction:column;align-items:center;text-align:center;gap:8px;background:var(--srf)}
.doc-item:hover{border-color:var(--acc);box-shadow:var(--shm)}
.doc-ico{width:44px;height:54px;background:var(--r);border-radius:4px;display:flex;align-items:center;justify-content:center;color:var(--rc);font-size:.62rem;font-weight:700;letter-spacing:.04em;position:relative}
.doc-ico::after{content:'';position:absolute;top:0;right:0;width:12px;height:12px;background:rgba(239,68,68,.3);border-bottom-left-radius:4px}
.doc-name{font-size:.82rem;font-weight:600;color:var(--tx);word-break:break-word;line-height:1.4}
.doc-meta{font-size:.72rem;color:var(--tx3)}
.upload-area{border:2px dashed var(--brd);border-radius:var(--rad);padding:30px;text-align:center;cursor:pointer;transition:all var(--tr);margin:14px 17px}
.upload-area:hover,.upload-area.drag{border-color:var(--acc);background:var(--acc-bg2)}
.upload-area svg{width:32px;height:32px;color:var(--tx3);margin-bottom:8px;stroke-width:1.5}
.upload-area p{font-size:.87rem;color:var(--tx2)}.upload-area small{font-size:.75rem;color:var(--tx3)}

/* ── CONFIG ──────────────────────────────────── */
.config-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.member-row{display:flex;align-items:center;gap:11px;padding:10px 0;border-bottom:1px solid var(--brd2)}
.member-row:last-child{border-bottom:none}
.m-av{width:34px;height:34px;border-radius:50%;background:var(--acc-bg);border:1.5px solid var(--acc);display:flex;align-items:center;justify-content:center;font-size:.78rem;color:var(--acc);font-weight:700;flex-shrink:0;text-transform:uppercase}
.m-info{flex:1}
.m-name{font-size:.88rem;font-weight:600;color:var(--tx)}
.m-email{font-size:.74rem;color:var(--tx3)}
.invite-box{background:var(--srf2);border:1px solid var(--brd);border-radius:var(--rads);padding:12px 14px;display:flex;align-items:center;gap:10px;margin-top:12px}
.invite-url{font-size:.8rem;color:var(--tx2);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-family:monospace}

/* ── MODAL ───────────────────────────────────── */
#modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;backdrop-filter:blur(3px)}
.modal{background:var(--srf);border-radius:var(--rad);width:100%;max-height:90vh;overflow-y:auto;box-shadow:var(--shl)}
.modal-sm{max-width:420px}.modal-md{max-width:560px}.modal-lg{max-width:700px}
.modal-hdr{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--brd);position:sticky;top:0;background:var(--srf);z-index:1}
.modal-hdr h2{font-size:1.05rem;font-weight:600}
.modal-close{background:none;border:none;color:var(--tx3);cursor:pointer;padding:4px;border-radius:var(--rads)}
.modal-close:hover{background:var(--srf2);color:var(--tx)}
.modal-close svg{width:16px;height:16px}
.modal-body{padding:20px}
.modal-footer{padding:14px 20px;border-top:1px solid var(--brd);display:flex;justify-content:flex-end;gap:9px;position:sticky;bottom:0;background:var(--srf)}
.form-section{margin-bottom:20px}
.form-section h3{font-size:.78rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--tx3);margin-bottom:12px;padding-bottom:6px;border-bottom:1px solid var(--brd2)}

/* ── TOAST ───────────────────────────────────── */
#toast-container{position:fixed;bottom:22px;right:22px;z-index:2000;display:flex;flex-direction:column;gap:9px}
.toast{background:var(--sb);color:#fff;padding:11px 16px;border-radius:var(--rad);font-size:.87rem;box-shadow:var(--shl);display:flex;align-items:center;gap:9px;min-width:240px;max-width:360px;animation:slideIn .25s ease;border-left:3px solid var(--acc)}
.toast.success{border-left-color:var(--gcb)}.toast.error{border-left-color:var(--rcb)}.toast.warning{border-left-color:var(--ycb)}
.toast svg{width:14px;height:14px;flex-shrink:0}
@keyframes slideIn{from{transform:translateX(30px);opacity:0}to{transform:translateX(0);opacity:1}}
@keyframes fadeOut{to{opacity:0;transform:translateY(8px)}}

/* ── MISC ────────────────────────────────────── */
.empty-state{text-align:center;padding:40px 20px;color:var(--tx3)}
.empty-state svg{width:40px;height:40px;stroke-width:1.2;margin-bottom:12px;opacity:.4}
.empty-state p{font-size:.9rem;margin-bottom:12px}
.g2{display:grid;grid-template-columns:1fr 1fr;gap:17px}
.g3{display:grid;grid-template-columns:2fr 1fr;gap:17px}
.tag{display:inline-flex;align-items:center;gap:3px;padding:2px 8px;border-radius:20px;font-size:.71rem;font-weight:600}
.sep{height:1px;background:var(--brd2);margin:14px 0}
.text-muted{color:var(--tx3);font-size:.85rem}
.text-right{text-align:right}
.fw600{font-weight:600}
.mt8{margin-top:8px}.mt12{margin-top:12px}.mt16{margin-top:16px}
.flex-center{display:flex;align-items:center;gap:8px}
.spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
#alert-banner{position:fixed;top:0;left:0;right:0;background:var(--acc);color:#fff;text-align:center;padding:9px 16px;font-size:.88rem;font-weight:600;z-index:3000;display:flex;align-items:center;justify-content:center;gap:10px;box-shadow:0 2px 8px rgba(0,0,0,.2);transform:translateY(-100%);transition:transform .4s ease}
#alert-banner.show{transform:translateY(0)}

/* ── TABLET ──────────────────────────────────── */
@media(max-width:900px){
  #sidebar{width:56px;overflow:hidden}
  .s-logo .appname{display:none}.s-logo .firmname{display:none}
  .nav-item span{display:none}.nbadge{display:none}
  .s-sec{display:none}.u-info{display:none}
  .kanban{grid-template-columns:1fr 1fr}
  .exp-detail-grid{grid-template-columns:1fr}
  .cal-wrap{grid-template-columns:1fr}
  .config-grid{grid-template-columns:1fr}
  .exp-info-grid{grid-template-columns:1fr 1fr}
  .g2{grid-template-columns:1fr}.g3{grid-template-columns:1fr}
}

/* ── MOBILE ──────────────────────────────────── */
@media(max-width:640px){
  :root{--bnav-h:62px}

  /* Auth — stack vertical */
  #screen-auth{flex-direction:column;overflow-y:auto;height:auto;min-height:100dvh}
  .auth-left{flex:0 0 auto;padding:36px 24px 24px;align-items:center;text-align:center}
  .auth-logo .name{font-size:2.4rem}
  .auth-tagline{font-size:.95rem;max-width:100%;text-align:center}
  .auth-ceo{margin:20px auto 0;max-width:100%;text-align:left}
  .auth-deco{position:static;border-top:1px solid rgba(255,255,255,.07);padding-top:14px;margin-top:16px;left:auto;right:auto;text-align:center}
  .auth-right{padding:24px 18px 40px;flex:1}
  .auth-card{max-width:100%}

  /* Onboarding / invite */
  .onboard-card{border-radius:0;border:none;padding:24px 18px;min-height:100dvh;box-shadow:none}
  .onboard-opts{grid-template-columns:1fr 1fr;gap:10px}
  .onboard-opt{padding:14px 10px}
  .invite-card{border-radius:0;min-height:100dvh;display:flex;flex-direction:column;justify-content:center;padding:32px 24px;border:none;box-shadow:none}

  /* Sidebar hidden on mobile — use bottom nav */
  #sidebar{display:none!important}

  /* Main content bottom padding for nav */
  #main-content{padding-bottom:calc(var(--bnav-h) + env(safe-area-inset-bottom, 0px))}

  /* Bottom Nav Bar */
  #bottom-nav{
    display:flex!important;
    position:fixed;bottom:0;left:0;right:0;
    height:calc(var(--bnav-h) + env(safe-area-inset-bottom, 0px));
    background:var(--sb);
    border-top:1px solid rgba(255,255,255,.08);
    z-index:200;
    box-shadow:0 -4px 20px rgba(0,0,0,.25);
    padding-bottom:env(safe-area-inset-bottom, 0px);
  }
  .bnav-item{
    flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
    gap:3px;color:rgba(255,255,255,.38);cursor:pointer;
    border:none;background:transparent;padding:8px 2px 6px;
    transition:color .15s ease;position:relative;
    font-size:.58rem;letter-spacing:.03em;font-weight:600;text-transform:uppercase;
    -webkit-tap-highlight-color:transparent;font-family:inherit;
  }
  .bnav-item svg{width:21px;height:21px;stroke-width:1.7;transition:transform .15s ease}
  .bnav-item.active{color:var(--acc)}
  .bnav-item.active svg{transform:scale(1.08)}
  .bnav-item:active svg{transform:scale(.9)}
  .bnav-dot{position:absolute;top:8px;right:calc(50% - 14px);width:7px;height:7px;border-radius:50%;background:var(--rcb);display:none;border:1.5px solid var(--sb)}
  .bnav-dot.show{display:block}

  /* FAB */
  #fab{
    display:flex!important;
    position:fixed;bottom:calc(var(--bnav-h) + env(safe-area-inset-bottom,0px) + 12px);right:16px;
    width:52px;height:52px;border-radius:50%;
    background:var(--acc);color:#fff;border:none;cursor:pointer;
    align-items:center;justify-content:center;
    box-shadow:0 4px 18px rgba(197,154,46,.5);
    z-index:190;transition:all .15s ease;
    -webkit-tap-highlight-color:transparent;
  }
  #fab:active{transform:scale(.91)}
  #fab svg{width:22px;height:22px;stroke-width:2.2}

  /* Mobile profile bar (shown in dashboard) */
  .mobile-profile-bar{
    display:flex!important;align-items:center;gap:10px;
    background:var(--sb);padding:12px 14px;
    margin:-14px -14px 14px;
    border-bottom:1px solid rgba(255,255,255,.07);
  }
  .mpb-av{width:34px;height:34px;border-radius:50%;background:var(--acc-bg);border:1.5px solid var(--acc);display:flex;align-items:center;justify-content:center;font-size:.8rem;color:var(--acc);font-weight:700;flex-shrink:0;text-transform:uppercase}
  .mpb-info{flex:1;min-width:0}
  .mpb-name{font-size:.87rem;color:#fff;font-weight:600}
  .mpb-firm{font-size:.68rem;color:rgba(255,255,255,.32);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .mpb-btn{background:rgba(255,255,255,.08);border:none;color:rgba(255,255,255,.45);padding:8px;border-radius:var(--rads);cursor:pointer;-webkit-tap-highlight-color:transparent}
  .mpb-btn svg{width:15px;height:15px;display:block}

  /* Mobile quick actions (dashboard) */
  .mobile-quick-actions{
    display:grid!important;
    grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:14px;
  }
  .mqa-item{
    background:var(--srf);border:1px solid var(--brd);border-radius:var(--rad);
    padding:12px 6px;text-align:center;cursor:pointer;
    display:flex;flex-direction:column;align-items:center;gap:5px;
    -webkit-tap-highlight-color:transparent;transition:all .15s ease;
    box-shadow:var(--sh);
  }
  .mqa-item:active{transform:scale(.94);background:var(--acc-bg2)}
  .mqa-ico{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center}
  .mqa-ico svg{width:17px;height:17px;stroke-width:1.9}
  .mqa-lbl{font-size:.64rem;color:var(--tx2);font-weight:600;line-height:1.3}

  /* Topbar */
  .topbar{padding:10px 14px;gap:8px;position:sticky;top:0}
  .tb-title{font-size:.95rem}
  .breadcrumb{font-size:.73rem}
  #topbar-actions{display:flex;gap:6px}
  #topbar-actions .btn{border-radius:50%;padding:8px;min-width:38px;min-height:38px}
  #topbar-actions .btn svg{width:15px;height:15px}
  #topbar-actions .btn-text{display:none}

  /* Page */
  .page{padding:14px}

  /* Page header */
  .page-hdr{margin-bottom:12px;flex-direction:column;gap:8px}
  .ph-l .title{font-size:1.08rem}
  .ph-r{width:100%;display:flex;gap:8px}
  .ph-r .btn{flex:1;justify-content:center;min-height:40px}

  /* Stats */
  .stats{grid-template-columns:1fr 1fr;gap:9px;margin-bottom:12px}
  .stat{padding:11px 12px;gap:8px}
  .stat-ico{width:34px;height:34px;flex-shrink:0}
  .stat-ico svg{width:15px;height:15px}
  .siv{font-size:1.3rem}
  .sil{font-size:.68rem}

  /* Cards */
  .card-hdr{padding:10px 13px;gap:8px}
  .card-title{font-size:.86rem}
  .card-body{padding:11px 13px}

  /* Tables */
  .card{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .tbl{min-width:440px}
  .tbl th,.tbl td{padding:7px 10px;font-size:.8rem}

  /* Kanban — horizontal scroll */
  .kanban{
    display:flex;overflow-x:auto;gap:11px;
    padding-bottom:8px;scroll-snap-type:x mandatory;
    -webkit-overflow-scrolling:touch;margin:0 -14px;padding:0 14px 8px;
  }
  .kcol{min-width:255px;flex-shrink:0;scroll-snap-align:start}

  /* Filters */
  .filters{gap:7px;flex-wrap:wrap}
  .sinp{width:100%;min-width:0}
  .fsel{font-size:.82rem;flex:1}
  .f-sp{display:none}

  /* Forms */
  .form-row{grid-template-columns:1fr}
  .form-inp{padding:11px 12px;font-size:1rem}

  /* Modal — bottom sheet */
  #modal-overlay{padding:0;align-items:flex-end}
  .modal{max-width:100%!important;border-radius:18px 18px 0 0;max-height:94dvh;display:flex;flex-direction:column}
  .modal-hdr{padding:14px 16px;border-radius:18px 18px 0 0}
  .modal-body{padding:14px 16px;flex:1;overflow-y:auto}
  .modal-footer{padding:12px 16px;gap:8px}
  .modal-footer .btn{flex:1;justify-content:center;padding:12px;min-height:44px}

  /* Calendar */
  .cal-wrap{grid-template-columns:1fr;gap:12px}
  .cal-cell{min-height:52px;padding:3px}
  .cn{font-size:.7rem;width:18px;height:18px}
  .cal-evt{font-size:.58rem;padding:1px 3px;margin-bottom:1px}
  .cal-day-lbl{font-size:.6rem;padding:5px 1px}
  .cal-nav h2{font-size:.9rem}
  .cal-nav{margin-bottom:10px}

  /* Exp detail */
  .exp-detail-grid{grid-template-columns:1fr}
  .exp-info-grid{grid-template-columns:1fr 1fr;gap:10px}
  .tabs-container{overflow-x:auto;-webkit-overflow-scrolling:touch;white-space:nowrap;display:flex;gap:0}
  .tab-btn{flex-shrink:0;font-size:.79rem;padding:8px 13px}

  /* Doc grid */
  .doc-grid{grid-template-columns:repeat(2,1fr);gap:10px;padding:10px 13px}
  .upload-area{margin:10px 13px;padding:20px 14px}

  /* Toast */
  #toast-container{bottom:calc(var(--bnav-h) + env(safe-area-inset-bottom,0px) + 8px);right:10px;left:10px}
  .toast{min-width:unset;width:100%;max-width:100%}

  /* Alert banner */
  #alert-banner{font-size:.78rem;padding:10px 14px;top:env(safe-area-inset-top,0px)}

  /* Buttons */
  .btn{min-height:38px}
  .btn-sm{min-height:32px}

  /* Client card */
  .client-card{padding:10px 13px}

  /* Up-item */
  .up-item{padding:10px 12px}

  /* Member row */
  .member-row{flex-wrap:wrap;gap:8px}
}

/* ── BÚSQUEDA GLOBAL ─────────────────────────── */
.global-search-wrap{position:relative;flex:0 1 340px}
.gs-ico{position:absolute;left:10px;top:50%;transform:translateY(-50%);width:14px;height:14px;color:var(--tx3);pointer-events:none;stroke-width:2}
.gs-inp{width:100%;border:1.5px solid var(--brd);border-radius:20px;padding:7px 14px 7px 32px;font-size:.84rem;font-family:var(--font);background:var(--srf2);color:var(--tx);outline:none;transition:all var(--tr)}
.gs-inp:focus{border-color:var(--acc);background:var(--srf);box-shadow:0 0 0 3px var(--acc-bg)}
.gs-inp::placeholder{color:var(--tx3)}
.gs-results{position:absolute;top:calc(100% + 6px);left:0;right:0;background:var(--srf);border:1px solid var(--brd);border-radius:var(--rad);box-shadow:var(--shl);z-index:300;max-height:380px;overflow-y:auto}
.gs-group{padding:8px 12px 4px;font-size:.66rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--tx3);border-bottom:1px solid var(--brd2)}
.gs-item{display:flex;align-items:center;gap:10px;padding:9px 12px;cursor:pointer;transition:background var(--tr)}
.gs-item:hover,.gs-item.focused{background:var(--acc-bg2)}
.gs-item-ico{width:28px;height:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.gs-item-ico svg{width:13px;height:13px;stroke-width:2}
.gs-item-main{flex:1;min-width:0}
.gs-item-title{font-size:.84rem;font-weight:600;color:var(--tx);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.gs-item-sub{font-size:.72rem;color:var(--tx3)}
.gs-empty{padding:20px;text-align:center;color:var(--tx3);font-size:.84rem}
@media(max-width:640px){
  .global-search-wrap{flex:1;max-width:none;order:-1;width:100%}
  .topbar{flex-wrap:wrap;gap:8px}
}

/* ── BUSCADOR EXPEDIENTE EN TAREAS ──────────── */
#drop-exp-tarea .gs-item:hover{background:var(--acc-bg2);cursor:pointer}
#drop-exp-tarea{border-top:none}
.notif-bell{position:relative;background:none;border:none;color:var(--tx2);cursor:pointer;padding:6px;border-radius:var(--rads);transition:color var(--tr)}
.notif-bell:hover{color:var(--tx);background:var(--srf2)}
.notif-bell svg{width:18px;height:18px;stroke-width:1.8;display:block}
.notif-badge{position:absolute;top:2px;right:2px;width:8px;height:8px;border-radius:50%;background:var(--rcb);border:2px solid var(--srf);display:none}
.notif-badge.show{display:block}
.notif-panel{position:absolute;top:calc(100% + 8px);right:0;width:320px;background:var(--srf);border:1px solid var(--brd);border-radius:var(--rad);box-shadow:var(--shl);z-index:400;overflow:hidden}
.notif-hdr{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid var(--brd);font-size:.82rem;font-weight:700;color:var(--tx)}
.notif-item{display:flex;gap:10px;padding:10px 14px;border-bottom:1px solid var(--brd2);cursor:pointer;transition:background var(--tr)}
.notif-item:hover{background:var(--acc-bg2)}
.notif-item.unread{background:var(--acc-bg2)}
.notif-dot{width:8px;height:8px;border-radius:50%;background:var(--acc);flex-shrink:0;margin-top:5px}
.notif-dot.read{background:transparent;border:1.5px solid var(--tx3)}
.notif-text{font-size:.82rem;color:var(--tx);line-height:1.45}
.notif-time{font-size:.7rem;color:var(--tx3);margin-top:2px}
.notif-footer{padding:10px 14px;text-align:center;font-size:.78rem;color:var(--acc);cursor:pointer;border-top:1px solid var(--brd2)}
.notif-footer:hover{background:var(--srf2)}
.notif-wrap{position:relative}

/* ── REPORTES / PRINT ────────────────────────── */
.report-card{background:var(--srf);border:1px solid var(--brd);border-radius:var(--rad);padding:20px 22px;cursor:pointer;transition:all var(--tr);display:flex;gap:16px;align-items:flex-start}
.report-card:hover{box-shadow:var(--shm);transform:translateY(-1px);border-color:var(--acc)}
.report-ico{width:48px;height:48px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.report-ico svg{width:22px;height:22px;stroke-width:1.7}
.report-title{font-size:.95rem;font-weight:700;color:var(--tx);margin-bottom:4px}
.report-desc{font-size:.81rem;color:var(--tx2);line-height:1.55}
.report-actions{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap}

/* ── FEED ──────────────────────────────────────────── */
.feed-wrap{max-width:680px;margin:0 auto;padding:20px 0}
.feed-composer{background:var(--cd);border:1px solid var(--brd);border-radius:var(--rad);padding:14px 16px;margin-bottom:20px}
.feed-composer-header{display:flex;gap:10px;align-items:flex-start}
.feed-av-sm{width:32px;height:32px;border-radius:50%;background:var(--acc-bg);color:var(--acc);font-size:.72rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;text-transform:uppercase}
.feed-textarea{width:100%;background:var(--cb);border:1px solid var(--brd);border-radius:8px;padding:10px 12px;font-size:.88rem;color:var(--tx1);resize:none;font-family:inherit;line-height:1.5;min-height:72px;box-sizing:border-box}
.feed-textarea:focus{outline:none;border-color:var(--acc)}
.feed-composer-footer{display:flex;justify-content:space-between;align-items:center;margin-top:10px}
.feed-char-count{font-size:.72rem;color:var(--tx3)}
.reaction-bar{display:flex;gap:4px;flex-wrap:wrap;align-items:center;margin-top:8px;min-height:28px}
.reaction-chip{display:inline-flex;align-items:center;gap:3px;font-size:.85rem;padding:3px 9px;border-radius:20px;border:1.5px solid var(--brd);background:var(--srf2);cursor:pointer;transition:all .15s;line-height:1.2}
.reaction-chip:hover{border-color:var(--acc);background:var(--acc-bg)}
.reaction-chip.mine{border-color:var(--acc);background:var(--acc-bg);color:var(--acc)}
.reaction-chip span{font-size:.72rem;font-weight:700}
.reaction-add{font-size:.8rem;padding:3px 8px;border-radius:20px;border:1.5px dashed var(--brd2);background:none;cursor:pointer;color:var(--tx3);transition:all .15s;line-height:1.4}
.reaction-add:hover{border-color:var(--acc);color:var(--acc);background:var(--acc-bg)}
.reaction-picker-pop{position:absolute;bottom:calc(100% + 6px);left:0;background:var(--srf);border:1px solid var(--brd);border-radius:var(--rad);padding:6px 8px;display:flex;gap:2px;box-shadow:var(--shm);z-index:500;white-space:nowrap}
.reaction-picker-pop.hidden{display:none}
.rp-item{font-size:1.35rem;cursor:pointer;padding:4px 5px;border-radius:6px;transition:background .1s;line-height:1}
.rp-item:hover{background:var(--acc-bg2)}
.feed-emoji-btn{font-size:1.1rem;background:none;border:1px solid var(--brd);border-radius:8px;padding:4px 8px;cursor:pointer;transition:background .15s;line-height:1}
.feed-emoji-btn:hover{background:var(--acc-bg2)}
.feed-emoji-picker{position:absolute;bottom:calc(100% + 6px);left:0;background:var(--srf);border:1px solid var(--brd);border-radius:var(--rad);padding:8px;display:grid;grid-template-columns:repeat(9,1fr);gap:1px;box-shadow:var(--shm);z-index:400;width:270px}
.feed-emoji-picker.hidden{display:none}
.feed-emoji-item{font-size:1.25rem;text-align:center;padding:5px 2px;border-radius:4px;cursor:pointer;line-height:1;transition:background .1s}
.feed-emoji-item:hover{background:var(--acc-bg2)}
.feed-mention-dropdown{position:absolute;left:0;top:100%;background:var(--cd);border:1px solid var(--brd);border-radius:8px;box-shadow:0 4px 16px rgba(0,0,0,.25);z-index:1000;min-width:200px;overflow:hidden;margin-top:2px}
.feed-mention-item{padding:8px 12px;cursor:pointer;display:flex;align-items:center;gap:8px;font-size:.85rem;color:var(--tx1)}
.feed-mention-item:hover{background:var(--cb)}
.feed-item{background:var(--cd);border:1px solid var(--brd);border-radius:var(--rad);padding:14px 16px;margin-bottom:12px;transition:border-color .15s}
.feed-item:hover{border-color:var(--acc)}
.feed-item-header{display:flex;gap:10px;align-items:center;margin-bottom:8px}
.feed-item-meta{flex:1;min-width:0}
.feed-item-author{font-weight:600;font-size:.88rem;color:var(--tx1)}
.feed-item-time{font-size:.72rem;color:var(--tx3);margin-top:1px}
.feed-item-badge{font-size:.63rem;font-weight:700;padding:2px 7px;border-radius:10px;background:var(--cb);color:var(--tx3);white-space:nowrap;flex-shrink:0}
.feed-link-chip{display:inline-flex;align-items:center;gap:5px;font-size:.72rem;font-weight:600;color:var(--acc);background:var(--acc-bg);border:1px solid color-mix(in srgb,var(--acc) 25%,transparent);border-radius:20px;padding:3px 11px;cursor:pointer;margin-top:7px;transition:background .15s;text-decoration:none}
.feed-link-chip:hover{background:var(--acc-bg2)}
.feed-activity-icon{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0;background:var(--acc-bg)}
.feed-activity-body{font-size:.85rem;color:var(--tx2);line-height:1.5}
.feed-post-body{font-size:.9rem;color:var(--tx1);line-height:1.6;white-space:pre-wrap;word-break:break-word}
.feed-post-body .mention{color:var(--acc);font-weight:600}
.feed-actions{display:flex;gap:6px;margin-top:10px;padding-top:10px;border-top:1px solid var(--brd)}
.feed-action-btn{background:none;border:none;color:var(--tx3);font-size:.78rem;cursor:pointer;display:flex;align-items:center;gap:5px;padding:4px 8px;border-radius:6px;font-family:inherit;transition:all .12s}
.feed-action-btn:hover{color:var(--tx1);background:var(--cb)}
.feed-comments{margin-top:12px;padding-top:12px;border-top:1px solid var(--brd)}
.feed-comment{display:flex;gap:8px;margin-bottom:10px}
.feed-comment-body{flex:1;background:var(--cb);border-radius:8px;padding:8px 12px;min-width:0}
.feed-comment-author{font-size:.78rem;font-weight:600;color:var(--tx1);display:flex;align-items:center;gap:4px}
.feed-comment-text{font-size:.82rem;color:var(--tx2);margin-top:3px;line-height:1.5;white-space:pre-wrap;word-break:break-word}
.feed-comment-text .mention{color:var(--acc);font-weight:600}
.feed-comment-meta{font-size:.68rem;color:var(--tx3);margin-top:4px}
.feed-comment-input-row{display:flex;gap:8px;margin-top:10px;align-items:flex-start}
.feed-comment-inp{flex:1;background:var(--cb);border:1px solid var(--brd);border-radius:8px;padding:7px 10px;font-size:.82rem;color:var(--tx1);font-family:inherit;resize:none;min-height:36px}
.feed-comment-inp:focus{outline:none;border-color:var(--acc)}
.feed-empty{text-align:center;padding:60px 0;color:var(--tx3);display:flex;flex-direction:column;align-items:center;gap:8px}
.feed-empty svg{opacity:.25}
.feed-empty p{font-size:.9rem;margin:0}

@media print{
  #sidebar,#bottom-nav,#fab,#topbar-actions,.topbar,.global-search-wrap,
  #alert-banner,#toast-container,#modal-overlay,.btn,button,
  .no-print{display:none!important}
  #main-content{padding:0!important;overflow:visible!important}
  .page{padding:0!important}
  body,html{background:#fff!important;color:#000!important;font-size:12pt}
  .card{box-shadow:none!important;border:1px solid #ddd!important;break-inside:avoid}
  .print-header{display:flex!important}
  .tbl th,.tbl td{font-size:10pt;padding:6px 8px}
  .badge{border:1px solid currentColor}
  a{color:inherit;text-decoration:none}
  @page{margin:15mm 12mm;size:A4}
}
/* ── Touch targets & 300ms tap delay prevention ── */
button,[role="button"],a,.nav-item,.stat,.kcard,.client-card,.exp-row,
.notif-item,.feed-item,.btn,.tbl tr[onclick]{touch-action:manipulation}
.notif-item{padding:12px 14px}
.print-header{display:none;align-items:flex-start;justify-content:space-between;margin-bottom:20px;padding-bottom:14px;border-bottom:2px solid #1a1a2e}

/* ── ANIMACIONES ENTRADA ─────────────────────── */
@keyframes fadeInUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.page-anim{animation:fadeInUp .22s ease both}
.stat{animation:fadeInUp .18s ease both}
.stat:nth-child(1){animation-delay:.03s}.stat:nth-child(2){animation-delay:.06s}
.stat:nth-child(3){animation-delay:.09s}.stat:nth-child(4){animation-delay:.12s}
.stat:nth-child(5){animation-delay:.15s}

/* ── FIRMA ATENEA AL PIE DEL SIDEBAR ────────── */
.sb-atenea-footer{
  padding:12px 16px 16px;
  border-top:1px solid rgba(255,255,255,.07);
  flex-shrink:0;
}
.sb-atenea-line{
  font-size:.59rem;letter-spacing:.09em;text-transform:uppercase;
  color:rgba(255,255,255,.25);margin-bottom:8px;
}
.sb-atenea-logo-wrap{
  display:inline-flex;flex-direction:row;text-decoration:none;
  align-items:center;gap:8px;
}
.sb-atenea-logo-wrap img{
  height:30px;width:auto;object-fit:contain;
  opacity:.9;transition:opacity .2s ease;
  border-radius:4px;background:transparent;
  /* Sin filtro — logo en colores originales */
}
.sb-atenea-logo-wrap:hover img{opacity:1}
.sb-atenea-nombre{
  font-size:.8rem;font-weight:700;color:rgba(255,255,255,.6);
  letter-spacing:.05em;transition:color .2s ease;
  display:block; /* Siempre visible como texto de respaldo */
}
.sb-atenea-logo-wrap:hover .sb-atenea-nombre{color:rgba(255,255,255,.9)}
.sb-atenea-ceo{
  font-size:.62rem;color:rgba(255,255,255,.2);margin-top:6px;letter-spacing:.02em;
}
/* Ningún SVG suelto sin dimensiones puede desbordarse */
svg:not([width]):not([height]){max-width:100%;max-height:100%}
.btn svg,button svg{max-width:20px!important;max-height:20px!important}
/* Asegurar layout del app */
#screen-app{overflow:hidden}
#main-content{min-width:0;flex:1 1 0}

@media(min-width:641px){
  /* Ocultar elementos exclusivos de móvil en escritorio */
  #bottom-nav{display:none!important}
  #fab{display:none!important}
  .mobile-profile-bar{display:none!important}
  .mobile-quick-actions{display:none!important}
  /* Búsqueda global en escritorio */
  .global-search-wrap{flex:0 1 300px}
}
