:root{--navy: #1E3A5F;--navy-700: #2A4A75;--navy-600: #3A5C8A;--navy-500: #5A789F;--navy-100: #E7ECF3;--navy-50: #F2F5F9;--gold: #C8841A;--gold-700: #B5760F;--gold-600: #A66907;--gold-100: #F7E9CE;--gold-50: #FCF5E5;--bg-page: #FAFAF7;--bg-card: #FFFFFF;--bg-soft: #F5F4F0;--bg-muted: #EFEDE7;--border-soft: #E8E6E1;--border: #D4D2CC;--border-strong: #B8B5AD;--fg: #1A1D24;--fg-2: #4A4F5A;--fg-3: #767C88;--fg-4: #A4A8B0;--fg-on-navy: #FFFFFF;--fg-on-navy-2: #B9C4D4;--ok: #2F8F5E;--ok-bg: #E7F4ED;--warn: #C8841A;--warn-bg: #FCF5E5;--bad: #C13B3B;--bad-bg: #FBE9E9;--info: #2A6FDB;--info-bg: #E6EEFB;--na: #767C88;--na-bg: #EFEDE7;--font-sans: "Manrope", ui-sans-serif, system-ui, sans-serif;--font-display: "Clash Grotesk", "Manrope", ui-sans-serif, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;--t-12: .75rem;--t-13: .8125rem;--t-14: .875rem;--t-16: 1rem;--t-20: 1.25rem;--t-24: 1.5rem;--t-32: 2rem;--t-40: 2.5rem;--lh-tight: 1.15;--lh-snug: 1.3;--lh-base: 1.5;--lh-loose: 1.65;--w-regular: 400;--w-medium: 500;--w-semibold: 600;--w-bold: 700;--w-black: 800;--track-tight: -.01em;--track-base: 0;--track-uppercase: .04em;--s-1: 4px;--s-2: 8px;--s-3: 12px;--s-4: 16px;--s-5: 20px;--s-6: 24px;--s-8: 32px;--s-10: 40px;--s-12: 48px;--s-16: 64px;--r-sm: 6px;--r-md: 10px;--r-lg: 12px;--r-pill: 999px;--shadow-card: 0 1px 2px rgba(20,20,20,.04);--shadow-pop: 0 4px 12px rgba(20,30,50,.08), 0 1px 2px rgba(20,20,20,.05);--shadow-modal: 0 12px 32px rgba(20,30,50,.12), 0 2px 6px rgba(20,30,50,.06);--shadow-focus: 0 0 0 3px rgba(200,132,26,.28);--ease: cubic-bezier(.2, .6, .2, 1);--t-fast: .12s;--t-base: .16s;--t-slow: .24s;--sidebar-w: 240px;--topbar-h: 56px;--content-max: 1400px}*,*:before,*:after{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:var(--font-sans);color:var(--fg);background:var(--bg-page);font-size:var(--t-14);line-height:var(--lh-base);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}img{max-width:100%;height:auto;display:block}a{text-decoration:none;color:inherit}ul{list-style:none;margin:0;padding:0}button{cursor:pointer;font-family:inherit;border:none}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:500}.app{display:grid;grid-template-columns:var(--sidebar-w) 1fr;height:100vh;overflow:hidden}.sidebar{background:var(--navy);color:var(--fg-on-navy);display:flex;flex-direction:column;padding:20px 16px;height:100vh;overflow-y:auto;overflow-x:hidden;position:relative;z-index:50;transition:transform var(--t-slow) var(--ease)}.brand{display:flex;align-items:center;justify-content:center;flex-direction:column;padding:0 0 16px;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:16px;gap:0}.brand-logo{width:100%;height:auto;max-height:160px;object-fit:cover;object-position:center;display:block;border-radius:0}.client-card{background:#ffffff0d;border:1px solid rgba(255,255,255,.08);border-radius:8px;padding:12px;margin-bottom:18px;display:flex;align-items:center;gap:10px}.client-card .av,.cc-avatar{width:32px;height:32px;border-radius:var(--r-pill);background:var(--gold-100);color:var(--navy);font-weight:700;font-size:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.client-card .name,.cc-name{font-size:13px;font-weight:600;color:#fff;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.client-card .meta,.cc-role{font-size:11px;color:var(--fg-on-navy-2);font-family:var(--font-mono)}.cc-info{min-width:0}.nav-group{padding:12px 10px 6px;font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:#8a99b2}.nav-item{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:6px;color:#c7d2e3;font-size:12px;font-weight:500;cursor:pointer;background:none;border:0;width:100%;text-align:left;font-family:inherit;transition:background var(--t-fast),color var(--t-fast);position:relative;white-space:nowrap}.nav-item:hover{background:#ffffff0f;color:#fff}.nav-item.active{background:#ffffff1a;color:#fff;font-weight:600}.nav-item.active:before{content:"";position:absolute;left:-16px;top:8px;bottom:8px;width:2px;background:var(--gold);border-radius:2px}.nav-item svg{width:18px;height:18px;stroke-width:1.75;flex-shrink:0}.nav-icon-badge{width:32px;height:32px;border-radius:9px;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:#ffffff1a;transition:background var(--t-fast)}.nav-item:hover .nav-icon-badge{background:#ffffff29}.nav-item.active .nav-icon-badge{background:var(--gold)}.nav-item .nav-label{flex:1;overflow:hidden;text-overflow:ellipsis}.sidebar-nav-scroll{display:flex;flex-direction:column;flex:1;overflow-y:auto;overflow-x:hidden;min-height:0}.sidebar-foot{margin-top:auto;padding-top:16px;border-top:1px solid rgba(255,255,255,.08)}.topbar{height:var(--topbar-h);padding:0 32px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border-soft);background:#ffffffe6;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);position:sticky;top:0;z-index:10;flex-shrink:0}.crumbs{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--fg-3)}.crumbs .sep{color:var(--fg-4)}.crumbs .current{color:var(--fg);font-weight:600}.topbar-actions{display:flex;align-items:center;gap:12px}.hamburger{display:none;background:none;border:none;padding:6px;border-radius:6px;color:var(--fg-2);cursor:pointer;transition:background var(--t-fast)}.hamburger:hover{background:var(--bg-soft)}.main{display:flex;flex-direction:column;min-width:0;overflow-y:auto;height:100vh}.page{padding:32px;max-width:var(--content-max);width:100%;flex:1}.page-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:28px;gap:16px;flex-wrap:wrap}.page-head h1{margin:0 0 4px;font-size:28px;font-weight:500;letter-spacing:-.01em;font-family:var(--font-display);color:var(--navy)}.page-head .sub,.page-head .page-sub{color:var(--fg-3);font-size:14px;margin:0}.page-head-actions{display:flex;gap:10px;flex-wrap:wrap}.btn{height:36px;padding:0 16px;border-radius:var(--r-sm);font-family:inherit;font-size:14px;font-weight:600;line-height:1;border:1px solid transparent;cursor:pointer;display:inline-flex;align-items:center;gap:8px;transition:all var(--t-fast) ease-out;white-space:nowrap}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-primary{background:var(--gold);color:#fff}.btn-primary:hover{background:var(--gold-700)}.btn-secondary{background:var(--navy);color:#fff}.btn-secondary:hover{background:var(--navy-700)}.btn-ghost{background:#fff;color:var(--fg);border-color:var(--border)}.btn-ghost:hover{background:var(--bg-soft);border-color:var(--border-strong)}.btn-text{background:transparent;color:var(--fg-2);padding:0 8px;height:32px;border:none}.btn-text:hover{color:var(--fg);background:var(--bg-soft)}.btn-danger{background:var(--bad);color:#fff}.btn-danger:hover{background:#a83232}.btn-sm{height:30px;padding:0 12px;font-size:13px}.btn svg{width:16px;height:16px;stroke-width:1.75}.input{height:38px;padding:0 12px;border:1px solid var(--border);border-radius:var(--r-sm);background:#fff;font-family:inherit;font-size:14px;color:var(--fg);outline:none;transition:border var(--t-fast) ease-out,box-shadow var(--t-fast) ease-out}.input::placeholder{color:var(--fg-4)}.input:focus{border-color:var(--gold);box-shadow:var(--shadow-focus)}.input-block{width:100%}.form-field{display:flex;flex-direction:column;gap:5px}.form-label{font-size:12px;font-weight:600;color:var(--fg-2);letter-spacing:.03em;text-transform:uppercase}.form-error{font-size:12px;color:var(--bad);margin-top:2px}textarea.input{height:auto;padding:10px 12px;resize:vertical}select.input{cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23767C88' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:32px;-moz-appearance:none;appearance:none;-webkit-appearance:none}.pill{display:inline-flex;align-items:center;gap:6px;height:22px;padding:0 10px;border-radius:var(--r-pill);font-size:12px;font-weight:600;border:0;white-space:nowrap}.pill .d{width:7px;height:7px;border-radius:var(--r-pill);flex-shrink:0}.pill.ok{background:var(--ok-bg);color:#1f6a45}.pill.ok .d{background:var(--ok)}.pill.warn{background:var(--warn-bg);color:#8a5a0e}.pill.warn .d{background:var(--warn)}.pill.bad{background:var(--bad-bg);color:#9b2a2a}.pill.bad .d{background:var(--bad)}.pill.info{background:var(--info-bg);color:#1e4f9c}.pill.info .d{background:var(--info)}.pill.na{background:var(--na-bg);color:#4a4f5a}.pill.na .d{background:var(--na)}.dot{width:8px;height:8px;border-radius:var(--r-pill);display:inline-block;flex-shrink:0}.dot.ok{background:var(--ok)}.dot.warn{background:var(--warn)}.dot.bad{background:var(--bad)}.dot.info{background:var(--info)}.dot.na{background:var(--na)}.card{background:#fff;border:1px solid var(--border-soft);border-radius:var(--r-md);box-shadow:0 2px 10px #141e3212;transition:transform var(--t-fast),box-shadow var(--t-fast),border-color var(--t-fast)}.card:hover{border-color:var(--border);box-shadow:0 10px 28px #141e3221}.kpi{background:#fff;border:1px solid var(--border-soft);border-radius:var(--r-md);padding:18px 20px;box-shadow:var(--shadow-card);display:flex;flex-direction:column;gap:6px;min-width:0}.kpi .lbl{font-size:11px;font-weight:600;color:var(--fg-3);text-transform:uppercase;letter-spacing:.04em}.kpi .v{font-family:var(--font-mono);font-size:32px;font-weight:700;color:var(--fg);line-height:1.1;letter-spacing:-.02em}.kpi .delta{font-size:12px;color:var(--fg-3);display:flex;align-items:center;gap:6px}.kpi .delta.ok{color:#1f6a45}.kpi .delta.bad{color:#9b2a2a}.kpi.warn{border-color:#f1dda8;background:linear-gradient(180deg,#fcf5e5,#fffcf3)}.kpi.bad{border-color:#efc4c4;background:linear-gradient(180deg,#fbe9e9,#fff6f6)}.month-card{background:#fff;border:1px solid var(--border-soft);border-radius:14px;padding:22px;position:relative;overflow:hidden;transition:transform .2s ease-out,box-shadow .2s ease-out,border-color .2s ease-out;cursor:pointer}.month-card:hover{transform:translateY(-1px);box-shadow:0 8px 24px #141e320f,0 1px 2px #141e320a;border-color:var(--border)}.month-card:after{content:"";position:absolute;top:0;right:0;width:140px;height:140px;border-radius:50%;transform:translate(45%,-45%);opacity:.5;pointer-events:none}.month-card.tone-ok:after{background:radial-gradient(closest-side,#C8E6D4 0%,transparent 100%)}.month-card.tone-warn:after{background:radial-gradient(closest-side,#F7DFA8 0%,transparent 100%)}.month-card.tone-bad:after{background:radial-gradient(closest-side,#EFC4C4 0%,transparent 100%)}.month-card .mc-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px;position:relative}.month-card .mc-month{font-family:var(--font-display);font-size:18px;font-weight:400;letter-spacing:-.01em;color:var(--fg)}.month-card .mc-pct-row{display:flex;align-items:baseline;gap:6px;margin-bottom:14px;position:relative}.month-card .mc-pct{font-family:var(--font-display);font-size:52px;font-weight:400;line-height:.95;letter-spacing:-.03em;font-variant-numeric:tabular-nums lining-nums;background-clip:text;-webkit-background-clip:text;color:transparent;-webkit-text-fill-color:transparent}.month-card .mc-pct.tone-ok{background-image:linear-gradient(135deg,#2f8f5e,#1f6a45)}.month-card .mc-pct.tone-warn{background-image:linear-gradient(135deg,#c8841a,#8a5a0e)}.month-card .mc-pct.tone-bad{background-image:linear-gradient(135deg,#c13b3b,#9b2a2a)}.month-card .mc-sym{font-family:var(--font-display);font-size:26px;font-weight:600;color:var(--fg-3)}.month-card .mc-bar{height:8px;background:var(--bg-muted);border-radius:var(--r-pill);overflow:hidden;margin-bottom:14px}.month-card .mc-bar>div{height:100%;border-radius:var(--r-pill);transition:width .4s ease-out}.month-card .mc-bar.tone-ok>div{background:linear-gradient(90deg,#2f8f5e,#3fa66e)}.month-card .mc-bar.tone-warn>div{background:linear-gradient(90deg,#c8841a,#e29a2a)}.month-card .mc-bar.tone-bad>div{background:linear-gradient(90deg,#c13b3b,#d55757)}.month-card .mc-foot{display:flex;align-items:center;gap:10px;font-size:12px;color:var(--fg-2);border-top:1px solid var(--border-soft);padding-top:12px}.month-card .mc-avatar{width:22px;height:22px;border-radius:var(--r-pill);background:var(--gold-100);color:var(--navy);font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.month-card .mc-meta{color:var(--fg-3);margin-left:auto;font-weight:500}.table{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--border-soft);border-radius:var(--r-md);overflow:hidden}.table th,.table td{text-align:left;padding:12px 16px;font-size:13px}.table th{font-weight:700;color:var(--navy);font-size:12px;text-transform:uppercase;letter-spacing:.05em;background:var(--bg-soft);border-bottom:1px solid var(--border-soft);white-space:nowrap}.table tbody tr{border-bottom:1px solid var(--border-soft);transition:background var(--t-fast)}.table tbody tr:hover{background:var(--bg-soft)}.table tbody tr:last-child{border-bottom:0}.table td.right,.table th.right{text-align:right}.num{font-family:var(--font-mono);font-variant-numeric:tabular-nums}.section-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:14px;flex-wrap:wrap;gap:8px}.section-head h3{margin:0;font-size:16px;font-weight:500;font-family:var(--font-display)}.section-head .count{font-family:var(--font-mono);font-size:12px;color:var(--fg-3)}.progress{height:6px;background:var(--bg-muted);border-radius:var(--r-pill);overflow:hidden}.progress>div{height:100%;border-radius:var(--r-pill);transition:width .2s}.drawer-scrim{position:fixed;top:0;right:0;bottom:0;left:0;background:#141e3252;z-index:100;opacity:0;pointer-events:none;transition:opacity var(--t-slow) var(--ease)}.drawer-scrim.open{opacity:1;pointer-events:auto}.drawer{position:fixed;top:0;right:0;height:100vh;width:460px;max-width:90vw;background:#fff;box-shadow:var(--shadow-modal);z-index:101;display:flex;flex-direction:column;transform:translate(100%);transition:transform var(--t-slow) var(--ease)}.drawer.open{transform:translate(0)}.drawer-head{padding:20px 24px;border-bottom:1px solid var(--border-soft);display:flex;align-items:flex-start;justify-content:space-between}.drawer-head h2{margin:0;font-size:20px;font-weight:500;font-family:var(--font-display)}.drawer-head .sub{color:var(--fg-3);font-size:13px;margin-top:2px}.drawer-body{padding:24px;overflow-y:auto;flex:1}.drawer-foot{padding:16px 24px;border-top:1px solid var(--border-soft);display:flex;gap:10px;justify-content:flex-end}.modal-scrim{position:fixed;top:0;right:0;bottom:0;left:0;background:#141e3266;z-index:200;display:flex;align-items:center;justify-content:center;animation:fadeIn .15s var(--ease)}.modal{background:#fff;border-radius:var(--r-lg);width:min(560px,94vw);max-height:88vh;overflow-y:auto;box-shadow:var(--shadow-modal);animation:scaleIn .18s var(--ease)}.modal-head{padding:20px 24px;border-bottom:1px solid var(--border-soft);display:flex;align-items:center;justify-content:space-between}.modal-head h3{margin:0;font-size:18px;font-weight:500;font-family:var(--font-display)}.modal-body{padding:24px;display:flex;flex-direction:column;gap:16px}.modal-foot{padding:16px 24px;border-top:1px solid var(--border-soft);display:flex;gap:10px;justify-content:flex-end}.icon-btn{background:none;border:0;padding:6px;border-radius:6px;cursor:pointer;color:var(--fg-3);transition:background var(--t-fast),color var(--t-fast);display:flex;align-items:center;justify-content:center}.icon-btn:hover{background:var(--bg-soft);color:var(--fg)}.icon-btn svg{width:18px;height:18px;stroke-width:1.75}.dl{display:grid;grid-template-columns:1fr 1fr;gap:14px 20px}.dl .k{font-size:11px;font-weight:600;color:var(--fg-3);text-transform:uppercase;letter-spacing:.04em;margin-bottom:3px}.dl .v{font-size:14px;color:var(--fg);font-weight:500}.seg{display:inline-flex;background:var(--bg-muted);border-radius:8px;padding:3px}.seg button{border:0;background:transparent;padding:6px 14px;font-family:inherit;font-size:13px;font-weight:600;color:var(--fg-2);border-radius:6px;cursor:pointer;transition:all var(--t-fast);white-space:nowrap}.seg button.active{background:#fff;color:var(--fg);box-shadow:0 1px 2px #1414140f}.tabs{display:flex;gap:0;border-bottom:1px solid var(--border-soft);margin-bottom:24px}.tabs button{border:0;background:transparent;padding:10px 16px;font-family:inherit;font-size:14px;font-weight:600;color:var(--fg-3);cursor:pointer;position:relative;margin-bottom:-1px;transition:color var(--t-fast)}.tabs button:hover{color:var(--fg-2)}.tabs button.active{color:var(--fg)}.tabs button.active:after{content:"";position:absolute;left:12px;right:12px;bottom:0;height:2px;background:var(--gold);border-radius:2px}.filter-bar{display:flex;gap:10px;align-items:center;padding:14px 16px;background:#fff;border:1px solid var(--border-soft);border-radius:var(--r-md);margin-bottom:16px;flex-wrap:wrap}.filter-bar .input{height:34px;font-size:13px}.filter-bar .grow{flex:1}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}.cal-h{font-size:11px;font-weight:600;color:var(--fg-3);text-transform:uppercase;letter-spacing:.04em;text-align:left;padding:6px 8px}.cal-day{min-height:96px;background:#fff;border:1px solid var(--border-soft);border-radius:8px;padding:8px 10px;display:flex;flex-direction:column;gap:4px;cursor:default;transition:border-color var(--t-fast)}.cal-day:hover{border-color:var(--border)}.cal-day.off{background:transparent;border-color:transparent}.cal-day.off .n{color:var(--fg-4)}.cal-day.today{border-color:var(--gold)}.cal-day .n{font-family:var(--font-mono);font-size:12px;color:var(--fg-2);font-weight:400}.cal-day.today .n{color:var(--gold)}.cal-ev{font-size:11px;padding:3px 8px;border-radius:4px;font-weight:600;line-height:1.25;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;cursor:pointer}.cal-ev:hover{filter:brightness(.95)}.cal-ev.warn{background:var(--warn-bg);color:#8a5a0e}.cal-ev.bad{background:var(--bad-bg);color:#9b2a2a}.cal-ev.info{background:var(--info-bg);color:#1e4f9c}.cal-ev.ok{background:var(--ok-bg);color:#1f6a45}.group-head{background:var(--bg-soft);padding:10px 16px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border-soft)}.group-head .name{font-size:13px;font-weight:700;color:var(--fg)}.group-head .nit{font-family:var(--font-mono);font-size:12px;color:var(--fg-3);margin-left:8px}.doc-cat{background:#fff;border:1px solid var(--border-soft);border-radius:var(--r-md);padding:20px}.doc-cat-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;gap:16px}.doc-cat-title{display:flex;align-items:center;gap:12px}.doc-cat-icon{width:36px;height:36px;border-radius:8px;background:var(--gold-50);color:var(--gold);display:flex;align-items:center;justify-content:center;flex-shrink:0}.doc-cat-icon svg{width:18px;height:18px;stroke-width:1.75}.doc-cat-title h3{margin:0;font-size:15px;font-weight:600}.doc-cat-title .sub{font-size:12px;color:var(--fg-3);font-family:var(--font-mono);margin-top:2px}.file-row{display:grid;grid-template-columns:1fr auto auto auto;gap:16px;align-items:center;padding:10px 12px;border-radius:6px;transition:background var(--t-fast)}.file-row:hover{background:var(--bg-soft)}.file-row .nm{display:flex;align-items:center;gap:10px;font-size:13px;font-weight:500;color:var(--fg);min-width:0}.file-row .nm svg{color:var(--fg-3);flex-shrink:0;width:16px;height:16px;stroke-width:1.75}.file-row .nm span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-row .meta{font-family:var(--font-mono);font-size:12px;color:var(--fg-3);white-space:nowrap}.drop-zone{border:1.5px dashed var(--border);background:transparent;border-radius:8px;padding:16px 18px;display:flex;align-items:center;justify-content:space-between;transition:all var(--t-fast);cursor:pointer}.drop-zone.active{border-color:var(--gold);background:var(--gold-50)}.drop-zone-hint{font-size:11px;color:var(--fg-4);font-family:var(--font-mono)}.empty{text-align:center;padding:40px 24px;color:var(--fg-3)}.empty h4{margin:0 0 6px;color:var(--fg);font-size:14px;font-weight:600}.empty p{margin:0 0 14px;font-size:13px}.toast{position:fixed;bottom:24px;right:24px;background:var(--navy);color:#fff;padding:12px 16px;border-radius:8px;box-shadow:var(--shadow-pop);display:flex;align-items:center;gap:12px;font-size:13px;font-weight:500;z-index:300;animation:slideInRight .25s var(--ease)}.toast.success{background:#1f6a45}.toast.error{background:var(--bad)}.spinner{width:20px;height:20px;border:2.5px solid rgba(200,132,26,.2);border-top-color:var(--gold);border-radius:var(--r-pill);animation:spin .75s linear infinite;flex-shrink:0}.spinner-sm{width:14px;height:14px;border-width:2px}.loading-row{text-align:center;padding:40px;color:var(--fg-3)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--navy);background-image:radial-gradient(ellipse at 20% 20%,rgba(200,132,26,.12) 0%,transparent 50%),radial-gradient(ellipse at 80% 80%,rgba(255,255,255,.04) 0%,transparent 50%)}.login-card{background:#fff;border-radius:16px;padding:44px 40px;width:min(420px,96vw);box-shadow:var(--shadow-modal)}.login-logo{text-align:center;margin-bottom:32px}.login-logo img{height:64px;margin:0 auto 12px}.login-logo p{font-size:14px;color:var(--fg-3);margin:4px 0 0}.login-fields{display:flex;flex-direction:column;gap:16px}.login-error{background:var(--bad-bg);border:1px solid #EFC4C4;color:var(--bad);font-size:13px;font-weight:500;padding:10px 14px;border-radius:8px}.search-wrap{position:relative}.search-wrap svg{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--fg-3);pointer-events:none}.search-wrap .input{padding-left:34px}.sidebar-scrim{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#141e3266;z-index:49}.sidebar-scrim.open{display:block}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes scaleIn{0%{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes slideDown{0%{transform:translateY(-8px);opacity:0}to{transform:translateY(0);opacity:1}}@media (max-width: 1024px) and (min-width: 768px){:root{--sidebar-w: 64px}.brand-name,.nav-label,.client-card,.sidebar-foot-info{display:none}.nav-item{justify-content:center;padding:10px 0;position:relative}.nav-item[data-tooltip]:hover:after{content:attr(data-tooltip);position:absolute;left:calc(100% + 8px);top:50%;transform:translateY(-50%);background:var(--navy-900);color:#fff;font-size:12px;font-weight:500;white-space:nowrap;padding:5px 10px;border-radius:var(--radius-sm);pointer-events:none;z-index:200;box-shadow:var(--shadow-md)}.brand{justify-content:center;padding:20px 0}.brand-logo{width:32px;height:32px}.sidebar-foot{justify-content:center;padding:16px 0}}@media (max-width: 767px){:root{--sidebar-w: 0px}.app{grid-template-columns:1fr}.main{display:flex;flex-direction:column;min-width:0;overflow-x:hidden;overflow-y:auto;height:100vh}.page{padding:16px!important}.sidebar{position:fixed;left:-280px;top:0;width:280px;height:100vh;z-index:200;transition:left .24s cubic-bezier(.2,.6,.2,1);box-shadow:none}.sidebar.open{left:0;box-shadow:0 8px 40px #00000052}.sidebar-scrim{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:199;opacity:0;pointer-events:none;transition:opacity .24s cubic-bezier(.2,.6,.2,1)}.sidebar-scrim.open{opacity:1;pointer-events:all}.topbar-hamburger{display:flex!important}.sidebar{overflow:hidden}.sidebar-close-btn{display:flex!important}.brand-logo{max-height:80px!important}.topbar{padding:0 16px;gap:12px}.soporte-grid{grid-template-columns:1fr!important}.soporte-grid>div{padding:28px 20px!important}.kpi-grid,.docs-client-grid{grid-template-columns:1fr!important}.page-head{flex-direction:column;align-items:flex-start!important}.page-head h1{font-size:22px!important}}@media (min-width: 768px){.topbar-hamburger{display:none}.sidebar-scrim{display:none!important}}.month-nav{display:flex;align-items:center;gap:10px;margin-bottom:18px;flex-wrap:wrap}.month-nav-arrows{display:flex;align-items:center;gap:6px}.view-toggle{display:flex;overflow:hidden}@media (max-width: 767px){.month-nav-arrows button{width:38px!important;height:38px!important;padding:0!important;display:flex!important;align-items:center!important;justify-content:center!important;border:none!important;background:var(--navy)!important;color:#fff!important;border-radius:50%!important;box-shadow:0 2px 8px #1e3a5f40}.month-nav-label{font-weight:700!important;font-size:15px!important;color:var(--navy)!important;flex:1;text-align:center}.view-toggle{border-radius:10px!important;box-shadow:0 2px 8px #0000001f;border:none!important}.view-toggle button{padding:0 16px!important;height:38px!important;font-size:13px!important;font-weight:700!important}.card{box-shadow:0 2px 12px #141e3214!important;border-radius:14px!important}.table tbody tr td{padding:12px 10px!important}.topbar-hamburger{width:38px!important;height:38px!important;padding:0!important;border-radius:50%!important;background:var(--navy-50)!important;border:none!important;display:flex!important;align-items:center!important;justify-content:center!important;color:var(--navy)!important}}@media (max-width: 1280px) and (min-width: 1025px){.page{padding:24px 28px}.page-head h1{font-size:24px!important}}@media (max-width: 900px){.table-responsive{overflow-x:auto;-webkit-overflow-scrolling:touch}.docs-detail-header{flex-direction:column;align-items:flex-start!important;gap:8px!important}.docs-upload-panel{flex-direction:column;gap:14px!important}.docs-upload-panel button{width:100%!important}.docs-upload-grid{grid-template-columns:1fr!important}.docs-filter-bar{flex-wrap:wrap}}@media (max-width: 600px){.kpi-grid,.docs-client-grid{grid-template-columns:1fr!important}}
