:root{--primary: #4f46e5;--primary-dark: #3730a3;--primary-light: #6366f1;--primary-50: #eef2ff;--primary-100: #e0e7ff;--accent: #4f46e5;--accent-hover: #4338ca;--success: #10b981;--success-light: #d1fae5;--danger: #ef4444;--danger-light: #fee2e2;--warning: #f59e0b;--warning-light: #fef3c7;--bg: #f8fafc;--bg-card: #ffffff;--bg-surface: #f1f5f9;--border: #e2e8f0;--border-light: #f1f5f9;--text: #0f172a;--text-muted: #64748b;--text-light: #94a3b8;--sidebar-w: 260px;--topbar-h: 60px;--radius: 12px;--radius-sm: 8px;--radius-xs: 6px;--shadow-xs: 0 1px 2px rgba(0,0,0,.05);--shadow: 0 1px 3px rgba(0,0,0,.06), 0 4px 16px rgba(0,0,0,.04);--shadow-md: 0 4px 20px rgba(0,0,0,.08);--shadow-lg: 0 8px 40px rgba(0,0,0,.12);--shadow-xl: 0 20px 60px rgba(0,0,0,.15);--transition: .15s ease;--transition-slow: .3s ease;--sidebar-bg: linear-gradient(180deg, #1e1b4b 0%, #312e81 60%, #3730a3 100%)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:15px;scroll-behavior:smooth}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg);color:var(--text);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit;font-size:.9rem}.app-layout{display:flex;min-height:100vh}.sidebar{position:fixed;left:0;top:0;bottom:0;width:var(--sidebar-w);background:var(--sidebar-bg);display:flex;flex-direction:column;z-index:100;transition:transform var(--transition-slow);box-shadow:4px 0 24px #00000026}.sidebar-brand{display:flex;align-items:center;gap:12px;padding:22px 20px 18px;border-bottom:1px solid rgba(255,255,255,.08)}.brand-icon{width:36px;height:36px;background:linear-gradient(135deg,#6366f1,#4f46e5);border-radius:10px;display:flex;align-items:center;justify-content:center;font-weight:800;color:#fff;flex-shrink:0;box-shadow:0 4px 12px #6366f180;font-size:1rem}.brand-name{font-weight:800;font-size:1.1rem;color:#fff;letter-spacing:-.4px}.sidebar-nav{flex:1;padding:10px;overflow-y:auto;display:flex;flex-direction:column;gap:2px}.nav-item{display:flex;align-items:center;gap:10px;padding:10px 12px;color:#ffffffa6;transition:background var(--transition),color var(--transition);font-size:.875rem;font-weight:500;border-radius:var(--radius-sm);position:relative}.nav-item:hover{background:#ffffff14;color:#fffffff2}.nav-item.active{background:#ffffff1f;color:#fff;font-weight:600}.nav-item.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:20px;background:#818cf8;border-radius:0 3px 3px 0}.nav-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-xs);font-size:.95rem;flex-shrink:0;transition:background var(--transition)}.nav-item.active .nav-icon{background:#818cf833}.sidebar-footer{padding:14px 10px;border-top:1px solid rgba(255,255,255,.08)}.user-card{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-sm);background:#ffffff0f;margin-bottom:8px}.user-avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem;flex-shrink:0;text-transform:uppercase;box-shadow:0 2px 8px #6366f166}.user-info-text{flex:1;min-width:0}.user-name{font-size:.82rem;font-weight:600;color:#fff;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:.7rem;color:#ffffff73;text-transform:capitalize}.sidebar-actions{display:flex;flex-direction:column;gap:2px}.btn-change-pw{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;background:transparent;border:none;border-radius:var(--radius-xs);color:#fff9;font-size:.82rem;font-weight:500;text-decoration:none;transition:background var(--transition),color var(--transition)}.btn-change-pw:hover{background:#ffffff14;color:#ffffffe6}.btn-logout{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;background:transparent;border:none;border-radius:var(--radius-xs);color:#ef4444b3;font-size:.82rem;font-weight:500;transition:background var(--transition),color var(--transition)}.btn-logout:hover{background:#ef44441a;color:#ef4444}.sidebar-overlay{display:none}.main-area{margin-left:var(--sidebar-w);flex:1;display:flex;flex-direction:column;min-height:100vh}.topbar{height:var(--topbar-h);background:#ffffffeb;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 28px;gap:16px;position:sticky;top:0;z-index:50;box-shadow:0 1px 8px #0000000a}.menu-toggle{background:none;border:none;font-size:1.2rem;color:var(--text-muted);padding:6px;display:none;border-radius:var(--radius-xs);transition:background var(--transition)}.menu-toggle:hover{background:var(--bg-surface)}.page-title{font-size:1rem;font-weight:700;color:var(--text);letter-spacing:-.2px;flex:1}.topbar-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.78rem;text-transform:uppercase;box-shadow:0 2px 8px #6366f159}.content{flex:1;padding:32px 32px 56px;max-width:1140px;width:100%}.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:9px 18px;border-radius:var(--radius-sm);font-size:.875rem;font-weight:600;border:1.5px solid transparent;transition:all var(--transition);white-space:nowrap;letter-spacing:-.1px}.btn:active{transform:scale(.97)}.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 2px 8px #4f46e540}.btn-primary:hover{background:var(--accent-hover);border-color:var(--accent-hover);box-shadow:0 4px 16px #4f46e559;transform:translateY(-1px)}.btn-ghost{background:transparent;color:var(--text-muted);border-color:var(--border)}.btn-ghost:hover{background:var(--bg-surface);color:var(--text);border-color:#cbd5e1}.btn-danger{background:transparent;color:var(--danger);border-color:#fca5a5}.btn-danger:hover{background:var(--danger-light);border-color:#f87171}.btn-sm{padding:6px 12px;font-size:.8rem;border-radius:var(--radius-xs)}.btn-lg{padding:13px 32px;font-size:.95rem}.btn-full{width:100%}.btn-hero{background:linear-gradient(135deg,var(--accent),var(--primary-dark));color:#fff;padding:14px 36px;font-size:1rem;font-weight:700;border-radius:var(--radius);box-shadow:0 4px 20px #4f46e559;border:none;letter-spacing:-.2px;display:inline-flex;align-items:center;gap:8px;transition:all var(--transition)}.btn-hero:hover{transform:translateY(-2px);box-shadow:0 8px 28px #4f46e573}.btn-hero-outline{display:inline-flex;align-items:center;gap:8px;padding:14px 32px;border:1.5px solid rgba(255,255,255,.25);border-radius:var(--radius);color:#ffffffd9;font-size:.95rem;font-weight:600;transition:all var(--transition);background:#ffffff0f;letter-spacing:-.1px}.btn-hero-outline:hover{background:#ffffff1f;border-color:#fff6;color:#fff}.btn-icon{background:none;border:none;padding:6px 8px;border-radius:var(--radius-xs);font-size:.85rem;color:var(--text-muted);transition:all var(--transition);display:inline-flex;align-items:center;gap:4px}.btn-icon.danger{color:var(--danger)}.btn-icon:hover{background:var(--bg-surface);color:var(--text)}.btn-icon.danger:hover{background:var(--danger-light)}.loading-spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite;margin:16px auto}.loading-spinner.center{margin:100px auto;display:block}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;padding:64px 24px;color:var(--text-muted)}.empty-state-icon{font-size:3rem;margin-bottom:16px;opacity:.4;display:block}.empty-state p{margin-bottom:20px;font-size:.95rem}.page-actions{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;flex-wrap:wrap;gap:12px}.page-actions h2{font-size:1.5rem;font-weight:800;letter-spacing:-.4px;color:var(--text)}.section-heading{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin:32px 0 14px}.table-wrapper{background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border);overflow:hidden;box-shadow:var(--shadow)}.data-table{width:100%;border-collapse:collapse;font-size:.875rem}.data-table th{background:var(--bg-surface);padding:12px 18px;text-align:left;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);border-bottom:1px solid var(--border)}.data-table td{padding:13px 18px;border-bottom:1px solid var(--border-light);vertical-align:middle}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:#fafbff}.data-table code{font-family:SF Mono,Fira Code,monospace;font-size:.78rem;background:var(--primary-50);padding:2px 7px;border-radius:5px;color:var(--primary);font-weight:500}.notes-cell{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}label{display:flex;flex-direction:column;gap:5px;font-size:.8rem;font-weight:600;color:var(--text);letter-spacing:-.1px}input[type=text],input[type=email],input[type=password],input[type=date],input[type=time],select,textarea{padding:10px 13px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:.875rem;background:var(--bg-card);color:var(--text);transition:border-color var(--transition),box-shadow var(--transition),background var(--transition);width:100%;font-weight:400}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #4f46e51a;background:#fff}input:disabled{background:var(--bg-surface);color:var(--text-muted);cursor:not-allowed}textarea{resize:vertical;min-height:100px}.checkbox-label{flex-direction:row;align-items:center;gap:9px;cursor:pointer;font-size:.875rem}.checkbox-label input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a8c;display:flex;align-items:center;justify-content:center;z-index:200;padding:16px;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.modal{background:var(--bg-card);border-radius:var(--radius);box-shadow:var(--shadow-xl);width:100%;max-width:500px;max-height:90vh;overflow-y:auto;animation:modalIn .2s cubic-bezier(.16,1,.3,1);border:1px solid var(--border)}.modal-lg{max-width:700px}@keyframes modalIn{0%{opacity:0;transform:scale(.95) translateY(-12px)}to{opacity:1;transform:none}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 22px 16px;border-bottom:1px solid var(--border)}.modal-header h2{font-size:1.05rem;font-weight:800;letter-spacing:-.3px}.modal-close{background:none;border:none;font-size:1rem;color:var(--text-muted);padding:6px 8px;border-radius:var(--radius-xs);transition:all var(--transition);display:flex;align-items:center;justify-content:center}.modal-close:hover{background:var(--bg-surface);color:var(--text)}.modal-body{padding:22px}.modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:22px;padding-top:18px;border-top:1px solid var(--border)}.toast-container{position:fixed;top:24px;right:24px;display:flex;flex-direction:column;gap:8px;z-index:1000}.toast{padding:13px 18px;border-radius:var(--radius-sm);font-size:.875rem;font-weight:500;min-width:220px;max-width:380px;box-shadow:var(--shadow-md);animation:toastIn .3s cubic-bezier(.16,1,.3,1);display:flex;align-items:center;gap:10px;border:1px solid transparent}@keyframes toastIn{0%{opacity:0;transform:translate(24px) scale(.95)}to{opacity:1;transform:none}}.toast-success{background:#f0fdf4;color:#166534;border-color:#bbf7d0}.toast-error{background:#fef2f2;color:#991b1b;border-color:#fecaca}.toast-info{background:var(--primary-50);color:var(--primary-dark);border-color:var(--primary-100)}.toast-warning{background:var(--warning-light);color:#92400e;border-color:#fde68a}.install-banner{position:fixed;bottom:24px;left:50%;transform:translate(-50%);background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:14px 18px;box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:14px;z-index:500;animation:slideUp .35s cubic-bezier(.16,1,.3,1);max-width:440px;width:calc(100% - 32px)}@keyframes slideUp{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.install-banner-icon{width:42px;height:42px;background:linear-gradient(135deg,var(--accent),var(--primary-dark));border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0;box-shadow:0 4px 12px #4f46e54d}.install-banner-text{flex:1;min-width:0}.install-banner-text strong{display:block;font-size:.875rem;font-weight:700;color:var(--text)}.install-banner-text span{font-size:.78rem;color:var(--text-muted)}.install-banner-actions{display:flex;gap:8px;align-items:center}.install-dismiss{background:none;border:none;color:var(--text-light);font-size:1.1rem;padding:4px;cursor:pointer;border-radius:4px;transition:color var(--transition);line-height:1}.install-dismiss:hover{color:var(--text)}.landing{min-height:100vh;background:var(--bg)}.landing-nav{position:sticky;top:0;background:#ffffffe0;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid rgba(226,232,240,.8);z-index:100}.landing-nav-inner{max-width:1200px;margin:0 auto;padding:14px 28px;display:flex;align-items:center;justify-content:space-between}.landing-logo{display:flex;align-items:center;gap:10px;font-size:1.15rem;font-weight:800;color:var(--text);letter-spacing:-.4px}.logo-icon{width:34px;height:34px;background:linear-gradient(135deg,var(--accent),var(--primary-dark));color:#fff;border-radius:9px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.9rem;box-shadow:0 4px 12px #4f46e559;flex-shrink:0}.hero{background:linear-gradient(135deg,#1e1b4b,#312e81 40%,#1d4ed8);color:#fff;padding:100px 28px 120px;position:relative;overflow:hidden}.hero:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(circle at 20% 50%,rgba(99,102,241,.15) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(168,85,247,.1) 0%,transparent 40%)}.hero-inner{max-width:840px;margin:0 auto;text-align:center;position:relative;z-index:1}.hero-badge{display:inline-flex;align-items:center;gap:8px;background:#6366f133;border:1px solid rgba(99,102,241,.4);color:#a5b4fc;padding:6px 16px;border-radius:24px;font-size:.75rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;margin-bottom:28px}.hero-badge-dot{width:6px;height:6px;border-radius:50%;background:#818cf8;box-shadow:0 0 8px #818cf8;animation:badge-pulse 2s infinite}@keyframes badge-pulse{0%,to{opacity:1}50%{opacity:.4}}.hero-title{font-size:clamp(2.2rem,5.5vw,3.5rem);font-weight:900;line-height:1.1;margin-bottom:22px;letter-spacing:-1px}.hero-accent{background:linear-gradient(135deg,#818cf8,#60a5fa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-subtitle{font-size:1.1rem;color:#ffffffb8;max-width:580px;margin:0 auto 44px;line-height:1.75;font-weight:400}.hero-actions{display:flex;gap:14px;justify-content:center;margin-bottom:60px;flex-wrap:wrap}.hero-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:#ffffff1a;border-radius:var(--radius);overflow:hidden;max-width:480px;margin:0 auto}.stat{background:#ffffff0f;padding:20px;display:flex;flex-direction:column;align-items:center;gap:4px}.stat-n{font-size:1.7rem;font-weight:900;color:#fff;line-height:1;letter-spacing:-1px}.stat-l{font-size:.7rem;color:#ffffff80;text-transform:uppercase;letter-spacing:.08em;font-weight:600}.features{padding:96px 28px}.features-inner{max-width:1200px;margin:0 auto}.section-center{text-align:center;margin-bottom:56px}.section-label{display:inline-block;background:var(--primary-50);color:var(--primary);padding:4px 14px;border-radius:20px;font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;margin-bottom:14px}.section-title{font-size:clamp(1.6rem,3vw,2.2rem);font-weight:900;color:var(--text);margin-bottom:12px;letter-spacing:-.6px}.section-desc{color:var(--text-muted);font-size:1rem;max-width:500px;margin:0 auto;line-height:1.7}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px}.feature-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:28px;transition:all var(--transition-slow);box-shadow:var(--shadow);position:relative;overflow:hidden}.feature-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent),var(--primary-dark));opacity:0;transition:opacity var(--transition-slow)}.feature-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px);border-color:var(--primary-100)}.feature-card:hover:before{opacity:1}.feature-icon-wrap{width:48px;height:48px;background:var(--primary-50);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;margin-bottom:18px}.feature-card h3{font-size:1rem;font-weight:700;color:var(--text);margin-bottom:8px;letter-spacing:-.2px}.feature-card p{font-size:.875rem;color:var(--text-muted);line-height:1.7}.cta-section{background:linear-gradient(135deg,var(--accent) 0%,var(--primary-dark) 100%);padding:80px 28px;text-align:center;color:#fff;position:relative;overflow:hidden}.cta-section:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(circle at 30% 60%,rgba(255,255,255,.05) 0%,transparent 50%)}.cta-inner{max-width:560px;margin:0 auto;position:relative}.cta-inner h2{font-size:clamp(1.8rem,4vw,2.4rem);font-weight:900;margin-bottom:14px;letter-spacing:-.6px}.cta-inner p{font-size:1.05rem;opacity:.82;margin-bottom:32px;line-height:1.65}.cta-section .btn-hero{background:#fff;color:var(--accent);box-shadow:0 4px 20px #0003}.cta-section .btn-hero:hover{background:#f0f2ff;box-shadow:0 8px 30px #00000040}.landing-footer{text-align:center;padding:28px;color:var(--text-muted);font-size:.82rem;border-top:1px solid var(--border)}.auth-page{min-height:100vh;display:flex;align-items:stretch;background:var(--bg)}.auth-side{display:none;width:420px;flex-shrink:0;background:linear-gradient(160deg,#1e1b4b,#312e81,#1d4ed8);padding:48px 40px;color:#fff;position:relative;overflow:hidden}.auth-side:before{content:"";position:absolute;width:300px;height:300px;background:radial-gradient(circle,rgba(99,102,241,.3) 0%,transparent 70%);bottom:-50px;right:-50px}.auth-side-content{position:relative;z-index:1;height:100%;display:flex;flex-direction:column}.auth-side-brand{display:flex;align-items:center;gap:10px;font-size:1.3rem;font-weight:800;margin-bottom:56px;letter-spacing:-.4px}.auth-side h2{font-size:2rem;font-weight:900;line-height:1.2;letter-spacing:-.6px;margin-bottom:16px}.auth-side p{font-size:.95rem;color:#ffffffa6;line-height:1.7;margin-bottom:32px}.auth-side-features{display:flex;flex-direction:column;gap:12px}.auth-side-feature{display:flex;align-items:center;gap:10px;font-size:.875rem;color:#fffc}.auth-side-feature-icon{width:28px;height:28px;background:#6366f14d;border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:.85rem;flex-shrink:0}.auth-main{flex:1;display:flex;align-items:center;justify-content:center;padding:40px 24px}.auth-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:40px 36px;width:100%;max-width:420px;box-shadow:var(--shadow-md)}.auth-logo{display:flex;align-items:center;gap:10px;font-size:1.15rem;font-weight:800;color:var(--text);margin-bottom:28px;text-decoration:none;letter-spacing:-.4px}.auth-card h2{font-size:1.6rem;font-weight:900;color:var(--text);margin-bottom:6px;letter-spacing:-.5px}.auth-sub{color:var(--text-muted);font-size:.875rem;margin-bottom:28px;line-height:1.5}.setup-notice{background:#fffbeb;border:1px solid #fde68a;border-radius:var(--radius-sm);padding:14px 16px;margin-bottom:20px;font-size:.85rem;color:#92400e;line-height:1.65}.setup-notice code{background:#fef3c7;padding:2px 6px;border-radius:4px;font-family:SF Mono,monospace;font-weight:600;font-size:.82rem}.auth-form{display:flex;flex-direction:column;gap:16px}.welcome-banner{background:linear-gradient(135deg,#1e1b4b,#312e81 60%,#1d4ed8);color:#fff;border-radius:var(--radius);padding:28px 32px;margin-bottom:8px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:14px;box-shadow:0 4px 24px #312e814d;position:relative;overflow:hidden}.welcome-banner:after{content:"";position:absolute;right:-30px;top:-40px;width:200px;height:200px;background:radial-gradient(circle,rgba(255,255,255,.06) 0%,transparent 70%);pointer-events:none}.welcome-banner h2{font-size:1.25rem;font-weight:800;margin-bottom:4px;letter-spacing:-.3px}.welcome-banner p{opacity:.75;font-size:.875rem}.today-date{font-size:.8rem;opacity:.65;text-align:right;font-weight:500}.checklist-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;margin-bottom:8px}.checklist-card{background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius);padding:22px;display:flex;align-items:center;gap:16px;box-shadow:var(--shadow);transition:all var(--transition-slow);text-decoration:none;color:var(--text);position:relative;overflow:hidden}.checklist-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:linear-gradient(180deg,var(--accent),var(--primary-dark));opacity:0;transition:opacity var(--transition);border-radius:4px 0 0 4px}.checklist-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);border-color:var(--primary-100)}.checklist-card:hover:before{opacity:1}.card-icon{width:46px;height:46px;background:linear-gradient(135deg,var(--accent),var(--primary-dark));color:#fff;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;font-weight:800;flex-shrink:0;box-shadow:0 4px 12px #4f46e54d}.card-info{flex:1;min-width:0}.card-info h3{font-size:.95rem;font-weight:700;margin-bottom:3px;letter-spacing:-.2px}.card-info p{font-size:.8rem;color:var(--text-muted);line-height:1.4;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.card-arrow{color:var(--text-light);font-size:1.1rem;transition:transform var(--transition),color var(--transition)}.checklist-card:hover .card-arrow{color:var(--accent);transform:translate(3px)}.recent-list{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}.recent-item{display:flex;align-items:center;gap:14px;padding:13px 18px;border-bottom:1px solid var(--border-light);font-size:.875rem;flex-wrap:wrap;transition:background var(--transition)}.recent-item:hover{background:#fafbff}.recent-item:last-child{border-bottom:none}.recent-name{font-weight:600;flex:1 1 140px}.recent-op{color:var(--text-muted);flex:1 1 100px}.recent-date{color:var(--text-light);font-size:.78rem;white-space:nowrap}.checklist-fill{max-width:840px}.fill-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:8px;flex-wrap:wrap;gap:12px}.fill-header h2{font-size:1.5rem;font-weight:900;letter-spacing:-.5px}.fill-header-sub{font-size:.82rem;color:var(--text-muted);margin-top:4px}.progress-pill{background:linear-gradient(135deg,var(--accent),var(--primary-dark));color:#fff;padding:6px 16px;border-radius:24px;font-size:.82rem;font-weight:700;box-shadow:0 2px 10px #4f46e54d;white-space:nowrap}.progress-bar-wrap{background:var(--border);border-radius:8px;height:6px;overflow:hidden;margin-bottom:24px;margin-top:16px}.progress-bar{height:100%;background:linear-gradient(90deg,var(--accent),var(--primary-dark));border-radius:8px;transition:width .4s cubic-bezier(.4,0,.2,1);box-shadow:0 0 8px #4f46e566}.meta-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin-bottom:22px;box-shadow:var(--shadow)}.block{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:16px;overflow:hidden;box-shadow:var(--shadow)}.section-title-bar{background:linear-gradient(135deg,#1e1b4b,#312e81);color:#fff;padding:12px 18px;font-size:.875rem;font-weight:700;letter-spacing:-.1px;display:flex;align-items:center;gap:8px}.section-title-bar:before{content:"";width:8px;height:8px;border-radius:50%;background:#818cf8;box-shadow:0 0 6px #818cf8;flex-shrink:0}.block table{width:100%;border-collapse:collapse;font-size:.875rem}.block th{background:var(--bg-surface);padding:10px 14px;text-align:left;font-size:.73rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);border-bottom:1px solid var(--border)}.block td{padding:11px 14px;border-bottom:1px solid var(--border-light);vertical-align:middle}.block tr:last-child td{border-bottom:none}.block tr:hover td{background:#fafbff}.checkCell{text-align:center;width:72px}.checkCell input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--accent)}.block td input[type=text]{width:100%;border:1.5px solid transparent;background:transparent;padding:5px 8px;font-size:.83rem;border-radius:var(--radius-xs);transition:all var(--transition)}.block td input[type=text]:focus{border-color:var(--accent);background:var(--bg-card);box-shadow:0 0 0 3px #4f46e514}.notes-block{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-bottom:22px;box-shadow:var(--shadow)}.notes-block textarea{border:none;border-radius:0;resize:vertical;min-height:110px;padding:16px 18px;border-top:1px solid var(--border)}.notes-block textarea:focus{box-shadow:none;outline:none}.submit-row{display:flex;justify-content:flex-end;gap:12px;padding-top:8px}.editor-form{display:flex;flex-direction:column;gap:16px}.sections-editor{margin-top:4px}.sections-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.sections-header h4{font-weight:700;color:var(--text-muted);font-size:.78rem;text-transform:uppercase;letter-spacing:.08em}.section-title-input{flex:1;min-width:160px}.dual-check-label{flex-direction:row;align-items:center;gap:7px;font-size:.8rem;color:var(--text-muted);white-space:nowrap;cursor:pointer}.dual-check-label input{width:auto}.role-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:14px;font-size:.72rem;font-weight:700;border:1px solid;text-transform:capitalize;letter-spacing:.02em}.pw-change-badge{margin-left:6px;font-size:.75rem;color:#f59e0b}.status-dot{display:inline-flex;align-items:center;gap:6px;font-size:.8rem;font-weight:500}.status-dot:before{content:"";width:7px;height:7px;border-radius:50%;display:inline-block}.status-dot.active{color:#059669}.status-dot.active:before{background:var(--success);box-shadow:0 0 5px #10b98180}.status-dot.inactive{color:var(--text-muted)}.status-dot.inactive:before{background:var(--text-light)}.settings-form{display:flex;flex-direction:column;gap:22px;max-width:580px}.settings-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:16px}.settings-card h3{font-size:.925rem;font-weight:700;color:var(--text);letter-spacing:-.2px;padding-bottom:12px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px}.info-row{display:flex;align-items:center;justify-content:space-between;font-size:.875rem;padding:8px 0;border-bottom:1px solid var(--border-light)}.info-row:last-child{border-bottom:none;padding-bottom:0}.info-row span{color:var(--text-muted)}.info-row strong{color:var(--text);font-weight:600}@media (min-width: 900px){.auth-side{display:flex;flex-direction:column}}@media (max-width: 768px){:root{--sidebar-w: 0px}.sidebar{transform:translate(-260px);width:260px}.sidebar.open{transform:translate(0);box-shadow:var(--shadow-xl)}.sidebar-overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:99}.main-area{margin-left:0}.menu-toggle{display:flex}.content{padding:20px 18px 48px}.welcome-banner{padding:18px 22px}.welcome-banner h2{font-size:1.1rem}.today-date{display:none}.checklist-grid,.features-grid{grid-template-columns:1fr}.hero{padding:64px 20px 80px}.meta-grid{grid-template-columns:1fr 1fr}.modal{max-height:95vh}.modal-lg{max-width:100%}.toast-container{top:12px;right:12px;left:12px}.toast{max-width:100%}.page-actions{flex-direction:column;align-items:flex-start}.section-block-header{flex-wrap:wrap}.data-table{font-size:.82rem}.data-table th,.data-table td{padding:10px 12px}}@media (max-width: 480px){.auth-card{padding:28px 22px}.hero{padding:48px 16px 64px}.install-banner{bottom:12px}}.modal-xl{max-width:900px}.history-export-btns{display:flex;gap:8px}.history-filters{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:18px;align-items:center}.history-filters select,.history-filters input[type=date],.history-filters input[type=text]{flex:1 1 160px;min-width:0;max-width:220px}.filter-date-label{display:flex;flex-direction:column;gap:3px;font-size:.72rem;font-weight:600;color:var(--text-muted);flex:1 1 160px;min-width:0;max-width:220px}.filter-date-label input{width:100%}.history-row-actions{display:flex;gap:6px;align-items:center;flex-wrap:wrap}.sub-detail{display:flex;flex-direction:column;gap:16px}.sub-detail-meta{display:flex;gap:20px;flex-wrap:wrap;background:var(--bg-surface);border-radius:var(--radius-sm);padding:12px 16px;font-size:.875rem}.sub-detail-notes{background:var(--warning-light);border-left:3px solid var(--warning);border-radius:0 var(--radius-xs) var(--radius-xs) 0;padding:10px 14px;font-size:.875rem;color:#92400e}.sub-detail-section{margin-bottom:4px}.sub-section-title{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);margin-bottom:8px;padding:8px 12px;background:var(--bg-surface);border-radius:var(--radius-xs)}.check-badge{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;font-size:.8rem;font-weight:700}.check-badge.yes{background:var(--success-light);color:var(--success)}.check-badge.no{background:var(--danger-light);color:var(--danger)}.text-value{font-size:.875rem;font-weight:500;color:var(--text)}.item-type-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:10px;font-size:.7rem;font-weight:600;background:var(--primary-50);color:var(--primary);border:1px solid var(--primary-100);text-transform:capitalize}.item-type-badge.small{margin-left:6px;font-size:.65rem;padding:1px 6px}.template-meta-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}@media (max-width: 600px){.template-meta-grid{grid-template-columns:1fr}}.sections-count{font-size:.75rem;color:var(--text-light);font-weight:400}.empty-sections{text-align:center;padding:24px;color:var(--text-muted);font-size:.875rem;background:var(--bg-surface);border-radius:var(--radius-sm);border:1.5px dashed var(--border)}.section-block{border:1.5px solid var(--border);border-radius:var(--radius-sm);margin-bottom:12px;background:var(--bg-card);overflow:hidden}.section-block-header{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px 14px;background:var(--bg-surface);border-bottom:1px solid var(--border);flex-wrap:wrap}.section-header-left{display:flex;align-items:center;gap:8px;flex:1;min-width:0}.section-header-right{display:flex;align-items:center;gap:6px;flex-shrink:0}.section-items{padding:14px;display:flex;flex-direction:column;gap:8px}.item-editor-row{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;border:1.5px solid var(--border);border-radius:var(--radius-xs);background:var(--bg-surface);transition:border-color var(--transition)}.item-editor-row:hover{border-color:var(--primary-100)}.item-index{width:22px;height:22px;border-radius:50%;background:var(--primary-50);color:var(--primary);font-size:.72rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px}.item-editor-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:8px}.item-editor-top{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.item-label-input{flex:1;min-width:120px}.item-type-select{width:140px;flex-shrink:0}.options-editor{border:1.5px solid var(--primary-100);border-radius:var(--radius-xs);background:var(--primary-50);padding:10px 12px;display:flex;flex-direction:column;gap:8px}.options-list{display:flex;flex-wrap:wrap;gap:6px}.option-tag{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;background:#fff;border:1.5px solid var(--primary-100);border-radius:14px;font-size:.78rem;font-weight:600;color:var(--primary)}.option-tag button{background:none;border:none;color:var(--primary-light);cursor:pointer;font-size:.75rem;padding:0;line-height:1;display:flex;align-items:center}.option-tag button:hover{color:var(--danger)}.option-add-row{display:flex;gap:8px;align-items:center}.option-add-row input{flex:1}.block td input[type=number]{padding:5px 8px;border:1.5px solid var(--border);border-radius:var(--radius-xs);font-size:.875rem;background:var(--bg-card);transition:all var(--transition)}.block td input[type=number].number-input-narrow{width:120px}.block td input[type=number]:focus{border-color:var(--accent);box-shadow:0 0 0 3px #4f46e514;outline:none}.block td select{padding:5px 8px;border:1.5px solid var(--border);border-radius:var(--radius-xs);font-size:.875rem;background:var(--bg-card);min-width:140px}.block td select:focus{border-color:var(--accent);box-shadow:0 0 0 3px #4f46e514;outline:none}
