.header{left:0;padding:20px 0;position:fixed;right:0;top:0;transition:all .3s ease;z-index:1000}.header.scrolled{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#1a1a2ef2;box-shadow:0 2px 20px #0000004d;padding:15px 0}.header-container{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1200px;padding:0 20px}.header-brand{left:50%;position:absolute;transform:translateX(-50%)}.header-brand .brand-logo{color:#fff;font-size:4rem;font-weight:800;letter-spacing:2px}.header-brand .brand-dev{color:#e94560}.logo-wrapper{gap:12px}.logo,.logo-wrapper{align-items:center;display:flex}.logo{color:#fff;font-size:1.76rem;font-weight:700;gap:20px;letter-spacing:1px;text-decoration:none}.logo-icon{height:80px;object-fit:contain;width:80px}.logo span{color:var(--text-primary)}.header-username{background:var(--border-color);border:1px solid var(--border-accent);border-radius:15px;color:#d8e0e8;font-size:.95rem;font-weight:500;padding:4px 12px}.nav-list{display:flex;gap:40px;list-style:none}.nav-list a{color:#fff;font-size:1.15rem;font-weight:500;position:relative;text-decoration:none;transition:color .3s ease}.nav-list a:after{bottom:-5px;content:"";height:2px;left:0;position:absolute;transition:width .3s ease;width:0}.nav-list a:hover{color:var(--text-primary)}.nav-list a:hover:after{width:100%}.nav-list .nav-login,.nav-list .nav-logout{border-radius:20px;font-size:.95rem;padding:8px 20px}.nav-list .nav-login{background:linear-gradient(135deg,#4a9eff,#3a7bd5);color:#fff!important}.nav-list .nav-login:hover{background:linear-gradient(135deg,#5aafff,#4a8be5);color:#fff!important}.nav-list .nav-login:after,.nav-list .nav-logout:after{display:none}.nav-list .nav-logout{background:var(--border-color);border:1px solid var(--border-accent);color:var(--accent-primary)!important}.nav-list .nav-logout:hover{background:var(--border-accent)}.mobile-menu-btn{background:#0000;border:none;cursor:pointer;display:none;flex-direction:column;height:21px;justify-content:space-between;padding:0;width:30px}.mobile-menu-btn span{background:#fff;border-radius:3px;display:block;height:3px;transition:all .3s ease;width:100%}.mobile-menu-btn.active span:first-child{transform:rotate(45deg) translate(5px,5px)}.mobile-menu-btn.active span:nth-child(2){opacity:0}.mobile-menu-btn.active span:nth-child(3){transform:rotate(-45deg) translate(7px,-6px)}@media (max-width:768px){.mobile-menu-btn{display:flex}.header-brand .brand-logo{font-size:1.5rem}.logo{gap:8px}.logo-icon{height:28px;width:28px}.nav{background:#1a1a2efa;left:0;max-height:0;overflow:hidden;padding:0;position:fixed;right:0;top:70px;transition:all .3s ease}.nav.open{max-height:300px;padding:20px 0}.nav-list{align-items:center;flex-direction:column;gap:20px}.nav-list a{font-size:1.1rem}}@media (max-width:576px){.logo-wrapper{display:flex}.logo-icon{height:22px;width:22px}.header-brand .brand-logo{font-size:1.3rem}}.hero{align-items:center;display:flex;flex-direction:column;justify-content:flex-start;min-height:100vh;overflow:hidden;padding:160px 20px 80px;position:relative}.hero-background{z-index:0}.hero-background,.hero-particles{bottom:0;left:0;position:absolute;right:0;top:0}.hero-particles{background:#0000}.hero-top{margin-bottom:30px;margin-top:25px}.hero-bottom-text,.hero-top{display:flex;justify-content:center;max-width:1400px;position:relative;width:100%;z-index:1}.hero-bottom-text{margin-top:30px}.hero-text{animation:fadeInUp .8s ease;text-align:center}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.hero-greeting{color:#fff;font-size:1.2rem;font-weight:500;margin-bottom:15px}.hero-greeting .highlight-dev{color:var(--text-primary)}.hero-name{color:#fff;font-size:1.4rem;font-weight:700;line-height:1.2;margin-bottom:15px;white-space:nowrap}.brand-logo{color:#fff;font-size:2.5rem;font-weight:800;letter-spacing:2px}.brand-dev{color:#e94560}.name-highlight{-webkit-text-fill-color:#0000;background:var(--accent-gradient);-webkit-background-clip:text;background-clip:text}.solution-title-row{align-items:center;display:inline-flex;justify-content:center}.solution-link-icon{align-items:center;cursor:pointer;display:inline-flex;margin-left:12px;text-decoration:none;transition:transform .3s ease}.solution-link-icon:hover{transform:scale(1.2)}.solution-link-icon .hand-icon{animation:pointBounce 1.5s ease-in-out infinite;font-size:1.8rem}@keyframes pointBounce{0%,to{transform:translateX(0)}50%{transform:translateX(8px)}}.hero-tagline{color:var(--text-primary);font-size:1.3rem;font-weight:500;letter-spacing:.5px;margin-bottom:5px}.hero-tagline-sub{color:#e0e8f0;letter-spacing:.3px}.hero-subtitle,.hero-tagline-sub{font-size:1.1rem;font-weight:400;margin-bottom:10px}.hero-subtitle{color:#fff}.hero-subtitle-vision{color:var(--text-primary);font-size:1.1rem;font-weight:500;line-height:1.6;margin-bottom:20px}.hero-description{color:#e0e8f0;font-size:1.1rem;line-height:1.8;margin-bottom:35px}.hero-buttons{gap:20px}.hero-bottom,.hero-buttons{display:flex;justify-content:center}.hero-bottom{align-items:center;animation:fadeInUp .8s ease .3s both;flex-direction:column;gap:30px;max-width:1400px;position:relative;width:100%;z-index:1}.tech-showcase{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:16px;box-shadow:0 20px 60px #0006;max-width:1240px;overflow:hidden;padding:0;width:100%}.showcase-tabs{background:#0000004d;border-bottom:1px solid var(--border-accent);display:flex}.showcase-tab{background:#0000;border:none;border-radius:4px 4px 0 0;color:#64748b;cursor:pointer;flex:1 1;font-size:.85rem;font-weight:600;letter-spacing:1px;padding:15px 20px;position:relative;text-transform:uppercase;transition:all .3s ease}.showcase-tab:hover{background:var(--border-color);color:var(--text-primary);transform:translateY(-2px)}.showcase-tab:not(.active):hover:after{background:var(--accent-gradient);bottom:0;content:"";height:2px;left:20%;opacity:.5;position:absolute;right:20%}.showcase-tab.active{background:var(--border-color);color:var(--text-primary)}.showcase-tab.active:after{background:var(--accent-gradient);bottom:0;content:"";height:3px;left:0;position:absolute;right:0}.showcase-tab.mes-tab{flex:1.2 1;font-size:1.02rem;padding:18px 24px}@media (max-width:576px){.showcase-tabs{-webkit-overflow-scrolling:touch;-ms-overflow-style:none;flex-wrap:nowrap;overflow-x:auto;scrollbar-width:none}.showcase-tabs::-webkit-scrollbar{display:none}.showcase-tab{flex:1 1 auto;font-size:.65rem;line-height:1.2;min-width:70px;padding:10px 8px;text-align:center;white-space:normal}.showcase-tab.mes-tab{font-size:.7rem;min-width:70px;padding:10px 8px}}.showcase-content{padding:20px}.simulation-tab-group{background:#0003;border:1px solid var(--border-accent);border-radius:12px;margin-bottom:20px;margin-top:25px;max-width:1240px;overflow:hidden;width:100%}.simulation-tabs{background:#0000004d;border-bottom:1px solid var(--border-accent);display:flex}.simulation-tab{background:#0000;border:none;border-radius:4px 4px 0 0;color:#64748b;cursor:pointer;font-size:.9rem;font-weight:600;padding:12px 24px;position:relative;transition:all .3s ease}.simulation-tab.active,.simulation-tab:hover{background:var(--border-color);color:var(--text-primary)}.simulation-tab.active:after{background:linear-gradient(90deg,#f97316,#ef4444);bottom:0;content:"";height:3px;left:0;position:absolute;right:0}.simulation-content{overflow:hidden;padding:15px}@media (max-width:576px){.simulation-tab-group{margin-top:15px}.simulation-tab{font-size:.8rem;padding:10px 16px}.simulation-content{overflow:hidden;padding:10px}}.showcase-panel{display:flex;flex-direction:column;gap:15px}.showcase-netexample{background:#050810;border-radius:12px;height:930px;overflow:hidden;width:100%}.showcase-netexample .topology-d3-container{background:#0000;border:none;height:100%;padding:10px}.showcase-netexample .topology-d3-container svg{height:100%;width:100%}.showcase-dlvision{height:620px;overflow-y:auto}.vision-content-wrapper{gap:15px}.vision-content-wrapper,.vision-video-section{display:flex;flex-direction:column}.vision-video-section video{border-radius:8px;height:auto;width:100%}.vision-support-text{background:var(--border-color);border:1px solid var(--border-accent);border-radius:8px;color:var(--text-primary);font-size:1rem;font-weight:600;margin-top:12px;padding:10px 15px;text-align:center}.vision-tech-section{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(4,1fr)}.tech-category-box{background:#ffffff0d;border:1px solid #ffffff1a;border-radius:8px;padding:10px}.tech-category-box.highlight{background:var(--border-color);border-color:var(--border-accent)}.tech-category-box h5{border-bottom:1px solid var(--border-accent);color:var(--text-primary);font-size:.8rem;margin-bottom:6px;padding-bottom:5px}.tech-category-box ul{list-style:none;margin:0;padding:0}.tech-category-box li{color:silver;font-size:.7rem;padding:2px 0 2px 10px;position:relative}.tech-category-box li:before{color:var(--text-primary);content:"•";left:0;position:absolute}@media (max-width:900px){.vision-tech-section{grid-template-columns:repeat(2,1fr)}}@media (max-width:576px){.vision-tech-section{grid-template-columns:1fr}}.showcase-coming-soon{align-items:center;background:#0003;border-radius:12px;display:flex;flex-direction:column;height:620px;justify-content:center;padding:40px;text-align:center;width:100%}.showcase-coming-soon .coming-soon-icon{animation:pulse 2s ease-in-out infinite;font-size:4rem;margin-bottom:20px}.showcase-coming-soon h3{color:#fff;font-size:1.8rem;font-weight:700;margin-bottom:15px}.showcase-coming-soon .coming-soon-text{color:var(--text-primary);font-size:2rem;font-weight:700;margin-bottom:20px;text-shadow:0 0 20px var(--border-accent)}.showcase-coming-soon .coming-soon-desc{color:#e0e8f0;font-size:1rem;line-height:1.6}.showcase-ethercat{background:#0003;border-radius:12px;display:flex;flex-direction:column;height:620px;overflow-y:auto;padding:30px;width:100%}.ethercat-header{margin-bottom:25px;text-align:center}.ethercat-header h3{color:#fff;font-size:1.6rem;margin:10px 0}.ethercat-info{flex:1 1}.ethercat-intro{color:#e0e8f0;font-size:1rem;margin-bottom:25px;text-align:center}.cost-comparison{background:#ffffff0d;border-radius:10px;margin-bottom:20px;padding:20px}.cost-comparison h4{color:var(--text-primary);font-size:1rem;margin-bottom:15px;text-align:center}.cost-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(3,1fr)}.cost-item{align-items:center;border-radius:8px;display:flex;flex-direction:column;padding:15px 10px;text-align:center}.cost-item.high{background:#ef444426;border:1px solid #ef44444d}.cost-item.mid{background:#fbbf2426;border:1px solid #fbbf244d}.cost-item.low{background:#22c55e26;border:1px solid #22c55e4d}.cost-label{font-size:.85rem;font-weight:700;margin-bottom:5px}.cost-item.high .cost-label{color:#ef4444}.cost-item.mid .cost-label{color:#fbbf24}.cost-item.low .cost-label{color:#22c55e}.cost-brand{color:#d0d8e0;font-size:.75rem;margin-bottom:8px}.cost-price{color:#fff;font-size:.9rem;font-weight:600}.our-solution{background:linear-gradient(135deg,var(--border-accent),var(--border-color));border:1px solid var(--border-accent);border-radius:10px;padding:20px;text-align:center}.our-solution h4{color:var(--text-primary);font-size:1.1rem;margin-bottom:10px}.our-solution p{color:#d0d0d0;font-size:.95rem;line-height:1.5}.our-solution strong{color:var(--text-primary);font-size:1.1rem}.showcase-3d-area{background:#0000004d;border-radius:12px;height:280px;overflow:hidden;position:relative;width:100%}.showcase-3d-area.showcase-3d-full{height:350px}.showcase-3d-placeholder{align-items:center;background:radial-gradient(circle at 30% 70%,var(--border-color) 0,#0000 50%),radial-gradient(circle at 70% 30%,#3b82f61a 0,#0000 50%);display:flex;flex-direction:column;gap:10px;height:100%;justify-content:center;width:100%}.placeholder-icon{font-size:48px;opacity:.8}.placeholder-text{color:#fff;font-size:18px;font-weight:600}.placeholder-subtext{color:#64748b;font-size:12px}.showcase-tech-list{border-top:1px solid #ffffff0d;display:flex;gap:15px;justify-content:center;padding:10px 0}.tech-item-small{align-items:center;background:#ffffff08;border-radius:8px;cursor:pointer;display:flex;flex-direction:column;gap:5px;padding:8px 12px;transition:all .3s ease}.tech-item-small:hover{background:var(--border-color);transform:translateY(-2px)}.tech-logo-small{background:#fffffff2;border-radius:8px;height:40px;object-fit:contain;padding:5px;width:40px}.tech-name-small{color:#d8e0e8;font-size:.65rem;text-align:center}.showcase-tech-grid{display:flex;flex-direction:column;gap:20px;padding:10px 0}.showcase-tech-grid .tech-category{margin-bottom:0}.showcase-tech-grid .tech-category h4{border-bottom:1px solid var(--border-accent);color:var(--text-primary);font-size:.8rem;letter-spacing:1.5px;margin-bottom:10px;padding-bottom:6px;text-transform:uppercase}.showcase-tech-grid .tech-items{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(4,1fr)}.showcase-tech-grid .tech-item{align-items:center;background:#ffffff08;border-radius:8px;display:flex;flex-direction:column;gap:4px;padding:8px 6px;transition:all .3s ease}.showcase-tech-grid .tech-item:hover{background:var(--border-color);transform:translateY(-2px)}.showcase-tech-grid .tech-logo-img{background:#fffffff2;border-radius:8px;height:45px;object-fit:contain;padding:6px;width:45px}.showcase-tech-grid .tech-name{color:#d8e0e8;font-size:.6rem;text-align:center}.tech-category{margin-bottom:20px}.tech-category:last-child{margin-bottom:0}.tech-category h4{border-bottom:1px solid var(--border-accent);color:var(--text-primary);font-size:.85rem;letter-spacing:2px;margin-bottom:12px;padding-bottom:8px;text-transform:uppercase}.tech-items{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(4,1fr)}.tech-item{align-items:center;background:#ffffff08;border-radius:10px;display:flex;flex-direction:column;gap:6px;padding:10px 8px;transition:all .3s ease}.tech-item:hover{background:var(--border-color);transform:translateY(-3px)}.tech-logo-img{background:#fffffff2;border-radius:10px;height:65px;object-fit:contain;padding:8px;width:65px}.tech-name{color:#d8e0e8;font-size:.7rem;text-align:center}.phone-simulator{align-items:center;display:flex;flex-direction:column;flex-shrink:0;gap:15px}.phone-frame{background:linear-gradient(145deg,#0a1a30,#001020);border-radius:40px;box-shadow:0 25px 50px #00000080,inset 0 1px 1px #ffffff1a;height:560px;padding:10px;width:280px}.phone-screen{background:#001030;border-radius:32px;display:flex;flex-direction:column;height:100%;overflow:hidden;position:relative;width:100%}.phone-status-bar{align-items:center;background:#0000004d;color:#fff;display:flex;font-size:11px;justify-content:space-between;padding:10px 18px}.phone-time{font-weight:600}.phone-status-icons{align-items:center;display:flex;font-size:10px;gap:8px}.phone-status-icons .signal{font-size:8px;letter-spacing:-2px}.phone-status-icons .battery{color:#4ade80}.phone-notification{animation:slideDown .3s ease;background:#001030f2;border-radius:14px;box-shadow:0 8px 25px #0006;left:10px;padding:12px;position:absolute;right:10px;top:45px;z-index:10}@keyframes slideDown{0%{opacity:0;transform:translateY(-100%)}to{opacity:1;transform:translateY(0)}}.notif-title{color:#fff;font-size:11px;font-weight:600;margin-bottom:3px}.notif-message{color:#94a3b8;font-size:10px}.phone-content{display:flex;flex:1 1;flex-direction:column;gap:15px;padding:15px}.phone-header{text-align:center}.phone-model{color:#fff;font-size:14px;font-weight:600}.phone-os{color:#64748b;font-size:10px}.sensor-display{background:#0000004d;border-radius:12px;padding:12px}.sensor-title{color:#4ade80;font-size:9px;letter-spacing:1px;margin-bottom:10px;text-align:center}.sensor-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(2,1fr)}.sensor-box{background:#ffffff0d;border-radius:8px;padding:10px;text-align:center}.sensor-label{color:#64748b;font-size:9px;margin-bottom:4px}.sensor-value{color:#4ade80;font-family:Monaco,monospace;font-size:14px;font-weight:600}.phone-apps{gap:15px;padding:10px 0}.app-icon,.phone-apps{display:flex;justify-content:center}.app-icon{align-items:center;border-radius:12px;cursor:pointer;font-size:20px;height:45px;transition:transform .2s;width:45px}.app-icon:hover{transform:scale(1.1)}.app-icon.messages{background:linear-gradient(135deg,#3b82f6,#2563eb)}.app-icon.phone{background:linear-gradient(135deg,#22c55e,#16a34a)}.app-icon.camera{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.app-icon.settings{background:linear-gradient(135deg,#64748b,#475569)}.phone-location{align-items:center;background:#0003;border-radius:8px;color:#64748b;display:flex;font-size:11px;gap:6px;justify-content:center;padding:8px}.phone-home-indicator{background:#ffffff4d;border-radius:2px;height:4px;margin:8px auto;width:100px}.app-header{align-items:center;background:#0003;display:flex;justify-content:space-between;padding:12px 15px}.app-title{color:#fff;font-size:16px;font-weight:700}.app-status{align-items:center;color:#4ade80;display:flex;font-size:10px;gap:6px}.status-dot{background:#ef4444;border-radius:50%;height:6px;width:6px}.status-dot.online{background:#4ade80;box-shadow:0 0 8px #4ade80}.app-tabs{background:#0000004d;display:flex;gap:4px;padding:4px}.tab-btn{background:#0000;border:none;border-radius:6px;color:#64748b;cursor:pointer;flex:1 1;font-size:11px;font-weight:500;padding:8px 4px;transition:all .2s}.tab-btn:hover{color:#94a3b8}.tab-btn.active{background:var(--accent-primary);color:#fff}.app-content{flex:1 1;overflow-y:auto;padding:12px}.monitor-view{display:flex;flex-direction:column;gap:10px}.sensor-card{align-items:center;background:#ffffff0d;border-radius:12px;display:flex;gap:12px;padding:12px;transition:all .2s}.sensor-card:hover{background:#ffffff14}.sensor-icon{align-items:center;border-radius:10px;display:flex;font-size:20px;height:40px;justify-content:center;width:40px}.sensor-icon.temp{background:#ef444433}.sensor-icon.humid{background:#3b82f633}.sensor-icon.pressure{background:#a855f733}.sensor-info{flex:1 1}.sensor-info .sensor-label{color:#64748b;font-size:11px;margin-bottom:2px}.sensor-info .sensor-value{color:#fff;font-family:Monaco,monospace;font-size:18px;font-weight:600}.control-view{display:flex;flex-direction:column;gap:8px}.control-item{align-items:center;background:#ffffff0d;border-radius:12px;cursor:pointer;display:flex;gap:12px;padding:12px;transition:all .2s}.control-item:hover{background:#ffffff1a}.control-icon{font-size:20px}.control-name{color:#fff;flex:1 1;font-size:13px}.control-toggle{border-radius:12px;font-size:10px;font-weight:600;padding:4px 12px;transition:all .2s}.control-toggle.off{background:#64748b4d;color:#64748b}.control-toggle.on{background:#4ade80;color:#0f172a}.alerts-view{display:flex;flex-direction:column;gap:8px}.no-alerts{color:#64748b;font-size:12px;padding:30px;text-align:center}.alert-item{align-items:flex-start;background:#ffffff0d;border-radius:10px;display:flex;gap:10px;padding:10px}.alert-item.warning{background:#f59e0b26;border-left:3px solid #f59e0b}.alert-item.success{background:#4ade8026;border-left:3px solid #4ade80}.alert-item.info{background:#3b82f626;border-left:3px solid #3b82f6}.alert-icon{font-size:14px}.alert-content{flex:1 1}.alert-msg{color:#fff;font-size:11px;margin-bottom:2px}.alert-time{color:#64748b;font-size:9px}.app-bottom-nav{background:#0000004d;display:flex;justify-content:space-around;padding:10px}.nav-item{border-radius:10px;cursor:pointer;font-size:18px;height:40px;justify-content:center;opacity:.5;transition:all .2s;width:40px}.nav-item:hover{opacity:.8}.nav-item.active{background:var(--border-accent);opacity:1}.simulator-label{color:#64748b;font-size:12px;letter-spacing:2px;text-transform:uppercase}.trend-view{display:flex;flex:1 1;flex-direction:column;gap:8px;overflow-y:auto;padding:10px}.mini-chart{background:#1e1e2ee6;border-left:3px solid;border-radius:10px;padding:10px}.mini-chart.temp{border-left-color:var(--text-primary)}.mini-chart.humid{border-left-color:#4a90a4}.mini-chart.flow{border-left-color:#22c55e}.mini-chart-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:5px}.mini-chart-label{color:#64748b;font-size:11px}.mini-chart-value{color:#fff;font-size:14px;font-weight:600}.mini-svg{height:40px;width:100%}.trend-title{color:#fff;font-size:16px;font-weight:600;margin-bottom:15px}.trend-chart{background:#1e1e2ecc;border-radius:12px;flex:1 1;padding:15px}.chart-labels,.trend-chart{display:flex;flex-direction:column}.chart-labels{bottom:30px;color:#64748b;font-size:10px;justify-content:space-between;left:5px;position:absolute;top:10px}.chart-area{flex:1 1;position:relative}.trend-svg{height:120px;width:100%}.chart-time-labels{margin-top:8px;padding:0 5px}.chart-time-axis,.chart-time-labels{color:#64748b;display:flex;font-size:9px;justify-content:space-between}.chart-time-axis{padding:5px 20px 0}.trend-values{display:flex;gap:10px;margin-top:12px}.trend-value-item{background:#1e1e2ecc;border-radius:8px;display:flex;flex:1 1;flex-direction:column;gap:4px;padding:10px}.trend-value-item.temp{border-left:3px solid var(--accent-primary)}.trend-value-item.humid{border-left:3px solid #4a90a4}.trend-value-item.flow{border-left:3px solid #22c55e}.trend-label{color:#64748b;font-size:10px}.trend-current{color:#fff;font-size:16px;font-weight:600}.trend-legend{display:flex;gap:20px;justify-content:center;margin-top:12px}.legend-item{align-items:center;color:#d8e0e8;display:flex;font-size:11px;gap:6px}.legend-color{border-radius:2px;height:3px;width:12px}.legend-color.temp{background:var(--accent-primary)}.legend-color.humid{background:#4a90a4}.legend-color.flow{background:#22c55e}.settings-view{flex:1 1;padding:15px}.settings-title{color:#fff;font-size:16px;font-weight:600;margin-bottom:15px}.settings-item{align-items:center;background:#1e1e2ecc;border-radius:10px;color:#e0e0e0;display:flex;font-size:13px;justify-content:space-between;margin-bottom:10px;padding:12px 15px}.settings-toggle{border-radius:12px;font-size:11px;font-weight:600;padding:4px 10px}.settings-toggle.on{background:#22c55e33;color:#22c55e}.settings-toggle.off{background:#64748b33;color:#64748b}.scroll-indicator{align-items:center;animation:bounce 2s infinite;bottom:30px;color:#707070;display:flex;flex-direction:column;font-size:.85rem;gap:10px;left:50%;position:absolute;transform:translateX(-50%)}@keyframes bounce{0%,20%,50%,80%,to{transform:translateX(-50%) translateY(0)}40%{transform:translateX(-50%) translateY(-10px)}60%{transform:translateX(-50%) translateY(-5px)}}.scroll-arrow{border-bottom:2px solid #707070;border-right:2px solid #707070;height:20px;transform:rotate(45deg);width:20px}@media (max-width:1400px){.phone-frame{height:480px;width:240px}}@media (max-width:1200px){.hero-bottom{align-items:center;flex-direction:column}.phone-frame{height:440px;width:220px}.tech-logo-img{height:50px;width:50px}}@media (max-width:992px){.hero-bottom{align-items:center;flex-direction:column}.phone-simulator{display:flex;margin-top:20px}.phone-frame{height:520px;width:260px}.showcase-netexample{height:500px;padding:5px}.showcase-netexample .topology-d3-container{padding:0}.tech-showcase{max-width:100%}.showcase-content{padding:10px}}@media (max-width:576px){.hero{padding-bottom:30px;padding-top:140px}.hero-top{margin-bottom:10px}.hero-tagline{font-size:1rem;margin-bottom:5px}.showcase-netexample{border-radius:8px;height:480px;padding:0}.showcase-content{padding:5px}.tech-showcase{border-radius:10px}.hero-bottom-text{margin-top:15px}}@media (max-width:768px){.tech-items{grid-template-columns:repeat(4,1fr)}.tech-logo-img{height:45px;width:45px}.hero-name{font-size:1.25rem}}@media (max-width:576px){.hero-name{font-size:.9rem;white-space:normal}.hero-description{font-size:1rem}.hero-subtitle-vision{font-size:.95rem;line-height:1.5;word-break:keep-all}.hero-tagline,.hero-tagline-sub{word-break:keep-all}.hero-buttons{flex-direction:column}.btn{text-align:center;width:100%}}.skills{background:var(--bg-primary);padding:100px 20px}.skills-grid{grid-gap:30px;display:grid;gap:30px;grid-template-columns:repeat(2,1fr)}.skill-card{background:linear-gradient(135deg,#2d2d3d,#1e1e2e);border-radius:16px;padding:30px;transition:transform .3s ease,box-shadow .3s ease}.skill-card:hover{box-shadow:0 20px 40px #0000004d;transform:translateY(-10px)}.skill-card-header{align-items:center;display:flex;gap:15px;margin-bottom:30px}.skill-icon{font-size:2rem}.skill-card-header h3{color:#fff;font-size:1.3rem;font-weight:600}.skill-description{color:#e0e8f0;font-size:.9rem;line-height:1.6;margin-bottom:20px}.skill-list{display:flex;flex-wrap:wrap;gap:10px;list-style:none}.skill-list li{background:var(--border-color);border-radius:20px;color:var(--text-primary);font-size:.85rem;padding:6px 14px}@media (max-width:768px){.skills-grid{grid-template-columns:1fr}}@media (max-width:576px){.skills-grid{grid-template-columns:1fr}.skill-card{padding:25px}}.contact{background:var(--bg-primary);padding:100px 20px}.contact-content{grid-gap:60px;display:grid;gap:60px;grid-template-columns:1fr 1.5fr;margin-top:20px}.contact-info h3{color:#fff;font-size:1.5rem;margin-bottom:15px}.contact-info>p{color:#a0a0a0;line-height:1.7;margin-bottom:30px}.info-list{display:flex;flex-direction:column;gap:25px;margin-bottom:40px}.info-item{align-items:flex-start;display:flex;gap:15px}.info-icon{align-items:center;background:var(--border-color);border-radius:12px;display:flex;flex-shrink:0;height:50px;justify-content:center;width:50px}.info-icon svg{color:var(--text-primary);height:24px;width:24px}.info-content{display:flex;flex-direction:column;gap:5px}.info-label{color:#707070;font-size:.85rem;letter-spacing:1px;text-transform:uppercase}.info-value{color:#fff;font-size:1rem;text-decoration:none;transition:color .3s ease}a.info-value:hover{color:var(--text-primary)}.social-links{display:flex;gap:15px}.social-link{align-items:center;background:#ffffff0d;border-radius:12px;display:flex;height:45px;justify-content:center;transition:all .3s ease;width:45px}.social-link:hover{background:var(--accent-primary);transform:translateY(-5px)}.social-link svg{color:#fff;height:20px;width:20px}.contact-form-wrapper{background:linear-gradient(135deg,#2d2d3d,#1e1e2e);border-radius:20px;padding:40px}.contact-form{display:flex;flex-direction:column;gap:25px}.form-row{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{color:#fff;font-weight:500}.form-group input,.form-group textarea{background:#ffffff0d;border:2px solid #ffffff1a;border-radius:10px;color:#fff;font-family:inherit;font-size:1rem;padding:14px 18px;transition:border-color .3s ease}.form-group input::placeholder,.form-group textarea::placeholder{color:#606060}.form-group input:focus,.form-group textarea:focus{border-color:var(--text-primary);outline:none}.form-group textarea{min-height:120px;resize:vertical}.submit-btn{align-self:flex-start;min-width:180px}.submit-btn.loading{cursor:not-allowed;opacity:.7}.success-message{color:#28c840}.error-message,.success-message{font-size:.95rem;margin-top:10px}@media (max-width:992px){.contact-content{gap:40px;grid-template-columns:1fr}}@media (max-width:576px){.form-row{grid-template-columns:1fr}.contact-form-wrapper{padding:25px}.submit-btn{font-size:.85rem;min-width:120px;padding:10px 20px;width:auto}}.visitor-count{align-items:center;background:#ffffff0d;border:1px solid var(--border-accent);border-radius:20px;color:#707070;display:flex;font-size:12px;gap:6px;padding:6px 12px}.visitor-icon{font-size:14px}.visitor-number{color:var(--text-primary);font-size:14px;font-weight:600}.admin-icon{cursor:pointer;font-size:12px;margin-left:4px;opacity:.5;transition:opacity .3s ease}.admin-icon:hover{opacity:1}@media (max-width:576px){.visitor-count{font-size:11px;padding:5px 10px;right:10px}}.footer{padding:60px 20px 30px}.footer-content{grid-gap:60px;border-bottom:1px solid #ffffff1a;display:grid;gap:60px;grid-template-columns:2fr 1fr 1fr;padding-bottom:40px}.footer-brand{max-width:350px}.footer-logo{align-items:center;display:flex;gap:20px;margin-bottom:15px;text-decoration:none}.footer-logo-icon{height:80px;width:auto}.footer-brand p{color:#c0c8d0;line-height:1.7}.footer-contact h4,.footer-links h4{color:#fff;font-size:1.1rem;font-weight:600;margin-bottom:20px}.footer-links ul{display:flex;flex-direction:column;gap:12px;list-style:none}.footer-links a{color:#c0c8d0;text-decoration:none;transition:color .3s ease}.footer-links a:hover{color:var(--text-primary)}.footer-contact p{color:#c0c8d0;margin-bottom:10px}.footer-contact a{color:var(--text-primary);text-decoration:none}.footer-contact a:hover{text-decoration:underline}.footer-bottom{align-items:center;display:flex;justify-content:space-between;padding-top:30px}.footer-bottom p{color:#a0a8b0;font-size:.9rem}.footer-bottom .highlight-dev{color:var(--text-primary)}.footer-social{display:flex;gap:15px}.footer-social a{align-items:center;background:#ffffff0d;border-radius:10px;display:flex;height:40px;justify-content:center;transition:all .3s ease;width:40px}.footer-social a:hover{background:var(--accent-primary);transform:translateY(-3px)}.footer-social svg{color:#fff;height:18px;width:18px}.footer-auth-visitor{align-items:center;display:flex;gap:15px}.footer-login{background:linear-gradient(135deg,#4a9eff,#3a7bd5);border-radius:15px;color:#fff!important;font-size:.85rem;font-weight:500;padding:6px 16px;text-decoration:none;transition:all .2s ease}.footer-login:hover{background:linear-gradient(135deg,#5aafff,#4a8be5);transform:translateY(-1px)}.footer-user{align-items:center;display:flex;gap:10px}.footer-user .user-name{color:#d8e0e8;font-size:.85rem}.footer-logout{background:var(--border-color);border:1px solid var(--border-accent);border-radius:12px;color:var(--accent-primary)!important;font-size:.8rem;padding:5px 12px;text-decoration:none;transition:all .2s ease}.footer-logout:hover{background:var(--border-accent)}.footer-wiki{background:#667eea26;border:1px solid #667eea;border-radius:12px;color:#667eea!important;font-size:.8rem;padding:5px 12px;text-decoration:none;transition:all .2s ease}.footer-wiki:hover{background:#667eea;color:#fff!important}@media (max-width:992px){.footer-content{gap:40px;grid-template-columns:1fr 1fr}.footer-brand{grid-column:span 2;max-width:none}}@media (max-width:576px){.footer-content{gap:30px;grid-template-columns:1fr}.footer-brand{grid-column:span 1}.footer-bottom{flex-direction:column;gap:20px;text-align:center}}.login-page{align-items:center;background:linear-gradient(135deg,#1a1a2e,#16213e 50%,#0f3460);display:flex;justify-content:center;min-height:100vh;padding:20px}.login-container{background:#2d2d3d;border-radius:16px;box-shadow:0 20px 60px #0000004d;max-width:400px;padding:40px;width:100%}.login-header{margin-bottom:30px;text-align:center}.login-header h1{color:#fff;font-size:2rem;margin-bottom:5px}.login-header h1 .highlight-dev{color:var(--text-primary)}.login-logo{align-items:center;display:flex;gap:15px;justify-content:center;margin-bottom:10px;text-decoration:none}.login-logo-icon{height:60px;width:auto}.login-header p{color:#a0a0a0;font-size:.95rem}.login-form{display:flex;flex-direction:column;gap:20px}.login-error{background:#ff5f5726;border:1px solid #ff5f57;border-radius:8px;color:#ff5f57;font-size:.9rem;padding:12px}.login-form .form-group{display:flex;flex-direction:column;gap:8px}.login-form label{color:#fff;font-size:.9rem;font-weight:500}.login-form input{background:#ffffff0d;border:2px solid #ffffff1a;border-radius:8px;color:#fff;font-size:1rem;padding:14px 16px;transition:border-color .3s ease}.login-form input:focus{border-color:var(--text-primary);outline:none}.login-btn{background:var(--accent-gradient);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;margin-top:10px;padding:14px;transition:all .3s ease}.login-btn:hover:not(:disabled){box-shadow:0 10px 30px var(--border-accent);transform:translateY(-2px)}.login-btn:disabled{cursor:not-allowed;opacity:.7}.login-notice{background:#4a90e226;border:1px solid #4a90e2;border-radius:8px;color:#4a90e2;font-size:.9rem;padding:14px;text-align:center}.login-form small{color:#707070;font-size:.8rem}.otp-notice{background:var(--border-color);border-color:var(--text-primary);color:var(--text-primary);line-height:1.6}.otp-input{font-family:monospace;font-size:1.5rem!important;letter-spacing:10px;text-align:center}.back-btn{background:#0000;border:1px solid #fff3;border-radius:8px;color:#a0a0a0;cursor:pointer;font-size:.95rem;padding:12px;transition:all .3s ease}.back-btn:hover{border-color:#fff6;color:#fff}.login-mode-toggle{border:1px solid #ffffff1a;border-radius:8px;display:flex;gap:0;margin-bottom:20px;overflow:hidden}.mode-btn{background:#0000;border:none;color:#a0a0a0;cursor:pointer;flex:1 1;font-size:.9rem;font-weight:500;padding:12px;transition:all .3s ease}.mode-btn:first-child{border-right:1px solid #ffffff1a}.mode-btn:hover{background:#ffffff0d}.mode-btn.active{background:var(--accent-gradient);color:#fff}.telegram-info{background:#0088cc26;border:1px solid #08c;border-radius:8px;color:#08c;font-size:.85rem;padding:12px;text-align:center}.telegram-waiting{padding:30px 10px;text-align:center}.telegram-icon{animation:pulse 2s infinite;font-size:4rem;margin-bottom:20px}.telegram-message{color:#fff;font-size:1.1rem;margin-bottom:10px}.telegram-submessage{color:#a0a0a0;font-size:.9rem;margin-bottom:30px}.telegram-spinner{animation:spin 1s linear infinite;border:3px solid #ffffff1a;border-radius:50%;border-top-color:#08c;height:40px;margin:0 auto;width:40px}.twofa-selection{display:flex;flex-direction:column;gap:15px}.twofa-prompt{color:#fff;font-size:1rem;margin-bottom:10px;text-align:center}.twofa-method-btn{align-items:center;background:#ffffff0d;border:2px solid #ffffff26;border-radius:12px;color:#fff;cursor:pointer;display:flex;font-size:1rem;gap:12px;justify-content:center;padding:18px 20px;transition:all .3s ease}.twofa-method-btn:hover{background:#ffffff1a;border-color:var(--text-primary);transform:translateY(-2px)}.method-icon{font-size:1.5rem}.method-label{font-weight:500}.switch-method-btn{background:#0000;border:none;color:#a0a0a0;cursor:pointer;font-size:.85rem;padding:10px;text-decoration:underline;transition:color .3s ease}.switch-method-btn:hover{color:#fff}.telegram-auto-trigger{color:#a0a0a0;padding:20px 0;text-align:center}.admin-layout{background:#1a1a2e}.admin-layout,.admin-loading{display:flex;min-height:100vh}.admin-loading{align-items:center;color:#a0a0a0;font-size:1.2rem;justify-content:center}.admin-sidebar{background:#2d2d3d;bottom:0;display:flex;flex-direction:column;left:-220px;min-width:220px;position:fixed;top:0;transition:left .3s ease;width:220px;z-index:1000}.admin-sidebar.open{left:0}.sidebar-header{border-bottom:1px solid #ffffff1a;padding:25px 20px}.sidebar-header .logo-link{align-items:center;display:flex;gap:10px;text-decoration:none}.sidebar-header .logo-link:hover h2{opacity:.8}.sidebar-logo-icon{height:36px;object-fit:contain;width:36px}.sidebar-header h2{color:#fff;font-size:1.5rem;margin-bottom:5px;transition:opacity .2s ease}.sidebar-header h2 .highlight-dev{color:var(--text-primary)}.sidebar-header span{color:#707070;font-size:.85rem}.sidebar-header .logout-link{cursor:pointer;display:block;transition:color .2s ease}.sidebar-header .logout-link:hover{color:var(--text-primary)}.sidebar-nav{flex:1 1;padding:20px 0}.nav-item{align-items:center;box-sizing:border-box;color:#a0a0a0;display:flex;gap:12px;padding:14px 20px;position:relative;text-decoration:none;transition:all .3s ease;width:100%}.nav-item:hover{background:var(--border-color);color:#fff}.nav-item.active{background:var(--border-color);border-right:3px solid var(--accent-primary);color:var(--text-primary)}.nav-icon{flex-shrink:0;font-size:1.2rem}.nav-text{flex:1 1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.badge{background:var(--accent-primary);border-radius:12px;color:#fff;font-size:.75rem;font-weight:600;margin-left:auto;padding:2px 8px}.sidebar-footer{border-top:1px solid #ffffff1a;padding:20px}.logout-btn{background:#ffffff0d;border:1px solid #ffffff1a;border-radius:8px;color:#a0a0a0;cursor:pointer;padding:12px;transition:all .3s ease;width:100%}.logout-btn:hover{background:#ff5f5726;border-color:#ff5f57;color:#ff5f57}.admin-main{box-sizing:border-box;flex:1 1;margin-left:0;max-width:100%;overflow-x:hidden;padding:30px 30px 30px 50px;width:100%}.admin-header{margin-bottom:30px}.admin-header h1{color:#fff;font-size:1.8rem;font-weight:600}.mobile-menu-toggle{background:#667eea;border:none;border-radius:0 8px 8px 0;box-shadow:2px 0 10px #667eea80;cursor:pointer;display:flex;flex-direction:column;gap:4px;left:0;padding:12px 8px;position:fixed;top:50%;transform:translateY(-50%);transition:all .2s ease;z-index:998}.mobile-menu-toggle:hover{background:#764ba2;padding-right:12px}.mobile-menu-toggle span{background:#fff;border-radius:1px;display:block;height:2px;transition:all .2s ease;width:20px}.sidebar-overlay{background:#00000080;bottom:0;display:none;left:0;position:fixed;right:0;top:0;z-index:999}.sidebar-overlay.show{display:block}.stats-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(3,1fr);margin-bottom:40px}.stat-card{align-items:center;background:#2d2d3d;border-radius:12px;display:flex;gap:20px;padding:25px;transition:transform .3s ease}.stat-card:hover{transform:translateY(-5px)}.stat-card.highlight{background:var(--accent-gradient)}.stat-icon{font-size:2.5rem}.stat-info{display:flex;flex-direction:column}.stat-value{color:#fff;font-size:2rem;font-weight:700}.stat-label{color:#a0a0a0;font-size:.9rem}.stat-card.highlight .stat-label{color:#fffc}.quick-links h3{color:#fff;font-size:1.2rem;margin-bottom:20px}.links-grid{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(3,1fr)}.quick-link{background:#2d2d3d;border-radius:12px;color:#a0a0a0;display:block;padding:20px;text-align:center;text-decoration:none;transition:all .3s ease}.quick-link:hover{background:var(--border-color);color:var(--text-primary)}.password-form-container{max-width:500px}.password-form{background:#2d2d3d;border-radius:12px;padding:30px}.password-form .form-group{margin-bottom:20px}.password-form label{color:#fff;display:block;font-size:.9rem;font-weight:500;margin-bottom:8px}.password-form input{background:#ffffff0d;border:2px solid #ffffff1a;border-radius:8px;box-sizing:border-box;color:#fff;font-size:1rem;padding:14px 16px;transition:border-color .3s ease;width:100%}.password-form input:focus{border-color:var(--text-primary);outline:none}.password-form small{color:#707070;display:block;font-size:.8rem;margin-top:6px}.password-form .form-error{background:#ff5f5726;border:1px solid #ff5f57;border-radius:8px;color:#ff5f57;font-size:.9rem;margin-bottom:20px;padding:12px}.password-form .form-success{background:#50c87826;border:1px solid #50c878;border-radius:8px;color:#50c878;font-size:.9rem;margin-bottom:20px;padding:12px}.password-form .submit-btn{background:var(--accent-gradient);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:14px;transition:all .3s ease;width:100%}.password-form .submit-btn:hover:not(:disabled){box-shadow:0 10px 30px var(--border-accent);transform:translateY(-2px)}.password-form .submit-btn:disabled{cursor:not-allowed;opacity:.7}@media (max-width:992px){.stats-grid{grid-template-columns:repeat(2,1fr)}.links-grid{grid-template-columns:1fr}}@media (max-width:768px){.admin-layout{flex-direction:column}.admin-main{padding:20px 15px 20px 40px}.admin-header h1{font-size:1.3rem}.mobile-menu-toggle{padding:10px 6px}.mobile-menu-toggle span{width:18px}.stats-grid{gap:12px;grid-template-columns:repeat(2,1fr)}.stat-card{gap:12px;padding:15px}.stat-icon{font-size:1.8rem}.stat-value{font-size:1.5rem}.stat-label{font-size:.8rem}.server-card{max-width:100%}.server-stats{gap:10px}.server-stats span{font-size:.75rem}.server-actions{flex-wrap:wrap}.server-actions button{flex:1 1;min-width:80px}}@media (max-width:480px){.admin-main{padding:70px 10px 15px}.stats-grid{gap:10px;grid-template-columns:1fr}.stat-card{padding:12px 15px}.daily-chart{padding:15px}.chart-container{height:120px}.chart-container.monthly .chart-bar-wrapper{min-width:20px}.chart-container.monthly .chart-bar{max-width:20px}.chart-container.monthly .bar-value{font-size:.6rem}.chart-container.monthly .bar-label{font-size:.55rem}.quick-links h3,.recent-visitors-section h3,.server-management h3,.visitors-section h3{font-size:1rem}.links-grid{gap:10px}.quick-link{font-size:.9rem;padding:15px}.modal-content{margin:10px;max-height:95vh}.modal-header{padding:15px}.modal-header h3{font-size:1rem}.modal-body{padding:15px}}.otp-setup-container{max-width:600px}.otp-action-card,.otp-disable-card,.otp-qr-card,.otp-status-card{background:#2d2d3d;border-radius:12px;margin-bottom:20px;padding:25px}.otp-action-card h3,.otp-disable-card h3,.otp-qr-card h3,.otp-status-card h3{color:#fff;font-size:1.1rem;margin-bottom:15px}.otp-status{border-radius:8px;display:inline-block;font-size:1.2rem;font-weight:600;padding:10px 15px}.otp-status.enabled{background:#50c87826;color:#50c878}.otp-status.disabled{background:#ff5f5726;color:#ff5f57}.otp-action-card p,.otp-disable-card p,.otp-qr-card p{color:#a0a0a0;line-height:1.6;margin-bottom:15px}.otp-setup-btn{background:var(--accent-gradient);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:14px 28px;transition:all .3s ease}.otp-setup-btn:hover{box-shadow:0 10px 30px var(--border-accent);transform:translateY(-2px)}.qr-code-wrapper{background:#fff;border-radius:12px;display:inline-block;margin:15px 0;padding:20px}.qr-code-wrapper img{display:block;height:200px;width:200px}.secret-key{background:#0000004d;border-radius:8px;margin:15px 0;padding:15px}.secret-key p{color:#707070;font-size:.85rem;margin-bottom:8px!important}.secret-key code{color:var(--text-primary);font-family:monospace;font-size:.95rem;word-break:break-all}.otp-verify-form{display:flex;gap:12px;margin-top:15px}.otp-verify-form input{background:#ffffff0d;border:2px solid #ffffff1a;border-radius:8px;color:#fff;flex:1 1;font-family:monospace;font-size:1.2rem;letter-spacing:8px;padding:14px 16px;text-align:center}.otp-verify-form input:focus{border-color:var(--text-primary);outline:none}.otp-verify-form button{background:var(--accent-gradient);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:14px 24px;transition:all .3s ease;white-space:nowrap}.otp-verify-form button:disabled{cursor:not-allowed;opacity:.5}.otp-verify-form button.disable-btn{background:linear-gradient(135deg,#ff5f57,#ff8a80)}.server-management{margin-bottom:40px}.server-management h3{color:#fff;font-size:1.2rem;margin-bottom:20px}.server-card{background:#2d2d3d;border-radius:12px;max-width:500px;padding:20px 25px}.server-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:15px}.server-name{color:#fff;font-size:1.1rem;font-weight:600}.server-status{border-radius:20px;font-size:.85rem;font-weight:600;padding:6px 14px}.server-status.running{background:#50c87833;color:#50c878}.server-status.stopped{background:#ff5f5733;color:#ff5f57}.server-stats{border-bottom:1px solid #ffffff1a;border-top:1px solid #ffffff1a;display:flex;flex-wrap:wrap;gap:20px;margin-bottom:15px;padding:12px 0}.server-stats span{color:#a0a0a0;font-family:monospace;font-size:.85rem}.server-actions{display:flex;gap:10px}.server-actions button{border:none;border-radius:8px;cursor:pointer;font-size:.9rem;font-weight:600;padding:10px 20px;transition:all .3s ease}.server-actions button:disabled{cursor:not-allowed;opacity:.5}.server-actions .btn-start{background:linear-gradient(135deg,#50c878,#6dd5a0);color:#fff}.server-actions .btn-start:hover:not(:disabled){box-shadow:0 5px 20px #50c8784d;transform:translateY(-2px)}.server-actions .btn-stop{background:linear-gradient(135deg,#ff5f57,#ff8a80);color:#fff}.server-actions .btn-stop:hover:not(:disabled){box-shadow:0 5px 20px #ff5f574d;transform:translateY(-2px)}.server-actions .btn-refresh{background:#ffffff1a;border:1px solid #ffffff1a;color:#a0a0a0}.server-actions .btn-refresh:hover:not(:disabled){background:#ffffff26;color:#fff}.stat-card.visitor-today{background:linear-gradient(135deg,#4facfe,#00f2fe)}.stat-card.visitor-today .stat-label{color:#fffc}.visitors-section{margin-bottom:40px}.visitors-section h3{color:#fff;font-size:1.2rem;margin-bottom:20px}.chart-hint{color:#707070;font-size:.8rem;font-weight:400}.daily-chart{background:#2d2d3d;border-radius:12px;padding:25px}.chart-container{align-items:flex-end;display:flex;gap:10px;height:200px;justify-content:space-around}.chart-container.monthly{gap:4px;overflow-x:auto;padding-bottom:10px}.chart-bar-wrapper{align-items:center;display:flex;flex:1 1;flex-direction:column;height:100%}.chart-bar{align-items:flex-start;border-radius:8px 8px 0 0;display:flex;justify-content:center;margin-top:auto;max-width:60px;min-height:30px;padding-top:8px;transition:all .3s ease;width:100%}.chart-bar,.chart-bar:hover{background:var(--accent-gradient)}.chart-bar:hover{transform:scaleY(1.02)}.chart-bar.clickable{cursor:pointer}.chart-bar-wrapper:hover .chart-bar.clickable{box-shadow:0 0 15px var(--border-accent)}.chart-container.monthly .chart-bar-wrapper{flex:0 0 auto;min-width:28px}.chart-container.monthly .chart-bar{max-width:28px}.chart-container.monthly .bar-value{font-size:.7rem}.chart-container.monthly .bar-label{font-size:.65rem}.bar-value{color:#fff;font-size:.85rem;font-weight:700}.bar-label{color:#a0a0a0;font-size:.8rem;margin-top:10px;white-space:nowrap}.no-data{padding:40px 0}.recent-visitors-section{margin-bottom:40px}.recent-visitors-section h3{color:#fff;font-size:1.2rem;margin-bottom:20px}.visitors-table-wrapper{background:#2d2d3d;border-radius:12px;overflow:hidden}.visitors-table{border-collapse:collapse;width:100%}.visitors-table td,.visitors-table th{padding:14px 16px;text-align:left}.visitors-table th{background:#0003;color:#a0a0a0;font-size:.85rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.visitors-table td{border-bottom:1px solid #ffffff0d;color:#fff;font-size:.9rem}.visitors-table tbody tr:hover{background:#ffffff08}.visitors-table tbody tr:last-child td{border-bottom:none}.ip-cell{color:#a0a0a0!important;font-family:monospace}.ip-clickable{cursor:pointer;transition:color .2s ease}.ip-clickable:hover{color:#667eea!important;color:var(--accent-primary,#667eea)!important;text-decoration:underline}.ip-loading{color:#707070;font-size:.8em;margin-left:4px}.ip-location{color:#50c878;display:block;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:.75rem;margin-top:2px}.device-badge{border-radius:12px;display:inline-block;font-size:.75rem;font-weight:600;padding:4px 10px;text-transform:capitalize}.device-badge.desktop{background:#4facfe33;color:#4facfe}.device-badge.mobile{background:var(--border-accent);color:var(--text-primary)}.device-badge.tablet{background:#50c87833;color:#50c878}.device-badge.unknown{background:#a0a0a033;color:#a0a0a0}.modal-overlay{padding:20px}.modal-content{border-radius:16px;display:flex;flex-direction:column;max-height:80vh;max-width:900px;overflow:hidden;width:100%}.modal-header{align-items:center;border-bottom:1px solid #ffffff1a;display:flex;justify-content:space-between;padding:20px 25px}.modal-header h3{color:#fff;font-size:1.2rem;margin:0}.modal-close{background:none;border:none;color:#a0a0a0;cursor:pointer;font-size:2rem;line-height:1;padding:0;transition:color .2s}.modal-close:hover{color:var(--text-primary)}.modal-body{flex:1 1;overflow-y:auto;padding:20px 25px}.modal-body .visitors-table{width:100%}@media (max-width:768px){.chart-container{gap:5px;height:150px}.chart-bar{max-width:40px}.bar-value{font-size:.75rem}.bar-label{font-size:.7rem}.visitors-table-wrapper{overflow-x:auto}.visitors-table{min-width:600px}.modal-content{max-height:90vh}.modal-body{overflow-x:auto}}.wiki-link-section{border-top:1px solid #ffffff1a;margin-top:30px;padding-top:20px;text-align:center}.wiki-link-btn{background:#667eea1a;border:1px solid #667eea;border-radius:8px;color:#667eea;display:inline-block;font-size:1rem;font-weight:500;padding:12px 30px;text-decoration:none;transition:all .3s ease}.wiki-link-btn:hover{background:#667eea;box-shadow:0 5px 15px #667eea4d;color:#fff;transform:translateY(-2px)}.admin-layout.tab-layout{flex-direction:column}.admin-topnav{background:#2d2d3d;border-bottom:1px solid #ffffff1a;height:60px;justify-content:space-between;padding:0 20px;position:-webkit-sticky;position:sticky;top:0;z-index:100}.admin-topnav,.topnav-left,.topnav-left .logo-link{align-items:center;display:flex}.topnav-left .logo-link{gap:8px;text-decoration:none}.topnav-logo-icon{height:28px;object-fit:contain;width:28px}.topnav-left .logo-text{color:#fff;font-size:1.2rem;font-weight:700}.topnav-left .logo-text .highlight-dev{color:var(--text-primary)}.topnav-tabs{gap:5px;height:100%}.tab-item,.topnav-tabs{align-items:center;display:flex}.tab-item{border-radius:8px;color:#a0a0a0;cursor:pointer;font-size:.9rem;gap:6px;padding:8px 16px;position:relative;text-decoration:none;transition:all .2s ease}.tab-item:hover{background:#ffffff14;color:#fff}.tab-item.active{background:var(--accent-gradient);color:#fff}.tab-icon{font-size:1rem}.tab-text{font-weight:500}.tab-badge{background:#ff5f57;border-radius:10px;color:#fff;font-size:.7rem;font-weight:600;margin-left:4px;padding:2px 6px}.settings-dropdown{position:relative}.dropdown-arrow{font-size:.6rem;margin-left:4px;transition:transform .2s}.dropdown-menu{background:#2d2d3d;border:1px solid #ffffff1a;border-radius:12px;box-shadow:0 10px 40px #0006;margin-top:8px;min-width:160px;padding:8px 0;top:100%;z-index:200}.dropdown-menu,.dropdown-menu:before{left:50%;position:absolute;transform:translateX(-50%)}.dropdown-menu:before{border-bottom:6px solid #ffffff1a;border-left:6px solid #0000;border-right:6px solid #0000;content:"";top:-6px}.dropdown-item{align-items:center;color:#a0a0a0;display:flex;gap:10px;padding:10px 16px;text-decoration:none;transition:all .2s}.dropdown-item:hover{background:#ffffff14;color:#fff}.dropdown-item span{font-size:1rem}.topnav-right{align-items:center;display:flex}.user-info{border-radius:8px;color:#a0a0a0;cursor:pointer;font-size:.9rem;padding:8px 12px;transition:all .2s}.user-info:hover{background:#ff5f5726;color:#ff5f57}.admin-layout.tab-layout .admin-main.tab-main{margin-left:0;padding:30px}.admin-layout.tab-layout .admin-sidebar,.admin-layout.tab-layout .mobile-menu-toggle,.admin-layout.tab-layout .sidebar-overlay{display:none}@media (max-width:900px){.topnav-tabs{gap:2px}.tab-item{padding:8px 10px}.tab-text{display:none}.tab-icon{font-size:1.2rem}.tab-badge{font-size:.6rem;padding:1px 4px;position:absolute;right:2px;top:2px}.dropdown-menu{left:auto;right:0;transform:none}.dropdown-menu:before{left:auto;right:20px;transform:none}}@media (max-width:600px){.admin-topnav{height:55px;padding:0 10px}.topnav-logo-icon{height:24px;width:24px}.topnav-left .logo-text{font-size:1rem}.tab-item{padding:6px 8px}.tab-icon{font-size:1.1rem}.user-info{font-size:.8rem;padding:6px 8px}.admin-layout.tab-layout .admin-main.tab-main{padding:20px 15px}}.contacts-content{grid-gap:20px;display:grid;gap:20px;grid-template-columns:400px 1fr;height:calc(100vh - 150px)}.contacts-list{background:#2d2d3d;border-radius:12px;overflow-y:auto}.contact-item{border-bottom:1px solid #ffffff0d;cursor:pointer;padding:20px;transition:background .3s ease}.contact-item:hover{background:#ffffff08}.contact-item.selected{border-left:3px solid var(--accent-primary)}.contact-item.selected,.contact-item.unread{background:var(--border-color)}.contact-item.unread .contact-name:before{background:var(--accent-primary);border-radius:50%;content:"";display:inline-block;height:8px;margin-right:8px;width:8px}.contact-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.contact-name{color:#fff;font-weight:600}.contact-date{color:#707070;font-size:.8rem}.contact-subject{color:#a0a0a0;font-size:.95rem;margin-bottom:5px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.contact-email{color:#606060;font-size:.85rem}.contact-detail{background:#2d2d3d;border-radius:12px;overflow-y:auto;padding:30px}.detail-header{margin-bottom:25px;padding-bottom:20px}.detail-header h2{font-size:1.4rem}.detail-info{margin-bottom:25px}.detail-info p{color:#a0a0a0;font-size:.95rem;margin-bottom:10px}.detail-info strong{color:#fff}.detail-info a{color:var(--text-primary);text-decoration:none}.detail-info a:hover{text-decoration:underline}.detail-message{background:#0003;border-radius:10px;margin-bottom:25px;padding:20px}.detail-message h3{color:#fff;font-size:1rem;margin-bottom:15px}.detail-message p{color:#a0a0a0;line-height:1.7;white-space:pre-wrap}.detail-actions{gap:15px}.reply-btn{background:var(--accent-gradient);border-radius:8px;color:#fff;font-weight:500;padding:12px 24px;text-decoration:none;transition:all .3s ease}.reply-btn:hover{box-shadow:0 10px 20px var(--border-accent);transform:translateY(-2px)}@media (max-width:992px){.contacts-content{grid-template-columns:1fr}.contacts-list{max-height:300px}}.wiki-standalone{box-sizing:border-box;overflow-x:hidden;padding:2px 0;width:100%}.wiki-loading,.wiki-standalone{background:#1a1a2e;min-height:100vh}.wiki-loading{color:#fff;font-size:1.2rem;justify-content:center}.wiki-header,.wiki-loading{align-items:center;display:flex}.wiki-header{background:#0000;border-bottom:1px solid #ffffff1a;justify-content:space-between;margin-bottom:2px;padding:1px 8px}.wiki-header-left{align-items:center;display:flex;gap:8px}.wiki-header-left h1{color:#fff;font-size:.8rem;margin:0}.back-link{background:#667eea1a;border-radius:3px;color:#667eea;font-size:.65rem;padding:2px 5px;transition:all .3s ease}.back-link:hover{background:#667eea33}.wiki-header-right{align-items:center;display:flex;gap:6px}.wiki-user{color:#a0a0a0;font-size:.65rem}.add-btn{background:linear-gradient(135deg,#667eea,#764ba2);background:var(--accent-gradient,linear-gradient(135deg,#667eea 0,#764ba2 100%));border:none;border-radius:3px;color:#fff;cursor:pointer;font-size:.7rem;font-weight:500;padding:2px 8px;transition:all .3s ease}.add-btn:hover{box-shadow:0 3px 10px #667eea66;transform:translateY(-1px)}.wiki-filters{border-bottom:1px solid #ffffff1a;display:flex;flex-direction:column;gap:10px;padding:15px}.category-filter{background:#0000004d;border:1px solid #ffffff1a;border-radius:6px;color:#fff;cursor:pointer;font-size:.9rem;padding:10px 12px;width:100%}.category-filter:focus{border-color:#667eea;border-color:var(--accent-primary,#667eea);outline:none}.search-input{background:#0000004d;border:1px solid #ffffff1a;border-radius:6px;color:#fff;font-size:.9rem;padding:10px 12px;width:100%}.search-input::placeholder{color:#707070}.search-input:focus{border-color:#667eea;border-color:var(--accent-primary,#667eea);outline:none}.wiki-content{box-sizing:border-box;display:flex;gap:0;height:calc(100vh - 120px);width:100%}.wiki-content.list-hidden{gap:0}.wiki-content.resizing{cursor:col-resize;-webkit-user-select:none;user-select:none}.resize-handle{background:#0000;cursor:col-resize;flex-shrink:0;position:relative;transition:background .2s ease;width:8px}.resize-handle:after{background:#667eea4d;border-radius:2px;content:"";height:40px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);transition:all .2s ease;width:4px}.resize-handle:hover{background:#667eea1a}.resize-handle:hover:after{background:#667eea;height:60px}.wiki-list{background:#2d2d3d;border-radius:12px;flex-shrink:0;overflow-y:auto;position:relative;transition:opacity .3s ease}.wiki-list.hidden{min-width:0!important;opacity:0;overflow:hidden;padding:0;width:0!important}.list-toggle{background:#667eea33;border:1px solid #667eea;border-radius:6px;color:#667eea;cursor:pointer;font-size:.75rem;padding:6px 12px;position:absolute;right:10px;top:10px;transition:all .2s ease;z-index:10}.list-toggle:hover{background:#667eea;color:#fff}.list-toggle-float{background:#667eea;border:none;border-radius:0 8px 8px 0;box-shadow:2px 0 10px #667eea80;cursor:pointer;left:0;padding:12px 8px;position:fixed;top:50%;transform:translateY(-50%);transition:all .2s ease;z-index:998}.list-toggle-float:hover{background:#764ba2;padding-right:12px}.sidebar-backdrop{background:#00000080;bottom:0;left:0;position:fixed;right:0;top:0;z-index:999}.wiki-content.desktop .wiki-list{border-radius:0;box-shadow:4px 0 20px #00000080;height:100vh;left:0;max-height:100vh;max-width:400px!important;position:fixed;top:0;transform:translateX(0);transition:transform .3s ease;width:400px!important;z-index:1000}.wiki-content.desktop .wiki-list.hidden{opacity:1;transform:translateX(-100%)}.wiki-content.desktop .list-toggle{display:none}.hamburger-icon{display:flex;flex-direction:column;gap:4px;width:20px}.hamburger-icon span{background:#fff;border-radius:1px;display:block;height:2px;transition:all .2s ease}.list-toggle-float:hover .hamburger-icon span{background:#fff}.no-data{color:#707070;padding:40px;text-align:center}.wiki-item{border-bottom:1px solid #ffffff0d;cursor:pointer;padding:15px 20px;transition:background .3s ease}.wiki-item:hover{background:#ffffff08}.wiki-item.selected{background:#ffffff14;background:var(--border-color,#ffffff14);border-left:3px solid #667eea;border-left:3px solid var(--accent-primary,#667eea)}.wiki-item-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.wiki-title{font-size:1rem}.format-badge,.wiki-title{color:#fff;font-weight:600}.format-badge{border-radius:4px;font-size:.7rem;padding:2px 8px;text-transform:uppercase}.wiki-item-meta{align-items:center;display:flex;justify-content:space-between;margin-bottom:5px}.wiki-category{color:#667eea;color:var(--accent-primary,#667eea);font-size:.8rem}.wiki-date{color:#707070;font-size:.75rem}.wiki-path{color:#505050;font-family:monospace;font-size:.75rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.wiki-detail{background:#2d2d3d;border-radius:0;box-sizing:border-box;flex:1 1;margin:0;overflow-y:auto;padding:15px;position:relative}.no-selection{align-items:center;color:#707070;display:flex;height:100%;justify-content:center}.detail-header{align-items:flex-start;border-bottom:1px solid #ffffff1a;display:flex;justify-content:space-between;margin-bottom:8px;padding-bottom:8px}.detail-header h2{color:#fff;flex:1 1;font-size:1rem;font-weight:600;margin:0}.detail-actions{display:flex;gap:10px}.refresh-btn{background:#667eea26;border:1px solid #667eea;border-radius:6px;color:#667eea;cursor:pointer;padding:8px 16px;transition:all .3s ease}.refresh-btn:hover{background:#667eea;color:#fff}.delete-btn{background:#ff5f5726;border:1px solid #ff5f57;border-radius:6px;color:#ff5f57;cursor:pointer;padding:8px 16px;transition:all .3s ease}.delete-btn:hover{background:#ff5f57;color:#fff}.detail-meta{align-items:center;display:flex;gap:15px;margin-bottom:15px}.meta-category{color:#667eea;color:var(--accent-primary,#667eea);font-weight:500}.meta-date{color:#707070;font-size:.85rem}.detail-path{background:#0003;border-radius:6px;color:#a0a0a0;font-family:monospace;font-size:.85rem;margin-bottom:20px;padding:10px 15px}.detail-path strong{color:#fff}.wiki-rendered-content{background:#0003;border-radius:10px;color:#d0d0d0;line-height:1.7;overflow-x:auto;padding:25px}.wiki-rendered-content *{box-sizing:border-box;font-family:inherit}.wiki-rendered-content link,.wiki-rendered-content style{display:none!important}.wiki-rendered-content .page-header h1,.wiki-rendered-content .sidebar h1,.wiki-rendered-content .sidebar h2,.wiki-rendered-content [class*=header] h1,.wiki-rendered-content [class*=title],.wiki-rendered-content h1,.wiki-rendered-content h2,.wiki-rendered-content h3,.wiki-rendered-content h4,.wiki-rendered-content h5,.wiki-rendered-content h6{color:#fff!important;font-family:inherit!important;font-weight:600!important;line-height:1.3!important;margin:.8em 0 .4em!important}.wiki-rendered-content .page-header h1,.wiki-rendered-content .sidebar h1,.wiki-rendered-content h1{font-size:1.1rem!important}.wiki-rendered-content .sidebar h2,.wiki-rendered-content h2{font-size:.95rem!important}.wiki-rendered-content h3{font-size:.85rem!important}.wiki-rendered-content h4{font-size:.8rem!important}.wiki-rendered-content h5{font-size:.75rem!important}.wiki-rendered-content h6{font-size:.7rem!important}.wiki-rendered-content p{margin-bottom:1em}.wiki-rendered-content a{color:#667eea;color:var(--accent-primary,#667eea);text-decoration:none}.wiki-rendered-content a:hover{text-decoration:underline}.wiki-rendered-content code{background:#0000004d;border-radius:4px;color:#e0e0e0;font-family:Consolas,Monaco,monospace;font-size:.9em;padding:2px 6px}.wiki-rendered-content pre{background:#0006;border-radius:8px;margin:1em 0;overflow-x:auto;padding:15px}.wiki-rendered-content pre code{background:#0000;font-size:.85rem;line-height:1.5;padding:0}.wiki-rendered-content ol,.wiki-rendered-content ul{margin-bottom:1em;padding-left:1.5em}.wiki-rendered-content li{margin-bottom:.5em}.wiki-rendered-content blockquote{border-left:4px solid #667eea;border-left:4px solid var(--accent-primary,#667eea);color:#a0a0a0;font-style:italic;margin:1em 0;padding-left:15px}.wiki-rendered-content table{border-collapse:collapse;margin:1em 0;width:100%}.wiki-rendered-content td,.wiki-rendered-content th{border:1px solid #ffffff1a;padding:10px;text-align:left}.wiki-rendered-content th{background:#0000004d;color:#fff}.wiki-rendered-content img{border-radius:8px;height:auto;max-width:100%}.wiki-rendered-content hr{border:none;border-top:1px solid #ffffff1a;margin:2em 0}.modal-overlay{align-items:center;background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#2d2d3d;border-radius:12px;max-width:500px;padding:30px;width:90%}.modal-content h3{color:#fff;font-size:1.3rem;margin-bottom:25px}.form-group{margin-bottom:20px}.form-group label{color:#a0a0a0;display:block;font-size:.9rem;margin-bottom:8px}.form-group input{background:#0000004d;border:1px solid #ffffff1a;border-radius:8px;color:#fff;font-size:1rem;padding:12px 15px;width:100%}.form-group input:focus{border-color:#667eea;border-color:var(--accent-primary,#667eea);outline:none}.form-group small{color:#707070;display:block;font-size:.8rem;margin-top:5px}.error-message{background:#ff5f5726;border:1px solid #ff5f57;border-radius:6px;color:#ff5f57;font-size:.9rem;margin-bottom:20px;padding:10px 15px}.modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:25px}.cancel-btn{background:#0000;border:1px solid #fff3;border-radius:8px;color:#a0a0a0;cursor:pointer;padding:10px 20px;transition:all .3s ease}.cancel-btn:hover{border-color:#fff6;color:#fff}.submit-btn{background:linear-gradient(135deg,#667eea,#764ba2);background:var(--accent-gradient,linear-gradient(135deg,#667eea 0,#764ba2 100%));border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:500;padding:10px 20px;transition:all .3s ease}.submit-btn:hover{box-shadow:0 5px 15px #667eea66;transform:translateY(-1px)}@media (max-width:992px){.wiki-content{flex-direction:column;height:auto}.wiki-list{max-height:300px;width:100%!important}.resize-handle{display:none}.wiki-detail{flex:1 1;min-height:400px}}@media (max-width:768px){.wiki-standalone{padding:5px 0}.wiki-header{padding:2px 8px}.wiki-header-left h1{font-size:.75rem}.back-link{font-size:.6rem;padding:2px 4px}.add-btn{font-size:.65rem;font-size:.9rem;padding:2px 6px;padding:8px 16px}.wiki-content{height:auto;position:relative}.wiki-content.mobile .wiki-list{border-radius:0;box-shadow:4px 0 20px #00000080;height:100vh;left:0;max-height:100vh;max-width:350px!important;position:fixed;top:0;transform:translateX(0);transition:transform .3s ease;width:85%!important;z-index:1000}.wiki-content.mobile .wiki-list.hidden{opacity:1;transform:translateX(-100%);width:85%!important}.wiki-content.mobile .list-toggle-float{padding:10px 6px}.wiki-content.mobile .hamburger-icon{gap:3px;width:18px}.wiki-list{border-radius:8px;max-height:250px}.wiki-item{padding:12px 15px}.wiki-title{font-size:.95rem}.wiki-detail{border-radius:0;margin:0;min-height:300px;padding:10px}.detail-header{flex-direction:column;gap:8px}.detail-header h2{font-size:.95rem}.detail-actions{width:100%}.detail-actions button{flex:1 1;font-size:.8rem;padding:6px 10px}.detail-meta{flex-wrap:wrap;font-size:.8rem;gap:8px}.detail-path{font-size:.7rem;padding:6px 10px;word-break:break-all}.wiki-rendered-content{font-size:.85rem;line-height:1.5;padding:12px}.wiki-rendered-content h1{font-size:1rem!important}.wiki-rendered-content h2{font-size:.9rem!important}.wiki-rendered-content h3{font-size:.8rem!important}.wiki-rendered-content pre{font-size:.7rem;overflow-x:auto;padding:8px}.wiki-rendered-content code,.wiki-rendered-content table{font-size:.8rem}.wiki-rendered-content td,.wiki-rendered-content th{padding:6px 8px}.modal-content{margin:15px;padding:20px;width:calc(100% - 30px)}.modal-content h3{font-size:1.1rem}.form-group input{padding:10px 12px}.modal-actions{flex-direction:column}.modal-actions button{width:100%}}@media (max-width:480px){.wiki-standalone{padding:5px 0}.wiki-header-left h1{font-size:.9rem}.back-link{font-size:.8rem;padding:3px 6px}.wiki-filters{gap:10px}.category-filter,.search-input{font-size:.9rem;padding:8px 12px}.wiki-list{max-height:200px}.wiki-item{padding:10px 12px}.wiki-title{font-size:.9rem}.wiki-category,.wiki-date{font-size:.7rem}.wiki-path{font-size:.65rem}.wiki-detail{margin:0;padding:8px}.detail-header h2{font-size:.95rem}.wiki-rendered-content{font-size:.8rem;line-height:1.5;padding:10px}.wiki-rendered-content h1{font-size:.95rem!important}.wiki-rendered-content h2{font-size:.85rem!important}.wiki-rendered-content h3{font-size:.75rem!important}.wiki-rendered-content pre{font-size:.65rem}.wiki-rendered-content code{font-size:.75rem}.list-toggle,.list-toggle-float{font-size:.7rem;padding:5px 10px}}.theme-settings-container{margin:0 auto;max-width:900px}.theme-info{margin-bottom:30px}.theme-info h3{color:#fff;color:var(--text-primary,#fff);font-size:1.3rem;margin-bottom:10px}.theme-info p{color:#a0a0a0;color:var(--text-secondary,#a0a0a0);font-size:.95rem}.theme-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(3,1fr)}@media (max-width:768px){.theme-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:480px){.theme-grid{grid-template-columns:1fr}}.theme-card{background:#2d2d3d;background:var(--bg-card,#2d2d3d);border:2px solid #0000;border-radius:12px;cursor:pointer;padding:15px;position:relative;transition:all .3s ease}.theme-card:hover{box-shadow:0 8px 25px #0000004d;transform:translateY(-3px)}.theme-card.active{border-color:#e94560;border-color:var(--accent-primary,#e94560)}.theme-preview{border-radius:8px;margin-bottom:12px;min-height:100px;padding:10px}.preview-header{border-radius:4px;height:8px;margin-bottom:10px}.preview-content{display:flex;flex-direction:column;gap:6px}.preview-accent{border-radius:3px;height:6px;width:40%}.preview-text{background:#8080804d;border-radius:3px;height:6px}.preview-text.short{width:60%}.theme-info-card{align-items:center;display:flex;justify-content:space-between}.theme-name-group{display:flex;flex-direction:column;gap:2px}.theme-name{color:#fff;color:var(--text-primary,#fff);font-size:.95rem;font-weight:600}.theme-name-en{color:#707070;color:var(--text-muted,#707070);font-size:.75rem}.theme-color{border:2px solid #fff3;border-radius:50%;height:20px;width:20px}.theme-active-badge{background:#e94560;background:var(--accent-primary,#e94560);border-radius:10px;color:#fff;font-size:.7rem;font-weight:500;padding:4px 8px;position:absolute;right:10px;top:10px}.saving-indicator{animation:pulse 1.5s infinite;color:#e94560;color:var(--accent-primary,#e94560);font-size:.9rem;padding:15px;text-align:center}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.theme-card.light .theme-preview{box-shadow:inset 0 0 0 1px #0000001a}.theme-card.light .preview-text{background:#0000001a}.user-login-page{align-items:center;background:linear-gradient(135deg,#1a1a2e,#16213e);display:flex;justify-content:center;min-height:100vh;padding:20px}.user-login-container{background:#2d2d3d;border-radius:12px;box-shadow:0 10px 40px #0000004d;max-width:400px;padding:40px;width:100%}.user-login-header{margin-bottom:30px;text-align:center}.user-login-header h1{color:#fff;font-size:2rem;margin-bottom:8px}.user-login-header h1 .highlight-dev{color:#4a9eff}.user-login-header p{color:#a0a0a0;font-size:.95rem}.user-login-form{display:flex;flex-direction:column;gap:20px}.user-login-form .form-group{display:flex;flex-direction:column;gap:8px}.user-login-form label{color:silver;font-size:.9rem;font-weight:500}.user-login-form input{background:#1a1a2e;border:1px solid #404050;border-radius:8px;color:#fff;font-size:1rem;padding:14px 16px;transition:border-color .2s ease,box-shadow .2s ease}.user-login-form input:focus{border-color:#4a9eff;box-shadow:0 0 0 3px #4a9eff1a;outline:none}.user-login-form input::placeholder{color:#606060}.user-login-error{background:#ff4d4d1a;border:1px solid #ff4d4d4d;border-radius:8px;color:var(--accent-secondary);font-size:.9rem;padding:12px 16px;text-align:center}.user-login-btn{background:linear-gradient(135deg,#4a9eff,#3a7bd5);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;margin-top:10px;padding:14px;transition:transform .2s ease,box-shadow .2s ease}.user-login-btn:hover:not(:disabled){box-shadow:0 5px 20px #4a9eff4d;transform:translateY(-2px)}.user-login-btn:disabled{cursor:not-allowed;opacity:.6}.user-login-footer{margin-top:25px;text-align:center}.user-login-footer .back-link{color:#808090;font-size:.9rem;text-decoration:none;transition:color .2s ease}.user-login-footer .back-link:hover{color:#4a9eff}@media (max-width:480px){.user-login-container{padding:30px 25px}.user-login-header h1{font-size:1.7rem}}.claude-chat{color:#fff;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,monospace}.claude-chat,.claude-loading{background:#001030;display:flex;height:100vh}.claude-loading{align-items:center;color:#5ba4e6;font-size:1.2rem;justify-content:center}.claude-sidebar{background:#050810;border-right:1px solid #1e3a5f;display:flex;flex-direction:column;transition:width .3s ease}.claude-sidebar.open{width:280px}.claude-sidebar.closed{width:50px}.sidebar-header{align-items:center;border-bottom:1px solid #1e3a5f;display:flex;justify-content:space-between;padding:16px}.sidebar-header h2{color:#5ba4e6;font-size:1.1rem;margin:0}.toggle-sidebar{background:#0000;border:none;color:#5ba4e6;cursor:pointer;font-size:1rem;padding:4px 8px}.toggle-sidebar:hover{color:#7ab8f0}.sidebar-user{border-bottom:1px solid #1e3a5f;padding:12px 16px}.user-info{display:flex;flex-direction:column;gap:4px}.user-name{color:#fff;font-weight:600}.user-role{color:#7ab8f0;font-size:.8rem;text-transform:uppercase}.sidebar-actions{padding:12px 16px}.btn-new-session{background:#3b82f6;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:500;padding:10px 16px;transition:background .2s;width:100%}.btn-new-session:hover:not(:disabled){background:#2563eb}.btn-new-session:disabled{background:#374151;cursor:not-allowed}.sidebar-footer{border-top:1px solid #1e3a5f;margin-top:auto;padding:16px}.btn-logout{background:#0000;border:1px solid #f87171;border-radius:6px;color:#f87171;cursor:pointer;padding:8px 16px;transition:all .2s;width:100%}.btn-logout:hover{background:#f87171;color:#fff}.session-list{flex:1 1;overflow-y:auto;padding:12px 16px}.session-list.empty{align-items:center;color:#6b7280;display:flex;justify-content:center}.session-list h3{color:#9ca3af;font-size:.8rem;margin:0 0 12px;text-transform:uppercase}.session-item{background:#0a1628;border:1px solid #1e3a5f;border-radius:8px;cursor:pointer;margin-bottom:8px;padding:12px;position:relative;transition:all .2s}.session-item:hover{border-color:#3b82f6}.session-item.active{background:#1e3a5f;border-color:#5ba4e6}.session-header{align-items:center;display:flex;gap:8px;margin-bottom:6px}.session-status{border-radius:50%;height:8px;width:8px}.session-id{color:#7ab8f0;font-family:monospace;font-size:.85rem}.session-info{display:flex;font-size:.75rem;justify-content:space-between}.session-dir{max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.btn-terminate{background:#0000;border:none;color:#f87171;cursor:pointer;font-size:.8rem;height:20px;opacity:0;position:absolute;right:8px;top:8px;transition:opacity .2s;width:20px}.session-item:hover .btn-terminate{opacity:1}.btn-terminate:hover{color:#ef4444}.claude-main{display:flex;flex:1 1;flex-direction:column;overflow:hidden}.status-bar{align-items:center;background:#050810;border-bottom:1px solid #1e3a5f;display:flex;font-size:.85rem;justify-content:space-between;padding:8px 16px}.status-left,.status-right{align-items:center;display:flex;gap:12px}.status-indicator{font-size:1rem}.status-text{font-weight:500}.session-info{color:#9ca3af}.status-error{color:#f87171;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.btn-reconnect{background:#3b82f6;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.8rem;padding:4px 12px}.btn-reconnect:hover{background:#2563eb}.work-dir{color:#6b7280;font-family:monospace;font-size:.75rem;max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.claude-content{display:flex;flex:1 1;flex-direction:column;overflow:hidden;padding:16px}.no-session{align-items:center;display:flex;flex:1 1;justify-content:center}.no-session-content{padding:40px;text-align:center}.no-session-content h3{color:#5ba4e6;font-size:1.5rem;margin-bottom:12px}.no-session-content p{color:#9ca3af;margin-bottom:24px}.btn-create-session{background:#3b82f6;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:500;padding:12px 24px;transition:background .2s}.btn-create-session:hover:not(:disabled){background:#2563eb}.btn-create-session:disabled{background:#374151;cursor:not-allowed}.terminal-output{background:#0a0a0a;border:1px solid #1e3a5f;border-radius:8px;flex:1 1;font-family:Fira Code,Consolas,monospace;font-size:.9rem;line-height:1.5;overflow:auto;padding:16px}.terminal-output pre{word-wrap:break-word;margin:0;white-space:pre-wrap}.message-list{background:#1e3a5f4d;border-radius:8px;margin:16px 0;max-height:200px;overflow-y:auto;padding:8px}.message{border-radius:8px;margin-bottom:8px;padding:12px}.message-user{background:#1e3a5f;border-left:3px solid #5ba4e6}.message-claude{background:#5ba4e61a;border-left:3px solid #7ab8f0}.message-system{background:#fbbf241a;border-left:3px solid #fbbf24;font-style:italic}.message-header{display:flex;font-size:.8rem;justify-content:space-between;margin-bottom:8px}.message-role{color:#5ba4e6;font-weight:600}.message-time{color:#6b7280}.message-content{line-height:1.6}.message-markdown code{background:#0a0a0a;border-radius:4px;font-family:monospace;padding:2px 6px}.message-markdown pre{background:#0a0a0a;border-radius:6px;overflow-x:auto;padding:12px}.input-area{background:#050810;border:1px solid #1e3a5f;border-radius:8px;display:flex;gap:12px;padding:12px}.input-textarea{background:#0a1628;border:1px solid #1e3a5f;border-radius:6px;color:#fff;flex:1 1;font-family:inherit;font-size:.95rem;max-height:200px;min-height:44px;padding:12px;resize:none}.input-textarea:focus{border-color:#3b82f6;outline:none}.input-textarea::placeholder{color:#6b7280}.input-textarea:disabled{background:#050810;cursor:not-allowed}.btn-send{background:#3b82f6;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:500;padding:12px 24px;transition:background .2s;white-space:nowrap}.btn-send:hover:not(:disabled){background:#2563eb}.btn-send:disabled{background:#374151;cursor:not-allowed}.ansi-bright-black{color:#4d4d4d}.ansi-bright-red{color:#ff6b6b}.ansi-bright-green{color:#4ade80}.ansi-bright-yellow{color:#fbbf24}.ansi-bright-blue{color:#60a5fa}.ansi-bright-magenta{color:#c084fc}.ansi-bright-cyan{color:#22d3ee}.ansi-bright-white{color:#fff}.message-list::-webkit-scrollbar,.session-list::-webkit-scrollbar,.terminal-output::-webkit-scrollbar{width:8px}.message-list::-webkit-scrollbar-track,.session-list::-webkit-scrollbar-track,.terminal-output::-webkit-scrollbar-track{background:#0a0a0a}.message-list::-webkit-scrollbar-thumb,.session-list::-webkit-scrollbar-thumb,.terminal-output::-webkit-scrollbar-thumb{background:#374151;border-radius:4px}.message-list::-webkit-scrollbar-thumb:hover,.session-list::-webkit-scrollbar-thumb:hover,.terminal-output::-webkit-scrollbar-thumb:hover{background:#4b5563}@media (max-width:768px){.claude-sidebar.open{width:240px}.status-bar{align-items:flex-start;flex-direction:column;gap:8px}.work-dir{max-width:100%}}.network-page{color:#fff;min-height:100vh}.network-page .container{margin:0 auto;max-width:1200px;padding:0 20px}.network-header{background:#0000004d;border-bottom:1px solid var(--border-accent);padding:100px 0 30px}.network-header .container{text-align:center}.header-top-row{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.back-link{align-items:center;color:#a0a0a0;display:inline-flex;font-size:.9rem;gap:8px;text-decoration:none;transition:color .3s ease}.header-user-badge{align-items:center;background:var(--border-color);border:1px solid var(--border-accent);border-radius:20px;display:flex;gap:8px;padding:8px 16px}.header-user-badge .user-icon{font-size:1rem}.header-user-badge .user-name{color:var(--text-primary);font-size:.9rem;font-weight:600}.back-link:hover{color:var(--text-primary)}.back-link svg{fill:currentColor}.network-header h1{font-size:2.5rem;font-weight:700;margin-bottom:10px}.network-header p{color:#a0a0a0;font-size:1.1rem}.network-content{padding:60px 0}.arch-section{margin-bottom:60px}.arch-section h2{border-bottom:2px solid var(--border-accent);color:#fff;font-size:1.8rem;font-weight:600;margin-bottom:20px;padding-bottom:10px}.section-desc{color:#a0a0a0;font-size:1.05rem;line-height:1.8}.topology-diagram{align-items:center;background:#0000004d;border-radius:16px;display:flex;flex-direction:column;gap:10px;padding:30px}.topology-3d-container{background:#0000004d;border-radius:16px;overflow:hidden;padding:40px 20px;perspective:1000px}.topology-3d{align-items:center;display:flex;flex-direction:column;transform:rotateX(15deg);transform-style:preserve-3d}.layer-3d{border-radius:16px;box-shadow:0 20px 40px #0006;max-width:600px;padding:20px;position:relative;transform-style:preserve-3d;width:100%}.layer-3d-label{background:#1a1a2e;border-radius:6px;color:#fff;font-size:.8rem;font-weight:600;left:20px;padding:4px 14px;position:absolute;top:-12px;z-index:1}.layer-3d-content{display:flex;flex-wrap:wrap;gap:15px;justify-content:center}.layer-top{background:linear-gradient(135deg,#22c55e33,#22c55e1a);border:1px solid #22c55e66;transform:translateZ(80px) translateY(0)}.site-3d{align-items:center;background:#0000004d;border:1px solid #22c55e4d;border-radius:10px;color:#d0d0d0;display:flex;flex-direction:column;font-size:.8rem;gap:6px;min-width:80px;padding:12px 16px}.site-3d.more{border-style:dashed;color:#64748b}.site-icon{font-size:1.5rem}.layer-middle{background:linear-gradient(135deg,var(--border-accent),var(--border-color));border:1px solid var(--border-accent);margin-top:-10px;transform:translateZ(40px) translateY(0)}.cloud-item{align-items:center;background:#0000004d;border-radius:10px;color:#d0d0d0;display:flex;flex-direction:column;font-size:.8rem;gap:6px;min-width:70px;padding:12px 16px}.cloud-icon{font-size:1.3rem}.layer-bottom{background:linear-gradient(135deg,#3b82f633,#3b82f61a);border:1px solid #3b82f666;margin-top:-10px;transform:translateZ(0) translateY(0)}.admin-3d{align-items:center;background:#0000004d;border-radius:10px;color:#d0d0d0;display:flex;flex-direction:column;font-size:.85rem;gap:6px;padding:12px 20px}.admin-icon{font-size:1.5rem}.connection-3d{background:linear-gradient(180deg,#ffffff4d,#ffffff1a);height:30px;position:relative;width:4px;z-index:10}.connection-3d:after,.connection-3d:before{content:"";height:0;left:50%;position:absolute;transform:translateX(-50%);width:0}.connection-3d:after{border-left:6px solid #0000;border-right:6px solid #0000;border-top:8px solid #ffffff4d;bottom:-8px}.topology-3d:hover .layer-top{transform:translateZ(100px) translateY(-5px)}.topology-3d:hover .layer-middle{transform:translateZ(50px)}.topology-3d:hover .layer-bottom{transform:translateZ(0) translateY(5px)}.layer-3d{transition:transform .4s ease}@media (max-width:768px){.topology-3d{transform:rotateX(10deg)}.layer-3d{padding:15px}.cloud-item,.site-3d{font-size:.7rem;min-width:60px;padding:10px 12px}.cloud-icon,.site-icon{font-size:1.2rem}}.topology-layer{border-radius:12px;max-width:800px;padding:20px;position:relative;width:100%}.topology-layer.external{background:#3b82f626;border:1px solid #3b82f64d}.topology-layer.route-server{background:var(--border-color);border:1px solid var(--border-accent)}.topology-layer.field-site{background:#22c55e26;border:1px solid #22c55e4d}.layer-label{background:#1a1a2e;border-radius:4px;color:#fff;font-size:.85rem;font-weight:600;left:20px;padding:2px 12px;position:absolute;top:-12px}.node{align-items:center;background:#ffffff0d;border-radius:10px;display:flex;flex-direction:column;min-width:120px;padding:15px 20px}.node-icon{font-size:2rem;margin-bottom:8px}.node-name{color:#fff;font-size:.9rem;font-weight:600}.node-desc{color:#a0a0a0;font-size:.75rem;margin-top:4px;text-align:center}.server-components{flex-wrap:wrap;gap:20px;margin:20px 0}.port-ranges,.server-components{display:flex;justify-content:center}.port-ranges{gap:15px;margin-top:15px}.port-badge{border-radius:20px;font-size:.8rem;font-weight:500;padding:6px 14px}.port-badge.ssh{background:#3b82f64d;color:#60a5fa}.port-badge.vnc{background:#a855f74d;color:#c084fc}.connection-line{align-items:center;display:flex;flex-direction:column;padding:10px 0}.protocol-label{background:var(--border-color);border-radius:4px;color:var(--text-primary);font-size:.8rem;font-weight:500;margin-bottom:8px;padding:4px 12px}.protocol-label.small{font-size:.7rem;text-align:center}.arrow-down{border-left:10px solid #0000;border-right:10px solid #0000;border-top:15px solid var(--accent-primary);height:0;width:0}.arrow-right{border-bottom:10px solid #0000;border-left:15px solid #22c55e;border-top:10px solid #0000;height:0;width:0}.field-nodes{flex-wrap:wrap;gap:20px;justify-content:center;margin-top:20px}.field-nodes,.local-connection{align-items:center;display:flex}.local-connection{flex-direction:column;gap:8px}.mserver-node{border:2px solid #3b82f680}.hmi-node{border:2px solid #a855f780}.multi-sites{align-items:center;display:flex;flex-wrap:wrap;gap:15px;justify-content:center;margin-top:20px}.site-box{background:#0000004d;border:1px solid #22c55e66;border-radius:12px;min-width:120px;padding:15px}.site-label{border-bottom:1px solid #22c55e4d;color:#4ade80;font-size:.8rem;font-weight:600;margin-bottom:10px;padding-bottom:8px;text-align:center}.site-devices{display:flex;flex-direction:column;gap:8px}.device-item{align-items:center;color:#d0d0d0;display:flex;font-size:.8rem;gap:8px}.device-icon{font-size:1rem}.site-more{align-items:center;color:#64748b;display:flex;flex-direction:column;font-size:.9rem;justify-content:center;padding:15px 20px}.site-more span:first-child{font-size:1.5rem;letter-spacing:3px}.port-table-wrapper{margin-bottom:30px;overflow-x:auto}.port-table{background:#0000004d;border-collapse:collapse;border-radius:12px;overflow:hidden;width:100%}.port-table td,.port-table th{border-bottom:1px solid #ffffff1a;padding:15px 20px;text-align:left}.port-table th{background:var(--border-accent);color:var(--text-primary);font-weight:600}.port-table td{color:#d0d0d0}.port-table code{background:#ffffff1a;border-radius:4px;color:#60a5fa;font-family:monospace;padding:4px 8px}.port-example{background:#0003;border-radius:12px;padding:20px}.port-example h4{color:#fff;margin-bottom:15px}.example-items{display:flex;flex-direction:column;gap:10px}.example-item{align-items:center;background:#ffffff0d;border-radius:8px;display:flex;gap:15px;padding:10px 15px}.example-item .device{color:#60a5fa;font-family:monospace;min-width:120px}.example-item .arrow{color:var(--text-primary)}.example-item .port{color:#4ade80;font-family:monospace}.flow-cards{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.flow-card{background:#0000004d;border:1px solid #ffffff1a;border-radius:12px;padding:25px}.flow-icon{font-size:2rem;margin-bottom:15px}.flow-card h4{color:#fff;font-size:1.1rem;margin-bottom:20px}.flow-steps{align-items:center;display:flex;flex-direction:column;gap:5px}.flow-step{background:var(--border-color);border-radius:6px;color:#e0e0e0;font-size:.85rem;padding:8px 16px;text-align:center;width:100%}.flow-arrow{color:var(--text-primary);font-size:.75rem;padding:4px 0}.tech-stack-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.tech-stack-card{background:linear-gradient(135deg,var(--border-accent),var(--border-accent));border:1px solid var(--border-accent);border-radius:12px;padding:25px}.tech-stack-card h4{border-bottom:1px solid var(--border-accent);color:var(--text-primary);font-size:1rem;margin-bottom:15px;padding-bottom:10px}.tech-stack-card ul{list-style:none;margin:0;padding:0}.tech-stack-card li{color:#d0d0d0;font-size:.9rem;list-style:none!important;padding:6px 0 6px 15px;position:relative}.tech-stack-card li:before{border-radius:50%;content:"";height:4px;left:0;position:absolute;top:50%;transform:translateY(-50%);width:4px}.feature-list{display:flex;flex-direction:column;gap:20px}.feature-item{background:#0000004d;border:1px solid #ffffff1a;border-radius:12px;display:flex;gap:20px;padding:25px}.feature-item.warning{background:#f59e0b1a;border-color:#f59e0b80}.feature-icon{flex-shrink:0;font-size:2rem}.feature-content h4{color:#fff;font-size:1.1rem;margin-bottom:8px}.feature-content p{color:#a0a0a0;font-size:.95rem;line-height:1.6}.network-footer{background:#0000004d;border-top:1px solid #ffffff1a;padding:30px 0;text-align:center}.network-footer p{color:#707070;font-size:.9rem}.network-footer .highlight-dev{color:var(--text-primary)}@media (max-width:768px){.network-header h1{font-size:1.8rem}.arch-section h2{font-size:1.4rem}.topology-diagram{padding:15px}.field-nodes,.server-components{flex-direction:column}.local-connection{margin:10px 0;transform:rotate(90deg)}.feature-item{flex-direction:column;text-align:center}.port-ranges{align-items:center;flex-direction:column}}@media (max-width:576px){.network-header h1{font-size:1.5rem}.example-item{flex-direction:column;gap:5px;text-align:center}.example-item .device{min-width:auto}}.topology-3d-webgl{background:#0000004d;border:1px solid var(--border-accent);border-radius:16px;cursor:grab;height:500px;overflow:hidden;width:100%}.topology-3d-webgl:active{cursor:grabbing}.topology-3d-loading{align-items:center;background:#0000004d;border:1px solid var(--border-accent);border-radius:16px;display:flex;flex-direction:column;gap:20px;height:400px;justify-content:center;width:100%}.loading-spinner{animation:spin 1s linear infinite;border:3px solid var(--border-accent);border-radius:50%;border-top-color:var(--text-primary);height:50px;width:50px}@keyframes spin{to{transform:rotate(1turn)}}.topology-3d-loading p{color:#a0a0a0;font-size:.95rem}@media (max-width:768px){.topology-3d-webgl{height:350px}}.topology-d3-container{background:#0000004d;border:1px solid var(--border-accent);border-radius:16px;overflow:hidden;padding:20px;width:100%}.topology-d3-container svg{display:block;margin:0 auto}.solutions-tabs-container{background:#0003;border-bottom:1px solid var(--border-accent);padding:15px 0}.solutions-tabs{flex-wrap:wrap;gap:10px}.solution-tab,.solutions-tabs{display:flex;justify-content:center}.solution-tab{align-items:center;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:8px;color:#a0a0a0;cursor:pointer;flex-direction:column;gap:4px;min-height:60px;min-width:140px;padding:12px 24px;transition:all .3s ease}.solution-tab:hover{background:var(--border-color);border-color:var(--border-accent);color:#fff}.solution-tab.active{background:var(--border-accent);border-color:var(--text-primary);color:#fff}.solution-tab .tab-name{font-size:1rem;font-weight:600}.solution-tab .tab-full-name{font-size:.75rem;opacity:.7}.solution-description{padding:30px 0 20px;text-align:center}.solution-description h2{-webkit-text-fill-color:#0000;background:var(--accent-gradient);-webkit-background-clip:text;background-clip:text;font-size:1.8rem;margin-bottom:10px}.solution-description p{color:#a0a0a0;font-size:1rem}@media (max-width:576px){.solutions-tabs{flex-wrap:nowrap;gap:6px;justify-content:flex-start;overflow-x:auto;padding-bottom:8px}.solution-tab{flex-shrink:0;max-width:110px;min-width:90px;padding:8px 12px}.solution-tab .tab-name{display:block;font-size:.8rem;overflow:hidden;text-align:center;text-overflow:ellipsis;white-space:nowrap;width:80px}.solution-tab .tab-full-name{display:none}.solution-description h2{font-size:1.4rem}}:root{--bg-primary:#001030;--bg-secondary:#001030;--bg-tertiary:#001030;--bg-card:#0c1829cc;--text-primary:#fff;--text-secondary:#f0f4f8;--text-muted:#d4e0ed;--accent-primary:#5ba4e6;--accent-secondary:#7ab8f0;--accent-gradient:linear-gradient(135deg,#5ba4e6,#7ab8f0);--border-color:#5ba4e633;--border-accent:#5ba4e680;--shadow-color:#00000080}[data-theme=dark-red]{--bg-primary:#1a1a2e;--bg-secondary:#16213e;--bg-tertiary:#0f3460;--bg-card:#0000004d;--text-primary:#fff;--text-secondary:#a0a0a0;--text-muted:#707070;--accent-primary:#e94560;--accent-secondary:#ff6b6b;--accent-gradient:linear-gradient(135deg,#e94560,#ff6b6b);--border-color:#ffffff1a;--border-accent:#e945604d;--shadow-color:#0000004d}[data-theme=corporate-blue]{--bg-primary:#001030;--bg-secondary:#001030;--bg-tertiary:#001030;--bg-card:#0c1829cc;--text-primary:#fff;--text-secondary:#f0f4f8;--text-muted:#d4e0ed;--accent-primary:#5ba4e6;--accent-secondary:#7ab8f0;--accent-gradient:linear-gradient(135deg,#5ba4e6,#7ab8f0);--border-color:#5ba4e633;--border-accent:#5ba4e680;--shadow-color:#00000080}[data-theme=industrial-orange]{--bg-primary:#1a202c;--bg-secondary:#111827;--bg-tertiary:#0f0f0f;--bg-card:#11182799;--text-primary:#fff;--text-secondary:#9ca3af;--text-muted:#6b7280;--accent-primary:#f59e0b;--accent-secondary:#fbbf24;--accent-gradient:linear-gradient(135deg,#f59e0b,#fbbf24);--border-color:#f59e0b33;--border-accent:#f59e0b66;--shadow-color:#00000080}[data-theme=tech-teal]{--bg-primary:#0f172a;--bg-secondary:#020617;--bg-tertiary:#000;--bg-card:#02061799;--text-primary:#f8fafc;--text-secondary:#94a3b8;--text-muted:#64748b;--accent-primary:#14b8a6;--accent-secondary:#2dd4bf;--accent-gradient:linear-gradient(135deg,#14b8a6,#2dd4bf);--border-color:#14b8a633;--border-accent:#14b8a666;--shadow-color:#00000080}[data-theme=trust-green]{--bg-primary:#1a1a2e;--bg-secondary:#0f1419;--bg-tertiary:#0a0f12;--bg-card:#0f141999;--text-primary:#fff;--text-secondary:#a1a1aa;--text-muted:#71717a;--accent-primary:#22c55e;--accent-secondary:#4ade80;--accent-gradient:linear-gradient(135deg,#22c55e,#4ade80);--border-color:#22c55e33;--border-accent:#22c55e66;--shadow-color:#0006}[data-theme=light-pro]{--bg-primary:#fff;--bg-secondary:#f1f5f9;--bg-tertiary:#e2e8f0;--bg-card:#fff;--text-primary:#1e293b;--text-secondary:#475569;--text-muted:#64748b;--accent-primary:#2563eb;--accent-secondary:#3b82f6;--accent-gradient:linear-gradient(135deg,#2563eb,#3b82f6);--border-color:#2563eb26;--border-accent:#2563eb4d;--shadow-color:#00000014}body{color:#fff;transition:background .3s ease,color .3s ease}.hero,body{background:#001030}.hero{background:var(--bg-primary)}.hero-highlight{color:#5ba4e6;color:var(--accent-primary)}.hero-cta .cta-primary{background:linear-gradient(135deg,#5ba4e6,#7ab8f0);background:var(--accent-gradient)}.hero-cta .cta-secondary{border-color:#5ba4e6;border-color:var(--accent-primary);color:#5ba4e6;color:var(--accent-primary)}.hero-cta .cta-secondary:hover{background:#5ba4e6;background:var(--accent-primary);color:#fff;color:var(--text-primary)}.header{background:#0000;transition:background .3s ease}.header.scrolled{background:#001030;background:var(--bg-secondary)}.logo span{color:#5ba4e6;color:var(--accent-primary)}.nav-list a{color:#f0f4f8;color:var(--text-secondary)}.nav-list a:hover{color:#5ba4e6;color:var(--accent-primary)}.nav-list a:after{background:#5ba4e6;background:var(--accent-primary)}.services-section{background:#001030;background:var(--bg-primary)}.skill-category{background:#0c1829cc;background:var(--bg-card);border-color:#5ba4e633;border-color:var(--border-color)}.skill-category h3{border-bottom-color:#5ba4e680;border-bottom-color:var(--border-accent);color:#5ba4e6;color:var(--accent-primary)}.skill-item{color:#f0f4f8;color:var(--text-secondary)}.skill-item:before{background:#5ba4e6;background:var(--accent-primary)}.about-section{background:#001030;background:var(--bg-primary)}.career-timeline:before{background:#5ba4e6;background:var(--accent-primary)}.career-item:before{background:#001030;background:var(--bg-primary);border-color:#5ba4e6;border-color:var(--accent-primary)}.career-item h4{color:#5ba4e6;color:var(--accent-primary)}.projects-section{background:#001030;background:var(--bg-primary)}.project-card{background:#0c1829cc;background:var(--bg-card);border-color:#5ba4e633;border-color:var(--border-color)}.project-card:hover{border-color:#5ba4e6;border-color:var(--accent-primary)}.project-tag{background:rgba(#5ba4e6,.1);background:rgba(var(--accent-primary),.1);color:#5ba4e6;color:var(--accent-primary)}.contact-section{background:#001030;background:var(--bg-primary)}.contact-form input,.contact-form textarea{background:#0c1829cc;background:var(--bg-card);border-color:#5ba4e633;border-color:var(--border-color);color:#fff;color:var(--text-primary)}.contact-form input:focus,.contact-form textarea:focus{border-color:#5ba4e6;border-color:var(--accent-primary)}.contact-form button{background:linear-gradient(135deg,#5ba4e6,#7ab8f0);background:var(--accent-gradient)}.footer{background:#001030;background:var(--bg-primary);border-top-color:#5ba4e633;border-top-color:var(--border-color)}.footer-bottom .highlight-dev,.footer-contact a,.footer-logo span{color:#5ba4e6;color:var(--accent-primary)}.network-page{background:#001030;background:var(--bg-primary)}.network-header{border-bottom-color:#5ba4e680;border-bottom-color:var(--border-accent)}.network-header h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#5ba4e6,#7ab8f0);background:var(--accent-gradient);-webkit-background-clip:text;background-clip:text}.arch-section h2{border-bottom-color:#5ba4e680;border-bottom-color:var(--border-accent)}.flow-card{background:#0c1829cc;background:var(--bg-card);border-color:#5ba4e633;border-color:var(--border-color)}.flow-step{background:rgba(#5ba4e6,.15);background:rgba(var(--accent-primary),.15)}.flow-arrow{color:#5ba4e6;color:var(--accent-primary)}.tech-stack-card{background:linear-gradient(135deg,#3c3c46cc,#2d2d37e6);border-color:#5ba4e680;border-color:var(--border-accent)}.tech-stack-card h4{border-bottom-color:#5ba4e680;border-bottom-color:var(--border-accent);color:#5ba4e6;color:var(--accent-primary)}.tech-stack-card li:before{background:#5ba4e6;background:var(--accent-primary)}.feature-item{background:#0c1829cc;background:var(--bg-card);border-color:#5ba4e633;border-color:var(--border-color)}.admin-layout{background:#001030;background:var(--bg-primary)}.admin-sidebar{background:#0c1829cc;background:var(--bg-card);border-right-color:#5ba4e633;border-right-color:var(--border-color)}.sidebar-header h2 .highlight-dev{color:#5ba4e6;color:var(--accent-primary)}.nav-item{color:#f0f4f8;color:var(--text-secondary)}.nav-item:hover{background:rgba(#5ba4e6,.1);background:rgba(var(--accent-primary),.1)}.nav-item.active,.nav-item:hover{color:#5ba4e6;color:var(--accent-primary)}.nav-item.active{background:rgba(#5ba4e6,.15);background:rgba(var(--accent-primary),.15)}.nav-item.active:before{background:#5ba4e6;background:var(--accent-primary)}.dashboard-card,.stat-card{background:#0c1829cc;background:var(--bg-card);border-color:#5ba4e633;border-color:var(--border-color)}.btn-primary,.stat-icon,.submit-btn{background:linear-gradient(135deg,#5ba4e6,#7ab8f0);background:var(--accent-gradient)}.machine-vision-page{background:#001030;background:var(--bg-primary)}.mv-header h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#5ba4e6,#7ab8f0);background:var(--accent-gradient);-webkit-background-clip:text;background-clip:text}.mv-section h2{border-bottom-color:#5ba4e680;border-bottom-color:var(--border-accent)}[data-theme=light-pro] .header{background:#ffffffe6}[data-theme=light-pro] .header.scrolled{background:#fffffffa;box-shadow:0 2px 20px #00000080;box-shadow:0 2px 20px var(--shadow-color)}[data-theme=light-pro] .logo{color:#fff;color:var(--text-primary)}[data-theme=light-pro] .hamburger span{background:#fff;background:var(--text-primary)}[data-theme=light-pro] .admin-sidebar,[data-theme=light-pro] .mobile-nav{background:#001030;background:var(--bg-primary)}[data-theme=light-pro] .admin-sidebar{box-shadow:2px 0 10px #00000080;box-shadow:2px 0 10px var(--shadow-color)}[data-theme=light-pro] .sidebar-header h2{color:#fff;color:var(--text-primary)}[data-theme=light-pro] .dashboard-card,[data-theme=light-pro] .stat-card{box-shadow:0 2px 10px #00000080;box-shadow:0 2px 10px var(--shadow-color)}[data-theme=light-pro] input,[data-theme=light-pro] select,[data-theme=light-pro] textarea{background:#001030;background:var(--bg-secondary);border-color:#5ba4e633;border-color:var(--border-color);color:#fff;color:var(--text-primary)}[data-theme=light-pro] .feature-item,[data-theme=light-pro] .flow-card,[data-theme=light-pro] .project-card,[data-theme=light-pro] .skill-category{background:#0c1829cc;background:var(--bg-card);box-shadow:0 2px 10px #00000080;box-shadow:0 2px 10px var(--shadow-color)}[data-theme=light-pro] .tech-stack-card{background:linear-gradient(135deg,#f1f5f9e6,#e2e8f0e6)}[data-theme=light-pro] .tech-stack-card li{color:#f0f4f8;color:var(--text-secondary)}[data-theme=light-pro] .machine-vision-page,[data-theme=light-pro] .network-page{background:#001030;background:var(--bg-primary)}[data-theme=light-pro] .topology-3d-container,[data-theme=light-pro] .topology-d3-container{background:#001030;background:var(--bg-secondary);border-color:#5ba4e680;border-color:var(--border-accent)}[data-theme=light-pro] .layer-3d-label{background:#001030;background:var(--bg-primary);color:#fff;color:var(--text-primary)}[data-theme=light-pro] .admin-3d,[data-theme=light-pro] .cloud-item,[data-theme=light-pro] .site-3d{background:#0c1829cc;background:var(--bg-card);color:#f0f4f8;color:var(--text-secondary)}.theme-preview-dark-red{background:linear-gradient(135deg,#1a1a2e,#16213e)}.theme-preview-corporate-blue{background:linear-gradient(135deg,#1e3a5f,#0f2744)}.theme-preview-industrial-orange{background:linear-gradient(135deg,#1a202c,#111827)}.theme-preview-tech-teal{background:linear-gradient(135deg,#0f172a,#020617)}.theme-preview-trust-green{background:linear-gradient(135deg,#1a1a2e,#0f1419)}.theme-preview-light-pro{background:linear-gradient(135deg,#fff,#f1f5f9)}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--bg-primary);color:var(--text-primary);font-family:Segoe UI,-apple-system,BlinkMacSystemFont,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;min-height:100vh}.app{overflow-x:hidden}main{position:relative}.container{margin:0 auto;max-width:1200px;padding:0 20px}.section-title{color:#fff;font-size:2.5rem;font-weight:700;margin-bottom:60px;position:relative;text-align:center}.section-title:after{background:var(--accent-gradient);border-radius:2px;bottom:-15px;content:"";height:4px;left:50%;position:absolute;transform:translateX(-50%);width:80px}.section-description{color:#e8eef5;font-size:1.1rem;margin-bottom:60px;margin-top:-40px;text-align:center}.btn{border:none;border-radius:8px;cursor:pointer;display:inline-block;font-size:1rem;font-weight:600;padding:14px 32px;text-decoration:none;transition:all .3s ease}.btn-primary{background:var(--accent-gradient);color:#fff}.btn-primary:hover{box-shadow:0 10px 30px var(--border-accent);transform:translateY(-3px)}.btn-secondary{background:#0000;border:2px solid var(--accent-primary);color:#fff}.btn-secondary:hover{background:var(--border-color);transform:translateY(-3px)}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#1a1a2e}::-webkit-scrollbar-thumb{background:var(--accent-primary);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--accent-secondary)}::selection{background:var(--border-accent);color:#fff}@media (max-width:768px){.section-title{font-size:2rem;margin-bottom:40px}.section-description{font-size:1rem;margin-bottom:40px;margin-top:-20px}}
/*# sourceMappingURL=main.c74a158e.css.map*/