@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap";*{box-sizing:border-box;margin:0;padding:0}html,body,#root{width:100%;height:100%}body{margin:0;padding:0}#root{flex-direction:column;display:flex}:root{--bg-color:#f4f5f7;--card-bg:#fff;--text-main:#111827;--text-muted:#6b7280;--text-light:#9ca3af;--border-color:#e5e7eb;--primary:#007bff;--primary-hover:#0056b3;--success:#10b981;--success-bg:#d1fae5;--danger:#ef4444;--danger-bg:#fee2e2;--warning:#f59e0b;--info-bg:#e0f2fe;--info-text:#0284c7;--planned-bg:#9ca3af}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-color);color:var(--text-main);font-family:Inter,sans-serif;line-height:1.5}.container{width:100%;max-width:100%;margin:0;padding:20px 20px 60px;overflow-x:hidden}@media (width>=1200px){.container{max-width:1100px;margin:0 auto;padding:24px 24px 60px}}h1{color:var(--text-main);font-size:28px;font-weight:800}.section-title{color:#8b5cf6;text-transform:uppercase;letter-spacing:.05em;margin:24px 0 12px 4px;font-size:12px;font-weight:700}.section-title-gray{color:var(--text-muted)}button{cursor:pointer;border:none;outline:none;font-family:inherit;transition:all .2s}.btn-primary{background-color:var(--primary);color:#fff;border-radius:8px;padding:8px 16px;font-size:14px;font-weight:600}.btn-primary:hover{background-color:var(--primary-hover)}.btn-ghost{color:var(--text-main);background-color:#e5e7eb;border-radius:8px;padding:8px 16px;font-size:14px;font-weight:500}.btn-ghost:hover{background-color:#d1d5db}.btn-text{color:var(--primary);background:0 0;padding:4px 8px;font-size:13px;font-weight:600}.btn-text:hover{text-decoration:underline}.btn-icon{color:var(--text-muted);background:0 0;border-radius:4px;justify-content:center;align-items:center;padding:4px;font-size:16px;display:inline-flex}.btn-icon:hover{color:var(--danger);background:#f3f4f6}.top-bar-form{justify-content:space-between;align-items:center;margin-bottom:32px;display:flex;position:relative}.top-bar-form h2{margin:0;font-size:18px;font-weight:700;position:absolute;left:50%;transform:translate(-50%)}.summary-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:32px;display:grid}.summary-card{background-color:#eef2f6;border-radius:12px;flex-direction:column;gap:8px;padding:16px;display:flex}.summary-card span{color:var(--text-muted);font-size:13px}.summary-card strong{font-size:24px;font-weight:800}.list-card{background:var(--card-bg);border:1px solid var(--border-color);cursor:pointer;border-radius:12px;margin-bottom:16px;padding:20px;transition:box-shadow .2s}.list-card:hover{box-shadow:0 4px 6px -1px #0000001a}.card-header{justify-content:space-between;margin-bottom:4px;display:flex}.card-title{color:var(--text-main);font-size:16px;font-weight:700}.card-subtitle{color:var(--text-muted);margin-bottom:16px;font-size:13px}.pill-group{align-items:center;gap:8px;display:flex}.pill{border-radius:999px;padding:2px 10px;font-size:12px;font-weight:600}.pill.active{background-color:var(--success-bg);color:var(--success)}.pill.normal{background-color:var(--info-bg);color:var(--info-text)}.form-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;margin-bottom:24px;padding:16px}@media (width>=768px){.form-card{padding:24px}}.grid-2{grid-template-columns:1fr;gap:20px;display:grid}@media (width>=768px){.grid-2{grid-template-columns:1fr 1fr}}.grid-3{grid-template-columns:1fr;gap:20px;display:grid}@media (width>=768px){.grid-3{grid-template-columns:1fr 1fr}}@media (width>=1024px){.grid-3{grid-template-columns:1fr 1fr 1fr}}.input-group{flex-direction:column;gap:6px;min-width:0;margin-bottom:12px;display:flex}.input-group label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;font-size:11px;font-weight:700}.input-control{border:1px solid var(--border-color);color:var(--text-main);box-sizing:border-box;background:#fff;border-radius:8px;outline:none;width:100%;padding:9px 12px;font-family:inherit;font-size:14px;transition:border .2s}.input-control:focus{border-color:var(--primary)}select.input-control{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='%236b7280'><path fill-rule='evenodd' d='M5.293 7.293a1 1 0 011.414 0L10 10.586l3.293-3.293a1 1 0 111.414 1.414l-4 4a1 1 0 01-1.414 0l-4-4a1 1 0 010-1.414z' clip-rule='evenodd' /></svg>");background-position:right 12px center;background-repeat:no-repeat;background-size:16px;padding-right:36px!important}textarea.input-control{resize:vertical;min-height:60px}.timeline-bar{border:1px solid var(--border-color);background:#f3f4f6;border-radius:8px;height:32px;display:flex;overflow:hidden}.timeline-segment{color:#fff;white-space:nowrap;text-overflow:ellipsis;border-right:1px solid #ffffff4d;justify-content:center;align-items:center;font-size:11px;font-weight:700;transition:width .3s;display:flex;overflow:hidden}.timeline-segment:last-child{border-right:none}.timeline-legend{color:var(--text-muted);flex-wrap:wrap;gap:16px;margin-top:12px;font-size:11px;display:flex}.legend-item{align-items:center;gap:6px;display:flex}.legend-dot{border-radius:50%;width:10px;height:10px}.fin-table-wrap{background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;flex-direction:column;margin-bottom:32px;display:flex;overflow-x:auto}.fin-table{border-collapse:collapse;width:100%;min-width:600px}.fin-table th,.fin-table td{text-align:right;border-bottom:1px solid var(--border-color);padding:14px 16px;font-size:14px}.fin-table th:first-child,.fin-table td:first-child{text-align:left}.fin-table th{color:var(--text-muted);text-transform:uppercase;background:#f9fafb;font-size:12px;font-weight:600}.fin-table tr:last-child td{background:#fefefe;border-bottom:none;font-weight:700}.milestone-card{background:#f8fafc;border:1px solid #d1d5db;border-radius:12px;margin-bottom:24px;padding:20px}.invoice-split{grid-template-columns:1fr;gap:16px;margin-bottom:20px;display:grid}@media (width>=768px){.invoice-split{grid-template-columns:1fr 1fr}}.inv-box{border:1px solid var(--border-color);background:#fff;border-radius:8px;flex-direction:column;padding:16px;display:flex;position:relative}.inv-box.final{background:#f0fdf4;border-color:#6ee7b7}.inv-header{color:var(--text-muted);justify-content:space-between;align-items:center;margin-bottom:16px;font-size:13px;font-weight:700;display:flex}.invoice-inputs{flex:1;grid-template-columns:1fr 1fr;gap:12px;display:grid}.payment-wrap{border:1px solid var(--border-color);background:#fff;border-radius:8px;margin-top:8px;overflow-x:auto}.payment-table{border-collapse:collapse;width:100%;min-width:650px}.payment-table th,.payment-table td{text-align:left;border-bottom:1px solid var(--border-color);vertical-align:middle;padding:10px 12px;font-size:13px}.payment-table th{color:var(--text-muted);background:#f9fafb;font-weight:600}.payment-table tr:last-child td{border-bottom:none}.empty-state{text-align:center;color:var(--text-muted);background:var(--card-bg);border:1px dashed var(--border-color);border-radius:12px;padding:40px 20px}.search-row{flex-flow:column wrap;align-items:stretch;gap:12px;margin-bottom:24px;display:flex}@media (width>=768px){.search-row{flex-direction:row;align-items:center}}.date-filters{border:1px solid var(--border-color);background:#fff;border-radius:8px;flex-wrap:wrap;align-items:center;gap:12px;padding:4px 12px;display:flex}@media (width<=768px){.top-bar-form{flex-direction:column;gap:16px}.top-bar-form h2{width:100%;position:static;transform:none}.pill-group{flex-wrap:wrap}}
