:root{--bg: #f8fafb;--panel: #ffffff;--text: #111827;--muted: #6b7280;--accent: #8b5cf6;--accent-weak: rgba(139, 92, 246, .15);--border: #e5e7eb;--good: #a78bfa;--warn: #eab308;--fab-bg: #8b5cf6;--fab-fg: #0b1117}*{box-sizing:border-box}html,body{height:100%}body{margin:0;background:var(--bg);color:var(--text);font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,Helvetica Neue,Arial,"Apple Color Emoji","Segoe UI Emoji"}.container{max-width:1100px;margin:0 auto;padding:16px 16px 80px}@media (min-width: 768px){.container{padding-bottom:16px}}.panel{background:var(--panel);border:none;border-radius:14px;padding:16px;box-shadow:0 8px 20px #0000000f;margin-bottom:16px}.row{display:flex;gap:12px;flex-wrap:wrap}.col{flex:1 1 280px;min-width:280px}.grid2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.grid3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}@media (max-width: 768px){.grid2,.grid3{grid-template-columns:1fr}.col{min-width:100%}}.btn{background:var(--accent);color:#fff;border:none;padding:12px 16px;border-radius:10px;cursor:pointer;font-weight:500;font-size:14px;transition:opacity .2s}.btn:active{opacity:.8}.btn.ghost{background:var(--accent-weak);color:var(--accent)}.btn.warn{background:var(--warn);color:#000}.btn.good{background:var(--good);color:#fff}.input,.select,.textarea{width:100%;padding:12px;border-radius:8px;border:none;border-bottom:1.5px solid rgba(229,231,235,.8);background:#fffffff2;color:var(--text);font-size:16px}.input:focus,.select:focus,.textarea:focus{outline:none;border-bottom-color:var(--accent);background:var(--panel)}.label{font-size:13px;color:var(--muted);margin-bottom:6px;display:block;font-weight:500}.section-title{font-weight:600;margin:8px 0;font-size:1.1rem}.spacer{height:16px}.muted{color:var(--muted)}.print-only{display:none!important}.right{text-align:right}.list{display:grid;gap:10px}.list-item{display:flex;gap:12px;align-items:center;justify-content:space-between;background:var(--panel);border:1px solid var(--border);border-radius:10px;padding:12px 14px}@media (max-width: 640px){.list-item{flex-direction:column;align-items:flex-start;gap:10px}.list-item .row{width:100%;justify-content:flex-end}.list-item .meta{display:flex;gap:8px;align-items:center;width:100%;justify-content:space-between}}.invoice-table{display:grid;margin-top:8px;border-radius:12px;overflow:hidden;border:1px solid var(--border)}.invoice-head,.invoice-row{display:grid;grid-template-columns:110px 1.5fr 70px 140px;gap:8px;align-items:center}.invoice-table.hours-only .invoice-head,.invoice-table.hours-only .invoice-row{grid-template-columns:110px 1.5fr 70px 140px}.invoice-head{background:transparent;color:var(--text);padding:8px 10px;font-weight:700;border-bottom:1px solid color-mix(in oklab,var(--border) 70%,transparent)}.invoice-row{background:var(--panel);border-top:1px dashed var(--border);padding:8px 10px}@media (prefers-color-scheme: light){.invoice-row{background:#fff}}.invoice-cell{min-width:0}.invoice-cell:before{display:none}.invoice-scroll{width:100%;overflow-x:auto}@media (max-width: 1024px){.invoice-head,.invoice-row{grid-template-columns:96px 1fr 70px 140px;font-size:13px}}@media (max-width: 768px){.invoice-scroll{overflow:visible}.invoice-table{border:none;gap:12px}.invoice-head{display:none}.invoice-row{grid-template-columns:1fr;border:1px solid var(--border);border-radius:12px;padding:16px;box-shadow:0 4px 10px #00000008;gap:12px}.invoice-row+.invoice-row{margin-top:0}.invoice-cell{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:4px 0;border-bottom:1px dashed var(--border)}.invoice-cell:last-child{border-bottom:none}.invoice-cell:before{display:block;content:attr(data-label);font-size:13px;color:var(--muted);font-weight:600}.invoice-cell.actions{justify-content:flex-end;padding-top:8px}}@media print{@page{margin:.5cm;size:auto}body{background:#fff;color:#000}.container{max-width:100%;padding:0;margin:0;width:100%}.panel{box-shadow:none;border:none;padding:0;margin:0;background:transparent;border-radius:0}.print-only{display:block!important}.invoice-scroll{overflow:visible}.invoice-table{display:grid!important;border:1px solid #eee!important;border-radius:12px;gap:0!important}.invoice-head{display:grid!important;grid-template-columns:110px 1fr 90px 90px 70px 80px 90px!important;border-bottom:2px solid #000;color:#000;background:#f9f9f9!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}.invoice-row{display:grid!important;grid-template-columns:110px 1.5fr 70px 70px 60px 80px 60px!important;border-bottom:1px solid #eee;page-break-inside:avoid;padding:8px 10px!important;gap:8px!important;box-shadow:none!important;margin-top:0!important;border-radius:0!important}.invoice-cell{display:block!important;border:none!important;padding:0!important;text-align:left}.invoice-cell.right{text-align:right}.invoice-cell:before{display:none!important;content:""!important}.invoice-summary .box{border:2px solid #000;background:transparent;padding:12px 20px;border-radius:12px;min-width:250px}.invoice-summary .row{margin:4px 0}.invoice-summary .label{color:#000;font-weight:600}.invoice-summary .value{color:#000;font-weight:700}.invoice-summary .grand{font-size:20px}.muted{color:#444}.section-title{color:#000}.no-print,.print-controls,.fab,.bottom-nav{display:none!important}}.invoice-summary{margin-top:10px;display:grid;grid-template-columns:1fr 180px}.invoice-summary .box{justify-self:end;background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:10px 12px;min-width:180px}.invoice-summary .row{display:flex;justify-content:space-between;align-items:center;margin:4px 0}.invoice-summary .label{color:var(--muted)}.invoice-summary .value{font-weight:700}.invoice-summary .grand{font-size:18px;color:var(--accent)}@media (max-width: 768px){.invoice-summary{grid-template-columns:1fr}.invoice-summary .box{justify-self:stretch;margin-top:12px}}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:50;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal{width:min(800px,92vw);max-height:90vh;overflow:auto;background:var(--panel);color:var(--text);border:1px solid var(--border);border-radius:16px;padding:24px;box-shadow:0 20px 50px #0000004d}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.close{background:transparent;border:1px solid var(--border);color:var(--muted);padding:8px 12px;border-radius:8px;cursor:pointer}@media (max-width: 640px){.modal{width:100vw;height:100vh;max-height:100vh;border-radius:0;border:none;padding:16px}.modal-header{margin-top:8px}}.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:var(--panel);border-top:1px solid var(--border);display:grid;grid-template-columns:repeat(5,1fr);padding:8px 8px 24px;z-index:40;box-shadow:0 -4px 20px #0000000d}.bottom-item{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 4px;color:var(--muted);text-decoration:none;background:transparent;border:none;cursor:pointer}.bottom-item.active{color:var(--accent)}.bottom-item svg{width:24px;height:24px}.fab{position:fixed;right:20px;bottom:90px;background:var(--fab-bg);color:var(--fab-fg);width:56px;height:56px;border-radius:50%;border:none;box-shadow:0 4px 15px #8b5cf666;font-size:28px;line-height:0;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .2s;z-index:45}.fab:active{transform:scale(.95)}
