:root{--blue-primary: #1c529d;--blue-dark: #1e3a5f;--blue-panel: #23518c;--blue-light: rgba(28, 82, 157, .07);--orange: #f39c12;--orange-dark: #e08e0b;--red: #ef4444;--green: #10b981;--amber: #f59e0b;--bg: #f0f4f8;--card: #ffffff;--border: #dbe4ef;--text: #334155;--text-soft: #64748b;--text-muted: #94a3b8;--shadow-sm: 0 2px 8px rgba(0,0,0,.06);--shadow-md: 0 8px 24px rgba(0,0,0,.1);--shadow-lg: 0 24px 48px rgba(0,0,0,.16);--radius: 16px;--radius-sm: 10px;--radius-xs: 6px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}html{scroll-behavior:smooth}body{font-family:Inter,sans-serif;background:var(--bg);color:var(--text);line-height:1.5;-webkit-font-smoothing:antialiased}.hidden{display:none!important}.login-screen{min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:24px;position:relative;background:linear-gradient(145deg,#0f2744,#1c529d,#2968bd)}.login-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 30% 50%,rgba(243,156,18,.15) 0%,transparent 60%),radial-gradient(ellipse at 80% 20%,rgba(255,255,255,.05) 0%,transparent 50%);pointer-events:none}.login-card{background:#fffffff7;border-radius:24px;padding:40px 32px 32px;width:100%;max-width:400px;box-shadow:var(--shadow-lg);position:relative;text-align:center;animation:slideUp .4s cubic-bezier(.16,1,.3,1)}@keyframes slideUp{0%{opacity:0;transform:translateY(32px)}to{opacity:1;transform:translateY(0)}}.login-logo-wrap{width:110px;height:110px;background:transparent;display:flex;align-items:center;justify-content:center;margin:0 auto 20px}.login-logo{width:100px;height:100px;object-fit:contain}.login-brand{font-size:26px;font-weight:800;color:var(--blue-dark);letter-spacing:-.5px}.login-subtitle{font-size:14px;color:var(--text-soft);margin:4px 0 28px}.login-form{text-align:left}.login-field label{font-size:13px;font-weight:600;color:var(--blue-primary);margin-bottom:8px;display:block}.pwd-wrap{position:relative;margin-bottom:12px}.pwd-wrap input{width:100%;padding:14px 48px 14px 16px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:15px;color:var(--text);font-family:inherit;transition:border-color .2s,box-shadow .2s;background:#fafbfd}.pwd-wrap input:focus{outline:none;border-color:var(--blue-primary);box-shadow:0 0 0 3px #1c529d1f}.pwd-toggle{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;font-size:18px;opacity:.5;transition:opacity .2s;padding:4px}.pwd-toggle:hover{opacity:.8}.login-error{color:var(--red);font-size:13px;font-weight:500;margin-bottom:14px;padding:10px 14px;background:#ef444414;border-radius:var(--radius-xs);animation:shake .4s ease}@keyframes shake{0%,to{transform:translate(0)}20%,60%{transform:translate(-6px)}40%,80%{transform:translate(6px)}}.btn-login{width:100%;padding:15px;background:linear-gradient(135deg,var(--blue-primary),var(--blue-dark));color:#fff;border:none;border-radius:var(--radius-sm);font-size:16px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;transition:opacity .2s,transform .1s;letter-spacing:.3px}.btn-login:hover{opacity:.92}.btn-login:active{transform:scale(.98)}.btn-login .arrow{font-size:18px;transition:transform .2s}.btn-login:hover .arrow{transform:translate(4px)}.login-footer{text-align:center;font-size:12px;color:var(--text-muted);margin-top:24px}.app-container{max-width:600px;margin:0 auto;min-height:100vh;background:var(--bg);padding-bottom:140px}.main-header{background:linear-gradient(135deg,var(--blue-primary) 0%,#2968bd 100%);color:#fff;padding:20px 20px 28px;border-bottom-left-radius:24px;border-bottom-right-radius:24px;box-shadow:0 4px 20px #1c529d40}.header-content{display:flex;align-items:center;gap:14px}.logo{width:64px;height:64px;background:#fff;border-radius:14px;padding:5px;object-fit:contain;flex-shrink:0;box-shadow:0 4px 12px #00000026}.company-info{flex:1;min-width:0}.company-info h2{font-size:17px;font-weight:700;margin-bottom:2px}.company-info p{font-size:12px;opacity:.85;margin-bottom:6px}.partner-badge{display:inline-flex;align-items:center;background:#ffffff26;font-size:11px;padding:3px 10px;border-radius:20px;font-weight:600}.badge-icon{width:12px;height:12px;margin-right:5px;background:#fff;border-radius:50%;padding:1px}.header-actions{display:flex;flex-direction:column;gap:6px;flex-shrink:0}.hdr-btn{background:#ffffff26;border:1px solid rgba(255,255,255,.2);color:#fff;width:38px;height:38px;border-radius:10px;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:background .2s}.hdr-btn:hover{background:#ffffff40}.tab-nav{display:flex;background:var(--card);margin:-14px 20px 0;border-radius:var(--radius);box-shadow:var(--shadow-md);position:relative;z-index:5;padding:4px;gap:4px}.tab-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:12px 8px;border:none;background:none;border-radius:12px;cursor:pointer;font-size:13px;font-weight:600;color:var(--text-soft);transition:all .25s ease;font-family:inherit}.tab-btn .tab-icon{font-size:16px}.tab-btn.active{background:linear-gradient(135deg,var(--blue-primary),#2968bd);color:#fff;box-shadow:0 4px 12px #1c529d59}.tab-content{animation:fadeIn .25s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.title-banner{background:var(--orange);color:#fff;text-align:center;padding:7px 0;margin:16px 20px 0;border-radius:var(--radius-xs);box-shadow:0 3px 10px #f39c124d}.title-banner h2{font-size:12px;font-weight:700;letter-spacing:1.5px}.report-content{padding:16px 20px}.badge-container{margin-bottom:14px}.report-number-badge{background:var(--orange);color:#fff;padding:5px 16px;border-radius:20px;font-size:13px;font-weight:700;display:inline-block;box-shadow:0 2px 6px #f39c1259}.card{background:var(--card);border-radius:var(--radius);padding:20px;margin-bottom:16px;box-shadow:var(--shadow-sm);border:1px solid rgba(0,0,0,.04)}.section-header{display:flex;align-items:center;margin-bottom:16px}.section-title{font-size:11px;font-weight:700;color:var(--text-muted);letter-spacing:1.5px;white-space:nowrap}.section-divider{flex:1;height:1px;background:var(--border);border:none;margin-left:10px}.form-row{display:flex;gap:12px;margin-bottom:14px}.form-group{margin-bottom:14px}.form-group.half{flex:1;margin-bottom:0}.form-group:last-child{margin-bottom:0}label{display:block;font-size:12px;font-weight:600;color:var(--blue-primary);margin-bottom:6px;letter-spacing:.2px}input[type=text],input[type=tel],input[type=time],input[type=date],input[type=password],textarea{width:100%;padding:12px 14px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:15px;color:var(--text);background:#fafbfd;font-family:inherit;transition:border-color .2s,box-shadow .2s;-moz-appearance:none;appearance:none;-webkit-appearance:none}input:focus,textarea:focus{outline:none;border-color:var(--blue-primary);box-shadow:0 0 0 3px #1c529d1a;background:#fff}input::placeholder,textarea::placeholder{color:var(--text-muted);font-size:14px}textarea{resize:vertical;line-height:1.5}.total-hours-panel{background:linear-gradient(135deg,var(--blue-panel),var(--blue-primary));border-radius:var(--radius-sm);padding:14px 18px;color:#fff;display:flex;justify-content:space-between;align-items:center;margin:14px 0;box-shadow:0 4px 12px #1c529d33;position:relative}.total-hours-label{font-size:12px;font-weight:500;line-height:1.4}.total-hours-value{font-size:26px;font-weight:800}.total-hint{font-size:10px;opacity:.7;position:absolute;bottom:8px;right:18px}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:8px}.mt-2{margin-top:8px}.button-group{display:grid}.button-group.grid-2{grid-template-columns:1fr 1fr;gap:8px}.toggle-btn{display:block;cursor:pointer}.toggle-btn input{position:absolute;opacity:0;cursor:pointer}.toggle-btn span{display:flex;align-items:center;justify-content:center;padding:11px 8px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:13px;font-weight:500;color:var(--text);background:#fafbfd;transition:all .2s;gap:5px}.toggle-btn input:checked~span{border-color:var(--blue-primary);background:var(--blue-light);color:var(--blue-primary);font-weight:700;box-shadow:0 0 0 3px #1c529d14}.toggle-btn.toggle-alert input:checked~span{border-color:var(--amber);background:#f59e0b14;color:var(--amber)}.toggle-btn.toggle-danger input:checked~span{border-color:var(--red);background:#ef444414;color:var(--red)}.signature-card{margin-bottom:32px}.signature-container{border:1.5px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;background:#f9fbff}.signature-pad{width:100%;height:180px;touch-action:none;display:block}.signature-footer{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;border-top:1px solid var(--border);background:#fff}.btn-clear{background:none;border:1px solid var(--border);padding:6px 12px;border-radius:var(--radius-xs);font-size:12px;color:var(--text-soft);cursor:pointer;transition:all .2s;font-family:inherit}.btn-clear:hover{background:#f1f5f9}.signature-hint{font-size:11px;color:var(--text-muted)}.action-buttons-container{position:fixed;bottom:0;left:0;right:0;background:#f0f4f8f5;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);padding:14px 20px;display:flex;flex-direction:column;gap:10px;box-shadow:0 -4px 20px #00000012;z-index:20;max-width:600px;margin:0 auto}.post-save-actions{display:flex;gap:10px}.post-save-actions .btn{flex:1}.btn{width:100%;padding:15px;border:none;border-radius:var(--radius-sm);font-size:15px;font-weight:700;display:flex;justify-content:center;align-items:center;gap:8px;cursor:pointer;transition:transform .1s,opacity .2s;font-family:inherit;letter-spacing:.2px}.btn:active{transform:scale(.98)}.btn-save{background:linear-gradient(135deg,var(--blue-primary),#2968bd);color:#fff}.btn-pdf{background:var(--blue-dark);color:#fff}.btn-share{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.btn-secondary{background:#fff;color:var(--blue-primary);border:1.5px solid var(--border)}.archive-header{display:flex;align-items:center;gap:12px;padding:20px 20px 8px}.archive-page-title{font-size:18px;font-weight:800;color:var(--blue-dark);flex:1}.archive-count-badge{background:var(--blue-light);color:var(--blue-primary);font-size:12px;font-weight:700;padding:4px 12px;border-radius:20px}.archive-list{padding:8px 20px 20px;display:flex;flex-direction:column;gap:12px}.archive-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow-sm);transition:box-shadow .2s}.archive-card:hover{box-shadow:var(--shadow-md)}.archive-card-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:10px}.archive-num{font-size:15px;font-weight:800;color:var(--blue-primary)}.archive-date{font-size:12px;color:var(--text-muted);margin-top:2px}.archive-client{font-size:14px;font-weight:600;color:var(--text);margin-bottom:8px;margin-top:2px}.archive-badges{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:12px}.badge{font-size:11px;font-weight:600;padding:3px 10px;border-radius:20px}.badge-type{background:#1c529d17;color:var(--blue-primary)}.badge-ok{background:#10b9811a;color:#059669}.badge-todo{background:#f59e0b1a;color:#d97706}.badge-urgent{background:#ef44441a;color:var(--red)}.archive-card-actions{display:flex;gap:8px;border-top:1px solid var(--border);padding-top:12px}.archive-action-btn{flex:1;padding:9px 6px;border:1px solid var(--border);border-radius:var(--radius-xs);background:#fff;font-size:12px;font-weight:600;color:var(--text-soft);cursor:pointer;transition:all .2s;font-family:inherit;display:flex;align-items:center;justify-content:center;gap:4px}.archive-action-btn:hover{border-color:var(--blue-primary);color:var(--blue-primary);background:var(--blue-light)}.archive-action-btn.btn-del:hover{border-color:var(--red);color:var(--red);background:#ef444412}.archive-loading{display:flex;flex-direction:column;align-items:center;gap:12px;padding:48px 20px;color:var(--text-muted)}.spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--blue-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.archive-empty{text-align:center;padding:56px 20px;color:var(--text-muted)}.empty-icon{font-size:48px;margin-bottom:16px;opacity:.4}.archive-empty p{font-size:16px;font-weight:600;margin-bottom:6px;color:var(--text-soft)}.archive-empty span{font-size:13px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f27448c;display:flex;align-items:flex-end;justify-content:center;z-index:100;padding:16px;animation:fadeIn .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-card{background:#fff;border-radius:24px 24px 16px 16px;width:100%;max-width:520px;max-height:88vh;display:flex;flex-direction:column;animation:slideUp .3s cubic-bezier(.16,1,.3,1);overflow:hidden}.modal-preview-card{max-height:90vh}.modal-small{max-height:60vh}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 20px 16px;border-bottom:1px solid var(--border);flex-shrink:0}.modal-header h3{font-size:16px;font-weight:700;color:var(--blue-dark)}.modal-close{width:32px;height:32px;background:var(--bg);border:none;border-radius:8px;cursor:pointer;font-size:14px;color:var(--text-soft);display:flex;align-items:center;justify-content:center;transition:background .2s}.modal-close:hover{background:var(--border)}.modal-body{padding:20px;overflow-y:auto;flex:1}.preview-scroll{-webkit-overflow-scrolling:touch}.modal-footer{display:flex;gap:10px;padding:16px 20px;border-top:1px solid var(--border);flex-shrink:0}.modal-footer button{flex:1;padding:12px;border-radius:var(--radius-sm);font-size:14px;font-weight:600;cursor:pointer;font-family:inherit;border:none;transition:opacity .2s}.btn-modal-cancel{background:var(--bg);color:var(--text-soft);border:1px solid var(--border)!important}.btn-modal-confirm{background:linear-gradient(135deg,var(--blue-primary),var(--blue-dark));color:#fff}.btn-modal-pdf{background:var(--blue-dark);color:#fff}.btn-modal-share{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.btn-modal-danger{background:var(--red);color:#fff}.modal-footer button:hover{opacity:.88}.form-msg{padding:10px 14px;border-radius:var(--radius-xs);font-size:13px;font-weight:500;margin-top:4px}.form-error{background:#ef444414;color:var(--red)}.form-success{background:#10b9811a;color:#059669}.preview-section{margin-bottom:18px}.preview-section-title{font-size:10px;font-weight:700;color:var(--text-muted);letter-spacing:1.5px;text-transform:uppercase;margin-bottom:10px;padding-bottom:6px;border-bottom:1px solid var(--border)}.preview-row{display:flex;gap:4px;margin-bottom:6px;font-size:14px}.preview-label{font-weight:600;color:var(--text-soft);min-width:130px;flex-shrink:0}.preview-value{color:var(--text)}.preview-text-block{font-size:14px;color:var(--text);background:var(--bg);border-radius:var(--radius-xs);padding:10px 12px;margin-top:4px;line-height:1.5;white-space:pre-wrap}.preview-signature{border:1px dashed var(--border);border-radius:var(--radius-xs);overflow:hidden;background:#f9fbff;margin-top:8px;height:140px;display:flex;align-items:center;justify-content:center}.preview-signature img{width:100%;height:140px;object-fit:contain}.preview-signature-empty{color:var(--text-muted);font-size:13px}.toast{position:fixed;bottom:160px;left:50%;transform:translate(-50%);background:#1e293b;color:#fff;padding:12px 20px;border-radius:50px;font-size:14px;font-weight:500;z-index:200;white-space:nowrap;box-shadow:var(--shadow-md);animation:toastIn .3s ease}.toast.toast-success{background:#059669}.toast.toast-error{background:var(--red)}@keyframes toastIn{0%{opacity:0;transform:translate(-50%) translateY(12px)}to{opacity:1;transform:translate(-50%) translateY(0)}}#pdf-render-container{position:fixed;top:0;left:0;width:100%;height:0;overflow:hidden;z-index:-100;pointer-events:none}.pdf-template{background:#fff;width:794px;padding:30px;font-family:Inter,sans-serif;color:#1e293b;margin:0 auto}
