:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;align-items:center;justify-content:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.wrapper{display:flex;align-items:center;justify-content:center;min-height:100vh}.login-container{width:100%;max-width:100%;margin:0 auto;padding:16px;display:flex;flex-direction:column;height:100vh;justify-content:center;align-items:center}.app-header{background:#304255;color:#fff;padding:12px 16px;text-align:center;font-size:21px;font-weight:600;border-radius:6px;margin-bottom:16px;width:calc(100% - 32px);max-width:600px;margin-left:auto;margin-right:auto}.card{background:#fff;border-radius:12px;padding:16px;margin-bottom:16px;box-shadow:0 4px 8px #0000000d;width:100%;max-width:600px}.card-title{font-size:19px;margin-bottom:12px}.field-row{display:flex;align-items:center;margin-bottom:20px}.field-row label{flex:0 0 150px;font-size:19px}.field-row input,.field-row select{flex:1;width:100%;padding:6px 8px;border:1px solid #ccc;border-radius:4px;font-size:19px;text-align:left}.button-row{text-align:center;margin-top:12px}.estimate-btn{background:#304255;color:#fff;border:none;padding:10px 20px;border-radius:8px;font-size:19px;cursor:pointer}.app-footer{font-size:16px;color:#999;text-align:center;margin-top:16px}@media (min-width: 768px){.login-container{width:95%;max-width:none}}@media (min-width: 1280px){.login-container{width:33.3333%;min-width:360px;max-width:none}}.select-container{width:100%;max-width:100%;margin:0 auto;padding:16px;display:flex;flex-direction:column;min-height:100vh;justify-content:center;align-items:center}@media (min-width: 768px){.select-container{width:95%;max-width:none}}@media (min-width: 1280px){.select-container{width:33.3333%;min-width:360px;max-width:none}}.back-icon{position:absolute;left:16px;top:50%;transform:translateY(-50%);width:24px;height:24px;cursor:pointer}.header-text>div:first-child{font-size:23px;font-weight:700}.header-text>div:last-child{font-size:17px;margin-top:4px}.card.select-card{background:#fff;border-radius:16px;box-shadow:0 4px 8px #0000001a;margin-top:16px;padding:24px 16px;flex:1}.select-btn{width:100%;background:#e0e4ea;color:#304255;border:none;border-radius:8px;padding:14px;font-size:18px;font-weight:600;margin-bottom:16px;cursor:pointer;text-align:left;height:150px}.select-btn:last-child{margin-bottom:0}.select-btn:hover{background:#d0d4da}.app-footer{margin-top:24px;font-size:16px;text-align:center;color:#999}.loading-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#0009;display:flex;flex-direction:column;justify-content:center;align-items:center;z-index:1000}.loading-overlay p{color:#fff;font-size:18px;margin-top:16px}.loading-spinner{width:50px;height:50px;border:4px solid #f3f3f3;border-top:4px solid #304255;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.input-container{width:100%;max-width:100%;margin:0 auto;padding:16px;display:flex;flex-direction:column;min-height:100vh;justify-content:center;align-items:center}@media (min-width: 768px){.input-container{width:95%;max-width:none}}@media (min-width: 1280px){.input-container{width:33.3333%;min-width:360px;max-width:none}}.app-header{position:relative;background:#304255;color:#fff;border-radius:6px;padding:12px 48px;margin-bottom:16px;text-align:center;width:calc(100% - 32px);max-width:600px;margin-left:-16px;margin-right:-16px}.icon-back{position:absolute;left:16px;top:50%;transform:translateY(-50%);width:24px;height:24px;cursor:pointer}.card{background:#fff;border-radius:16px;box-shadow:0 4px 8px #0000001a;margin-top:16px;padding:16px;color:#000;width:100%;max-width:600px;box-sizing:border-box}.card-title{font-size:19px;font-weight:600;color:#304255;margin-bottom:8px}.field-row{display:flex;align-items:center;margin-bottom:12px;width:100%}.field-row label{flex:0 0 150px;font-size:18px}.unit-input{flex:1;display:flex;align-items:center}.unit-input input,.field-row select{width:100%;max-width:400px;padding:6px 8px;border:1px solid #ccc;border-radius:4px;font-size:18px;text-align:center}.unit-input span{margin-left:6px;font-size:18px}.full-input{width:97%;padding:6px 8px;border:1px solid #ccc;border-radius:4px;font-size:18px;text-align:left;background-color:#fff;color:#000}.diagram-wrapper{text-align:center;margin:16px 0}.diagram-img{max-width:400px;border-radius:8px}.button-row-bottom{position:sticky;bottom:0;padding:16px;text-align:center;z-index:10}.estimate-btn{background:#304255;color:#fff;border:none;padding:10px 20px;border-radius:8px;font-size:18px;cursor:pointer;width:100%}.estimate-btn:disabled{background:#aaa;cursor:default}.app-footer{font-size:16px;color:#999;text-align:center;margin-top:8px}.checkbox-row{display:flex;align-items:center;margin-top:12px;font-size:16px;color:#333;gap:8px}.checkbox-row input[type=checkbox]{width:18px;height:18px;accent-color:#304255;cursor:pointer}.type-selector button{padding:8px 16px;font-size:16px;margin-right:8px;border:1px solid #ccc;border-radius:6px;background:#f9f9f9;cursor:pointer}.type-selector button.active{border:2px solid #304255;background-color:#e6edf4;font-weight:700}.type-selector button{color:#111;background:#f9f9f9;border-color:#cbd5e1;font-weight:600}.type-selector button:focus-visible{outline:3px solid #60a5fa;outline-offset:2px}.type-selector button:hover{filter:brightness(.97)}.type-selector button.active{background-color:#e6edf4;border-color:#304255;color:#0b1726}@media (prefers-color-scheme: dark){.type-selector button{background:#0f172a;border-color:#334155;color:#e5e7eb}.type-selector button:hover{filter:none;background:#111827}.type-selector button.active{background:#1e293b;border-color:#60a5fa;color:#f8fafc}}.container{width:100%;max-width:100%;margin:0 auto;padding:16px;display:flex;flex-direction:column;min-height:100vh}@media (min-width: 1280px){.container{width:78%;min-width:1100px;max-width:1400px}.table-wrap{overflow-x:hidden!important}.table.table-4cols{min-width:0!important;width:100%}}.app-header{position:relative;background:#304255;color:#fff;border-radius:12px;padding:12px 48px;text-align:center;margin-left:-16px;margin-right:-16px}.back-icon{position:absolute;left:16px;top:50%;transform:translateY(-50%);font-size:24px;color:#fff;cursor:pointer}.home-icon{position:absolute;right:16px;top:50%;transform:translateY(-50%);font-size:24px;color:#fff;cursor:pointer}.header-text{display:flex;flex-direction:column;align-items:center}.header-sub{font-size:17px;margin-top:4px}.card{background:#fff;border-radius:16px;box-shadow:0 4px 8px #0000001a;margin-top:6px;padding:16px;color:#000}.card-title{font-size:19px;font-weight:600;color:#304255;margin-bottom:10px}.table-wrap{width:100%;overflow-x:auto;overflow-y:visible}.table-scale-canvas{will-change:transform}.table{width:100%;border-collapse:collapse;table-layout:fixed;font-size:18px}.table:not(.table-4cols) thead th,.table:not(.table-4cols) tbody td{width:33.3333%;padding:7px;text-align:left}.num.strong{font-weight:700}.table thead th{background:#f7f7f7;color:#555;font-weight:600}.table tbody tr{border-top:1px solid #eee}.table tbody td{color:#444}.table:not(.table-4cols) thead th:nth-child(2),.table:not(.table-4cols) tbody td:nth-child(2){text-align:center}.table:not(.table-4cols) thead th:nth-child(3),.table:not(.table-4cols) tbody td:nth-child(3){text-align:right}.qty{font-weight:600;white-space:normal;word-break:break-word}.summary{margin-top:16px}.summary-header{display:flex;justify-content:space-between;align-items:center;font-size:19px;font-weight:600;color:#304255;cursor:pointer}.icon{width:16px;height:16px}.summary-list{list-style:none;padding:8px 0 0;margin:0}.summary-list li{display:flex;justify-content:space-between;padding:6px 0;font-size:18px;border-bottom:1px solid #eee}.label{min-width:160px;text-align:right;white-space:nowrap;margin-right:8px}.dotfill{flex-grow:1;border-bottom:3px dotted #bbb;height:0;margin:0 20px;transform:translateY(13px)}.value{white-space:nowrap;text-align:left}.summary-list li:last-child{border-bottom:none}.app-footer{margin-top:auto;font-size:16px;text-align:center;color:#999}.delete-btn{margin-top:1rem;padding:10px 16px;background-color:#d9534f;color:#fff;font-size:16px;font-weight:700;border:none;border-radius:6px;cursor:pointer}.table tbody td.qty{text-align:right}.qty.editing{display:flex;justify-content:flex-end;align-items:center;gap:6px;white-space:nowrap;width:100%}.qty-input{width:70px;text-align:right;margin-left:auto;height:32px;box-sizing:border-box;padding:4px 6px;font-size:16px}.input-box{height:32px;width:100%;font-size:16px;padding:4px 6px;box-sizing:border-box;border:1px solid #ccc;border-radius:4px}.name-cell{white-space:normal;word-break:keep-all;line-height:1.4}.table.table-4cols thead th:nth-child(1),.table.table-4cols tbody td:nth-child(1){width:28%;text-align:left}.table.table-4cols thead th:nth-child(2),.table.table-4cols tbody td:nth-child(2){width:28%;text-align:left}.table.table-4cols thead th:nth-child(3),.table.table-4cols tbody td:nth-child(3){width:18%;text-align:right}.table.table-4cols thead th:nth-child(4),.table.table-4cols tbody td:nth-child(4){width:26%;text-align:right}.total-cell{vertical-align:top}.total-line{display:flex;flex-direction:column;align-items:flex-end;gap:4px}.total-value{font-weight:800;color:#1f2d3d;font-size:17px}.table.table-4cols thead th{background:linear-gradient(#fafafa,#f3f5f8);color:#3b4757;font-weight:700;border-bottom:1px solid #e8ecf1}.table.table-4cols tbody tr{border-top:1px solid #eee}.table.table-4cols tbody tr:hover{background:#fafcff}.num{text-align:right;white-space:nowrap}.toggle-unit{border:1px solid #d7dde5;background:#f6f8fb;border-radius:999px;padding:4px 10px;font-size:13px;color:#304255;cursor:pointer}.toggle-unit:hover{background:#eef2f7}.unit-panel{overflow:hidden;max-height:0;opacity:0;transform:translateY(-2px);transition:max-height .25s ease,opacity .18s ease,transform .18s ease;margin-top:6px;text-align:right}.unit-panel.open{max-height:56px;opacity:1;transform:translateY(0)}.unit-view strong{font-weight:800;color:#304255}.unit-label{margin-left:4px;color:#8aa0b3;font-size:14px}.unit-edit{display:inline-flex;align-items:center;gap:8px}.unit-edit label{font-size:14px;color:#6b7b8f}.name-cell{white-space:normal;word-break:keep-all;line-height:1.5}@media (max-width: 640px){.table-wrap{overflow-x:auto;overflow-y:visible}.table.table-4cols thead th,.table.table-4cols tbody td{padding:10px 12px;font-size:17px}.toggle-unit{padding:4px 10px;font-size:12px}}.table.table-4cols thead th,.table.table-4cols tbody td{display:table-cell!important}.spec{word-break:keep-all;overflow-wrap:anywhere;line-height:1.4}.basic-spec .spec-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px 16px}.spec-item{display:flex;justify-content:space-between;padding:8px 10px;border:1px solid #edf1f5;border-radius:10px;background:#fafcff}.spec-label{font-weight:600;color:#304255}.spec-value{font-weight:700;color:#1f2d3d}@media (max-width: 640px){.basic-spec .spec-grid{grid-template-columns:1fr}}.estimate-price-card{background:linear-gradient(135deg,#f8f9fc,#e8f0ff);border:2px solid #3b82f6}.estimate-price-card .card-title{color:#1e40af}.estimate-highlight{color:#1e40af!important;font-size:19px!important;font-weight:800!important}.estimate-price-card select{border:2px solid #3b82f6;color:#1e40af;font-weight:600;cursor:pointer}.estimate-price-card select:hover{background-color:#eff6ff}.summary-table{table-layout:auto!important}.summary-table td:nth-child(4),.summary-table th:nth-child(4){min-width:200px;white-space:nowrap}html,body,#root{width:100%;height:100%;margin:0;padding:0}body{display:flex;align-items:center;justify-content:center}.container{width:100%;max-width:100%;margin:0 auto;padding:16px;display:flex;flex-direction:column;min-height:100vh;justify-content:center;align-items:center}@media (min-width: 768px){.container{width:95%;max-width:none}}@media (min-width: 1280px){.container{width:33.3333%;min-width:360px;max-width:none}}.app-header{background:#304255;color:#fff;border-radius:12px;padding:12px 16px;text-align:center;position:relative;margin-left:-16px;margin-right:-16px}.back-icon{position:absolute;left:16px;top:50%;transform:translateY(-50%);color:#fff;font-size:24px;cursor:pointer}.home-icon{position:absolute;right:16px;top:50%;transform:translateY(-50%);color:#fff;font-size:24px;cursor:pointer}.header-title{font-size:23px;font-weight:700}.card.list-card{background:#fff;border-radius:16px;box-shadow:0 4px 8px #0000001a;margin-top:16px;padding:24px 16px;flex:1}.list-item{flex:1;background:#e0e4ea;border:none;border-radius:8px;padding:12px;margin-bottom:0;display:flex;justify-content:space-between;align-items:center;font-size:18px;cursor:pointer;gap:8px}.list-title{white-space:normal;word-break:break-word;overflow-wrap:break-word}.list-item:last-child{margin-bottom:0}.list-item:hover{background:#d0d4da}.list-title{font-weight:600;color:#304255}.list-date{font-size:16px;color:#555}.app-footer{margin:24px 0 8px;font-size:16px;text-align:center;color:#999}.list-item-wrapper{display:flex;align-items:stretch;gap:4px;margin-bottom:.5rem;flex-wrap:nowrap}.delete-button{margin:1rem auto;padding:8px 16px;background-color:#d9534f;color:#fff;border:none;border-radius:6px;cursor:pointer;display:block}.list-item.selected{background-color:#c6d6e5;box-shadow:inset 0 0 0 2px #304255}.item-checkbox{transform:scale(1.5);cursor:pointer}.item-checkbox:checked{accent-color:#304255}.delete-button-top{margin:0 auto 16px;padding:10px 20px;background-color:#d9534f;color:#fff;border:none;border-radius:8px;cursor:pointer;display:block;font-size:16px;font-weight:600}.delete-button-top:hover{background-color:#c9302c}.delete-icon-btn{background:transparent;border:none;cursor:pointer;padding:12px;display:flex;align-items:center;justify-content:center;color:#d9534f;font-size:22px;border-radius:8px;transition:all .2s ease;min-height:100%;flex-shrink:0}.delete-icon-btn:hover{background-color:#ffe6e6;color:#c9302c}.delete-icon-btn:active{transform:scale(.95)}.delete-button-wrapper{width:100%;margin-bottom:12px}.delete-button-top{margin:-8px auto 12px;padding:10px 20px;background-color:#d9534f;color:#fff;border:none;border-radius:8px;cursor:pointer;display:block;font-size:16px;font-weight:600}.list-items-container{display:block;width:100%}.pagination{display:flex;justify-content:center;align-items:center;gap:8px;margin-top:24px;padding-top:16px;border-top:1px solid #e0e4ea}.pagination-btn{padding:8px 16px;background-color:#304255;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:600;transition:all .2s ease}.pagination-btn:hover:not(:disabled){background-color:#425566}.pagination-btn:disabled{background-color:#d0d4da;cursor:not-allowed;opacity:.5}.pagination-numbers{display:flex;gap:4px;align-items:center}.pagination-number{min-width:36px;height:36px;padding:0 8px;background-color:#e0e4ea;color:#304255;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:600;transition:all .2s ease}.pagination-number:hover{background-color:#d0d4da}.pagination-number.active{background-color:#304255;color:#fff}.pagination-dots{padding:0 4px;color:#999;font-weight:700}.search-box{width:100%;max-width:600px;margin-top:16px;position:relative}.search-input{width:100%;padding:12px 40px 12px 16px;font-size:16px;border:2px solid #e0e4ea;border-radius:8px;box-sizing:border-box;transition:border-color .2s ease}.search-input:focus{outline:none;border-color:#304255}.search-input::placeholder{color:#999}.search-clear{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:transparent;border:none;font-size:18px;color:#999;cursor:pointer;padding:4px}.search-clear:hover{color:#304255}.ap-wrap{max-width:1080px;margin:24px auto}.ap-grid{display:grid;grid-template-columns:1fr 1fr auto;gap:12px;align-items:center}.ap-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px;margin-top:12px}.ap-actions{justify-self:end;display:flex;gap:8px}.ap-input{height:36px;padding:8px 10px;font-size:15px;line-height:1.3;box-sizing:border-box;width:100%}.ap-input-num{text-align:right}.ap-table{width:100%;border-collapse:collapse;table-layout:fixed}.ap-table thead tr{background:#f5f5f5}.ap-table th,.ap-table td{padding:8px;text-align:left}.ap-col-right{display:flex;gap:10px;justify-content:flex-end;align-items:center}.ap-muted{min-width:70px;text-align:right;opacity:.6}.ap-section{margin-top:24px}@media (max-width: 768px){.ap-wrap{padding:0 12px}.ap-table .unit-col{display:none}.ap-table.table-pipe colgroup .col-spec{width:60%!important}.ap-table.table-pipe colgroup .col-price{width:40%!important}.ap-table.table-sub colgroup .col-name{width:30%!important}.ap-table.table-sub colgroup .col-spec,.ap-table.table-sub colgroup .col-price{width:35%!important}.ap-table.table-labor colgroup .col-name{width:45%!important}.ap-table.table-labor colgroup .col-price{width:55%!important}.ap-table.table-liner colgroup .col-name{width:30%!important}.ap-table.table-liner colgroup .col-spec{width:32%!important}.ap-table.table-liner colgroup .col-price{width:38%!important}.ap-table .ap-input-num{width:100px!important;min-width:80px!important;font-size:14px!important}.ap-table .ap-muted{min-width:50px!important;font-size:12px!important}.ap-grid{grid-template-columns:1fr!important}.ap-actions{justify-self:stretch!important}.list-item-wrapper{display:flex!important;align-items:center!important}.list-item{font-size:14px!important}.list-title{font-size:15px!important}.list-date{font-size:12px!important}.card.list-card>div:first-child{flex-direction:column!important}.list-item-wrapper{margin-bottom:8px}.list-date{font-size:11px!important}}
