:root{--bg-primary:#0a0a1a;--bg-secondary:#0f0f2a;--bg-tertiary:#14142e;--bg-surface:#ffffff08;--bg-surface-hover:#ffffff0f;--bg-glass:#ffffff0a;--bg-glass-strong:#ffffff14;--border-subtle:#ffffff0f;--border-default:#ffffff1a;--border-strong:#ffffff26;--border-accent:#8b5cf64d;--text-primary:#f0f0f8;--text-secondary:#a0a0c0;--text-muted:#6a6a8e;--text-inverse:#0a0a1a;--accent-primary:#8b5cf6;--accent-primary-hover:#a78bfa;--accent-primary-muted:#8b5cf626;--accent-primary-subtle:#8b5cf614;--accent-secondary:#06b6d4;--accent-secondary-hover:#22d3ee;--accent-secondary-muted:#06b6d426;--status-planning:#f59e0b;--status-in-progress:#3b82f6;--status-on-hold:#ef4444;--status-completed:#10b981;--priority-low:#6ee7b7;--priority-medium:#fbbf24;--priority-high:#f97316;--priority-critical:#ef4444;--shadow-sm:0 1px 2px #0000004d;--shadow-md:0 4px 12px #0006;--shadow-lg:0 8px 32px #00000080;--shadow-glow:0 0 20px #8b5cf626;--shadow-glow-strong:0 0 40px #8b5cf640;--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:32px;--space-2xl:48px;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:24px;--radius-full:9999px;--font-family:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-size-xs:.75rem;--font-size-sm:.8125rem;--font-size-base:.9375rem;--font-size-lg:1.125rem;--font-size-xl:1.375rem;--font-size-2xl:1.75rem;--font-size-3xl:2.25rem;--transition-fast:.15s cubic-bezier(.4, 0, .2, 1);--transition-base:.25s cubic-bezier(.4, 0, .2, 1);--transition-slow:.4s cubic-bezier(.4, 0, .2, 1);--sidebar-width:260px;--sidebar-collapsed:72px;--header-height:0px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{font-family:var(--font-family);background:var(--bg-primary);color:var(--text-primary);min-height:100vh;line-height:1.6;overflow-x:hidden}body:before{content:"";pointer-events:none;z-index:0;background:radial-gradient(80% 60% at 10% 20%,#8b5cf614 0%,#0000 60%),radial-gradient(60% 50% at 90% 80%,#06b6d40f 0%,#0000 60%),radial-gradient(50% 40%,#8b5cf608 0%,#0000 50%);width:100%;height:100%;position:fixed;top:0;left:0}#app{z-index:1;min-height:100vh;display:flex;position:relative}a{color:var(--accent-primary);text-decoration:none}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{border-radius:var(--radius-full);background:#ffffff1a}::-webkit-scrollbar-thumb:hover{background:#fff3}.glass-card{background:var(--bg-glass);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);transition:border-color var(--transition-base), box-shadow var(--transition-base), transform var(--transition-base)}.glass-card:hover{border-color:var(--border-default);box-shadow:var(--shadow-md)}.glass-card-interactive:hover{border-color:var(--border-accent);box-shadow:var(--shadow-glow);transform:translateY(-2px)}.sidebar{width:var(--sidebar-width);background:var(--bg-glass);-webkit-backdrop-filter:blur(24px);border-right:1px solid var(--border-subtle);z-index:100;min-height:100vh;transition:width var(--transition-base), transform var(--transition-base);flex-direction:column;display:flex;position:fixed;top:0;left:0}.sidebar-header{padding:var(--space-lg) var(--space-lg);align-items:center;gap:var(--space-md);border-bottom:1px solid var(--border-subtle);display:flex}.sidebar-logo{border-radius:var(--radius-md);background:linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));width:36px;height:36px;font-weight:800;font-size:var(--font-size-lg);color:#fff;flex-shrink:0;justify-content:center;align-items:center;display:flex}.sidebar-title{font-size:var(--font-size-base);color:var(--text-primary);white-space:nowrap;font-weight:700;overflow:hidden}.sidebar-subtitle{font-size:var(--font-size-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em}.sidebar-nav{padding:var(--space-md);gap:var(--space-xs);flex-direction:column;flex:1;display:flex}.sidebar-section-label{font-size:var(--font-size-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;padding:var(--space-md) var(--space-md) var(--space-sm);font-weight:600}.nav-item{align-items:center;gap:var(--space-md);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);font-size:var(--font-size-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);-webkit-user-select:none;user-select:none;border:1px solid #0000;font-weight:500;display:flex}.nav-item:hover{background:var(--bg-surface-hover);color:var(--text-primary)}.nav-item.active{background:var(--accent-primary-muted);color:var(--accent-primary-hover);border-color:var(--border-accent)}.nav-item .nav-icon{width:20px;height:20px;font-size:var(--font-size-lg);flex-shrink:0;justify-content:center;align-items:center;display:flex}.nav-item .nav-label{white-space:nowrap;overflow:hidden}.sidebar-footer{padding:var(--space-md) var(--space-lg);border-top:1px solid var(--border-subtle);font-size:var(--font-size-xs);color:var(--text-muted);text-align:center}.main-content{margin-left:var(--sidebar-width);padding:var(--space-2xl);min-height:100vh;transition:margin-left var(--transition-base);flex:1}.page-header{margin-bottom:var(--space-xl)}.page-title{font-size:var(--font-size-2xl);color:var(--text-primary);letter-spacing:-.02em;margin-bottom:var(--space-xs);font-weight:800}.page-subtitle{font-size:var(--font-size-base);color:var(--text-secondary)}.stats-grid{gap:var(--space-lg);margin-bottom:var(--space-xl);grid-template-columns:repeat(auto-fit,minmax(220px,1fr));display:grid}.stat-card{padding:var(--space-lg);position:relative;overflow:hidden}.stat-card:before{content:"";border-radius:var(--radius-lg) var(--radius-lg) 0 0;height:3px;position:absolute;top:0;left:0;right:0}.stat-card.purple:before{background:linear-gradient(90deg, var(--accent-primary), var(--accent-primary-hover))}.stat-card.cyan:before{background:linear-gradient(90deg, var(--accent-secondary), var(--accent-secondary-hover))}.stat-card.green:before{background:linear-gradient(90deg, var(--status-completed), #34d399)}.stat-card.amber:before{background:linear-gradient(90deg, var(--status-planning), #fbbf24)}.stat-icon{border-radius:var(--radius-md);width:40px;height:40px;margin-bottom:var(--space-md);justify-content:center;align-items:center;font-size:1.25rem;display:flex}.stat-icon.purple{background:var(--accent-primary-muted)}.stat-icon.cyan{background:var(--accent-secondary-muted)}.stat-icon.green{background:#10b98126}.stat-icon.amber{background:#f59e0b26}.stat-value{font-size:var(--font-size-2xl);color:var(--text-primary);margin-bottom:var(--space-xs);font-weight:800;line-height:1}.stat-label{font-size:var(--font-size-sm);color:var(--text-secondary);font-weight:500}.projects-grid{gap:var(--space-lg);grid-template-columns:repeat(auto-fill,minmax(340px,1fr));display:grid}.project-card{padding:var(--space-lg);cursor:pointer;position:relative}.project-card-header{margin-bottom:var(--space-md);justify-content:space-between;align-items:flex-start;display:flex}.project-card-title{font-size:var(--font-size-lg);color:var(--text-primary);margin-bottom:var(--space-xs);font-weight:700}.project-card-desc{font-size:var(--font-size-sm);color:var(--text-secondary);margin-bottom:var(--space-md);-webkit-line-clamp:2;-webkit-box-orient:vertical;line-height:1.5;display:-webkit-box;overflow:hidden}.project-card-footer{gap:var(--space-sm);flex-direction:column;display:flex}.progress-row{align-items:center;gap:var(--space-md);display:flex}.progress-bar-container{background:var(--bg-surface);border-radius:var(--radius-full);flex:1;height:6px;overflow:hidden}.progress-bar-fill{border-radius:var(--radius-full);background:linear-gradient(90deg, var(--accent-primary), var(--accent-secondary));height:100%;transition:width var(--transition-slow)}.progress-text{font-size:var(--font-size-xs);color:var(--text-muted);white-space:nowrap;font-weight:600}.badge{align-items:center;gap:var(--space-xs);border-radius:var(--radius-full);font-size:var(--font-size-xs);white-space:nowrap;border:1px solid #0000;padding:3px 10px;font-weight:600;display:inline-flex}.badge-planning{color:var(--status-planning);background:#f59e0b1f;border-color:#f59e0b33}.badge-in-progress{color:var(--status-in-progress);background:#3b82f61f;border-color:#3b82f633}.badge-on-hold{color:var(--status-on-hold);background:#ef44441f;border-color:#ef444433}.badge-completed{color:var(--status-completed);background:#10b9811f;border-color:#10b98133}.badge-low{color:var(--priority-low);background:#6ee7b71f}.badge-medium{color:var(--priority-medium);background:#fbbf241f}.badge-high{color:var(--priority-high);background:#f973161f}.badge-critical{color:var(--priority-critical);background:#ef44441f}.tag{border-radius:var(--radius-full);font-size:var(--font-size-xs);background:var(--accent-primary-subtle);color:var(--accent-primary-hover);border:1px solid #8b5cf626;align-items:center;padding:2px 8px;font-weight:500;display:inline-flex}.tags-container{gap:var(--space-xs);margin-bottom:var(--space-md);flex-wrap:wrap;display:flex}.btn{justify-content:center;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-fast);font-weight:600;font-family:var(--font-family);white-space:nowrap;-webkit-user-select:none;user-select:none;border:1px solid #0000;display:inline-flex}.btn-primary{background:var(--accent-primary);color:#fff;box-shadow:0 2px 8px #8b5cf64d}.btn-primary:hover{background:var(--accent-primary-hover);transform:translateY(-1px);box-shadow:0 4px 16px #8b5cf666}.btn-secondary{background:var(--bg-glass-strong);color:var(--text-primary);border-color:var(--border-default)}.btn-secondary:hover{background:var(--bg-surface-hover);border-color:var(--border-strong)}.btn-ghost{color:var(--text-secondary);background:0 0}.btn-ghost:hover{background:var(--bg-surface-hover);color:var(--text-primary)}.btn-danger{color:#f87171;background:#ef44441f;border-color:#ef444433}.btn-danger:hover{background:#ef444433}.btn-icon{border-radius:var(--radius-md);width:36px;height:36px;padding:0}.btn-sm{padding:var(--space-xs) var(--space-sm);font-size:var(--font-size-xs)}.btn-lg{padding:var(--space-md) var(--space-xl);font-size:var(--font-size-base);border-radius:var(--radius-lg)}.btn-accent{background:linear-gradient(135deg, var(--accent-secondary), #0891b2);color:#fff;box-shadow:0 2px 8px #06b6d44d}.btn-accent:hover{background:linear-gradient(135deg, var(--accent-secondary-hover), var(--accent-secondary));transform:translateY(-1px);box-shadow:0 4px 16px #06b6d466}.project-card-shortcuts{gap:var(--space-xs);margin-bottom:var(--space-sm);width:100%;display:flex}.btn-shortcut{border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-fast);font-size:.6875rem;font-weight:600;font-family:var(--font-family);white-space:nowrap;-webkit-user-select:none;user-select:none;letter-spacing:.02em;border:1px solid #0000;align-items:center;gap:4px;padding:4px 10px;display:inline-flex}.btn-shortcut-open{color:#60a5fa;background:#3b82f61f;border-color:#3b82f633}.btn-shortcut-open:hover{background:#3b82f640;transform:translateY(-1px);box-shadow:0 0 12px #3b82f633}.btn-shortcut-edit{color:#22d3ee;background:#06b6d41f;border-color:#06b6d433}.btn-shortcut-edit:hover{background:#06b6d440;transform:translateY(-1px);box-shadow:0 0 12px #06b6d433}.form-divider{background:var(--border-subtle);height:1px;margin:var(--space-lg) 0 var(--space-md)}.form-section-label{font-size:var(--font-size-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:var(--space-md);font-weight:700}.form-hint{color:var(--text-muted);font-weight:400;font-size:var(--font-size-xs)}.form-group{margin-bottom:var(--space-md)}.form-label{font-size:var(--font-size-sm);color:var(--text-secondary);margin-bottom:var(--space-xs);font-weight:600;display:block}.form-input,.form-select,.form-textarea{width:100%;padding:var(--space-sm) var(--space-md);background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--font-size-sm);font-family:var(--font-family);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);outline:none}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-primary-muted)}.form-input::placeholder,.form-textarea::placeholder{color:var(--text-muted)}.form-textarea{resize:vertical;min-height:80px}.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='%23a0a0c0' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:32px}.form-select option{background:var(--bg-secondary);color:var(--text-primary)}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;opacity:0;transition:opacity var(--transition-base);padding:var(--space-lg);background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-overlay.visible{opacity:1}.modal{background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:var(--radius-xl);width:100%;max-width:520px;max-height:90vh;box-shadow:var(--shadow-lg);transition:transform var(--transition-base);overflow-y:auto;transform:scale(.95)translateY(10px)}.modal-overlay.visible .modal{transform:scale(1)translateY(0)}.modal-header{padding:var(--space-lg);border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:center;display:flex}.modal-title{font-size:var(--font-size-lg);color:var(--text-primary);font-weight:700}.modal-body{padding:var(--space-lg)}.modal-footer{justify-content:flex-end;align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);border-top:1px solid var(--border-subtle);display:flex}.toast-container{top:var(--space-lg);right:var(--space-lg);z-index:2000;gap:var(--space-sm);flex-direction:column;display:flex;position:fixed}.toast{background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:var(--radius-md);padding:var(--space-md) var(--space-lg);box-shadow:var(--shadow-lg);align-items:center;gap:var(--space-md);min-width:280px;max-width:400px;font-size:var(--font-size-sm);color:var(--text-primary);animation:.3s ease-out toast-slide-in;display:flex}.toast.toast-exit{animation:.25s ease-in forwards toast-slide-out}.toast-success{border-left:3px solid var(--status-completed)}.toast-error{border-left:3px solid var(--status-on-hold)}.toast-info{border-left:3px solid var(--accent-primary)}.toast-icon{font-size:var(--font-size-lg);flex-shrink:0}@keyframes toast-slide-in{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@keyframes toast-slide-out{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(100%)}}.task-list{gap:var(--space-sm);flex-direction:column;display:flex}.task-item{align-items:center;gap:var(--space-md);padding:var(--space-md);border-radius:var(--radius-md);background:var(--bg-surface);border:1px solid var(--border-subtle);transition:all var(--transition-fast);display:flex}.task-item:hover{border-color:var(--border-default);background:var(--bg-surface-hover)}.task-checkbox{border-radius:var(--radius-sm);border:2px solid var(--border-strong);cursor:pointer;width:20px;height:20px;transition:all var(--transition-fast);background:0 0;flex-shrink:0;justify-content:center;align-items:center;display:flex}.task-checkbox.checked{background:var(--accent-primary);border-color:var(--accent-primary)}.task-checkbox.checked:after{content:"✓";color:#fff;font-size:12px;font-weight:700}.task-info{flex:1;min-width:0}.task-name{font-size:var(--font-size-sm);color:var(--text-primary);transition:color var(--transition-fast);font-weight:500}.task-name.completed{color:var(--text-muted);text-decoration:line-through}.task-meta{align-items:center;gap:var(--space-sm);margin-top:2px;display:flex}.task-actions{align-items:center;gap:var(--space-xs);opacity:0;transition:opacity var(--transition-fast);display:flex}.task-item:hover .task-actions{opacity:1}.timeline{padding-left:var(--space-lg);flex-direction:column;gap:0;display:flex;position:relative}.timeline:before{content:"";background:var(--border-subtle);width:2px;position:absolute;top:8px;bottom:8px;left:7px}.timeline-item{padding:var(--space-sm) 0 var(--space-md) var(--space-md);position:relative}.timeline-item:before{content:"";left:calc(-1 * var(--space-lg) + 3px);background:var(--accent-primary);border:2px solid var(--bg-primary);border-radius:50%;width:10px;height:10px;position:absolute;top:12px}.timeline-time{font-size:var(--font-size-xs);color:var(--text-muted)}.timeline-text{font-size:var(--font-size-sm);color:var(--text-secondary)}.timeline-text strong{color:var(--text-primary);font-weight:600}.chart-container{padding:var(--space-lg);min-height:200px;position:relative}.chart-title{font-size:var(--font-size-base);color:var(--text-primary);margin-bottom:var(--space-md);font-weight:700}.bar-chart{align-items:flex-end;gap:var(--space-md);height:160px;padding-top:var(--space-md);display:flex}.bar-chart-item{align-items:center;gap:var(--space-xs);flex-direction:column;flex:1;justify-content:flex-end;height:100%;display:flex}.bar{border-radius:var(--radius-sm) var(--radius-sm) 0 0;width:100%;max-width:60px;transition:height var(--transition-slow);min-height:4px}.bar-label{font-size:var(--font-size-xs);color:var(--text-muted);text-align:center;white-space:nowrap;font-weight:500}.bar-value{font-size:var(--font-size-xs);color:var(--text-secondary);font-weight:700}.donut-chart-wrapper{justify-content:center;align-items:center;gap:var(--space-2xl);flex-wrap:wrap;display:flex}.donut-chart{width:160px;height:160px;position:relative}.donut-chart svg{width:100%;height:100%;transform:rotate(-90deg)}.donut-chart-center{flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.donut-chart-center .value{font-size:var(--font-size-xl);color:var(--text-primary);font-weight:800}.donut-chart-center .label{font-size:var(--font-size-xs);color:var(--text-muted)}.chart-legend{gap:var(--space-sm);flex-direction:column;display:flex}.legend-item{align-items:center;gap:var(--space-sm);font-size:var(--font-size-sm);color:var(--text-secondary);display:flex}.legend-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.legend-value{color:var(--text-primary);margin-left:auto;font-weight:600}.empty-state{padding:var(--space-2xl);text-align:center;flex-direction:column;justify-content:center;align-items:center;display:flex}.empty-state-icon{margin-bottom:var(--space-md);opacity:.4;font-size:3rem}.empty-state-title{font-size:var(--font-size-lg);color:var(--text-primary);margin-bottom:var(--space-xs);font-weight:700}.empty-state-text{font-size:var(--font-size-sm);color:var(--text-secondary);margin-bottom:var(--space-lg);max-width:400px}.section{margin-bottom:var(--space-xl)}.section-header{margin-bottom:var(--space-md);justify-content:space-between;align-items:center;display:flex}.section-title{font-size:var(--font-size-lg);color:var(--text-primary);font-weight:700}.project-detail-header{justify-content:space-between;align-items:flex-start;gap:var(--space-lg);margin-bottom:var(--space-xl);flex-wrap:wrap;display:flex}.project-detail-info{flex:1}.project-detail-title{font-size:var(--font-size-3xl);color:var(--text-primary);letter-spacing:-.03em;margin-bottom:var(--space-sm);font-weight:800}.project-detail-desc{font-size:var(--font-size-base);color:var(--text-secondary);margin-bottom:var(--space-md);max-width:600px;line-height:1.7}.project-detail-actions{gap:var(--space-sm);flex-shrink:0;display:flex}.project-stats-row{gap:var(--space-md);margin-bottom:var(--space-xl);grid-template-columns:repeat(auto-fit,minmax(160px,1fr));display:grid}.project-stat{padding:var(--space-md)}.project-stat-value{font-size:var(--font-size-xl);color:var(--text-primary);font-weight:800}.project-stat-label{font-size:var(--font-size-xs);color:var(--text-muted);font-weight:500}.back-btn{align-items:center;gap:var(--space-sm);font-size:var(--font-size-sm);color:var(--text-secondary);cursor:pointer;margin-bottom:var(--space-lg);transition:color var(--transition-fast);padding:var(--space-xs) 0;font-family:var(--font-family);background:0 0;border:none;font-weight:500;display:inline-flex}.back-btn:hover{color:var(--accent-primary)}.two-col{gap:var(--space-lg);grid-template-columns:1fr 1fr;display:grid}.analytics-grid{gap:var(--space-lg);grid-template-columns:repeat(auto-fit,minmax(400px,1fr));display:grid}@media (width<=1024px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main-content{margin-left:0}.two-col,.analytics-grid{grid-template-columns:1fr}}@media (width<=768px){.main-content{padding:var(--space-md)}.stats-grid{grid-template-columns:repeat(2,1fr)}.projects-grid{grid-template-columns:1fr}.page-title{font-size:var(--font-size-xl)}}@media (width<=480px){.stats-grid{grid-template-columns:1fr}}.mobile-toggle{top:var(--space-md);left:var(--space-md);z-index:200;border-radius:var(--radius-md);background:var(--bg-glass-strong);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border-default);width:40px;height:40px;color:var(--text-primary);font-size:var(--font-size-lg);cursor:pointer;justify-content:center;align-items:center;display:none;position:fixed}@media (width<=1024px){.mobile-toggle{display:flex}}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.gap-lg{gap:var(--space-lg)}.mt-md{margin-top:var(--space-md)}.mt-lg{margin-top:var(--space-lg)}.mb-md{margin-bottom:var(--space-md)}.mb-lg{margin-bottom:var(--space-lg)}.text-muted{color:var(--text-muted)}.text-secondary{color:var(--text-secondary)}.font-bold{font-weight:700}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.pin-gate{z-index:9999;background:var(--bg-primary);justify-content:center;align-items:center;animation:.6s ease-out pin-gate-enter;display:flex;position:fixed;inset:0;overflow:hidden}.pin-gate-particles{pointer-events:none;position:absolute;inset:0}.pin-particle{opacity:.08;filter:blur(80px);border-radius:50%;animation:20s ease-in-out infinite pin-float;position:absolute}.pin-particle-1{background:var(--accent-primary);width:500px;height:500px;animation-delay:0s;top:-10%;left:-5%}.pin-particle-2{background:var(--accent-secondary);width:400px;height:400px;animation-delay:-7s;bottom:-10%;right:-5%}.pin-particle-3{background:linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));width:300px;height:300px;animation-delay:-14s;top:50%;left:50%;transform:translate(-50%,-50%)}@keyframes pin-float{0%,to{transform:translate(0)scale(1)}25%{transform:translate(30px,-40px)scale(1.05)}50%{transform:translate(-20px,20px)scale(.95)}75%{transform:translate(40px,30px)scale(1.02)}}.pin-gate-card{z-index:1;padding:var(--space-2xl) var(--space-2xl);background:var(--bg-glass);-webkit-backdrop-filter:blur(40px);border:1px solid var(--border-default);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg), var(--shadow-glow);flex-direction:column;align-items:center;min-width:360px;max-width:420px;animation:.7s ease-out .1s both pin-card-enter;display:flex;position:relative}@keyframes pin-gate-enter{0%{opacity:0}to{opacity:1}}@keyframes pin-card-enter{0%{opacity:0;transform:scale(.9)translateY(20px)}to{opacity:1;transform:scale(1)translateY(0)}}.pin-gate-icon{border-radius:var(--radius-lg);background:linear-gradient(135deg, var(--accent-primary-muted), #06b6d41a);border:1px solid var(--border-accent);width:80px;height:80px;color:var(--accent-primary);margin-bottom:var(--space-lg);justify-content:center;align-items:center;transition:all .5s;display:flex}.pin-gate-icon.pin-lock-success{color:var(--status-completed);background:linear-gradient(135deg,#10b98133,#10b9810d);border-color:#10b98166;box-shadow:0 0 30px #10b98133}.pin-gate-title{font-size:var(--font-size-2xl);color:var(--text-primary);letter-spacing:-.02em;margin-bottom:var(--space-xs);background:linear-gradient(135deg, var(--text-primary), var(--accent-primary-hover));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-weight:800}.pin-gate-subtitle{font-size:var(--font-size-sm);color:var(--text-muted);margin-bottom:var(--space-xl)}.pin-digits-container{gap:var(--space-md);margin-bottom:var(--space-lg);display:flex}.pin-digit{text-align:center;width:56px;height:64px;font-size:var(--font-size-2xl);font-weight:700;font-family:var(--font-family);color:var(--text-primary);background:var(--bg-surface);border:2px solid var(--border-default);border-radius:var(--radius-md);transition:all var(--transition-fast);caret-color:var(--accent-primary);outline:none}.pin-digit:focus{border-color:var(--accent-primary);box-shadow:0 0 0 4px var(--accent-primary-muted), var(--shadow-glow);background:var(--bg-surface-hover)}.pin-digit.pin-digit-error{border-color:var(--status-on-hold);animation:.3s pin-digit-flash;box-shadow:0 0 0 4px #ef444426}.pin-digit.pin-digit-success{border-color:var(--status-completed);color:var(--status-completed);box-shadow:0 0 0 4px #10b98126,0 0 20px #10b9811a}@keyframes pin-digit-flash{0%,to{background:var(--bg-surface)}50%{background:#ef44441a}}.pin-error{font-size:var(--font-size-sm);color:var(--status-on-hold);opacity:0;transition:all var(--transition-base);height:20px;margin-bottom:var(--space-md);font-weight:600;transform:translateY(-4px)}.pin-error.visible{opacity:1;transform:translateY(0)}.pin-gate-footer{align-items:center;gap:var(--space-sm);display:flex}.pin-gate-lock-label{font-size:var(--font-size-xs);color:var(--text-muted);letter-spacing:.04em;font-weight:500}.pin-shake{animation:.5s ease-in-out pin-shake-anim}@keyframes pin-shake-anim{0%,to{transform:translate(0)}10%,50%,90%{transform:translate(-8px)}30%,70%{transform:translate(8px)}}.pin-gate-exit{animation:.5s ease-in forwards pin-gate-leave}@keyframes pin-gate-leave{to{opacity:0;transform:scale(1.05)}}@media (width<=480px){.pin-gate-card{min-width:auto;margin:var(--space-md);padding:var(--space-xl) var(--space-lg)}.pin-digit{width:48px;height:56px;font-size:var(--font-size-xl)}}@keyframes fade-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.animate-in{animation:.4s ease-out fade-in}.stagger-1{animation-delay:50ms}.stagger-2{animation-delay:.1s}.stagger-3{animation-delay:.15s}.stagger-4{animation-delay:.2s}
