:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Hiragino Sans,Noto Sans JP,sans-serif;line-height:1.5;font-weight:400;color:#374151;background-color:#f3f4f6;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}#root{min-height:100vh}h1,h2,h3,h4,h5,h6,p{margin:0}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer}input,select,textarea{font-family:inherit}.header{display:flex;align-items:center;justify-content:space-between;background:#fff;border-bottom:1px solid #e5e7eb;padding:0 24px;height:56px;position:sticky;top:0;z-index:100;box-shadow:0 1px 3px #00000014}.header-left{display:flex;align-items:center;gap:24px}.logo{display:flex;align-items:center;gap:8px;cursor:pointer}.logo-text{font-size:18px;font-weight:700;color:#0ea5e9;letter-spacing:-.3px}.main-nav{display:flex;align-items:center;gap:4px;height:56px}.nav-label{padding:0 16px;font-size:14px;font-weight:600;color:#0ea5e9;border-bottom:2px solid #0ea5e9;height:56px;display:flex;align-items:center}.header-center{display:flex;align-items:center;gap:4px}.header-action-btn{display:flex;align-items:center;gap:4px;background:none;border:none;padding:6px 12px;font-size:13px;color:#4b5563;cursor:pointer;border-radius:6px;transition:background .15s}.header-action-btn:hover{background:#f3f4f6}.header-right{display:flex;align-items:center;gap:12px}.user-info{display:flex;align-items:center;gap:6px;font-size:12px;color:#6b7280}.clinic-name{color:#374151;font-size:12px;max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-name{color:#374151;font-size:12px;font-weight:500}.header-divider{width:1px;height:20px;background:#d1d5db}.data-menu-wrapper{position:relative}.header-action-btn.active{background:#eff6ff;color:#1d4ed8}.chevron{transition:transform .15s}.chevron.open{transform:rotate(180deg)}.data-dropdown{position:absolute;top:calc(100% + 8px);left:0;background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 4px 16px #0000001a;min-width:180px;z-index:200;overflow:hidden}.dropdown-item{display:flex;align-items:center;gap:8px;width:100%;padding:10px 16px;background:none;border:none;font-size:14px;color:#374151;cursor:pointer;transition:background .1s;text-align:left}.dropdown-item:hover{background:#f3f4f6}.work-order-list{padding:24px}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.page-header h1{font-size:22px;font-weight:700;color:#111827;margin:0}.btn-primary{background:#1d4ed8;color:#fff;border:none;padding:10px 20px;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:background .15s}.tabs{display:flex;gap:4px;border-bottom:1px solid #e5e7eb;margin-bottom:16px}.tab-btn{position:relative;background:none;border:none;padding:10px 20px;font-size:14px;font-weight:500;color:#6b7280;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .15s;display:flex;align-items:center;gap:6px}.tab-btn:hover{color:#374151}.tab-btn.active{color:#111827;border-bottom-color:#111827;font-weight:600}.tab-badge{background:#111827;color:#fff;font-size:11px;font-weight:700;border-radius:10px;padding:1px 6px;min-width:18px;text-align:center}.list-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;flex-wrap:wrap;gap:12px}.search-box{display:flex;align-items:center;gap:8px;border:1px solid #d1d5db;border-radius:6px;padding:8px 14px;background:#fff;width:220px}.search-box svg{color:#9ca3af;flex-shrink:0}.search-box input{border:none;outline:none;font-size:14px;color:#374151;width:100%}.search-box input::placeholder{color:#9ca3af}.pagination-controls{display:flex;align-items:center;gap:12px}.total-count{font-size:13px;color:#6b7280}.pagination-buttons{display:flex;align-items:center;gap:4px}.page-btn{width:32px;height:32px;border:1px solid #d1d5db;border-radius:4px;background:#fff;font-size:13px;cursor:pointer;transition:background .15s;display:flex;align-items:center;justify-content:center}.page-btn:hover{background:#f3f4f6}.page-btn.active{background:#1d4ed8;color:#fff;border-color:#1d4ed8}.page-nav-btn{width:32px;height:32px;border:1px solid #d1d5db;border-radius:4px;background:#fff;cursor:pointer;font-size:11px;display:flex;align-items:center;justify-content:center;transition:background .15s}.page-nav-btn:hover:not(:disabled){background:#f3f4f6}.page-nav-btn:disabled{opacity:.4;cursor:not-allowed}.page-ellipsis{color:#9ca3af;font-size:13px;padding:0 2px}.view-toggle{display:flex;border:1px solid #d1d5db;border-radius:6px;overflow:hidden}.view-btn{width:36px;height:32px;background:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#9ca3af;transition:background .15s,color .15s}.view-btn:hover{background:#f3f4f6}.view-btn.active{background:#1d4ed8;color:#fff}.table-container{background:#fff;border:1px solid #e5e7eb;border-radius:8px;overflow:hidden}.work-order-table{width:100%;border-collapse:collapse;font-size:14px}.work-order-table thead tr{background:#f9fafb;border-bottom:1px solid #e5e7eb}.work-order-table th{padding:10px 12px;text-align:left;font-size:12px;font-weight:600;color:#6b7280;white-space:nowrap}.sort-btn{background:none;border:none;cursor:pointer;color:#9ca3af;font-size:11px;padding:0 2px;margin-left:2px}.sort-btn:hover{color:#374151}.order-row{cursor:pointer;border-bottom:none;transition:background .1s}.order-row:hover,.order-row.selected{background:#eff6ff}.order-row td{padding:10px 12px;color:#374151;vertical-align:middle}.delivery-row{border-bottom:1px solid #e5e7eb;background:#fafafa;cursor:pointer}.delivery-row:hover{background:#eff6ff}.delivery-row td{padding:6px 12px 8px}.delivery-status-row{display:flex;align-items:center;gap:16px;flex-wrap:wrap}.delivery-label{font-size:12px;color:#6b7280}.delivery-item{display:flex;align-items:center;gap:6px;font-size:12px;color:#6b7280}.delivery-select{border:1px solid #d1d5db;border-radius:4px;padding:2px 20px 2px 6px;font-size:12px;color:#374151;cursor:pointer;background-color:#fff;appearance:auto}.delivery-value{font-size:12px;color:#6b7280}.order-note{font-size:12px;color:#6b7280;font-style:italic}.empty-state{text-align:center;padding:60px;color:#9ca3af;font-size:14px}.grid-container{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}.order-card{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:16px;cursor:pointer;transition:box-shadow .15s,border-color .15s}.order-card:hover{border-color:#93c5fd;box-shadow:0 2px 8px #00000014}.card-header-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.card-patient-id{font-size:12px;color:#9ca3af}.card-status-badge{font-size:11px;padding:2px 8px;border-radius:12px;background:#dbeafe;color:#1d4ed8}.card-patient-name{font-size:16px;font-weight:600;color:#111827;margin-bottom:4px}.card-work-type{font-size:14px;color:#374151;margin-bottom:4px}.card-lab{font-size:12px;color:#6b7280;margin-bottom:8px}.card-dates{display:flex;flex-direction:column;gap:2px;font-size:12px;color:#6b7280;margin-bottom:8px}.card-dentist{font-size:12px;color:#374151;font-weight:500}.empty-state-grid{grid-column:1 / -1;text-align:center;padding:60px;color:#9ca3af;font-size:14px}.col-check{width:40px}.col-patient-id{width:80px}.col-patient-name{min-width:140px;white-space:nowrap}.col-lab{width:120px;white-space:nowrap}.col-work-type{width:100px}.col-delivery-type{width:90px}.col-set-date,.col-due-date,.col-request-date{width:100px;white-space:nowrap}.col-dentist{min-width:130px;white-space:nowrap}.form-page{max-width:900px;margin:0 auto;padding:24px 24px 48px}.form-page-header{display:flex;align-items:center;gap:16px;margin-bottom:20px}.form-page-header h1{font-size:20px;font-weight:700;color:#111827;margin:0}.back-btn{background:none;border:1px solid #d1d5db;border-radius:6px;padding:6px 14px;font-size:13px;color:#6b7280;cursor:pointer;transition:background .15s;flex-shrink:0}.work-order-form{display:flex;flex-direction:column;gap:12px}.form-card{background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:24px}.section-label{font-size:14px;font-weight:700;color:#111827;padding-left:10px;border-left:3px solid #1d6fa4;margin:0 0 16px;line-height:1.4}.section-label.no-mb{margin-bottom:12px}.required-badge{display:inline-block;background:#ef4444;color:#fff;font-size:10px;font-weight:700;padding:1px 5px;border-radius:3px;margin-left:5px;vertical-align:middle}.patient-row{display:flex;gap:16px;flex-wrap:wrap;align-items:flex-start}.form-group{display:flex;flex-direction:column;gap:6px;flex:0 0 180px}.patient-name-group{flex:1;min-width:160px}.form-group label{font-size:13px;font-weight:500;color:#374151}.input-with-icon{position:relative}.input-with-icon input{padding-right:34px;width:100%;box-sizing:border-box}.input-icon{position:absolute;right:10px;top:50%;transform:translateY(-50%);color:#9ca3af;pointer-events:none;display:flex;align-items:center}.form-hint{font-size:12px;color:#6b7280;margin:8px 0 0}.link-text{color:#1d6fa4;cursor:pointer;text-decoration:underline}input[type=text],input[type=date],select,textarea{border:1px solid #d1d5db;border-radius:6px;padding:8px 10px;font-size:14px;color:#374151;outline:none;background:#fff;transition:border-color .15s;width:100%;box-sizing:border-box;font-family:inherit}input:focus,select:focus,textarea:focus{border-color:#1d6fa4;box-shadow:0 0 0 2px #1d6fa41a}input.field-error,select.field-error{border-color:#ef4444}.error-msg{font-size:12px;color:#ef4444;margin:2px 0 0}.tag-chips{display:flex;gap:8px;flex-wrap:wrap}.tag-chip-btn{padding:4px 14px;border-radius:20px;border:1px solid var(--tag-color, #d1d5db);background:transparent;color:var(--tag-color, #6b7280);font-size:13px;font-weight:600;cursor:pointer;transition:background .15s,color .15s}.tag-chip-btn.selected{background:var(--tag-color, #6b7280);color:#fff}.dentist-lab-card{display:grid;grid-template-columns:1fr 1fr;gap:32px}.info-col{min-width:0}.lab-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.lab-section-header .section-label{margin-bottom:0}.btn-change{background:#fff;border:1px solid #1d6fa4;border-radius:6px;padding:5px 12px;font-size:13px;color:#1d6fa4;cursor:pointer;display:flex;align-items:center;gap:5px;transition:background .15s;flex-shrink:0}.btn-change:hover{background:#f0f7ff}.info-table{width:100%;border-collapse:collapse}.info-table tr{border-bottom:1px solid #f3f4f6}.info-table tr:last-child{border-bottom:none}.info-table th,.info-table td{padding:9px 0;text-align:left;font-size:13px}.info-table th{color:#6b7280;font-weight:500;width:90px;padding-right:8px;vertical-align:top;white-space:nowrap}.info-table td{color:#111827;font-weight:500}.info-table td select{padding:4px 8px;font-size:13px;width:100%}.arch-menu-card{display:grid;grid-template-columns:300px 1fr;gap:28px;align-items:start}.arch-col{display:flex;flex-direction:column;align-items:center}.tooth-svg{width:100%;max-width:280px;-webkit-user-select:none;user-select:none}.tooth-g{cursor:pointer}.tooth-g:hover circle{stroke:#1d6fa4}.selected-teeth-label{font-size:12px;color:#6b7280;margin:4px 0 0;text-align:center}.menu-col{padding-top:2px}.menu-sub-label{font-size:13px;font-weight:600;color:#374151;margin:0 0 10px;display:flex;align-items:center}.work-type-grid{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.work-type-btn{padding:7px 16px;border:1px solid #1d6fa4;border-radius:6px;background:#fff;color:#1d6fa4;font-size:14px;cursor:pointer;transition:background .15s,color .15s;white-space:nowrap;width:auto}.work-type-btn:hover{background:#f0f7ff}.work-type-btn.selected{background:#1d6fa4;color:#fff}.cascade-menu{display:flex;flex-direction:column;gap:16px;margin-bottom:20px}.cascade-level{display:flex;flex-direction:column;gap:8px}.cascade-section-label{font-size:14px;font-weight:700;color:#111827;padding-left:10px;border-left:3px solid #1d6fa4;margin:0;line-height:1.4}.cascade-btns{display:flex;flex-wrap:wrap;gap:6px}.cascade-btn{padding:6px 16px;border:1px solid #d1d5db;border-radius:6px;background:#fff;color:#374151;font-size:13px;cursor:pointer;transition:background .15s,color .15s,border-color .15s;white-space:nowrap;width:auto}.cascade-btn:hover{border-color:#1d6fa4;color:#1d6fa4}.cascade-btn.active{background:#1d6fa4;color:#fff;border-color:#1d6fa4}.tooth-grid{display:flex;flex-direction:column;gap:2px}.tooth-grid-row{display:flex;align-items:center;gap:3px}.tooth-grid-sep{width:1px;height:28px;background:#374151;flex-shrink:0;margin:0 4px}.tooth-grid-divider{height:1px;background:#374151;margin:2px 0}.tooth-num-btn{width:28px;height:28px;border:1px solid #d1d5db;border-radius:5px;background:#fff;color:#374151;font-size:13px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:background .12s,color .12s,border-color .12s;flex-shrink:0}.tooth-num-btn:hover{border-color:#1d6fa4;color:#1d6fa4}.tooth-num-btn.active{background:#1d6fa4;color:#fff;border-color:#1d6fa4}.entries-list{width:100%;display:flex;flex-direction:column;gap:6px;margin-top:12px}.entry-card{display:flex;align-items:flex-start;gap:6px;background:#f0f7ff;border:1px solid #bfdbfe;border-radius:6px;padding:8px 10px}.entry-info{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.entry-work-type{font-size:13px;font-weight:700;color:#1d6fa4}.entry-menu{font-size:12px;color:#374151;word-break:break-all}.entry-teeth{font-size:12px;color:#6b7280}.entry-delete{background:none;border:none;color:#9ca3af;font-size:16px;cursor:pointer;padding:0 2px;line-height:1;flex-shrink:0}.entry-delete:hover{color:#ef4444}.shade-grid{display:flex;flex-wrap:wrap;gap:6px}.shade-btn{padding:5px 12px;border:1px solid #d1d5db;border-radius:6px;background:#fff;color:#374151;font-size:13px;font-weight:600;cursor:pointer;transition:background .12s,color .12s,border-color .12s;min-width:44px;text-align:center}.shade-btn:hover{border-color:#1d6fa4;color:#1d6fa4}.shade-btn.active{background:#1d6fa4;color:#fff;border-color:#1d6fa4}.entry-shade{color:#1d6fa4;font-weight:600}.tooth-type-list{display:flex;flex-direction:column;gap:6px;margin-top:12px;padding:10px 12px;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px}.tooth-type-row{display:flex;align-items:center;gap:6px}.tooth-type-num{font-size:13px;font-weight:600;color:#374151;width:28px;flex-shrink:0}.tooth-type-btn{padding:3px 12px;border:1px solid #d1d5db;border-radius:5px;background:#fff;color:#374151;font-size:13px;font-weight:600;cursor:pointer;transition:background .12s,color .12s,border-color .12s}.tooth-type-btn:hover{border-color:#1d6fa4;color:#1d6fa4}.tooth-type-btn.active{background:#1d6fa4;color:#fff;border-color:#1d6fa4}.btn-register{background:#1d6fa4;color:#fff;border:none;border-radius:6px;padding:10px 40px;font-size:15px;font-weight:600;cursor:pointer;transition:background .15s}.btn-register:hover{background:#175d8a}.dates-area{display:flex;flex-direction:column;gap:14px;border-top:1px solid #f3f4f6;padding-top:16px}.datetime-group{display:flex;flex-direction:column;gap:6px}.dt-label{font-size:13px;font-weight:600;color:#374151}.datetime-inputs{display:flex;gap:8px;flex-wrap:wrap}.datetime-inputs input[type=date]{flex:1;min-width:130px;max-width:170px}.datetime-inputs input[type=text]{flex:0 0 110px}.delivery-type-buttons{display:flex;gap:8px;flex-wrap:wrap}.delivery-btn{padding:8px 22px;border:1px solid #d1d5db;border-radius:6px;background:#fff;color:#374151;font-size:14px;cursor:pointer;min-width:80px;text-align:center;transition:all .15s;width:auto}.delivery-btn:hover{border-color:#1d6fa4;color:#1d6fa4}.delivery-btn.selected{border-color:#1d6fa4;background:#1d6fa4;color:#fff}.notes-textarea{width:100%;box-sizing:border-box;border:1px solid #d1d5db;border-radius:6px;padding:10px 12px;font-size:14px;color:#374151;resize:vertical;min-height:120px;outline:none;font-family:inherit;display:block}.notes-textarea:focus{border-color:#1d6fa4;box-shadow:0 0 0 2px #1d6fa41a}.char-count{text-align:right;font-size:12px;color:#9ca3af;margin:6px 0 0}.upload-card{padding:18px 24px}.upload-label{font-size:13px;font-weight:600;color:#374151;margin:0 0 10px}.upload-row{display:flex;align-items:center;gap:10px}.btn-upload{background:#fff;border:1px solid #d1d5db;border-radius:6px;padding:8px 18px;font-size:13px;color:#374151;cursor:pointer;display:flex;align-items:center;gap:6px;transition:background .15s;width:auto}.btn-upload:hover{background:#f3f4f6}.upload-info-icon{color:#9ca3af;font-size:16px}.notes-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px;flex-wrap:wrap}.notes-header .section-label{margin-bottom:0;flex-shrink:0}.template-panel-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border:1px solid #1d6fa4;border-radius:6px;background:#fff;color:#1d6fa4;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s;white-space:nowrap;flex-shrink:0}.template-panel-btn:hover{background:#f0f7ff}.tpl-overlay{position:fixed;inset:0;z-index:200}.tpl-panel{position:fixed;top:0;right:0;width:360px;height:100vh;background:#fff;border-left:1px solid #e5e7eb;box-shadow:-4px 0 20px #0000001a;z-index:201;display:flex;flex-direction:column;overflow:hidden}.tpl-panel-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid #e5e7eb;flex-shrink:0}.tpl-panel-title{font-size:15px;font-weight:700;color:#111827}.tpl-close-btn{background:none;border:none;font-size:20px;color:#6b7280;cursor:pointer;line-height:1;padding:2px 6px;border-radius:4px}.tpl-close-btn:hover{background:#f3f4f6}.tpl-list{flex:1;overflow-y:auto;padding:8px 0}.tpl-empty{padding:40px 20px;text-align:center;color:#9ca3af;font-size:13px}.tpl-item{display:flex;align-items:flex-start;gap:8px;padding:14px 16px;border-bottom:1px solid #f3f4f6}.tpl-item:last-child{border-bottom:none}.tpl-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.tpl-item-title{font-size:14px;font-weight:600;color:#111827;word-break:break-word}.tpl-item-text{font-size:12px;color:#6b7280;white-space:pre-wrap;word-break:break-word}.tpl-select-btn{padding:5px 14px;background:#1d6fa4;color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:background .15s}.tpl-select-btn:hover{background:#175d8a}.tpl-icon-btn{background:none;border:1px solid #e5e7eb;border-radius:6px;padding:5px 8px;color:#6b7280;cursor:pointer;display:flex;align-items:center;flex-shrink:0;transition:background .15s}.tpl-icon-btn:hover{background:#f3f4f6}.tpl-icon-btn.danger{color:#ef4444;border-color:#fca5a5}.tpl-icon-btn.danger:hover{background:#fef2f2}.tpl-edit-form{flex:1;display:flex;flex-direction:column;gap:8px}.tpl-edit-form input,.tpl-edit-form textarea{border:1px solid #d1d5db;border-radius:6px;padding:7px 10px;font-size:13px;outline:none;font-family:inherit;width:100%;box-sizing:border-box}.tpl-edit-form input:focus,.tpl-edit-form textarea:focus{border-color:#1d6fa4}.tpl-edit-form textarea{resize:vertical}.tpl-edit-actions{display:flex;gap:6px}.tpl-save-btn{background:#1d6fa4;color:#fff;border:none;border-radius:6px;padding:6px 14px;font-size:13px;font-weight:600;cursor:pointer}.tpl-save-btn:hover{background:#175d8a}.tpl-cancel-btn{background:#fff;color:#6b7280;border:1px solid #d1d5db;border-radius:6px;padding:6px 14px;font-size:13px;cursor:pointer}.tpl-cancel-btn:hover{background:#f3f4f6}.memo-tab-header{margin-bottom:0}.memo-tab{display:inline-block;background:#1d6fa4;color:#fff;font-size:12px;font-weight:600;padding:5px 14px;border-radius:6px 6px 0 0}.memo-textarea{width:100%;box-sizing:border-box;border:1px solid #d1d5db;border-radius:0 6px 6px;padding:10px 12px;font-size:14px;color:#374151;resize:vertical;min-height:100px;outline:none;font-family:inherit;display:block}.memo-textarea:focus{border-color:#1d6fa4;box-shadow:0 0 0 2px #1d6fa41a}.checkbox-label{display:flex;align-items:center;gap:6px;font-size:13px;color:#6b7280;cursor:pointer;margin-top:10px}.checkbox-label input[type=checkbox]{width:15px;height:15px;cursor:pointer;accent-color:#1d6fa4;flex-shrink:0;padding:0;border:none;box-shadow:none}.form-actions{display:flex;justify-content:center;gap:12px;padding:8px 0}.btn-draft{background:#fff;color:#374151;border:1px solid #d1d5db;padding:12px 0;border-radius:6px;font-size:15px;font-weight:500;cursor:pointer;min-width:160px;transition:background .15s;width:auto}.btn-draft:hover{background:#f3f4f6}.btn-request{background:#1d6fa4;color:#fff;border:none;padding:12px 0;border-radius:6px;font-size:15px;font-weight:600;cursor:pointer;min-width:160px;transition:background .15s;width:auto}.btn-request:hover{background:#175d8a}.patient-select-row{display:flex;align-items:center;gap:8px;margin-bottom:12px;flex-wrap:wrap}.patient-select{flex:1;min-width:0;border:1px solid #d1d5db;border-radius:6px;padding:8px 10px;font-size:14px;color:#374151;background:#fff}.btn-patient-action{background:#fff;border:1px solid #d1d5db;border-radius:6px;padding:7px 14px;font-size:13px;color:#374151;cursor:pointer;white-space:nowrap;transition:background .15s}.btn-patient-action:hover{background:#f3f4f6}.patient-inline-form{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:14px;margin-bottom:14px;display:flex;gap:12px;align-items:flex-start;flex-wrap:wrap}.patient-inline-fields{display:flex;gap:8px;flex:1;min-width:0;flex-wrap:wrap}.patient-inline-fields input{border:1px solid #d1d5db;border-radius:6px;padding:7px 10px;font-size:14px;color:#374151;outline:none;flex:1;min-width:120px}.patient-inline-fields input:focus{border-color:#1d6fa4;box-shadow:0 0 0 2px #1d6fa41a}.patient-inline-actions{display:flex;gap:6px;flex-shrink:0}@media(max-width:700px){.dentist-lab-card{grid-template-columns:1fr;gap:20px}.arch-menu-card{grid-template-columns:1fr}.arch-col{max-width:260px;margin:0 auto}}.detail-page{max-width:800px;margin:0 auto;padding:24px}.detail-page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;flex-wrap:wrap;gap:12px}.detail-header-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.status-badge{font-size:12px;font-weight:600;padding:4px 12px;border-radius:12px}.detail-content{display:flex;flex-direction:column;gap:16px}.detail-card{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:24px}.section-title{font-size:15px;font-weight:700;color:#111827;margin:0 0 16px;padding-bottom:10px;border-bottom:1px solid #f3f4f6}.detail-list{display:flex;flex-direction:column;gap:12px;margin:0}.detail-row{display:grid;grid-template-columns:140px 1fr;gap:8px;align-items:start}.detail-row dt{font-size:13px;font-weight:500;color:#6b7280}.detail-row dd{font-size:14px;color:#111827;margin:0}.delivery-badge{font-size:12px;padding:2px 10px;border-radius:4px;background:#f3f4f6;color:#6b7280}.delivery-badge.sent{background:#d1fae5;color:#065f46}.detail-notes{font-size:14px;color:#374151;line-height:1.6;white-space:pre-wrap;margin:0}.detail-meta{background:#f9fafb;border-color:#e5e7eb}.detail-meta p{font-size:12px;color:#9ca3af;margin:0 0 4px}.detail-meta p:last-child{margin:0}.btn-primary{background:#1d4ed8;color:#fff;border:none;padding:8px 18px;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s}.btn-secondary{background:#fff;color:#374151;border:1px solid #d1d5db;padding:8px 18px;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:background .15s}.btn-secondary:hover{background:#f3f4f6}.btn-archive{background:#f3f4f6;color:#374151;border:1px solid #d1d5db;padding:8px 18px;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:background .15s}.btn-archive:hover{background:#e5e7eb}.btn-danger{background:#fff;color:#ef4444;border:1px solid #fca5a5;padding:8px 18px;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:background .15s}.confirm-overlay{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:200}.confirm-dialog{background:#fff;border-radius:12px;padding:32px;max-width:360px;width:90%;text-align:center;box-shadow:0 20px 40px #00000026}.confirm-dialog h3{font-size:18px;font-weight:700;color:#111827;margin:0 0 8px}.confirm-dialog p{font-size:14px;color:#6b7280;margin:0 0 24px}.dashboard{padding:24px;max-width:1100px;margin:0 auto}.dashboard-header{display:flex;align-items:center;gap:16px;margin-bottom:24px;flex-wrap:wrap}.dashboard-header h1{font-size:22px;font-weight:700;color:#111827;margin:0;flex:1}.period-selector{display:flex;border:1px solid #d1d5db;border-radius:6px;overflow:hidden}.period-btn{background:#fff;border:none;padding:6px 16px;font-size:13px;color:#6b7280;cursor:pointer;transition:background .15s,color .15s;border-right:1px solid #d1d5db}.period-btn:last-child{border-right:none}.period-btn:hover{background:#f3f4f6}.period-btn.active{background:#1d4ed8;color:#fff}.summary-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}@media(max-width:700px){.summary-cards{grid-template-columns:repeat(2,1fr)}}.summary-card{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:20px;text-align:center}.summary-label{font-size:13px;color:#6b7280;margin:0 0 8px}.summary-value{font-size:36px;font-weight:700;color:#111827;margin:0;line-height:1}.summary-value.remake{color:#ef4444}.summary-unit{font-size:16px;font-weight:400;color:#6b7280;margin-left:4px}.charts-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.chart-card{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:20px}.chart-wide{grid-column:1 / -1}.chart-title{font-size:15px;font-weight:700;color:#111827;margin:0 0 16px}.chart-empty{height:240px;display:flex;align-items:center;justify-content:center;color:#9ca3af;font-size:14px}@media(max-width:700px){.charts-grid{grid-template-columns:1fr}.chart-wide{grid-column:1}}.wm-tabs{display:flex;gap:0;margin-bottom:16px;background:#f3f4f6;border-radius:8px;padding:4px;width:fit-content}.wm-tab{background:none;border:none;padding:8px 28px;font-size:14px;font-weight:500;color:#6b7280;cursor:pointer;border-radius:6px;transition:background .15s,color .15s;white-space:nowrap}.wm-tab:hover{color:#374151}.wm-tab.active{background:#fff;color:#111827;font-weight:700;box-shadow:0 1px 4px #0000001a}.wm-table-card{background:#fff;border:1px solid #e5e7eb;border-radius:10px;overflow:hidden}.wm-table-header{display:flex;justify-content:space-between;align-items:center;padding:10px 20px;background:#f0f0f0;font-size:13px;font-weight:600;color:#6b7280;border-bottom:1px solid #e5e7eb}.wm-table-body{display:flex;flex-direction:column}.wm-row{display:flex;align-items:center;justify-content:space-between;padding:10px 20px;border-bottom:1px solid #f3f4f6;min-height:44px}.wm-row:last-child{border-bottom:none}.wm-row.depth-0{background:#fafafa;padding-left:20px}.wm-row.depth-1{padding-left:36px}.wm-row.depth-2{padding-left:56px}.wm-row.depth-3{padding-left:76px}.wm-group.depth-0{font-weight:700;font-size:14px;color:#111827}.wm-group.depth-1{font-size:13px;color:#374151}.wm-group.depth-2{font-size:12px;color:#6b7280}.wm-label{font-size:inherit;color:#374151;display:flex;align-items:center;gap:0;flex:1;min-width:0}.wm-group.depth-0 .wm-label{font-weight:700;color:#111827}.wm-group.depth-1 .wm-label{color:#374151}.wm-group.depth-2 .wm-label{color:#6b7280}.wm-prefix{color:#9ca3af;font-size:13px;margin-right:2px;font-family:monospace}.toggle-switch{display:flex;align-items:center;width:56px;height:26px;border-radius:13px;position:relative;cursor:pointer;transition:background .2s;flex-shrink:0;-webkit-user-select:none;user-select:none}.toggle-switch.on{background:#0c7bb3}.toggle-switch.off{background:#d1d5db}.toggle-label{position:absolute;font-size:10px;font-weight:700;color:#fff;transition:left .2s;line-height:1;pointer-events:none}.toggle-switch.on .toggle-label{left:7px}.toggle-switch.off .toggle-label{left:8px;color:#9ca3af}.toggle-thumb{position:absolute;width:20px;height:20px;border-radius:50%;background:#fff;box-shadow:0 1px 4px #00000040;transition:left .2s;pointer-events:none}.toggle-switch.on .toggle-thumb{left:33px}.toggle-switch.off .toggle-thumb{left:3px}.settings-page{padding:24px;max-width:720px;margin:0 auto}.settings-header{display:flex;align-items:center;gap:16px;margin-bottom:28px;flex-wrap:wrap}.settings-header h1{font-size:22px;font-weight:700;color:#111827;margin:0;flex:1}.back-btn{background:none;border:1px solid #d1d5db;border-radius:6px;padding:6px 14px;font-size:13px;color:#6b7280;cursor:pointer;transition:background .15s}.back-btn:hover{background:#f3f4f6}.btn-primary{background:#1d4ed8;color:#fff;border:none;padding:8px 18px;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:background .15s}.btn-primary:hover{background:#1e40af}.settings-sections{display:flex;flex-direction:column;gap:16px}.settings-card{background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:24px}.settings-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:16px}.settings-card-header>div{flex:1;min-width:0}.settings-card-header h2{font-size:15px;font-weight:700;color:#111827;margin:0 0 4px;word-break:break-word}.settings-card-header p{font-size:13px;color:#6b7280;margin:0;word-break:break-word}.settings-nav-btn{background:none;border:1px solid #d1d5db;border-radius:6px;padding:7px 14px;font-size:13px;color:#374151;cursor:pointer;white-space:nowrap;transition:background .15s}.settings-nav-btn:hover{background:#f3f4f6}.tag-preview{display:flex;flex-wrap:wrap;gap:8px}.tag-chip{display:inline-flex;align-items:center;font-size:12px;font-weight:600;padding:4px 10px;border-radius:20px;border:1px solid}.settings-card-clickable{cursor:pointer;transition:box-shadow .15s,border-color .15s}.settings-card-clickable:hover{border-color:#93c5fd;box-shadow:0 2px 8px #0000000f}.settings-nav-arrow{font-size:18px;color:#9ca3af;flex-shrink:0}.wm-tab-preview{display:flex;gap:8px;flex-wrap:wrap}.wm-tab-chip{background:#f3f4f6;border:1px solid #e5e7eb;border-radius:6px;padding:4px 14px;font-size:13px;font-weight:500;color:#374151}.tags-editor{background:#fff;border:1px solid #e5e7eb;border-radius:10px;overflow:hidden}.tag-row{border-bottom:1px solid #f3f4f6}.tag-row:last-child{border-bottom:none}.tag-display-row{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;gap:12px}.tag-chip-lg{display:inline-flex;align-items:center;gap:8px;font-size:14px;font-weight:600;padding:5px 14px;border-radius:20px;border:1px solid}.tag-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.tag-row-actions{display:flex;gap:8px}.tag-action-btn{background:none;border:1px solid #e5e7eb;border-radius:6px;padding:5px 14px;font-size:13px;color:#374151;cursor:pointer;transition:background .15s}.tag-action-btn:hover{background:#f3f4f6}.tag-action-btn.danger{color:#ef4444;border-color:#fca5a5}.tag-action-btn.danger:hover{background:#fef2f2}.tag-edit-row{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;gap:16px;background:#f9fafb}.add-row{border-bottom:1px solid #e5e7eb}.tag-edit-left{display:flex;flex-direction:column;gap:10px;flex:1;min-width:0}.color-picker{display:flex;gap:6px;flex-wrap:wrap}.color-dot{width:22px;height:22px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:transform .1s,border-color .1s;padding:0}.color-dot:hover{transform:scale(1.2)}.color-dot.selected{border-color:#fff;box-shadow:0 0 0 2px #374151;transform:scale(1.15)}.tag-name-input{border:1px solid #d1d5db;border-radius:6px;padding:7px 12px;font-size:14px;color:#374151;outline:none;width:100%;max-width:300px}.tag-name-input:focus{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f61f}.tag-edit-actions{display:flex;flex-direction:column;gap:6px;flex-shrink:0}.btn-save{background:#1d4ed8;color:#fff;border:none;border-radius:6px;padding:7px 16px;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s}.btn-save:hover:not(:disabled){background:#1e40af}.btn-save:disabled{opacity:.5;cursor:not-allowed}.btn-cancel{background:#fff;color:#6b7280;border:1px solid #d1d5db;border-radius:6px;padding:7px 16px;font-size:13px;cursor:pointer;transition:background .15s}.btn-cancel:hover{background:#f3f4f6}.tags-empty{padding:48px;text-align:center;color:#9ca3af;font-size:14px}.modal-overlay{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:300;padding:16px}.confirm-dialog{background:#fff;border-radius:12px;padding:32px;max-width:380px;width:100%;box-shadow:0 20px 40px #00000026;text-align:center}.confirm-dialog h3{font-size:17px;font-weight:700;color:#111827;margin:0 0 10px}.confirm-dialog p{font-size:14px;color:#6b7280;margin:0 0 24px;line-height:1.6}.confirm-actions{display:flex;gap:12px;justify-content:center}.btn-cancel-lg{background:#fff;color:#374151;border:1px solid #d1d5db;border-radius:6px;padding:9px 20px;font-size:14px;cursor:pointer;transition:background .15s}.btn-cancel-lg:hover{background:#f3f4f6}.btn-danger{background:#fff;color:#ef4444;border:1px solid #fca5a5;border-radius:6px;padding:9px 20px;font-size:14px;cursor:pointer;transition:background .15s}.btn-danger:hover{background:#fef2f2}.dentist-preview{display:flex;flex-wrap:wrap;gap:8px}.dentist-preview-chip{background:#f3f4f6;border:1px solid #e5e7eb;border-radius:6px;padding:5px 14px;font-size:13px;font-weight:500;color:#374151}.dentist-preview-empty{font-size:13px;color:#9ca3af}.dentist-editor{background:#fff;border:1px solid #e5e7eb;border-radius:10px;overflow:hidden}.dentist-row{border-bottom:1px solid #f3f4f6}.dentist-row:last-child{border-bottom:none}.dentist-display-row{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;gap:12px}.dentist-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.dentist-name{font-size:14px;font-weight:600;color:#111827;display:block}.dentist-sub{font-size:12px;color:#6b7280;display:block}.dentist-edit-row{padding:16px 20px;background:#f9fafb;border-bottom:1px solid #e5e7eb}.dentist-edit-fields{display:flex;flex-direction:column;gap:10px;margin-bottom:12px}.dentist-edit-fields input{border:1px solid #d1d5db;border-radius:6px;padding:7px 12px;font-size:14px;color:#374151;outline:none;width:100%}.dentist-edit-fields input:focus{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f61f}.dentist-edit-fields input::placeholder{color:#9ca3af}.dentist-empty{padding:48px;text-align:center;color:#9ca3af;font-size:14px}.template-edit-form{display:flex;flex-direction:column;gap:8px;width:100%}.template-edit-form input{border:1px solid #d1d5db;border-radius:6px;padding:8px 10px;font-size:14px;outline:none;font-family:inherit}.template-edit-form input:focus{border-color:#1d6fa4}.template-edit-form textarea{border:1px solid #d1d5db;border-radius:6px;padding:8px 10px;font-size:14px;resize:vertical;outline:none;font-family:inherit}.template-edit-form textarea:focus{border-color:#1d6fa4}.template-info{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.template-title{font-size:14px;font-weight:600;color:#111827}.template-text-preview{font-size:12px;color:#6b7280;white-space:pre-wrap;word-break:break-all}*{box-sizing:border-box}.app{min-height:100vh;background:#f3f4f6;display:flex;flex-direction:column}.main-content{flex:1;overflow-y:auto}.notification{position:fixed;bottom:24px;right:24px;background:#111827;color:#fff;padding:12px 20px;border-radius:8px;font-size:14px;display:flex;align-items:center;gap:8px;box-shadow:0 4px 12px #0003;z-index:300;animation:slideUp .2s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
