:root{--bg:#f4f7fa;--panel:#fff;--soft:#eef4f8;--ink:#17202a;--muted:#667789;--line:#dbe5ed;--blue:#2563eb;--green:#15803d;--orange:#b45309;--red:#b91c1c;--teal:#0f766e;--shadow:0 14px 36px rgba(24,36,51,.08)}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--ink);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}button,input,select,textarea{font:inherit}button{cursor:pointer}.app{min-height:100vh;display:grid;grid-template-columns:264px minmax(0,1fr)}.sidebar{background:#111827;color:#f8fafc;padding:24px 20px;display:flex;flex-direction:column;gap:28px}.brand{display:flex;align-items:center;gap:12px}.brand-mark{width:40px;height:40px;border-radius:8px;background:#38bdf8;color:#082f49;display:grid;place-items:center;font-weight:800}.brand span,.brand strong{display:block}.brand span{color:#a8b3c2;font-size:12px}.nav{display:grid;grid-gap:4px;gap:4px}.nav button{border:0;background:transparent;color:#cbd5e1;text-align:left;padding:11px 12px;border-radius:8px}.nav button.active,.nav button:hover{background:#1f2937;color:#fff}.nav-group{display:grid;grid-gap:2px;gap:2px;margin-top:6px}.nav-group-header{display:flex;align-items:center;gap:8px;width:100%;border:0;background:transparent;color:#94a3b8;padding:9px 12px;border-radius:8px;text-align:left;font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.nav-group-header:hover{background:#1f2937;color:#cbd5e1}.nav-group-chevron{display:inline-block;width:10px;transition:transform .15s ease;font-size:10px}.nav-group.expanded .nav-group-chevron{transform:rotate(90deg)}.nav-group-pages{display:grid;grid-gap:2px;gap:2px;padding-left:8px}.nav-group-pages button{padding-left:18px;font-size:13px}.sidebar-card{margin-top:auto;background:#1f2937;border:1px solid rgba(255,255,255,.08);border-radius:8px;padding:16px}.sidebar-card .label,.sidebar-card .small{color:#a8b3c2}.sidebar-card strong{display:block;margin-top:4px;font-size:24px}main{min-width:0;padding:28px}.topbar{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;margin-bottom:22px}h1,h2,h3,p{margin:0}h1{font-size:clamp(26px,4vw,38px);line-height:1.1;letter-spacing:0}h2{font-size:18px}h3{font-size:14px}.subtitle{color:var(--muted);margin-top:8px;max-width:760px}.actions,.row-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}.btn{border:1px solid var(--line);background:var(--panel);color:var(--ink);border-radius:8px;min-height:38px;padding:0 13px;display:inline-flex;align-items:center;justify-content:center;gap:8px;white-space:nowrap}.btn.primary{background:var(--blue);border-color:var(--blue);color:#fff}.btn.danger{background:#fee2e2;border-color:#fecaca;color:var(--red)}.btn.small-btn{min-height:30px;padding:0 10px;font-size:12px}.btn:disabled{cursor:not-allowed;opacity:.48}.link-btn{border:0;background:transparent;color:var(--blue);padding:0;text-align:left}.link-btn:hover{text-decoration:underline}.metrics{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));grid-gap:14px;gap:14px;margin-bottom:18px}.detail-panel,.metric,.panel{background:var(--panel);border:1px solid var(--line);border-radius:8px;box-shadow:var(--shadow)}.metric{padding:18px;min-height:126px;display:grid;align-content:space-between;grid-gap:14px;gap:14px}.field span,.metric .label,.small{color:var(--muted);font-size:12px}.metric strong{display:block;margin-top:6px;font-size:30px;line-height:1}.grid,.two-col{display:grid;grid-template-columns:minmax(0,1fr) minmax(360px,.72fr);grid-gap:18px;gap:18px}.panel{min-width:0;overflow:hidden}.panel-header{padding:18px 18px 0;display:flex;align-items:flex-start;justify-content:space-between;gap:14px}.panel-header p{color:var(--muted);font-size:13px;margin-top:3px}.form-grid,.mini-form{padding:18px;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));grid-gap:12px;gap:12px;align-items:end}.register-grid{grid-template-columns:repeat(5,minmax(0,1fr))}.mini-form{padding:0;grid-template-columns:repeat(2,minmax(0,1fr))}.mini-form .btn{align-self:end;min-width:0;white-space:normal}.field{display:grid;grid-gap:6px;gap:6px}.field input,.field select,.field textarea{width:100%;border:1px solid var(--line);border-radius:8px;background:#fff;min-height:38px;padding:0 11px;color:var(--ink)}.field textarea{min-height:88px;padding-top:9px;resize:vertical}table{width:100%;border-collapse:collapse;font-size:14px}td,th{border-top:1px solid var(--line);padding:13px 18px;text-align:left;vertical-align:top}th{color:var(--muted);font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.04em}th,tr.clickable:hover{background:#f8fafc}.customer{display:grid;grid-gap:3px;gap:3px}.customer span{color:var(--muted);font-size:12px}.status{display:inline-flex;align-items:center;min-height:26px;border-radius:999px;padding:0 9px;font-size:12px;font-weight:700;white-space:nowrap}.green{background:#dcfce7;color:var(--green)}.orange{background:#ffedd5;color:var(--orange)}.red{background:#fee2e2;color:var(--red)}.blue{background:#dbeafe;color:var(--blue)}.teal{background:#ccfbf1;color:var(--teal)}.detail-panel{padding:18px;display:grid;grid-gap:16px;gap:16px;align-content:start}.lists,.payment-grid,.schedule-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:12px;gap:12px}.payment-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.payment-box{background:var(--soft);border-radius:8px;padding:12px;min-width:0}.payment-box span{color:var(--muted);display:block;font-size:12px}.payment-box strong{display:block;margin-top:4px;font-size:16px;overflow-wrap:anywhere}.progress{display:grid;grid-gap:8px;gap:8px}.progress-head{display:flex;justify-content:space-between;gap:10px;color:var(--muted);font-size:12px}.bar{height:10px;border-radius:999px;background:#e5e7eb;overflow:hidden;margin-top:6px}.bar>span{display:block;height:100%;background:#14b8a6}.list-box{border:1px solid var(--line);border-radius:8px;overflow:hidden;min-width:0}.list-box h3{padding:10px 12px;background:#f8fafc}.list-box ul{list-style:none;padding:8px 12px 12px;margin:0;display:grid;grid-gap:7px;gap:7px}.list-box li{color:var(--muted);font-size:13px;overflow-wrap:anywhere}.partner-list,.product-items{margin-top:1.5rem}.partner-row-item{display:flex;justify-content:space-between;align-items:center;gap:10px}.partner-row-item span{color:var(--ink);font-size:13px}.product-row{display:grid;grid-template-columns:minmax(200px,2fr) minmax(90px,1fr) minmax(110px,1fr) auto;grid-gap:10px;gap:10px;align-items:end;padding:10px 12px;border-top:1px solid var(--line)}.product-row .btn{min-width:88px}.form-actions{margin-top:1rem}.paid-input{display:flex;gap:6px;align-items:stretch}.paid-input input{flex:1 1}.paid-input .btn{white-space:nowrap}.inline-warning{padding:8px 18px 0;font-size:13px}.format-row>td{background:#f8fafc;padding:0}.format-card{padding:16px 18px;display:grid;grid-gap:10px;gap:10px}.format-card h4{margin:0;font-size:14px}.format-card h5{margin:6px 0 0;font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}.format-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));grid-gap:10px;gap:10px;margin:0}.format-grid>div{background:#fff;border:1px solid var(--line);border-radius:8px;padding:10px 12px}.format-grid dt{color:var(--muted);font-size:12px}.format-grid dd{margin:4px 0 0;font-weight:700;font-size:14px}.format-list{list-style:none;padding:0;margin:0;display:grid;grid-gap:6px;gap:6px}.format-list li{display:flex;gap:10px;align-items:center;flex-wrap:wrap;background:#fff;border:1px solid var(--line);border-radius:8px;padding:8px 12px;font-size:13px}.format-list li strong{font-weight:600}@media (max-width:720px){.format-grid{grid-template-columns:1fr 1fr}}.breakdown-row td{font-size:13px;padding:10px 18px}.breakdown-row td:first-child{padding-left:32px}.breakdown-cell{display:flex;gap:8px;align-items:flex-start}.breakdown-cell .branch{color:var(--muted);font-weight:700}.modal-backdrop{position:fixed;inset:0;background:rgba(15,23,42,.55);display:grid;place-items:center;padding:20px;z-index:50}.modal-content{background:var(--panel);border-radius:12px;box-shadow:var(--shadow);width:100%;max-width:540px;max-height:90vh;overflow:auto}.modal-content.modal-wide{max-width:920px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;border-bottom:1px solid var(--line)}.modal-header h3{font-size:16px}.modal-body{padding:18px}.modal-body>.detail-panel{background:transparent;border:0;box-shadow:none;padding:0}.modal-form{display:grid;grid-gap:12px;gap:12px}.modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:4px}.reminder-alert{background:#fef3c7;border:1px solid #fcd34d;border-radius:8px;padding:14px 16px;margin-bottom:18px;box-shadow:var(--shadow)}.reminder-alert-head{display:flex;flex-direction:column;gap:4px;margin-bottom:8px}.reminder-alert-head strong{color:#92400e;font-size:14px}.reminder-alert ul{list-style:none;padding:0;margin:0;display:grid;grid-gap:6px;gap:6px}.reminder-alert li{background:#fff;border:1px solid var(--line);border-radius:8px}.reminder-alert .link-btn{width:100%;background:transparent;border:0;padding:10px 12px;display:flex;align-items:center;gap:10px;flex-wrap:wrap;cursor:pointer;text-align:left}.reminder-alert .link-btn:hover{background:#f8fafc}.reminder-alert .link-btn span{color:var(--muted);font-size:13px}.reminder-alert .link-btn .status{margin-left:auto}.preferred-row{background:var(--soft);border-radius:8px;padding:12px}.preferred-display{display:flex;align-items:center;gap:10px;margin-top:4px;flex-wrap:wrap}.preferred-display strong{font-size:16px}.preferred-edit{display:flex;gap:6px;align-items:center;margin-top:4px;flex-wrap:wrap}.preferred-edit input{min-height:34px;padding:0 10px;border:1px solid var(--line);border-radius:8px}.table-controls{display:flex;gap:8px;align-items:center;padding:14px 18px 0;flex-wrap:wrap}.table-controls .search-input{flex:1 1 220px;padding:0 12px}.table-controls .search-input,.table-controls select{min-height:36px;border:1px solid var(--line);border-radius:8px;background:#fff;color:var(--ink)}.table-controls select{padding:0 10px}.empty{text-align:center;color:var(--muted);padding:24px;font-size:13px}.th-sort{background:transparent;border:0;color:inherit;font:inherit;padding:0;cursor:pointer;display:inline-flex;align-items:center;gap:6px;text-transform:uppercase;letter-spacing:.04em}.th-sort:hover{color:var(--ink)}.th-sort.active{color:var(--blue)}.th-arrow{font-size:11px;opacity:.55}.th-sort.active .th-arrow{opacity:1}.kanban{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:14px;gap:14px;padding:18px}.kanban-col{background:var(--soft);border:1px solid var(--line);border-radius:10px;padding:12px;min-height:360px;display:flex;flex-direction:column;transition:background .15s ease}.kanban-col-droppable{background:#e0f2fe}.kanban-col-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;padding:0 4px}.kanban-col-head strong{font-size:13px;text-transform:uppercase;letter-spacing:.04em;color:var(--ink)}.kanban-count{background:#fff;color:var(--muted);font-size:11px;font-weight:700;padding:2px 8px;border-radius:999px;border:1px solid var(--line)}.kanban-cards{display:flex;flex-direction:column;gap:8px;flex:1 1}.kanban-card{background:#fff;border:1px solid var(--line);border-radius:8px;padding:10px 12px;cursor:-webkit-grab;cursor:grab;box-shadow:0 1px 2px rgba(15,23,42,.04);display:flex;flex-direction:column;gap:6px}.kanban-card:hover{box-shadow:var(--shadow);border-color:#93c5fd}.kanban-card.dragging{opacity:.5}.kanban-card-head{display:flex;justify-content:space-between;align-items:center;gap:6px}.kanban-card-context{font-size:13px;color:var(--ink);line-height:1.35}.kanban-card-meta{display:flex;gap:10px;font-size:12px;color:var(--muted)}.task-code{font-size:11px;font-weight:700;color:var(--muted);letter-spacing:.04em}.task-owner{font-weight:600;color:var(--ink)}.task-note{cursor:help}.kanban-add{align-self:stretch;justify-content:center;background:transparent;border-style:dashed;color:var(--muted)}.kanban-add:hover{border-color:var(--blue);color:var(--blue)}.priority-high{background:#fee2e2;color:var(--red)}.priority-medium{background:#fef3c7;color:#92400e}.priority-low{background:#dbeafe;color:var(--blue)}@media (max-width:1120px){.kanban{grid-template-columns:1fr}}.view-toggle{display:inline-flex;border:1px solid var(--line);border-radius:8px;overflow:hidden;margin-left:auto}.view-toggle button{background:#fff;border:0;min-height:36px;padding:0 14px;color:var(--muted);cursor:pointer;font-size:13px}.view-toggle button:not(:last-child){border-right:1px solid var(--line)}.view-toggle button.active{background:var(--blue);color:#fff}.register-modal{display:grid;grid-gap:0;gap:0}.register-modal .form-grid,.register-modal .register-grid{padding:18px 0 0}.register-modal .product-items{margin:18px 0}.register-modal .inline-warning,.register-modal .modal-actions{padding:8px 0 0}.register-intro{margin-top:6px}.empty,.error{color:var(--muted);padding:18px}.error{color:var(--red)}@media (max-width:1120px){.app{grid-template-columns:1fr}.sidebar{display:block}.nav{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));margin-top:18px}.sidebar-card{display:none}.metrics{grid-template-columns:repeat(2,minmax(0,1fr))}.grid,.two-col{grid-template-columns:1fr}.register-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:720px){.sidebar,main{padding:18px}.panel-header,.topbar{flex-direction:column;align-items:stretch}.form-grid,.lists,.metrics,.mini-form,.nav,.payment-grid,.product-row,.register-grid,.schedule-grid{grid-template-columns:1fr}.actions,.row-actions{justify-content:stretch}.btn,.product-row .btn{width:100%}.panel{overflow:hidden}table,tbody,td,th,thead,tr{display:block}table{min-width:0}thead{display:none}tbody{padding:0 18px 18px}tr{border-top:1px solid var(--line);padding:12px 0}td,th,tr:first-child{border-top:0}td,th{padding:0}td{display:grid;grid-template-columns:minmax(92px,.44fr) minmax(0,1fr);grid-gap:12px;gap:12px;align-items:start;min-width:0;padding:7px 0}td:before{content:attr(data-label);color:var(--muted);font-size:11px;font-weight:800;letter-spacing:.04em;text-transform:uppercase}td:empty:after{content:"-";color:var(--muted)}td>*{min-width:0}td>.bar,td>.small{grid-column:2}.empty{display:block;padding:18px 0}.empty:before,.format-row>td:before{content:none}.format-row{padding:0}.format-row>td{display:block;padding:0 0 12px}.format-card{padding:14px}.format-grid{grid-template-columns:1fr}.breakdown-row td:first-child{padding-left:0}.breakdown-cell .branch{display:none}}