.navbar{-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--color-border);z-index:100;background:#ffffffb8;justify-content:space-between;align-items:center;padding:20px 32px;display:flex;position:sticky;top:0}.navbar-left{align-items:center;gap:32px;display:flex}.navbar-logo{object-fit:contain;border-radius:8px;flex-shrink:0;width:36px;height:36px}.navbar-title{color:var(--color-text-primary);white-space:nowrap;font-size:16px;font-weight:600}.navbar-tabs{border-radius:var(--radius-sm);background:#0000000a;gap:4px;padding:3px;display:flex}.navbar-tab{color:var(--color-text-secondary);transition:all var(--transition-fast);background:0 0;border-radius:8px;padding:6px 16px;font-size:13px;font-weight:500}.navbar-tab.active{color:var(--color-text-primary);background:#fff;box-shadow:0 1px 3px #00000014}.navbar-right{align-items:center;gap:16px;display:flex}.navbar-weather{color:var(--color-accent);white-space:nowrap;font-size:13px;font-weight:600}.navbar-date{color:var(--color-text-secondary);white-space:nowrap;font-size:13px;font-weight:500}@media (width<=768px){.navbar{-webkit-overflow-scrolling:touch;flex-wrap:nowrap;justify-content:flex-start;gap:0;padding:10px 12px;overflow-x:auto}.navbar::-webkit-scrollbar{display:none}.navbar-left{flex-wrap:nowrap;flex-shrink:0;gap:6px}.navbar-title{text-overflow:ellipsis;max-width:80px;font-size:13px;overflow:hidden}.navbar-tabs{flex-shrink:0;gap:2px;padding:2px}.navbar-tab{white-space:nowrap;border-radius:6px;padding:5px 8px;font-size:11px}.navbar-right{flex-shrink:0;gap:6px;margin-left:auto}.navbar-weather{font-size:11px}.navbar-date{font-size:10px}}.float-calc{z-index:9999;-webkit-user-select:none;user-select:none;transition:width .2s,height .2s,border-radius .2s;position:fixed}.float-calc--collapsed{cursor:grab;flex-direction:column;align-items:center;gap:4px;display:flex}.float-calc__toggle{color:#fff;cursor:pointer;background:#ff9f0a;border:none;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;font-size:22px;display:flex;box-shadow:0 4px 16px #ff9f0a66}.float-calc__toggle:hover{opacity:.85;transform:scale(1.05)}.float-calc__label{color:#666;text-align:center;white-space:nowrap;font-size:10px}.float-calc--expanded{background:#1c1c1e;border-radius:12px;width:280px;overflow:hidden;box-shadow:0 8px 32px #0006}.float-calc__display{text-align:right;color:#fff;cursor:grab;word-break:break-all;min-height:52px;padding:14px 40px 10px 16px;font-size:32px;line-height:1.2}.float-calc__display:active{cursor:grabbing}.float-calc__close{color:#fff;cursor:pointer;background:#ffffff26;border:none;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:16px;line-height:1;display:flex;position:absolute;top:6px;right:6px}.float-calc__close:hover{background:#ffffff40}.float-calc__grid{grid-template-columns:repeat(4,1fr);gap:8px;padding:12px;display:grid}.float-calc__btn{cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;height:48px;font-size:18px;transition:opacity .15s;display:flex}.float-calc__btn:active{opacity:.7}.float-calc__btn--num{color:#fff;background:#333}.float-calc__btn--op{color:#fff;background:#ff9f0a}.float-calc__btn--clear{color:#1c1c1e;background:#d6d6d6}.float-calc__btn--equals{color:#fff;background:#ff9f0a;grid-column:1/-1}.float-calc__btn--num:hover,.float-calc__btn--op:hover,.float-calc__btn--clear:hover,.float-calc__btn--equals:hover{opacity:.85}.compare-bar{width:100%}.compare-bar__values{align-items:center;gap:12px;margin-bottom:8px;display:flex}.compare-bar__item{text-align:center;flex:1}.compare-bar__label{color:var(--color-text-secondary);margin-bottom:4px;font-size:11px;display:block}.compare-bar__value{color:var(--color-text-primary);font-size:18px;font-weight:700}.compare-bar__vs{flex-shrink:0}.compare-bar__badge{border-radius:var(--radius-full);padding:3px 10px;font-size:11px;font-weight:600;display:inline-block}.compare-bar__badge.pass{color:var(--color-success);background:#32d74b26}.compare-bar__badge.fail{color:var(--color-danger);background:#ff453a26}.compare-bar__track{background:#ffffff14;border-radius:3px;height:6px;position:relative;overflow:hidden}.compare-bar__fill{height:100%;transition:width .5s var(--ease-out);border-radius:3px}.compare-bar__fill.pass{background:var(--color-success)}.compare-bar__fill.fail{background:var(--color-danger)}.detail-overlay{-webkit-backdrop-filter:blur(8px);z-index:200;background:#0006;justify-content:center;align-items:center;padding:40px;display:flex;position:fixed;inset:0}.detail-panel{background:var(--color-card);border-radius:24px;width:100%;max-width:600px;max-height:85vh;padding:40px;position:relative;overflow-y:auto;box-shadow:0 24px 80px #00000080}.detail-close{width:32px;height:32px;color:var(--color-text-secondary);transition:background var(--transition-fast);background:#0000000a;border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;top:16px;right:16px}.detail-close:hover{background:#00000014}.detail-title{margin-bottom:8px;font-size:20px;font-weight:700}.detail-formula{color:var(--color-text-secondary);border-radius:var(--radius-sm);background:#00000008;margin-bottom:28px;padding:8px 14px;font-size:13px}.detail-body{flex-direction:column;gap:28px;display:flex}.detail-ring-section{flex-direction:column;align-items:center;gap:12px;display:flex}.detail-standard{color:var(--color-text-secondary);font-size:13px}.detail-section-title{color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px;font-size:13px;font-weight:600}.detail-inputs{flex-direction:column;gap:12px;display:flex}.detail-input-group{flex-direction:column;gap:4px;display:flex}.detail-input-label{color:var(--color-text-primary);align-items:center;gap:8px;font-size:13px;font-weight:500;display:flex}.detail-input-hint{color:var(--color-text-secondary);font-size:11px;font-weight:400}.detail-input{border-radius:var(--radius-sm);width:100%;color:var(--color-text-primary);transition:border-color var(--transition-fast);background:#fff;border:1.5px solid #1c1c1e;padding:10px 14px;font-size:15px;font-weight:500}.detail-input:focus{border-color:#1c1c1e;box-shadow:0 0 0 2px #0000001a}.detail-input::placeholder{color:var(--color-text-secondary);font-weight:400}.detail-compare{border-top:1px solid var(--color-border);padding-top:8px}@media (width<=768px){.detail-overlay{align-items:flex-end;padding:12px}.detail-panel{border-radius:20px 20px 0 0;max-width:100%;max-height:90vh;padding:24px 16px}.detail-close{top:12px;right:12px}.detail-title{font-size:17px}.detail-formula{margin-bottom:20px;padding:6px 10px;font-size:12px}.detail-body{gap:20px}.detail-input{padding:8px 12px;font-size:14px}}.alert-panel{background:var(--color-card);border-left:1px solid var(--color-border);z-index:50;width:300px;transition:width var(--transition-normal);flex-direction:column;display:flex;position:fixed;top:72px;bottom:0;right:0;box-shadow:-2px 0 12px #0000000f}.alert-panel--mini{width:48px}.alert-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.alert-header-right{align-items:center;gap:10px;display:flex}.alert-title{color:var(--color-danger);font-size:14px;font-weight:700}.alert-count{color:var(--color-danger);background:#ff3b301a;border-radius:13px;justify-content:center;align-items:center;min-width:26px;height:26px;padding:0 6px;font-size:13px;font-weight:700;display:flex}.alert-minimize{width:24px;height:24px;color:var(--color-text-secondary);transition:background var(--transition-fast);background:#0000000a;border-radius:6px;justify-content:center;align-items:center;display:flex}.alert-minimize:hover{background:#00000014}.alert-toggle{background:var(--color-card);border-bottom:1px solid var(--color-border);width:48px;height:48px;transition:background var(--transition-fast);flex-direction:column;justify-content:center;align-items:center;gap:2px;font-size:16px;display:flex}.alert-toggle:hover{background:#ff3b300d}.alert-count-sm{color:var(--color-danger);font-size:12px;font-weight:700}.alert-empty{text-align:center;color:var(--color-success);padding:32px 20px;font-size:14px;font-weight:600}.alert-list{flex:1;padding:8px 0;overflow-y:auto}.alert-item{border-bottom:1px solid var(--color-border);cursor:pointer;transition:background var(--transition-fast);flex-direction:column;gap:4px;padding:10px 20px;display:flex}.alert-item:hover{background:#ff3b300d}.alert-item:last-child{border-bottom:none}.alert-item-name{color:var(--color-text-primary);font-size:13px;font-weight:600;line-height:1.3}.alert-item-values{align-items:baseline;gap:4px;display:flex}.alert-item-rate{color:var(--color-danger);font-size:15px;font-weight:700}.alert-item-standard{color:var(--color-text-secondary);font-size:11px}.alert-item--activity{border-left:3px solid var(--color-accent)}.alert-section-title{color:var(--color-accent);text-transform:uppercase;letter-spacing:.5px;padding:12px 20px 4px;font-size:11px;font-weight:700}@media (width<=768px){.alert-panel{border-left:none;border-top:1px solid var(--color-border);width:100%;max-height:40vh;transition:max-height var(--transition-normal);border-radius:16px 16px 0 0;position:fixed;inset:auto 0 0;box-shadow:0 -4px 20px #00000026}.alert-panel--mini{width:100%;max-height:48px}.alert-header{padding:12px 16px}.alert-title{font-size:13px}.alert-list{padding:4px 0}.alert-item{padding:8px 16px}.alert-item-name{font-size:12px}.alert-item-rate{font-size:14px}.alert-empty{padding:20px 16px;font-size:13px}}.excel-import{flex-direction:column;gap:10px;display:flex}.excel-import-btn{border-radius:var(--radius-full);background:var(--color-card);color:var(--color-text-primary);transition:all var(--transition-fast);border:2px solid #1c1c1e;align-self:flex-start;align-items:center;gap:8px;padding:8px 18px;font-size:13px;font-weight:600;display:inline-flex}.excel-import-btn:hover:not(:disabled){color:#fff;background:#1c1c1e}.excel-import-btn:disabled{opacity:.5;cursor:not-allowed}.excel-log{background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-sm);max-height:300px;padding:10px 14px;font-family:ui-monospace,Consolas,monospace;font-size:12px;overflow-y:auto}.excel-log-line{color:var(--color-text-secondary);border-bottom:1px solid var(--color-border);padding:2px 0}.excel-log-line:last-child{border-bottom:none}.excel-error{color:var(--color-danger);background:#ff3b3014;border-radius:6px;padding:8px 12px;font-size:13px;font-weight:600}.dashboard{min-height:100vh;padding-right:300px}.dashboard-main{flex-direction:column;gap:24px;max-width:1000px;margin:0 auto;padding:32px 48px;display:flex}.dashboard-toolbar{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.toolbar-row-break{flex-basis:100%;height:0}.total-pop-input{align-items:center;gap:8px;display:flex}.total-pop-input label{color:var(--color-text-secondary);white-space:nowrap;font-size:13px;font-weight:600}.total-pop-input input{border-radius:var(--radius-full);text-align:center;background:#fff;border:1.5px solid #1c1c1e;width:120px;padding:7px 12px;font-size:14px;font-weight:600}.total-pop-input input:focus{box-shadow:0 0 0 2px #00000014}.clear-btn{border-radius:var(--radius-full);color:var(--color-danger);border:1.5px solid var(--color-danger);transition:all var(--transition-fast);background:0 0;padding:8px 18px;font-size:13px;font-weight:600}.clear-btn:hover{background:var(--color-danger);color:#fff}.category-section{flex-direction:column;gap:12px;display:flex}.category-section-title{margin-bottom:4px;font-size:17px;font-weight:700}.metric-rows{background:var(--color-card);border-radius:var(--radius-md);flex-direction:column;gap:2px;display:flex;overflow:hidden;box-shadow:0 2px 8px #0003}.metric-row{cursor:pointer;transition:background var(--transition-fast);border-bottom:1px solid var(--color-border);align-items:center;gap:16px;padding:14px 24px;display:flex}.metric-row:last-child{border-bottom:none}.metric-row:hover{background:#ffffff08}.metric-row__name{width:220px;color:var(--color-text-primary);flex-shrink:0;font-size:14px;font-weight:600;line-height:1.3}.metric-row__bar-wrap{flex:1}.metric-row__bar-track{background:#0000000a;border:1px solid #1c1c1e;border-radius:4px;height:8px;position:relative;overflow:visible}.metric-row__bar-fill{height:100%;transition:width .6s var(--ease-out);border-radius:4px;min-width:0}.metric-row__bar-fill--unknown{width:0!important}.metric-row__quarter-mark,.metric-row__final-mark{flex-direction:column;align-items:center;display:flex;position:absolute;top:-2px;bottom:-2px;transform:translate(-50%)}.quarter-mark-line,.final-mark-line{background:var(--color-danger);border-radius:2px;flex:1;width:3px}.metric-row__value{text-align:right;font-variant-numeric:tabular-nums;flex-shrink:0;width:72px;font-size:16px;font-weight:700}.metric-row__badge{text-align:center;border-radius:var(--radius-full);flex-shrink:0;width:60px;padding:3px 0;font-size:12px;font-weight:700}.metric-row__badge--pass{color:var(--color-success);background:#32d74b1f}.metric-row__badge--near{color:var(--color-warning);background:#ff9f0a1f}.metric-row__badge--fail{color:var(--color-danger);background:#ff453a1f}.metric-row__badge--unknown{color:var(--color-text-secondary);background:#ffffff0d}@keyframes blink{0%,to{background:#ff3b301f}50%{background:0 0}}.metric-row--blink{animation:.3s ease-in-out 2 blink}@media (width<=768px){.dashboard{padding-bottom:320px;padding-right:0}.dashboard-main{gap:16px;max-width:100%;padding:12px 10px}.dashboard-toolbar{display:none}.category-section-title{font-size:15px}.metric-row{gap:8px;padding:10px 12px}.metric-row__name{flex:30%;width:auto;min-width:0;font-size:12px;line-height:1.4}.metric-row__bar-wrap{flex:25%;min-width:30px}.metric-row__value{flex-shrink:0;width:50px;font-size:14px}.metric-row__badge{flex-shrink:0;width:44px;font-size:11px}}.reminder-banner{color:#fff;background:linear-gradient(135deg,#0071e3,#42a5f5);justify-content:space-between;align-items:center;padding:12px 24px;display:flex;overflow:hidden}.reminder-banner__content{align-items:center;gap:8px;font-size:13px;font-weight:500;display:flex}.reminder-banner__dismiss{color:#fff;border-radius:var(--radius-full);transition:background var(--transition-fast);background:#fff3;padding:5px 16px;font-size:12px;font-weight:600}.reminder-banner__dismiss:hover{background:#ffffff4d}.upload-zone{border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);border:1.5px dashed #00000026;align-items:center;gap:8px;min-height:36px;padding:8px 12px;display:flex}.upload-zone:hover,.upload-zone.drag-over{background:#00000008;border-color:#1c1c1e}.upload-zone__label{color:var(--color-text-secondary);white-space:nowrap;min-width:42px;font-size:12px;font-weight:600}.upload-zone:hover .upload-zone__label,.upload-zone.drag-over .upload-zone__label{color:var(--color-text-primary)}.upload-zone__hint{color:var(--color-text-secondary);opacity:.5;font-size:11px}.upload-zone__files{flex-wrap:wrap;gap:4px;display:flex}.upload-zone__file-group{align-items:center;gap:2px;display:inline-flex}.upload-zone__file{color:var(--color-accent);border-radius:var(--radius-full);background:#0000000d;padding:2px 8px;font-size:11px;text-decoration:none}.upload-zone__file:hover{text-decoration:underline}.upload-file-remove{color:var(--color-text-secondary);transition:color var(--transition-fast);background:0 0;padding:0;font-size:14px;line-height:1}.upload-file-remove:hover{color:var(--color-danger)}.upload-picker-overlay{-webkit-backdrop-filter:blur(4px);z-index:9999;background:#0006;justify-content:center;align-items:flex-end;padding:16px;display:flex;position:fixed;inset:0}.upload-picker{background:var(--color-card);width:100%;max-width:360px;animation:picker-slide-up .25s var(--ease-out);border-radius:20px;flex-direction:column;gap:2px;padding:8px;display:flex;box-shadow:0 8px 40px #0000004d}@keyframes picker-slide-up{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.upload-picker__title{text-align:center;color:var(--color-text-secondary);padding:10px 0 8px;font-size:13px;font-weight:600}.upload-picker__btn{color:var(--color-text-primary);transition:background var(--transition-fast);text-align:left;background:0 0;border-radius:12px;align-items:center;gap:14px;width:100%;padding:14px 16px;display:flex}.upload-picker__btn:hover{background:#0000000a}.upload-picker__btn:active{background:#00000014}.upload-picker__icon{text-align:center;flex-shrink:0;width:40px;font-size:28px}.upload-picker__text{flex-direction:column;gap:2px;display:flex}.upload-picker__text strong{font-size:15px;font-weight:600}.upload-picker__text small{color:var(--color-text-secondary);font-size:12px;font-weight:400}.upload-picker__cancel{color:var(--color-text-secondary);transition:background var(--transition-fast);background:#0000000a;border-radius:12px;margin-top:4px;padding:14px;font-size:15px;font-weight:600}.upload-picker__cancel:hover{background:#00000014}.upload-zone__file--img{cursor:pointer;color:var(--color-accent);-webkit-text-decoration:underline dotted;text-decoration:underline dotted}.img-preview-overlay{-webkit-backdrop-filter:blur(8px);z-index:10001;background:#000000e6;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.img-preview-box{flex-direction:column;align-items:center;gap:16px;max-width:90vw;max-height:85vh;display:flex;position:relative}.img-preview-close{color:#fff;width:36px;height:36px;transition:background var(--transition-fast);background:#ffffff26;border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;top:-40px;right:0}.img-preview-close:hover{background:#ffffff4d}.img-preview-img{object-fit:contain;border-radius:12px;max-width:100%;max-height:70vh;box-shadow:0 8px 32px #00000080}.img-preview-download{border-radius:var(--radius-full);color:#1c1c1e;transition:opacity var(--transition-fast);background:#fff;align-items:center;gap:8px;padding:10px 24px;font-size:14px;font-weight:700;text-decoration:none;display:inline-flex}.img-preview-download:hover{opacity:.85}.wm-preview-overlay{-webkit-backdrop-filter:blur(12px);z-index:10000;background:#000000d9;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.wm-preview{width:100%;max-width:400px;max-height:90vh;animation:picker-slide-up .25s var(--ease-out);background:#1c1c1e;border-radius:20px;flex-direction:column;gap:12px;padding:16px;display:flex;overflow-y:auto;box-shadow:0 16px 48px #00000080}.wm-preview__title{text-align:center;color:#fff;font-size:15px;font-weight:700}.wm-preview__img-wrap{aspect-ratio:4/3;background:#000;border-radius:12px;position:relative;overflow:hidden}.wm-preview__img{object-fit:contain;width:100%;height:100%;display:block}.wm-preview__wm-overlay{pointer-events:none;flex-direction:column;align-items:flex-end;gap:2px;display:flex;position:absolute;bottom:16px;right:16px}.wm-preview__wm-line{color:#ffffffd9;text-shadow:0 0 4px #000000b3;white-space:nowrap;font-family:Microsoft YaHei,PingFang SC,sans-serif;font-size:13px;font-weight:700}.wm-preview__fields{flex-direction:column;gap:8px;display:flex}.wm-preview__input{color:#fff;width:100%;transition:border-color var(--transition-fast);background:#ffffff14;border:1.5px solid #fff3;border-radius:10px;padding:10px 14px;font-family:inherit;font-size:14px}.wm-preview__input:focus{border-color:#ffffff80;outline:none}.wm-preview__input::placeholder{color:#ffffff4d}.wm-preview__actions{gap:10px;display:flex}.wm-preview__btn{transition:all var(--transition-fast);border-radius:12px;flex:1;padding:14px;font-size:15px;font-weight:700}.wm-preview__btn--confirm{color:#1c1c1e;background:#fff}.wm-preview__btn--confirm:active{opacity:.8}.wm-preview__btn--cancel{color:#fff;background:#ffffff1a}.wm-preview__btn--cancel:active{background:#fff3}@media (width<=768px){.upload-picker{border-radius:20px 20px 0 0;max-width:100%}.wm-preview{border-radius:20px 20px 0 0;max-width:100%;max-height:95vh;padding:12px}.wm-preview__img-wrap{aspect-ratio:1}.wm-preview__wm-line{font-size:11px}.wm-preview__input{padding:8px 12px;font-size:13px}.wm-preview__btn{padding:12px;font-size:14px}}.activity-manage{min-height:100vh}.activity-main{flex-direction:column;gap:40px;max-width:1200px;margin:0 auto;padding:32px;display:flex}.activity-section-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.activity-section-title{margin-bottom:8px;font-size:17px;font-weight:700}.activity-section-header .activity-section-title{margin-bottom:0}.activity-section-desc{color:var(--color-text-secondary);margin-bottom:20px;font-size:12px}.activity-grid{grid-template-columns:repeat(auto-fill,minmax(340px,1fr));align-items:start;gap:16px;display:grid}@media (width<=400px){.activity-grid{grid-template-columns:1fr}}.activity-card{background:var(--color-card);border-radius:var(--radius-md);word-break:break-word;overflow-wrap:break-word;flex-direction:column;gap:12px;min-width:0;padding:20px;display:flex;box-shadow:0 2px 8px #0000000f}.activity-card-header{justify-content:space-between;align-items:center;display:flex}.activity-card-header h3{font-size:15px;font-weight:600}.activity-date{color:var(--color-text-secondary);white-space:nowrap;font-size:12px;font-weight:500}.activity-desc{color:var(--color-text-secondary);font-size:13px}.activity-uploads{flex-direction:column;gap:6px;margin-top:4px;display:flex}.board-card{gap:14px}.board-name-select{border:1px solid var(--color-border);color:var(--color-text-primary);cursor:pointer;width:100%;transition:border-color var(--transition-fast);background:0 0;border-radius:6px;padding:6px 8px;font-family:inherit;font-size:14px;font-weight:600}.board-name-select:focus{border-color:#1c1c1e;outline:none}.board-name-input{color:var(--color-text-primary);width:100%;transition:border-color var(--transition-fast);background:0 0;border:1px solid #0000;border-radius:6px;padding:4px 8px;font-size:15px;font-weight:600}.board-name-input:hover{border-color:var(--color-border)}.board-name-input:focus{background:#00000005;border-color:#1c1c1e}.board-remove-btn{width:28px;height:28px;color:var(--color-text-secondary);transition:all var(--transition-fast);background:0 0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.board-remove-btn:hover{color:var(--color-danger);background:#ff3b301a}.board-dates{gap:12px;display:flex}.board-date-label{color:var(--color-text-secondary);flex-direction:column;flex:1;gap:4px;font-size:12px;font-weight:500;display:flex}.board-date-input{color:var(--color-text-primary);transition:border-color var(--transition-fast);box-sizing:border-box;background:#fff;border:1.5px solid #1c1c1e;border-radius:8px;width:100%;min-width:0;padding:7px 10px;font-family:inherit;font-size:13px}.board-date-input:focus{outline:none;box-shadow:0 0 0 2px #00000014}.btn-primary{border-radius:var(--radius-full);color:#fff;transition:all var(--transition-fast);background:#1c1c1e;align-items:center;gap:6px;padding:8px 20px;font-size:13px;font-weight:600;display:inline-flex}.btn-primary:hover{background:#3a3a3c;transform:scale(1.02)}.sync-status{border-radius:var(--radius-sm);background:#00000008;align-items:center;gap:8px;padding:8px 16px;font-size:12px;font-weight:500;display:flex}.sync-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.sync-ok .sync-dot{background:var(--color-success)}.sync-saving .sync-dot{background:var(--color-warning);animation:.8s ease-in-out infinite pulse-dot}.sync-local .sync-dot{background:var(--color-warning)}.sync-offline .sync-dot{background:var(--color-danger)}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.3}}.sync-text{color:var(--color-text-secondary);flex:1}.sync-refresh-btn{border-radius:var(--radius-full);background:var(--color-card);color:var(--color-text-secondary);border:1px solid var(--color-border);white-space:nowrap;transition:all var(--transition-fast);align-items:center;gap:4px;padding:4px 10px;font-size:11px;font-weight:600;display:inline-flex}.sync-refresh-btn:hover{background:var(--color-text-primary);color:#fff;border-color:var(--color-text-primary)}.summary-field{flex-direction:column;gap:4px;display:flex}.summary-label{color:var(--color-text-secondary);font-size:12px;font-weight:600}.summary-textarea{width:100%;color:var(--color-text-primary);resize:vertical;min-height:60px;transition:border-color var(--transition-fast);background:#fff;border:1.5px solid #1c1c1e;border-radius:8px;padding:8px 12px;font-family:inherit;font-size:13px;line-height:1.5}.summary-textarea:focus{outline:none;box-shadow:0 0 0 2px #00000014}.summary-textarea::placeholder{color:var(--color-text-secondary);font-weight:400}.pagination{justify-content:center;align-items:center;gap:16px;padding:16px 0 4px;display:flex}.pagination-btn{border-radius:var(--radius-full);background:var(--color-card);color:var(--color-text-primary);border:1.5px solid var(--color-border);transition:all var(--transition-fast);padding:8px 18px;font-size:13px;font-weight:600}.pagination-btn:hover:not(:disabled){color:#fff;background:#1c1c1e;border-color:#1c1c1e}.pagination-btn:disabled{opacity:.3;cursor:not-allowed}.pagination-info{color:var(--color-text-secondary);text-align:center;min-width:60px;font-size:13px;font-weight:600}.search-bar{background:var(--color-card);border-radius:var(--radius-md);transition:border-color var(--transition-fast);border:2px solid #0000;align-items:center;gap:10px;padding:10px 16px;display:flex;box-shadow:0 2px 8px #0000000f}.search-bar:focus-within{border-color:#1c1c1e}.search-icon{color:var(--color-text-secondary);flex-shrink:0}.search-input{color:var(--color-text-primary);background:0 0;border:none;outline:none;flex:1;font-family:inherit;font-size:14px}.search-input::placeholder{color:var(--color-text-secondary)}.search-clear{width:24px;height:24px;color:var(--color-text-secondary);transition:background var(--transition-fast);background:#0000000f;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.search-clear:hover{background:#0000001f}.search-clear-btn{border-radius:var(--radius-full);color:var(--color-text-secondary);border:1px solid var(--color-border);transition:all var(--transition-fast);background:0 0;padding:6px 16px;font-size:12px;font-weight:600}.search-clear-btn:hover{background:var(--color-text-primary);color:#fff}.search-highlight{border:2px solid var(--color-accent)}.search-snippet{color:var(--color-text-primary);white-space:pre-wrap;word-break:break-word;font-size:13px;line-height:1.6}.work-record-card{gap:10px}.work-record-name{color:var(--color-text-secondary);font-size:13px;font-weight:600}.work-record-field{flex-direction:column;gap:4px;display:flex}.work-record-label{color:var(--color-text-secondary);font-size:12px;font-weight:600}.work-type-tabs{flex-wrap:wrap;gap:4px;display:flex}.work-type-tab{border:1px solid var(--color-border);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;background:#fff;border-radius:14px;padding:3px 10px;font-size:11px}.work-type-tab:hover{border-color:var(--color-text-primary);color:var(--color-text-primary)}.measure-row{gap:8px;min-width:0;padding:8px 0;display:flex}.measure-row select,.measure-row input{box-sizing:border-box;background:#fff;border:1.5px solid #1c1c1e;border-radius:8px;flex:1;width:100%;min-width:0;padding:6px 10px;font-size:13px}.work-type-tab.active{color:#fff;background:#4a90d9;border-color:#4a90d9}.name-alert{z-index:99999;-webkit-backdrop-filter:blur(16px);color:#ffb340;background:#1e1e1ef7;border:1.5px solid #ff9f0a80;border-radius:14px;align-items:flex-start;gap:10px;max-width:320px;padding:16px 18px;font-size:15px;font-weight:700;line-height:1.5;animation:.35s cubic-bezier(.22,.61,.36,1) toast-slide-in;display:flex;position:fixed;top:50%;right:24px;transform:translateY(-50%);box-shadow:0 8px 40px #0009}@media (width<=768px){.name-alert{max-width:none;font-size:14px;top:12px;left:12px;right:12px;transform:none}}@keyframes toast-slide-in{0%{opacity:0;transform:translateY(-50%)translate(40px)}to{opacity:1;transform:translateY(-50%)translate(0)}}.name-alert-close{color:#ffb340;width:22px;height:22px;transition:background var(--transition-fast);background:#ffffff1a;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;margin-top:-1px;display:flex}.name-alert-close:hover{background:#fff3}@media (width<=768px){.name-alert{max-width:none;left:12px;right:12px}}@keyframes fade-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.card-collapsed{cursor:pointer;transition:all var(--transition-fast);gap:6px;padding:12px 16px}.card-collapsed:hover{box-shadow:0 4px 16px #0000001f}.card-expanded{cursor:default}.card-time-sm{color:var(--color-text-secondary);white-space:nowrap;margin-left:auto;margin-right:8px;font-size:11px;font-weight:500}.card-preview{color:var(--color-text-secondary);text-overflow:ellipsis;white-space:nowrap;margin:0;font-size:12px;line-height:1.4;overflow:hidden}.work-record-empty{color:var(--color-text-secondary);text-align:center;padding:24px;font-size:13px}@media (width<=768px){.activity-main{gap:24px;padding:12px 10px}.activity-grid{grid-template-columns:1fr;gap:12px}.activity-card{padding:14px}.activity-section-header{flex-wrap:wrap;gap:8px}.board-dates{flex-direction:column;gap:8px}.sync-status{flex-wrap:wrap;gap:4px;padding:6px 12px;font-size:11px}.sync-refresh-btn{margin-left:auto}.summary-textarea{min-height:50px;font-size:12px}.mobile-form-card{border:2px solid var(--color-accent);margin-bottom:16px}.mobile-form-actions{gap:10px;padding-top:8px;display:flex}.mobile-save-btn{flex:1;justify-content:center;padding:12px;font-size:15px}.mobile-cancel-btn{border-radius:var(--radius-full);color:var(--color-text-secondary);border:1.5px solid var(--color-border);background:0 0;flex:0 0 80px;padding:12px;font-size:14px;font-weight:600}}.mobile-form-overlay{-webkit-backdrop-filter:blur(4px);z-index:1000;background:#00000080;justify-content:center;align-items:flex-end;padding:16px;display:flex;position:fixed;inset:0}.mobile-form-modal{background:var(--color-card);width:100%;max-width:500px;max-height:85vh;animation:picker-slide-up .25s var(--ease-out);border-radius:20px 20px 0 0;flex-direction:column;gap:12px;padding:20px 16px;display:flex;overflow-y:auto;box-shadow:0 -8px 40px #0000004d}.mobile-form-title{text-align:center;color:var(--color-text-primary);font-size:16px;font-weight:700}@media (width<=768px){.mobile-form-modal{max-width:100%}.activity-main{padding:0 8px}.mobile-entry-btn{padding:14px 16px}.mobile-entry-text{font-size:16px}.mobile-entry-sub{font-size:13px}.work-type-tabs{gap:3px}.work-type-tab{padding:4px 8px;font-size:12px}}.mobile-entries{flex-direction:column;gap:14px;padding:20px 16px;display:flex}.mobile-entry-btn{background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;text-align:left;transition:all var(--transition-fast);flex-direction:column;align-items:flex-start;gap:4px;padding:18px 20px;display:flex}.mobile-entry-btn:active{background:#f0f0f5;transform:scale(.98)}.mobile-entry-icon{font-size:28px}.mobile-entry-text{color:var(--color-text-primary);font-size:17px;font-weight:700}.mobile-entry-sub{color:var(--color-text-secondary);font-size:13px}.mobile-entries-hint{text-align:center;color:#aaa;margin-top:8px;font-size:12px}.tools-page{min-height:100vh}.tools-main{max-width:1000px;margin:0 auto;padding:32px 48px}.tools-main h2{margin-bottom:24px;font-size:17px;font-weight:700}.tools-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;display:grid}.tool-card{background:var(--color-card);border-radius:var(--radius-md);border:1px solid var(--color-border);transition:all var(--transition-fast);flex-direction:column;gap:8px;padding:24px;text-decoration:none;display:flex;box-shadow:0 2px 8px #0000000f}.tool-card:hover{border-color:#1c1c1e;transform:translateY(-2px);box-shadow:0 6px 20px #0000001a}.tool-card h3{color:var(--color-text-primary);font-size:15px;font-weight:600}.tool-card p{color:var(--color-text-secondary);font-size:13px}.tool-soon{color:var(--color-text-secondary);border-radius:var(--radius-full);background:#0000000a;align-self:flex-start;padding:3px 10px;font-size:11px;font-weight:600}.drug-page{max-width:720px;margin:0 auto;padding:32px 24px}.drug-page h2{color:var(--color-text-primary);margin:0 0 20px;font-size:17px;font-weight:700}.dtabs{border-radius:var(--radius-sm);background:#0000000a;gap:3px;width:fit-content;margin-bottom:28px;padding:3px;display:flex}.dtab{color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;border-radius:8px;padding:6px 16px;font-size:13px;font-weight:500}.dtab.on{color:var(--color-text-primary);background:#fff;box-shadow:0 1px 3px #0000001a}.dbody{flex-direction:column;gap:18px;display:flex}.urow{flex-direction:column;gap:6px;display:flex}.ulabel{color:var(--color-text-secondary);font-size:13px;font-weight:600}.ubox{border:1.5px dashed var(--color-border);border-radius:var(--radius-md);transition:border-color var(--transition-fast);flex-direction:column;gap:8px;padding:14px 16px;display:flex}.ubox:hover{border-color:var(--color-text-secondary)}.uhint{color:#aaa;font-size:11px}.flist{flex-direction:column;gap:4px;display:flex}.fhint{color:#bbb;font-size:12px}.fitem{background:#f5f5f7;border-radius:8px;justify-content:space-between;align-items:center;padding:5px 10px;font-size:12px;display:flex}.fdel{color:var(--color-danger);cursor:pointer;background:0 0;border:none;padding:0 4px;font-size:18px;line-height:1}.fdel:disabled{opacity:.3;cursor:default}.ubtn{border:1px solid var(--color-border);color:var(--color-text-primary);cursor:pointer;background:#fff;border-radius:8px;align-self:flex-start;padding:5px 14px;font-size:12px}.ubtn:disabled{opacity:.4;cursor:default}.yrow{align-items:center;gap:10px;display:flex}.ysel{border:1px solid var(--color-border);background:#fff;border-radius:8px;padding:5px 10px;font-size:13px}.go{border-radius:var(--radius-sm);color:#fff;cursor:pointer;transition:background var(--transition-fast);background:#4a90d9;border:none;align-self:flex-start;padding:10px 28px;font-size:14px;font-weight:600}.go:hover{background:#357abd}.go:disabled{opacity:.5;cursor:default}.go.orange{background:#e67e22}.go.orange:hover{background:#d35400}.smsg{border-radius:var(--radius-sm);padding:10px 16px;font-size:13px;font-weight:500}.smsg.ok{color:var(--color-success);background:#34c7591a}.smsg.err{color:var(--color-danger);background:#ff3b301a}.preview{color:var(--color-success);margin:0;font-size:13px}.desc{color:#aaa;margin:-8px 0 0;font-size:12px}.resident-page{max-width:960px;margin:0 auto;padding:32px 24px}.resident-page h2{margin:0 0 20px;font-size:17px;font-weight:700}.rtabs{border-radius:var(--radius-sm);background:#0000000a;gap:3px;width:fit-content;margin-bottom:24px;padding:3px;display:flex}.rtab{color:var(--color-text-secondary);cursor:pointer;background:0 0;border:none;border-radius:8px;padding:6px 16px;font-size:13px;font-weight:500}.rtab.on{color:var(--color-text-primary);background:#fff;box-shadow:0 1px 3px #0000001a}.rtab-body{flex-direction:column;gap:16px;display:flex}.upload-bar{align-items:center;gap:12px;display:flex}.upload-btn{border:1px solid var(--color-border);cursor:pointer;color:var(--color-text-primary);background:#fff;border-radius:8px;padding:6px 14px;font-size:13px}.upload-btn:hover{border-color:#4a90d9}.umsg{font-size:12px}.umsg.ok{color:var(--color-success)}.umsg.err{color:var(--color-danger)}.search-bar2{gap:8px;display:flex}.search-bar2 input{border:1px solid var(--color-border);border-radius:8px;flex:1;padding:8px 12px;font-size:14px}.search-bar2 button{color:#fff;cursor:pointer;background:#4a90d9;border:none;border-radius:8px;padding:8px 18px;font-size:13px;font-weight:600}.search-bar2 button:disabled{opacity:.5}.rtotal{color:var(--color-text-secondary);font-size:12px}.rtable-wrap{border:1px solid var(--color-border);border-radius:var(--radius-sm);overflow-x:auto}.rtable{border-collapse:collapse;width:100%;font-size:12px}.rtable th{text-align:left;white-space:nowrap;border-bottom:1px solid var(--color-border);background:#f5f5f7;padding:8px 10px;font-weight:600}.rtable td{white-space:nowrap;text-overflow:ellipsis;border-bottom:1px solid #0000000a;max-width:280px;padding:6px 10px;overflow:hidden}.rtable tr:hover td{white-space:normal;background:#fafafa;max-width:none;overflow:visible}.em-form{background:var(--color-card);border-radius:var(--radius-md);border:1px solid var(--color-border);flex-direction:column;gap:10px;padding:16px;display:flex}.em-fields{grid-template-columns:1fr 1fr;gap:8px;display:grid}.em-fields input,.em-fields textarea,.em-fields select{box-sizing:border-box;background:#fff;border:1.5px solid #1c1c1e;border-radius:8px;width:100%;padding:8px 10px;font-size:13px}.em-fields textarea{resize:vertical;grid-column:1/-1}.em-save{color:#fff;cursor:pointer;background:#e67e22;border:none;border-radius:8px;align-self:flex-start;padding:8px 20px;font-size:14px;font-weight:600}.em-save:disabled{opacity:.5}.emsg{color:var(--color-danger);font-size:12px}.em-list-title{margin:8px 0 0;font-size:14px;font-weight:700}.em-list{flex-direction:column;gap:8px;display:flex}.em-card{background:var(--color-card);border-radius:var(--radius-sm);border:1px solid var(--color-border);padding:12px}.em-card-hd{align-items:center;gap:10px;margin-bottom:6px;display:flex}.em-name{font-size:14px;font-weight:700}.em-time{color:#aaa;font-size:11px}.em-del{color:var(--color-danger);cursor:pointer;background:0 0;border:none;margin-left:auto;font-size:16px}.em-card-body{color:var(--color-text-secondary);flex-wrap:wrap;gap:6px 16px;font-size:12px;display:flex}.em-cond{color:var(--color-danger);font-weight:600}.em-notes{background:#fff8e1;border-radius:6px;width:100%;margin:4px 0 0;padding:6px 8px;font-size:12px}.empty-hint{text-align:center;color:#bbb;padding:40px 0;font-size:13px}.field-err{color:var(--color-danger);margin-top:2px;font-size:11px;display:block}@media (width<=768px){.resident-page{padding:12px 8px}.resident-page h2{margin-bottom:12px;font-size:18px}.rtabs{margin-bottom:16px}.em-fields{grid-template-columns:1fr;gap:6px}.em-fields input,.em-fields select,.em-fields textarea{border-color:#1c1c1e!important;padding:10px 12px!important;font-size:16px!important}.em-form{padding:12px}.upload-bar{flex-direction:column;gap:8px}.search-bar2{flex-wrap:wrap}.search-bar2 input{min-width:0}.rtable-wrap{-webkit-overflow-scrolling:touch;overflow-x:auto}.rtable{white-space:nowrap;font-size:13px}.rtable th,.rtable td{padding:6px 8px}.em-card-body{flex-direction:column;gap:4px;font-size:14px!important}.rtab{padding:6px 12px;font-size:14px}}.login-page{background:var(--color-bg);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-form{background:var(--color-card);border-radius:24px;flex-direction:column;gap:20px;width:360px;padding:48px 40px;display:flex;box-shadow:0 8px 32px #00000014}.login-logo{object-fit:contain;border-radius:12px;width:64px;height:64px;margin:0 auto;display:block}.login-form h1{text-align:center;color:var(--color-text-primary);font-size:20px;font-weight:700}.login-subtitle{text-align:center;color:var(--color-text-secondary);margin-top:-12px;font-size:13px}.login-field{flex-direction:column;gap:6px;display:flex}.login-field label{color:var(--color-text-secondary);font-size:13px;font-weight:600}.login-field input{border-radius:var(--radius-sm);color:var(--color-text-primary);background:#fff;border:1.5px solid #1c1c1e;padding:10px 14px;font-size:15px}.login-field input:focus{box-shadow:0 0 0 2px #00000014}.login-error{color:var(--color-danger);text-align:center;font-size:13px;font-weight:600}.login-btn{border-radius:var(--radius-full);color:#fff;letter-spacing:2px;transition:opacity var(--transition-fast);background:#1c1c1e;padding:12px;font-size:15px;font-weight:700}.login-btn:hover{opacity:.85}@media (width<=768px){.login-form{border-radius:20px;gap:16px;width:calc(100% - 32px);max-width:360px;padding:32px 20px}.login-form h1{font-size:18px}.login-btn{padding:14px}}:root{--color-bg:#f2f2f7;--color-card:#fff;--color-card-elevated:#f9f9fb;--color-text-primary:#1c1c1e;--color-text-secondary:#8e8e93;--color-text-body:#6e6e73;--color-accent:#8e8e93;--color-accent-hover:#636366;--color-success:#34c759;--color-warning:#ff9f0a;--color-danger:#ff3b30;--color-border:#00000014;--color-shadow:#0000000a;--radius-sm:10px;--radius-md:18px;--radius-full:980px;--ease-out:cubic-bezier(.25, .1, .25, 1);--transition-fast:.2s var(--ease-out);--transition-normal:.35s var(--ease-out)}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--color-bg);color:var(--color-text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;max-width:100vw;font-family:-apple-system,BlinkMacSystemFont,Microsoft YaHei,PingFang SC,sans-serif;font-size:19px;font-weight:500;overflow-x:hidden}#root{max-width:100vw;overflow-x:hidden}button,input,select,textarea{font-family:inherit;font-size:inherit}button{cursor:pointer;border:none;outline:none}input,select{outline:none}textarea{outline:none;font-size:17px}h1{font-size:25px}h2{font-size:21px}h3{font-size:18px}label,.upload-label,.work-record-label,.summary-label{font-size:16px!important}input[type=text],input[type=date],input[type=datetime-local],input[type=number],select{padding:10px 14px!important;font-size:17px!important}button{font-size:17px}.card-time-sm{font-size:14px!important}.navbar-tab{font-size:17px!important}.rtable{font-size:16px!important}.rtable th{font-size:14px!important}.em-card-body{font-size:16px!important}.empty-hint,.upload-hint,.uhint{font-size:15px!important}@media (width<=768px){body{font-size:16px}h1{font-size:22px!important}h2{font-size:18px!important}h3{font-size:16px!important}input[type=text],input[type=date],input[type=datetime-local],input[type=number],select,textarea{padding:10px 12px!important;font-size:16px!important}button{min-height:44px;font-size:16px}label{font-size:14px!important}.activity-card,.em-card{gap:8px;padding:14px 12px}.rtable-wrap{-webkit-overflow-scrolling:touch;margin:0 -8px;padding:0 8px;overflow-x:auto}.rtable{font-size:14px!important}.rtable th,.rtable td{white-space:nowrap;padding:6px 8px}.em-fields{gap:8px;grid-template-columns:1fr!important}.em-fields input,.em-fields select,.em-fields textarea{padding:10px 12px!important;font-size:16px!important}.search-bar2{flex-wrap:wrap}.search-bar2 input{flex:100%}.drug-page,.resident-page,.dashboard{padding:12px 10px!important}.activity-section{padding:0}.navbar{flex-wrap:wrap;padding:8px 10px!important}.navbar-title{font-size:14px!important}.navbar-tabs{flex-wrap:nowrap;gap:2px;overflow-x:auto}.navbar-tab{white-space:nowrap;padding:6px 10px!important;font-size:13px!important}.dashboard-toolbar{flex-direction:column;gap:8px}.total-pop-input{width:100%}.btn-primary,.btn-go,.em-save{text-align:center;width:100%;min-height:44px}}
