:root{--primary: #1a3a5c;--accent: #e67e22;--light: #f4f6f9;--white: #ffffff;--border: #dde3ec;--green: #27ae60;--red: #e74c3c;--blue: #2980b9;--gray: #7f8c8d;--orange: #e67e22;--red-light: #fdedec;--yellow-light: #fef5e7;--green-light: #eafaf1;--sidebar-w: 220px}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Segoe UI,sans-serif;background:var(--light);color:#2c3e50;min-height:100vh}#root{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-w);background:var(--primary);color:#fff;display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100}.logo{padding:16px 14px 14px;border-bottom:1px solid rgba(255,255,255,.15);line-height:1.3}.sidebar-logo-img{width:100%;max-width:180px;display:block}.sidebar nav{flex:1;padding:14px 0;overflow-y:auto}.sidebar nav a{display:flex;align-items:center;gap:10px;padding:11px 20px;color:#ffffffc7;text-decoration:none;font-size:.88rem;cursor:pointer;transition:background .2s}.sidebar nav a:hover,.sidebar nav a.active{background:#ffffff1f;color:#fff}.sidebar nav .ico{font-size:1.1rem;width:20px;text-align:center}.sidebar .section-label{font-size:.68rem;text-transform:uppercase;letter-spacing:.08em;color:#fff6;padding:14px 20px 4px}.sidebar-footer{padding:14px 20px;font-size:.75rem;opacity:.5;border-top:1px solid rgba(255,255,255,.1)}.main-content{margin-left:var(--sidebar-w);flex:1;display:flex;flex-direction:column}.topbar{background:var(--white);border-bottom:1px solid var(--border);padding:0 28px;height:58px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:50}.topbar-left{display:flex;align-items:center;gap:14px}.topbar-left h1{font-size:1rem;font-weight:600}.topbar-right{display:flex;align-items:center;gap:12px}.content{padding:24px 28px;flex:1}.btn{padding:7px 16px;border-radius:6px;border:none;font-size:.82rem;cursor:pointer;font-weight:600;transition:opacity .2s}.btn:hover{opacity:.85}.btn-primary{background:var(--accent);color:#fff}.btn-outline{background:transparent;border:1px solid var(--border);color:#555}.btn-secondary{background:var(--light);border:1px solid var(--border);color:#555}.btn-danger{background:var(--red);color:#fff}.btn-sm{padding:4px 10px;font-size:.75rem}.chantier-select,select{border:1px solid var(--border);border-radius:6px;padding:5px 10px;font-size:.85rem;background:var(--light);cursor:pointer}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.kpi-card{background:var(--white);border-radius:10px;padding:18px 20px;border-left:4px solid var(--accent);box-shadow:0 1px 4px #0000000f}.kpi-card.green{border-color:var(--green)}.kpi-card.blue{border-color:var(--blue)}.kpi-card.red{border-color:var(--red)}.kpi-card.orange{border-color:var(--orange)}.kpi-label{font-size:.75rem;color:var(--gray);text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px}.kpi-value{font-size:1.55rem;font-weight:700}.kpi-sub{font-size:.78rem;color:var(--gray);margin-top:4px}.kpi-delta{font-size:.8rem;font-weight:600;margin-top:4px}.kpi-delta.up{color:var(--green)}.kpi-delta.down{color:var(--red)}.row{display:grid;gap:20px;margin-bottom:20px}.row-2{grid-template-columns:1fr 1fr}.row-3{grid-template-columns:2fr 1fr}.card{background:var(--white);border-radius:10px;padding:20px 22px;box-shadow:0 1px 4px #0000000f}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.card-title{font-size:.92rem;font-weight:700}.card-action{font-size:.78rem;color:var(--accent);cursor:pointer;text-decoration:underline}table{width:100%;border-collapse:collapse;font-size:.82rem}th{background:var(--light);color:var(--gray);text-align:left;padding:8px 10px;font-size:.75rem;text-transform:uppercase;letter-spacing:.04em}td{padding:9px 10px;border-bottom:1px solid var(--border);vertical-align:middle}tr:last-child td{border-bottom:none}tr:hover td{background:#fafbfd}.tag{display:inline-block;padding:2px 9px;border-radius:20px;font-size:.72rem;font-weight:600}.tag-green{background:#eafaf1;color:var(--green)}.tag-orange{background:#fef5e7;color:var(--accent)}.tag-red{background:#fdedec;color:var(--red)}.tag-blue{background:#eaf4fb;color:var(--blue)}.tag-gray{background:#f2f3f4;color:var(--gray)}.progress-wrap{background:#ecf0f1;border-radius:20px;height:8px;overflow:hidden}.progress-bar{height:100%;border-radius:20px;transition:width .3s}.bar-green{background:var(--green)}.bar-orange{background:var(--accent)}.bar-red{background:var(--red)}.bar-blue{background:var(--blue)}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.form-group{display:flex;flex-direction:column;gap:5px}.form-group.full{grid-column:1 / -1}.form-group label{font-size:.78rem;color:var(--gray);font-weight:600}.form-group input,.form-group select,.form-group textarea{border:1px solid var(--border);border-radius:6px;padding:7px 10px;font-size:.85rem;background:var(--light);font-family:inherit}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:2px solid var(--accent);border-color:transparent}.modal-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:200;align-items:center;justify-content:center}.modal-overlay.open{display:flex}.modal{background:var(--white);border-radius:12px;padding:28px 30px;width:600px;max-width:95vw;max-height:90vh;overflow-y:auto;box-shadow:0 8px 32px #0000002e}.modal h2{font-size:1rem;margin-bottom:18px}.modal-footer{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}.alert-card{padding:10px;border-radius:8px;border-left:3px solid;font-size:.82rem;margin-bottom:8px}.alert-danger{background:#fdedec;border-color:var(--red)}.alert-warning{background:#fef5e7;border-color:var(--accent)}.alert-info{background:#eaf4fb;border-color:var(--blue)}.alert-success{background:#eafaf1;border-color:var(--green)}.chart-wrap{position:relative;height:220px}.treso-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:20px}.treso-box{background:var(--white);border-radius:10px;padding:16px 18px;text-align:center;box-shadow:0 1px 4px #0000000f}.treso-box .amount{font-size:1.4rem;font-weight:700;margin:6px 0 4px}.treso-box .lbl{font-size:.73rem;color:var(--gray);text-transform:uppercase;letter-spacing:.04em}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--primary);width:100%}.login-card{background:var(--white);border-radius:12px;padding:40px;width:420px;max-width:95vw;box-shadow:0 8px 32px #0003;text-align:center}.login-logo{display:block;margin:0 auto 12px;width:300px;max-width:95%}.login-card .subtitle{color:var(--gray);font-size:.85rem;text-align:center;margin-bottom:24px}.login-card .form-group{margin-bottom:16px;text-align:left}.login-card .btn{width:100%;padding:10px;font-size:.9rem}.login-error{color:var(--red);font-size:.82rem;text-align:center;margin-bottom:12px}.login-qualibat{display:flex;align-items:center;justify-content:center;gap:10px;margin-top:24px;padding-top:18px;border-top:1px solid var(--border)}.login-qualibat img{height:40px;border-radius:4px}.login-qualibat span{font-size:.72rem;color:var(--gray);text-align:left;line-height:1.3}.hamburger-btn{display:none;flex-direction:column;justify-content:center;gap:5px;background:none;border:none;cursor:pointer;padding:4px 6px;border-radius:6px}.hamburger-btn span{display:block;width:22px;height:2px;background:#2c3e50;border-radius:2px}.hamburger-btn:hover{background:var(--light)}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:99}.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}.topbar-user{font-size:.82rem;color:var(--gray)}@media(max-width:1100px){.kpi-grid{grid-template-columns:repeat(3,1fr)!important}}@media(max-width:900px){.kpi-grid{grid-template-columns:1fr 1fr!important}.row-2,.row-3,.treso-summary,.form-grid{grid-template-columns:1fr}}@media(max-width:768px){.sidebar{transform:translate(-100%);transition:transform .25s ease;z-index:100}.sidebar.open{transform:translate(0)}.sidebar-overlay{display:block}.main-content{margin-left:0}.hamburger-btn{display:flex}.topbar{padding:0 14px}}@media(max-width:600px){.kpi-grid{grid-template-columns:1fr 1fr;gap:10px;margin-bottom:16px}.kpi-card{padding:12px 14px}.kpi-value{font-size:1.15rem}.kpi-label{font-size:.68rem}.content{padding:14px 10px}.topbar-user{display:none}.topbar{height:48px}.topbar-left h1{font-size:.88rem}.modal{padding:20px 16px;width:100%;max-width:100vw;border-radius:12px 12px 0 0}.modal-overlay{align-items:flex-end}table{min-width:520px;font-size:.78rem}th{padding:6px 8px;font-size:.7rem}td{padding:7px 8px}.card{padding:12px 10px;margin-bottom:14px}.card-header{flex-wrap:wrap;gap:8px}.card-title{font-size:.85rem}.form-grid{grid-template-columns:1fr;gap:10px}.form-group.full{grid-column:1}.btn{padding:6px 12px;font-size:.78rem}.btn-primary{padding:8px 14px}.treso-box{padding:12px 14px}.treso-box .amount{font-size:1.15rem}.chart-wrap{height:180px!important}.tag{font-size:.68rem;padding:2px 7px}}@media(max-width:440px){.kpi-grid{grid-template-columns:1fr;gap:8px}.kpi-card{padding:10px 12px}.kpi-value{font-size:1.1rem}.content{padding:10px 8px}.card{padding:10px 8px;border-radius:8px}.topbar{padding:0 10px}.btn{font-size:.75rem}}@keyframes toast-in{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:translate(0)}}th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}th.sortable:hover{color:var(--blue)}.guide-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:300;background:#0000008c;animation:guide-fade-in .3s ease}.guide-spotlight{border-radius:8px;box-shadow:0 0 0 9999px #0000008c;background:transparent;pointer-events:none}.guide-tooltip{position:fixed;z-index:302;background:var(--white);border-radius:12px;padding:20px 22px;width:340px;max-width:90vw;box-shadow:0 8px 32px #00000038;animation:guide-fade-in .25s ease}.guide-tooltip-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.guide-tooltip-title{font-size:.92rem;font-weight:700;color:var(--primary)}.guide-tooltip-counter{font-size:.72rem;background:var(--light);color:var(--gray);padding:2px 8px;border-radius:10px;font-weight:600}.guide-tooltip-desc{font-size:.82rem;color:#555;line-height:1.5;margin-bottom:14px}.guide-tooltip-footer{display:flex;justify-content:space-between;align-items:center}.guide-tooltip-nav{display:flex;gap:6px}.guide-btn-help{width:30px;height:30px;border-radius:50%;background:var(--accent);color:#fff;border:none;font-size:.9rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:opacity .2s}.guide-btn-help:hover{opacity:.85}@media(max-width:768px){.guide-tooltip{width:calc(100vw - 24px)!important;max-width:100vw}.guide-btn-help{width:28px;height:28px;font-size:.8rem}}@keyframes guide-fade-in{0%{opacity:0}to{opacity:1}}.guide-sidebar-link{display:flex;align-items:center;gap:8px;padding:7px 20px;color:#ffffffa6;text-decoration:none;font-size:.82rem;cursor:pointer;transition:background .2s,color .2s}.guide-sidebar-link:hover{background:#ffffff14;color:#fff}.guide-sidebar-link.active{background:#ffffff24;color:#fff;font-weight:600}.guide-sidebar-link .ico{font-size:.75rem;width:16px;text-align:center}.guide-content{padding:32px 40px;max-width:900px}.guide-content h2{margin-top:48px;padding-top:20px;border-top:1px solid var(--border);font-size:1.15rem;color:var(--primary)}.guide-content h2:first-of-type{margin-top:0;border-top:none;padding-top:0}.guide-content h3{font-size:.95rem;margin-top:24px;margin-bottom:8px;color:#34495e}.guide-content p{font-size:.85rem;line-height:1.65;margin:8px 0;color:#444}.guide-content ul,.guide-content ol{font-size:.85rem;line-height:1.65;margin:8px 0 8px 20px;color:#444}.guide-content table{margin:12px 0}.guide-formula{background:#eaf2fb;border-left:4px solid var(--blue);border-radius:8px;padding:16px 20px;font-family:Courier New,monospace;margin:16px 0;font-size:.84rem;line-height:1.6;color:#2c3e50}.guide-tip{background:var(--green-light);border-left:4px solid var(--green);border-radius:8px;padding:12px 16px;margin:12px 0;font-size:.85rem;line-height:1.5}.guide-tip strong{color:var(--green)}.guide-warning{background:var(--yellow-light);border-left:4px solid var(--orange);border-radius:8px;padding:12px 16px;margin:12px 0;font-size:.85rem;line-height:1.5}.guide-warning strong{color:var(--orange)}.guide-step{display:flex;gap:12px;align-items:flex-start;margin:10px 0}.guide-step-num{width:28px;height:28px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.8rem;flex-shrink:0}.guide-step-text{font-size:.85rem;line-height:1.5;padding-top:3px}.guide-step-text strong{color:var(--primary)}.guide-layers{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin:20px 0}.guide-layer{background:var(--white);border:1px solid var(--border);border-radius:8px;padding:14px;text-align:center;font-size:.82rem}.guide-layer .layer-num{width:24px;height:24px;border-radius:50%;background:var(--accent);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-weight:700;font-size:.72rem;margin-bottom:6px}.guide-layer .layer-title{font-weight:700;font-size:.82rem;margin-bottom:4px}.guide-layer .layer-desc{font-size:.75rem;color:var(--gray)}.guide-print-btn{position:fixed;bottom:24px;right:24px;z-index:50;background:var(--primary);color:#fff;border:none;border-radius:50%;width:48px;height:48px;font-size:1.2rem;cursor:pointer;box-shadow:0 4px 12px #0003;display:flex;align-items:center;justify-content:center;transition:opacity .2s}.guide-print-btn:hover{opacity:.85}.guide-roles-table{width:100%;border-collapse:collapse;margin:12px 0;font-size:.82rem}.guide-roles-table th{background:var(--primary);color:#fff;padding:8px 12px;text-align:left}.guide-roles-table td{padding:8px 12px;border-bottom:1px solid var(--border)}.guide-roles-table tr:nth-child(2n) td{background:#fafbfd}.guide-faq-item{margin:16px 0}.guide-faq-q{font-weight:700;font-size:.88rem;color:var(--primary);margin-bottom:4px}.guide-faq-a{font-size:.84rem;color:#555;line-height:1.55}.consent-banner{position:fixed;bottom:0;left:0;right:0;z-index:250;background:var(--white);border-top:2px solid var(--border);box-shadow:0 -4px 20px #0000001a;padding:20px 28px;animation:consent-slide-up .3s ease}.consent-banner-inner{max-width:900px;margin:0 auto}.consent-banner h3{font-size:.95rem;margin-bottom:8px;color:var(--primary)}.consent-banner p{font-size:.82rem;color:#555;line-height:1.55;margin-bottom:14px}.consent-banner-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.consent-banner-links{font-size:.75rem;margin-top:10px}.consent-banner-links a{color:var(--blue);text-decoration:underline;margin-right:14px}.consent-detail{margin:14px 0}.consent-category{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;background:var(--light);border:1px solid var(--border);border-radius:6px;margin-bottom:6px;font-size:.82rem}.consent-category input{width:16px;height:16px;accent-color:var(--accent);margin-top:2px;flex-shrink:0}.consent-category.locked{opacity:.7}.legal-page{min-height:100vh;background:var(--light);padding:40px 20px}.legal-content{max-width:800px;margin:0 auto;background:var(--white);border-radius:12px;padding:40px;box-shadow:0 1px 4px #0000000f}.legal-content h1{font-size:1.3rem;color:var(--primary);margin-bottom:24px}.legal-content h2{font-size:1rem;color:var(--primary);margin:24px 0 8px}.legal-content h3{font-size:.9rem;color:#34495e;margin:16px 0 6px}.legal-content p,.legal-content li{font-size:.85rem;line-height:1.65;color:#444}.legal-content ul{margin:8px 0 8px 20px}.legal-content table{width:100%;border-collapse:collapse;margin:12px 0;font-size:.82rem}.legal-content th{background:var(--light);padding:8px 10px;text-align:left;font-size:.75rem;text-transform:uppercase;color:var(--gray)}.legal-content td{padding:8px 10px;border-bottom:1px solid var(--border)}.legal-content code{background:var(--light);padding:1px 6px;border-radius:4px;font-size:.8rem}.legal-back{display:inline-block;margin-bottom:20px;color:var(--accent);text-decoration:none;font-size:.85rem}.legal-back:hover{text-decoration:underline}.login-legal-links{margin-top:14px;display:flex;justify-content:center;gap:16px;font-size:.72rem}.login-legal-links a{color:var(--gray);text-decoration:none}.login-legal-links a:hover{color:var(--blue);text-decoration:underline}@keyframes consent-slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}@media(max-width:600px){.consent-banner{padding:14px 12px}.consent-banner-actions{flex-direction:column;align-items:stretch}.consent-banner-actions .btn{width:100%;text-align:center}.legal-content{padding:20px 16px}.legal-content h1{font-size:1.1rem}}@media print{.sidebar,.topbar,.guide-print-btn,.consent-banner{display:none!important}.guide-content{max-width:100%;padding:0;margin:0}.guide-content h2{break-before:page}.main-content{margin-left:0!important}}@media(max-width:900px){.guide-content{padding:20px 16px}.guide-layers{grid-template-columns:1fr 1fr}}@media(max-width:600px){.guide-layers{grid-template-columns:1fr}.guide-content{padding:16px 10px}}
