:root{--bg: #f4f6fa;--panel: #ffffff;--border: #e2e7ef;--text: #1f2733;--muted: #6b7686;--primary: #2563eb;--primary-dark: #1d4ed8;--accent: #dceefb;--shadow: 0 1px 3px rgba(20, 30, 50, .06), 0 1px 2px rgba(20, 30, 50, .04);--radius: 10px}*{box-sizing:border-box}body{margin:0;font-family:-apple-system,Segoe UI,Roboto,Inter,system-ui,sans-serif;background:var(--bg);color:var(--text);font-size:14px}.centered{min-height:100vh;display:grid;place-items:center}.spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.muted{color:var(--muted)}.login-wrap{min-height:100vh;display:grid;place-items:center;padding:20px;background:url(/tuntiraportti_bg.png) center / cover no-repeat fixed}.login-card{background:var(--panel);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow);padding:32px;width:100%;max-width:380px;display:flex;flex-direction:column;gap:14px}.login-card h1{font-size:20px;margin:0}.login-card p{margin:0}.login-card label{display:flex;flex-direction:column;gap:6px;font-weight:600;font-size:13px}.token-row{display:flex;gap:6px}.token-row input{flex:1}.hint{font-weight:400;color:var(--muted);font-size:12px}input,select{border:1px solid var(--border);border-radius:8px;padding:9px 10px;font-size:14px;background:#fff;color:var(--text);font-family:inherit}input:focus,select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1f}button{cursor:pointer;font-family:inherit;font-size:14px;border-radius:8px;border:1px solid transparent;padding:9px 16px;font-weight:600;transition:background .15s,border-color .15s}button:disabled{opacity:.5;cursor:not-allowed}.primary{background:var(--primary);color:#fff}.primary:hover:not(:disabled){background:var(--primary-dark)}.secondary{background:#fff;color:var(--primary);border-color:var(--primary)}.secondary:hover:not(:disabled){background:var(--accent)}.ghost{background:transparent;color:var(--muted);border-color:var(--border)}.ghost:hover{background:#f0f2f6}.error-box{background:#fdecec;border:1px solid #f5b5b5;color:#a02020;border-radius:8px;padding:10px 12px;font-size:13px}.error-box.wide{margin:0 20px}.app{width:100%;margin:0;padding:0 24px 48px}.topbar{display:flex;align-items:center;justify-content:space-between;padding:16px 0}.brand{font-weight:700;font-size:18px}.topbar-right{display:flex;align-items:center;gap:14px}.mainnav{display:flex;gap:6px}.navbtn{background:transparent;border:1px solid transparent;color:var(--muted);padding:7px 14px;border-radius:8px;font-weight:600}.navbtn:hover{background:#f0f2f6;color:var(--text)}.navbtn.active{background:var(--accent);color:var(--primary-dark)}.checkbox{display:flex;align-items:center;gap:8px;font-weight:600;font-size:13px}.checkbox input{width:auto}.panel{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:18px}.filters{display:flex;flex-direction:column;gap:18px}.filter-group{display:flex;flex-direction:column;gap:8px}.filter-group .label{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}.seg{display:inline-flex;flex-wrap:wrap;border:1px solid var(--border);border-radius:8px;overflow:hidden;width:fit-content;max-width:100%}.seg-btn{background:#fff;border:none;border-radius:0;padding:8px 14px;color:var(--muted);font-weight:600}.seg-btn.active{background:var(--primary);color:#fff}.seg-btn+.seg-btn{border-left:1px solid var(--border)}.range-inputs{display:flex;align-items:center;gap:10px}.dash{color:var(--muted)}.quick-row{display:flex;flex-wrap:wrap;gap:8px}.chip{background:#fff;border:1px solid var(--border);color:var(--text);padding:7px 14px;border-radius:999px;font-weight:500}.chip:hover{border-color:var(--primary)}.chip.active{background:var(--accent);border-color:var(--primary);color:var(--primary-dark)}.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.grid3 label{display:flex;flex-direction:column;gap:6px;font-weight:600;font-size:13px}.actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.resolved{margin-left:auto;font-variant-numeric:tabular-nums}.empty{text-align:center;color:var(--muted);padding:50px 20px;background:var(--panel);border:1px dashed var(--border);border-radius:var(--radius);margin-top:18px}.summary{display:grid;grid-template-columns:300px 1fr;gap:18px;margin-top:18px}.cards{display:flex;flex-direction:column;gap:12px}.card-row{display:flex;gap:12px}.card-row .card{flex:1;padding:14px}.card-row .card .card-value{font-size:22px}.card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:18px}.card.big{background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;border:none}.card.big.alert{background:linear-gradient(135deg,#d64545,#b02525)}.card-value{font-size:28px;font-weight:700;font-variant-numeric:tabular-nums}.card.big .card-value{font-size:34px}.card-label{color:var(--muted);font-size:13px;margin-top:4px}.card.big .card-label{color:#ffffffd9}.breakdown{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:18px}.breakdown-list{margin-top:14px;display:flex;flex-direction:column;gap:9px;max-height:320px;overflow-y:auto}.breakdown-row{display:grid;grid-template-columns:200px 1fr 64px;align-items:center;gap:12px}.bd-name{font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bd-bar{background:#eef1f6;border-radius:999px;height:9px;overflow:hidden}.bd-fill{display:block;height:100%;background:var(--primary);border-radius:999px}.bd-hours{text-align:right;font-variant-numeric:tabular-nums;font-weight:600}.table-panel{margin-top:18px;padding:0;overflow:hidden}.table-scroll{overflow-x:auto;max-height:70vh;overflow-y:auto}.report-table{width:100%;border-collapse:collapse;font-size:13px}.report-table th,.report-table td{padding:9px 12px;text-align:left;border-bottom:1px solid var(--border);white-space:nowrap}.report-table thead th{position:sticky;top:0;background:#f7f9fc;z-index:1;cursor:pointer;-webkit-user-select:none;user-select:none;font-weight:700;color:#374151}.report-table thead th:hover{background:#eef2f8}.report-table tbody tr:nth-child(2n){background:#fafbfd}.report-table tbody tr.matka{background:#eaf4fc}.report-table tbody tr.matka:nth-child(2n){background:#e2effa}.report-table tbody tr.alert-row{background:#fdecec}.report-table tbody tr.alert-row:hover{background:#fbd9d9}.report-table tbody tr:hover{background:var(--accent)}.report-table .num{text-align:right;font-variant-numeric:tabular-nums}.report-table .pd{font-weight:600;color:var(--primary-dark)}.report-table .desc{white-space:normal;min-width:220px;max-width:360px;color:var(--muted)}.report-table .bold{font-weight:700}.report-table tfoot td{position:sticky;bottom:0;background:#f7f9fc;border-top:2px solid var(--border)}.report-table .actions-col{text-align:center;white-space:nowrap}.linkbtn{background:none;border:none;padding:2px 6px;font-size:12px;font-weight:600;color:var(--primary);cursor:pointer}.linkbtn:hover{text-decoration:underline}.linkbtn.danger{color:#c0392b}.edited-badge{font-size:12px;font-weight:600;color:#b26a00;background:#fff4e0;border:1px solid #f0d39a;border-radius:999px;padding:4px 10px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#141e3273;display:grid;place-items:center;z-index:50;padding:16px}.modal{background:var(--panel);border-radius:14px;box-shadow:0 10px 40px #00000040;padding:24px;width:100%;max-width:440px;display:flex;flex-direction:column;gap:12px}.modal h2{margin:0;font-size:18px}.modal-sub{margin:0 0 4px;font-size:13px}.modal label{display:flex;flex-direction:column;gap:6px;font-weight:600;font-size:13px}.modal textarea{border:1px solid var(--border);border-radius:8px;padding:9px 10px;font-family:inherit;font-size:14px;resize:vertical}.modal textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1f}.modal-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:6px}@media (max-width: 800px){.app{padding:0 12px 32px}.grid3,.summary{grid-template-columns:1fr}.breakdown-row{grid-template-columns:120px 1fr 56px}.topbar{flex-wrap:wrap;gap:8px}.actions{flex-direction:column;align-items:stretch}.resolved{margin-left:0}.range-inputs{flex-wrap:wrap}}
