:root{--bg:#fafaf9;--surface:#fff;--surface-muted:#f5f5f4;--surface-tertiary:#efeeec;--border:#e7e5e2;--border-strong:#d6d3ce;--text-primary:#18181b;--text-secondary:#57534e;--text-tertiary:#a8a29e;--accent:#1d4ed8;--accent-hover:#1842c4;--accent-light:#eef4fe;--accent-border:#bfdafd;--success-bg:#ecfdf5;--success-text:#047857;--warning-bg:#fef3c7;--warning-text:#92400e;--warning-border:#fde68a;--danger-bg:#fef2f2;--danger-text:#b91c1c;--danger-border:#fecaca;--radius-sm:6px;--radius-md:8px;--radius-lg:12px;--shadow-sm:0 1px 2px #0000000a;--shadow-md:0 4px 16px #00000014;--shadow-lg:0 20px 50px #0000002e}*{box-sizing:border-box;margin:0;padding:0}html,body{background:var(--bg);color:var(--text-primary);-webkit-font-smoothing:antialiased;min-height:100vh;font-family:Geist,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px;line-height:1.5}button,input,select{font-family:inherit}a{color:inherit;text-decoration:none}.muted{color:var(--text-secondary)}.tertiary{color:var(--text-tertiary)}.small{font-size:12px}.accent{color:var(--accent);font-weight:500}.text-right{text-align:right}.hidden{display:none!important}.topbar{background:var(--surface);border-bottom:1px solid var(--border);align-items:center;height:56px;padding:0 24px;display:flex}.brand{align-items:center;gap:10px;margin-right:40px;display:flex}.logo{background:var(--accent);border-radius:var(--radius-sm);color:#fff;justify-content:center;align-items:center;width:28px;height:28px;display:flex}.brand-name{letter-spacing:-.01em;font-size:15px;font-weight:500}.role-badge{background:var(--surface-muted);color:var(--text-secondary);letter-spacing:.05em;border-radius:4px;margin-left:6px;padding:3px 7px;font-size:10px;font-weight:500}.tabs{align-items:stretch;gap:2px;height:100%;display:flex}.tab{color:var(--text-secondary);cursor:pointer;border-bottom:2px solid #0000;align-items:center;margin-bottom:-1px;padding:0 16px;font-size:13px;text-decoration:none;transition:color .15s;display:flex}.tab:hover{color:var(--text-primary)}.tab.active{color:var(--text-primary);border-bottom-color:var(--accent);font-weight:500}.spacer{flex:1}.user-menu{align-items:center;gap:10px;display:flex}.user-avatar{background:var(--accent-light);width:32px;height:32px;color:var(--accent);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;font-size:12px;font-weight:500;display:flex}.user-name{color:var(--text-secondary);font-size:13px}.subheader{background:var(--surface);border-bottom:1px solid var(--border);justify-content:space-between;align-items:flex-end;gap:16px;padding:20px 24px;display:flex}.period-label{color:var(--text-tertiary);letter-spacing:.06em;margin-bottom:4px;font-size:11px}.period-title{letter-spacing:-.01em;font-size:20px;font-weight:500}.breadcrumb{color:var(--text-secondary);padding:12px 24px 0;font-size:12px}.breadcrumb a{color:var(--accent)}.breadcrumb .sep{color:var(--text-tertiary);margin:0 6px}.btn-primary,.btn-ghost,.btn-danger{border-radius:var(--radius-md);cursor:pointer;border:1px solid #0000;align-items:center;gap:7px;padding:9px 16px;font-size:13px;font-weight:500;transition:all .15s;display:inline-flex}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-primary:disabled{background:var(--border-strong);color:var(--text-tertiary);cursor:not-allowed}.btn-ghost{color:var(--text-secondary);border-color:var(--border);background:0 0}.btn-ghost:hover{background:var(--surface-muted);color:var(--text-primary)}.btn-danger{background:var(--danger-bg);color:var(--danger-text);border-color:var(--danger-border)}.btn-danger:hover{background:#fee2e2}.icon-btn{border-radius:var(--radius-sm);width:32px;height:32px;color:var(--text-secondary);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;transition:background .15s;display:inline-flex}.icon-btn:hover{background:var(--surface-muted);color:var(--text-primary)}.container{max-width:1080px;margin:0 auto;padding:28px 24px 48px}.container.wide{max-width:1400px}.progress-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin-bottom:16px;padding:22px 24px}.progress-top{justify-content:space-between;align-items:flex-end;gap:16px;margin-bottom:18px;display:flex}.big-number{letter-spacing:-.02em;font-feature-settings:"tnum";margin-top:4px;font-size:32px;font-weight:500}.big-number .unit{color:var(--text-tertiary);font-size:14px;font-weight:400}.med-number{font-feature-settings:"tnum";margin-top:4px;font-size:16px}.bar{background:var(--surface-tertiary);border-radius:999px;height:8px;margin-bottom:10px;overflow:hidden}.bar.thin{height:5px;margin-bottom:0}.bar-fill{background:var(--accent);border-radius:999px;width:0%;height:100%;transition:width .5s cubic-bezier(.4,0,.2,1)}.bar-fill.warning{background:#d97706}.bar-fill.success{background:#16a34a}.bar-labels{color:var(--text-tertiary);font-feature-settings:"tnum";justify-content:space-between;font-size:11px;display:flex}.stats{grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:24px;display:grid}.stats.four{grid-template-columns:repeat(4,1fr)}.stat{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:14px 16px}.stat-value{font-feature-settings:"tnum";margin-top:4px;font-size:20px;font-weight:500}.tickets-header{justify-content:space-between;align-items:baseline;margin-bottom:12px;display:flex}.tickets-header h2{font-size:16px;font-weight:500}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.tickets-table{border-collapse:collapse;width:100%}.tickets-table thead{background:var(--surface-muted);border-bottom:1px solid var(--border)}.tickets-table th{text-align:left;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;padding:11px 16px;font-size:11px;font-weight:500}.tickets-table th.col-thumb{width:60px;padding-right:0}.tickets-table th.col-date{width:90px}.tickets-table th.col-eur{text-align:right;width:80px}.tickets-table th.col-cop{text-align:right;width:130px}.tickets-table td{border-top:1px solid var(--border);vertical-align:middle;padding:12px 16px;font-size:13px}.tickets-table tbody tr:first-child td{border-top:none}.tickets-table td.col-eur,.tickets-table td.col-cop{text-align:right;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.tickets-table td.col-cop{font-weight:500}.thumb{border:1px solid var(--border);background:#fff;border-radius:3px;width:36px;height:44px;padding:4px 3px;display:inline-block;overflow:hidden}.thumb img{object-fit:cover;border-radius:2px;width:100%;height:100%}.thumb.empty{background:var(--surface-muted)}.merchant-cell{display:inline}.category-tag{color:var(--text-tertiary);margin-left:6px;font-size:12px}.empty-state{text-align:center;color:var(--text-tertiary);padding:48px 24px}.empty-state p{margin:4px 0}.empty-icon{color:var(--border-strong);margin-bottom:12px}.modal-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:100;background:#0f0f128c;justify-content:center;align-items:center;padding:16px;animation:.18s ease-out fade-in;display:flex;position:fixed;inset:0}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--surface);border-radius:var(--radius-lg);width:100%;max-width:520px;box-shadow:var(--shadow-lg);flex-direction:column;max-height:92vh;animation:.22s cubic-bezier(.4,0,.2,1) modal-in;display:flex;overflow:hidden}@keyframes modal-in{0%{opacity:0;transform:translateY(8px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.modal-header h3{font-size:16px;font-weight:500}.modal-body{flex:1;padding:20px;overflow-y:auto}.modal-footer{border-top:1px solid var(--border);background:var(--surface-muted);justify-content:flex-end;gap:8px;padding:14px 20px;display:flex}.dropzone{border:2px dashed var(--border-strong);border-radius:var(--radius-md);cursor:pointer;text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:6px;padding:36px 24px;transition:all .15s;display:flex}.dropzone:hover,.dropzone.dragover{border-color:var(--accent);background:var(--accent-light)}.dropzone-icon{color:var(--text-tertiary);margin-bottom:6px}.dropzone-text{font-weight:500}.preview-wrap{text-align:center;margin-bottom:16px}.preview-wrap img{border-radius:var(--radius-md);border:1px solid var(--border);max-width:100%;max-height:260px}.preview-wrap.small img{max-height:160px}.processing-state{text-align:center;padding:16px 0 4px}.spinner{border:3px solid var(--surface-tertiary);border-top-color:var(--accent);border-radius:50%;width:32px;height:32px;margin:0 auto 12px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.banner{border-radius:var(--radius-md);align-items:flex-start;gap:8px;margin-bottom:14px;padding:10px 12px;font-size:13px;display:flex}.banner.warning{background:var(--warning-bg);color:var(--warning-text);border:1px solid var(--warning-border)}.banner.danger{background:var(--danger-bg);color:var(--danger-text);border:1px solid var(--danger-border)}.banner.success{background:var(--success-bg);color:var(--success-text);border:1px solid #a7f3d0}.banner svg{flex-shrink:0;margin-top:1px}.form{flex-direction:column;gap:12px;display:flex}.form-row{flex-direction:column;gap:5px;display:flex}.form-row.two-col{flex-direction:row;gap:10px}.form-row.two-col>div{flex-direction:column;flex:1;gap:5px;display:flex}.form-row label{color:var(--text-secondary);font-size:12px;font-weight:500}.form-row input,.form-row select{border:1px solid var(--border-strong);border-radius:var(--radius-sm);background:var(--surface);color:var(--text-primary);padding:9px 11px;font-size:14px;transition:border-color .15s,box-shadow .15s}.form-row input:focus,.form-row select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light);outline:none}.form-row input[readonly]{background:var(--surface-muted);color:var(--text-secondary)}.rate-note{color:var(--text-secondary);margin-top:4px;font-size:12px}.login-shell{background:linear-gradient(180deg, var(--bg), var(--surface-muted));justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:400px;box-shadow:var(--shadow-md);padding:32px}.login-brand{align-items:center;gap:12px;margin-bottom:24px;display:flex}.login-brand .logo{width:36px;height:36px}.login-brand .brand-name{font-size:18px}.login-tabs{border-bottom:1px solid var(--border);gap:4px;margin-bottom:20px;display:flex}.login-tabs button{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:10px 16px;font-size:13px;font-weight:500}.login-tabs button.active{color:var(--text-primary);border-bottom-color:var(--accent)}.login-form{flex-direction:column;gap:14px;display:flex}.login-form .btn-primary{justify-content:center;width:100%;padding:11px}.login-note{text-align:center;color:var(--text-tertiary);margin-top:14px;font-size:12px}.admin-table{border-collapse:collapse;width:100%}.admin-table thead{background:var(--surface-muted);border-bottom:1px solid var(--border)}.admin-table th{text-align:left;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;padding:10px 20px;font-size:11px;font-weight:500}.admin-table td{border-top:1px solid var(--border);vertical-align:middle;padding:14px 20px;font-size:13px}.admin-table tbody tr{cursor:pointer;transition:background .12s}.admin-table tbody tr:hover{background:var(--surface-muted)}.empleado-cell{align-items:center;gap:10px;min-width:0;display:flex}.empleado-cell .avatar{background:var(--accent-light);width:30px;height:30px;color:var(--accent);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:11px;font-weight:500;display:flex}.empleado-cell .info{min-width:0}.empleado-cell .name{font-size:13px;font-weight:500}.empleado-cell .sub{color:var(--text-tertiary);font-size:11px}.progress-cell{align-items:center;gap:8px;min-width:140px;display:flex}.progress-cell .bar{flex:1;height:5px;margin:0}.progress-cell .pct{color:var(--text-secondary);text-align:right;font-variant-numeric:tabular-nums;min-width:36px;font-size:11px}.progress-cell .pct.warning{color:#d97706;font-weight:500}.pill{white-space:nowrap;border-radius:999px;padding:2px 8px;font-size:11px;font-weight:500;display:inline-block}.pill.success{background:var(--success-bg);color:var(--success-text)}.pill.open{background:var(--accent-light);color:var(--accent)}.pill.muted{background:var(--surface-muted);color:var(--text-secondary)}.toolbar{border-bottom:1px solid var(--border);background:var(--surface);align-items:center;gap:10px;padding:14px 20px;display:flex}.toolbar .search{flex:1;position:relative}.toolbar .search input{border:1px solid var(--border-strong);border-radius:var(--radius-md);background:var(--surface);width:100%;height:34px;padding:0 12px 0 34px;font-size:13px}.toolbar .search svg{color:var(--text-tertiary);position:absolute;top:50%;left:11px;transform:translateY(-50%)}.period-tabs{border-bottom:1px solid var(--border);background:var(--surface);gap:4px;padding:0 20px;display:flex}.period-tabs .pt{color:var(--text-secondary);cursor:pointer;border-bottom:2px solid #0000;margin-bottom:-1px;padding:9px 14px;font-size:13px}.period-tabs .pt.active{color:var(--text-primary);border-bottom-color:var(--accent);font-weight:500}.period-tabs .pt .dot{color:var(--success-text);margin-left:6px;font-size:11px}.detail-strip{background:var(--surface);border-bottom:1px solid var(--border);grid-template-columns:repeat(4,1fr);display:grid}.detail-strip .item{border-right:1px solid var(--border);padding:14px 20px}.detail-strip .item:last-child{border-right:none}.detail-strip .label{color:var(--text-secondary);margin-bottom:3px;font-size:11px}.detail-strip .value{font-variant-numeric:tabular-nums;font-size:16px;font-weight:500}@media (max-width:640px){.topbar{height:52px;padding:0 16px}.brand{margin-right:16px}.tabs{gap:0}.tab{padding:0 10px;font-size:12px}.user-name{display:none}.subheader{flex-wrap:wrap;padding:16px}.container{padding:18px 14px 40px}.progress-card{padding:16px}.big-number{font-size:24px}.stats,.stats.four,.detail-strip{grid-template-columns:1fr 1fr}.detail-strip .item:nth-child(2){border-right:none}.tickets-table th.col-eur,.tickets-table td.col-eur{display:none}.admin-table th,.admin-table td{padding:12px 14px}.modal-content{margin:0}}.user-menu-wrap{position:relative}.user-pill{cursor:pointer;color:var(--text-secondary);background:0 0;border:1px solid #0000;border-radius:999px;align-items:center;gap:8px;padding:4px 8px 4px 12px;transition:all .15s;display:inline-flex}.user-pill:hover{background:var(--surface-muted);border-color:var(--border)}.user-pill .user-name{font-size:13px}.user-pill svg{color:var(--text-tertiary)}.user-avatar.lg{width:38px;height:38px;font-size:14px}.user-dropdown{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);min-width:240px;box-shadow:var(--shadow-md);z-index:50;animation:.15s ease-out dropdown-in;position:absolute;top:calc(100% + 6px);right:0;overflow:hidden}@keyframes dropdown-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.user-dropdown-header{align-items:center;gap:10px;padding:14px 14px 12px;display:flex}.user-dropdown-header .info{flex:1;min-width:0}.user-dropdown-header .name{font-size:13px;font-weight:500}.user-dropdown-header .sub{color:var(--text-tertiary);text-overflow:ellipsis;white-space:nowrap;font-size:11px;overflow:hidden}.user-dropdown-divider{background:var(--border);height:1px}.user-dropdown-item{width:100%;color:var(--text-primary);text-align:left;cursor:pointer;background:0 0;border:none;align-items:center;gap:10px;padding:10px 14px;font-size:13px;transition:background .12s;display:flex}.user-dropdown-item svg{color:var(--text-tertiary);flex-shrink:0}.user-dropdown-item:hover{background:var(--surface-muted)}.user-dropdown-item.danger,.user-dropdown-item.danger svg{color:var(--danger-text)}.user-dropdown-item.danger:hover{background:var(--danger-bg)}.profile-section{border-top:1px solid var(--border);margin-top:6px;padding-top:12px}.credenciales-block{background:var(--surface-muted);border:1px solid var(--border);border-radius:var(--radius-md);margin-top:14px;padding:14px 16px}.cred-row{border-bottom:1px dashed var(--border);justify-content:space-between;align-items:center;padding:6px 0;display:flex}.cred-row:last-child{border-bottom:none}.cred-label{color:var(--text-secondary);font-size:12px;font-weight:500}.cred-value{color:var(--text-primary);word-break:break-all;text-align:right;font-size:13px}.cred-value.mono{background:var(--surface);border:1px solid var(--border);border-radius:4px;padding:3px 7px;font-family:Geist Mono,ui-monospace,Menlo,monospace;font-size:13px}.row-menu-wrap{display:inline-block;position:relative}.row-menu-backdrop{z-index:49;position:fixed;inset:0}.row-menu{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);min-width:200px;box-shadow:var(--shadow-md);z-index:50;margin-top:4px;animation:.12s ease-out dropdown-in;position:absolute;top:100%;right:0;overflow:hidden}.row-menu-item{width:100%;color:var(--text-primary);text-align:left;cursor:pointer;background:0 0;border:none;align-items:center;gap:10px;padding:9px 12px;font-size:13px;transition:background .12s;display:flex}.row-menu-item svg{color:var(--text-tertiary);flex-shrink:0}.row-menu-item:hover:not(:disabled){background:var(--surface-muted)}.row-menu-item:disabled{opacity:.4;cursor:not-allowed}.row-menu-item.danger,.row-menu-item.danger svg{color:var(--danger-text)}.row-menu-item.danger:hover:not(:disabled){background:var(--danger-bg)}.row-menu-divider{background:var(--border);height:1px;margin:4px 0}.no-hover:hover{background:var(--surface)!important;cursor:default!important}.confirm-icon{color:var(--danger-text);justify-content:center;margin:4px 0 14px;display:flex}.pill.warning{background:var(--warning-bg);color:var(--warning-text)}
