:root{--bg: #f7f8fa;--surface: #ffffff;--surface-2: #fafbfc;--text-1: #1a1f2e;--text-2: #6b7280;--text-3: #9ca3af;--border: #e5e7eb;--border-strong: #d1d5db;--primary: #2563eb;--primary-600: #1d4ed8;--primary-50: #eff6ff;--primary-100: #dbeafe;--success: #16a34a;--success-50: #f0fdf4;--success-100: #dcfce7;--warning: #f59e0b;--warning-50: #fffbeb;--warning-100: #fef3c7;--error: #dc2626;--error-50: #fef2f2;--error-100: #fee2e2;--shadow-sm: 0 1px 2px rgba(15, 23, 42, .04), 0 1px 3px rgba(15, 23, 42, .06);--shadow-md: 0 4px 12px rgba(15, 23, 42, .06), 0 2px 4px rgba(15, 23, 42, .04);--shadow-lg: 0 12px 32px rgba(15, 23, 42, .1), 0 4px 8px rgba(15, 23, 42, .04);--radius-sm: 6px;--radius: 8px;--radius-lg: 12px;--radius-xl: 16px}*,*:before,*:after{box-sizing:border-box}html,body,#root{height:100%;margin:0;padding:0}body{font-family:Manrope,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-feature-settings:"cv11","ss01","ss03";color:var(--text-1);background:var(--bg);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}button{font:inherit;cursor:pointer;border:0;background:transparent;color:inherit;padding:0}input,textarea,select{font:inherit;color:inherit}a{color:inherit;text-decoration:none}input:focus-visible,textarea:focus-visible,select:focus-visible,button:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:9px 14px;border-radius:7px;font-size:13.5px;font-weight:600;letter-spacing:-.005em;transition:background .12s,border-color .12s,color .12s;white-space:nowrap;border:1px solid transparent}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-600)}.btn-secondary{background:var(--surface);border-color:var(--border-strong);color:var(--text-1)}.btn-secondary:hover:not(:disabled){background:#f9fafb;border-color:#b0b5bd}.btn-ghost{color:var(--text-2);padding:9px 10px}.btn-ghost:hover:not(:disabled){background:#f3f4f6;color:var(--text-1)}.btn-danger{background:var(--error);color:#fff}.btn-danger:hover:not(:disabled){background:#b91c1c}.btn-sm{padding:6px 10px;font-size:12.5px;border-radius:6px}.btn-lg{padding:11px 18px;font-size:14px}.btn-block{width:100%}.field{display:flex;flex-direction:column;gap:6px}.field-label{font-size:12.5px;font-weight:600;color:var(--text-1);letter-spacing:-.005em}.field-help{font-size:11.5px;color:var(--text-2)}.field-error{font-size:11.5px;color:var(--error);display:flex;align-items:center;gap:4px}.input,.select,.textarea{width:100%;padding:9px 12px;border-radius:7px;border:1px solid var(--border-strong);background:var(--surface);font-size:13.5px;transition:border-color .12s,box-shadow .12s}.input:hover,.select:hover,.textarea:hover{border-color:#a0a6b0}.input:focus,.select:focus,.textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb26}.input.has-error{border-color:var(--error)}.input.has-error:focus{box-shadow:0 0 0 3px #dc262626}.input-with-icon{position:relative}.input-with-icon .input{padding-left:36px}.input-with-icon .input.right-icon{padding-right:36px;padding-left:12px}.input-with-icon .icon-left,.input-with-icon .icon-right{position:absolute;top:50%;transform:translateY(-50%);color:var(--text-3);display:grid;place-items:center}.input-with-icon .icon-left{left:11px}.input-with-icon .icon-right{right:11px;cursor:pointer}.input-with-icon .icon-right:hover{color:var(--text-1)}.select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236B7280' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}.textarea{resize:vertical;min-height:96px;line-height:1.5;font-family:inherit}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.card-header{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:12px}.card-title{font-size:15px;font-weight:700;letter-spacing:-.01em}.card-body{padding:20px}.card-body.flush{padding:0}.badge{display:inline-flex;align-items:center;gap:5px;padding:2px 8px;border-radius:999px;font-size:11.5px;font-weight:600;letter-spacing:-.005em;white-space:nowrap}.badge .dot{width:6px;height:6px;border-radius:50%}.badge-success{background:var(--success-50);color:#15803d}.badge-success .dot{background:var(--success)}.badge-warning{background:var(--warning-50);color:#b45309}.badge-warning .dot{background:var(--warning)}.badge-error{background:var(--error-50);color:#b91c1c}.badge-error .dot{background:var(--error)}.badge-primary{background:var(--primary-50);color:var(--primary-600)}.badge-primary .dot{background:var(--primary)}.badge-neutral{background:#f3f4f6;color:#4b5563}.badge-neutral .dot{background:#9ca3af}.avatar{width:32px;height:32px;border-radius:50%;display:grid;place-items:center;font-weight:600;font-size:12px;color:#fff;flex-shrink:0}.toggle{position:relative;width:36px;height:20px;background:#d1d5db;border-radius:999px;transition:background .15s;flex-shrink:0}.toggle:after{content:"";position:absolute;top:2px;left:2px;width:16px;height:16px;background:#fff;border-radius:50%;box-shadow:0 1px 2px #00000026;transition:transform .15s}.toggle.on{background:var(--primary)}.toggle.on:after{transform:translate(16px)}.toggle.on.success{background:var(--success)}.cbox{width:18px;height:18px;border-radius:5px;border:1.5px solid var(--border-strong);background:var(--surface);display:grid;place-items:center;transition:background .1s,border-color .1s;flex-shrink:0}.cbox.checked{background:var(--success);border-color:var(--success)}.cbox.checked.primary{background:var(--primary);border-color:var(--primary)}.cbox svg{opacity:0}.cbox.checked svg{opacity:1;color:#fff}.tbl{width:100%;border-collapse:collapse;font-size:13px}.tbl thead th{text-align:left;font-weight:600;font-size:11.5px;text-transform:uppercase;letter-spacing:.04em;color:var(--text-2);padding:11px 14px;border-bottom:1px solid var(--border);background:var(--surface-2);white-space:nowrap}.tbl tbody td{padding:13px 14px;border-bottom:1px solid var(--border);vertical-align:middle}.tbl tbody tr:last-child td{border-bottom:0}.tbl tbody tr:hover td{background:#fafbfc}.tbl tbody td.confirmed-cell{background:#16a34a0d}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}@media (max-width: 768px){.kpi-grid{grid-template-columns:repeat(2,1fr)}}.kpi{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px 18px}.kpi-label{font-size:12px;color:var(--text-2);font-weight:500}.kpi-value{font-size:26px;font-weight:700;letter-spacing:-.025em;margin-top:4px}.kpi-delta{font-size:11.5px;color:var(--text-2);margin-top:2px;display:flex;align-items:center;gap:4px}.kpi-delta.pos{color:var(--success)}.toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%);background:#111827;color:#fff;padding:10px 16px 10px 12px;border-radius:10px;display:flex;align-items:center;gap:9px;font-size:13px;font-weight:500;box-shadow:var(--shadow-lg);z-index:50;animation:toast-in .25s ease-out}@keyframes toast-in{0%{transform:translate(-50%,10px);opacity:0}to{transform:translate(-50%);opacity:1}}.toast .check{background:var(--success);width:20px;height:20px;border-radius:50%;display:grid;place-items:center}.toast.error{background:var(--error)}.toast.error .check{background:#0003}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#11182773;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:grid;place-items:center;z-index:40;animation:fade-in .18s ease-out}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.modal{width:560px;max-width:calc(100% - 48px);background:var(--surface);border-radius:14px;box-shadow:var(--shadow-lg);overflow:hidden;animation:modal-in .22s cubic-bezier(.2,.7,.3,1)}@keyframes modal-in{0%{transform:translateY(8px) scale(.98);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.modal-header{padding:18px 22px 14px;display:flex;align-items:flex-start;justify-content:space-between;gap:12px;border-bottom:1px solid var(--border)}.modal-title{font-size:16px;font-weight:700;letter-spacing:-.01em}.modal-subtitle{font-size:12.5px;color:var(--text-2);margin-top:2px}.modal-close{width:28px;height:28px;border-radius:6px;display:grid;place-items:center;color:var(--text-2)}.modal-close:hover{background:#f3f4f6;color:var(--text-1)}.modal-body{padding:20px 22px;max-height:65vh;overflow:auto}.modal-footer{padding:14px 22px;border-top:1px solid var(--border);background:var(--surface-2);display:flex;align-items:center;justify-content:flex-end;gap:8px}.drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#11182773;z-index:40}.drawer{position:fixed;top:0;right:0;bottom:0;width:460px;max-width:100vw;background:var(--surface);box-shadow:-10px 0 30px #0f172a1a;display:flex;flex-direction:column;animation:drawer-in .25s cubic-bezier(.2,.7,.3,1);z-index:45}@keyframes drawer-in{0%{transform:translate(20px);opacity:0}to{transform:translate(0);opacity:1}}.bottomsheet-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#11182780;z-index:40;display:flex;align-items:flex-end;animation:fade-in .18s ease-out}.bottomsheet{width:100%;background:var(--surface);border-radius:18px 18px 0 0;max-height:92%;display:flex;flex-direction:column;animation:sheet-in .28s cubic-bezier(.2,.7,.3,1)}@keyframes sheet-in{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.sheet-handle{width:36px;height:4px;background:#d1d5db;border-radius:999px;margin:10px auto 0}.sheet-header{padding:12px 18px 14px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.sheet-title{font-size:17px;font-weight:700;letter-spacing:-.015em}.sheet-body{padding:16px 18px;overflow:auto;flex:1}.sheet-footer{padding:12px 18px 22px;border-top:1px solid var(--border);display:flex;gap:10px}.sheet-footer .m-btn{flex:1}.skel{background:linear-gradient(90deg,#f3f4f6,#e5e7eb,#f3f4f6);background-size:200% 100%;animation:skel 1.4s ease-in-out infinite;border-radius:6px}@keyframes skel{0%{background-position:200% 0}to{background-position:-200% 0}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:64px 24px;text-align:center}.empty-illu{width:96px;height:96px;border-radius:24px;background:linear-gradient(135deg,#f3f4f6,#e5e7eb);display:grid;place-items:center;color:var(--text-3);margin-bottom:16px}.empty-title{font-size:15px;font-weight:700}.empty-desc{font-size:13px;color:var(--text-2);margin-top:4px;max-width:320px}.app-shell{display:flex;height:100vh;overflow:hidden}.app-shell .main{flex:1;display:flex;flex-direction:column;min-width:0}.sidebar{width:240px;flex:0 0 240px;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;height:100%}.sidebar-brand{padding:22px 20px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--border)}.brand-mark{width:32px;height:32px;border-radius:8px;background:linear-gradient(135deg,#1a1f2e,#2a3a5f);display:grid;place-items:center;color:#fff;font-weight:700;font-size:13px;letter-spacing:-.02em;position:relative}.brand-mark:after{content:"";position:absolute;top:4px;right:4px;bottom:4px;left:4px;border:1.5px solid rgba(255,255,255,.35);border-radius:5px}.brand-text{display:flex;flex-direction:column;line-height:1.15}.brand-text .b1{font-weight:700;font-size:14px;letter-spacing:-.01em}.brand-text .b2{font-size:11px;color:var(--text-2);font-weight:500;letter-spacing:.02em;text-transform:uppercase}.sidebar-nav{padding:16px 12px;flex:1}.nav-label{font-size:10.5px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-3);padding:12px 12px 6px;display:flex;align-items:center;gap:8px}.nav-label .admin-pill{background:var(--primary-50);color:var(--primary);border-radius:4px;padding:1px 5px;font-size:9px;letter-spacing:.04em}.nav-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:7px;font-size:13.5px;font-weight:500;color:var(--text-1);cursor:pointer;transition:background .12s;width:100%;text-align:left}.nav-item:hover{background:#f3f4f6}.nav-item.active{background:var(--primary-50);color:var(--primary)}.nav-item.active svg{color:var(--primary)}.nav-item svg{color:var(--text-2);flex-shrink:0}.nav-divider{height:1px;background:var(--border);margin:14px 12px}.sidebar-account{border-top:1px solid var(--border);padding:12px;display:flex;align-items:center;gap:10px}.account-info{flex:1;min-width:0}.account-info .name{font-weight:600;font-size:13px}.account-info .role{font-size:11.5px;color:var(--text-2)}.page-header{padding:20px 32px 18px;border-bottom:1px solid var(--border);background:var(--surface);display:flex;align-items:flex-start;justify-content:space-between;gap:16px}@media (max-width: 768px){.page-header{padding:14px 16px}}.breadcrumb{font-size:12px;color:var(--text-2);display:flex;align-items:center;gap:6px;margin-bottom:6px}.breadcrumb .sep{color:var(--text-3)}.page-title{font-size:22px;font-weight:700;letter-spacing:-.015em}.page-subtitle{font-size:13.5px;color:var(--text-2);margin-top:2px}.page-content{flex:1;overflow:auto;padding:24px 32px;background:var(--bg)}@media (max-width: 768px){.page-content{padding:16px 16px 96px}}.m-bottomnav{position:fixed;bottom:0;left:0;right:0;background:var(--surface);border-top:1px solid var(--border);padding:8px 6px 18px;display:flex;justify-content:space-around;z-index:20}.m-bnav-item{display:flex;flex-direction:column;align-items:center;gap:3px;padding:6px 10px;border-radius:10px;font-size:10.5px;font-weight:600;color:var(--text-3);min-width:64px;background:transparent}.m-bnav-item.active{color:var(--primary)}.m-input,.m-select,.m-textarea{width:100%;padding:13px 14px;border-radius:10px;border:1px solid var(--border-strong);background:var(--surface);font-size:15px;font-family:inherit}.m-input:focus,.m-select:focus,.m-textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb26}.m-field-label{font-size:12.5px;font-weight:600;margin-bottom:6px;display:block}.m-textarea{resize:none;min-height:110px;line-height:1.5}.m-btn{padding:13px 18px;border-radius:11px;font-weight:700;font-size:15px;display:inline-flex;align-items:center;justify-content:center;gap:8px;width:100%;border:1px solid transparent}.m-btn:disabled{opacity:.5}.m-btn-primary{background:var(--primary);color:#fff}.m-btn-primary:active{background:var(--primary-600)}.m-btn-secondary{background:var(--surface);border-color:var(--border-strong);color:var(--text-1)}.repair-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:14px;display:flex;flex-direction:column;gap:10px;cursor:pointer}.repair-card+.repair-card{margin-top:10px}.repair-card.confirmed{background:linear-gradient(180deg,rgba(22,163,74,.04) 0%,var(--surface) 100%);border-color:#16a34a40}.repair-card-head{display:flex;align-items:center;justify-content:space-between;gap:8px}.repair-card-room{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-2)}.repair-card-title{font-size:16px;font-weight:700;letter-spacing:-.01em;line-height:1.25}.repair-card-desc{font-size:13.5px;color:var(--text-2);line-height:1.4}.repair-card-meta{display:flex;align-items:center;gap:12px;padding-top:10px;border-top:1px dashed var(--border);font-size:12px;color:var(--text-2)}.repair-card-meta-item{display:flex;align-items:center;gap:4px}.unit-selected{background:linear-gradient(135deg,#1a1f2e,#2a3a5f);color:#fff;border:0;padding:16px;border-radius:14px;display:flex;flex-direction:column;gap:8px;width:100%;text-align:left;cursor:pointer}.chip{display:inline-flex;align-items:center;gap:6px;padding:7px 12px;border-radius:999px;background:var(--surface);border:1px solid var(--border-strong);font-size:13px;font-weight:500;color:var(--text-1);white-space:nowrap}.chip.active{background:var(--text-1);color:#fff;border-color:var(--text-1)}.chip-row{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px;scrollbar-width:none}.chip-row::-webkit-scrollbar{display:none}.photo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.photo-thumb{aspect-ratio:1;border-radius:10px;background:linear-gradient(135deg,#e5e7eb,#d1d5db);position:relative;overflow:hidden;display:grid;place-items:center;color:var(--text-3)}.photo-thumb img{width:100%;height:100%;object-fit:cover}.photo-thumb.upload{background:var(--surface);border:1.5px dashed var(--border-strong);color:var(--text-2);font-size:11px;text-align:center;padding:6px;flex-direction:column;display:flex;align-items:center;justify-content:center;gap:4px;cursor:pointer}.user-row{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:12px 14px;display:flex;align-items:center;gap:12px}.user-row+.user-row{margin-top:8px}.user-row .avatar{width:40px;height:40px;font-size:13px}.user-row .info{flex:1;min-width:0}.user-row .name{font-weight:700;font-size:14.5px;letter-spacing:-.005em}.user-row .email{font-size:12.5px;color:var(--text-2);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cad-row{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:14px;display:flex;flex-direction:column;gap:8px}.cad-row+.cad-row{margin-top:8px}.cad-row .top{display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:11.5px;color:var(--text-2)}.cad-row .unit{font-weight:700;font-size:14.5px;letter-spacing:-.005em}.cad-row .item{font-size:13px;color:var(--text-2)}.icon-btn{width:32px;height:32px;border-radius:8px;display:grid;place-items:center;color:var(--text-2);background:transparent}.icon-btn:hover{background:#f3f4f6;color:var(--text-1)}.fab{position:fixed;right:18px;bottom:96px;width:60px;height:60px;border-radius:20px;background:var(--primary);color:#fff;display:grid;place-items:center;box-shadow:0 14px 32px #2563eb73;z-index:15}
