:root{--md-sys-color-primary:#1a73e8;--md-sys-color-on-primary:#fff;--md-sys-color-primary-container:#d3e3fd;--md-sys-color-surface:#fff;--md-sys-color-surface-variant:#f1f3f4;--md-sys-color-on-surface:#202124;--md-sys-color-on-surface-variant:#5f6368;--md-sys-color-outline:#dadce0;--md-sys-color-error:#d93025;--md-sys-color-success:#1e8e3e;--md-sys-color-warning:#f9ab00;--grade-a-color:#4caf50;--grade-a-bg:#e6f4ea;--grade-b-color:#2196f3;--grade-b-bg:#e8f0fe;--grade-c-color:#ff9800;--grade-c-bg:#fef7e0;--grade-c-text:#b06000;--grade-d-color:#f44336;--grade-d-bg:#fce8e6}html{scroll-behavior:smooth}body{overscroll-behavior-y:contain}:focus-visible,button:focus-visible,[role=button]:focus-visible{outline:2px solid var(--md-sys-color-primary);outline-offset:2px}*{box-sizing:border-box;margin:0;padding:0}body{color:var(--md-sys-color-on-surface);background:#f8f9fa;flex-direction:column;height:100vh;font-family:Google Sans,Roboto,-apple-system,sans-serif;line-height:1.5;display:flex;overflow:hidden}#__next{flex-direction:column;height:100vh;display:flex}.material-symbols-outlined{font-variation-settings:"FILL" 0,"wght" 400,"GRAD" 0,"opsz" 24}.top-nav{background:var(--md-sys-color-surface);border-bottom:1px solid var(--md-sys-color-outline);z-index:100;justify-content:space-between;align-items:center;height:64px;padding:0 24px;display:flex;position:sticky;top:0}.nav-left{align-items:center;gap:16px;display:flex}.logo{color:var(--md-sys-color-on-surface);align-items:center;gap:8px;font-size:20px;font-weight:500;display:flex}.logo .material-symbols-outlined{color:var(--md-sys-color-primary);font-size:28px}.nav-right{align-items:center;gap:8px;display:flex}.icon-btn{cursor:pointer;width:40px;height:40px;color:var(--md-sys-color-on-surface-variant);background:0 0;border:none;border-radius:20px;justify-content:center;align-items:center;transition:background .2s;display:flex}.icon-btn:hover{background:var(--md-sys-color-surface-variant)}.container{flex-direction:column;flex:1;width:100%;padding:24px;display:flex;overflow:hidden}.page-header{margin-bottom:24px}.page-title{color:var(--md-sys-color-on-surface);margin-bottom:8px;font-size:28px;font-weight:400}.page-subtitle{color:var(--md-sys-color-on-surface-variant);font-size:14px}.stats-row{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px;display:grid}.stat-card{background:var(--md-sys-color-surface);border:1px solid var(--md-sys-color-outline);border-radius:12px;padding:20px}.stat-label{color:var(--md-sys-color-on-surface-variant);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;font-size:12px}.stat-value{color:var(--md-sys-color-on-surface);font-size:36px;font-weight:400}.stat-value.primary{color:var(--md-sys-color-primary)}.stat-value.success{color:var(--md-sys-color-success)}.main-layout{flex:1;grid-template-columns:minmax(350px,1fr) 2fr;align-items:stretch;gap:24px;min-height:0;display:grid}.machine-list-card{flex-direction:column;height:100%;min-height:0;display:flex}.machine-list-card .card-body{flex:1;min-height:0;overflow-y:auto}.card{background:var(--md-sys-color-surface);border:1px solid var(--md-sys-color-outline);border-radius:12px;overflow:hidden}.card-header{border-bottom:1px solid var(--md-sys-color-outline);align-items:center;gap:12px;padding:16px 20px;display:flex}.card-header .material-symbols-outlined{color:var(--md-sys-color-on-surface-variant)}.card-title{color:var(--md-sys-color-on-surface);font-size:14px;font-weight:500}.card-body{padding:0}.machine-list-filter{border-bottom:1px solid var(--md-sys-color-outline);background:var(--md-sys-color-surface);z-index:1;flex-direction:column;gap:8px;padding:12px 16px;display:flex;position:sticky;top:0}.machine-search-input{border:1px solid var(--md-sys-color-outline);background:var(--md-sys-color-surface);border-radius:8px;width:100%;padding:8px 12px 8px 36px;font-size:14px;position:relative}.machine-search-input:focus{border-color:var(--md-sys-color-primary);outline:none}.machine-search-wrapper{position:relative}.machine-search-wrapper .material-symbols-outlined{color:var(--md-sys-color-outline);font-size:18px;position:absolute;top:50%;left:10px;transform:translateY(-50%)}.machine-filter-chips{scroll-snap-type:x mandatory;flex-wrap:wrap;gap:6px;display:flex}.filter-chip{cursor:pointer;border:1px solid var(--md-sys-color-outline);background:var(--md-sys-color-surface);scroll-snap-align:start;border-radius:16px;padding:4px 10px;font-size:12px;transition:all .15s}.filter-chip:hover{background:var(--md-sys-color-surface-variant)}.filter-chip.active{background:var(--md-sys-color-primary);color:var(--md-sys-color-on-primary);border-color:var(--md-sys-color-primary)}.filter-chip.grade-A.active{background:#4caf50;border-color:#4caf50}.filter-chip.grade-B.active{background:#2196f3;border-color:#2196f3}.filter-chip.grade-C.active{background:#ff9800;border-color:#ff9800}.filter-chip.grade-D.active{background:#f44336;border-color:#f44336}.spinner{border:3px solid #e8eaed;border-top-color:#1a73e8;border-radius:50%;width:24px;height:24px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.machine-group{border-bottom:1px solid var(--md-sys-color-outline)}.machine-group:last-child{border-bottom:none}.machine-group-header{background:var(--md-sys-color-surface-variant);color:var(--md-sys-color-on-surface-variant);cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;padding:10px 16px;font-size:12px;font-weight:600;display:flex}.machine-group-header:hover{background:#e8eaed}.machine-group-header .group-info{align-items:center;gap:8px;display:flex}.machine-group-header .group-count{background:var(--md-sys-color-outline);color:#fff;border-radius:10px;padding:2px 8px;font-size:11px}.machine-group-header .expand-icon{font-size:18px;transition:transform .2s}.machine-group.collapsed .expand-icon{transform:rotate(-90deg)}.machine-group.collapsed .machine-group-items{display:none}.machine-list-item{border-bottom:1px solid var(--md-sys-color-outline);cursor:pointer;align-items:center;gap:12px;padding:12px 16px;transition:background .15s;display:flex}.machine-list-item:last-child{border-bottom:none}.machine-list-item:hover{background:var(--md-sys-color-surface-variant)}.machine-list-item.selected{background:var(--md-sys-color-primary-container)}.machine-icon{background:var(--md-sys-color-surface-variant);border-radius:20px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.machine-icon .material-symbols-outlined{color:var(--md-sys-color-on-surface-variant);font-size:20px}.machine-info{flex:1;min-width:0}.machine-name{color:var(--md-sys-color-on-surface);margin-bottom:2px;font-size:14px;font-weight:500}.machine-meta{color:var(--md-sys-color-on-surface-variant);font-size:12px}.machine-score{text-align:right}.score-value{font-size:20px;font-weight:500}.score-value.grade-A{color:var(--md-sys-color-success)}.score-value.grade-B{color:var(--md-sys-color-primary)}.score-value.grade-C{color:var(--md-sys-color-warning)}.score-value.grade-D{color:var(--md-sys-color-error)}.grade-chip{border-radius:4px;padding:2px 8px;font-size:11px;font-weight:500;display:inline-block}.grade-chip.grade-A{color:var(--md-sys-color-success);background:#e6f4ea}.grade-chip.grade-B{color:var(--md-sys-color-primary);background:#e8f0fe}.grade-chip.grade-C{color:#b06000;background:#fef7e0}.grade-chip.grade-D{color:var(--md-sys-color-error);background:#fce8e6}.empty-state{text-align:center;color:var(--md-sys-color-on-surface-variant);flex-direction:column;justify-content:center;align-items:center;min-height:180px;padding:60px 20px;display:flex}.empty-state .material-symbols-outlined{opacity:.5;margin-bottom:16px;font-size:48px}.empty-state p{font-size:14px}.detail-panel{grid-template-columns:1fr 1fr;gap:16px;height:100%;min-height:0;display:grid}.detail-panel .card:first-child{flex-direction:column;min-height:0;display:flex;overflow:hidden}.detail-panel .card:first-child .card-body{flex:1;min-height:0;overflow-y:auto}.detail-panel .card:last-child{flex-direction:column;min-height:0;display:flex;overflow:hidden}.detail-panel .card:last-child .card-body{flex:1;min-height:0;overflow-y:auto}.user-avatar{background:var(--md-sys-color-primary);width:32px;height:32px;color:var(--md-sys-color-on-primary);border-radius:16px;justify-content:center;align-items:center;font-size:14px;font-weight:500;display:flex}.tenant-badge{border-left:1px solid #dadce0;align-items:center;gap:8px;margin-left:8px;padding-left:16px;display:flex}.tenant-badge .material-symbols-outlined{color:#5f6368;font-size:18px}.tenant-badge span{color:#5f6368;font-size:14px}.user-menu{border-left:1px solid #dadce0;align-items:center;gap:8px;margin-left:8px;padding-left:16px;display:flex}.user-menu .material-symbols-outlined{color:#5f6368;font-size:20px}.user-menu .user-name{color:#5f6368;font-size:14px}@media (max-width:768px){body{height:auto;min-height:100vh;overflow:auto}#__next{height:auto;min-height:100vh}.top-nav{height:56px;padding:0 16px}.logo{font-size:16px}.logo .material-symbols-outlined{font-size:24px}.container{padding:16px;overflow:visible}.page-title{font-size:22px}.stats-row{grid-template-columns:repeat(2,1fr);gap:12px}.stat-card{padding:16px}.stat-value{font-size:28px}.main-layout{grid-template-columns:1fr;gap:16px}.machine-list-card{max-height:none}.machine-list-card .card-body{max-height:none;overflow-y:visible}.detail-panel{grid-template-columns:1fr;gap:12px}.card-header{padding:12px 16px}.card-body{padding:16px}.machine-list-filter{flex-direction:column;gap:8px;padding:8px 12px}.machine-filter-chips{-webkit-overflow-scrolling:touch;flex-wrap:nowrap;gap:6px;padding-bottom:4px;overflow-x:auto}.filter-chip{flex-shrink:0;padding:6px 12px;font-size:12px}.timeline-delete{border-radius:22px;width:44px;height:44px}}@media (max-width:480px){.top-nav{padding:0 12px}.nav-right .icon-btn:not(:last-child){display:none}.container{padding:12px}.page-header{margin-bottom:16px}.page-title{font-size:20px}.page-subtitle{font-size:12px}.stats-row{grid-template-columns:1fr;gap:8px}.stat-card{border-radius:8px;padding:12px}.stat-label{font-size:10px}.stat-value{font-size:24px}.machine-list-item{padding:12px 16px}.machine-name{font-size:14px}.icon-btn{width:44px;height:44px}.filter-chip{align-items:center;min-height:44px;padding:10px 14px;display:flex}input,select,textarea{min-height:44px;padding:12px;font-size:16px!important}.machine-name,.machine-meta,.page-title,.card-title{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.machine-info{overflow:hidden}.tenant-badge,.user-menu .user-name{display:none}.grade-chip{min-height:32px;padding:8px 12px}}.timeline-list{padding:16px}.timeline-item{align-items:flex-start;gap:16px;padding-bottom:20px;display:flex;position:relative}.timeline-item:not(:last-child):before{content:"";background:var(--md-sys-color-outline);width:2px;position:absolute;top:40px;bottom:0;left:19px}.timeline-dot{background:var(--md-sys-color-primary-container);border-radius:20px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.timeline-dot .material-symbols-outlined{color:var(--md-sys-color-primary);font-size:20px}.timeline-content{flex:1;padding-top:2px}.timeline-title{color:var(--md-sys-color-on-surface);margin-bottom:4px;font-size:14px;font-weight:500}.timeline-meta{color:var(--md-sys-color-on-surface-variant);font-size:12px}.timeline-chip{background:var(--md-sys-color-surface-variant);color:var(--md-sys-color-on-surface-variant);text-transform:uppercase;border-radius:4px;margin-right:8px;padding:2px 8px;font-size:11px;font-weight:500;display:inline-block}.timeline-memo{color:#5f6368;background:#f8f9fa;border-radius:6px;align-items:flex-start;gap:6px;margin-top:8px;padding:8px 12px;font-size:12px;line-height:1.4;display:flex}.timeline-delete{cursor:pointer;color:#9aa0a6;opacity:.5;background:0 0;border:none;border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;margin-left:auto;transition:all .2s;display:flex}.timeline-item:hover .timeline-delete{opacity:1}.timeline-delete:hover{color:#c5221f;background:#fce8e6}.timeline-delete .material-symbols-outlined{font-size:18px}.quick-action-grid{grid-template-columns:repeat(2,1fr);gap:10px;padding:12px;display:grid}.quick-action-wrapper{width:100%;position:relative}.quick-action-btn{cursor:pointer;background:#fff;border:2px solid #e0e0e0;border-radius:12px;flex-direction:column;justify-content:center;align-items:center;gap:8px;width:100%;min-height:70px;padding:14px 10px;font-family:inherit;transition:all .2s;display:flex}.quick-action-btn:hover:not(:disabled){background:#e8f0fe;border-color:#1a73e8;transform:translateY(-3px);box-shadow:0 6px 20px #1a73e826}.quick-action-btn:active:not(:disabled){transform:translateY(-1px);box-shadow:0 3px 10px #1a73e826}.quick-action-btn:disabled{opacity:.35;cursor:not-allowed;background:#f5f5f5}.quick-action-btn .material-symbols-outlined{color:#1a73e8;font-size:32px}.quick-action-btn:hover:not(:disabled) .material-symbols-outlined{color:#1557b0}.quick-action-label{color:#3c4043;text-align:center;font-size:14px;font-weight:500}@media (hover:none) and (pointer:coarse){.machine-list-item:hover{background:0 0}.machine-list-item:active{background:var(--md-sys-color-surface-variant)}::-webkit-scrollbar{display:none}*{-ms-overflow-style:none;scrollbar-width:none}}.mobile-only{display:none!important}.desktop-only{display:block!important}@media (max-width:768px){.mobile-only{display:block!important}.desktop-only{display:none!important}.mobile-quick-actions-container{background:var(--md-sys-color-surface);border-top:1px solid var(--md-sys-color-outline);z-index:1000;padding-bottom:env(safe-area-inset-bottom);transition:all .2s;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -4px 12px #00000014}.mobile-quick-actions-container.collapsed{padding:0}.mobile-quick-actions-container.expanded{padding:0 16px 12px;padding-bottom:calc(12px + env(safe-area-inset-bottom))}.mobile-quick-actions-container .quick-action-grid{grid-template-columns:repeat(3,1fr);gap:8px;padding:0}.mobile-quick-actions-container .quick-action-btn{min-height:60px;padding:8px 4px}.mobile-quick-actions-container .quick-action-btn .material-symbols-outlined{font-size:24px}.mobile-quick-actions-container .quick-action-label{font-size:11px}.main-layout{padding-bottom:60px}}.toast-container{z-index:2000;pointer-events:none;flex-direction:column;gap:12px;display:flex;position:fixed;bottom:24px;right:24px}.toast{pointer-events:auto;background:var(--md-sys-color-surface);border:1px solid var(--md-sys-color-outline);opacity:0;border-radius:8px;align-items:center;min-width:300px;max-width:400px;padding:12px 16px;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;transform:translate(100%);box-shadow:0 4px 12px #00000026}.toast-enter{opacity:1;transform:translate(0)}.toast-exit{opacity:0;transform:translate(100%)}.toast-icon{margin-right:12px;font-size:20px}.toast-success .toast-icon{color:var(--md-sys-color-success)}.toast-error .toast-icon{color:var(--md-sys-color-error)}.toast-info .toast-icon{color:var(--md-sys-color-primary)}.toast-message{color:var(--md-sys-color-on-surface);flex:1;font-size:14px}.toast-close{cursor:pointer;color:var(--md-sys-color-on-surface-variant);background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;margin-left:8px;padding:4px;transition:background .2s;display:flex}.toast-close:hover{background:var(--md-sys-color-surface-variant)}.toast-close .material-symbols-outlined{font-size:18px}@media (max-width:768px){.toast-container{align-items:center;bottom:80px;left:16px;right:16px}.toast{width:100%;min-width:0;transform:translateY(100%)}.toast-enter{transform:translateY(0)}.toast-exit{transform:translateY(100%)}}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}html{scroll-behavior:auto}}.dialog-backdrop{z-index:1000;background-color:#00000080;justify-content:center;align-items:center;width:100%;height:100%;animation:.2s ease-out fadeIn;display:flex;position:fixed;top:0;left:0}.dialog-container{background:var(--md-sys-color-surface);border-radius:28px;width:100%;max-width:320px;padding:24px;animation:.2s ease-out scaleIn;box-shadow:0 11px 15px -7px #0003,0 24px 38px 3px #00000024,0 9px 46px 8px #0000001f}.dialog-title{color:var(--md-sys-color-on-surface);margin-bottom:16px;font-size:24px;font-weight:400}.dialog-message{color:var(--md-sys-color-on-surface-variant);margin-bottom:24px;font-size:14px;line-height:1.5}.dialog-actions{justify-content:flex-end;gap:8px;display:flex}.dialog-btn{cursor:pointer;background:0 0;border:none;border-radius:20px;padding:10px 24px;font-size:14px;font-weight:500;transition:background .2s}.dialog-btn.cancel{color:var(--md-sys-color-primary)}.dialog-btn.cancel:hover{background:#1a73e814}.dialog-btn.confirm{background:var(--md-sys-color-primary);color:var(--md-sys-color-on-primary)}.dialog-btn.confirm:hover{box-shadow:0 1px 2px #0000004d,0 1px 3px 1px #00000026}.dialog-btn.confirm.danger{background:var(--md-sys-color-error);color:#fff}.dialog-btn.confirm.danger:hover{background:#c5221f}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.page-header.flex-row{align-items:center;gap:16px;display:flex}.card-header.space-between{justify-content:space-between}.header-title-group{align-items:center;gap:8px;display:flex}.text-btn{cursor:pointer;background:0 0;border:none;font-size:14px;font-weight:500}.text-btn.primary{color:var(--md-sys-color-primary)}.text-btn:hover{text-decoration:underline}.settings-body{padding:24px}.settings-list{flex-direction:column;gap:8px;padding:12px 16px;display:flex}.settings-item{background:var(--md-sys-color-surface-variant);border-radius:12px;justify-content:space-between;align-items:center;gap:12px;padding:12px 16px;transition:background-color .15s;display:flex}.settings-item:hover{background:color-mix(in srgb,var(--md-sys-color-surface-variant)80%,var(--md-sys-color-primary)20%)}.settings-item-label{flex:1;align-items:center;gap:10px;min-width:0;display:flex}.item-icon{background:var(--md-sys-color-surface);width:36px;height:36px;color:var(--md-sys-color-primary);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.item-icon .material-symbols-outlined{font-size:20px;line-height:1}.item-name{color:var(--md-sys-color-on-surface);font-size:14px;font-weight:500}.settings-item-control{flex-shrink:0}.card-footer{border-top:1px solid var(--md-sys-color-outline);background:rgba(var(--md-sys-color-surface-variant),.1);justify-content:flex-end;gap:12px;padding:16px;display:flex}.btn{cursor:pointer;border:none;border-radius:20px;justify-content:center;align-items:center;height:40px;padding:0 24px;font-size:14px;font-weight:500;transition:all .2s;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn.primary{background:var(--md-sys-color-primary);color:var(--md-sys-color-on-primary)}.btn.primary:hover:not(:disabled){box-shadow:0 1px 3px #0000004d}.btn.text{color:var(--md-sys-color-primary);background:0 0}.btn.text:hover:not(:disabled){background:#1a73e814}.score-stepper{flex-direction:column;gap:4px;display:flex}.stepper-label{color:var(--md-sys-color-on-surface-variant);font-size:12px}.stepper-controls{background:var(--md-sys-color-surface);border-radius:10px;align-items:center;gap:2px;padding:2px;display:flex;box-shadow:0 1px 3px #00000014}.stepper-btn{width:32px;height:32px;color:var(--md-sys-color-on-surface-variant);cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;transition:all .15s;display:flex}.stepper-btn .material-symbols-outlined{font-size:18px}.stepper-btn:hover:not(:disabled){background:var(--md-sys-color-surface-variant);color:var(--md-sys-color-primary)}.stepper-btn:active:not(:disabled){transform:scale(.92)}.stepper-btn:disabled{opacity:.3;cursor:not-allowed}.stepper-value-container{cursor:text;justify-content:center;align-items:center;min-width:40px;height:32px;padding:0 4px;display:flex}.stepper-value{color:var(--md-sys-color-primary);font-variant-numeric:tabular-nums;font-size:15px;font-weight:600}.stepper-input{text-align:center;width:40px;height:100%;color:var(--md-sys-color-primary);font-variant-numeric:tabular-nums;background:0 0;border:none;outline:none;padding:0;font-size:15px;font-weight:600}@media (max-width:768px){.settings-item{padding:10px 14px}.stepper-btn{width:36px;height:36px}.stepper-value-container{height:36px}}
