@import"https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:ital,wght@0,400;0,500;0,600;0,700;0,800;1,400&display=swap";:root{--font: "Plus Jakarta Sans", system-ui, sans-serif;--bg: #f3f1ec;--bg-elevated: #faf9f6;--surface: #ffffff;--surface-hover: #fdfcfa;--text: #141c18;--text-secondary: #4a5c54;--text-muted: #7a8f85;--primary: #0f5c47;--primary-hover: #0d4f3d;--primary-soft: rgba(15, 92, 71, .1);--primary-glow: rgba(15, 92, 71, .25);--accent-matto: #d4622a;--accent-matto-soft: rgba(212, 98, 42, .12);--accent-parketti: #b8860b;--accent-parketti-soft: rgba(184, 134, 11, .12);--accent-laatta: #3b6ea8;--accent-pinnoitus: #3d8b6e;--border: rgba(20, 28, 24, .08);--border-strong: rgba(20, 28, 24, .14);--danger: #c23b3b;--danger-soft: rgba(194, 59, 59, .1);--radius-sm: 10px;--radius: 14px;--radius-lg: 20px;--radius-xl: 28px;--shadow-sm: 0 1px 2px rgba(20, 28, 24, .04);--shadow: 0 4px 20px rgba(20, 28, 24, .06), 0 1px 3px rgba(20, 28, 24, .04);--shadow-lg: 0 12px 40px rgba(20, 28, 24, .1), 0 4px 12px rgba(20, 28, 24, .05);--shadow-nav: 0 -8px 32px rgba(20, 28, 24, .08);--header-h: auto;--nav-h: 72px;--ease: cubic-bezier(.22, 1, .36, 1);--duration: .22s}*,*:before,*:after{box-sizing:border-box}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-height:100dvh;font-family:var(--font);font-size:15px;line-height:1.5;color:var(--text);background:var(--bg);background-image:radial-gradient(ellipse 120% 80% at 50% -30%,rgba(15,92,71,.08),transparent),radial-gradient(ellipse 60% 40% at 100% 0%,rgba(212,98,42,.05),transparent)}#root{min-height:100dvh}button,input{font-family:inherit}button{-webkit-tap-highlight-color:transparent}input[type=number]{-moz-appearance:textfield}input[type=number]::-webkit-outer-spin-button,input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}::selection{background:var(--primary-soft);color:var(--primary)}@keyframes fadeUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}.app{--app-max: 440px;--sidebar-w: 260px;max-width:var(--app-max);margin:0 auto;min-height:100dvh;display:flex;flex-direction:column;position:relative}.app-shell{display:flex;flex-direction:column;flex:1;min-width:0}.app-main{flex:1;padding:1.25rem 1.25rem calc(var(--nav-h) + 1.5rem);min-width:0}.app-sidebar{display:none}.app-main>section,.app-main>.laskuri,.app-main>.urakka{animation:fadeUp var(--duration) var(--ease) both}.app-header{position:sticky;top:0;z-index:20;padding:1rem 1.25rem 1.1rem;background:#faf9f6d1;backdrop-filter:blur(16px) saturate(1.4);-webkit-backdrop-filter:blur(16px) saturate(1.4);border-bottom:1px solid var(--border)}.app-header-top{display:flex;align-items:center;gap:.75rem}.app-logo{display:flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:var(--radius);background:linear-gradient(135deg,var(--primary) 0%,#178564 100%);color:#fff;box-shadow:0 4px 14px var(--primary-glow);flex-shrink:0}.app-brand h1{margin:0;font-size:1.15rem;font-weight:800;letter-spacing:-.03em;line-height:1.2;color:var(--text)}.app-brand p{margin:.1rem 0 0;font-size:.75rem;font-weight:500;color:var(--text-muted)}.projekti-asetukset{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1rem;padding:.75rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm)}.projekti-chip{display:inline-flex;align-items:center;gap:.5rem;padding:.4rem .65rem;background:var(--bg);border:1px solid var(--border);border-radius:999px;font-size:.8rem;font-weight:600;color:var(--text-secondary)}.projekti-chip input[type=number]{width:3.5rem;padding:.2rem .4rem;border:none;border-radius:6px;background:var(--surface);font-size:.85rem;font-weight:700;color:var(--text);text-align:center}.projekti-chip input[type=number]:focus{outline:2px solid var(--primary-soft)}.projekti-chip.checkbox{cursor:pointer}.projekti-chip.checkbox .checkbox-box{width:1rem;height:1rem;margin-top:0}.projekti-chip.checkbox input{position:absolute;opacity:0;width:0;height:0}.projekti-chip--info{color:var(--text-muted);font-size:.8rem;font-weight:500}.alapalkki{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:var(--app-max);padding:.65rem 1.25rem calc(.65rem + env(safe-area-inset-bottom,0px));z-index:30}.alapalkki-inner{display:grid;grid-template-columns:repeat(3,1fr);gap:.35rem;padding:.35rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-nav)}.alapalkki button{display:flex;align-items:center;justify-content:center;gap:.45rem;padding:.75rem 1rem;border:none;border-radius:var(--radius-lg);background:transparent;font-size:.875rem;font-weight:600;color:var(--text-muted);cursor:pointer;transition:color var(--duration) var(--ease),background var(--duration) var(--ease)}.alapalkki button:hover:not(:disabled){color:var(--text-secondary);background:var(--bg)}.alapalkki button.active{color:var(--primary);background:var(--primary-soft)}.badge{display:inline-flex;align-items:center;justify-content:center;min-width:1.15rem;height:1.15rem;padding:0 .35rem;font-size:.65rem;font-weight:700;background:var(--primary);color:#fff;border-radius:999px}.etusivu-hero{margin-bottom:1.5rem}.etusivu-hero h2{margin:0 0 .35rem;font-size:1.5rem;font-weight:800;letter-spacing:-.04em;line-height:1.15;color:var(--text)}.ingress{margin:0;font-size:.95rem;color:var(--text-secondary);line-height:1.55;max-width:32ch}.suunnitelu-cta{display:flex;align-items:center;gap:1rem;width:100%;margin-bottom:2rem;padding:1.1rem 1.25rem;border:1px dashed var(--primary);border-radius:var(--radius-lg);background:var(--primary-soft);cursor:pointer;text-align:left;transition:border-color var(--duration) var(--ease),box-shadow var(--duration) var(--ease)}.suunnitelu-cta:hover{border-color:var(--primary);box-shadow:var(--shadow)}.suunnitelu-cta-ikoni{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:var(--radius);background:var(--surface);color:var(--primary);flex-shrink:0}.suunnitelu-cta-teksti{flex:1;min-width:0;display:flex;flex-direction:column;gap:.2rem}.suunnitelu-cta-otsikko{font-size:1rem;font-weight:800;color:var(--text);letter-spacing:-.02em}.suunnitelu-cta-kuvaus{font-size:.85rem;color:var(--text-secondary);line-height:1.4}.suunnitelu-cta-nuoli{color:var(--primary);flex-shrink:0}.etusivu-suunnitelu-hero{margin-bottom:1.75rem}.etusivu-suunnitelu-hero h2{margin:0 0 .35rem;font-size:1.5rem;font-weight:800;letter-spacing:-.04em}.btn-ghost--link{margin-top:.75rem;padding:0;font-size:.9rem;color:var(--primary)}.header-suunnitelu-badge{margin:.5rem 0 0;padding:.35rem .75rem;font-size:.8rem;font-weight:600;color:var(--primary);background:var(--primary-soft);border-radius:var(--radius-sm);display:inline-block}.sidebar-suunnitelu{padding:.75rem 0 1rem;border-bottom:1px solid var(--border);margin-bottom:.75rem}.sidebar-suunnitelu-teksti{margin:0 0 .65rem;font-size:.8rem;line-height:1.45;color:var(--text-muted)}.sidebar-vaihda--inline{width:100%;margin-top:0}.alapalkki-inner--kaksi{grid-template-columns:1fr 1fr}.tyolaji-grid{display:flex;flex-direction:column;gap:.65rem}.tyolaji-kortti{position:relative;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:1rem;width:100%;padding:1.1rem 1.15rem;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);cursor:pointer;text-align:left;box-shadow:var(--shadow-sm);transition:transform var(--duration) var(--ease),box-shadow var(--duration) var(--ease),border-color var(--duration) var(--ease);overflow:hidden}.tyolaji-kortti:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--tyolaji-accent, var(--primary));opacity:0;transition:opacity var(--duration) var(--ease)}.tyolaji-kortti:not(:disabled):hover{transform:translateY(-2px);box-shadow:var(--shadow);border-color:var(--border-strong)}.tyolaji-kortti:not(:disabled):hover:before,.tyolaji-kortti:not(:disabled):active:before{opacity:1}.tyolaji-kortti:not(:disabled):active{transform:translateY(0)}.tyolaji-kortti--matto{--tyolaji-accent: var(--accent-matto)}.tyolaji-kortti--matto .tyolaji-ikoni{background:var(--accent-matto-soft);color:var(--accent-matto)}.tyolaji-kortti--parketti{--tyolaji-accent: var(--accent-parketti)}.tyolaji-kortti--parketti .tyolaji-ikoni{background:var(--accent-parketti-soft);color:var(--accent-parketti)}.tyolaji-kortti--laatta{--tyolaji-accent: var(--accent-laatta)}.tyolaji-kortti--laatta .tyolaji-ikoni{background:#3b6ea81f;color:var(--accent-laatta)}.tyolaji-kortti--pinnoitus{--tyolaji-accent: var(--accent-pinnoitus)}.tyolaji-kortti--pinnoitus .tyolaji-ikoni{background:#3d8b6e1f;color:var(--accent-pinnoitus)}.tyolaji-kortti.tulossa{opacity:.55;cursor:not-allowed;filter:grayscale(.2)}.tyolaji-ikoni{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:var(--radius);flex-shrink:0}.tyolaji-teksti{min-width:0}.tyolaji-nimi{display:block;font-size:1.05rem;font-weight:700;letter-spacing:-.02em;color:var(--text)}.tyolaji-kortti .tyolaji-arrow{color:var(--text-muted);transition:transform var(--duration) var(--ease),color var(--duration) var(--ease)}.tyolaji-kortti:not(:disabled):hover .tyolaji-arrow{color:var(--tyolaji-accent, var(--primary));transform:translate(3px)}.tyolaji-badge{position:absolute;top:.75rem;right:.75rem;padding:.2rem .5rem;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);background:var(--bg);border-radius:6px}.toolbar{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.25rem}.btn-ghost{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem .85rem;border:1px solid var(--border);border-radius:999px;background:var(--surface);font-size:.8rem;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:background var(--duration) var(--ease),color var(--duration) var(--ease),border-color var(--duration) var(--ease)}.btn-ghost:hover{background:var(--bg-elevated);color:var(--primary);border-color:var(--primary-soft)}.btn-back{display:inline-flex;align-items:center;gap:.35rem;margin-bottom:1rem;padding:.45rem .75rem .45rem .5rem;border:none;border-radius:999px;background:var(--surface);font-size:.85rem;font-weight:600;color:var(--text-secondary);cursor:pointer;box-shadow:var(--shadow-sm);border:1px solid var(--border);transition:color var(--duration) var(--ease),background var(--duration) var(--ease)}.btn-back:hover{color:var(--primary);background:var(--primary-soft)}.haku-wrap{position:relative;margin-bottom:1.25rem}.haku-wrap .haku-ikoni{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.haku-kentta{width:100%;padding:.9rem 1rem .9rem 2.75rem;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);font-size:1rem;font-weight:500;color:var(--text);box-shadow:var(--shadow-sm);transition:border-color var(--duration) var(--ease),box-shadow var(--duration) var(--ease)}.haku-kentta::placeholder{color:var(--text-muted);font-weight:400}.haku-kentta:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft)}.kategoria-lista{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}.kategoria-lista li button{display:flex;align-items:center;gap:.85rem;width:100%;padding:1rem 1.1rem;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);font-size:.95rem;font-weight:600;text-align:left;color:var(--text);cursor:pointer;box-shadow:var(--shadow-sm);transition:transform var(--duration) var(--ease),box-shadow var(--duration) var(--ease),border-color var(--duration) var(--ease)}.kategoria-lista li button:hover{transform:translate(4px);box-shadow:var(--shadow);border-color:var(--border-strong)}.kategoria-lista li button.active{border-color:var(--primary);background:var(--primary-soft);color:var(--primary)}.kat-nimi{flex:1;min-width:0}.kat-num{display:flex;align-items:center;justify-content:center;width:2.25rem;height:2.25rem;border-radius:var(--radius-sm);background:linear-gradient(135deg,var(--primary-soft),rgba(15,92,71,.04));color:var(--primary);font-weight:800;font-size:.85rem;flex-shrink:0}.kat-lkm{margin-left:auto;padding:.25rem .55rem;font-size:.72rem;font-weight:600;color:var(--text-muted);background:var(--bg);border-radius:999px}.hinta-lista{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}.hinta-nappi{display:grid;grid-template-columns:auto 1fr;grid-template-rows:auto auto auto;gap:.15rem .75rem;width:100%;padding:1rem 1.1rem;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);text-align:left;cursor:pointer;box-shadow:var(--shadow-sm);transition:transform var(--duration) var(--ease),box-shadow var(--duration) var(--ease),border-color var(--duration) var(--ease)}.hinta-nappi:hover{transform:translateY(-1px);box-shadow:var(--shadow);border-color:#0f5c4733}.hinta-nappi--valittu{border-color:var(--primary);background:var(--primary-soft);box-shadow:0 0 0 1px var(--primary)}.hinta-koodi{grid-row:1 / 4;align-self:start;display:inline-flex;padding:.35rem .5rem;font-size:.75rem;font-weight:800;letter-spacing:.02em;color:var(--primary);background:var(--primary-soft);border-radius:8px;font-variant-numeric:tabular-nums}.hinta-kuvaus{grid-column:2;font-size:.92rem;font-weight:600;line-height:1.35;color:var(--text)}.hinta-meta{grid-column:2;font-size:.82rem;font-weight:600;color:var(--text-secondary)}.hinta-meta em{font-style:normal;font-weight:500;color:var(--text-muted)}.hinta-kat{grid-column:2;font-size:.72rem;font-weight:500;color:var(--text-muted)}.laskuri-header{margin-bottom:1.25rem;padding:1.15rem 1.2rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow)}.laskuri-header .koodi{display:inline-block;padding:.3rem .55rem;font-size:.75rem;font-weight:800;color:var(--primary);background:var(--primary-soft);border-radius:8px;letter-spacing:.03em}.laskuri-header h2{margin:.65rem 0 .4rem;font-size:1.1rem;font-weight:700;letter-spacing:-.02em;line-height:1.35}.laskuri-header .meta{margin:0;font-size:.88rem;font-weight:600;color:var(--text-secondary)}.laskuri-header .meta .ehto{font-weight:500;color:var(--text-muted)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.1rem 1.2rem;margin-bottom:.85rem;box-shadow:var(--shadow-sm)}.card-title{margin:0 0 .85rem;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted)}.maara-syote label:not(.checkbox){display:block;margin-bottom:.5rem;font-size:.88rem;font-weight:600;color:var(--text-secondary)}.maara-syote input[type=number]{width:100%;padding:1rem 1.1rem;font-size:1.75rem;font-weight:700;letter-spacing:-.03em;border:2px solid var(--border);border-radius:var(--radius);background:var(--bg-elevated);color:var(--text);transition:border-color var(--duration) var(--ease),box-shadow var(--duration) var(--ease)}.maara-syote input[type=number]:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px var(--primary-soft)}.korotukset{border:none;padding:0;margin:0}.korotukset legend{padding:0}.checkbox{display:flex;align-items:flex-start;gap:.65rem;margin-bottom:.55rem;font-size:.88rem;font-weight:500;color:var(--text-secondary);cursor:pointer;line-height:1.4}.checkbox:last-child{margin-bottom:0}.checkbox input{position:absolute;opacity:0;width:0;height:0}.checkbox-box{flex-shrink:0;width:1.25rem;height:1.25rem;margin-top:.1rem;border:2px solid var(--border-strong);border-radius:6px;background:var(--bg-elevated);transition:background var(--duration) var(--ease),border-color var(--duration) var(--ease),box-shadow var(--duration) var(--ease);position:relative}.checkbox input:checked+.checkbox-box{background:var(--primary);border-color:var(--primary);box-shadow:0 2px 8px var(--primary-glow)}.checkbox input:checked+.checkbox-box:after{content:"";position:absolute;left:.32rem;top:.12rem;width:.35rem;height:.6rem;border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg)}.checkbox input:focus-visible+.checkbox-box{outline:2px solid var(--primary);outline-offset:2px}.checkbox.inline{margin-top:.85rem;padding-top:.85rem;border-top:1px dashed var(--border)}.tulos{background:linear-gradient(145deg,var(--primary) 0%,#147a5f 100%);border-radius:var(--radius-lg);padding:1.2rem 1.25rem;margin:1rem 0 1.25rem;color:#fff;box-shadow:0 8px 28px var(--primary-glow);animation:scaleIn .35s var(--ease) both}.tulos-rivi{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:.4rem;font-size:.9rem;font-weight:500;opacity:.9}.tulos-rivi.muted{font-size:.82rem;opacity:.75}.tulos-rivi.yhteensa{font-size:1.35rem;font-weight:800;letter-spacing:-.03em;margin-top:.65rem;padding-top:.75rem;border-top:1px solid rgba(255,255,255,.2);opacity:1}.tulos-rivi.yhteensa span:last-child{font-variant-numeric:tabular-nums}.huomio{font-size:.8rem;color:var(--text-muted);margin:.65rem 0 0;line-height:1.45}.laskuri-header .huomio{margin-top:.5rem;padding:.5rem .65rem;background:var(--bg);border-radius:var(--radius-sm);color:var(--text-secondary)}.btn-primary{width:100%;padding:1rem 1.25rem;border:none;border-radius:var(--radius-lg);background:linear-gradient(135deg,var(--primary) 0%,#147a5f 100%);color:#fff;font-size:1rem;font-weight:700;letter-spacing:-.01em;cursor:pointer;box-shadow:0 6px 20px var(--primary-glow);transition:transform var(--duration) var(--ease),box-shadow var(--duration) var(--ease),opacity var(--duration) var(--ease)}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 10px 28px var(--primary-glow)}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-primary:disabled{opacity:.45;cursor:not-allowed;box-shadow:none}.btn-secondary{width:100%;margin-top:1rem;padding:.85rem;border:1px solid rgba(194,59,59,.25);border-radius:var(--radius);background:var(--danger-soft);font-weight:600;font-size:.9rem;cursor:pointer;color:var(--danger);transition:background var(--duration) var(--ease)}.btn-secondary:hover{background:#c23b3b29}.urakka.tyhja{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:3rem 1.5rem;background:var(--surface);border:1px dashed var(--border-strong);border-radius:var(--radius-lg)}.urakka.tyhja .empty-icon{width:56px;height:56px;margin-bottom:1rem;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--primary-soft);color:var(--primary)}.urakka.tyhja p{margin:0;font-size:.95rem;color:var(--text-secondary);max-width:24ch}.hinta-lahde-valitsin{display:grid;grid-template-columns:1fr 1fr;gap:.35rem;margin-bottom:1rem;padding:.25rem;background:var(--bg);border-radius:var(--radius)}.hinta-lahde-valitsin button{display:flex;align-items:center;justify-content:center;gap:.4rem;padding:.6rem .5rem;border:none;border-radius:var(--radius-sm);background:transparent;font:inherit;font-size:.82rem;font-weight:600;color:var(--text-muted);cursor:pointer;transition:background var(--duration) var(--ease),color var(--duration) var(--ease)}.hinta-lahde-valitsin button.active{background:var(--surface);color:var(--primary);box-shadow:var(--shadow-sm)}.hinta-lahde-badge{padding:.1rem .4rem;font-size:.68rem;font-weight:700;border-radius:999px;background:var(--primary-soft);color:var(--primary)}.projektihinnat-osio-yla{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:.35rem}.projektihinnat-osio-yla .panel-otsikko{margin:0}.projektihinnat-osio-info{margin:0 0 1rem;font-size:.82rem;color:var(--text-muted);line-height:1.45}.hinta-lista--omat li{display:flex;align-items:stretch;gap:.35rem}.hinta-lista--omat .hinta-nappi{flex:1;margin-bottom:0}.projektihinta-poista-lista{flex-shrink:0;align-self:center}.oma-hinta-panel .oma-hinta-summa{margin:.5rem 0 0;font-size:1.75rem;font-weight:800;color:var(--primary);font-variant-numeric:tabular-nums}.urakka-lisays{margin-bottom:1.25rem;padding:1rem 1.1rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.urakka-lisays-yla{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:.65rem}.urakka-lisays-otsikko{margin:0;font-size:.9rem;font-weight:800;letter-spacing:-.02em}.urakka-lisays-tyhja{margin:0;font-size:.82rem;color:var(--text-muted);line-height:1.45}.urakka-tyhja-viesti{text-align:center;padding:2rem 1rem 1.5rem;color:var(--text-secondary)}.urakka-tyhja-viesti .empty-icon{width:48px;height:48px;margin:0 auto .75rem;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--primary-soft);color:var(--primary)}.urakka-tyhja-viesti p{margin:0;font-size:.9rem}.projektihinta-lista{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.4rem}.projektihinta-lista li{display:flex;align-items:stretch;gap:.35rem}.projektihinta-nappi{flex:1;display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.65rem .85rem;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);cursor:pointer;text-align:left;transition:border-color var(--duration) var(--ease),background var(--duration) var(--ease)}.projektihinta-nappi:hover{border-color:var(--primary);background:var(--primary-soft)}.projektihinta-nimi{font-size:.88rem;font-weight:600;color:var(--text)}.projektihinta-summa{font-size:.88rem;font-weight:700;color:var(--primary);font-variant-numeric:tabular-nums}.modal-ingress{margin:-.5rem 0 1rem;font-size:.85rem;color:var(--text-secondary);line-height:1.45}.urakka-lista{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}.urakka-rivi{display:flex;justify-content:space-between;align-items:flex-start;gap:.75rem;padding:1rem 1.05rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);animation:fadeUp .3s var(--ease) both}.urakka-rivi-sisalto{display:flex;flex-direction:column;gap:.25rem;min-width:0}.urakka-rivi-sisalto strong{display:flex;align-items:center;gap:.4rem;font-size:.88rem;font-weight:800;color:var(--text)}.urakka-tyolaji{padding:.15rem .4rem;font-size:.62rem;font-weight:700;letter-spacing:.05em;color:var(--primary);background:var(--primary-soft);border-radius:4px}.urakka-kuvaus{font-size:.85rem;font-weight:500;color:var(--text-secondary);line-height:1.35}.urakka-maara,.urakka-korotukset{font-size:.78rem;color:var(--text-muted)}.urakka-rivi-oikea{display:flex;flex-direction:column;align-items:flex-end;gap:.35rem;flex-shrink:0}.urakka-summa{font-size:1rem;font-weight:800;letter-spacing:-.02em;color:var(--primary);font-variant-numeric:tabular-nums;white-space:nowrap}.btn-icon{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;border:none;border-radius:var(--radius-sm);background:var(--danger-soft);color:var(--danger);cursor:pointer;transition:background var(--duration) var(--ease),transform var(--duration) var(--ease)}.btn-icon:hover{background:#c23b3b2e;transform:scale(1.05)}.urakka-yhteensa{display:flex;justify-content:space-between;align-items:center;margin-top:1.25rem;padding:1.25rem 1.35rem;background:linear-gradient(135deg,var(--text) 0%,#2a3d36 100%);color:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg)}.urakka-yhteensa span:first-child{font-size:.88rem;font-weight:600;opacity:.8}.urakka-yhteensa strong{font-size:1.5rem;font-weight:800;letter-spacing:-.03em;font-variant-numeric:tabular-nums}.tyhja-viesti{text-align:center;padding:2.5rem 1rem;color:var(--text-muted);font-weight:500}.tyomaat-osio{margin-bottom:2rem}.tyomaat-osio-yla{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem}.tyomaat-osio-yla h2{margin:0;font-size:1.15rem;font-weight:800;letter-spacing:-.03em}.tyomaat-tyhja{text-align:center;padding:2rem 1.5rem;background:var(--surface);border:1px dashed var(--border-strong);border-radius:var(--radius-lg)}.tyomaat-tyhja-ikoni{width:56px;height:56px;margin:0 auto 1rem;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--primary-soft);color:var(--primary)}.tyomaat-tyhja p{margin:0 0 1rem;color:var(--text-secondary)}.btn-primary--inline{width:auto;display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem}.tyomaa-lista{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}.tyomaa-lista li{display:flex;align-items:stretch;gap:.35rem}.tyomaa-kortti{flex:1;display:flex;align-items:center;gap:.85rem;padding:1rem 1.1rem;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);cursor:pointer;text-align:left;box-shadow:var(--shadow-sm);transition:border-color var(--duration) var(--ease),box-shadow var(--duration) var(--ease)}.tyomaa-kortti:hover{border-color:var(--border-strong);box-shadow:var(--shadow)}.tyomaa-kortti--valittu{border-color:var(--primary);background:var(--primary-soft);box-shadow:0 0 0 1px var(--primary)}.tyomaa-kortti-ikoni{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:var(--radius);background:var(--bg);color:var(--primary);flex-shrink:0}.tyomaa-kortti--valittu .tyomaa-kortti-ikoni{background:#0f5c4726}.tyomaa-kortti-teksti{flex:1;min-width:0}.tyomaa-kortti-nimi{display:block;font-weight:700;font-size:.95rem;color:var(--text)}.tyomaa-kortti-nuoli{display:flex;align-items:center;color:var(--text-muted);flex-shrink:0;transition:color var(--duration) var(--ease),transform var(--duration) var(--ease)}.tyomaa-kortti:hover .tyomaa-kortti-nuoli{color:var(--primary);transform:translate(2px)}.tyomaa-kortti--valittu .tyomaa-kortti-nimi{color:var(--primary)}.tyomaa-kortti-osoite,.tyomaa-kortti-meta{display:block;font-size:.8rem;color:var(--text-muted);margin-top:.15rem}.tyomaa-valittu-badge{flex-shrink:0;padding:.2rem .5rem;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--primary);background:#0f5c471f;border-radius:6px;align-self:flex-start}.tyomaa-kortti-toiminnot{display:flex;flex-direction:column;gap:.35rem;flex-shrink:0}.btn-icon--neutral{background:var(--bg);color:var(--text-muted)}.btn-icon--neutral:hover{background:var(--primary-soft);color:var(--primary)}.tyomaa-valitsin{margin-bottom:1.25rem;padding-bottom:1.25rem;border-bottom:1px solid var(--border)}.tyomaa-valitsin-label{display:flex;align-items:center;gap:.4rem;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:.5rem}.tyomaa-valitsin-rivi{display:flex;gap:.35rem}.tyomaa-select{flex:1;min-width:0;padding:.6rem .75rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-elevated);font-size:.88rem;font-weight:600;color:var(--text);cursor:pointer}.tyomaa-select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft)}.tyomaa-valitsin-linkit{display:flex;flex-wrap:wrap;gap:.5rem .75rem;margin-top:.5rem}.tyomaa-valitsin-link{border:none;background:none;padding:0;font-size:.75rem;font-weight:600;color:var(--primary);cursor:pointer;text-decoration:underline;text-underline-offset:2px}.header-tyomaa-mobile{margin-top:1rem}.tyomaa-sivu{max-width:640px;margin:0 auto;padding-bottom:2rem}.tyomaa-sivu-takaisin{margin-bottom:1.25rem}.tyomaa-sivu-hero{margin-bottom:1.5rem;padding:1.25rem 1.35rem;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);box-shadow:var(--shadow-sm)}.tyomaa-sivu-hero-yla{display:flex;align-items:flex-start;gap:1rem}.tyomaa-sivu-ikoni{display:flex;align-items:center;justify-content:center;width:52px;height:52px;border-radius:var(--radius);background:var(--primary-soft);color:var(--primary);flex-shrink:0}.tyomaa-sivu-otsikko{flex:1;min-width:0}.tyomaa-sivu-otsikko h2{margin:0;font-size:1.35rem;font-weight:800;line-height:1.2}.tyomaa-sivu-osoite,.tyomaa-sivu-huomio{margin:.35rem 0 0;font-size:.88rem;color:var(--text-muted)}.tyomaa-sivu-urakka-yhteenveto{margin:1rem 0 0;padding-top:1rem;border-top:1px solid var(--border);font-size:.88rem;color:var(--text-muted)}.tyomaa-sivu-jatko{margin-top:2rem;padding-top:2rem;border-top:1px solid var(--border)}.tyomaa-sivu-jatko h3{margin:0 0 .35rem;font-size:1.1rem;font-weight:800}.tyomaa-sivu-jatko .ingress{margin:0 0 1.25rem}.etusivu-jatko{margin-top:2rem;padding-top:2rem;border-top:1px solid var(--border)}.etusivu-jatko h3{margin:0 0 1rem;font-size:1.1rem;font-weight:800}.tyolaji-grid--disabled{opacity:.55;pointer-events:none}.huomio--varoitus{color:#b45309;background:#b4530914;padding:.5rem .75rem;border-radius:var(--radius-sm);margin-bottom:1rem}.detail-placeholder-tyomaa{margin-top:1rem;font-size:.88rem}.urakka-tyomaa-otsikko{margin:0 0 1rem;padding:.65rem .85rem;background:var(--bg);border-radius:var(--radius-sm);font-size:.88rem;color:var(--text-secondary)}.urakka-tyomaa-otsikko strong{color:var(--text)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:flex;align-items:center;justify-content:center;padding:1.25rem;background:#141c1873;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeUp .2s var(--ease) both}.modal.tyomaa-lomake{width:100%;max-width:440px;max-height:90dvh;overflow-y:auto;padding:1.5rem;background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);animation:scaleIn .25s var(--ease) both}.modal.tyomaa-lomake h2{margin:0 0 1.25rem;font-size:1.25rem;font-weight:800}.etusivu-kuvat{margin-bottom:2rem}.tyomaa-kuvat{padding:1rem}.tyomaa-kuvat--compact{padding:0}.tyomaa-kuvat-yla{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1rem}.tyomaa-kuvat-otsikko{margin:0;font-size:1.15rem;font-weight:800;letter-spacing:-.03em}.tyomaa-kuvat-kohde{margin:.25rem 0 0;font-size:.85rem;color:var(--text-muted)}.btn-ghost--small{padding:.35rem .65rem;font-size:.8rem}.tyomaa-kuvat-input{position:absolute;width:0;height:0;opacity:0;pointer-events:none}.tyomaa-kuvat-ota{width:100%;display:flex;align-items:center;justify-content:center;gap:.6rem;padding:1rem;margin-bottom:1rem}.tyomaa-kuvat-lomake{margin-bottom:1.25rem}.tyomaa-kuvat-esikatselu{width:100%;max-height:220px;object-fit:cover;border-radius:var(--radius);margin-bottom:.75rem;background:var(--bg)}.tyomaa-kuvat-kuvaus-label{display:block;font-size:.85rem;font-weight:600;color:var(--text-secondary);margin-bottom:.75rem}.tyomaa-kuvat-kuvaus{display:block;width:100%;margin-top:.35rem;padding:.75rem .9rem;border:1px solid var(--border);border-radius:var(--radius-sm);font:inherit;background:var(--surface)}.tyomaa-kuvat-lomake-napit{display:flex;gap:.5rem;justify-content:flex-end}.tyomaa-kuvat-galleria{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.75rem}.tyomaa-kuva-kortti{position:relative;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;background:var(--surface)}.tyomaa-kuva-link{display:block;width:100%;padding:0;border:none;background:none;cursor:pointer;aspect-ratio:4 / 3;overflow:hidden}.tyomaa-kuva-link img{width:100%;height:100%;object-fit:cover}.tyomaa-kuva-meta{padding:.5rem .6rem .6rem}.tyomaa-kuva-teksti{margin:0 0 .2rem;font-size:.8rem;font-weight:600;line-height:1.3;color:var(--text)}.tyomaa-kuva-aika{font-size:.7rem;color:var(--text-muted)}.tyomaa-kuva-poista{position:absolute;top:.35rem;right:.35rem;background:#ffffffeb;box-shadow:var(--shadow-sm)}.btn-icon--danger{color:var(--danger)}.btn-icon--danger:hover{background:var(--danger-soft)}.tyomaa-kuvat-info{margin:1.25rem 0 0;font-size:.75rem;color:var(--text-muted)}.kuva-lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;display:flex;align-items:center;justify-content:center;padding:1rem;background:#000000e0}.kuva-lightbox-sulje{position:absolute;top:.75rem;right:.75rem;z-index:2;width:2.5rem;height:2.5rem;border:none;border-radius:50%;background:#ffffff1f;color:#fff;font-size:1.75rem;line-height:1;cursor:pointer}.kuva-lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);z-index:2;display:flex;align-items:center;justify-content:center;width:3rem;height:3rem;border:none;border-radius:50%;background:#ffffff1f;color:#fff;cursor:pointer}.kuva-lightbox-nav--edellinen{left:.5rem}.kuva-lightbox-nav--seuraava{right:.5rem}.kuva-lightbox-nuoli-oikea{transform:scaleX(-1)}.kuva-lightbox-sisalto{margin:0;max-width:min(96vw,1100px);max-height:92vh;text-align:center}.kuva-lightbox-sisalto img{max-width:100%;max-height:calc(92vh - 4rem);object-fit:contain;border-radius:var(--radius)}.kuva-lightbox-sisalto figcaption{margin-top:.75rem;color:#ffffffe6;font-size:.9rem}.kuva-lightbox-teksti{margin:0 0 .25rem;font-weight:600}.kuva-lightbox-laskuri{display:block;margin-top:.35rem;font-size:.8rem;opacity:.75}.app--kuvat-only .app-main{max-width:720px;margin:0 auto}.app--kuvat-only .kuvat-only-takaisin{margin-bottom:1rem}.tyomaa-sivu-kuvat-yla{display:flex;justify-content:flex-end;margin-top:1.5rem;margin-bottom:-.25rem}.workspace--kuvat .workspace-detail-panel{padding:0}@media(min-width:1024px){.tyomaa-kuvat-galleria{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}.tyomaa-kuvat{padding:1.25rem 1.5rem}}.lomake-kentta{display:block;margin-bottom:1rem;font-size:.85rem;font-weight:600;color:var(--text-secondary)}.lomake-kentta input,.lomake-kentta textarea{display:block;width:100%;margin-top:.4rem;padding:.7rem .85rem;border:1px solid var(--border);border-radius:var(--radius);font-size:1rem;font-weight:500;color:var(--text);background:var(--bg-elevated)}.lomake-kentta input:focus,.lomake-kentta textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft)}.lomake-kentta textarea{resize:vertical;min-height:4rem}.pakollinen{color:var(--danger)}.lomake-checkboxit{margin-bottom:1.25rem}.modal-toiminnot{display:flex;gap:.65rem;justify-content:flex-end}.btn-secondary--neutral{color:var(--text-secondary);border-color:var(--border);background:var(--bg)}.btn-secondary--neutral:hover{background:var(--bg-elevated);color:var(--text)}.workspace{display:flex;flex-direction:column;gap:0;min-height:0}.workspace-list-panel,.workspace-detail-panel{min-width:0}.workspace-detail-panel{display:none}.workspace--detail-open .workspace-detail-panel{display:block}.workspace--detail-open.workspace--urakka .workspace-list-panel,.workspace--detail-open.workspace--kuvat .workspace-list-panel,.btn-back--desktop,.detail-placeholder{display:none}.panel-otsikko{margin:0 0 1rem;font-size:1.1rem;font-weight:800;letter-spacing:-.03em}.panel-otsikko-rivi{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.toolbar--list{margin-bottom:1rem}.header-projekti-mobile{margin-top:1rem}@media(max-width:1023px){.workspace--detail-open .workspace-list-panel,.workspace--detail-open.workspace--urakka .workspace-list-panel,.workspace--detail-open.workspace--kuvat .workspace-list-panel{display:none}}@media(min-width:768px){.app{--app-max: 720px}.app-main{padding-left:1.75rem;padding-right:1.75rem}.etusivu-hero h2{font-size:1.85rem}.tyolaji-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.85rem}.tyolaji-kortti{margin-bottom:0}.kategoria-lista{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem}.kategoria-lista li button{margin-bottom:0}.hinta-lista{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem}.hinta-nappi{margin-bottom:0;height:100%}}@media(min-width:1024px){.app{--app-max: 100%;--sidebar-w: 272px;display:grid;grid-template-columns:var(--sidebar-w) 1fr;max-width:none;margin:0;min-height:100dvh}.app--workspace{grid-template-columns:var(--sidebar-w) 1fr}.app:not(.app--workspace) .app-shell{grid-column:1 / -1}.app:not(.app--workspace){display:block;max-width:960px;margin:0 auto}.app-sidebar{display:flex;flex-direction:column;position:sticky;top:0;height:100dvh;padding:1.5rem 1.25rem;background:var(--surface);border-right:1px solid var(--border);box-shadow:var(--shadow-sm);z-index:25}.sidebar-brand{display:flex;align-items:center;gap:.75rem;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border)}.sidebar-brand .app-brand h1{font-size:1.05rem}.sidebar-nav{display:flex;flex-direction:column;gap:.35rem;margin-bottom:1.5rem}.sidebar-nav button{display:flex;align-items:center;gap:.65rem;width:100%;padding:.75rem 1rem;border:none;border-radius:var(--radius);background:transparent;font-size:.9rem;font-weight:600;color:var(--text-muted);cursor:pointer;text-align:left;transition:background var(--duration) var(--ease),color var(--duration) var(--ease)}.sidebar-nav button:hover{background:var(--bg);color:var(--text-secondary)}.sidebar-nav button.active{background:var(--primary-soft);color:var(--primary)}.sidebar-projekti{flex:1;min-height:0}.sidebar-projekti .projekti-asetukset{flex-direction:column;align-items:stretch;margin-top:0}.sidebar-projekti .projekti-chip{width:100%;justify-content:space-between}.sidebar-vaihda{margin-top:auto;padding:.7rem 1rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);font-size:.85rem;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:background var(--duration) var(--ease),color var(--duration) var(--ease)}.sidebar-vaihda:hover{background:var(--primary-soft);color:var(--primary);border-color:transparent}.app-shell{min-height:100dvh}.app-header{padding:1.25rem 2rem 1rem}.app-header-top .app-brand p,.header-projekti-mobile,.header-tyomaa-mobile,.app--workspace .app-header{display:none}.tyomaa-lista{display:grid;grid-template-columns:repeat(2,1fr);gap:.65rem}.tyomaa-lista li{flex-direction:column}.tyomaa-kortti-toiminnot{flex-direction:row;justify-content:flex-end;padding:0 .5rem .5rem}.app-main{padding:1.75rem 2rem 2rem}.app--workspace .app-main{padding-bottom:2rem}.alapalkki{display:none}.etusivu{max-width:920px;margin:0 auto;padding-top:1rem}.tyomaat-osio{margin-bottom:2.5rem}.etusivu-hero{margin-bottom:2rem}.etusivu-hero h2{font-size:2.25rem}.ingress{font-size:1.05rem;max-width:42ch}.tyolaji-grid{grid-template-columns:repeat(2,1fr);gap:1rem}.workspace{display:grid;grid-template-columns:minmax(340px,420px) minmax(0,1fr);gap:1.5rem;align-items:start;min-height:calc(100dvh - 3.5rem)}.workspace--urakka,.workspace--kuvat{grid-template-columns:1fr}.workspace-list-panel,.workspace-detail-panel{display:block!important;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow);overflow:hidden}.workspace-list-panel{max-height:calc(100dvh - 3.5rem);overflow-y:auto;padding:1.25rem}.workspace-detail-panel{max-height:calc(100dvh - 3.5rem);overflow-y:auto;padding:1.5rem;position:sticky;top:1.75rem}.workspace--detail-open .workspace-list-panel{display:block!important}.workspace--urakka .workspace-list-panel{display:none!important}.workspace--urakka .workspace-detail-panel{max-width:720px;margin:0 auto;width:100%}.btn-back--mobile{display:none}.btn-back--desktop{display:inline-flex}.detail-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;min-height:360px;padding:2rem;color:var(--text-muted)}.workspace--detail-open .detail-placeholder{display:none}.detail-placeholder-icon{width:72px;height:72px;margin-bottom:1.25rem;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--primary-soft);color:var(--primary)}.detail-placeholder h3{margin:0 0 .5rem;font-size:1.15rem;font-weight:700;color:var(--text)}.detail-placeholder p{margin:0;font-size:.9rem;max-width:28ch;line-height:1.5}.kategoria-lista,.hinta-lista{grid-template-columns:1fr}.laskuri .btn-primary{position:sticky;bottom:0}}@media(min-width:1280px){.app{--sidebar-w: 300px}.workspace{grid-template-columns:minmax(380px,480px) minmax(0,1fr);gap:2rem}.app-main{padding:2rem 2.5rem}.etusivu{max-width:960px}.tyolaji-grid{gap:1.15rem}}@media(min-width:1440px){.app:not(.app--workspace){max-width:1100px}.workspace{grid-template-columns:minmax(400px,520px) minmax(0,1fr)}.workspace--urakka .workspace-detail-panel{max-width:800px}}
