@import"https://fonts.googleapis.com/css2?family=Noto+Sans+TC:wght@400;500;700&display=swap";:root{--primary-50: #e3f2fd;--primary-100: #bbdefb;--primary-200: #90caf9;--primary-300: #64b5f6;--primary-400: #42a5f5;--primary-500: #1e88e5;--primary-600: #1976d2;--primary-700: #1565c0;--primary-800: #0d47a1;--primary-900: #0a2463;--accent-50: #fff3e0;--accent-100: #ffe0b2;--accent-200: #ffcc80;--accent-300: #ffb74d;--accent-400: #ffa726;--accent-500: #ff9800;--accent-600: #fb8c00;--accent-700: #f57c00;--accent-800: #ef6c00;--accent-900: #e65100;--status-pending: #ef4444;--status-pending-bg: rgba(239, 68, 68, .15);--status-in-progress: #f59e0b;--status-in-progress-bg: rgba(245, 158, 11, .15);--status-completed: #22c55e;--status-completed-bg: rgba(34, 197, 94, .15);--status-overdue: #dc2626;--bg-primary: #0f1724;--bg-secondary: #1a2332;--bg-tertiary: #243044;--bg-card: #1e2b3d;--bg-card-hover: #253549;--bg-overlay: rgba(0, 0, 0, .6);--bg-input: #1a2332;--text-primary: #f1f5f9;--text-secondary: #94a3b8;--text-tertiary: #64748b;--text-inverse: #0f172a;--border-color: #2d3e54;--border-light: #1e2d42;--divider: rgba(148, 163, 184, .12);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .5);--shadow-xl: 0 12px 40px rgba(0, 0, 0, .6);--shadow-glow: 0 0 20px rgba(30, 136, 229, .3);--font-family: "Noto Sans TC", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-size-xs: .6875rem;--font-size-sm: .8125rem;--font-size-base: .9375rem;--font-size-md: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.375rem;--font-size-2xl: 1.75rem;--font-size-3xl: 2.25rem;--font-weight-regular: 400;--font-weight-medium: 500;--font-weight-bold: 700;--space-xs: 4px;--space-sm: 8px;--space-md: 12px;--space-lg: 16px;--space-xl: 24px;--space-2xl: 32px;--space-3xl: 48px;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 20px;--radius-full: 50%;--header-height: 56px;--bottom-nav-height: 64px;--safe-area-bottom: env(safe-area-inset-bottom, 0px);--fab-size: 56px;--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .4s cubic-bezier(.4, 0, .2, 1);--z-base: 1;--z-dropdown: 100;--z-sticky: 200;--z-overlay: 300;--z-modal: 400;--z-toast: 500;--z-max: 999}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}html{font-size:16px;-webkit-text-size-adjust:100%;height:100%;height:100dvh;overflow:hidden}body{font-family:var(--font-family);font-size:var(--font-size-base);font-weight:var(--font-weight-regular);color:var(--text-primary);background-color:var(--bg-secondary);line-height:1.5;height:100%;height:100dvh;overflow:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;user-select:none;-webkit-user-select:none}a{color:var(--primary-400);text-decoration:none}img{max-width:100%;display:block}input,button,textarea,select{font-family:inherit;font-size:inherit;outline:none}button{cursor:pointer;border:none;background:none;color:inherit}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}#app{display:flex;flex-direction:column;height:100%;max-width:100%;margin:0 auto;position:relative;overflow:hidden;background-color:var(--bg-primary);padding-top:env(safe-area-inset-top,0px)}.login-gate{position:fixed;inset:0;z-index:99999;background:linear-gradient(135deg,#0a0e17,#121a2b,#0d1420);display:flex;align-items:center;justify-content:center;padding:24px}.login-gate-content{text-align:center;max-width:340px;width:100%}.login-gate-icon{width:80px;height:80px;border-radius:24px;background:linear-gradient(135deg,var(--primary-600),var(--primary-500));display:flex;align-items:center;justify-content:center;margin:0 auto 24px;box-shadow:0 8px 32px #1e88e54d}.login-gate-icon .material-symbols-outlined{font-size:40px;color:#fff}.login-gate-title{font-size:28px;font-weight:700;color:#fff;margin-bottom:8px;letter-spacing:1px}.login-gate-desc{font-size:14px;color:#ffffff80;margin-bottom:32px}.login-gate-btn{display:flex;align-items:center;justify-content:center;gap:12px;width:100%;padding:14px 24px;border-radius:12px;background:#fff;color:#333;font-size:15px;font-weight:600;border:none;cursor:pointer;transition:all .2s;box-shadow:0 2px 12px #0003}.login-gate-btn:active{transform:scale(.97);box-shadow:0 1px 6px #0003}.login-gate-btn:disabled{opacity:.6;cursor:not-allowed}.login-gate-error{margin-top:16px;padding:12px 16px;border-radius:10px;background:#ef535026;border:1px solid rgba(239,83,80,.3);color:#ef5350;font-size:13px;line-height:1.5}.login-gate-footer{margin-top:24px;font-size:12px;color:#ffffff40}.app-header{display:flex;align-items:center;height:var(--header-height);padding:0 var(--space-md);background:var(--bg-secondary);border-bottom:1px solid var(--border-light);flex-shrink:0;z-index:var(--z-sticky);gap:var(--space-sm)}.app-header .header-title{flex:1;font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.app-header .header-subtitle{font-size:var(--font-size-xs);color:var(--text-tertiary);font-weight:var(--font-weight-regular);margin-left:var(--space-xs)}.header-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-full);transition:background var(--transition-fast);flex-shrink:0;color:var(--text-secondary)}.header-btn:active{background:var(--bg-tertiary)}.header-btn .material-symbols-outlined{font-size:24px}.app-content{flex:1;overflow-y:auto;overflow-x:hidden;padding-bottom:calc(var(--bottom-nav-height) + var(--safe-area-bottom) + var(--space-lg));scroll-behavior:smooth;-webkit-overflow-scrolling:touch}.app-content.no-padding{padding-bottom:0}.page{display:none;padding:var(--space-lg);min-height:100%;animation:fadeIn .25s ease}.page.active{display:block}.page.full-page{padding:0}.bottom-nav{display:flex;align-items:center;justify-content:space-around;height:var(--bottom-nav-height);padding-bottom:var(--safe-area-bottom);background:var(--bg-secondary);border-top:1px solid var(--border-light);flex-shrink:0;z-index:var(--z-sticky)}.nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;height:100%;gap:2px;color:var(--text-tertiary);transition:color var(--transition-fast);position:relative}.nav-item .material-symbols-outlined{font-size:24px;transition:transform var(--transition-fast)}.nav-item span:last-child{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium)}.nav-item.active{color:var(--primary-400)}.nav-item.active .material-symbols-outlined{transform:scale(1.1)}.nav-item:active{color:var(--primary-300)}.nav-badge{position:absolute;top:6px;right:calc(50% - 20px);min-width:18px;height:18px;padding:0 5px;background:var(--status-pending);color:#fff;font-size:10px;font-weight:var(--font-weight-bold);border-radius:9px;display:flex;align-items:center;justify-content:center;line-height:1}.section-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--space-md);padding-left:var(--space-xs)}.material-symbols-outlined{font-variation-settings:"FILL" 0,"wght" 400,"GRAD" 0,"opsz" 24;vertical-align:middle}@media(max-width:767px){#app{max-width:480px}}@media(min-width:768px){.page{max-width:640px;margin-left:auto;margin-right:auto;padding:var(--space-lg) var(--space-xl)}.app-header{padding:0 var(--space-xl)}.app-header .header-title{font-size:var(--font-size-xl)}.bottom-nav{max-width:500px;margin:0 auto;border-radius:var(--radius-lg) var(--radius-lg) 0 0;box-shadow:0 -4px 20px #0000004d;height:72px}.nav-item{gap:4px}.nav-item .material-symbols-outlined{font-size:28px}.nav-item span:last-child{font-size:var(--font-size-sm)}.header-btn:hover{background:var(--bg-tertiary)}.nav-item:hover{color:var(--primary-300)}.card{transition:all var(--transition-fast)}.card:hover{border-color:var(--primary-700);box-shadow:0 4px 16px #0000004d;transform:translateY(-2px)}.card-title{font-size:var(--font-size-lg)}.card-subtitle{font-size:var(--font-size-sm)}.btn{cursor:pointer}.btn:hover{filter:brightness(1.15)}}@media(min-width:1200px){.page{max-width:720px}.bottom-nav{max-width:560px}.app-header{padding:0 calc(50% - 360px)}}.card{background:linear-gradient(145deg,var(--bg-card),var(--bg-secondary));border:1px solid var(--border-light);border-top:1px solid rgba(255,255,255,.08);border-radius:var(--radius-lg);padding:var(--space-lg);margin-bottom:var(--space-md);transition:all var(--transition-normal);position:relative;overflow:hidden;box-shadow:0 4px 12px #00000026}@media(hover:hover){.card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #00000040;border-color:var(--border-color)}}.card:active{transform:scale(.98);background:var(--bg-card-hover);box-shadow:0 2px 8px #0003}.card-highlight{position:absolute;left:0;top:0;bottom:0;width:4px}.card-highlight.pending{background:var(--status-pending)}.card-highlight.in-progress{background:var(--status-in-progress)}.card-highlight.completed{background:var(--status-completed)}.card-header{display:flex;align-items:flex-start;gap:var(--space-md);margin-bottom:var(--space-md)}.card-icon{width:44px;height:44px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0;background:var(--primary-900);color:var(--primary-300)}.card-icon .material-symbols-outlined{font-size:24px}.card-info{flex:1;min-width:0}.card-title{font-size:var(--font-size-md);font-weight:var(--font-weight-bold);color:var(--text-primary);margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.card-subtitle{font-size:var(--font-size-sm);color:var(--text-secondary)}.card-meta{display:flex;align-items:center;gap:var(--space-sm);font-size:var(--font-size-xs);color:var(--text-tertiary);margin-top:var(--space-sm)}.card-meta .material-symbols-outlined{font-size:14px}.card-actions{display:flex;align-items:center;gap:var(--space-sm);margin-top:var(--space-md);padding-top:var(--space-md);border-top:1px solid var(--divider);flex-wrap:wrap}@media(max-width:420px){.card-actions{gap:6px}.card-actions .btn{font-size:var(--font-size-xs);padding:6px 10px;min-height:36px}.card-actions .btn .material-symbols-outlined{font-size:16px}.card-actions .btn-icon{width:36px;height:36px}}.stats-row{display:flex;gap:var(--space-sm);margin-top:var(--space-md)}.stat-chip{display:flex;align-items:center;gap:4px;padding:4px 10px;border-radius:var(--radius-xl);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium)}.stat-chip.pending{background:var(--status-pending-bg);color:var(--status-pending)}.stat-chip.in-progress{background:var(--status-in-progress-bg);color:var(--status-in-progress)}.stat-chip.completed{background:var(--status-completed-bg);color:var(--status-completed)}.stat-chip .material-symbols-outlined{font-size:14px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:10px 20px;border-radius:var(--radius-md);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);transition:all var(--transition-fast);white-space:nowrap;min-height:44px}.btn .material-symbols-outlined{font-size:20px}.btn-primary{background:var(--primary-600);color:#fff}.btn-primary:active{background:var(--primary-700);transform:scale(.96)}.btn-accent{background:var(--accent-600);color:#fff}.btn-accent:active{background:var(--accent-700);transform:scale(.96)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:active{background:var(--border-color)}.btn-ghost{color:var(--text-secondary);padding:8px 12px}.btn-ghost:active{background:var(--bg-tertiary)}.btn-danger{background:var(--status-pending);color:#fff}.btn-danger:active{background:var(--status-overdue)}.btn-full{width:100%}.btn-sm{padding:6px 14px;font-size:var(--font-size-sm);min-height:36px}.btn-icon{width:40px;height:40px;padding:0;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:all var(--transition-fast)}.btn-icon:active{background:var(--bg-tertiary);color:var(--text-primary)}.fab{position:fixed;bottom:calc(var(--bottom-nav-height) + var(--safe-area-bottom) + var(--space-lg));right:var(--space-lg);width:var(--fab-size);height:var(--fab-size);border-radius:var(--radius-xl);background:var(--accent-600);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-lg);z-index:var(--z-dropdown);transition:all var(--transition-normal)}.fab:active{transform:scale(.9);box-shadow:var(--shadow-xl)}.fab .material-symbols-outlined{font-size:28px}.form-group{margin-bottom:var(--space-lg)}.form-label{display:block;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--text-secondary);margin-bottom:var(--space-sm)}.form-input,.form-select,.form-textarea{width:100%;padding:12px var(--space-lg);background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--font-size-base);transition:border-color var(--transition-fast);min-height:48px}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--primary-500);box-shadow:0 0 0 3px #1e88e526}.form-input::placeholder{color:var(--text-tertiary)}.form-textarea{min-height:80px;resize:vertical;line-height:1.5}.form-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2394a3b8' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px}.dialog-overlay{position:fixed;inset:0;background:var(--bg-overlay);display:none;align-items:flex-end;justify-content:center;z-index:var(--z-toast);padding:var(--space-lg);animation:fadeIn .2s ease}.dialog-overlay.active{display:flex}.dialog{background:var(--bg-card);border-radius:var(--radius-xl) var(--radius-xl) 0 0;width:100%;max-width:480px;max-height:85vh;overflow-y:auto;animation:slideUp .3s cubic-bezier(.4,0,.2,1);border:1px solid var(--border-color)}.dialog-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-xl) var(--space-xl) var(--space-md);position:sticky;top:0;background:var(--bg-card);z-index:1}.dialog-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold)}.dialog-body{padding:0 var(--space-xl) var(--space-xl)}.dialog-footer{display:flex;gap:var(--space-sm);padding:var(--space-lg) var(--space-xl) var(--space-xl);justify-content:flex-end}.toast{position:fixed;bottom:calc(var(--bottom-nav-height) + var(--safe-area-bottom) + var(--space-xl));left:50%;transform:translate(-50%) translateY(100px);background:var(--bg-tertiary);color:var(--text-primary);padding:12px 24px;border-radius:var(--radius-lg);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);box-shadow:var(--shadow-lg);z-index:var(--z-toast);opacity:0;transition:all .3s cubic-bezier(.4,0,.2,1);text-align:center;max-width:calc(100% - 48px);pointer-events:none;border:1px solid var(--border-color)}.toast.show{opacity:1;transform:translate(-50%) translateY(0)}.toast.undo{display:flex;align-items:center;gap:var(--space-md);pointer-events:auto;padding:10px 12px 10px 20px}.toast.undo .undo-btn{padding:6px 16px;border-radius:var(--radius-md);background:var(--primary-600);color:#fff;font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);border:none;cursor:pointer;white-space:nowrap;transition:background var(--transition-fast)}.toast.undo .undo-btn:active{background:var(--primary-700);transform:scale(.95)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-3xl) var(--space-xl);text-align:center;min-height:300px}.empty-state .empty-icon{font-size:64px;color:var(--text-tertiary);margin-bottom:var(--space-xl);opacity:.5}.empty-state h3{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--text-secondary);margin-bottom:var(--space-sm)}.empty-state p{font-size:var(--font-size-sm);color:var(--text-tertiary);max-width:260px}.progress-bar{width:100%;height:6px;background:var(--bg-tertiary);border-radius:3px;overflow:hidden;margin-top:var(--space-sm)}.progress-fill{height:100%;background:linear-gradient(90deg,var(--status-completed),var(--primary-400));border-radius:3px;transition:width var(--transition-slow)}.status-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 12px;border-radius:var(--radius-xl);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);box-shadow:inset 0 0 0 1px #ffffff0d}.status-badge.pending{background:var(--status-pending-bg);color:var(--status-pending)}.status-badge.in-progress{background:var(--status-in-progress-bg);color:var(--status-in-progress)}.status-badge.completed{background:var(--status-completed-bg);color:var(--status-completed)}.quick-text-list{display:flex;flex-wrap:wrap;gap:var(--space-sm);margin-bottom:var(--space-md)}.quick-text-chip{padding:6px 14px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-xl);font-size:var(--font-size-sm);color:var(--text-secondary);transition:all var(--transition-fast);white-space:nowrap}.quick-text-chip:active{background:var(--primary-900);border-color:var(--primary-600);color:var(--primary-300)}.quick-text-chip.active{background:var(--primary-900);border-color:var(--primary-500);color:var(--primary-300)}.photo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-sm)}.photo-item{position:relative;aspect-ratio:1;border-radius:var(--radius-md);overflow:hidden;background:var(--bg-tertiary)}.photo-item img{width:100%;height:100%;object-fit:cover}.photo-item .photo-delete{position:absolute;top:4px;right:4px;width:24px;height:24px;background:#0009;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center}.photo-item .photo-delete .material-symbols-outlined{font-size:16px;color:#fff}.photo-add{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;border:2px dashed var(--border-color);border-radius:var(--radius-md);aspect-ratio:1;color:var(--text-tertiary);transition:all var(--transition-fast)}.photo-add:active{border-color:var(--primary-500);color:var(--primary-400);background:var(--primary-900)}.photo-add .material-symbols-outlined{font-size:28px}.photo-add span:last-child{font-size:var(--font-size-xs)}.loading-overlay{position:fixed;inset:0;background:var(--bg-overlay);display:none;align-items:center;justify-content:center;flex-direction:column;gap:var(--space-lg);z-index:var(--z-max)}.loading-overlay.active{display:flex}.loading-spinner{width:48px;height:48px;border:4px solid var(--border-color);border-top-color:var(--primary-400);border-radius:50%;animation:spin .8s linear infinite}.loading-text{color:var(--text-secondary);font-size:var(--font-size-sm)}.swipe-container{position:relative;overflow:hidden}.swipe-actions{position:absolute;right:0;top:0;bottom:0;display:flex;transform:translate(100%);transition:transform var(--transition-normal)}.swipe-action{display:flex;align-items:center;justify-content:center;width:72px;color:#fff}.swipe-action.delete{background:var(--status-pending)}.swipe-action.edit{background:var(--primary-600)}.sidebar-overlay{position:fixed;inset:0;background:var(--bg-overlay);z-index:var(--z-overlay);display:none;opacity:0;transition:opacity var(--transition-normal)}.sidebar-overlay.active{display:block;opacity:1}.sidebar-panel{position:fixed;top:0;right:0;bottom:0;width:85%;max-width:380px;background:var(--bg-secondary);z-index:var(--z-modal);transform:translate(100%);transition:transform .35s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;overflow:hidden}.sidebar-panel.active{transform:translate(0)}.sidebar-header{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-lg);border-bottom:1px solid var(--border-light);flex-shrink:0}.sidebar-body{flex:1;overflow-y:auto;padding:var(--space-lg);-webkit-overflow-scrolling:touch}.sidebar-footer{padding:var(--space-lg);border-top:1px solid var(--border-light);flex-shrink:0}.photo-actions{position:absolute;bottom:0;left:0;right:0;display:flex;justify-content:flex-end;gap:2px;padding:4px;background:linear-gradient(transparent,#000000b3);opacity:1}.photo-action-btn{width:28px;height:28px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;background:#00000080;color:#fff;transition:all var(--transition-fast);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.photo-action-btn:active{transform:scale(.9)}.photo-action-btn .material-symbols-outlined{font-size:16px}.photo-action-btn.btn-share-photo{background:#1e88e5b3}.photo-action-btn.btn-share-photo:active{background:#1e88e5}.watermark-settings{padding:var(--space-sm) var(--space-lg)}.toggle-row{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md) 0;border-bottom:1px solid var(--divider);cursor:pointer}.toggle-row:last-child{border-bottom:none}.toggle-row-icon{font-size:22px;color:var(--text-tertiary);flex-shrink:0}.toggle-row-label{flex:1;font-size:var(--font-size-base);color:var(--text-primary);font-weight:var(--font-weight-medium)}.toggle-switch{position:relative;width:48px;height:28px;flex-shrink:0}.toggle-switch input[type=checkbox]{opacity:0;width:0;height:0;position:absolute}.toggle-slider{position:absolute;inset:0;background:var(--bg-tertiary);border-radius:14px;border:1px solid var(--border-color);transition:all .3s ease;cursor:pointer}.toggle-slider:before{content:"";position:absolute;width:22px;height:22px;border-radius:50%;background:#fff;top:2px;left:2px;transition:transform .3s cubic-bezier(.4,0,.2,1);box-shadow:0 1px 3px #0000004d}.watermark-preview{position:relative;background:var(--bg-tertiary);overflow:hidden}.watermark-preview-bar{position:absolute;bottom:0;left:0;right:0;display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:#000000a6;min-height:32px}.watermark-preview-left,.watermark-preview-right{font-size:11px;font-weight:700;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.watermark-preview-left{flex:1;min-width:0}.watermark-preview-right{flex-shrink:0;margin-left:8px;color:#ffffffd9}.toggle-switch input:checked+.toggle-slider{background:var(--primary-600);border-color:var(--primary-600)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(20px)}.pressure-result-icon{width:36px;height:36px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;background:var(--bg-tertiary)}.pressure-result-icon.completed{background:var(--status-completed-bg)}.pressure-result-icon.pending{background:var(--status-pending-bg)}.pressure-values-row{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-sm);margin-top:var(--space-md);padding-top:var(--space-md);border-top:1px solid var(--divider)}.pressure-value{display:flex;flex-direction:column;align-items:center;gap:2px}.pressure-label{font-size:var(--font-size-xs);color:var(--text-tertiary)}.pressure-number{font-size:var(--font-size-md);font-weight:var(--font-weight-bold);font-variant-numeric:tabular-nums;color:var(--text-primary)}.pressure-number.completed{color:var(--status-completed)}.pressure-number.pending{color:var(--status-pending)}.pressure-calc-result{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);background:var(--bg-tertiary);border-radius:var(--radius-md);margin-top:var(--space-md);margin-bottom:var(--space-md)}.pressure-calc-item{display:flex;align-items:center;gap:var(--space-sm);font-size:var(--font-size-sm);color:var(--text-secondary)}.pressure-calc-divider{width:1px;height:24px;background:var(--border-color)}.pressure-calc-badge{padding:2px 10px;border-radius:var(--radius-xl);font-weight:var(--font-weight-bold);font-size:var(--font-size-sm)}.pressure-calc-badge.pass{background:var(--status-completed-bg);color:var(--status-completed)}.pressure-calc-badge.fail{background:var(--status-pending-bg);color:var(--status-pending)}.pressure-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md)}.pressure-detail-item{padding:var(--space-md);background:var(--bg-tertiary);border-radius:var(--radius-md);text-align:center}.pressure-detail-label{font-size:var(--font-size-xs);color:var(--text-tertiary);margin-bottom:4px}.pressure-detail-value{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);font-variant-numeric:tabular-nums;color:var(--text-primary)}.pressure-detail-value small{font-size:var(--font-size-xs);font-weight:var(--font-weight-regular);color:var(--text-tertiary)}.pressure-detail-value.completed{color:var(--status-completed)}.pressure-detail-value.pending{color:var(--status-pending)}.tool-card{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-lg) var(--space-xl);background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-lg);margin-bottom:var(--space-md);cursor:pointer;transition:all var(--transition-normal)}.tool-card:active{transform:scale(.98);background:var(--bg-card-hover)}.tool-card-icon{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.tool-card-icon .material-symbols-outlined{font-size:26px}.tool-card-info{flex:1;min-width:0}.tool-card-title{font-size:var(--font-size-md);font-weight:var(--font-weight-bold);color:var(--text-primary);margin-bottom:2px}.tool-card-desc{font-size:var(--font-size-xs);color:var(--text-tertiary)}.tool-card-badge{font-size:var(--font-size-xs);color:var(--text-secondary);font-weight:var(--font-weight-medium);flex-shrink:0}@media(min-width:768px){.stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md)}.tool-card{display:inline-flex;width:calc(50% - var(--space-sm));vertical-align:top}.tool-card:nth-child(odd){margin-right:var(--space-sm)}.tool-card:nth-child(2n){margin-left:var(--space-sm)}.photo-grid{grid-template-columns:repeat(4,1fr)}.sidebar-panel{width:420px}.dialog{max-width:500px}.form-input:hover,.form-textarea:hover,.form-select:hover{border-color:var(--primary-600)}.btn:hover{filter:brightness(1.1)}.daily-report-card{display:inline-block;width:calc(50% - var(--space-sm));vertical-align:top}.daily-report-card:nth-child(odd){margin-right:var(--space-sm)}.daily-report-card:nth-child(2n){margin-left:var(--space-sm)}}@media(min-width:1200px){.sidebar-panel{width:500px}.dialog{max-width:600px}.photo-grid{grid-template-columns:repeat(5,1fr)}.card-actions .btn{font-size:var(--font-size-sm);padding:8px 16px}.card-actions .btn-icon{width:36px;height:36px}.card-actions .btn-icon:hover{background:var(--bg-tertiary);border-radius:var(--radius-md)}.empty-state .empty-icon{font-size:72px}.empty-state h3{font-size:var(--font-size-xl)}}.daily-cal-header{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) 0;margin-bottom:var(--space-sm)}.daily-cal-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--text-primary);min-width:120px;text-align:center}.daily-cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px;margin-bottom:var(--space-md)}.daily-cal-day-header{text-align:center;font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);color:var(--text-tertiary);padding:4px 0}.daily-cal-cell{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:var(--radius-md);background:var(--bg-tertiary);cursor:default;position:relative;transition:all var(--transition-fast);min-height:44px}.daily-cal-cell.empty{background:transparent}.daily-cal-cell.future{opacity:.35}.daily-cal-cell.weekend .daily-cal-day-num{color:var(--text-tertiary)}.daily-cal-cell.today{border:2px solid var(--primary-500)}.daily-cal-cell.has-data{cursor:pointer}.daily-cal-cell.has-data:active{transform:scale(.92)}.daily-cal-day-num{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--text-secondary);line-height:1}.daily-cal-cell.has-data .daily-cal-day-num{color:var(--text-primary)}.daily-cal-count{font-size:10px;font-weight:var(--font-weight-bold);color:var(--accent-400);line-height:1;margin-top:1px}.daily-month-summary{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-sm) var(--space-md);background:var(--bg-tertiary);border-radius:var(--radius-lg);margin-bottom:var(--space-lg);border:1px solid var(--border-color);overflow-x:auto}.daily-summary-item{display:flex;align-items:center;gap:4px;font-size:var(--font-size-xs);color:var(--text-secondary);white-space:nowrap}.daily-list-item{padding:var(--space-md) var(--space-lg);background:var(--bg-card);border-radius:var(--radius-lg);margin-bottom:var(--space-xs);border:1px solid var(--border-color);cursor:pointer;transition:all var(--transition-fast)}.daily-list-item:active{transform:scale(.98);background:var(--bg-tertiary)}.daily-list-item.highlight{border-color:var(--primary-500);box-shadow:0 0 0 1px var(--primary-500),var(--shadow-sm)}.daily-list-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-xs)}.daily-list-date{font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);color:var(--text-primary)}.daily-list-total{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--accent-400)}.daily-list-total span{font-size:var(--font-size-xs);font-weight:400;color:var(--text-tertiary)}.daily-list-trades{display:flex;flex-wrap:wrap;gap:4px}.daily-trade-tag{font-size:11px;padding:2px 8px;border-radius:var(--radius-xl);background:#ffffff0f;color:var(--text-secondary);border:1px solid var(--border-color)}.daily-trade-tag b{color:var(--primary-300);font-weight:var(--font-weight-bold)}.stage-selector{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-sm)}.stage-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:var(--space-md) var(--space-sm);border-radius:var(--radius-md);border:2px solid var(--border-color);background:var(--bg-tertiary);color:var(--text-tertiary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-fast)}.stage-btn.active{border-color:var(--primary-500);background:var(--primary-900);color:var(--primary-300)}.stage-btn:active{transform:scale(.96)}.pressure-stage-row.clickable:active{background:var(--bg-tertiary)}.pressure-stage-row.empty{opacity:.5}.report-photo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-sm);max-height:60vh;overflow-y:auto;padding:var(--space-xs)}.report-photo-item{position:relative;border-radius:var(--radius-md);overflow:hidden;cursor:pointer;border:3px solid transparent;transition:border-color .2s,transform .15s}.report-photo-item:active{transform:scale(.96)}.report-photo-item img{width:100%;aspect-ratio:1;object-fit:cover;display:block}.report-photo-item .report-photo-checkbox{position:absolute;top:4px;right:4px;width:28px;height:28px;border-radius:50%;background:#0006;display:flex;align-items:center;justify-content:center;opacity:.6;transition:all .2s}.report-photo-item .report-photo-checkbox .material-symbols-outlined{font-size:20px;color:#ffffff80}.report-photo-item.selected{border-color:var(--primary)}.report-photo-item.selected .report-photo-checkbox{background:var(--primary);opacity:1}.report-photo-item.selected .report-photo-checkbox .material-symbols-outlined{color:#fff}.report-photo-label{position:absolute;bottom:0;left:0;right:0;padding:2px 6px;background:linear-gradient(transparent,#000000b3);color:#fff;font-size:var(--font-size-xs);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.drawing-viewer-page{position:relative;height:100%;background:#0a0e17}.drawing-map{width:100%;height:100%;background:#0a0e17;z-index:var(--z-base)}.drawing-map .leaflet-control-zoom{display:none}.drawing-topbar{position:absolute;top:0;left:0;right:0;display:flex;align-items:center;padding:var(--space-sm) var(--space-md);background:linear-gradient(180deg,#0f1724f2,#0f172400);z-index:var(--z-dropdown);gap:4px}.drawing-topbar .back-btn{width:36px;height:36px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;background:#0006;color:var(--text-primary);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);flex-shrink:0}.breadcrumb{display:flex;align-items:center;flex:1;min-width:0;gap:2px;overflow:hidden}.breadcrumb-sep{color:var(--text-tertiary);font-size:14px;flex-shrink:0}.breadcrumb-item{font-size:var(--font-size-xs);color:var(--text-tertiary);padding:3px 6px;border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:80px;transition:all var(--transition-fast)}.breadcrumb-item:active{background:#ffffff1a}.breadcrumb-item.current{color:var(--text-primary);font-weight:var(--font-weight-bold);font-size:var(--font-size-sm);max-width:120px}.drawing-topbar .version-badge{padding:4px 10px;background:#1e88e54d;border:1px solid rgba(30,136,229,.5);border-radius:var(--radius-xl);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--primary-200);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);flex-shrink:0}.drawing-topbar .nav-tree-btn{width:36px;height:36px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;background:#0006;color:var(--text-secondary);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);flex-shrink:0;transition:all var(--transition-fast)}.drawing-topbar .nav-tree-btn:active{background:var(--primary-600);color:#fff}.quick-nav-overlay{position:fixed;inset:0;background:#00000080;z-index:calc(var(--z-modal) - 1);opacity:0;pointer-events:none;transition:opacity var(--transition-fast)}.quick-nav-overlay.active{opacity:1;pointer-events:auto}.quick-nav-drawer{position:fixed;top:0;right:0;bottom:0;width:min(320px,85vw);background:var(--bg-secondary);z-index:var(--z-modal);transform:translate(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;overflow:hidden}.quick-nav-drawer.active{transform:translate(0)}.quick-nav-header{padding:var(--space-lg) var(--space-lg) var(--space-md);border-bottom:1px solid var(--border-color);display:flex;align-items:center;gap:var(--space-md)}.quick-nav-header h3{flex:1;font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--text-primary);margin:0}.quick-nav-body{flex:1;overflow-y:auto;padding:var(--space-md) 0;-webkit-overflow-scrolling:touch}.nav-floor-group{margin-bottom:var(--space-xs)}.nav-floor-label{padding:var(--space-sm) var(--space-lg);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px}.nav-system-item{display:flex;align-items:center;gap:var(--space-md);padding:10px var(--space-lg) 10px calc(var(--space-lg) + 12px);cursor:pointer;transition:background var(--transition-fast);border-left:3px solid transparent}.nav-system-item:active{background:#ffffff0d}.nav-system-item.current{background:#1e88e51f;border-left-color:var(--primary-500)}.nav-system-item .nav-sys-icon{width:32px;height:32px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);font-size:16px;flex-shrink:0}.nav-system-item.current .nav-sys-icon{background:var(--primary-600);color:#fff}.nav-system-item .nav-sys-name{flex:1;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--text-secondary)}.nav-system-item.current .nav-sys-name{color:var(--text-primary);font-weight:var(--font-weight-bold)}.nav-system-item .nav-sys-badge{font-size:var(--font-size-xs);color:var(--text-tertiary)}.floor-switcher{position:absolute;left:var(--space-md);top:50%;transform:translateY(-50%);z-index:var(--z-dropdown);display:flex;flex-direction:column;gap:var(--space-xs)}.floor-switch-btn{width:40px;height:40px;border-radius:var(--radius-md);background:#1e2b3dd9;border:1px solid var(--border-color);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all var(--transition-fast)}.floor-switch-btn.active{background:var(--primary-600);border-color:var(--primary-500);color:#fff}.floor-switch-btn:active{transform:scale(.9)}.drawing-toolbar{position:absolute;bottom:0;left:0;right:0;padding:var(--space-md) var(--space-lg);padding-bottom:calc(var(--space-md) + var(--safe-area-bottom));background:linear-gradient(0deg,#0f1724f2,#0f172400);z-index:var(--z-dropdown);display:flex;align-items:center;gap:var(--space-md)}.drawing-tool-btn{display:flex;flex-direction:column;align-items:center;gap:2px;padding:var(--space-sm);border-radius:var(--radius-md);color:var(--text-secondary);font-size:var(--font-size-xs);min-width:56px;transition:all var(--transition-fast)}.drawing-tool-btn .material-symbols-outlined{font-size:22px}.drawing-tool-btn.active{color:var(--primary-300);background:#1e88e526}.drawing-tool-btn:active{transform:scale(.9)}.drawing-toolbar .spacer{flex:1}.add-pin-indicator{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none;z-index:var(--z-dropdown);text-align:center;display:none}.add-pin-indicator.active{display:block}.add-pin-crosshair{width:48px;height:48px;border:2px solid var(--accent-500);border-radius:var(--radius-full);margin:0 auto var(--space-sm);position:relative;animation:pulse 1.5s ease-in-out infinite}.add-pin-crosshair:before,.add-pin-crosshair:after{content:"";position:absolute;background:var(--accent-500)}.add-pin-crosshair:before{width:2px;height:16px;top:50%;left:50%;transform:translate(-50%,-50%)}.add-pin-crosshair:after{width:16px;height:2px;top:50%;left:50%;transform:translate(-50%,-50%)}.add-pin-text{font-size:var(--font-size-sm);color:var(--accent-300);font-weight:var(--font-weight-medium);text-shadow:0 1px 4px rgba(0,0,0,.6);background:#0006;padding:4px 12px;border-radius:var(--radius-xl);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.pin-hit-area{width:44px;height:44px;display:flex;align-items:center;justify-content:center;cursor:pointer}.pin-marker{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-full);font-size:11px;font-weight:var(--font-weight-bold);color:#fff;cursor:pointer;transition:transform var(--transition-fast);box-shadow:0 2px 8px #0006;border:2px solid rgba(255,255,255,.3);position:relative}.pin-creator-badge{position:absolute;bottom:-5px;right:-5px;width:16px;height:16px;border-radius:50%;background:#0f1724d9;border:1.5px solid rgba(255,255,255,.5);color:#fff;font-size:9px;font-weight:700;display:flex;align-items:center;justify-content:center;line-height:1;pointer-events:none}.pin-marker.pending{background:var(--status-pending)}.pin-marker.in-progress{background:var(--status-in-progress)}.pin-marker.completed{background:var(--status-completed)}.pin-marker.selected{transform:scale(1.3);border-color:#fff;box-shadow:0 0 0 4px #fff3,0 2px 12px #00000080;z-index:100!important}.pin-marker.overdue{animation:overdueFlash 1s ease-in-out infinite}.pin-tooltip{background:#0f1724eb!important;border:1px solid rgba(255,255,255,.15)!important;border-radius:8px!important;color:#fff!important;font-size:12px!important;font-weight:500!important;padding:5px 10px!important;box-shadow:0 4px 12px #0006!important;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);white-space:nowrap;pointer-events:none!important}.pin-tooltip:before{border-top-color:#0f1724eb!important}.pin-popup{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--space-md);min-width:180px;box-shadow:var(--shadow-lg)}.pin-popup .pin-popup-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);color:var(--text-primary);margin-bottom:4px}.pin-popup .pin-popup-desc{font-size:var(--font-size-xs);color:var(--text-secondary);margin-bottom:var(--space-sm)}.pin-popup .pin-popup-action{font-size:var(--font-size-xs);color:var(--primary-400);font-weight:var(--font-weight-medium)}.version-compare{position:absolute;inset:0;display:none;z-index:var(--z-dropdown)}.version-compare.active{display:flex}.version-compare-slider{position:absolute;top:0;bottom:0;width:4px;background:var(--accent-500);z-index:10;cursor:ew-resize}.version-compare-slider:after{content:"⟷";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:36px;height:36px;background:var(--accent-600);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px;box-shadow:var(--shadow-md)}.drawing-stats-bar{position:absolute;bottom:80px;left:var(--space-md);right:var(--space-md);display:flex;gap:var(--space-sm);z-index:var(--z-dropdown);pointer-events:none}.drawing-stat-pill{padding:4px 10px;background:#1e2b3dd9;border-radius:var(--radius-xl);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);display:flex;align-items:center;gap:4px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border-color)}.drawing-stat-pill.pending{color:var(--status-pending)}.drawing-stat-pill.in-progress{color:var(--status-in-progress)}.drawing-stat-pill.completed{color:var(--status-completed)}.drawing-stat-pill.inspection{color:var(--primary-300)}.pin-marker.inspection{background:var(--primary-500);border-color:#fff6}.pin-marker.inspection.pass{background:var(--primary-500)}.pin-marker.inspection.conditional{background:var(--status-in-progress)}.pin-marker.inspection.fail{background:var(--status-pending)}.pin-type-selector{display:flex;gap:var(--space-md);padding:var(--space-md) 0}.pin-type-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:var(--space-sm);padding:var(--space-xl) var(--space-md);border-radius:var(--radius-lg);border:2px solid var(--border-color);background:var(--bg-card);transition:all var(--transition-fast);cursor:pointer}.pin-type-btn:active{transform:scale(.96)}.pin-type-btn .pin-type-icon{width:48px;height:48px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:24px}.pin-type-btn .pin-type-icon.deficiency{background:#ef535026;color:var(--status-pending)}.pin-type-btn .pin-type-icon.inspection{background:#1e88e526;color:var(--primary-400)}.pin-type-btn .pin-type-title{font-size:var(--font-size-base);font-weight:var(--font-weight-bold);color:var(--text-primary)}.pin-type-btn .pin-type-desc{font-size:var(--font-size-xs);color:var(--text-tertiary);text-align:center}.result-btn-group{display:flex;gap:var(--space-sm)}.result-btn{flex:1;padding:10px;border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);text-align:center;border:1px solid var(--border-color);background:var(--bg-tertiary);color:var(--text-secondary);transition:all var(--transition-fast)}.result-btn:active{transform:scale(.96)}.result-btn.active[data-result=pass]{background:var(--primary-600);border-color:var(--primary-500);color:#fff}.result-btn.active[data-result=conditional]{background:var(--status-in-progress);border-color:var(--status-in-progress);color:#fff}.result-btn.active[data-result=fail]{background:var(--status-pending);border-color:var(--status-pending);color:#fff}.pin-cluster{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-full);font-size:14px;font-weight:var(--font-weight-bold);color:#fff;box-shadow:0 2px 10px #0006;border:2px solid rgba(255,255,255,.35)}.pin-cluster.cluster-deficiency{background:var(--status-pending)}.pin-cluster.cluster-inspection{background:var(--primary-500)}.pin-cluster.cluster-mixed{background:linear-gradient(135deg,var(--status-pending) 50%,var(--primary-500) 50%)}.marker-cluster-small,.marker-cluster-medium,.marker-cluster-large,.marker-cluster-small div,.marker-cluster-medium div,.marker-cluster-large div{background:transparent!important}.filter-bar{position:absolute;top:52px;left:0;right:0;display:flex;gap:6px;padding:6px var(--space-md);z-index:var(--z-dropdown);overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.filter-bar::-webkit-scrollbar{display:none}.filter-chip{flex-shrink:0;padding:5px 12px;border-radius:var(--radius-xl);font-size:12px;font-weight:var(--font-weight-medium);border:1px solid var(--border-color);background:#1e2b3dcc;color:var(--text-secondary);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.filter-chip:active{transform:scale(.94)}.filter-chip.active{background:var(--primary-600);border-color:var(--primary-500);color:#fff}.autosave-indicator{font-size:var(--font-size-xs);color:var(--text-tertiary);text-align:center;padding:4px 0;transition:opacity .3s}.autosave-indicator.saving{color:var(--accent-400)}.autosave-indicator.saved{color:var(--status-completed)}.pin-dragging .pin-marker{animation:pinDragPulse 1s ease-in-out infinite;cursor:grab}.pin-dragging .pin-marker:active{cursor:grabbing}@keyframes pinDragPulse{0%,to{box-shadow:0 0 #ffc10780,0 2px 8px #0006}50%{box-shadow:0 0 0 10px #ffc10700,0 2px 12px #00000080}}.move-pin-banner{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:var(--z-dropdown);text-align:center;pointer-events:none}.move-pin-banner .move-pin-text{font-size:var(--font-size-sm);color:var(--accent-300);font-weight:var(--font-weight-bold);text-shadow:0 1px 4px rgba(0,0,0,.6);background:#0009;padding:8px 20px;border-radius:var(--radius-xl);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:1px solid rgba(255,193,7,.3)}.move-pin-confirm-bar{position:absolute;bottom:100px;left:var(--space-md);right:var(--space-md);display:flex;gap:var(--space-sm);z-index:var(--z-dropdown)}.move-pin-confirm-bar button{flex:1;padding:12px;border-radius:var(--radius-lg);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border-color)}.move-pin-confirm-bar .btn-cancel-move{background:#1e2b3de6;color:var(--text-secondary)}.move-pin-confirm-bar .btn-confirm-move{background:var(--primary-600);border-color:var(--primary-500);color:#fff}.annotation-toolbar{position:absolute;right:var(--space-md);top:50%;transform:translateY(-50%);z-index:var(--z-dropdown);display:flex;flex-direction:column;gap:4px;background:#0f1724e6;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:var(--radius-lg);border:1px solid var(--border-color);padding:6px}.ann-tool-btn{width:40px;height:40px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;background:transparent;color:var(--text-secondary);border:none;cursor:pointer;transition:all var(--transition-fast)}.ann-tool-btn .material-symbols-outlined{font-size:20px}.ann-tool-btn:hover{background:#ffffff14}.ann-tool-btn.active{background:var(--primary-600);color:#fff}.ann-tool-btn:disabled{opacity:.3;cursor:default}.ann-delete-btn:not(:disabled):hover{background:#ef444433;color:#ef4444}.ann-color-picker{display:flex;flex-wrap:wrap;gap:3px;padding:4px 0;border-top:1px solid var(--border-color);border-bottom:1px solid var(--border-color);margin:2px 0;justify-content:center}.ann-color{width:20px;height:20px;border-radius:var(--radius-full);border:2px solid transparent;cursor:pointer;transition:all var(--transition-fast)}.ann-color:hover{transform:scale(1.15)}.ann-color.active{border-color:#fff;box-shadow:0 0 0 2px #ffffff4d}.annotation-text-marker{background:none!important;border:none!important}.ann-text{font-size:13px;font-weight:700;padding:2px 8px;background:#0009;border:1.5px solid currentColor;border-radius:4px;white-space:nowrap;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);cursor:pointer;-webkit-user-select:none;user-select:none}.ann-cursor-circle,.ann-cursor-arrow{cursor:crosshair!important}.ann-cursor-text{cursor:text!important}.ann-cursor-select{cursor:default!important}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes slideDown{0%{transform:translateY(0)}to{transform:translateY(100%)}}@keyframes slideFromTop{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes slideOutRight{0%{transform:translate(0)}to{transform:translate(100%)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1;transform:translate(-50%,-50%) scale(1)}50%{opacity:.6;transform:translate(-50%,-50%) scale(1.1)}}@keyframes overdueFlash{0%,to{box-shadow:0 2px 8px #0006}50%{box-shadow:0 0 0 6px #dc26264d,0 2px 8px #0006}}.offline-pulse{display:inline-block;width:8px;height:8px;border-radius:50%;background:#ef5350;animation:offlinePulse 1.5s ease-in-out infinite;flex-shrink:0}@keyframes offlinePulse{0%,to{opacity:1;box-shadow:0 0 #ef535099}50%{opacity:.7;box-shadow:0 0 0 6px #ef535000}}@keyframes ripple{0%{transform:scale(0);opacity:.5}to{transform:scale(4);opacity:0}}@keyframes bounceIn{0%{transform:scale(0);opacity:0}60%{transform:scale(1.15)}to{transform:scale(1);opacity:1}}@keyframes shimmer{0%{background-position:-200px 0}to{background-position:200px 0}}.animate-fade-in{animation:fadeIn .25s ease}.animate-slide-up{animation:slideUp .3s cubic-bezier(.4,0,.2,1)}.animate-bounce-in{animation:bounceIn .4s cubic-bezier(.4,0,.2,1)}.skeleton{background:linear-gradient(90deg,var(--bg-tertiary) 25%,var(--bg-card-hover) 50%,var(--bg-tertiary) 75%);background-size:400px 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-sm)}.stagger-item{animation:fadeIn .3s ease backwards}.stagger-item:nth-child(1){animation-delay:.05s}.stagger-item:nth-child(2){animation-delay:.1s}.stagger-item:nth-child(3){animation-delay:.15s}.stagger-item:nth-child(4){animation-delay:.2s}.stagger-item:nth-child(5){animation-delay:.25s}.stagger-item:nth-child(6){animation-delay:.3s}.stagger-item:nth-child(7){animation-delay:.35s}.stagger-item:nth-child(8){animation-delay:.4s}.stagger-item:nth-child(9){animation-delay:.45s}.stagger-item:nth-child(10){animation-delay:.5s}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}
