.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;position:relative;overflow:hidden}.login-background{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0}.grid-lines{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(0,212,170,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(0,212,170,.03) 1px,transparent 1px);background-size:60px 60px;-webkit-mask-image:radial-gradient(ellipse at center,black 20%,transparent 70%);mask-image:radial-gradient(ellipse at center,black 20%,transparent 70%)}.glow-orb{position:absolute;border-radius:50%;filter:blur(100px);opacity:.4;animation:float 20s ease-in-out infinite}.orb-1{width:500px;height:500px;background:var(--accent-primary);top:-200px;left:-100px}.orb-2{width:400px;height:400px;background:var(--accent-secondary);bottom:-150px;right:-100px;animation-delay:-10s}@keyframes float{0%,to{transform:translate(0)}25%{transform:translate(30px,30px)}50%{transform:translateY(50px)}75%{transform:translate(-30px,30px)}}.login-container{width:100%;max-width:420px;position:relative;z-index:1;animation:slideUp .6s ease}.login-header{text-align:center;margin-bottom:2.5rem}.logo{width:80px;height:80px;margin:0 auto 1.5rem;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;color:#000;box-shadow:var(--shadow-lg),0 0 40px #00d4aa4d}.login-logo{width:120px;height:auto;margin-bottom:1rem}.login-header h1{font-size:2rem;font-weight:700;margin-bottom:.25rem}.logo-kunye{color:#1a2744}.logo-tech{color:#3db9e5}.login-slogan{font-size:.9rem;color:var(--text-muted);margin-bottom:1rem;font-weight:500}.login-header p{color:var(--text-secondary);font-size:1rem}.login-form{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:2rem;display:flex;flex-direction:column;gap:1.5rem;box-shadow:var(--shadow-lg)}.input-with-icon{position:relative}.input-with-icon svg{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:var(--text-muted)}.input-with-icon .input{padding-left:2.75rem;width:100%}.login-form .btn{width:100%;margin-top:.5rem}.login-footer{margin-top:2rem;text-align:center}.demo-credentials{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:1rem}.demo-credentials p{color:var(--text-muted);font-size:.85rem;margin-bottom:.5rem}.demo-credentials code{display:block;font-family:var(--font-mono);color:var(--accent-primary);font-size:.85rem;margin-top:.25rem}.sidebar-header{display:flex;align-items:center;gap:.75rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border-color);margin-bottom:1.5rem}.sidebar-logo-img{width:36px;height:36px;object-fit:contain;border-radius:var(--radius-sm)}.sidebar-logo{width:40px;height:40px;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:#000}.sidebar-header span{font-size:1.25rem;font-weight:600}.sidebar-nav{flex:1}.nav-item{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;border-radius:var(--radius-md);color:var(--text-secondary);text-decoration:none;transition:all .2s ease;margin-bottom:.25rem}.nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-item.active{background:#00d4aa1a;color:var(--accent-primary)}.sidebar-footer{display:flex;align-items:center;justify-content:space-between;padding-top:1.5rem;border-top:1px solid var(--border-color)}.user-info{display:flex;align-items:center;gap:.75rem}.user-avatar{width:40px;height:40px;background:linear-gradient(135deg,var(--accent-primary),#00b894);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-weight:600;color:#000}.user-avatar.user{background:linear-gradient(135deg,var(--accent-secondary),#0284c7)}.user-details{display:flex;flex-direction:column}.user-name{font-weight:500;font-size:.95rem}.user-role{font-size:.8rem;color:var(--text-muted);text-transform:capitalize}.user-company{display:flex;align-items:center;gap:.375rem;font-size:.75rem;color:var(--text-muted)}.logout-btn{width:36px;height:36px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.logout-btn:hover{background:var(--accent-danger);border-color:var(--accent-danger);color:#fff}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:2rem}.stats-grid.user-stats{grid-template-columns:repeat(2,1fr);max-width:500px}.stat-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:1.25rem;display:flex;align-items:center;gap:1rem;transition:all .2s ease}.stat-card:hover{border-color:var(--border-light);transform:translateY(-2px)}.stat-card.highlight{border-color:var(--accent-primary);box-shadow:0 0 20px #00d4aa1a}.stat-icon{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center}.stat-icon.total{background:#94a3b826;color:var(--text-secondary)}.stat-icon.pending{background:#f59e0b26;color:var(--status-pending)}.stat-icon.reviewing{background:#0ea5e926;color:var(--status-reviewing)}.stat-icon.completed{background:#10b98126;color:var(--status-completed)}.stat-content{display:flex;flex-direction:column}.stat-value{font-size:1.75rem;font-weight:600;line-height:1}.stat-label{font-size:.85rem;color:var(--text-muted);margin-top:.25rem}.filter-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem;padding:.375rem;background:var(--bg-secondary);border-radius:var(--radius-md);width:fit-content}.filter-tab{display:flex;align-items:center;gap:.5rem;padding:.625rem 1rem;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-secondary);font-family:var(--font-sans);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease}.filter-tab:hover{color:var(--text-primary)}.filter-tab.active{background:var(--bg-card);color:var(--text-primary);box-shadow:var(--shadow-sm)}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1rem}.project-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:1.5rem;text-decoration:none;transition:all .2s ease;display:flex;flex-direction:column;gap:.75rem}.project-card:hover{border-color:var(--accent-primary);transform:translateY(-4px);box-shadow:var(--shadow-lg),0 0 30px #00d4aa1a}.project-card-header{display:flex;align-items:center;justify-content:space-between}.card-arrow{color:var(--text-muted);transition:all .2s ease}.project-card:hover .card-arrow{color:var(--accent-primary);transform:translate(4px)}.project-name{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin:0}.project-part{font-family:var(--font-mono);font-size:.85rem;color:var(--text-muted);margin:0}.project-meta{display:flex;flex-wrap:wrap;gap:1rem;margin-top:.5rem}.meta-item{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--text-secondary)}.meta-item.deadline{color:var(--status-warning)}.project-progress{margin-top:auto;padding-top:1rem;border-top:1px solid var(--border-color)}.progress-header{display:flex;justify-content:space-between;font-size:.8rem;color:var(--text-muted);margin-bottom:.5rem}@media (max-width: 1200px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.stats-grid,.projects-grid{grid-template-columns:1fr}}.step-viewer{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden}.step-viewer canvas{display:block}.step-viewer.measure-mode canvas{cursor:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" viewBox="0 0 16 16"><circle cx="8" cy="8" r="5" fill="none" stroke="rgba(255,170,0,0.9)" stroke-width="1.5"/><circle cx="8" cy="8" r="1.5" fill="rgba(255,170,0,1)"/></svg>') 8 8,crosshair}.measurement-label{font-family:SF Mono,Monaco,Consolas,monospace;text-shadow:0 0 8px rgba(0,0,0,.8),0 0 4px rgba(0,0,0,.8);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);box-shadow:0 2px 8px #0006}.viewer-loading,.viewer-error{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;background:var(--bg-primary);z-index:10}.viewer-loading p,.viewer-error p{color:var(--text-secondary);font-size:.9rem}.viewer-error p{color:var(--accent-danger)}.viewer-controls{position:absolute;top:1rem;right:1rem;display:flex;flex-direction:column;gap:.5rem;z-index:20}.control-divider{height:1px;background:var(--border-color);margin:.25rem 0}.control-btn{width:44px;height:44px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.control-btn:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-light);transform:scale(1.05)}.control-btn.active{background:var(--accent-primary);border-color:var(--accent-primary);color:#000}.control-btn:disabled{opacity:.3;cursor:not-allowed}.hover-tooltip{position:absolute;top:1rem;left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:.25rem;background:#ffff0026;border:1px solid rgba(255,255,0,.5);padding:.75rem 1.25rem;border-radius:var(--radius-md);z-index:100;pointer-events:none;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.hover-tooltip-main{display:flex;align-items:center;gap:.5rem;font-family:var(--font-mono);font-size:1rem;font-weight:700;color:#ff0}.hover-length{font-size:1.1rem}.hover-tooltip-hint{font-size:.7rem;color:#ffff00b3;text-transform:uppercase;letter-spacing:.5px}.measure-result-panel{position:absolute;top:1rem;left:1rem;background:var(--bg-card);border-radius:var(--radius-lg);padding:0;min-width:220px;z-index:100;box-shadow:0 8px 32px #0006;overflow:hidden;pointer-events:auto}.measure-type-badge{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1rem;font-size:.75rem;font-weight:700;letter-spacing:1px;text-transform:uppercase}.measure-type-badge.edge{background:linear-gradient(135deg,#0f83,#00ff881a);color:#0f8;border-bottom:2px solid #00ff88}.measure-type-badge.diameter{background:linear-gradient(135deg,#f803,#ff88001a);color:#f80;border-bottom:2px solid #ff8800}.measure-type-badge.surface{background:linear-gradient(135deg,#00d4aa33,#00d4aa1a);color:#00d4aa;border-bottom:2px solid #00d4aa}.measure-type-badge.distance{background:linear-gradient(135deg,#fa03,#ffaa001a);color:#fa0;border-bottom:2px solid #ffaa00}.measure-value-container{padding:1.25rem 1rem}.measure-value{display:flex;flex-direction:column;align-items:center;gap:.25rem}.measure-value .value-label{font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.measure-value .value-number{font-family:var(--font-mono);font-size:2rem;font-weight:700;line-height:1}.measure-value .value-unit{font-size:.8rem;color:var(--text-muted)}.measure-value.edge .value-number{color:#0f8}.measure-value.diameter .value-number{color:#f80}.measure-value.surface .value-number{color:#00d4aa}.measure-value.distance .value-number{color:#fa0}.measure-instruction{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:.5rem;color:var(--text-secondary);font-size:.9rem}.step-indicator{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;background:#fa03;border:1px solid #ffaa00;border-radius:50%;font-size:.75rem;font-weight:700;color:#fa0}.distance-components{display:flex;flex-direction:column;gap:.5rem;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-color)}.component-item{display:flex;align-items:center;justify-content:space-between;padding:.5rem .75rem;background:var(--bg-secondary);border-radius:var(--radius-sm);font-family:var(--font-mono);font-size:.85rem}.component-label{font-weight:700;color:var(--accent-primary);min-width:35px}.component-value{color:var(--text-primary);font-weight:600}.clear-btn{display:block;width:100%;padding:.75rem;margin-top:1rem;background:var(--bg-secondary);border:none;border-top:1px solid var(--border-color);color:var(--text-muted);font-size:.8rem;cursor:pointer;transition:all .2s;border-radius:0 0 var(--radius-lg) var(--radius-lg)}.clear-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.live-distance-panel{position:absolute;bottom:5rem;right:1rem;background:#0a0b0df2;border:2px solid #ffaa00;border-radius:var(--radius-lg);padding:0;min-width:280px;z-index:150;box-shadow:0 12px 48px #ffaa004d;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);animation:liveDistancePulse 2s ease-in-out infinite;pointer-events:auto}@keyframes liveDistancePulse{0%,to{box-shadow:0 12px 48px #ffaa004d}50%{box-shadow:0 12px 48px #ffaa0080}}.live-distance-header{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem;background:#ffaa0026;border-bottom:1px solid #ffaa00;font-size:.7rem;font-weight:700;letter-spacing:1px;color:#fa0}.live-distance-values{padding:1.25rem 1rem;display:flex;flex-direction:column;gap:1rem}.live-distance-main{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color)}.live-distance-main .value-label{font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.live-distance-main .value-display{display:flex;align-items:baseline;gap:.5rem}.live-distance-main .value-number{font-family:var(--font-mono);font-size:2.5rem;font-weight:700;color:#fa0;line-height:1;text-shadow:0 0 20px rgba(255,170,0,.5)}.live-distance-main .value-unit{font-size:1rem;color:var(--text-muted)}.axis-distances{display:flex;flex-direction:column;gap:.5rem}.axis-item{display:flex;align-items:center;justify-content:space-between;padding:.5rem .75rem;background:var(--bg-secondary);border-radius:var(--radius-sm);font-family:var(--font-mono);font-size:.85rem}.axis-label{font-weight:700;color:var(--accent-primary);min-width:35px}.axis-value{color:var(--text-primary)}.measure-instructions{position:absolute;top:1rem;left:1rem;display:flex;flex-direction:column;gap:.5rem;z-index:20}.instruction-item{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:#0a0b0dd9;border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:.8rem;color:var(--text-muted);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.instruction-item svg{color:var(--accent-primary);flex-shrink:0}.viewer-help{position:absolute;bottom:1rem;left:1rem;display:flex;gap:.75rem;z-index:20}.help-item{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:#0a0b0dd9;border-radius:var(--radius-sm);font-size:.7rem;color:var(--text-muted);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.help-item svg{opacity:.6}@media (max-width: 768px){.viewer-help{display:none}.measure-result-panel{left:.5rem;right:.5rem;max-width:none}.measure-instructions{left:.5rem;right:60px}.measure-value .value-number{font-size:1.75rem}.live-distance-panel{bottom:.5rem;right:.5rem;left:.5rem;min-width:unset;max-width:none}.live-distance-main .value-number{font-size:2rem}.axis-item{font-size:.75rem}}.project-detail-page{height:100vh;display:flex;flex-direction:column;background:var(--bg-primary)}.detail-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);flex-shrink:0}.header-left{display:flex;align-items:center;gap:1.5rem}.back-link{display:flex;align-items:center;gap:.5rem;color:var(--text-secondary);text-decoration:none;padding:.5rem .75rem;border-radius:var(--radius-md);transition:all .2s ease}.back-link:hover{color:var(--text-primary);background:var(--bg-hover)}.header-info{display:flex;flex-direction:column;gap:.5rem}.header-top{display:flex;align-items:center;gap:1rem}.header-top h1{font-size:1.25rem;font-weight:600;margin:0}.header-meta{display:flex;gap:1.5rem}.header-meta .meta-item{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--text-muted)}.detail-content{flex:1;display:grid;grid-template-columns:1fr 380px;overflow:hidden}.viewer-panel{display:flex;flex-direction:column;border-right:1px solid var(--border-color)}.panel-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-bottom:1px solid var(--border-color);background:var(--bg-secondary)}.panel-header h2{font-size:1rem;font-weight:600;margin:0}.panel-header .file-name{font-family:var(--font-mono);font-size:.8rem;color:var(--text-muted)}.viewer-container{flex:1;position:relative;background:var(--bg-primary);overflow:hidden}.no-model{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;color:var(--text-muted)}.checklist-panel{display:flex;flex-direction:column;background:var(--bg-secondary);overflow-y:auto}.checklist-panel .panel-header{position:sticky;top:0;z-index:10}.progress-text{font-family:var(--font-mono);font-size:.85rem;color:var(--accent-primary)}.checklist-panel .progress-bar{margin:0 1.5rem 1rem}.checklist-items{padding:0 1.5rem;display:flex;flex-direction:column;gap:.75rem}.checklist-items .checkbox-wrapper{padding:1rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);transition:all .2s ease}.checklist-items .checkbox-wrapper:hover{border-color:var(--border-light)}.checklist-items .checkbox-wrapper:has(input:checked){background:#00d4aa0d;border-color:#00d4aa4d}.item-number{color:var(--text-muted);margin-right:.5rem}.checked-indicator{margin-left:auto;font-size:.75rem;color:var(--accent);background:#00d4aa1a;padding:.25rem .5rem;border-radius:var(--radius-sm);font-weight:500}.checkbox-wrapper.is-checked{background:#00d4aa14;border-color:#00d4aa66}.upload-section{margin:1.5rem;padding:1.25rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md)}.upload-section h3{font-size:.9rem;font-weight:600;margin:0 0 .25rem}.upload-section p{font-size:.8rem;color:var(--text-muted);margin:0 0 1rem}.upload-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.625rem 1rem;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:.85rem;cursor:pointer;transition:all .2s ease}.upload-btn:hover{background:var(--bg-hover);border-color:var(--accent-primary)}.upload-btn input{display:none}.documents-section{margin:0 1.5rem 1.5rem;padding:1.25rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md)}.documents-section h3{font-size:.9rem;font-weight:600;margin:0 0 1rem}.documents-list{display:flex;flex-direction:column;gap:.5rem}.document-item-wrapper{display:flex;align-items:center;gap:.5rem}.document-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:var(--bg-secondary);border-radius:var(--radius-sm);color:var(--text-primary);text-decoration:none;font-size:.85rem;transition:all .2s ease;flex:1}.document-item:hover{background:var(--bg-hover)}.document-item span{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.document-item svg:last-child{color:var(--text-muted);opacity:0;transition:opacity .2s ease}.document-item:hover svg:last-child{opacity:1}.delete-doc-btn{display:flex;align-items:center;justify-content:center;padding:.5rem;background:transparent;border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;transition:all .2s ease;flex-shrink:0}.delete-doc-btn:hover{background:#ef44441a;border-color:#ef44444d;color:#ef4444}.delete-doc-btn:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 1024px){.detail-content{grid-template-columns:1fr;grid-template-rows:1fr 1fr}.viewer-panel{border-right:none;border-bottom:1px solid var(--border-color)}}.back-link{display:inline-flex;align-items:center;gap:.5rem;color:var(--text-secondary);text-decoration:none;font-size:.9rem;margin-bottom:.5rem;transition:color .2s ease}.back-link:hover{color:var(--accent-primary)}.new-project-form{max-width:800px}.form-section{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:1.5rem;margin-bottom:1.5rem}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.section-title{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0 0 1rem}.section-header .section-title{margin:0}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}@media (max-width: 640px){.form-grid{grid-template-columns:1fr}}.file-upload{display:flex;flex-direction:column;align-items:center;gap:.75rem;color:var(--text-muted)}.file-upload svg{color:var(--text-muted)}.file-upload.active svg{color:var(--accent-primary)}.file-info{display:flex;flex-direction:column;align-items:center;gap:.25rem}.file-name{color:var(--accent-primary);font-weight:500}.file-size{font-size:.85rem;color:var(--text-muted)}.file-hint{font-size:.8rem;color:var(--text-muted)}.checklist-items{display:flex;flex-direction:column;gap:.75rem}.checklist-input-row{display:flex;align-items:center;gap:.75rem}.checklist-number{width:28px;height:28px;background:var(--bg-tertiary);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:500;color:var(--text-muted);flex-shrink:0}.checklist-input-row .input{flex:1}.form-actions{display:flex;gap:1rem;justify-content:flex-end}.users-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem}.user-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:1.5rem;display:flex;align-items:center;gap:1rem;transition:all .2s ease}.user-card:hover{border-color:var(--border-light);transform:translateY(-2px)}.user-card-avatar{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:1.25rem;font-weight:600;flex-shrink:0}.user-card-avatar[data-role=admin]{background:linear-gradient(135deg,var(--accent-primary),#00b894);color:#000}.user-card-avatar[data-role=user]{background:linear-gradient(135deg,var(--accent-secondary),#0284c7);color:#fff}.user-card-info{flex:1;min-width:0}.user-card-info h3{font-size:1rem;font-weight:600;margin:0 0 .25rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-email,.user-company{display:flex;align-items:center;gap:.5rem;font-size:.8rem;color:var(--text-muted);margin:.25rem 0 0}.role-badge{display:flex;align-items:center;gap:.375rem;padding:.375rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600;flex-shrink:0}.role-badge.admin{background:#00d4aa26;color:var(--accent-primary);border:1px solid rgba(0,212,170,.3)}.role-badge.user{background:#0ea5e926;color:var(--accent-secondary);border:1px solid rgba(14,165,233,.3)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.modal{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);width:100%;max-width:480px;max-height:90vh;overflow-y:auto;animation:slideUp .3s ease}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-color)}.modal-header h2{font-size:1.125rem;font-weight:600;margin:0}.modal-close{width:32px;height:32px;background:transparent;border:none;color:var(--text-muted);font-size:1.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:all .2s ease}.modal-close:hover{background:var(--bg-hover);color:var(--text-primary)}.modal-body{padding:1.5rem;display:flex;flex-direction:column;gap:1rem}.modal-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:.5rem}.success-message{background:#10b9811a;border:1px solid rgba(16,185,129,.3);color:var(--accent-success);padding:.875rem 1rem;border-radius:var(--radius-md);font-size:.9rem}.error-message{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:var(--accent-danger);padding:.875rem 1rem;border-radius:var(--radius-md);font-size:.9rem}:root{--bg-primary: #0a0b0d;--bg-secondary: #12141a;--bg-tertiary: #1a1d26;--bg-card: #15171f;--bg-hover: #1e2130;--accent-primary: #00d4aa;--accent-secondary: #0ea5e9;--accent-warning: #f59e0b;--accent-danger: #ef4444;--accent-success: #10b981;--text-primary: #f1f5f9;--text-secondary: #94a3b8;--text-muted: #64748b;--border-color: #2a2f3d;--border-light: #3a4050;--status-pending: #f59e0b;--status-reviewing: #0ea5e9;--status-completed: #10b981;--shadow-sm: 0 1px 2px 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-glow: 0 0 20px rgba(0, 212, 170, .15);--font-sans: "Outfit", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono: "JetBrains Mono", monospace;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px}*{margin:0;padding:0;box-sizing:border-box}html,body{height:100%}body{font-family:var(--font-sans);background:var(--bg-primary);color:var(--text-primary);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{height:100%}body:before{content:"";position:fixed;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at 20% 80%,rgba(0,212,170,.03) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(14,165,233,.03) 0%,transparent 50%),linear-gradient(180deg,var(--bg-primary) 0%,#080910 100%);pointer-events:none;z-index:-1}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;gap:1rem}.loading-spinner{width:48px;height:48px;border:3px solid var(--border-color);border-top-color:var(--accent-primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;font-family:var(--font-sans);font-size:.9rem;font-weight:500;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease;text-decoration:none}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,var(--accent-primary),#00b894);color:#000;box-shadow:var(--shadow-md),0 0 20px #00d4aa33}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-lg),0 0 30px #00d4aa4d}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover:not(:disabled){background:var(--bg-hover);border-color:var(--border-light)}.btn-danger{background:var(--accent-danger);color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-sm{padding:.5rem 1rem;font-size:.85rem}.btn-lg{padding:1rem 2rem;font-size:1rem}.input-group{display:flex;flex-direction:column;gap:.5rem}.input-group label{font-size:.85rem;font-weight:500;color:var(--text-secondary)}.input{padding:.875rem 1rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-sans);font-size:.95rem;transition:all .2s ease}.input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #00d4aa1a}.input::placeholder{color:var(--text-muted)}.card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:1.5rem;transition:all .2s ease}.card:hover{border-color:var(--border-light);box-shadow:var(--shadow-md)}.badge{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .75rem;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;border-radius:9999px}.badge-pending{background:#f59e0b26;color:var(--status-pending);border:1px solid rgba(245,158,11,.3)}.badge-reviewing{background:#0ea5e926;color:var(--status-reviewing);border:1px solid rgba(14,165,233,.3)}.badge-completed{background:#10b98126;color:var(--status-completed);border:1px solid rgba(16,185,129,.3)}.progress-bar{width:100%;height:6px;background:var(--bg-secondary);border-radius:3px;overflow:hidden}.progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--accent-primary),var(--accent-secondary));border-radius:3px;transition:width .3s ease}.layout{display:flex;min-height:100vh}.sidebar{width:280px;background:var(--bg-secondary);border-right:1px solid var(--border-color);display:flex;flex-direction:column;padding:1.5rem}.main-content{flex:1;padding:2rem;overflow-y:auto}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem}.page-title{font-size:1.75rem;font-weight:600;color:var(--text-primary)}.page-subtitle{font-size:.95rem;color:var(--text-secondary);margin-top:.25rem}.grid{display:grid;gap:1.5rem}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}@media (max-width: 1024px){.grid-3{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.grid-2,.grid-3{grid-template-columns:1fr}.sidebar{display:none}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:fadeIn .3s ease}.animate-slide-up{animation:slideUp .4s ease}.stagger-children>*{animation:slideUp .4s ease backwards}.stagger-children>*:nth-child(1){animation-delay:.05s}.stagger-children>*:nth-child(2){animation-delay:.1s}.stagger-children>*:nth-child(3){animation-delay:.15s}.stagger-children>*:nth-child(4){animation-delay:.2s}.stagger-children>*:nth-child(5){animation-delay:.25s}.stagger-children>*:nth-child(6){animation-delay:.3s}.checkbox-wrapper{display:flex;align-items:center;gap:.75rem;cursor:pointer}.checkbox-wrapper input[type=checkbox]{display:none}.checkbox-custom{width:22px;height:22px;border:2px solid var(--border-light);border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0}.checkbox-wrapper input[type=checkbox]:checked+.checkbox-custom{background:var(--accent-primary);border-color:var(--accent-primary)}.checkbox-custom svg{width:14px;height:14px;color:#000;opacity:0;transform:scale(.5);transition:all .2s ease}.checkbox-wrapper input[type=checkbox]:checked+.checkbox-custom svg{opacity:1;transform:scale(1)}.checkbox-label{font-size:.95rem;color:var(--text-primary);line-height:1.4}.checkbox-wrapper input[type=checkbox]:checked~.checkbox-label{color:var(--text-secondary);text-decoration:line-through}.file-upload{border:2px dashed var(--border-color);border-radius:var(--radius-lg);padding:2rem;text-align:center;cursor:pointer;transition:all .2s ease}.file-upload:hover{border-color:var(--accent-primary);background:#00d4aa08}.file-upload.active{border-color:var(--accent-primary);background:#00d4aa0d}.file-upload input[type=file]{display:none}.toast-container{position:fixed;bottom:2rem;right:2rem;z-index:1000}.toast{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:1rem 1.5rem;margin-top:.5rem;box-shadow:var(--shadow-lg);animation:slideUp .3s ease;display:flex;align-items:center;gap:.75rem}.toast-success{border-color:var(--accent-success)}.toast-error{border-color:var(--accent-danger)}.empty-state{text-align:center;padding:4rem 2rem;color:var(--text-muted)}.empty-state-icon{width:64px;height:64px;margin:0 auto 1rem;opacity:.5}.empty-state-title{font-size:1.25rem;color:var(--text-secondary);margin-bottom:.5rem}
