.animated-icon{align-items:center;display:inline-flex;justify-content:center}@keyframes heartbeat{0%{transform:scale(1)}5%{transform:scale(1.2)}10%{transform:scale(1)}15%{transform:scale(1.25)}20%{transform:scale(1)}to{transform:scale(1)}}.animated-icon-heartbeat{animation:heartbeat 1.5s ease-in-out infinite;transform-origin:center}@keyframes radioWave{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.2)}}.animated-icon-radioWave{animation:radioWave 1.5s ease-in-out infinite}@keyframes branchPulse{0%,to{transform:scale(1) rotate(0deg)}25%{transform:scale(1.1) rotate(2deg)}75%{transform:scale(1.1) rotate(-2deg)}}.animated-icon-branchPulse{animation:branchPulse 3s ease-in-out infinite}@keyframes databaseSpin{0%{transform:rotateY(0deg)}to{transform:rotateY(1turn)}}.animated-icon-databaseSpin{animation:databaseSpin 4s linear infinite}@keyframes searchScan{0%,to{transform:translateX(0) scale(1)}25%{transform:translateX(2px) scale(1.05)}75%{transform:translateX(-2px) scale(1.05)}}.animated-icon-searchScan{animation:searchScan 2s ease-in-out infinite}@keyframes clipboardCheck{0%,90%,to{transform:translateY(0)}45%{transform:translateY(-4px)}}.animated-icon-clipboardCheck{animation:clipboardCheck 2.5s ease-in-out infinite}@keyframes transform{0%,to{transform:scaleX(1)}50%{transform:scaleX(-1)}}.animated-icon-transform{animation:transform 3s ease-in-out infinite}@keyframes gentlePulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.85;transform:scale(1.08)}}.animated-icon-gentlePulse{animation:gentlePulse 3s ease-in-out infinite}@keyframes glow{0%,to{filter:drop-shadow(0 0 2px currentColor)}50%{filter:drop-shadow(0 0 8px currentColor)}}.animated-icon-glow{animation:glow 2s ease-in-out infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.animated-icon-bounce{animation:bounce 2s ease-in-out infinite}@keyframes rotate{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.animated-icon-rotate{animation:rotate 3s linear infinite}.animated-icon-pulse{animation:pulse 2s ease-in-out infinite}.landing-page{background:#f8fafc;display:flex;flex-direction:column;min-height:100vh}.hero-banner{align-items:flex-start;background:linear-gradient(180deg,#fafafb00 40%,#fafafb80 70%,#fafafbe6 90%,#fafafb),url(/static/media/platformbannerbackground.f44faec3361b988a2906.jpg);background-position:top;background-repeat:no-repeat;background-size:100% 200px;display:flex;height:200px;justify-content:center;margin-bottom:0;margin-top:72px;overflow:hidden;padding-top:70px;position:relative}.hero-banner:before{inset:0}.hero-banner:after,.hero-banner:before{background:#0000;content:"";pointer-events:none;position:absolute}.hero-banner:after{bottom:0;height:0;left:0;right:0}@keyframes heroGlow{0%,to{opacity:.3}50%{opacity:.6}}.hero-content{padding:0 24px;position:relative;text-align:center;width:100%;z-index:10}.hero-content h1{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;animation:fadeInUp 1s ease-out;color:#fff;font-size:2.25rem;font-weight:700;letter-spacing:normal;line-height:1.4;margin:0 auto;max-width:100%;text-rendering:optimizeLegibility;text-shadow:0 2px 8px #00000080}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.hero-subtitle{color:#fff9;font-size:1rem;font-weight:400;margin-top:16px}.main-content{background-image:radial-gradient(circle at 20% 30%,#3b82f608 0,#0000 50%),radial-gradient(circle at 80% 70%,#8b5cf608 0,#0000 50%);flex:1 1;padding:0 0 80px}.container{margin:0 auto;padding:0 24px;width:100%}.section{border-bottom:1px solid #e2e8f080;margin-bottom:48px;padding-bottom:32px}.section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.section-header{gap:12px;margin-bottom:20px}.section-header,.section-icon{align-items:center;display:flex}.section-icon{background:linear-gradient(135deg,#3b82f6,#8b5cf6);border-radius:8px;box-shadow:0 2px 8px #3b82f633;color:#fff;height:32px;justify-content:center;width:32px}.section-icon.toolbox-icon{background:linear-gradient(135deg,#10b981,#3b82f6);box-shadow:0 2px 8px #10b98133}.section-header h2{color:#64748b;font-size:.8125rem;font-weight:700;letter-spacing:.1em;margin:0}.landing-page.dark .section-header h2{color:#94a3b8}.section-subtitle{color:#94a3b8;font-size:.75rem;font-style:italic;font-weight:400;margin-left:auto}.cards-grid{grid-gap:18px;display:grid;gap:18px}.apps-grid,.toolbox-grid{grid-template-columns:repeat(4,1fr)}.app-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 1px 3px #0000000a;display:flex;flex-direction:column;outline:none;overflow:hidden;padding:20px;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1)}.clickable-card{cursor:pointer}.app-card:before{background:#3b82f6;background:var(--card-accent-color,#3b82f6);height:3px;left:0;right:0;top:0;transition:opacity .3s ease}.app-card:after,.app-card:before{content:"";opacity:0;pointer-events:none;position:absolute}.app-card:after{background:radial-gradient(circle,#3b82f6 0,#0000 70%);background:radial-gradient(circle,var(--card-accent-color,#3b82f6) 0,#0000 70%);border-radius:50%;height:0;left:50%;top:50%;transform:translate(-50%,-50%);transition:all .4s ease;width:0}.app-card:hover{border-color:#cbd5e1;border-color:var(--card-accent-color,#cbd5e1);box-shadow:0 20px 40px #00000026,0 12px 20px #0000001a,0 0 50px #0000;box-shadow:0 20px 40px #00000026,0 12px 20px #0000001a,0 0 50px var(--card-accent-color,#0000);transform:translateY(-8px) scale(1.02)}.app-card:hover:before{opacity:1}.app-card:hover:after{height:300px;opacity:.03;width:300px}.app-card:active{transform:translateY(-4px) scale(1.01);transition:transform .1s ease}.app-card:hover .card-icon{animation:icon-bounce .4s ease}@keyframes icon-bounce{0%{transform:scale(1)}50%{transform:scale(1.15)}to{transform:scale(1)}}.app-card:hover .card-content h3{color:#3b82f6;color:var(--card-accent-color,#3b82f6);transition:color .2s ease}.card-hover-indicator{align-items:center;background:#3b82f6;background:var(--card-accent-color,#3b82f6);border-radius:50%;bottom:16px;color:#fff;display:flex;height:36px;justify-content:center;opacity:0;pointer-events:none;position:absolute;right:16px;transform:scale(.8);transition:all .3s cubic-bezier(.4,0,.2,1);width:36px;z-index:5}.app-card:hover .card-hover-indicator{opacity:1;transform:scale(1)}.card-icon{align-items:center;border-radius:10px;display:flex;height:44px;justify-content:center;margin-bottom:14px;position:relative;transition:all .3s ease;width:44px;z-index:1}.card-icon:before{background:inherit;border-radius:16px;content:"";filter:blur(10px);inset:-4px;opacity:0;position:absolute;transition:opacity .3s ease}.app-card:hover .card-icon{box-shadow:0 12px 24px #0003;transform:scale(1.15)}.app-card:hover .card-icon:before{opacity:.6}.card-content{flex:1 1;position:relative;z-index:1}.card-content h3{color:#0f172a;font-size:1rem;font-weight:600;letter-spacing:-.01em;margin:0 0 8px;transition:color .3s ease}.app-card:hover .card-content h3{color:#0f172a;color:var(--card-accent-color,#0f172a)}.card-content p{color:#64748b;font-size:.875rem;line-height:1.5;margin:0;white-space:pre-line}.card-footer{gap:10px;margin-top:12px}.card-author{align-items:center;background:linear-gradient(135deg,#3b82f614,#3b82f61f);background:linear-gradient(135deg,rgba(var(--author-color-rgb,59,130,246),.08) 0,rgba(var(--author-color-rgb,59,130,246),.12) 100%);border-left:2px solid #3b82f6;border-left:2px solid var(--author-color,#3b82f6);border-radius:6px;color:#475569;display:flex;flex:1 1;font-size:.8125rem;font-weight:500;gap:6px;min-width:0;padding:6px 10px;transition:all .3s ease}.dark-mode .card-author{background:linear-gradient(135deg,#3b82f626,#3b82f633);background:linear-gradient(135deg,rgba(var(--author-color-rgb,59,130,246),.15) 0,rgba(var(--author-color-rgb,59,130,246),.2) 100%);color:#cbd5e1}.card-author svg{color:#3b82f6;color:var(--author-color,#3b82f6);flex-shrink:0}.app-card:hover .card-author{background:linear-gradient(135deg,#3b82f626,#3b82f638);background:linear-gradient(135deg,rgba(var(--author-color-rgb,59,130,246),.15) 0,rgba(var(--author-color-rgb,59,130,246),.22) 100%);border-left-width:3px}.customer-badges{align-items:center;display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.customer-badge{align-items:center;background:#f1f5f9;background:var(--customer-bg,#f1f5f9);border:1.5px solid #64748b;border:1.5px solid var(--customer-color,#64748b);border-radius:20px;display:flex;gap:6px;padding:5px 10px;transition:all .2s ease}.dark-mode .customer-badge{background:#ffffff0d;border-color:#64748b;border-color:var(--customer-color,#64748b)}.customer-badge:hover{box-shadow:0 3px 10px #0000001f;transform:translateY(-1px)}.customer-logo-wrapper{align-items:center;display:flex;flex-shrink:0;justify-content:center}.company-logo-svg{display:block}.company-logo-svg.chevron-logo{height:16px;width:22px}.company-logo-svg.westlake-logo{height:14px;width:42px}.company-logo-svg.kuraray-logo{height:12px;width:38px}.company-logo-svg.tsar-logo{height:15px;width:32px}.dark-mode .company-logo-svg.westlake-logo text{fill:#4fc3f7}.dark-mode .company-logo-svg.westlake-logo path{stroke:#4fc3f7}.dark-mode .company-logo-svg.kuraray-logo text{fill:#4dd0e1}.dark-mode .company-logo-svg.tsar-logo rect{fill:#5b7fa8}.dark-mode .customer-logo-wrapper{background:#ffffff1a;border-radius:4px;padding:2px 4px}.customer-name{color:#64748b;color:var(--customer-color,#64748b);font-size:.75rem;font-weight:600;letter-spacing:.25px}.dark-mode .customer-name{color:#94a3b8;color:var(--customer-color,#94a3b8)}.dark-mode .customer-badge[style*="--customer-color: #1E3856"] .customer-name{color:#8ab4f8!important}.dark-mode .customer-badge[style*="--customer-color: #0056A4"] .customer-name{color:#5b9ef4!important}.dark-mode .customer-badge[style*="--customer-color: #0077B5"] .customer-name{color:#4fc3f7!important}.dark-mode .customer-badge[style*="--customer-color: #00A0AF"] .customer-name{color:#4dd0e1!important}.customer-label{color:#94a3b8;font-size:.6875rem;font-weight:700;letter-spacing:.75px;margin-left:2px;text-transform:uppercase}.dark-mode .customer-label{color:var(--text-muted)}.app-card:hover .customer-badge{box-shadow:0 3px 12px #00000026}.guide-button{align-items:center;background:#3b82f61a;border:1px solid #3b82f64d;border-radius:6px;color:#3b82f6;cursor:pointer;display:flex;flex-shrink:0;font-size:.8125rem;font-weight:500;gap:6px;padding:6px 12px;transition:all .2s ease}.guide-button:hover{background:#3b82f633;border-color:#3b82f6;transform:translateY(-1px)}.dark-mode .guide-button{background:#3b82f626;color:#60a5fa}.dark-mode .guide-button:hover{background:#3b82f640}.app-card[draggable=true]{cursor:move;user-select:none;-webkit-user-select:none}.app-card.dragging{opacity:.5;transform:scale(.95)}.app-card[draggable=true]:active{cursor:grabbing}.card-icon{-webkit-backface-visibility:hidden;backface-visibility:hidden;will-change:transform}.app-card.restricted{cursor:not-allowed;filter:grayscale(.3);opacity:.75;position:relative}.app-card.restricted:hover{box-shadow:0 4px 12px #00000014;transform:translateY(-2px)}.app-card.restricted:before{background:linear-gradient(135deg,#0000000d,#00000026);border-radius:12px;bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0;z-index:1}.restricted-overlay{align-items:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#dc2626e6;border-radius:6px;box-shadow:0 2px 8px #dc26264d;color:#fff;display:flex;font-size:.75rem;font-weight:600;gap:6px;padding:6px 12px;position:absolute;right:12px;top:12px;z-index:10}.restricted-overlay svg{height:14px;width:14px}.dark-mode .app-card.restricted:before{background:linear-gradient(135deg,#0000001a,#0000004d)}.dark-mode .restricted-overlay{background:#ef4444e6;box-shadow:0 2px 8px #ef444466}.guide-modal{background:#fff;border-radius:16px;box-shadow:0 25px 50px #00000040;display:flex;flex-direction:column;max-height:85vh;max-width:600px;overflow:hidden;position:relative;width:90%}.dark-mode .guide-modal{background:#fff;background:var(--card-bg);border:1px solid #e2e8f0;border:1px solid var(--border-color)}.guide-header{align-items:center;background:linear-gradient(135deg,#3b82f60d,#0000);background:linear-gradient(135deg,rgba(var(--guide-color-rgb,59,130,246),.05) 0,#0000 100%);border-bottom:1px solid #f1f5f9;display:flex;gap:16px;padding:24px}.dark-mode .guide-header{background:linear-gradient(135deg,#3b82f61a,#0000);background:linear-gradient(135deg,rgba(var(--guide-color-rgb,59,130,246),.1) 0,#0000 100%);border-color:#e2e8f0;border-color:var(--border-color)}.guide-icon{align-items:center;border-radius:12px;display:flex;flex-shrink:0;height:56px;justify-content:center;width:56px}.guide-header h2{color:#0f172a;font-size:1.25rem;font-weight:600;margin:0 0 4px}.dark-mode .guide-header h2{color:#0f172a;color:var(--text-primary)}.guide-subtitle{color:#64748b;font-size:.875rem;margin:0}.dark-mode .guide-subtitle{color:#64748b;color:var(--text-secondary)}.guide-content{flex:1 1;overflow-y:auto;padding:24px}.guide-section h3{color:#1e293b;font-size:1rem;font-weight:600;margin:0 0 16px}.dark-mode .guide-section h3{color:#0f172a;color:var(--text-primary)}.guide-steps{display:flex;flex-direction:column;gap:14px;list-style:none;margin:0;padding:0}.guide-steps li{align-items:flex-start;display:flex;gap:12px}.step-number{align-items:center;background:linear-gradient(135deg,#3b82f6,#8b5cf6);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:.8125rem;font-weight:600;height:28px;justify-content:center;width:28px}.step-text{color:#475569;flex:1 1;font-size:.9375rem;line-height:1.6;padding-top:4px}.dark-mode .step-text{color:#64748b;color:var(--text-secondary)}.guide-tips{background:#fef3c7;border-left:3px solid #f59e0b;border-radius:8px;display:flex;gap:12px;margin-top:24px;padding:16px}.dark-mode .guide-tips{background:#f59e0b26;border-color:#f59e0b}.tip-icon{flex-shrink:0;font-size:1.5rem}.guide-tips h4{color:#92400e;font-size:.875rem;font-weight:600;margin:0 0 6px}.dark-mode .guide-tips h4{color:#fbbf24}.guide-tips p{color:#78350f;font-size:.875rem;line-height:1.5;margin:0}.dark-mode .guide-tips p{color:#fcd34d}.guide-author{align-items:center;border-top:1px solid #f1f5f9;color:#64748b;display:flex;font-size:.875rem;gap:8px;margin-top:20px;padding-top:20px}.dark-mode .guide-author{border-color:#e2e8f0;border-color:var(--border-color);color:#64748b;color:var(--text-secondary)}.guide-author strong{color:#1e293b}.dark-mode .guide-author strong{color:#0f172a;color:var(--text-primary)}.guide-footer{background:#f8fafc;border-top:1px solid #f1f5f9;display:flex;gap:12px;padding:20px 24px}.dark-mode .guide-footer{background:#0f172a80;border-color:#e2e8f0;border-color:var(--border-color)}.chevron-icon{background:linear-gradient(135deg,#005eb8,#d62828)}.chevron-grid{gap:20px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.footer{background:#fff;border-top:1px solid #e2e8f0;padding:24px 0}.footer p{color:#94a3b8;font-size:.875rem;margin:0;text-align:center}@media (max-width:1200px){.chevron-grid,.toolbox-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:900px){.apps-grid,.chevron-grid,.toolbox-grid{grid-template-columns:1fr}.container{padding:0 24px}.hero-content h1{font-size:1.875rem}.main-content{padding:40px 0 60px}}@media (max-width:600px){.hero-banner{height:200px;margin-top:64px;padding-top:60px}.hero-content h1{font-size:1.5rem}.hero-subtitle{font-size:.875rem}.main-content{padding:32px 0 48px}.container{padding:0 16px}.section{margin-bottom:48px}.app-card{padding:24px}.card-icon{height:44px;width:44px}}:root{--bg-primary:#f8fafc;--bg-secondary:#fff;--text-primary:#0f172a;--text-secondary:#64748b;--border-color:#e2e8f0;--modal-overlay:#00000080}.dark-mode{--bg-primary:#0f172a;--bg-secondary:#1e293b;--modal-overlay:#000c}.dark-mode .landing-page{background:#f8fafc;background:var(--bg-primary)}.dark-mode .section{border-bottom-color:#33415580}.dark-mode .hero-banner:after{background:#0000}.dark-mode .hero-banner{background:linear-gradient(180deg,#0f172a00 40%,#0f172a80 70%,#0f172ae6 90%,#0f172a),url(/static/media/platformbannerbackground.f44faec3361b988a2906.jpg);background-position:top;background-repeat:no-repeat;background-size:100% 200px}.dark-mode .app-card{background:#fff;background:var(--card-bg);border-color:#e2e8f0;border-color:var(--border-color)}.dark-mode .app-card:hover{border-color:#475569;box-shadow:0 12px 32px #00000080,0 8px 16px #0006}.dark-mode .clickable-card:hover{border-color:#3b82f6;box-shadow:0 12px 32px #3b82f64d,0 4px 8px #3b82f633}.dark-mode .card-content h3,.dark-mode .card-content p{color:#0f172a;color:var(--text-primary)}.dark-mode .card-content p{color:#64748b;color:var(--text-secondary)}.dark-mode .footer{background:#fff;background:var(--bg-secondary);border-color:#e2e8f0;border-color:var(--border-color)}.dark-mode-toggle{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border:1px solid #ffffff4d;border-radius:50%;color:#fff;cursor:pointer;display:flex;height:44px;justify-content:center;position:absolute;right:24px;top:20px;transition:all .3s ease;width:44px}.dark-mode-toggle:hover{background:#ffffff4d;transform:scale(1.1)}.announcement-banner{background:linear-gradient(135deg,#3b82f6,#8b5cf6);color:#fff;margin-top:72px;overflow:hidden;padding:12px 24px}.announcement-content{align-items:center;display:flex;font-size:.875rem;gap:12px;margin:0 auto;max-width:1400px}.announcement-content .sparkle{animation:sparkle 2s ease-in-out infinite;display:inline-block;margin-right:4px}@keyframes sparkle{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.2)}}.announcement-content kbd{background:#fff3;border-radius:4px;font-family:monospace;font-size:.75rem;padding:2px 6px}.dismiss-btn{background:#0000;border:none;border-radius:4px;color:#fff;cursor:pointer;margin-left:auto;padding:4px;transition:background .2s}.dismiss-btn:hover{background:#fff3}.search-section{margin-bottom:32px;margin-top:24px;position:relative;z-index:5}.search-bar{align-items:center;background:#fff;border:2px solid #e2e8f0;border-radius:10px;box-shadow:0 2px 12px #0000000f;display:flex;gap:10px;padding:10px 16px;transition:all .3s ease}.dark-mode .search-bar{background:#fff;background:var(--card-bg);border-color:#e2e8f0;border-color:var(--border-color)}.search-bar:focus-within{border-color:#3b82f6;box-shadow:0 4px 24px #3b82f633}.search-bar svg{color:#64748b;flex-shrink:0}.search-bar input{background:#0000;border:none;color:#0f172a;flex:1 1;font-size:.9375rem;outline:none}.dark-mode .search-bar input{color:#0f172a;color:var(--text-primary)}.search-bar input::placeholder{color:#94a3b8}.clear-btn{align-items:center;background:#f1f5f9;border:none;border-radius:6px;color:#64748b;cursor:pointer;display:flex;justify-content:center;padding:6px;transition:all .2s}.dark-mode .clear-btn{background:#e2e8f0;background:var(--border-color)}.clear-btn:hover{background:#e2e8f0;color:#0f172a}.keyboard-help-btn{align-items:center;background:#0000;border:1px solid #e2e8f0;border-radius:6px;color:#94a3b8;cursor:pointer;display:flex;justify-content:center;padding:6px 8px;transition:all .2s}.dark-mode .keyboard-help-btn{border-color:#e2e8f0;border-color:var(--border-color);color:#64748b}.keyboard-help-btn:hover{background:#f1f5f9;border-color:#3b82f6;color:#3b82f6}.dark-mode .keyboard-help-btn:hover{background:#e2e8f0;background:var(--border-color);border-color:#60a5fa;color:#60a5fa}.keyboard-help-dialog{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0003;max-width:400px;padding:24px;width:90%}.dark-mode .keyboard-help-dialog{background:#fff;background:var(--card-bg);border:1px solid #e2e8f0;border:1px solid var(--border-color)}.keyboard-help-header{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;gap:12px;margin-bottom:20px;padding-bottom:16px}.dark-mode .keyboard-help-header{border-bottom-color:#e2e8f0;border-bottom-color:var(--border-color)}.keyboard-help-header svg{color:#3b82f6}.keyboard-help-header h3{color:#0f172a;flex:1 1;font-size:1.125rem;margin:0}.dark-mode .keyboard-help-header h3{color:#0f172a;color:var(--text-primary)}.keyboard-help-header .close-btn{align-items:center;background:#0000;border:none;border-radius:6px;color:#64748b;cursor:pointer;display:flex;justify-content:center;padding:4px;transition:all .2s}.keyboard-help-header .close-btn:hover{background:#f1f5f9;color:#0f172a}.dark-mode .keyboard-help-header .close-btn:hover{background:#e2e8f0;background:var(--border-color);color:#0f172a;color:var(--text-primary)}.keyboard-shortcuts-list{display:flex;flex-direction:column;gap:12px}.shortcut-item{align-items:center;display:flex;gap:12px}.shortcut-item kbd{background:linear-gradient(180deg,#f8fafc,#e2e8f0);border:1px solid #cbd5e1;border-radius:6px;box-shadow:0 2px 0 #cbd5e1;color:#475569;font-family:inherit;font-size:.8125rem;font-weight:600;min-width:28px;padding:4px 10px;text-align:center}.dark-mode .shortcut-item kbd{background:linear-gradient(180deg,#334155,#1e293b);border-color:#475569;box-shadow:0 2px 0 #1e293b;color:#e2e8f0}.shortcut-item span{color:#475569;font-size:.9375rem}.dark-mode .shortcut-item span{color:#64748b;color:var(--text-secondary)}.keyboard-help-tip{border-top:1px solid #e2e8f0;color:#64748b;font-size:.8125rem;margin-top:20px;padding-top:16px;text-align:center}.dark-mode .keyboard-help-tip{border-top-color:#e2e8f0;border-top-color:var(--border-color);color:var(--text-muted)}.keyboard-help-tip kbd{background:#f1f5f9;border:1px solid #e2e8f0;border-radius:4px;color:#3b82f6;font-family:inherit;font-size:.75rem;font-weight:600;padding:2px 6px}.dark-mode .keyboard-help-tip kbd{background:#e2e8f0;background:var(--border-color);border-color:#475569;color:#60a5fa}.tag-filters{align-items:center;display:flex;flex-wrap:wrap;gap:8px;margin-top:16px}.tag-filters-label{color:#64748b;font-size:.875rem;font-weight:500;margin-right:4px}.dark-mode .tag-filters-label{color:#64748b;color:var(--text-secondary)}.tag-chip{align-items:center;background:#fff;border:2px solid #e2e8f0;border:2px solid var(--tag-color,#e2e8f0);border-radius:20px;color:#64748b;color:var(--tag-color,#64748b);cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:6px;padding:8px 16px;transition:all .2s}.dark-mode .tag-chip{background:#fff;background:var(--card-bg)}.tag-chip:hover{background:#e2e8f0;background:var(--tag-color,#e2e8f0);box-shadow:0 4px 12px #00000026;color:#fff;transform:translateY(-2px)}.tag-icon{font-size:1rem;line-height:1}.tag-logo-wrapper{align-items:center;display:flex;flex-shrink:0;justify-content:center}.tag-logo-svg{display:block}.tag-logo-svg.chevron-tag{height:15px;width:20px}.tag-logo-svg.westlake-tag{height:12px;width:38px}.tag-logo-svg.kuraray-tag{height:11px;width:34px}.tag-logo-svg.tsar-tag{height:13px;width:28px}.dark-mode .tag-logo-svg.westlake-tag text{fill:#4fc3f7}.dark-mode .tag-logo-svg.westlake-tag path{stroke:#4fc3f7}.dark-mode .tag-logo-svg.kuraray-tag text{fill:#4dd0e1}.dark-mode .tag-logo-svg.tsar-tag rect{fill:#5b7fa8}.active-filter{align-items:center;background:linear-gradient(135deg,#eff6ff,#f0f9ff);border:2px solid #3b82f6;border-radius:12px;color:#1e40af;display:flex;font-size:.875rem;gap:8px;margin-top:16px;padding:12px 16px}.dark-mode .active-filter{background:#3b82f61a;border-color:#3b82f6;color:#60a5fa}.active-filter strong{font-weight:600}.clear-filter-btn{align-items:center;background:#dbeafe;border:none;border-radius:50%;color:#1e40af;cursor:pointer;display:flex;height:24px;justify-content:center;margin-left:auto;transition:all .2s;width:24px}.dark-mode .clear-filter-btn{background:#3b82f633;color:#60a5fa}.clear-filter-btn:hover{background:#3b82f6;color:#fff;transform:scale(1.1)}.tag-filters svg{color:#64748b}.tag-filter{background:#fff;border:1px solid #e2e8f0;border-radius:20px;color:#64748b;cursor:pointer;font-size:.875rem;padding:6px 14px;transition:all .2s}.dark-mode .tag-filter{background:#fff;background:var(--card-bg);border-color:#e2e8f0;border-color:var(--border-color);color:#64748b;color:var(--text-secondary)}.tag-filter:hover{border-color:#3b82f6;color:#3b82f6}.tag-filter.active{background:#3b82f6;border-color:#3b82f6;color:#fff}.app-number{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;border-radius:50%;color:#fff;font-size:.75rem;font-weight:600;height:24px;left:12px;width:24px}.app-number,.favorite-btn{align-items:center;display:flex;justify-content:center;position:absolute;top:12px;z-index:2}.favorite-btn{background:#ffffffe6;border:1px solid #e2e8f0;border-radius:50%;color:#94a3b8;cursor:pointer;height:32px;right:12px;transition:all .2s;width:32px}.dark-mode .favorite-btn{background:#1e293be6;border-color:#e2e8f0;border-color:var(--border-color)}.favorite-btn:hover{background:#fff;border-color:#f59e0b;color:#f59e0b;transform:scale(1.1)}.favorite-btn.active{background:#fef3c7;border-color:#f59e0b;color:#f59e0b}.dark-mode .favorite-btn.active{background:#f59e0b33}.card-header-row{justify-content:space-between;margin-bottom:8px}.card-header-row,.info-btn{align-items:center;display:flex}.info-btn{background:#0000;border:1px solid #e2e8f0;border-radius:50%;color:#64748b;cursor:pointer;flex-shrink:0;height:24px;justify-content:center;transition:all .2s;width:24px}.dark-mode .info-btn{border-color:#e2e8f0;border-color:var(--border-color)}.info-btn:hover{background:#f1f5f9;border-color:#3b82f6;color:#3b82f6}.dark-mode .info-btn:hover{background:#e2e8f0;background:var(--border-color)}.app-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px}.app-tag{border:1px solid;border-radius:10px;font-size:.6875rem;font-weight:500;opacity:.8;padding:2px 8px}.last-used{color:#94a3b8;gap:4px;margin-top:8px}.last-used,.status-indicator{align-items:center;display:flex;font-size:.75rem}.status-indicator{color:#64748b;gap:6px;text-transform:capitalize}.status-dot{background:#10b981;border-radius:50%;height:6px;width:6px}.status-indicator.offline .status-dot{background:#ef4444}.status-indicator.degraded .status-dot{background:#f59e0b}.card-footer{align-items:center;border-top:1px solid #f1f5f9;display:flex;justify-content:space-between;margin-top:auto;padding-top:12px}.dark-mode .card-footer{border-color:#e2e8f0;border-color:var(--border-color)}.popular-grid{gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.popular-card{padding:24px 16px!important;text-align:center}.popular-badge{background:linear-gradient(135deg,#f59e0b,#ef4444);border-radius:12px;color:#fff;font-size:.6875rem;font-weight:600;padding:4px 8px;position:absolute;right:8px;top:8px}.recent-grid{gap:16px;grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}.analytics-section{background:linear-gradient(135deg,#3b82f60d,#8b5cf60d);border-radius:16px;margin-bottom:48px;padding:32px}.analytics-icon{background:linear-gradient(135deg,#3b82f6,#8b5cf6)}.favorites-icon{background:linear-gradient(135deg,#f59e0b,#f97316)}.recent-icon{background:linear-gradient(135deg,#10b981,#059669)}.no-results{color:#94a3b8;padding:60px 20px;text-align:center}.no-results p{font-size:1.125rem}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:var(--modal-overlay);padding:20px}.modal-content{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;display:flex;flex-direction:column;max-height:90vh;max-width:600px;overflow:hidden;width:100%}.dark-mode .modal-content{background:#fff;background:var(--card-bg);border:1px solid #e2e8f0;border:1px solid var(--border-color)}.modal-close{align-items:center;background:#ffffffe6;border:1px solid #e2e8f0;border-radius:50%;color:#64748b;cursor:pointer;display:flex;height:36px;justify-content:center;position:absolute;right:16px;top:16px;transition:all .2s;width:36px;z-index:10}.dark-mode .modal-close{background:#1e293be6;border-color:#e2e8f0;border-color:var(--border-color)}.modal-close:hover{background:#fff;color:#ef4444;transform:scale(1.1)}.modal-header{gap:16px;padding:32px;position:relative}.modal-header,.modal-icon{align-items:center;display:flex}.modal-icon{border-radius:16px;color:#fff;flex-shrink:0;height:64px;justify-content:center;width:64px}.modal-header h2{color:#0f172a;font-size:1.5rem;font-weight:600;margin:0}.dark-mode .modal-header h2{color:#0f172a;color:var(--text-primary)}.modal-category{color:#64748b;font-size:.875rem;margin:4px 0 0}.modal-body{overflow-y:auto;padding:0 32px 32px}.modal-info-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(3,1fr);margin-bottom:24px}.info-item{display:flex;flex-direction:column;gap:4px}.info-item label{color:#94a3b8;font-size:.75rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.info-item span{color:#0f172a;font-size:.875rem;font-weight:500}.dark-mode .info-item span{color:#0f172a;color:var(--text-primary)}.status-badge{align-items:center;border-radius:12px;display:inline-flex;font-size:.75rem;font-weight:600;gap:6px;padding:4px 10px;text-transform:capitalize;width:-webkit-fit-content;width:fit-content}.status-badge.online{background:#d1fae5;color:#059669}.status-badge.offline{background:#fee2e2;color:#dc2626}.status-badge.degraded{background:#fef3c7;color:#d97706}.dark-mode .status-badge.online{background:#10b98133;color:#34d399}.dark-mode .status-badge.offline{background:#ef444433;color:#f87171}.dark-mode .status-badge.degraded{background:#f59e0b33;color:#fbbf24}.modal-description{margin-bottom:24px}.modal-description label{color:#94a3b8;display:block;font-size:.75rem;font-weight:600;letter-spacing:.05em;margin-bottom:8px;text-transform:uppercase}.modal-description p{color:#475569;font-size:.9375rem;line-height:1.6;margin:0}.dark-mode .modal-description p{color:#64748b;color:var(--text-secondary)}.modal-tags{display:flex;flex-wrap:wrap;gap:8px}.modal-tag{border:1.5px solid;border-radius:12px;font-size:.8125rem;font-weight:500;padding:6px 12px}.modal-footer{border-top:1px solid #f1f5f9;display:flex;gap:12px;padding:24px 32px}.dark-mode .modal-footer{border-color:#e2e8f0;border-color:var(--border-color)}.btn-primary,.btn-secondary{align-items:center;border-radius:10px;cursor:pointer;display:flex;flex:1 1;font-size:.9375rem;font-weight:600;gap:8px;justify-content:center;padding:12px 20px;transition:all .2s}.btn-secondary{background:#fff;border:2px solid #e2e8f0;color:#475569}.dark-mode .btn-secondary{background:#fff;background:var(--bg-secondary);border-color:#e2e8f0;border-color:var(--border-color);color:#0f172a;color:var(--text-primary)}.btn-secondary:hover{background:#f8fafc;border-color:#cbd5e1}.dark-mode .btn-secondary:hover{background:#e2e8f0;background:var(--border-color)}.btn-primary{background:#3b82f6;border:2px solid #3b82f6;color:#fff}.btn-primary:hover{box-shadow:0 8px 20px #3b82f64d;transform:translateY(-2px)}@media (max-width:900px){.modal-info-grid,.popular-grid{grid-template-columns:1fr}.analytics-section{padding:24px}}@media (max-width:600px){.search-section{margin-top:-20px}.search-bar{padding:12px 16px}.tag-filters{flex-wrap:nowrap;overflow-x:auto;padding-bottom:8px}.modal-header{padding:24px}.modal-body{padding:0 24px 24px}.modal-footer{flex-direction:column;padding:16px 24px}.app-number{display:none}.dark-mode-toggle{height:36px;right:12px;top:12px;width:36px}}.loading-container{align-items:center;display:flex;flex-direction:column;gap:1.5rem;justify-content:center;min-height:60vh}.loading-spinner{animation:spin .8s linear infinite;border:4px solid #006cac1a;border-radius:50%;border-top-color:#006cac;height:50px;width:50px}@keyframes spin{to{transform:rotate(1turn)}}.loading-container p{color:#64748b;font-size:1.1rem}.undo-notification{align-items:center;background:#2d3748;border-radius:8px;box-shadow:0 4px 12px #0000004d;color:#fff;display:flex;gap:1rem;max-width:400px;padding:1rem 1.5rem;position:fixed;right:20px;top:90px;z-index:1001}.undo-notification strong{color:#4299e1}.undo-notification button{background:#4299e1;border:none;border-radius:4px;color:#fff;cursor:pointer;font-weight:600;padding:.5rem 1rem;transition:background .2s}.undo-notification button:hover{background:#3182ce}.modal-overlay{align-items:center;background:#00000080;display:flex;inset:0;justify-content:center;position:fixed;z-index:1000}.confirmation-dialog{background:#fff;border-radius:12px;box-shadow:0 8px 24px #0003;max-width:400px;padding:2rem;width:90%}.landing-page.dark .confirmation-dialog{background:#1e293b;color:#fff}.confirmation-dialog h3{color:#1e293b;font-size:1.5rem;margin:0 0 1rem}.landing-page.dark .confirmation-dialog h3{color:#fff}.confirmation-dialog p{color:#64748b;margin-bottom:1.5rem}.landing-page.dark .confirmation-dialog p{color:#94a3b8}.dialog-actions{display:flex;gap:1rem;justify-content:flex-end}.dialog-actions button{border:none;border-radius:6px;cursor:pointer;font-weight:600;padding:.75rem 1.5rem;transition:all .2s}.cancel-btn{background:#e2e8f0;color:#1e293b}.cancel-btn:hover{background:#cbd5e0}.confirm-btn{background:#e53e3e;color:#fff}.confirm-btn:hover{background:#c53030}.landing-page.dark .cancel-btn{background:#334155;color:#fff}.landing-page.dark .cancel-btn:hover{background:#475569}.controls-bar{flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-top:1.5rem}.controls-bar,.sort-controls{align-items:center;display:flex}.sort-controls{gap:.5rem}.sort-controls label{color:#64748b;font-size:.95rem;font-weight:600}.landing-page.dark .sort-controls label{color:#94a3b8}.sort-controls select{background:#fff;border:2px solid #e2e8f0;border-radius:6px;color:#1e293b;cursor:pointer;font-size:.95rem;padding:.5rem 1rem;transition:all .2s}.sort-controls select:hover{border-color:#006cac}.sort-controls select:focus{border-color:#006cac;box-shadow:0 0 0 3px #006cac1a;outline:none}.landing-page.dark .sort-controls select{background:#1e293b;border-color:#334155;color:#fff}.landing-page.dark .sort-controls select:hover{border-color:#4299e1}.clear-favorites-btn{background:#e53e3e;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:600;padding:.5rem 1rem;transition:all .2s}.clear-favorites-btn:hover{background:#c53030;box-shadow:0 2px 8px #e53e3e4d;transform:translateY(-1px)}.empty-state{color:#64748b;padding:4rem 2rem;text-align:center}.empty-icon{color:#cbd5e0;margin-bottom:1rem}.landing-page.dark .empty-icon{color:#334155}.empty-state h3{color:#1e293b;font-size:1.5rem;margin-bottom:.5rem}.landing-page.dark .empty-state h3{color:#fff}.empty-state p{font-size:1.1rem;margin-bottom:1.5rem}.empty-favorites{align-items:center;animation:pulse-border 2s ease-in-out infinite;background:linear-gradient(135deg,#fef3c7,#fde68a 50%,#fef3c7);border:2px dashed #f59e0b;border-radius:16px;display:flex;flex-direction:column;justify-content:center;padding:3rem 2rem;text-align:center}@keyframes pulse-border{0%,to{border-color:#f59e0b}50%{border-color:#fbbf24}}.dark-mode .empty-favorites{background:linear-gradient(135deg,#f59e0b1a,#fbbf2426 50%,#f59e0b1a);border-color:#d97706}.empty-favorites-icon{align-items:center;animation:bounce-star 2s ease-in-out infinite;background:#fff;border-radius:50%;box-shadow:0 4px 12px #f59e0b33;display:flex;height:64px;justify-content:center;margin-bottom:16px;width:64px}@keyframes bounce-star{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.dark-mode .empty-favorites-icon{background:#fff;background:var(--card-bg)}.empty-favorites-icon svg{color:#f59e0b}.empty-favorites h3{color:#92400e;font-size:1.125rem;font-weight:600;margin:0 0 8px}.dark-mode .empty-favorites h3{color:#fcd34d}.empty-favorites p{color:#b45309;font-size:.875rem;margin:0;max-width:280px}.dark-mode .empty-favorites p{color:#fbbf24}.empty-favorites p svg{color:#f59e0b}.secondary-btn{background:#e2e8f0;border:none;border-radius:6px;color:#1e293b;cursor:pointer;font-weight:600;padding:.75rem 1.5rem;transition:all .2s}.secondary-btn:hover{background:#cbd5e0}.landing-page.dark .secondary-btn{background:#334155;color:#fff}.landing-page.dark .secondary-btn:hover{background:#475569}.sr-only{clip:rect(0,0,0,0);border-width:0;height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}.app-card.selected{border:2px solid #006cac!important;box-shadow:0 4px 12px #006cac4d!important;transform:translateY(-2px)}.landing-page.dark .app-card.selected{border-color:#4299e1!important;box-shadow:0 4px 12px #4299e166!important}@media (max-width:768px){.controls-bar{align-items:stretch;flex-direction:column}.sort-controls{justify-content:space-between}.sort-controls select{flex:1 1}.undo-notification{left:20px;max-width:none;right:20px;top:80px}.confirmation-dialog{margin:0 20px}.dialog-actions{flex-direction:column-reverse}.dialog-actions button{width:100%}}@media (max-width:600px){.empty-state{padding:3rem 1rem}.empty-state h3{font-size:1.25rem}.empty-state p{font-size:1rem}.undo-notification{align-items:stretch;flex-direction:column;text-align:center}.undo-notification button{width:100%}}.collapsible-section-header{align-items:center;background:#0000;border:none;cursor:pointer;display:flex;gap:12px;margin-bottom:20px;padding:0;text-align:left;transition:opacity .2s ease}.collapsible-section-header:hover{opacity:.8}.collapsible-section-header h2{color:#64748b;flex:1 1;font-size:.8125rem;font-weight:700;letter-spacing:.1em;margin:0}.section-count{background:#0000;border:none;color:#94a3b8;font-size:.75rem;font-weight:500;margin-left:.5rem;margin-right:.5rem;padding:0}.workplace-section .workplace-icon{background:linear-gradient(135deg,#f59e0b,#eab308);box-shadow:0 2px 8px #f59e0b33}.toolbox-section .toolbox-icon{background:linear-gradient(135deg,#8b5cf6,#a78bfa);box-shadow:0 2px 8px #8b5cf633}.landing-page.dark .collapsible-section-header h2{color:#94a3b8}.landing-page.dark .section-count{color:#64748b}.loading-screen{align-items:center;background:linear-gradient(180deg,#f9fafb,#eef4ff);display:flex;inset:0;justify-content:center;position:fixed;z-index:9999}.loading-content{align-items:center;display:flex;flex-direction:column;gap:32px}.loading-logo{animation:float 3s ease-in-out infinite;height:auto;width:120px}.loading-logo path{animation:lighten .5s ease-in-out infinite}.loading-logo path:first-child{animation-delay:0s}.loading-logo path:nth-child(2){animation-delay:.125s}.loading-logo path:nth-child(3){animation-delay:.25s}.loading-logo path:nth-child(4){animation-delay:.375s}@keyframes lighten{0%{opacity:1}25%{opacity:.3}50%{opacity:.3}75%{opacity:.3}to{opacity:1}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.loading-text{animation:pulse 2s ease-in-out infinite;color:var(--gray-500);font-size:.9375rem;font-weight:500}.seating-chart-visual{background:#f9fafb;background:var(--background);min-height:100vh;overflow:hidden;padding:70px 24px 6px}.chart-main-layout{grid-gap:24px;align-items:start;display:grid;gap:24px;grid-template-columns:1fr 380px}.chart-header{background:#fff;background:var(--card-bg);border-radius:10px;box-shadow:0 2px 8px #0000000d;flex-wrap:wrap;gap:12px;justify-content:space-between;margin-bottom:6px;padding:6px 16px}.chart-header,.header-left{align-items:center;display:flex}.header-left{gap:16px}.header-icon{color:#1c70f7;color:var(--primary)}.chart-title{color:#111827;color:var(--text-primary);font-size:24px;font-weight:700;margin:0}.chart-subtitle{color:#6b7280;color:var(--text-secondary);font-size:13px;margin:4px 0 0}.building-selector-wrapper{display:inline-block;position:relative}.building-selector-button{align-items:center;background:#f9fafb;background:var(--background);border:2px solid #e5e7eb;border:2px solid var(--border-color);border-radius:8px;cursor:pointer;display:flex;font-family:inherit;gap:10px;min-width:200px;padding:6px 12px;transition:all .2s ease;width:200px}.building-selector-button:hover{background:#fff;background:var(--card-bg);border-color:#1c70f7;border-color:var(--primary)}.building-selector-text{color:#111827;color:var(--text-primary);flex:1 1;font-size:15px;font-weight:600;text-align:left}.dropdown-icon{color:#6b7280;color:var(--text-secondary);flex-shrink:0;transition:all .2s ease}.dropdown-icon.open{transform:rotate(180deg)}.building-selector-button:hover .dropdown-icon{color:#1c70f7;color:var(--primary)}.building-dropdown-menu{animation:slideDown .2s ease;background:#fff;background:var(--card-bg);border:2px solid #e5e7eb;border:2px solid var(--border-color);border-radius:10px;box-shadow:0 8px 24px #0000001f;left:0;min-width:180px;overflow:hidden;position:absolute;top:calc(100% + 8px);z-index:1000}.building-dropdown-item{align-items:center;color:#111827;color:var(--text-primary);cursor:pointer;display:flex;font-size:15px;font-weight:500;gap:12px;padding:12px 16px;transition:all .2s ease}.building-dropdown-item.campus-item{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);font-weight:600}.building-dropdown-item.building-sub-item{font-size:14px;font-weight:400;padding-left:32px}.building-dropdown-item:hover{background:#f9fafb;background:var(--background)}.building-dropdown-item.active{background:#1c70f7;background:var(--primary);color:#fff}.building-dropdown-item.active:hover{background:#1c70f7;background:var(--primary);opacity:.9}.building-dropdown-item svg{color:currentColor;flex-shrink:0}.back-to-home-btn{align-items:center;background:#f9fafb;background:var(--background);border:2px solid #e5e7eb;border:2px solid var(--border-color);border-radius:8px;color:#111827;color:var(--text-primary);cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:6px;padding:6px 12px;transition:all .2s ease}.back-to-home-btn:hover{background:#fff;background:var(--card-bg);border-color:#1c70f7;border-color:var(--primary);color:#1c70f7;color:var(--primary)}.panel-search-container{margin-bottom:16px;position:relative;width:100%}.panel-search-icon{color:#6b7280;color:var(--text-secondary);left:14px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.panel-search-input{background:#f9fafb;background:var(--background);border:2px solid #e5e7eb;border:2px solid var(--border-color);border-radius:10px;color:#111827;color:var(--text-primary);font-size:14px;padding:10px 36px 10px 40px;transition:all .2s ease;width:100%}.panel-search-input:focus{border-color:#1c70f7;border-color:var(--primary);outline:none}.panel-search-clear{align-items:center;background:none;border:none;color:#6b7280;color:var(--text-secondary);cursor:pointer;display:flex;font-size:24px;height:24px;justify-content:center;position:absolute;right:12px;top:50%;transform:translateY(-50%);width:24px}.panel-search-clear:hover{color:#111827;color:var(--text-primary)}.chart-search-container{position:relative;width:380px}.chart-search-icon{color:#6b7280;color:var(--text-secondary);left:14px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.chart-search-input{background:#f9fafb;background:var(--background);border:2px solid #e5e7eb;border:2px solid var(--border-color);border-radius:10px;color:#111827;color:var(--text-primary);font-size:14px;padding:10px 36px 10px 40px;transition:all .2s ease;width:100%}.chart-search-input:focus{border-color:#1c70f7;border-color:var(--primary);outline:none}.search-clear{align-items:center;background:none;border:none;color:#6b7280;color:var(--text-secondary);cursor:pointer;display:flex;font-size:24px;height:24px;justify-content:center;position:absolute;right:12px;top:50%;transform:translateY(-50%);width:24px}.search-results-panel{height:100%;overflow-y:auto}.results-header-panel{align-items:center;border-bottom:2px solid #e5e7eb;border-bottom:2px solid var(--border-color);color:#1c70f7;color:var(--primary);display:flex;font-size:14px;font-weight:600;gap:8px;margin-bottom:20px;padding-bottom:16px}.results-list-panel{display:flex;flex-direction:column;gap:12px}.result-item-panel{background:#f9fafb;background:var(--background);border:2px solid #0000;border-radius:12px;cursor:pointer;padding:16px;transition:all .2s ease}.result-item-panel:hover{border-color:#1c70f7;border-color:var(--primary);box-shadow:0 4px 12px #00000014}.result-item-header{align-items:flex-start;display:flex;gap:12px;margin-bottom:12px}.result-user-icon{color:#1c70f7;color:var(--primary);flex-shrink:0;margin-top:2px}.result-item-content{flex:1 1}.result-item-location{align-items:center;color:#6b7280;color:var(--text-secondary);display:flex;font-size:13px;gap:6px;margin-left:30px}.result-item-location svg{flex-shrink:0}.location-separator{color:#6b7280;color:var(--text-secondary);margin:0 2px}.search-results-sidebar{background:#fff;background:var(--card-bg);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:16px;box-shadow:0 8px 32px #0000001a;left:24px;max-height:600px;overflow-y:auto;padding:16px;position:absolute;top:160px;width:280px;z-index:100}.results-header{align-items:center;color:#1c70f7;color:var(--primary);display:flex;font-size:14px;font-weight:600;gap:8px;margin-bottom:16px}.results-list{display:flex;flex-direction:column;gap:8px}.result-item{align-items:center;background:#f9fafb;background:var(--background);border:2px solid #0000;border-radius:10px;cursor:pointer;display:flex;gap:12px;padding:12px;transition:all .2s ease}.result-item:hover{border-color:#1c70f7;border-color:var(--primary);transform:translateY(-2px)}.result-item svg{color:#1c70f7;color:var(--primary);flex-shrink:0}.result-name{color:#111827;color:var(--text-primary);font-size:14px;font-weight:600;margin-bottom:4px}.result-loc{align-items:center;display:flex;font-size:12px;gap:4px}.result-loc,.result-loc svg{color:#6b7280;color:var(--text-secondary)}.floor-plan-section{display:flex;flex-direction:column;gap:16px;height:calc(100vh - 150px);min-width:0}.campus-overview-wrapper{background:#fff;background:var(--card-bg);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:16px;overflow:hidden;padding:16px}.campus-overview,.campus-overview-wrapper{align-items:center;display:flex;height:100%;justify-content:center}.campus-overview{position:relative;width:100%}.campus-image-container{display:inline-block;position:relative}.campus-overview-image{border-radius:8px;display:block;max-height:calc(100vh - 300px);max-width:100%;object-fit:contain}.campus-zone{background:#3b82f659;border:3px solid #3b82f699;border-radius:8px;cursor:pointer;position:absolute;transform-origin:center;transition:all .3s ease}.campus-zone:hover{background:#3b82f68c;border-color:#3b82f6e6;box-shadow:0 6px 20px #3b82f680;transform:scale(1.05)}.floor-plan-wrapper{align-items:center;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:16px;display:flex;height:100%;justify-content:center;overflow:hidden;padding:16px}.floor-plan,.floor-plan-wrapper{background:#fff;background:var(--card-bg)}.floor-plan{min-width:auto;position:relative}.wall{background:#393c44;background:var(--wall-color);border:none;pointer-events:none;z-index:10}.wall.door{background:#0000;border:2px dashed #393c44;border:2px dashed var(--wall-color)}.room{align-items:center;background:#e0f2fe4d;border:2px solid #0000;border-radius:6px;cursor:pointer;display:flex;flex-direction:column;justify-content:flex-start;overflow:hidden;padding:6px 8px 8px;transition:all .2s ease;z-index:2}.room.office{background:#dbeafe66}.room.warehouse{background:#f3e8ff66}.room.storage{background:#fef3c766}.room:hover{background:#dbeafe99}.room.highlighted{animation:pulse 1.5s infinite;background:#fee2e2d9;border:3px solid #dc2626}@keyframes pulse{0%,to{border-color:#dc2626;box-shadow:0 0 0 4px #dc262680}50%{border-color:#ef4444;box-shadow:0 0 0 14px #dc262699}}.room-label{color:#1c70f7;color:var(--primary);font-size:11px;font-weight:700;margin-bottom:4px;text-align:center}.room-people{align-items:stretch;display:flex;flex:1 1;flex-direction:column;gap:2px;width:100%}.person-tag{align-items:center;background:#fff;background:var(--card-bg);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:4px;color:#1c70f7;color:var(--primary);cursor:pointer;display:flex;font-size:9px;font-weight:600;gap:3px;min-width:0;overflow:hidden;padding:3px 5px;text-overflow:ellipsis;transition:all .2s ease;white-space:nowrap}.person-tag svg{flex-shrink:0;height:10px;width:10px}.person-tag:hover{background:#1c70f7;background:var(--primary);color:#fff;color:var(--card-bg)}.person-tag.more{background:#f9fafb;background:var(--background);color:#1c70f7;color:var(--primary)}.cube{align-items:center;background:#bbf7d080;border:2px solid #22c55e99;border-radius:6px;box-shadow:0 1px 3px #0000001a;cursor:pointer;display:flex;flex-direction:column;justify-content:flex-start;overflow:visible;padding:2px;transition:all .2s ease;z-index:2}.cube:hover{background:#bbf7d0b3;border-color:#22c55ecc;box-shadow:0 2px 6px #00000026}.cube.highlighted{animation:pulse 1.5s infinite;background:#fee2e2d9;border-color:#dc2626;box-shadow:inset 0 0 0 3px #dc2626}.cube.empty{background:#e5e7eb4d;border-color:#9ca3af66;cursor:default}.cube.empty:hover{background:#e5e7eb66;border-color:#9ca3af80}.cube-label{color:#22c55ee6;font-size:9px;font-weight:700;margin-bottom:1px;text-align:center}.cube.empty .cube-label{color:#9ca3af99;margin-bottom:0}.cube-people{align-items:center;display:flex;flex:1 1;flex-direction:column;gap:1px;justify-content:center;overflow:visible;width:100%}.cube-person-name{color:#111827;color:var(--text-primary);font-size:8px;font-weight:600;line-height:1.2;max-width:none;overflow:visible;text-align:center;white-space:nowrap}.conference-room{align-items:center;background:#fbbf2440;border:none;border-radius:0;cursor:pointer;display:flex;flex-direction:column;justify-content:flex-start;overflow:hidden;padding:8px;transition:all .2s ease;z-index:2}.conference-room:hover{background:#fbbf2466}.conference-room.highlighted{animation:pulse 1.5s infinite;background:#fee2e299;box-shadow:inset 0 0 0 2px #ef4444}.conference-room-label{color:#b45309e6;font-size:10px;font-weight:700;line-height:1.2;margin-bottom:6px;text-align:center}.facility{align-items:center;background:#e5e7eb99;border:none;border-radius:6px;display:flex;justify-content:center;overflow:hidden;z-index:2}.facility-coffee,.facility-gym,.facility-printer{background:#c4b5fd80;border:2px solid #8b5cf699}.facility-icon{color:#6d28d9e6;flex-shrink:0}.facility-label{word-wrap:break-word;color:#4b5563f2;font-size:9px;font-weight:700;letter-spacing:.3px;line-height:1.3;max-width:100%;overflow-wrap:break-word;padding:2px 4px;text-align:center;text-transform:capitalize;white-space:pre-wrap}.info-panel{background:#fff;background:var(--card-bg);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:16px;height:calc(100vh - 150px);overflow-x:hidden;overflow-y:auto;padding:24px;top:120px}.info-panel::-webkit-scrollbar{width:8px}.info-panel::-webkit-scrollbar-track{background:#0000}.info-panel::-webkit-scrollbar-thumb{background:#e5e7eb;background:var(--border-color);border-radius:4px}.info-panel::-webkit-scrollbar-thumb:hover{background:#6b7280;background:var(--text-secondary)}.no-selection{align-items:center;color:#6b7280;color:var(--text-secondary);display:flex;flex-direction:column;gap:16px;justify-content:center;padding:60px 20px;text-align:center}.no-selection svg{color:#e5e7eb;color:var(--border-color)}.person-details{text-align:center}.details-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:24px}.details-header h3{font-size:16px;font-weight:600;margin:0}.close-details-btn,.details-header h3{color:#111827;color:var(--text-primary)}.close-details-btn{align-items:center;background:#f9fafb;background:var(--background);border:none;border-radius:8px;cursor:pointer;display:flex;font-size:24px;height:32px;justify-content:center;transition:all .2s ease;width:32px}.close-details-btn:hover{background:#e5e7eb;background:var(--border-color);transform:rotate(90deg)}.details-avatar{align-items:center;background:linear-gradient(135deg,#3b82f6,#2563eb);border-radius:50%;color:#fff;display:flex;height:80px;justify-content:center;margin:0 auto 16px;width:80px}.details-name{color:#111827;color:var(--text-primary);font-size:24px;font-weight:700;margin:0 0 4px}.details-title{color:#6b7280;color:var(--text-secondary);font-size:14px;margin:0 0 24px}.details-info{display:flex;flex-direction:column;gap:16px;text-align:left}.info-row{align-items:center;background:#f9fafb;background:var(--background);border-radius:10px;display:flex;gap:12px;padding:12px}.info-row svg{color:#1c70f7;color:var(--primary);flex-shrink:0}.info-row a,.info-row span{color:#111827;color:var(--text-primary);font-size:14px;text-decoration:none}.info-row a:hover{color:#1c70f7;color:var(--primary);text-decoration:underline}.book-room-btn{align-items:center;background:#1c70f7;background:var(--primary);border:none;border-radius:10px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;justify-content:center;margin-top:20px;padding:12px 20px;transition:all .2s ease;width:100%}.book-room-btn:hover{background:#1c70f7e6;box-shadow:0 4px 12px #1c70f74d;transform:translateY(-1px)}.book-room-btn svg{flex-shrink:0}.dark-mode .book-room-btn{background:#1c70f7;background:var(--primary)}.dark-mode .book-room-btn:hover{background:#a1bae4e6;box-shadow:0 4px 12px #a1bae44d}.room-details{text-align:left}.room-header{align-items:center;background:#f9fafb;background:var(--background);border-radius:12px;display:flex;gap:16px;margin-bottom:24px;padding:16px}.room-icon{color:#1c70f7;color:var(--primary)}.room-name{color:#111827;color:var(--text-primary);font-size:24px;font-weight:700;margin:0}.room-people-list{margin-top:16px}.room-people-list h4{border-bottom:2px solid #e5e7eb;border-bottom:2px solid var(--border-color);color:#6b7280;color:var(--text-secondary);font-size:14px;font-weight:600;margin:0 0 12px;padding-bottom:8px}.room-person-item{align-items:center;background:#f9fafb;background:var(--background);border:2px solid #0000;border-radius:10px;cursor:pointer;display:flex;gap:12px;margin-bottom:8px;padding:12px;transition:all .2s ease}.room-person-item:hover{border-color:#1c70f7;border-color:var(--primary);transform:translateX(4px)}.room-person-item svg{color:#1c70f7;color:var(--primary);flex-shrink:0}.person-item-name{color:#111827;color:var(--text-primary);font-size:14px;font-weight:600;margin-bottom:2px}.person-item-title{color:#6b7280;color:var(--text-secondary);font-size:12px}:root{--primary:#1c70f7;--background:#f9fafb;--card-bg:#fff;--text-primary:#111827;--text-secondary:#6b7280;--border-color:#e5e7eb;--wall-color:#393c44}.dark-mode{--primary:#a1bae4;--background:#0f172a;--card-bg:#1e293b;--text-primary:#f1f5f9;--text-secondary:#94a3b8;--border-color:#334155;--wall-color:#393c44}.dark-mode .facility{background:#47556966}.dark-mode .facility-label{color:#cbd5e1e6}.dark-mode .facility-coffee,.dark-mode .facility-gym,.dark-mode .facility-printer{background:#8b5cf64d;border-color:#a78bfa99}.dark-mode .facility-icon{color:#c4b5fdf2}.dark-mode .cube{background:#22c55e33;border-color:#22c55e80}.dark-mode .cube:hover{background:#22c55e4d;border-color:#22c55eb3}.dark-mode .cube-label{color:#86efacf2}.dark-mode .cube.empty .cube-label{color:#94a3b8b3}.dark-mode .conference-room-label{color:#fbbf24f2}@media (max-width:1400px){.chart-main-layout{grid-template-columns:1fr 320px}}@media (max-width:1200px){.chart-main-layout{grid-template-columns:1fr}.info-panel{max-height:500px;position:relative;top:0}.search-results-sidebar{margin-bottom:24px;max-height:300px;position:static;width:100%}}@media (max-width:768px){.seating-chart-visual{padding:70px 12px 12px}.chart-header{align-items:center;flex-direction:row;flex-wrap:wrap;gap:12px;padding:8px 12px}.header-left{gap:12px}.header-icon{display:none}.building-selector-button{font-size:16px;min-width:140px;padding:8px 12px}.building-selector-text{font-size:16px}.back-to-home-btn{flex:1 1;font-size:13px;justify-content:center;padding:8px 12px}.chart-main-layout{gap:16px;grid-template-columns:1fr}.floor-plan-section{min-height:50vh;order:1}.info-panel{max-height:none;order:2;width:100%}.floor-plan-wrapper{align-items:center;display:flex;justify-content:center;min-height:50vh;padding:12px}.floor-plan{max-width:100%!important}.panel-search-container{margin-bottom:12px}.panel-search-input{font-size:16px;padding:10px 36px 10px 40px}.search-results-panel{max-height:40vh;overflow-y:auto}.result-item-panel{padding:12px}.result-item-header{gap:10px}.result-name{font-size:14px}.result-title{font-size:12px}.result-item-location{font-size:12px;margin-left:28px}.person-details,.room-details{padding:16px}.details-name{font-size:20px}.details-title,.info-row{font-size:14px}.room-label{font-size:8px;margin-bottom:2px}.room-people{gap:2px}.person-tag{font-size:7px;gap:3px;padding:2px 4px}.person-tag svg{flex-shrink:0;height:10px;width:10px}.no-selection{padding:40px 20px}.no-selection p{font-size:14px}}@media (max-width:480px){.seating-chart-visual{padding:70px 8px 8px}.chart-header{gap:8px;padding:8px}.building-selector-button{font-size:14px;min-width:120px}.building-selector-text{font-size:14px}.back-to-home-btn{font-size:12px;padding:6px 10px}.back-to-home-btn svg{height:16px;width:16px}.floor-plan-section{min-height:45vh}.floor-plan-wrapper{min-height:45vh;padding:8px}.info-panel{padding:12px}.panel-search-input{padding:8px 32px 8px 36px}.room-label{font-size:7px;margin-bottom:2px}.room-people{gap:1px}.person-tag{font-size:6px;gap:2px;padding:2px 4px}.person-tag svg{flex-shrink:0;height:9px;width:9px}}.navbar{background:#000;border-bottom:none;height:72px;left:0;position:fixed;right:0;top:0;z-index:1000}.navbar-container{height:100%;justify-content:space-between;margin:0 auto;padding:0 24px;width:100%}.navbar-container,.navbar-logo{align-items:center;display:flex}.navbar-logo{text-decoration:none}.logo-image{height:36px;width:auto}.logo-text{color:#fff;font-size:1.1rem;font-weight:500;letter-spacing:.05em;margin:0;position:relative}.logo-text:after{background:linear-gradient(90deg,#3b82f6,#8b5cf6);bottom:-2px;content:"";height:2px;left:0;opacity:0;position:absolute;transition:opacity .3s ease;width:100%}.navbar-logo:hover .logo-text:after{opacity:1}.navbar-actions{align-items:center;display:flex;gap:8px}.dark-mode-toggle-nav{align-items:center;background:#0000;border:1px solid #fff3;border-radius:8px;color:#ffffffb3;cursor:pointer;display:flex;height:40px;justify-content:center;transition:all .2s ease;width:40px}.dark-mode-toggle-nav:hover{background:#ffffff1a;border-color:#fff6;color:#fff;transform:scale(1.05)}.dark-mode .dark-mode-toggle-nav{background:#ffffff1a;color:#fcd34d}.help-dropdown{position:relative}.help-button{align-items:center;background:#0000;border:none;border-radius:8px;color:#ffffffb3;cursor:pointer;display:flex;height:40px;justify-content:center;transition:all .15s ease;width:40px}.help-button:hover{background:#ffffff1a;color:#fff}.help-overlay{inset:0;position:fixed;z-index:999}.help-menu{animation:slideDown .15s ease;background:#fff;border:1px solid #eaecf0;border-radius:10px;box-shadow:0 12px 28px #1018281f;overflow:hidden;position:absolute;right:0;top:calc(100% + 8px);width:200px;z-index:1000}.help-menu-item{align-items:center;background:#0000;border:none;color:#344054;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:10px;padding:12px 16px;transition:all .1s ease;width:100%}.help-menu-item:hover{background:#f9fafb;color:#111827}.help-menu-item svg{color:#6b7280}.help-menu-item:hover svg{color:#4f46e5}.login-button{background:#0000;border:1px solid #ffffff4d;border-radius:8px;color:#fff;cursor:pointer;font-size:.875rem;font-weight:500;padding:10px 20px;transition:all .15s ease}.login-button:hover{background:#ffffff1a;border-color:#ffffff80}.profile-dropdown{position:relative}.profile-trigger{align-items:center;background:#0000;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;gap:8px;padding:8px 12px;transition:all .15s ease}.profile-trigger:hover{background:#ffffff1a}.profile-avatar{border-radius:50%;height:28px;object-fit:cover;width:28px}.profile-name{color:#ffffffe6;font-size:.875rem;font-weight:400}.chevron{opacity:.7;transition:transform .2s ease}.chevron.rotated{transform:rotate(180deg)}.profile-overlay{inset:0;position:fixed;z-index:999}.profile-menu{animation:slideDown .2s ease;background:#fff;border:1px solid #eaecf0;border-radius:12px;box-shadow:0 20px 40px #10182826;overflow:hidden;position:absolute;right:0;top:calc(100% + 8px);width:280px;z-index:1000}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.profile-header{align-items:center;display:flex;gap:12px;padding:16px}.profile-menu-avatar{border-radius:50%;height:40px;object-fit:cover;width:40px}.profile-menu-avatar-placeholder{align-items:center;background:#f2f4f7;border-radius:50%;color:#667085;display:flex;height:40px;justify-content:center;width:40px}.profile-info{display:flex;flex-direction:column;min-width:0}.profile-menu-name{color:#101828;font-size:.875rem;font-weight:600}.profile-menu-email,.profile-menu-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-menu-email{color:#667085;font-size:.8125rem}.profile-divider{background:#eaecf0;height:1px}.profile-menu-item{align-items:center;background:#0000;border:none;color:#344054;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:12px;padding:12px 16px;transition:all .15s ease;width:100%}.profile-menu-item:hover{background:#f9fafb}.profile-menu-item.logout{color:#d92d20}.profile-menu-item.logout:hover{background:#fef3f2}.mobile-toggle{background:#0000;border:none;color:#fff;cursor:pointer;display:none;padding:8px}.mobile-menu{background:#101828;border-top:1px solid #ffffff1a;display:none;padding:16px}.mobile-login-button{background:#0000;border:1px solid #ffffff4d;border-radius:8px;color:#fff;cursor:pointer;font-size:.875rem;font-weight:500;padding:12px;width:100%}@media (max-width:768px){.navbar{height:64px}.profile-name{display:none}.mobile-menu,.mobile-toggle{display:block}.navbar-container{padding:0 16px}}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f9fafb;color:#101828;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:16px;line-height:1.6}.app{min-height:100vh}h1,h2,h3,h4,h5,h6{color:#101828;font-weight:600;line-height:1.2}p{color:#475467}a{color:#3b82f6;text-decoration:none}a:hover{color:#2563eb}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
/*# sourceMappingURL=main.bf7af447.css.map*/