@import"https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;1,9..40,400&display=swap";@import"https://fonts.googleapis.com/css2?family=DM+Mono:wght@400;500&display=swap";@import"https://fonts.googleapis.com/css2?family=DM+Serif+Display:ital@0;1&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--blue-950: #0A1929;--blue-900: #0D2D52;--blue-800: #0C447C;--blue-700: #1356A0;--blue-600: #1976D2;--blue-100: #BFDBFE;--blue-50: #EFF6FF;--green-800: #14532D;--green-700: #15803D;--green-600: #16A34A;--green-100: #DCFCE7;--green-50: #F0FDF4;--amber-800: #78350F;--amber-700: #B45309;--amber-100: #FEF3C7;--amber-50: #FFFBEB;--red-700: #B91C1C;--red-100: #FEE2E2;--red-50: #FEF2F2;--purple-700: #7C3AED;--purple-100: #EDE9FE;--purple-50: #F5F3FF;--teal-700: #0F766E;--teal-100: #CCFBF1;--teal-50: #F0FDFA;--indigo-700: #4338CA;--indigo-100: #E0E7FF;--indigo-50: #EEF2FF;--gray-900: #0F172A;--gray-800: #1E293B;--gray-700: #334155;--gray-600: #475569;--gray-500: #64748B;--gray-400: #94A3B8;--gray-300: #CBD5E1;--gray-200: #E2E8F0;--gray-100: #F1F5F9;--gray-50: #F8FAFC;--white: #FFFFFF;--text-primary: var(--gray-900);--text-secondary: var(--gray-500);--text-muted: var(--gray-400);--border: var(--gray-200);--border-med: var(--gray-300);--surface: var(--white);--bg: var(--gray-100);--shadow-xs: 0 1px 2px rgba(15,23,42,.04);--shadow-sm: 0 1px 3px rgba(15,23,42,.07), 0 1px 2px rgba(15,23,42,.04);--shadow-md: 0 4px 6px rgba(15,23,42,.05), 0 2px 4px rgba(15,23,42,.04);--shadow-lg: 0 10px 24px rgba(15,23,42,.08), 0 4px 8px rgba(15,23,42,.04);--radius-sm: 5px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--font: "DM Sans", system-ui, -apple-system, sans-serif;--font-mono: "DM Mono", "Courier New", monospace}html,body,#root{height:100%;font-family:var(--font);color:var(--text-primary);background:var(--bg);-webkit-font-smoothing:antialiased}.app-shell{display:flex;height:100vh;overflow:hidden}.sidebar{width:236px;min-width:236px;display:flex;flex-direction:column;border-right:1px solid rgba(0,0,0,.35);box-shadow:4px 0 32px #0006;position:relative;overflow:hidden;background-color:#040e1e;background-image:radial-gradient(ellipse 160% 55% at -10% 12%,rgba(14,80,160,.72) 0%,rgba(8,40,100,.45) 40%,transparent 70%),radial-gradient(ellipse 120% 40% at 110% 48%,rgba(25,118,210,.38) 0%,rgba(12,68,124,.22) 40%,transparent 68%),radial-gradient(ellipse 180% 45% at -20% 92%,rgba(10,55,130,.55) 0%,rgba(6,28,80,.3) 45%,transparent 70%),radial-gradient(ellipse 70% 22% at 100% 4%,rgba(96,208,255,.18) 0%,rgba(25,118,210,.1) 50%,transparent 75%),radial-gradient(ellipse 90% 18% at 50% 68%,rgba(19,86,160,.3) 0%,transparent 65%),linear-gradient(175deg,#0d2d52,#081830 35%,#050f20 65%,#040e1e),repeating-linear-gradient(-52deg,transparent,transparent 28px,rgba(255,255,255,.014) 28px,rgba(255,255,255,.014) 29px)}.sidebar-brand{display:flex;align-items:center;gap:12px;padding:22px 18px 18px;border-bottom:1px solid rgba(255,255,255,.07)}.brand-logo{width:36px;height:36px;border-radius:9px;background:linear-gradient(135deg,var(--blue-700),var(--blue-600));color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;flex-shrink:0;letter-spacing:-.5px;box-shadow:0 2px 8px #0000004d}.brand-name{color:#fff;font-size:15px;font-weight:600;letter-spacing:-.3px}.brand-sub{color:#ffffff61;font-size:10.5px;margin-top:1px;font-weight:400}.sidebar-nav{flex:1;padding:10px;overflow-y:auto}.nav-section{padding:14px 10px 5px;font-size:10px;color:#ffffff47;letter-spacing:.1em;text-transform:uppercase;font-weight:600}.nav-item{display:flex;align-items:center;gap:10px;padding:9px 12px;cursor:pointer;color:#fff9;font-size:13.5px;border-radius:var(--radius-md);margin-bottom:1px;transition:background .13s,color .13s;position:relative}.nav-item:hover{background:#ffffff12;color:#ffffffe6}.nav-item.active{background:#ffffff1f;color:#fff;font-weight:500}.nav-item.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:20px;background:var(--blue-100);border-radius:0 3px 3px 0}.nav-icon{width:18px;text-align:center;font-size:13px;flex-shrink:0;opacity:.7}.nav-item.active .nav-icon{opacity:1}.sidebar-slogan{padding:18px 18px 16px;border-top:1px solid rgba(255,255,255,.08);border-bottom:1px solid rgba(255,255,255,.05);position:relative}.sidebar-slogan:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 200% 140% at 50% 110%,rgba(25,118,210,.12) 0%,transparent 65%);pointer-events:none}.slogan-divider{width:28px;height:1.5px;background:linear-gradient(90deg,#60d0ff80,#ffffff1a);margin-bottom:12px;border-radius:2px}.slogan-text{font-family:"DM Serif Display",Georgia,serif;font-style:italic;font-size:16.5px;line-height:1.5;letter-spacing:.01em;background:linear-gradient(160deg,#ffffffd1,#bfdbfea6 55%,#60d0ff73);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:0 2px 12px rgba(25,118,210,.3);position:relative}.slogan-text:before{content:"“";font-size:28px;line-height:0;vertical-align:-10px;margin-right:2px;opacity:.45;background:linear-gradient(160deg,#ffffffb3,#60d0ff66);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.slogan-text:after{content:"”";font-size:28px;line-height:0;vertical-align:-10px;margin-left:2px;opacity:.45;background:linear-gradient(160deg,#ffffffb3,#60d0ff66);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.sidebar-footer{padding:14px 16px;display:flex;align-items:center;justify-content:space-between;gap:10px}.user-info{flex:1;min-width:0}.user-name{color:#fff;font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{color:#ffffff61;font-size:10.5px;margin-top:1px}.logout-btn{background:#ffffff12;border:1px solid rgba(255,255,255,.12);border-radius:6px;color:#ffffff80;font-size:11px;font-family:var(--font);padding:5px 9px;cursor:pointer;transition:all .13s;white-space:nowrap}.logout-btn:hover{background:#ffffff21;color:#fff}.main-area{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--bg)}.topbar{background:var(--surface);border-bottom:1px solid var(--border);padding:0 28px;height:56px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0;box-shadow:var(--shadow-xs);z-index:10}.topbar-title{font-size:14px;font-weight:600;color:var(--text-primary);letter-spacing:-.1px}.topbar-meta{font-size:12px;color:var(--text-secondary)}.page-content{flex:1;min-height:0;overflow-y:auto;padding:24px 28px;display:flex;flex-direction:column;gap:20px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm)}.card-header{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.card-title{font-size:14px;font-weight:600;color:var(--text-primary)}.card-subtitle{font-size:12px;color:var(--text-secondary);margin-top:2px}.card-section-title{padding:12px 20px 6px;font-size:11px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.07em;border-top:1px solid var(--border);margin-top:4px}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px 22px;box-shadow:var(--shadow-sm);position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;width:4px;height:100%;background:var(--blue-700);border-radius:4px 0 0 4px}.stat-label{font-size:11px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.07em;margin-bottom:10px}.stat-value{font-size:28px;font-weight:700;letter-spacing:-1px;color:var(--text-primary);line-height:1}.stat-sub{font-size:12px;color:var(--text-secondary);margin-top:6px}.stat-sub.up{color:var(--green-700)}.table{width:100%;border-collapse:collapse;font-size:13.5px}.table th{padding:11px 20px;text-align:left;font-size:11px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border);background:var(--gray-50);white-space:nowrap}.table td{padding:13px 20px;border-bottom:1px solid var(--border);vertical-align:middle}.table tr:last-child td{border-bottom:none}.table-row-clickable{cursor:pointer;transition:background .1s}.table-row-clickable:hover td{background:var(--gray-50)}.td-main{font-weight:500}.td-sub{font-size:11px;color:var(--text-secondary);margin-top:2px}.td-loading{text-align:center;padding:40px!important;color:var(--text-secondary)}.table-footer{padding:12px 20px;font-size:12px;color:var(--text-secondary);border-top:1px solid var(--border)}.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:99px;font-size:11px;font-weight:600;letter-spacing:.02em;white-space:nowrap}.badge-pend{background:var(--amber-100);color:var(--amber-700)}.badge-auth{background:#dbeafe;color:#1d4ed8}.badge-fact{background:var(--purple-100);color:var(--purple-700)}.badge-paid{background:#cffafe;color:#0e7490}.badge-rev{background:#fce7f3;color:#9d174d}.badge-done{background:var(--green-100);color:var(--green-700)}.badge-info,.badge-blue{background:var(--blue-50);color:var(--blue-700)}.badge-entregado{background:var(--indigo-100);color:var(--indigo-700)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 16px;border-radius:var(--radius-md);font-size:13px;font-family:var(--font);cursor:pointer;border:1px solid var(--border-med);background:var(--surface);color:var(--text-primary);font-weight:500;transition:all .13s;white-space:nowrap;line-height:1.4}.btn:hover{background:var(--gray-50);border-color:var(--gray-300)}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.45;cursor:not-allowed;transform:none}.btn-primary{background:var(--blue-800);color:#fff;border-color:var(--blue-800);box-shadow:0 1px 3px #0c447c40}.btn-primary:hover{background:var(--blue-900);border-color:var(--blue-900)}.btn-success{background:var(--green-700);color:#fff;border-color:var(--green-700);box-shadow:0 1px 3px #15803d40}.btn-success:hover{background:var(--green-800);border-color:var(--green-800)}.btn-danger{background:var(--red-700);color:#fff;border-color:var(--red-700)}.btn-danger:hover{background:#991b1b}.btn-sm{padding:5px 12px;font-size:12px}.btn-default{background:var(--surface)}.form-group{display:flex;flex-direction:column;gap:5px}.form-group.full{grid-column:1 / -1}.form-label{font-size:12px;color:var(--text-secondary);font-weight:600}.form-input,.form-select{padding:9px 12px;border:1px solid var(--border-med);border-radius:var(--radius-md);font-size:13.5px;font-family:var(--font);background:var(--surface);color:var(--text-primary);transition:border-color .13s,box-shadow .13s}.form-input:focus,.form-select:focus{outline:none;border-color:var(--blue-700);box-shadow:0 0 0 3px #1356a01a}.form-input::placeholder{color:var(--text-muted)}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.field-hint{font-size:11px;color:var(--text-secondary);margin-top:3px}.alert{padding:12px 16px;border-radius:var(--radius-md);font-size:13px;font-weight:500;margin-bottom:4px}.alert-success{background:var(--green-50);color:var(--green-700);border:1px solid var(--green-100)}.alert-danger{background:var(--red-50);color:var(--red-700);border:1px solid var(--red-100)}.alert-info{background:var(--blue-50);color:var(--blue-700);border:1px solid var(--blue-100)}.tl-item{display:flex;gap:12px}.tl-left{display:flex;flex-direction:column;align-items:center;width:24px;flex-shrink:0}.tl-icon{width:22px;height:22px;border-radius:50%;background:var(--blue-50);color:var(--blue-700);display:flex;align-items:center;justify-content:center;font-size:10px;flex-shrink:0;margin-top:2px}.tl-line{width:1px;flex:1;background:var(--border);min-height:14px;margin:3px 0}.tl-body{flex:1;padding-bottom:16px}.tl-title{font-size:13px;font-weight:500;margin-bottom:3px}.tl-meta{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.tl-meta>span:first-child{font-size:11px;color:var(--text-secondary)}.tl-ip{font-size:10px;color:var(--text-muted);font-family:var(--font-mono)}.actor-badge{font-size:10px;padding:1px 7px;border-radius:99px;font-weight:500}.actor-admin{background:var(--blue-50);color:var(--blue-700)}.actor-cliente{background:var(--green-50);color:var(--green-700)}.actor-sistema{background:var(--gray-100);color:var(--gray-500)}.two-col{display:grid;grid-template-columns:1fr 1fr;gap:16px}.folio-tag{font-family:var(--font-mono);font-size:12px;color:var(--text-secondary);background:var(--gray-100);padding:2px 8px;border-radius:var(--radius-sm);border:1px solid var(--border);font-weight:500}.detail-row{display:flex;justify-content:space-between;align-items:baseline;padding:9px 0;border-bottom:1px solid var(--border);font-size:13px}.detail-row:last-child{border-bottom:none}.detail-row>span:first-child{color:var(--text-secondary);min-width:130px}.portal-link-box{font-family:var(--font-mono);font-size:11px;background:var(--gray-50);border:1px solid var(--border-med);border-radius:var(--radius-sm);padding:8px 10px;word-break:break-all;color:var(--text-secondary)}.action-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border-radius:var(--radius-md);background:var(--gray-50);border:1px solid var(--border)}.action-title{font-size:13px;font-weight:600;margin-bottom:2px}.action-desc{font-size:11px;color:var(--text-secondary)}.close-action{border-color:var(--green-100);background:var(--green-50)}.action-waiting{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-secondary);padding:8px 0}.waiting-dot{width:8px;height:8px;border-radius:50%;background:var(--amber-700);animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.closed-state{text-align:center;padding:24px}.closed-icon{font-size:30px;color:var(--green-700);margin-bottom:8px}.closed-title{font-size:14px;font-weight:600;color:var(--green-700)}.closed-sub{font-size:12px;color:var(--text-secondary);margin-top:4px}.doc-row-small{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--border);font-size:13px}.doc-row-small:last-child{border-bottom:none}.doc-pill{font-size:10px;font-weight:600;background:var(--blue-50);color:var(--blue-700);padding:2px 7px;border-radius:4px}.step-indicator{display:flex;align-items:center}.step-item{display:flex;align-items:center;flex:1}.step-circle{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;flex-shrink:0;border:1.5px solid var(--border-med);background:var(--surface);color:var(--text-secondary);transition:all .2s}.step-circle.done{background:var(--green-700);border-color:var(--green-700);color:#fff}.step-circle.active{background:var(--blue-800);border-color:var(--blue-800);color:#fff}.step-label{font-size:11px;color:var(--text-secondary);margin-left:6px;white-space:nowrap}.step-label.active{color:var(--blue-800);font-weight:600}.step-line{flex:1;height:1.5px;background:var(--border);margin:0 8px;transition:background .2s}.step-line.done{background:var(--green-700)}.company-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;padding:16px}.company-card{background:var(--surface);border-radius:var(--radius-md);padding:18px;border:1px solid var(--border);transition:all .15s;box-shadow:var(--shadow-xs)}.company-card:hover{box-shadow:var(--shadow-lg);border-color:var(--gray-300);transform:translateY(-1px)}.company-initial{width:40px;height:40px;border-radius:10px;color:#fff;display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:700;margin-bottom:12px;box-shadow:0 2px 8px #00000026}.company-name{font-size:13.5px;font-weight:600;margin-bottom:3px}.company-rfc{font-size:11px;color:var(--text-secondary);margin-bottom:8px;font-family:var(--font-mono)}.company-stat{font-size:12px;color:var(--text-secondary)}.progress-bar{height:3px;background:var(--gray-200);border-radius:2px;overflow:hidden}.progress-fill{height:100%;border-radius:2px;transition:width .4s}.close-item{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-bottom:1px solid var(--border);gap:12px}.close-item-title{font-size:13px;font-weight:600}.close-item-sub{font-size:11px;color:var(--text-secondary);margin-top:2px}.close-item-monto{font-size:12px;color:var(--green-700);font-weight:600;margin-top:4px}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(145deg,var(--blue-950) 0%,var(--blue-800) 100%);padding:20px}.login-card{background:var(--surface);border-radius:var(--radius-xl);padding:40px;width:100%;max-width:400px;box-shadow:0 24px 64px #0000004d}.login-logo{display:flex;align-items:center;gap:14px;margin-bottom:32px}.login-logo-mark{width:46px;height:46px;border-radius:12px;background:linear-gradient(135deg,var(--blue-800),var(--blue-600));color:#fff;display:flex;align-items:center;justify-content:center;font-size:17px;font-weight:700;flex-shrink:0;letter-spacing:-.5px;box-shadow:0 4px 12px #0c447c66}.login-brand{font-size:19px;font-weight:700;letter-spacing:-.4px}.login-tagline{font-size:12px;color:var(--text-secondary);margin-top:2px}.login-form{display:flex;flex-direction:column;gap:16px}.login-hint{margin-top:24px;padding:14px;background:var(--gray-50);border-radius:var(--radius-md);border:1px solid var(--border)}.hint-title{font-size:11px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px}.hint-row{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-secondary);margin-bottom:5px}.hint-role{background:var(--blue-50);color:var(--blue-700);padding:1px 7px;border-radius:99px;font-size:10px;font-weight:600}.portal-shell{min-height:100vh;background:var(--bg);display:flex;justify-content:center;padding:24px 16px}.portal-container{width:100%;max-width:560px;display:flex;flex-direction:column;gap:14px}.portal-header{text-align:center;padding:8px 0 4px}.portal-brand{font-size:13px;color:var(--blue-700);font-weight:600;margin-bottom:6px}.portal-title{font-size:22px;font-weight:700;letter-spacing:-.4px;margin-bottom:4px}.portal-subtitle{font-size:13px;color:var(--text-secondary)}.portal-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px;box-shadow:var(--shadow-sm)}.portal-card-title{font-size:14px;font-weight:600;margin-bottom:12px}.portal-info-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--border);font-size:13px}.portal-info-row:last-child{border-bottom:none}.portal-info-row>span:first-child{color:var(--text-secondary)}.portal-action-card{border:1px solid var(--blue-100);background:var(--blue-50)}.portal-doc-row{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid var(--border)}.portal-doc-row:last-child{border-bottom:none}.portal-doc-icon{width:30px;height:30px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0}.portal-footer{text-align:center;font-size:11px;color:var(--text-muted);padding:8px 0}.portal-loading,.portal-error{text-align:center;padding:60px 20px;color:var(--text-secondary)}.portal-banner{border-radius:var(--radius-md);padding:14px 16px;display:flex;align-items:flex-start;gap:12px;font-size:13px}.portal-banner.cotizacion{background:var(--amber-50);border:1px solid var(--amber-100);color:var(--amber-700)}.portal-banner.autorizado{background:var(--purple-50);border:1px solid var(--purple-100);color:var(--purple-700)}.portal-banner.facturado{background:var(--blue-50);border:1px solid var(--blue-100);color:var(--blue-700)}.portal-banner.pagado{background:var(--green-50);border:1px solid var(--green-100);color:var(--green-700)}.portal-banner.cerrado{background:var(--teal-50);border:1px solid var(--teal-100);color:var(--teal-700)}.portal-banner-icon{font-size:16px;margin-top:1px;flex-shrink:0}.portal-banner-title{font-weight:600;margin-bottom:2px}.portal-banner-sub{font-size:12px;opacity:.8}.upload-zone{border:1.5px dashed var(--border-med);border-radius:var(--radius-md);padding:20px;text-align:center;cursor:pointer;transition:all .15s}.upload-zone:hover{border-color:var(--blue-700);background:var(--blue-50)}.loading-full,.loading-page{display:flex;align-items:center;justify-content:center;height:100%;font-size:14px;color:var(--text-secondary)}.empty-state{padding:40px;text-align:center;color:var(--text-secondary);font-size:13px}
