.layout-container{display:flex;min-height:100vh;width:100%}.sidebar{background-color:#221a15;color:#f1e6d8;display:flex;flex-direction:column;padding:20px;box-sizing:border-box;box-shadow:2px 0 10px #0000004d;border-right:1px solid #3a2d24;border-top-left-radius:0;border-top-right-radius:0;transition:width .3s cubic-bezier(.4,0,.2,1),min-width .3s cubic-bezier(.4,0,.2,1);position:fixed;top:77px;left:0;height:calc(100vh - 77px);z-index:100;overflow-y:auto;overflow-x:hidden}.header-container{display:flex;align-items:center;gap:10px;width:100%;max-height:75px}.header-container .header-container-svg,.header-container .header-title{cursor:pointer}.sidebar-header-container{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:30px;width:100%;box-sizing:border-box;transition:all .3s cubic-bezier(.4,0,.2,1);overflow:visible;position:relative}.sidebar-header{flex:1 1 auto;min-width:0;display:flex;align-items:center;padding:0;margin:0;transition:all .3s cubic-bezier(.4,0,.2,1)}.sidebar-header h2{color:#f3cf98;text-align:left;font-size:1.5rem;font-weight:800;transition:opacity .2s ease,transform .2s ease;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.sidebar-nav ul{list-style:none;padding:0;margin:0;width:100%;box-sizing:border-box}.sidebar-nav li{margin-bottom:5px;width:100%;box-sizing:border-box}.sidebar-nav a{color:#d6c6b6;text-decoration:none;padding:10px 15px;display:block;border-radius:8px;transition:background-color .2s,color .2s,transform .05s ease;width:100%;box-sizing:border-box;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-nav a:hover{background-color:#2a201b;color:#f1e6d8;transform:translateY(-1px)}.sidebar-nav a.active{background-color:#d6a77a;color:#1b1410}.sidebar-nav .nav-group-button{width:100%;border:none;background:transparent;color:#d6c6b6;text-decoration:none;padding:10px 15px;display:flex;align-items:center;justify-content:space-between;border-radius:8px;transition:background-color .2s,color .2s,transform .05s ease;box-sizing:border-box;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-nav .nav-group-button:hover{background-color:#2a201b;color:#f1e6d8;transform:translateY(-1px)}.sidebar-nav .nav-group-button.active{background-color:#d6a77a2e;color:#f3cf98}.nav-group-button-content{display:flex;align-items:center;min-width:0}.nav-group-children{max-height:0;overflow:hidden;padding-left:18px!important;transition:max-height .25s ease}.nav-group-children.expanded{max-height:240px}.nav-child-link{display:flex!important;align-items:center;gap:0;padding-left:20px!important}.nav-group-chevron{font-size:.8rem;color:inherit;transition:transform .2s ease}.nav-group-chevron.expanded{transform:rotate(180deg)}.nav-child-marker{width:8px;height:8px;border-radius:999px;background-color:currentColor;opacity:.7;display:inline-block;margin-right:12px;flex-shrink:0}.sidebar-footer{margin-top:auto;text-align:left;font-size:.8em;color:#b9a796;padding:10px;width:100%;box-sizing:border-box;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-nav-small ul{list-style:none;padding:0;margin:0;width:100%;box-sizing:border-box}.sidebar-nav-small li{margin-bottom:5px;width:100%;box-sizing:border-box}.sidebar-nav-small a{color:#d6c6b6;text-decoration:none;margin-top:10px;display:block;border-radius:8px;width:100%;box-sizing:border-box;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-nav-small a:hover{background-color:#2a201b;color:#f1e6d8;transform:translateY(-1px)}.sidebar-nav-small a.active{background-color:#d6a77a;color:#1b1410}.sidebar-nav-small ul li a img{width:40px;height:39px;box-sizing:border-box;text-align:center;justify-content:center;align-items:center;display:block;padding:5px;color:#d6c6b6;text-decoration:none}.sidebar-nav-small a.active i{background-color:#d6a77a;color:#1b1410}.main-content{flex-grow:1;display:flex;flex-direction:column;margin-left:250px;margin-top:77px;transition:margin-left .3s cubic-bezier(.4,0,.2,1)}.header{background:linear-gradient(180deg,#2a201b,#1b1410);padding:15px 20px;box-shadow:0 2px 10px #00000059;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #3a2d24;position:fixed;top:0;left:0;right:0;width:100%;z-index:1000;height:77px;max-height:77px}.header-right{display:flex;align-items:center;gap:15px}.header-title{color:#f3cf98;text-align:left;font-size:1.5rem;font-weight:800;transition:opacity .2s ease,transform .2s ease;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.user-avatar{width:36px;height:36px;border-radius:50%;background:radial-gradient(circle at 30% 30%,#f3cf98,#d6a77a 60%,#b98658);color:#1b1410;display:flex;justify-content:center;align-items:center;font-weight:800;font-size:.9em;border:1px solid #3a2d24}.logout-button{background-color:#d96b6b;color:#1b1410;border:none;padding:8px 15px;border-radius:8px;cursor:pointer;transition:background-color .2s,transform .05s ease}.logout-button:hover{background-color:#c85e5e;transform:translateY(-1px)}.page-content{flex-grow:1;padding:20px;background-color:transparent}.sidebar-collapsed{width:80px;min-width:80px;max-width:80px;top:77px;height:calc(100vh - 77px);box-sizing:border-box;overflow-x:hidden}.sidebar-collapsed .sidebar-header-container{justify-content:center;padding-right:10px;width:100%;box-sizing:border-box}.sidebar-collapsed .sidebar-header h2{opacity:0;transform:scale(.8);pointer-events:none}.sidebar-toggle,.sidebar-toggle-mobile{background:linear-gradient(135deg,#f3cf981a,#d6a77a0d);border:1px solid rgba(243,207,152,.2);color:#f1e6d8;cursor:pointer;padding:12px;border-radius:8px;display:flex;align-items:center;justify-content:center;transition:all .2s cubic-bezier(.4,0,.2,1);position:static;z-index:10;box-shadow:0 2px 8px #00000026;min-width:44px;min-height:44px;margin:0}.sidebar-header-container .sidebar-toggle{flex-shrink:0;margin-right:8px}.sidebar-toggle:hover,.sidebar-toggle-mobile:hover{background:linear-gradient(135deg,#f3cf9826,#d6a77a1a);border-color:#f3cf984d;transform:scale(1.05) translateY(-1px);box-shadow:0 4px 12px #0003}.sidebar-toggle:active,.sidebar-toggle-mobile:active{transform:scale(.98) translateY(0);box-shadow:0 1px 4px #0000001a}.sidebar-toggle-icon{transition:transform .3s cubic-bezier(.4,0,.2,1)}.sidebar-toggle-icon.rotated{transform:rotate(180deg)}.sidebar-overlay .active .sidebar-collapse-button{position:absolute;top:50%;right:0;transform:translateY(-50%);width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,#f3cf981f,#d6a77a0f);border:1px solid rgba(243,207,152,.25);box-shadow:0 4px 12px #00000040,inset 0 0 0 1px #00000026;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.sidebar-overlay{display:none;position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#00000080;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:999;opacity:0;transition:opacity .3s cubic-bezier(.4,0,.2,1)}.sidebar-overlay.active{opacity:1}.sidebar-collapsed .sidebar-nav,.sidebar-collapsed .sidebar-footer{opacity:0;transform:translate(-20px) scale(.95);transition:opacity .3s cubic-bezier(.4,0,.2,1),transform .3s cubic-bezier(.4,0,.2,1);pointer-events:none}.sidebar-collapsed .sidebar-nav a{transform:translateY(-5px);opacity:0;transition:all .2s cubic-bezier(.4,0,.2,1)}.main-content{transition:margin-left .3s cubic-bezier(.4,0,.2,1),margin-top .3s cubic-bezier(.4,0,.2,1),padding-left .3s cubic-bezier(.4,0,.2,1)}.main-content-expanded{margin-left:80px;margin-top:77px}.main-content:not(.main-content-expanded) .page-content{padding-left:50px}.sidebar-toggle-mobile{display:none;margin-right:10px}@media(max-width:768px){.layout-container{position:relative}.sidebar{position:fixed;top:77px;left:0;height:calc(100vh - 77px);z-index:1001;transform:translate(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1);box-shadow:4px 0 20px #0006}.sidebar:not(.sidebar-collapsed){transform:translate(0)}.sidebar-collapsed{width:70px;min-width:70px;max-width:70px;transform:translate(-100%);top:77px;height:calc(100vh - 77px);box-sizing:border-box;overflow-x:hidden}.main-content-expanded{margin-left:0;padding-left:16px;margin-top:77px}.main-content{margin-left:0;margin-top:77px}.sidebar-toggle-mobile{display:flex!important;background:linear-gradient(135deg,#f3cf9826,#d6a77a1a);border:1px solid rgba(243,207,152,.3);box-shadow:0 2px 8px #00000026;padding:12px;min-width:44px;min-height:44px}.sidebar-toggle{display:none}.page-content{padding:16px 16px 16px 20px}.sidebar-overlay{display:block;top:77px;height:calc(100vh - 77px)}}.sidebar-toggle:focus,.sidebar-toggle-mobile:focus{outline:2px solid #f3cf98;outline-offset:2px}.sidebar-toggle:focus:not(:focus-visible),.sidebar-toggle-mobile:focus:not(:focus-visible){outline:none}.sidebar-nav a{transition:all .2s cubic-bezier(.4,0,.2,1);display:flex}.sidebar-nav a:hover{transform:translateY(-1px)}.sidebar-nav a:active{transform:translateY(0)}.dashboard-container{padding:24px;margin:0 auto;max-width:1400px;width:100%;box-sizing:border-box}.dashboard-header{margin-bottom:40px;text-align:center;position:relative}.page-title{color:#f3cf98;margin-bottom:12px;font-size:2.5rem;font-weight:700;background:linear-gradient(135deg,#f3cf98,#d6a77a);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;text-align:center}.page-description{color:#b9a796;margin:0 auto;max-width:600px;font-size:1.1rem;line-height:1.6;text-align:center;opacity:.9}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:28px;margin-bottom:56px;place-items:center}.metric-card{background:linear-gradient(135deg,#221a15,#2a201b);border:1px solid #3a2d24;border-radius:20px;padding:28px;box-shadow:0 8px 32px #0006,0 2px 8px #0003;position:relative;overflow:hidden;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);width:100%;max-width:320px}.metric-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#f3cf98,#d6a77a,#f3cf98);border-radius:20px 20px 0 0}.metric-card:after{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(243,207,152,.03) 0%,transparent 70%);opacity:0}.metric-card.system-status:before{background:linear-gradient(90deg,#5cb85c,#4cae4c)}.metric-icon{display:flex;align-items:center;justify-content:center;width:56px;height:56px;background-color:#f3cf981a;border-radius:12px;margin-bottom:16px;color:#f3cf98}.metric-content{text-align:center}.metric-value{font-size:2.5rem;font-weight:800;color:#f3cf98;margin:0 0 8px;line-height:1}.metric-value.status-online{color:#5cb85c}.metric-label{font-size:.9rem;color:#b9a796;margin:0;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.dashboard-section{margin-bottom:56px;position:relative}.dashboard-section:before{content:"";position:absolute;top:-20px;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(243,207,152,.2),transparent)}.section-title{color:#f3cf98;font-size:1.8rem;font-weight:600;margin:0 0 28px;background:linear-gradient(135deg,#f3cf98,#d6a77a);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;position:relative;display:inline-block}.section-title:after{content:"";position:absolute;bottom:-8px;left:0;width:60px;height:3px;background:linear-gradient(90deg,#f3cf98,#d6a77a);border-radius:2px}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.view-all-link{display:flex;align-items:center;gap:8px;color:#d6a77a;text-decoration:none;font-size:.9rem;font-weight:500;transition:color .2s ease}.view-all-link:hover{color:#f3cf98}.quick-actions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:24px;place-items:center}.action-card{display:flex;align-items:center;gap:20px;background:linear-gradient(135deg,#221a15,#2a201b);border:1px solid #3a2d24;border-radius:16px;padding:24px;text-decoration:none;color:inherit;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 8px 32px #0006,0 2px 8px #0003;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);position:relative;overflow:hidden;width:100%;max-width:400px}.action-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#f3cf98,#d6a77a);opacity:0;transition:opacity .3s ease}.action-card:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 16px 48px #0009,0 8px 24px #f3cf981a;border-color:#f3cf984d}.action-card:hover:before{opacity:1}.action-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;background-color:#f3cf981a;border-radius:10px;color:#f3cf98;flex-shrink:0}.action-content{flex:1}.action-content h4{margin:0 0 4px;color:#f3cf98;font-size:1.1rem;font-weight:600}.action-content p{margin:0;color:#b9a796;font-size:.9rem}.action-arrow{color:#b9a796;flex-shrink:0;transition:color .2s ease,transform .2s ease}.action-card:hover .action-arrow{color:#f3cf98;transform:translate(2px)}.recent-mappings{background:linear-gradient(135deg,#221a15,#2a201b);border:1px solid #3a2d24;border-radius:16px;overflow:hidden;box-shadow:0 12px 32px #0006,0 4px 16px #0003;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);position:relative}.recent-mappings:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#f3cf98,#d6a77a);border-radius:16px 16px 0 0}.mapping-item{display:flex;align-items:center;padding:24px;border-bottom:1px solid rgba(58,45,36,.5);transition:all .2s cubic-bezier(.4,0,.2,1);position:relative}.mapping-item:last-child{border-bottom:none}.mapping-item:before{content:"";position:absolute;left:0;top:0;bottom:0;width:0;background:linear-gradient(90deg,rgba(243,207,152,.05),transparent);transition:width .2s ease}.mapping-item:hover{background:linear-gradient(135deg,#f3cf9805,#2a201bcc);transform:translate(4px)}.mapping-item:hover:before{width:4px}.mapping-info{flex:1}.mapping-header{display:flex;align-items:center;gap:12px;margin-bottom:8px}.mapping-name{margin:0;color:#f3cf98;font-size:1.1rem;font-weight:600}.protocol-badge{padding:4px 10px;border-radius:20px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.protocol-badge.tcp{background-color:#4a90e233;color:#4a90e2;border:1px solid rgba(74,144,226,.3)}.protocol-badge.udp{background-color:#5cb85c33;color:#5cb85c;border:1px solid rgba(92,184,92,.3)}.mapping-details{margin:0 0 4px;color:#b9a796;font-size:.9rem;font-family:Monaco,Menlo,Ubuntu Mono,monospace}.mapping-description{margin:0;color:#7a6b61;font-size:.85rem;font-style:italic}.mapping-actions{flex-shrink:0;margin-left:16px}.loading-spinner{display:flex;flex-direction:column;align-items:center;justify-content:center;color:#b9a796}.spinner{width:48px;height:48px;border:3px solid rgba(243,207,152,.1);border-top:3px solid #f3cf98;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}.error-message{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;color:#b9a796}.error-message svg{color:#d9534f;margin-bottom:16px}.error-message h3{margin:0 0 8px;color:#f3cf98;font-size:1.5rem}.error-message p{margin:0 0 20px;max-width:400px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 40px;text-align:center;background:linear-gradient(135deg,#221a15,#2a201b);border:1px solid #3a2d24;border-radius:16px;box-shadow:0 12px 32px #0006,0 4px 16px #0003;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);position:relative;overflow:hidden}.empty-state:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#f3cf98,#d6a77a);border-radius:16px 16px 0 0}.empty-state svg{color:#b9a796;margin-bottom:20px;opacity:.7}.empty-state h3{margin:0 0 8px;color:#f3cf98;font-size:1.3rem;font-weight:600}.empty-state p{margin:0 0 24px;color:#b9a796;max-width:300px;line-height:1.5}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(max-width:1024px){.dashboard-container{padding:20px;max-width:100%}.dashboard-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px}.quick-actions-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px}}@media(max-width:768px){.dashboard-container{padding:16px}.dashboard-header{margin-bottom:32px}.dashboard-header:after{width:60px}.page-title{font-size:2.25rem}.page-description{font-size:1rem;max-width:100%}.dashboard-grid{grid-template-columns:1fr;gap:20px;margin-bottom:40px}.metric-card{padding:24px;max-width:100%}.metric-icon{width:52px;height:52px}.metric-value{font-size:2.25rem}.dashboard-section{margin-bottom:40px}.section-title{font-size:1.5rem}.quick-actions-grid{grid-template-columns:1fr;gap:16px}.action-card{padding:20px;max-width:100%}.recent-mappings{border-radius:12px}.recent-mappings:before{border-radius:12px 12px 0 0}.mapping-item{padding:20px;flex-direction:column;align-items:flex-start;gap:16px}.mapping-actions{margin-left:0;align-self:flex-end}.section-header{flex-direction:column;align-items:flex-start;gap:16px}.view-all-link{align-self:flex-end}.empty-state{padding:60px 30px;border-radius:12px}.empty-state:before{border-radius:12px 12px 0 0}}@media(max-width:480px){.dashboard-header{margin-bottom:24px}.page-title{font-size:1.75rem}.metric-card{padding:16px}.metric-value{font-size:1.75rem}.action-card{flex-direction:column;text-align:center;gap:12px}.action-content h4{font-size:1rem}}.aapanel-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;gap:1rem;color:#b9a796}.aapanel-loading-spinner{width:40px;height:40px;border:3px solid #3a2d24;border-top-color:#d6a77a;border-radius:50%;animation:aapanel-spin .8s linear infinite}@keyframes aapanel-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.aapanel-banner{display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:10px;margin-bottom:1.25rem;font-size:.9rem;font-weight:500}.aapanel-banner-warning{background:#f0ad4e1f;border:1px solid rgba(240,173,78,.35);color:#f0ad4e}.aapanel-stats{display:grid;grid-template-columns:repeat(6,1fr);gap:12px;margin-bottom:1.25rem}.aapanel-stat-card{background:linear-gradient(135deg,#221a15,#2a201bf2);border:1px solid #3a2d24;border-radius:12px;padding:16px;text-align:center;position:relative;overflow:hidden;transition:all .2s ease}.aapanel-stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,#d6a77a,transparent)}.aapanel-stat-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px #0000004d}.aapanel-stat-value{font-size:1.75rem;font-weight:700;color:#f3cf98;line-height:1.2}.aapanel-stat-label{font-size:.75rem;color:#b9a796;text-transform:uppercase;letter-spacing:.5px;margin-top:4px}.aapanel-stat-input:before{background:linear-gradient(90deg,transparent,#4a90e2,transparent)}.aapanel-stat-input .aapanel-stat-value{color:#6ab0f3}.aapanel-stat-output:before{background:linear-gradient(90deg,transparent,#a78bfa,transparent)}.aapanel-stat-output .aapanel-stat-value{color:#b99bf7}.aapanel-stat-forward:before{background:linear-gradient(90deg,transparent,#f0ad4e,transparent)}.aapanel-stat-forward .aapanel-stat-value{color:#f5c36d}.aapanel-stat-allow:before{background:linear-gradient(90deg,transparent,#5cb85c,transparent)}.aapanel-stat-allow .aapanel-stat-value{color:#7dd87d}.aapanel-stat-deny:before{background:linear-gradient(90deg,transparent,#d9534f,transparent)}.aapanel-stat-deny .aapanel-stat-value{color:#e87c78}.aapanel-controls{margin-bottom:1.5rem;padding:1.25rem;background:linear-gradient(135deg,rgba(var(--cookie-background),.9),rgba(var(--cookie-primary-rgb),.01));border-radius:14px;border:1px solid var(--cookie-border);box-shadow:0 2px 16px #0000000a,0 1px 2px #0000000f;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);position:relative;z-index:5}.aapanel-controls-row{display:flex;gap:1.5rem;align-items:center;flex-wrap:wrap;position:relative}.badge{display:inline-block;padding:3px 10px;border-radius:6px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.badge-input{background:#4a90e226;color:#6ab0f3;border:1px solid rgba(74,144,226,.3)}.badge-output{background:#a78bfa26;color:#b99bf7;border:1px solid rgba(167,139,250,.3)}.badge-forward{background:#f0ad4e26;color:#f5c36d;border:1px solid rgba(240,173,78,.3)}.badge-allow{background:#5cb85c26;color:#7dd87d;border:1px solid rgba(92,184,92,.3)}.badge-deny{background:#d9534f26;color:#e87c78;border:1px solid rgba(217,83,79,.3)}.aapanel-checkbox-col{width:40px;text-align:center!important}.aapanel-checkbox-col input[type=checkbox]{width:16px;height:16px;accent-color:#d6a77a;cursor:pointer}.aapanel-id-col{font-family:Courier New,Courier,monospace;font-weight:600;color:#b9a796}.aapanel-name-col{font-weight:600}.aapanel-ports-col code{background:#d6a77a1a;border:1px solid rgba(214,167,122,.2);padding:2px 8px;border-radius:4px;font-size:.85rem;color:#f3cf98;white-space:nowrap}.aapanel-row-selected{background:#d6a77a14!important;border-left:3px solid #d6a77a}.aapanel-error-box{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 16px;border-radius:10px;margin-bottom:1.25rem;background:#d9534f1a;border:1px solid rgba(217,83,79,.3);color:#e87c78}.aapanel-error-box p{margin:0}.aapanel-quick-add{margin-bottom:1.25rem}.aapanel-quick-add-title{color:#f3cf98;font-size:1.1rem;margin:0 0 4px}.aapanel-quick-add-desc{color:#b9a796;font-size:.85rem;margin:0 0 16px}.aapanel-quick-add-form{display:flex;gap:12px;align-items:flex-end;flex-wrap:wrap}.aapanel-quick-add-field{flex:1;min-width:140px}.aapanel-quick-add-field label{display:block;margin-bottom:6px;color:#f3cf98;font-size:14px;font-weight:500}.aapanel-quick-add-btn{flex-shrink:0;height:42px}.aapanel-modal-wide{width:min(780px,94vw)}.aapanel-port-list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.aapanel-port-list-header label{margin-bottom:0}.aapanel-port-list{background:#1a1411;border:1px solid #3a2d24;border-radius:8px;overflow:hidden}.aapanel-port-list-row{display:flex;align-items:center;gap:8px;padding:8px 12px;border-bottom:1px solid #2a201b}.aapanel-port-list-row:last-child{border-bottom:none}.aapanel-port-list-row-header{background:linear-gradient(135deg,#2a201b,#33261f);font-size:.75rem;font-weight:700;color:#f3cf98;text-transform:uppercase;letter-spacing:.5px;padding:6px 12px}.aapanel-port-list-col-port,.aapanel-port-list-col-proto{flex:2;min-width:0}.aapanel-port-list-col-action{flex:0 0 40px;display:flex;justify-content:center}.aapanel-port-remove-btn{padding:4px 6px!important;min-width:unset!important}.aapanel-port-list-row .form-control{padding:7px 10px;font-size:13px}.ip-dropdown-disabled{opacity:.5;pointer-events:none}.aapanel-rule-preview{margin-top:8px}.aapanel-rule-preview label{display:block;margin-bottom:6px;color:#f3cf98;font-size:14px;font-weight:500}.aapanel-command-preview{display:block;background:#1a1411;border:1px solid #3a2d24;border-radius:8px;padding:12px 16px;font-size:.8rem;color:#88c07a;font-family:Courier New,Courier,monospace;word-break:break-all;white-space:pre-wrap;line-height:1.6}.field-hint{color:#8a7a6a;font-size:.75rem;margin-top:4px}.btn-spinner{display:inline-block;width:14px;height:14px;border:2px solid transparent;border-top-color:currentColor;border-radius:50%;animation:aapanel-spin .8s linear infinite;margin-right:4px}.form-control:disabled{opacity:.5;cursor:not-allowed}.modal-card{width:min(720px,92vw);background:#221a15;border:1px solid #3a2d24;border-radius:14px;box-shadow:0 12px 36px #00000080}.modal-header{padding:14px 16px;border-bottom:1px solid #3a2d24}.port-forwarding-table tbody tr:hover{background:linear-gradient(135deg,#33261f,#33261fe6);transform:scale(1.005);box-shadow:0 4px 12px #0000004d}@media(max-width:1200px){.aapanel-stats{grid-template-columns:repeat(3,1fr)}}@media(max-width:1024px){.page-title{color:#f3cf98;font-size:2rem;font-weight:700;margin:0 0 10px;background:linear-gradient(135deg,#f3cf98,#d6a77a);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}.page-description{color:#b9a796;margin-bottom:0;font-size:1rem}.aapanel-controls-row{flex-direction:column;align-items:stretch}.aapanel-controls-row>*{width:100%}}@media(max-width:768px){.aapanel-stats{grid-template-columns:repeat(2,1fr)}.aapanel-quick-add-form{flex-direction:column}.grid-2,.grid-3{grid-template-columns:1fr}.btn{padding:12px 16px;font-size:16px}.btn-sm{padding:8px 14px;font-size:14px}.btn-group{flex-direction:column;gap:8px;width:100%}.btn-group .btn{width:100%}.modal-footer{flex-direction:column-reverse;gap:8px}.modal-footer .btn{width:100%}.aapanel-controls{margin-bottom:1rem}.aapanel-controls-row{gap:.75rem}.sort-indicator{font-size:.75rem;padding:.375rem .5rem}.sort-indicator-text{display:none}}@media(max-width:480px){.aapanel-stats{grid-template-columns:1fr 1fr}}.page-container-container{padding:0}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;gap:1rem;flex-wrap:wrap}.page-header-left{flex:1}.page-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.dns-domain-selector-card{margin-bottom:1.25rem;padding:16px 20px}.dns-domain-selector-row{display:flex;align-items:center;gap:14px;flex-wrap:wrap}.dns-domain-label{color:#f3cf98;font-size:14px;font-weight:600;white-space:nowrap;margin:0}.dns-domain-select{flex:1;max-width:380px;min-width:200px}.dns-no-domains{color:#b9a796;font-size:.9rem}.dns-no-domains code{background:#d6a77a1a;border:1px solid rgba(214,167,122,.2);padding:1px 6px;border-radius:4px;color:#f3cf98;font-size:.85rem}.dns-domain-hint{margin-top:10px;font-size:.8rem;color:#8a7a6a}.dns-domain-hint code{background:#d6a77a14;border:1px solid rgba(214,167,122,.15);padding:1px 5px;border-radius:3px;color:#b9a796;font-size:.8rem}.dns-stats{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:1.25rem}.dns-stats .aapanel-stat-card{flex:1;min-width:90px}.dns-stat-a:before{background:linear-gradient(90deg,transparent,#4a90e2,transparent)}.dns-stat-a .aapanel-stat-value{color:#6ab0f3}.dns-stat-aaaa:before{background:linear-gradient(90deg,transparent,#a78bfa,transparent)}.dns-stat-aaaa .aapanel-stat-value{color:#b99bf7}.dns-stat-cname:before{background:linear-gradient(90deg,transparent,#f0ad4e,transparent)}.dns-stat-cname .aapanel-stat-value{color:#f5c36d}.dns-stat-mx:before{background:linear-gradient(90deg,transparent,#5cb85c,transparent)}.dns-stat-mx .aapanel-stat-value{color:#7dd87d}.dns-stat-txt:before{background:linear-gradient(90deg,transparent,#20c997,transparent)}.dns-stat-txt .aapanel-stat-value{color:#5adbb5}.dns-stat-ns:before{background:linear-gradient(90deg,transparent,#fd7e14,transparent)}.dns-stat-ns .aapanel-stat-value{color:#ffa04d}.badge-type-a{background:#4a90e226;color:#6ab0f3;border:1px solid rgba(74,144,226,.3)}.badge-type-aaaa{background:#a78bfa26;color:#b99bf7;border:1px solid rgba(167,139,250,.3)}.badge-type-cname{background:#f0ad4e26;color:#f5c36d;border:1px solid rgba(240,173,78,.3)}.badge-type-mx{background:#5cb85c26;color:#7dd87d;border:1px solid rgba(92,184,92,.3)}.badge-type-txt{background:#20c99726;color:#5adbb5;border:1px solid rgba(32,201,151,.3)}.badge-type-ns{background:#fd7e1426;color:#ffa04d;border:1px solid rgba(253,126,20,.3)}.badge-type-other{background:#b9a7961a;color:#b9a796;border:1px solid rgba(185,167,150,.25)}.dns-table{table-layout:auto}.dns-name-col{min-width:180px}.dns-record-name{background:#d6a77a14;border:1px solid rgba(214,167,122,.15);padding:2px 8px;border-radius:4px;font-size:.85rem;color:#f3cf98;word-break:break-all}.dns-value-col{min-width:140px;max-width:260px}.dns-record-value{background:#d6a77a1a;border:1px solid rgba(214,167,122,.2);padding:2px 8px;border-radius:4px;font-size:.85rem;color:#88c07a;word-break:break-all;white-space:pre-wrap;font-family:Courier New,Courier,monospace}.dns-ttl-col{color:#b9a796;font-size:.85rem;width:80px}.dns-note-col{color:#8a7a6a;font-size:.85rem;max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dns-modal-wide{width:min(700px,94vw)}.dns-textarea{resize:vertical;min-height:80px;font-family:Courier New,Courier,monospace;font-size:13px}@media(max-width:1024px){.dns-stats{flex-wrap:wrap}.dns-stats .aapanel-stat-card{min-width:80px}}@media(max-width:768px){.dns-domain-selector-row{flex-direction:column;align-items:stretch}.dns-domain-select{max-width:100%}.dns-value-col{max-width:140px}.dns-note-col{display:none}}@media(max-width:480px){.dns-ttl-col{display:none}}.search-input-container{position:relative;width:100%;max-width:400px}.search-input-wrapper{position:relative;display:flex;align-items:center;width:100%;background:linear-gradient(135deg,var(--cookie-background) 0%,rgba(var(--cookie-primary-rgb),.02) 100%);border-radius:12px;border:1px solid var(--cookie-border);box-shadow:0 2px 8px #0000000f;transition:all .2s cubic-bezier(.4,0,.2,1)}.search-input-wrapper:hover{border-color:var(--cookie-border-hover);box-shadow:0 4px 16px #0000001a}.search-input-wrapper:focus-within{border-color:var(--cookie-border-primary);box-shadow:0 0 0 3px rgba(var(--cookie-primary-rgb),.15)}.search-input{width:100%;padding:.875rem 2.75rem;border:none;border-radius:12px;background:transparent;color:var(--cookie-text);font-size:.875rem;transition:all .2s cubic-bezier(.4,0,.2,1);box-sizing:border-box}.search-input:focus{outline:none;background:rgba(var(--cookie-primary-rgb),.01)}.search-input::-moz-placeholder{color:var(--cookie-text-muted)}.search-input::placeholder{color:var(--cookie-text-muted)}.search-icon{position:absolute;left:1rem;color:var(--cookie-text-muted);pointer-events:none;z-index:1;transition:color .2s ease}.search-input-wrapper:focus-within .search-icon{color:var(--cookie-primary)}.search-clear-btn{position:absolute;right:.875rem;display:flex;align-items:center;justify-content:center;width:1.75rem;height:1.75rem;border:none;border-radius:50%;background:rgba(var(--cookie-primary-rgb),.1);color:var(--cookie-primary);cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);z-index:1;transform:scale(.9);opacity:.8}.search-clear-btn:hover{background:var(--cookie-primary);color:#fff;transform:scale(1);opacity:1;box-shadow:0 2px 8px rgba(var(--cookie-primary-rgb),.3)}@media(max-width:768px){.search-input-container{max-width:100%}.search-input{font-size:16px}}@media(prefers-color-scheme:dark){.search-input-wrapper{background:linear-gradient(135deg,var(--cookie-input-background) 0%,rgba(var(--cookie-primary-rgb),.02) 100%);border-color:var(--cookie-input-border)}.search-input{background:transparent;color:var(--cookie-input-text)}.search-input:focus{background:rgba(var(--cookie-primary-rgb),.01)}.search-icon{color:var(--cookie-text-muted)}.search-clear-btn:hover{background:var(--cookie-primary);color:#fff}}.search-input-wrapper:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--cookie-primary),transparent);opacity:0;transition:opacity .2s ease}.search-input-wrapper:focus-within:before{opacity:.6}.filter-dropdown{position:relative;display:inline-block;min-width:180px;z-index:10}.filter-dropdown-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;padding:.875rem 1.125rem;border:1px solid var(--cookie-border);border-radius:12px;background:linear-gradient(135deg,var(--cookie-background) 0%,rgba(var(--cookie-primary-rgb),.02) 100%);color:var(--cookie-text);font-size:.875rem;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);box-sizing:border-box;box-shadow:0 2px 8px #0000000f;position:relative;overflow:hidden}.filter-dropdown-toggle:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.08),transparent);transition:left .5s}.filter-dropdown-toggle:hover:before{left:100%}.filter-dropdown-toggle:hover{border-color:var(--cookie-border-hover);background:linear-gradient(135deg,var(--cookie-muted) 0%,rgba(var(--cookie-primary-rgb),.05) 100%);box-shadow:0 4px 16px #0000001a;transform:translateY(-1px)}.filter-dropdown-open{border-color:var(--cookie-border-primary);box-shadow:0 0 0 3px rgba(var(--cookie-primary-rgb),.15);background:linear-gradient(135deg,var(--cookie-background) 0%,rgba(var(--cookie-primary-rgb),.05) 100%)}.filter-dropdown-text{flex:1;text-align:left;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.filter-dropdown-arrow{flex-shrink:0;margin-left:.5rem;transition:transform .15s ease;color:var(--cookie-text-muted)}.filter-dropdown-arrow-up{transform:rotate(180deg)}.filter-dropdown-menu{position:absolute;top:100%;left:0;right:0;z-index:9999;margin-top:.5rem;padding:0;border:1px solid var(--cookie-border);border-radius:12px;background:linear-gradient(135deg,#221a15,#2a201b);box-shadow:0 8px 32px #00000040,0 4px 16px #00000026;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);max-height:320px;overflow-y:auto;animation:dropdownFadeIn .2s cubic-bezier(.4,0,.2,1);min-width:200px;width:100%;will-change:transform,opacity;transform-origin:top center}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.filter-dropdown-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-bottom:1px solid var(--cookie-border);background:linear-gradient(135deg,#2a201b,#33261f)}.filter-dropdown-title{font-size:.875rem;font-weight:600;color:var(--cookie-text)}.filter-dropdown-clear-all{padding:.25rem .5rem;border:none;border-radius:var(--cookie-radius-sm);background:transparent;color:var(--cookie-primary);font-size:.75rem;font-weight:500;cursor:pointer;transition:background-color .15s ease}.filter-dropdown-clear-all:hover{background:var(--cookie-muted)}.filter-dropdown-options{padding:.25rem 0}.filter-dropdown-option{padding:0;cursor:pointer;transition:background-color .15s ease}.filter-dropdown-option:hover{background:var(--cookie-muted)}.filter-dropdown-option-selected{background:rgba(var(--cookie-primary-rgb),.1)}.filter-dropdown-option-selected:hover{background:rgba(var(--cookie-primary-rgb),.15)}.filter-dropdown-option-content{display:flex;align-items:center;padding:.5rem 1rem;gap:.5rem}.filter-dropdown-checkbox{display:flex;align-items:center;justify-content:center;width:1rem;height:1rem;border:2px solid var(--cookie-border);border-radius:.25rem;background:var(--cookie-background);color:var(--cookie-primary);flex-shrink:0}.filter-dropdown-option-selected .filter-dropdown-checkbox{background:var(--cookie-primary);border-color:var(--cookie-border-primary)}.filter-dropdown-option-label{flex:1;font-size:.875rem;color:var(--cookie-text)}.filter-dropdown-option-count{font-size:.75rem;color:var(--cookie-text-muted);font-weight:500}.filter-dropdown-footer{padding:.5rem 1rem;border-top:1px solid var(--cookie-border);background:linear-gradient(135deg,#2a201b,#33261f);text-align:center}.filter-dropdown-clear-single{padding:.375rem .75rem;border:1px solid var(--cookie-border);border-radius:var(--cookie-radius-sm);background:var(--cookie-background);color:var(--cookie-text);font-size:.75rem;cursor:pointer;transition:all .15s ease}.filter-dropdown-clear-single:hover{background:var(--cookie-muted);border-color:var(--cookie-border-hover)}@media(max-width:768px){.filter-dropdown{min-width:160px}.filter-dropdown-toggle{font-size:16px}.filter-dropdown-menu{min-width:200px}}.filter-dropdown{isolation:isolate}@media(prefers-color-scheme:dark){.filter-dropdown-toggle{background:linear-gradient(135deg,var(--cookie-button-background) 0%,rgba(var(--cookie-primary-rgb),.02) 100%);border-color:var(--cookie-button-border);color:var(--cookie-button-text)}.filter-dropdown-toggle:hover{background:linear-gradient(135deg,var(--cookie-button-hover) 0%,rgba(var(--cookie-primary-rgb),.05) 100%);border-color:var(--cookie-button-border)}.filter-dropdown-menu{background:linear-gradient(135deg,#1a1411,#221a15);border-color:var(--cookie-card-border);box-shadow:0 8px 32px #0000004d,0 4px 16px #0003}.filter-dropdown-header,.filter-dropdown-footer{background:linear-gradient(135deg,#221a15,#2a201b);border-color:var(--cookie-card-border)}.filter-dropdown-option:hover{background:linear-gradient(135deg,var(--cookie-muted) 0%,rgba(var(--cookie-primary-rgb),.03) 100%)}.filter-dropdown-option-selected{background:linear-gradient(135deg,rgba(var(--cookie-primary-rgb),.15),rgba(var(--cookie-primary-rgb),.08))}.filter-dropdown-option-selected:hover{background:linear-gradient(135deg,rgba(var(--cookie-primary-rgb),.2),rgba(var(--cookie-primary-rgb),.1))}.filter-dropdown-checkbox{background:var(--cookie-input-background);border-color:var(--cookie-input-border)}.filter-dropdown-clear-single{background:var(--cookie-button-background);border-color:var(--cookie-button-border);color:var(--cookie-button-text)}.filter-dropdown-clear-single:hover{background:var(--cookie-button-hover)}}.filter-dropdown-menu:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--cookie-primary),transparent);opacity:.6}.filter-dropdown-toggle:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--cookie-primary),transparent);opacity:0;transition:opacity .2s ease}.filter-dropdown-toggle:focus:before,.filter-dropdown-open:before{opacity:.6}.sortable-header{position:relative;transition:all .2s cubic-bezier(.4,0,.2,1)}.sortable-header:hover{background:rgba(var(--cookie-primary-rgb),.05)}.sortable-header-active{background:rgba(var(--cookie-primary-rgb),.1);color:var(--cookie-primary)}.sortable-header-active:hover{background:rgba(var(--cookie-primary-rgb),.15)}.sortable-header-content{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.25rem 0}.sortable-header-text{flex:1;font-weight:inherit;text-transform:inherit;letter-spacing:inherit}.sortable-header-icon{display:flex;align-items:center;justify-content:center;width:1.25rem;height:1.25rem;flex-shrink:0;transition:all .2s ease;opacity:.6}.sortable-header:hover .sortable-header-icon{opacity:.8}.sortable-header-active .sortable-header-icon{opacity:1}.sort-icon-active{color:var(--cookie-primary)}.sort-icon-inactive{color:var(--cookie-text-muted)}.sortable-header:after{content:"";position:absolute;bottom:0;left:50%;width:0;height:2px;background:var(--cookie-primary);transition:all .2s cubic-bezier(.4,0,.2,1);transform:translate(-50%)}.sortable-header:hover:after{width:60%}.sortable-header-active:after{width:80%;background:var(--cookie-primary);box-shadow:0 0 8px rgba(var(--cookie-primary-rgb),.4)}@media(max-width:768px){.sortable-header-content{gap:.25rem}.sortable-header-icon{width:1rem;height:1rem}.sortable-header-icon svg{width:12px;height:12px}}.dns-table .sortable-header,.port-forwarding-table .sortable-header{padding:14px 16px;border:1px solid #3a2d24;background:linear-gradient(135deg,#2a201b,#33261f);color:#f3cf98;font-weight:700;font-size:.875rem;text-transform:uppercase;letter-spacing:.5px;position:relative;transition:all .2s cubic-bezier(.4,0,.2,1);border-top:none;cursor:pointer!important;-webkit-user-select:none;-moz-user-select:none;user-select:none;pointer-events:auto!important;z-index:10}.dns-table .sortable-header:hover,.port-forwarding-table .sortable-header:hover{background:linear-gradient(135deg,#33261f,#3a2d24);border-color:#f3cf9833}.dns-table .sortable-header-active,.port-forwarding-table .sortable-header-active{background:linear-gradient(135deg,rgba(var(--cookie-primary-rgb),.15),rgba(var(--cookie-primary-rgb),.08));color:var(--cookie-primary);border-color:rgba(var(--cookie-primary-rgb),.3)}.dns-table .sortable-header-active:after,.port-forwarding-table .sortable-header-active:after{content:"";position:absolute;bottom:0;left:50%;width:60%;height:2px;background:var(--cookie-primary);border-radius:1px;box-shadow:0 0 8px rgba(var(--cookie-primary-rgb),.4);transform:translate(-50%)}@media(prefers-color-scheme:dark){.sortable-header:hover{background:rgba(var(--cookie-primary-rgb),.08)}.sortable-header-active{background:rgba(var(--cookie-primary-rgb),.15)}.sortable-header-active:hover{background:rgba(var(--cookie-primary-rgb),.2)}.sort-icon-inactive{opacity:.4}.dns-table .sortable-header:hover,.port-forwarding-table .sortable-header:hover{background:linear-gradient(135deg,#33261f,#3a2d24)}.dns-table .sortable-header-active,.port-forwarding-table .sortable-header-active{background:linear-gradient(135deg,rgba(var(--cookie-primary-rgb),.2),rgba(var(--cookie-primary-rgb),.1))}}.pagination-container{display:flex;flex-direction:column;gap:1rem;margin-top:1.5rem;padding:1.5rem;background:linear-gradient(135deg,var(--cookie-background) 0%,rgba(var(--cookie-primary-rgb),.02) 100%);border-radius:12px;border:1px solid var(--cookie-border);box-shadow:0 4px 20px #00000014,0 1px 3px #0000001f;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.pagination-info{display:flex;align-items:center;justify-content:space-between;font-size:.875rem;color:var(--cookie-text-muted)}.page-size-selector{display:flex;align-items:center;gap:.5rem}.page-size-selector label{font-weight:500;color:var(--cookie-text)}.page-size-select{padding:.25rem .5rem;border:1px solid var(--cookie-border);border-radius:var(--cookie-radius-sm);background:var(--cookie-background);color:var(--cookie-text);font-size:.875rem;cursor:pointer}.page-size-select:focus{outline:none;border-color:var(--cookie-border-primary);box-shadow:0 0 0 2px rgba(var(--cookie-primary-rgb),.1)}.pagination-controls{display:flex;align-items:center;justify-content:center;gap:.5rem}.pagination-pages{display:flex;align-items:center;gap:.25rem}.pagination-btn{display:flex;align-items:center;gap:.375rem;padding:.625rem 1rem;border:1px solid var(--cookie-border);border-radius:8px;background:linear-gradient(135deg,var(--cookie-background) 0%,rgba(var(--cookie-primary-rgb),.01) 100%);color:var(--cookie-text);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);white-space:nowrap;position:relative;overflow:hidden}.pagination-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);transition:left .5s}.pagination-btn:hover:not(:disabled):before{left:100%}.pagination-btn:hover:not(:disabled){background:linear-gradient(135deg,var(--cookie-muted) 0%,rgba(var(--cookie-primary-rgb),.05) 100%);border-color:var(--cookie-border-hover);transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.pagination-btn:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.pagination-btn-active{background:linear-gradient(135deg,var(--cookie-primary) 0%,rgba(var(--cookie-primary-rgb),.8) 100%)!important;border-color:var(--cookie-border-primary)!important;color:#fff!important;box-shadow:0 4px 16px rgba(var(--cookie-primary-rgb),.3);transform:translateY(-1px)}.pagination-btn-active:hover{box-shadow:0 6px 20px rgba(var(--cookie-primary-rgb),.4)}.pagination-btn-prev,.pagination-btn-next{font-weight:600}.pagination-page{min-width:2.5rem;justify-content:center}@media(max-width:768px){.pagination-container{padding:.75rem}.pagination-info{flex-direction:column;align-items:flex-start;gap:.5rem}.page-size-selector{align-self:flex-end}.pagination-controls{flex-wrap:wrap;gap:.25rem}.pagination-btn{padding:.375rem .5rem;font-size:.75rem}.pagination-btn-prev,.pagination-btn-next{display:none}}@media(prefers-color-scheme:dark){.pagination-container{background:linear-gradient(135deg,var(--cookie-card-background) 0%,rgba(var(--cookie-primary-rgb),.03) 100%);border-color:var(--cookie-card-border);box-shadow:0 4px 20px #00000026,0 1px 3px #0003}.page-size-select{background:var(--cookie-input-background);border-color:var(--cookie-input-border);color:var(--cookie-input-text)}.pagination-btn{background:linear-gradient(135deg,var(--cookie-button-background) 0%,rgba(var(--cookie-primary-rgb),.01) 100%);border-color:var(--cookie-button-border);color:var(--cookie-button-text)}.pagination-btn:hover:not(:disabled){background:linear-gradient(135deg,var(--cookie-button-hover) 0%,rgba(var(--cookie-primary-rgb),.05) 100%)}}.pagination-container:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--cookie-primary),transparent);opacity:.6}.pagination-btn-active:after{content:"";position:absolute;bottom:-2px;left:50%;transform:translate(-50%);width:60%;height:2px;background:var(--cookie-primary);border-radius:1px;box-shadow:0 0 8px rgba(var(--cookie-primary-rgb),.5)}.ip-dropdown{position:relative;width:100%}.ip-dropdown-toggle{width:100%;padding:.5rem .75rem;border:1px solid var(--cookie-border);border-radius:.375rem;background-color:#2a201b;color:var(--cookie-text);font-size:.875rem;text-align:left;cursor:pointer;display:flex;align-items:center;justify-content:space-between;transition:all .15s ease;min-height:2.5rem}.ip-dropdown-toggle:hover{border-color:var(--cookie-border-primary)}.ip-dropdown-toggle:focus{outline:none;border-color:var(--cookie-border-primary);box-shadow:0 0 0 2px #3b82f633}.ip-dropdown-open{border-color:var(--cookie-border-primary);box-shadow:0 0 0 2px #3b82f633}.ip-dropdown-error{border-color:var(--cookie-border-danger)}.ip-dropdown-text{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ip-dropdown-arrow{flex-shrink:0;margin-left:.5rem;transition:transform .15s ease}.ip-dropdown-arrow-up{transform:rotate(180deg)}.ip-dropdown-menu{position:absolute;top:100%;left:0;right:0;z-index:1000;margin-top:.25rem;background-color:#2a201b;border:1px solid var(--cookie-border);border-radius:.375rem;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;max-height:300px;overflow-y:auto}.ip-dropdown-header{padding:.75rem 1rem;border-bottom:1px solid var(--cookie-border);display:flex;align-items:center;justify-content:space-between}.ip-dropdown-title{font-size:.875rem;font-weight:600;color:var(--cookie-text)}.ip-dropdown-options{max-height:200px;overflow-y:auto}.ip-dropdown-option{padding:.5rem 1rem;cursor:pointer;display:flex;align-items:center;transition:background-color .15s ease}.ip-dropdown-option:hover{background-color:#3a2d24}.ip-dropdown-option-selected{background-color:var(--cookie-primary);color:#fff}.ip-dropdown-option-label{font-size:.875rem;flex:1}.ip-dropdown-divider{height:1px;background-color:var(--cookie-border);margin:.25rem 0}.ip-dropdown-manual-option{font-style:italic;color:var(--cookie-primary)}.ip-dropdown-manual-form{padding:0}.ip-dropdown-manual-input{padding:1rem;border-bottom:1px solid var(--cookie-border)}.ip-dropdown-input{width:100%;padding:.5rem;border:1px solid var(--cookie-border);border-radius:.25rem;background-color:var(--cookie-input-bg);color:var(--cookie-text);font-size:.875rem}.ip-dropdown-input:focus{outline:none;border-color:var(--cookie-border-primary)}.ip-dropdown-input-error{border-color:var(--cookie-border-danger)}.ip-dropdown-error-message{margin-top:.25rem;font-size:.75rem;color:var(--cookie-danger)}.ip-dropdown-manual-actions{padding:.75rem 1rem;display:flex;gap:.5rem;justify-content:flex-end}.ip-dropdown-btn{padding:.375rem .75rem;border-radius:.25rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s ease;border:1px solid transparent}.ip-dropdown-btn-secondary{background-color:transparent;color:var(--cookie-text);border-color:var(--cookie-border)}.ip-dropdown-btn-secondary:hover{background-color:#3a2d24}.ip-dropdown-btn-primary{background-color:var(--cookie-primary);color:#fff}.ip-dropdown-btn-primary:hover:not(:disabled){background-color:var(--cookie-primary-hover)}.ip-dropdown-btn:disabled{opacity:.5;cursor:not-allowed}@media(max-width:768px){.ip-dropdown-menu{max-height:250px}.ip-dropdown-options{max-height:150px}}.port-forwarding-container{padding:0;margin:0}.port-forwarding-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:1.5rem;gap:1rem}.port-forwarding-title-section{flex:1}.card{background:linear-gradient(135deg,#221a15,#2a201bf2);border:1px solid #3a2d24;border-radius:16px;box-shadow:0 12px 32px #0006,0 4px 16px #0003;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);padding:24px;position:relative;overflow:visible}.card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--cookie-primary),transparent)}.port-forwarding-table{width:100%;border-collapse:separate;border-spacing:0;border-radius:12px;overflow:visible;box-shadow:0 4px 16px #0003;table-layout:auto}.port-forwarding-table th,.port-forwarding-table td{border:1px solid #3a2d24;padding:14px 16px;text-align:left;color:#f1e6d8;transition:all .2s cubic-bezier(.4,0,.2,1);position:relative}.port-forwarding-table th{background:linear-gradient(135deg,#2a201b,#33261f);font-weight:700;color:#f3cf98;font-size:.875rem;text-transform:uppercase;letter-spacing:.5px;position:sticky;top:0;z-index:5}.port-forwarding-table th:after{content:"";position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(243,207,152,.3),transparent)}.port-forwarding-table tbody tr:nth-child(2n){background:linear-gradient(135deg,#201813,#201813cc)}.port-forwarding-table tbody tr:nth-child(odd){background:linear-gradient(135deg,#1a1411,#1a1411cc)}.port-forwarding-table tbody tr:hover{background:linear-gradient(135deg,#33261f,#33261fe6);transform:scale(1.01);box-shadow:0 4px 12px #0000004d}.port-forwarding-table tbody tr:hover td{border-color:#f3cf9833}.modal-overlay{position:fixed;inset:0;display:grid;place-items:center;background:#0000008c;z-index:50}.modal-card{width:min(680px,92vw);background:#221a15;border:1px solid #3a2d24;border-radius:14px;box-shadow:0 12px 36px #00000080}.modal-header{padding:14px 16px;border-bottom:1px solid #3a2d24;display:flex;justify-content:space-between;align-items:center}.modal-close-btn{background:transparent;border:none;color:#b9a796;cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.modal-close-btn:hover{background:#ffffff1a;color:#f3cf98}.modal-header h3{margin:0;color:#f3cf98}.modal-body{padding:16px;display:grid;gap:12px}.modal-footer{padding:14px 16px;border-top:1px solid #3a2d24;display:flex;justify-content:flex-end;gap:10px}.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}@media(max-width:720px){.grid-2,.grid-3{grid-template-columns:1fr}}.port-forwarding-table .btn{margin:0;min-width:60px}.port-forwarding-table .btn+.btn{margin-left:6px}.modal-footer .btn-group{margin-left:auto}.modal-footer .btn{min-width:80px}.port-forwarding-container .btn{margin-bottom:16px}.form-control{width:100%;padding:10px 12px;background-color:#2a201b;border:1px solid #3a2d24;border-radius:6px;color:#f1e6d8;font-size:14px;transition:all .2s cubic-bezier(.4,0,.2,1)}.form-control:focus{outline:none;border-color:#d6a77a;box-shadow:0 0 0 3px #d6a77a33}.form-control::-moz-placeholder{color:#b9a796}.form-control::placeholder{color:#b9a796}label{display:block;margin-bottom:6px;color:#f3cf98;font-size:14px;font-weight:500}@media(max-width:768px){.btn{padding:12px 16px;font-size:16px}.btn-sm{padding:8px 14px;font-size:14px}.btn-group{flex-direction:column;gap:8px;width:100%}.btn-group .btn{width:100%}.modal-footer{flex-direction:column-reverse;gap:8px}.modal-footer .btn{width:100%}.port-forwarding-table .btn{padding:6px 8px;font-size:12px}}.form-control-error{border-color:#d9534f!important;box-shadow:0 0 0 3px #d9534f33!important}.form-control-error:focus{border-color:#d9534f!important;box-shadow:0 0 0 3px #d9534f4d!important}.field-error{color:#d9534f;font-size:.875rem;margin-top:4px;font-weight:500;display:flex;align-items:center;gap:4px}.field-error:before{content:"⚠️";font-size:.75rem}.field-success{color:#5cb85c;font-size:.875rem;margin-top:4px;font-weight:500;display:flex;align-items:center;gap:4px}.field-success:before{content:"✅";font-size:.75rem}.form-group{position:relative}.form-group.has-error .form-control{border-color:#d9534f;box-shadow:0 0 0 3px #d9534f33}.form-group.has-success .form-control{border-color:#5cb85c;box-shadow:0 0 0 3px #5cb85c33}.form-control-feedback{position:absolute;top:50%;right:12px;transform:translateY(-50%);pointer-events:none}.form-control-feedback.error{color:#d9534f}.form-control-feedback.success{color:#5cb85c}.port-forwarding-controls{margin-bottom:1.5rem;padding:1.25rem;background:linear-gradient(135deg,rgba(var(--cookie-background),.9),rgba(var(--cookie-primary-rgb),.01));border-radius:14px;border:1px solid var(--cookie-border);box-shadow:0 2px 16px #0000000a,0 1px 2px #0000000f;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);position:relative;z-index:5}.port-forwarding-controls-row{display:flex;gap:1.5rem;align-items:center;flex-wrap:wrap;position:relative}.port-forwarding-controls-row:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--cookie-border),transparent)}.sort-indicator{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:rgba(var(--cookie-primary-rgb),.1);border:1px solid rgba(var(--cookie-primary-rgb),.2);border-radius:8px;font-size:.875rem;color:var(--cookie-primary);white-space:nowrap}.sort-indicator-text{font-weight:500}.sort-clear-btn{display:flex;align-items:center;justify-content:center;width:1.25rem;height:1.25rem;border:none;border-radius:50%;background:transparent;color:var(--cookie-primary);cursor:pointer;transition:all .2s ease;font-size:.75rem;line-height:1}.sort-clear-btn:hover{background:rgba(var(--cookie-primary-rgb),.2);transform:scale(1.1)}@media(max-width:1024px){.port-forwarding-title-section{flex:1}.page-title{color:#f3cf98;font-size:2rem;font-weight:700;margin:0 0 10px;background:linear-gradient(135deg,#f3cf98,#d6a77a);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}.page-description{color:#b9a796;margin-bottom:0;font-size:1rem}.port-forwarding-controls-row{flex-direction:column;align-items:stretch}.port-forwarding-controls-row>*{width:100%}}@media(max-width:768px){.port-forwarding-controls{margin-bottom:1rem}.port-forwarding-controls-row{gap:.75rem}.port-forwarding-header{margin-bottom:1rem}.sort-indicator{font-size:.75rem;padding:.375rem .5rem}.sort-indicator-text{display:none}.sort-clear-btn{width:1rem;height:1rem;font-size:.625rem}}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;padding:24px}.login-box{width:100%;max-width:420px;background:var(--cookie-surface);border:1px solid var(--cookie-border);border-radius:16px;box-shadow:0 12px 36px #0006;padding:24px 22px}.login-brand{display:flex;align-items:center;gap:12px;margin-bottom:6px}.login-logo{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;background:radial-gradient(circle at 30% 30%,#f3cf98,#d6a77a 60%,#b98658);border:1px solid var(--cookie-border);box-shadow:0 6px 18px #00000059;animation:logo-pop .9s ease both}@keyframes logo-pop{0%{transform:scale(.85);opacity:0}to{transform:scale(1);opacity:1}}.login-title{font-size:1.2rem;font-weight:800;margin:0;color:var(--cookie-accent-2)}.login-subtitle{margin:0 0 16px 54px;font-size:.9rem;color:var(--cookie-muted)}.form-group{margin-bottom:12px}label{display:block;margin-bottom:6px;color:var(--cookie-muted);font-size:.9rem}.form-control{width:100%;padding:12px;border-radius:10px;border:1px solid var(--cookie-border);background:#1f1915;color:var(--cookie-text);transition:border-color .15s,box-shadow .15s,background .15s}.form-control:focus{outline:none;border-color:var(--cookie-border-primary);box-shadow:0 0 0 3px #d6a77a40}.login-button{width:100%;padding:12px 14px;border:none;border-radius:10px;background:linear-gradient(90deg,#d6a77a,#f3cf98);color:#1b1410;font-weight:800;letter-spacing:.3px;cursor:pointer;transition:transform .06s ease,filter .2s}.login-button:hover{filter:brightness(1.05)}.login-button:active{transform:translateY(1px)}.error-message{margin-top:6px;margin-bottom:12px;color:var(--cookie-danger);font-size:.875rem;font-weight:500;text-align:center;padding:12px;background:#d96b6b1a;border:1px solid rgba(217,107,107,.2);border-radius:8px;max-height:30px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.modal-overlay{position:fixed;inset:0;background-color:#000000bf;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:fadeIn .2s ease-out}.modal-content{background:linear-gradient(135deg,#2a201b,#33261f);border:1px solid #3a2d24;border-radius:16px;width:100%;max-width:800px;max-height:90vh;overflow-y:auto;box-shadow:0 24px 48px #00000080,0 0 0 1px #f3cf980d;animation:modalSlideIn .25s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(20px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.form-control{width:100%;padding:10px 14px;background:linear-gradient(135deg,#201813,#201813cc);border:1px solid #3a2d24;border-radius:8px;color:#f1e6d8;font-size:14px;transition:all .2s}.form-control:focus{outline:none;border-color:#d6a77a;box-shadow:0 0 0 3px #d6a77a1a}.form-control::-moz-placeholder{color:#6b5a4d}.form-control::placeholder{color:#6b5a4d}.form-select{width:100%;padding:10px 14px;background:linear-gradient(135deg,#201813,#201813cc);border:1px solid #3a2d24;border-radius:8px;color:#f1e6d8;font-size:14px;cursor:pointer;transition:all .2s}.form-select:focus{outline:none;border-color:#d6a77a;box-shadow:0 0 0 3px #d6a77a1a}.form-select option{background:#2a201b;color:#f1e6d8;padding:8px}.form-checkbox-label{display:flex;align-items:center;gap:10px;color:#f1e6d8;font-size:14px;cursor:pointer}.form-checkbox-label input[type=checkbox]{width:18px;height:18px;accent-color:#d6a77a;cursor:pointer}.compose-editor{width:100%;padding:14px 16px;background:#161110;border:1px solid #3a2d24;border-radius:10px;color:#e0d4c8;font-family:Monaco,Menlo,Ubuntu Mono,Consolas,monospace;font-size:13px;line-height:1.6;resize:vertical;min-height:300px;-moz-tab-size:2;-o-tab-size:2;tab-size:2;transition:border-color .2s,box-shadow .2s}.compose-editor:focus{outline:none;border-color:#d6a77a;box-shadow:0 0 0 3px #d6a77a1a,inset 0 0 20px #0003}.compose-editor::-moz-placeholder{color:#5a4a3d}.compose-editor::placeholder{color:#5a4a3d}.coolify-stats{margin-bottom:28px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px}.stat-card{background:linear-gradient(135deg,#2a201b,#33261f);border:1px solid #3a2d24;border-radius:14px;padding:20px;text-align:center;transition:all .2s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#d6a77a,#f3cf98);opacity:.6}.stat-card:hover{border-color:#4a3a2f;transform:translateY(-2px);box-shadow:0 8px 24px #0000004d}.stat-value{font-size:2.25rem;font-weight:700;color:#f3cf98;margin-bottom:4px;line-height:1.2}.stat-label{font-size:.8rem;color:#b9a796;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.coolify-tabs{display:flex;gap:4px;margin-bottom:24px;border-bottom:2px solid #3a2d24;padding-bottom:0}.coolify-tab{display:inline-flex;align-items:center;gap:8px;padding:12px 20px;font-size:14px;font-weight:500;color:#8a7a6d;background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;cursor:pointer;transition:all .2s;border-radius:8px 8px 0 0}.coolify-tab:hover{color:#f1e6d8;background:#d6a77a0d}.coolify-tab-active{color:#f3cf98;border-bottom-color:#d6a77a;background:#d6a77a14}.coolify-tab svg{width:16px;height:16px}.coolify-content{animation:fadeIn .2s ease-out}.resource-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:16px}.resource-card{background:linear-gradient(135deg,#1b1410,#221a15);border:1px solid #3a2d24;border-radius:12px;padding:18px;transition:all .2s cubic-bezier(.4,0,.2,1);position:relative}.resource-card:hover{border-color:#4a3a2f;transform:translateY(-2px);box-shadow:0 8px 24px #00000040}.resource-card-top{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:12px}.resource-name{font-size:1rem;font-weight:600;color:#f1e6d8;margin:0;display:flex;align-items:center;gap:8px}.resource-name svg{width:16px;height:16px;color:#d6a77a;flex-shrink:0}.resource-description{color:#8a7a6d;font-size:.85rem;margin:0 0 10px;line-height:1.4}.resource-meta{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:14px;padding-bottom:14px;border-bottom:1px solid rgba(58,45,36,.6)}.resource-meta-tag{display:inline-flex;align-items:center;gap:5px;font-size:.75rem;color:#6b5a4d;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.resource-meta-tag svg{width:12px;height:12px;flex-shrink:0}.resource-actions{display:flex;gap:8px;flex-wrap:wrap}.resource-actions .btn-sm{flex:1;min-width:0;justify-content:center}.service-type-badge{background:#9b59b626;border:1px solid rgba(155,89,182,.3);color:#b07cd8;padding:3px 10px;border-radius:20px;font-size:.75rem;font-weight:600;white-space:nowrap;text-transform:capitalize;letter-spacing:.3px}.status-badge{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:20px;font-size:.75rem;font-weight:600;white-space:nowrap;text-transform:capitalize;letter-spacing:.3px}.status-badge-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.status-running{background:#88c07a26;border:1px solid rgba(136,192,122,.3);color:#88c07a}.status-running .status-badge-dot{background:#88c07a;box-shadow:0 0 6px #88c07a80;animation:pulse 2s ease-in-out infinite}.status-stopped{background:#d9534f26;border:1px solid rgba(217,83,79,.3);color:#d96b6b}.status-stopped .status-badge-dot{background:#d96b6b;box-shadow:0 0 6px #d9534f80}.status-deploying{background:#4a90e226;border:1px solid rgba(74,144,226,.3);color:#4a90e2}.status-deploying .status-badge-dot{background:#4a90e2;box-shadow:0 0 6px #4a90e280;animation:pulse 2s ease-in-out infinite}.status-unknown{background:#f0ad4e26;border:1px solid rgba(240,173,78,.3);color:#f0ad4e}.status-unknown .status-badge-dot{background:#f0ad4e;box-shadow:0 0 6px #f0ad4e80}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 24px;text-align:center}.empty-state-icon{width:80px;height:80px;margin-bottom:20px;color:#4a3a2f}.empty-state-title{font-size:1.25rem;font-weight:600;color:#f1e6d8;margin:0 0 8px}.empty-state-text{color:#8a7a6d;font-size:.9rem;margin:0 0 24px;max-width:400px}.error-banner{background:#d9534f1a;border:1px solid rgba(217,83,79,.3);border-radius:12px;padding:14px 20px;margin-bottom:20px;display:flex;align-items:center;justify-content:space-between;gap:12px;animation:fadeIn .2s ease-out}.error-banner-text{color:#d96b6b;font-size:.9rem;font-weight:500;display:flex;align-items:center;gap:8px}.error-banner-text svg{flex-shrink:0}.error-banner-close{background:none;border:none;color:#d96b6b;cursor:pointer;padding:4px;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .2s}.error-banner-close:hover{background:#d9534f26}.coolify-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:20px}.loading-spinner{width:48px;height:48px;border:3px solid #3a2d24;border-top:3px solid #d6a77a;border-radius:50%;animation:spin .8s linear infinite}.loading-text{color:#b9a796;font-size:.9rem}@media(max-width:768px){.resource-grid{grid-template-columns:1fr}.stats-grid{grid-template-columns:repeat(2,1fr);gap:12px}.resource-actions{flex-direction:column}.resource-actions .btn-sm{width:100%}.coolify-tabs{flex-direction:column;gap:0}.coolify-tab{border-bottom:none;border-left:2px solid transparent;border-radius:0;margin-bottom:0}.coolify-tab-active{border-bottom-color:transparent;border-left-color:#d6a77a}.modal-content{margin:10px;max-width:none;border-radius:12px}.modal-header,.modal-body,.modal-footer{padding-left:16px;padding-right:16px}}.deploying-overlay{position:absolute;inset:0;background:#1b1410d9;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;border-radius:12px;z-index:5}.deploying-content{display:flex;flex-direction:column;align-items:center;gap:10px}.deploying-spinner{width:28px;height:28px;border:2px solid #3a2d24;border-top:2px solid #d6a77a;border-radius:50%;animation:spin .8s linear infinite}.deploying-text{color:#d6a77a;font-size:.8rem;font-weight:600}.confirm-dialog{text-align:center;padding:16px 0}.confirm-dialog-icon{width:56px;height:56px;margin:0 auto 16px;color:#d96b6b;opacity:.9}.confirm-dialog-text{color:#f1e6d8;font-size:1rem;margin:0 0 8px}.confirm-dialog-subtext{color:#8a7a6d;font-size:.85rem;margin:0}.aapanel-proxy-shell{display:grid;gap:24px}.aapanel-proxy-layout{display:grid;grid-template-columns:minmax(0,1.6fr) minmax(280px,.9fr);gap:24px;align-items:start}.aapanel-proxy-card{padding:24px}.aapanel-proxy-form{display:grid;gap:20px}.aapanel-proxy-toggle-row{display:grid;gap:12px}.aapanel-proxy-toggle{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;border:1px solid rgba(243,207,152,.15);border-radius:14px;background:#1e18148c}.aapanel-proxy-toggle input{margin-top:4px}.aapanel-proxy-toggle strong,.aapanel-proxy-step-title,.aapanel-proxy-result h3{color:#f6e3c4}.aapanel-proxy-toggle span,.aapanel-proxy-step p,.aapanel-proxy-result li,.aapanel-proxy-meta-item,.aapanel-proxy-domain-hint,.aapanel-proxy-note{color:#c9b7a4}.aapanel-proxy-domain-hint{margin-top:8px;font-size:.92rem}.aapanel-proxy-preview{background:linear-gradient(145deg,#2e241cf0,#1b1511f0);border:1px solid rgba(243,207,152,.12);border-radius:18px;padding:24px;position:sticky;top:24px}.aapanel-proxy-preview code{display:block;word-break:break-word}.aapanel-proxy-steps,.aapanel-proxy-meta,.aapanel-proxy-result-list{display:grid;gap:14px}.aapanel-proxy-step,.aapanel-proxy-meta-item{padding:14px 16px;border-radius:14px;background:#ffffff08;border:1px solid rgba(243,207,152,.08)}.aapanel-proxy-step-number{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:999px;background:#f3cf98;color:#1d1713;font-weight:700;margin-bottom:10px}.aapanel-proxy-result{padding:20px 22px}.aapanel-proxy-result ul{margin:0;padding-left:18px}.aapanel-proxy-site-code{background:#d6a77a1a;border:1px solid rgba(214,167,122,.2);padding:2px 8px;border-radius:4px;color:#f3cf98}@media(max-width:1100px){.aapanel-proxy-layout{grid-template-columns:1fr}.aapanel-proxy-preview{position:static}}.page-title{color:#f3cf98;margin-bottom:10px;font-size:2rem;font-weight:700}.page-description{color:#b9a796;margin-bottom:20px;font-size:1rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 16px;font-size:14px;font-weight:500;line-height:1.4;text-decoration:none;border:1px solid transparent;border-radius:8px;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);white-space:nowrap;-webkit-user-select:none;-moz-user-select:none;user-select:none;position:relative;overflow:hidden}.btn:focus{outline:none;box-shadow:0 0 0 3px #f3cf984d}.btn:focus:not(:focus-visible){box-shadow:none}.btn:disabled{opacity:.6;cursor:not-allowed;pointer-events:none}.btn-sm{padding:6px 12px;font-size:12px;border-radius:6px}.btn-lg{padding:12px 20px;font-size:16px;border-radius:10px}.btn-primary{background-color:#d6a77a;color:#1b1410;border-color:#d6a77a}.btn-primary:hover:not(:disabled){background-color:#c4996a;border-color:#c4996a;transform:translateY(-1px);box-shadow:0 4px 12px #d6a77a4d}.btn-primary:active{transform:translateY(0)}.btn-secondary{background-color:#2a201b;color:#f1e6d8;border-color:#3a2d24}.btn-secondary:hover:not(:disabled){background-color:#33261f;border-color:#4a3a2f;transform:translateY(-1px);box-shadow:0 4px 12px #2a201b4d}.btn-secondary:active{transform:translateY(0)}.btn-info{background-color:#4a90e2;color:#fff;border-color:#4a90e2}.btn-info:hover:not(:disabled){background-color:#357abd;border-color:#357abd;transform:translateY(-1px);box-shadow:0 4px 12px #4a90e24d}.btn-info:active{transform:translateY(0)}.btn-success{background-color:#5cb85c;color:#fff;border-color:#5cb85c}.btn-success:hover:not(:disabled){background-color:#4cae4c;border-color:#4cae4c;transform:translateY(-1px);box-shadow:0 4px 12px #5cb85c4d}.btn-success:active{transform:translateY(0)}.btn-warning{background-color:#f0ad4e;color:#1b1410;border-color:#f0ad4e}.btn-warning:hover:not(:disabled){background-color:#ec971f;border-color:#ec971f;transform:translateY(-1px);box-shadow:0 4px 12px #f0ad4e4d}.btn-warning:active{transform:translateY(0)}.btn-danger{background-color:#d9534f;color:#fff;border-color:#d9534f}.btn-danger:hover:not(:disabled){background-color:#c9302c;border-color:#c9302c;transform:translateY(-1px);box-shadow:0 4px 12px #d9534f4d}.btn-danger:active{transform:translateY(0)}.btn-outline{background-color:transparent;border-color:#d6a77a;color:#d6a77a}.btn-outline:hover:not(:disabled){background-color:#d6a77a;color:#1b1410;transform:translateY(-1px);box-shadow:0 4px 12px #d6a77a4d}.btn-outline:active{transform:translateY(0)}.btn-group{display:flex;gap:8px;align-items:center}.btn-group .btn{flex:none}@media(max-width:768px){.btn{padding:12px 16px;font-size:16px}.btn-sm{padding:8px 14px;font-size:14px}.btn-group{flex-direction:column;gap:8px;width:100%}.btn-group .btn{width:100%}}.btn-loading{position:relative;color:transparent}.btn-loading:after{content:"";position:absolute;width:16px;height:16px;top:50%;left:50%;transform:translate(-50%,-50%);border:2px solid transparent;border-top:2px solid currentColor;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:translate(-50%,-50%) rotate(0)}to{transform:translate(-50%,-50%) rotate(360deg)}}.btn-icon{padding:8px;width:36px;height:36px}.btn-icon svg{width:18px;height:18px}@media(max-width:1024px){.page-title{color:#f3cf98;font-size:2rem;font-weight:700;margin:0 0 10px;background:linear-gradient(135deg,#f3cf98,#d6a77a);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}.page-description{color:#b9a796;margin-bottom:0;font-size:1rem}}.server-table{width:100%;border-collapse:collapse;border-spacing:0;border-radius:12px;overflow:visible;box-shadow:0 4px 16px #0003;table-layout:auto}.server-table th,.server-table td{border:1px solid #3a2d24;padding:14px 16px;text-align:left;color:#f1e6d8;transition:all .2s cubic-bezier(.4,0,.2,1);position:relative}.server-table th{background:linear-gradient(135deg,#2a201b,#33261f);color:#f3cf98;font-weight:700;font-size:.875rem;text-transform:uppercase;letter-spacing:.5px;position:sticky;top:0;z-index:5}.server-table tbody tr:nth-child(2n){background:linear-gradient(135deg,#201813,#201813cc)}.server-table .btn{margin:0;min-width:60px}.server-table .btn+.btn{margin-left:12px}.modal-overlay{position:fixed;inset:0;background-color:#000000bf;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content{background:linear-gradient(135deg,#2a201b,#33261f);border:1px solid #3a2d24;border-radius:12px;width:100%;max-width:1000px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 40px #00000080}.modal-header{padding:24px 24px 0;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #3a2d24;margin-bottom:24px}.modal-title{color:#f3cf98;font-size:1.5rem;font-weight:700;margin:0 0 10px}.modal-close{background:none;border:none;color:#b9a796;cursor:pointer;padding:4px;border-radius:6px;transition:all .2s}.modal-close:hover{background-color:#d983791a;color:#d9534f}.modal-body{padding:0 24px}.modal-footer{padding:24px;border-top:1px solid #3a2d24;display:flex;gap:12px;justify-content:flex-end;margin-top:24px}.form-group{margin-bottom:20px}.form-label{display:block;color:#f1e6d8;font-size:14px;font-weight:500;margin-bottom:8px}.form-input,.form-select{width:100%;padding:12px 16px;background:linear-gradient(135deg,#201813,#201813cc);border:1px solid #3a2d24;border-radius:8px;color:#f1e6d8;font-size:14px;transition:all .2s}.form-input:focus,.form-select:focus{outline:none;border-color:#d6a77a;box-shadow:0 0 0 3px #d6a77a1a}.form-input::-moz-placeholder{color:#b9a796}.form-input::placeholder{color:#b9a796}.form-select{cursor:pointer}.servers-stats{margin-bottom:24px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.stat-card{background:linear-gradient(135deg,#2a201b,#33261f);border:1px solid #3a2d24;border-radius:12px;padding:20px;text-align:center;transition:all .2s}.stat-value{font-size:2.5rem;font-weight:700;color:#f3cf98;margin-bottom:4px}.stat-label{font-size:.875rem;color:#b9a796;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.server-table td{vertical-align:middle}@media(max-width:768px){.modal-content{margin:20px;max-width:none}.modal-header,.modal-body,.modal-footer{padding-left:20px;padding-right:20px}.stats-grid{grid-template-columns:repeat(2,1fr);gap:12px}.stat-card{padding:16px}.stat-value{font-size:2rem}}@media(max-width:480px){.stats-grid{grid-template-columns:1fr}.modal-footer{flex-direction:column}.modal-footer .btn{width:100%}}.font-medium{font-weight:500}.font-mono{font-family:Monaco,Menlo,Ubuntu Mono,monospace}.text-xs{font-size:.75rem}.text-sm{font-size:.875rem}.text-gray-400{color:#9ca3af}.text-green-400{color:#4ade80}.text-red-400{color:#f87171}.text-yellow-400{color:#fbbf24}.text-blue-400{color:#60a5fa}.inline-flex{display:inline-flex}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px;margin-bottom:16px}.form-control{width:100%;padding:8px 12px;background:linear-gradient(135deg,#201813,#201813cc);border:1px solid #3a2d24;border-radius:6px;color:#f1e6d8;font-size:14px;transition:all .2s}.form-control:focus{outline:none;border-color:#d6a77a;box-shadow:0 0 0 2px #d6a77a1a}.form-control-error{border-color:#d9534f!important;box-shadow:0 0 0 2px #d9534f1a!important}.field-error{color:#d9534f;font-size:12px;margin-top:4px}.ip-dropdown-error{border-color:#d9534f!important;box-shadow:0 0 0 2px #d9534f1a!important}@media(max-width:768px){.grid-2,.grid-3{grid-template-columns:1fr;gap:12px}}.px-2\.5{padding-left:.625rem;padding-right:.625rem}.py-0\.5{padding-top:.125rem;padding-bottom:.125rem}.w-2{width:.5rem}.h-2{height:.5rem}.mr-2{margin-right:.5rem}.rounded-full{border-radius:9999px}.bg-green-500\/20{background-color:#22c55e33}.bg-red-500\/20{background-color:#ef444433}.bg-yellow-500\/20{background-color:#f59e0b33}.bg-gray-500\/20{background-color:#6b728033}.border{border-width:1px}.border-green-500\/30{border-color:#22c55e4d}.border-red-500\/30{border-color:#ef44444d}.border-yellow-500\/30{border-color:#f59e0b4d}.border-gray-500\/30{border-color:#6b72804d}.ports-display{display:flex;flex-wrap:wrap;gap:4px;max-width:100%}.port-item{display:inline-flex;align-items:center;background:linear-gradient(135deg,#2a201b,#33261f);border:1px solid #3a2d24;border-radius:6px;padding:2px 8px;font-size:12px;color:#f1e6d8;white-space:nowrap}.port-number{font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-weight:600;color:#d6a77a}.port-protocol{color:#b9a796;margin-left:4px;font-weight:500;text-transform:uppercase}.port-item-button{display:inline-flex;align-items:center;background:linear-gradient(135deg,#2a201b,#33261f);border:1px solid #3a2d24;border-radius:6px;padding:2px 8px;font-size:12px;color:#f1e6d8;white-space:nowrap;cursor:pointer;transition:all .2s ease;text-decoration:none}.port-item-button:hover{background:linear-gradient(135deg,#33261f,#3a2d24);border-color:#d6a77a;transform:translateY(-1px);box-shadow:0 2px 8px #d6a77a33}.port-item-button:active{transform:translateY(0);box-shadow:0 1px 4px #d6a77a1a}.port-item-button:focus{outline:none;border-color:#d6a77a;box-shadow:0 0 0 2px #d6a77a4d}.ports-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.ports-table{border:1px solid #3a2d24;border-radius:8px;overflow:hidden;background:linear-gradient(135deg,#201813,#201813cc)}.modal-table{width:100%;border-collapse:collapse;font-size:14px}.modal-table th{background:linear-gradient(135deg,#2a201b,#33261f);color:#f3cf98;font-weight:600;text-align:left;padding:12px 16px;border-bottom:1px solid #3a2d24}.modal-table th:nth-child(1),.modal-table th:nth-child(2),.modal-table th:nth-child(3),.modal-table th:nth-child(6){width:150px;min-width:150px;max-width:150px}.modal-table th:nth-child(4),.modal-table th:nth-child(5){width:auto;min-width:150px}.modal-table td{padding:12px 16px;border-bottom:1px solid #3a2d24;vertical-align:middle}.modal-table tbody tr:nth-child(2n){background:#2a201b4d}.modal-table tbody tr:hover{background:#d6a77a0d}.port-input{width:100%;padding:8px 12px;background:linear-gradient(135deg,#201813,#201813cc);border:1px solid #3a2d24;border-radius:6px;color:#f1e6d8;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:14px;transition:all .2s}.port-input:focus{outline:none;border-color:#d6a77a;box-shadow:0 0 0 2px #d6a77a1a}.port-input::-moz-placeholder{color:#9ca3af}.port-input::placeholder{color:#9ca3af}.protocol-select{width:100%;padding:8px 12px;background:linear-gradient(135deg,#201813,#201813cc);border:1px solid #3a2d24;border-radius:6px;color:#f1e6d8;font-size:14px;cursor:pointer;transition:all .2s;min-width:120px}.protocol-select:focus{outline:none;border-color:#d6a77a;box-shadow:0 0 0 2px #d6a77a1a}.protocol-select option{background:#2a201b;color:#f1e6d8;padding:8px}.empty-ports{text-align:center;padding:24px;color:#9ca3af;font-style:italic;background:#2a201b33}.btn:disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.btn:disabled:hover{transform:none;box-shadow:none}@media(max-width:768px){.ports-header{flex-direction:column;align-items:stretch;gap:12px}.modal-table{font-size:12px}.modal-table th,.modal-table td{padding:8px 12px}.protocol-select{min-width:100px}}@media(max-width:480px){.ports-display{flex-direction:column;align-items:flex-start}.port-item{margin-bottom:4px}}.kekslabmap-root{--bg-0: #080808;--bg-1: #0f0f0f;--bg-2: #161616;--bg-3: #1f1f1f;--bg-4: #2a2a2a;--border-subtle: rgba(255, 255, 255, .06);--border-muted: rgba(255, 255, 255, .1);--border-strong: rgba(255, 255, 255, .18);--text-1: rgba(255, 255, 255, .92);--text-2: rgba(255, 255, 255, .6);--text-3: rgba(255, 255, 255, .35);--accent: #6366f1;--accent-dim: #4f46e5;--accent-glow: rgba(99, 102, 241, .2);--node-server: #60a5fa;--node-vm: #34d399;--node-container: #a78bfa;--node-app: #c084fc;--node-router: #f87171;--node-switch: #fb923c;--node-vpn: #a3e635;--node-external: #6b7280;--status-online: #22c55e;--status-offline: #ef4444;--status-unknown: #4b5563;--font-sans: "Inter", system-ui, -apple-system, sans-serif;--font-mono: "JetBrains Mono", monospace;--ease: cubic-bezier(.4, 0, .2, 1);--duration-fast: .12s;--duration-normal: .2s;--sidebar-width: 200px;--bg-primary: var(--bg-0);--bg-secondary: var(--bg-2);--bg-tertiary: var(--bg-3);--bg-hover: var(--bg-4);--border-color: var(--border-subtle);--border-focus: var(--accent);--text-primary: var(--text-1);--text-secondary: var(--text-2);--text-muted: var(--text-3);--accent-blue: var(--accent);--accent-blue-dim: var(--accent-dim);--accent-green: var(--status-online);--accent-red: var(--status-offline);--font-heading: var(--font-sans)}.kekslabmap-root *{margin:0;padding:0;box-sizing:border-box}.kekslabmap-root{height:100%;width:100%}.kekslabmap-root{font-family:var(--font-sans);font-size:13px;line-height:1.5;color:var(--text-1);background-color:var(--bg-0);overflow:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.kekslabmap-root h1,.kekslabmap-root h2,.kekslabmap-root h3,.kekslabmap-root h4,.kekslabmap-root h5,.kekslabmap-root h6{font-family:var(--font-sans);font-weight:600;letter-spacing:-.01em;color:var(--text-1)}.kekslabmap-root h1{font-size:20px}.kekslabmap-root h2{font-size:15px}.kekslabmap-root h3{font-size:13px}.kekslabmap-root a{color:var(--accent);text-decoration:none;transition:color var(--duration-fast) var(--ease)}.kekslabmap-root a:hover{color:var(--accent-dim)}.kekslabmap-root button{font-family:var(--font-sans);font-size:13px;font-weight:500;cursor:pointer;border:1px solid var(--border-subtle);background:var(--bg-3);color:var(--text-2);padding:7px 14px;border-radius:6px;transition:background var(--duration-fast) var(--ease),border-color var(--duration-fast) var(--ease),color var(--duration-fast) var(--ease)}.kekslabmap-root button:hover{background:var(--bg-4);border-color:var(--border-muted);color:var(--text-1)}.kekslabmap-root button:active{background:var(--bg-4)}.kekslabmap-root button:disabled{opacity:.4;cursor:not-allowed}.kekslabmap-root .btn-primary{background:var(--accent);border-color:var(--accent);color:#fff}.kekslabmap-root .btn-primary:hover{background:var(--accent-dim);border-color:var(--accent-dim);color:#fff;box-shadow:0 0 0 3px var(--accent-glow)}.kekslabmap-root .btn-ghost{background:transparent;border-color:transparent;color:var(--text-2)}.kekslabmap-root .btn-ghost:hover{background:var(--bg-3);border-color:var(--border-subtle);color:var(--text-1)}.kekslabmap-root .btn-danger{background:transparent;border-color:#ef44444d;color:var(--status-offline)}.kekslabmap-root .btn-danger:hover{background:#ef44441a;border-color:var(--status-offline);color:var(--status-offline)}.kekslabmap-root .btn-secondary{background:transparent;border-color:var(--border-subtle);color:var(--text-2)}.kekslabmap-root .btn-secondary:hover{border-color:var(--border-muted);color:var(--text-1)}.kekslabmap-root input,.kekslabmap-root textarea,.kekslabmap-root select{font-family:var(--font-sans);font-size:13px;background:var(--bg-3);border:1px solid var(--border-subtle);color:var(--text-1);padding:8px 12px;border-radius:6px;outline:none;transition:border-color var(--duration-fast) var(--ease),box-shadow var(--duration-fast) var(--ease)}.kekslabmap-root input:focus,.kekslabmap-root textarea:focus,.kekslabmap-root select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.kekslabmap-root input::-moz-placeholder,.kekslabmap-root textarea::-moz-placeholder{color:var(--text-3)}.kekslabmap-root input::placeholder,.kekslabmap-root textarea::placeholder{color:var(--text-3)}.kekslabmap-root .app-layout{display:flex;height:100vh;width:100vw}.kekslabmap-root .main-content{flex:1;display:flex;flex-direction:column;overflow:hidden;animation:fadeIn var(--duration-normal) var(--ease)}.kekslabmap-root .page-container{flex:1;overflow:hidden;position:relative}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes pulseDot{0%,to{opacity:1}50%{opacity:.4}}@keyframes dash{to{stroke-dashoffset:-20}}.kekslabmap-root ::-webkit-scrollbar{width:6px;height:6px}.kekslabmap-root ::-webkit-scrollbar-track{background:transparent}.kekslabmap-root ::-webkit-scrollbar-thumb{background:var(--border-muted);border-radius:3px}.kekslabmap-root ::-webkit-scrollbar-thumb:hover{background:var(--border-strong)}.kekslabmap-root .status-dot{width:6px;height:6px;border-radius:50%;display:inline-block;flex-shrink:0}.kekslabmap-root .status-dot.online{background:var(--status-online);animation:pulseDot 2.5s var(--ease) infinite}.kekslabmap-root .status-dot.offline{background:var(--status-offline)}.kekslabmap-root .status-dot.unknown{background:var(--status-unknown)}.kekslabmap-root .status-badge{display:inline-flex;align-items:center;gap:5px;padding:3px 8px;border-radius:9999px;font-size:11px;font-weight:500}.kekslabmap-root .status-badge.online{background:#22c55e1a;color:var(--status-online);border:1px solid rgba(34,197,94,.2)}.kekslabmap-root .status-badge.offline{background:#ef44441a;color:var(--status-offline);border:1px solid rgba(239,68,68,.2)}.kekslabmap-root .status-badge.unknown{background:#4b556326;color:var(--text-3);border:1px solid var(--border-subtle)}.kekslabmap-root .tag{display:inline-block;font-size:11px;padding:2px 7px;background:var(--bg-3);border:1px solid var(--border-subtle);color:var(--text-2);border-radius:4px;margin:2px}.kekslabmap-root .card{background:var(--bg-2);border:1px solid var(--border-subtle);border-radius:10px;padding:20px}.kekslabmap-root .card-header{display:flex;align-items:center;justify-content:space-between;padding-bottom:14px;border-bottom:1px solid var(--border-subtle);margin-bottom:14px}.kekslabmap-root .type-badge{display:inline-flex;align-items:center;gap:5px;padding:3px 8px;border-radius:5px;font-size:11px;font-weight:500}.kekslabmap-root .type-badge.server{background:#60a5fa1a;color:var(--node-server);border:1px solid rgba(96,165,250,.2)}.kekslabmap-root .type-badge.vm{background:#34d3991a;color:var(--node-vm);border:1px solid rgba(52,211,153,.2)}.kekslabmap-root .type-badge.container{background:#a78bfa1a;color:var(--node-container);border:1px solid rgba(167,139,250,.2)}.kekslabmap-root .type-badge.application{background:#c084fc1a;color:var(--node-app);border:1px solid rgba(192,132,252,.2)}.kekslabmap-root .type-badge.router{background:#f871711a;color:var(--node-router);border:1px solid rgba(248,113,113,.2)}.kekslabmap-root .type-badge.switch{background:#fb923c1a;color:var(--node-switch);border:1px solid rgba(251,146,60,.2)}.kekslabmap-root .type-badge.vpn_server{background:#a3e6351a;color:var(--node-vpn);border:1px solid rgba(163,230,53,.2)}.kekslabmap-root .type-badge.external_network{background:#6b72801a;color:var(--node-external);border:1px solid rgba(107,114,128,.2)}.kekslabmap-root .icon-container{display:inline-flex;align-items:center;justify-content:center;padding:8px;border-radius:8px}.kekslabmap-root .icon-container.server{background:#60a5fa1f;color:var(--node-server)}.kekslabmap-root .icon-container.vm{background:#34d3991f;color:var(--node-vm)}.kekslabmap-root .icon-container.container{background:#a78bfa1f;color:var(--node-container)}.kekslabmap-root .icon-container.application{background:#c084fc1f;color:var(--node-app)}.kekslabmap-root .icon-container.router{background:#f871711f;color:var(--node-router)}.kekslabmap-root .icon-container.switch{background:#fb923c1f;color:var(--node-switch)}.kekslabmap-root .icon-container.vpn_server{background:#a3e6351f;color:var(--node-vpn)}.kekslabmap-root .icon-container.external_network{background:#6b72801f;color:var(--node-external)}.kekslabmap-root .form-group label{display:block;font-size:11px;font-weight:500;color:var(--text-3);margin-bottom:6px;letter-spacing:.02em}.kekslabmap-root .form-group textarea{min-height:80px;resize:vertical}.kekslabmap-root .form-row{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}.kekslabmap-root .empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center;color:var(--text-3)}.kekslabmap-root .empty-state svg{margin-bottom:16px;opacity:.3}.kekslabmap-root .loading{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-3)}.kekslabmap-root .section-header{display:flex;align-items:center;gap:8px;font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text-3);padding-bottom:10px;border-bottom:1px solid var(--border-subtle);margin-bottom:14px}.kekslabmap-root .list-item{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--bg-2);border:1px solid var(--border-subtle);border-radius:7px;cursor:pointer;transition:background var(--duration-fast) var(--ease),border-color var(--duration-fast) var(--ease)}.kekslabmap-root .list-item:hover{background:var(--bg-3);border-color:var(--border-muted)}.kekslabmap-root .react-flow__background{background-color:var(--bg-0)!important}.kekslabmap-root .react-flow__minimap{background:var(--bg-2)!important;border:1px solid var(--border-subtle)!important;border-radius:8px!important}.kekslabmap-root .react-flow__minimap-mask{fill:var(--accent-glow)!important}.kekslabmap-root .react-flow__controls{background:var(--bg-2)!important;border:1px solid var(--border-subtle)!important;border-radius:8px!important;overflow:hidden!important;box-shadow:none!important}.kekslabmap-root .react-flow__controls-button{display:flex!important;align-items:center!important;justify-content:center!important;width:32px!important;height:32px!important;padding:0!important;background:var(--bg-3)!important;border:0!important;border-bottom:1px solid var(--border-subtle)!important;border-radius:0!important;color:var(--text-2)!important;fill:var(--text-2)!important;transition:background var(--duration-fast) var(--ease) !important,color var(--duration-fast) var(--ease)!important}.kekslabmap-root .react-flow__controls-button:hover{background:var(--bg-4)!important;color:var(--text-1)!important;fill:var(--text-1)!important}.kekslabmap-root .react-flow__controls-button svg{width:16px!important;height:16px!important;stroke:currentColor!important;fill:currentColor!important}.kekslabmap-root .react-flow__controls-button:first-child{border-top-left-radius:8px!important;border-top-right-radius:8px!important}.kekslabmap-root .react-flow__controls-button:last-child{border-bottom:0!important;border-bottom-left-radius:8px!important;border-bottom-right-radius:8px!important}.kekslabmap-root .animated-edge{stroke-dasharray:5 5;animation:dash .5s linear infinite}.react-flow{direction:ltr;--xy-edge-stroke-default: #b1b1b7;--xy-edge-stroke-width-default: 1;--xy-edge-stroke-selected-default: #555;--xy-connectionline-stroke-default: #b1b1b7;--xy-connectionline-stroke-width-default: 1;--xy-attribution-background-color-default: rgba(255, 255, 255, .5);--xy-minimap-background-color-default: #fff;--xy-minimap-mask-background-color-default: rgba(240, 240, 240, .6);--xy-minimap-mask-stroke-color-default: transparent;--xy-minimap-mask-stroke-width-default: 1;--xy-minimap-node-background-color-default: #e2e2e2;--xy-minimap-node-stroke-color-default: transparent;--xy-minimap-node-stroke-width-default: 2;--xy-background-color-default: transparent;--xy-background-pattern-dots-color-default: #91919a;--xy-background-pattern-lines-color-default: #eee;--xy-background-pattern-cross-color-default: #e2e2e2;background-color:var(--xy-background-color, var(--xy-background-color-default));--xy-node-color-default: inherit;--xy-node-border-default: 1px solid #1a192b;--xy-node-background-color-default: #fff;--xy-node-group-background-color-default: rgba(240, 240, 240, .25);--xy-node-boxshadow-hover-default: 0 1px 4px 1px rgba(0, 0, 0, .08);--xy-node-boxshadow-selected-default: 0 0 0 .5px #1a192b;--xy-node-border-radius-default: 3px;--xy-handle-background-color-default: #1a192b;--xy-handle-border-color-default: #fff;--xy-selection-background-color-default: rgba(0, 89, 220, .08);--xy-selection-border-default: 1px dotted rgba(0, 89, 220, .8);--xy-controls-button-background-color-default: #fefefe;--xy-controls-button-background-color-hover-default: #f4f4f4;--xy-controls-button-color-default: inherit;--xy-controls-button-color-hover-default: inherit;--xy-controls-button-border-color-default: #eee;--xy-controls-box-shadow-default: 0 0 2px 1px rgba(0, 0, 0, .08);--xy-edge-label-background-color-default: #ffffff;--xy-edge-label-color-default: inherit;--xy-resize-background-color-default: #3367d9}.react-flow.dark{--xy-edge-stroke-default: #3e3e3e;--xy-edge-stroke-width-default: 1;--xy-edge-stroke-selected-default: #727272;--xy-connectionline-stroke-default: #b1b1b7;--xy-connectionline-stroke-width-default: 1;--xy-attribution-background-color-default: rgba(150, 150, 150, .25);--xy-minimap-background-color-default: #141414;--xy-minimap-mask-background-color-default: rgba(60, 60, 60, .6);--xy-minimap-mask-stroke-color-default: transparent;--xy-minimap-mask-stroke-width-default: 1;--xy-minimap-node-background-color-default: #2b2b2b;--xy-minimap-node-stroke-color-default: transparent;--xy-minimap-node-stroke-width-default: 2;--xy-background-color-default: #141414;--xy-background-pattern-dots-color-default: #777;--xy-background-pattern-lines-color-default: #777;--xy-background-pattern-cross-color-default: #777;--xy-node-color-default: #f8f8f8;--xy-node-border-default: 1px solid #3c3c3c;--xy-node-background-color-default: #1e1e1e;--xy-node-group-background-color-default: rgba(240, 240, 240, .25);--xy-node-boxshadow-hover-default: 0 1px 4px 1px rgba(255, 255, 255, .08);--xy-node-boxshadow-selected-default: 0 0 0 .5px #999;--xy-handle-background-color-default: #bebebe;--xy-handle-border-color-default: #1e1e1e;--xy-selection-background-color-default: rgba(200, 200, 220, .08);--xy-selection-border-default: 1px dotted rgba(200, 200, 220, .8);--xy-controls-button-background-color-default: #2b2b2b;--xy-controls-button-background-color-hover-default: #3e3e3e;--xy-controls-button-color-default: #f8f8f8;--xy-controls-button-color-hover-default: #fff;--xy-controls-button-border-color-default: #5b5b5b;--xy-controls-box-shadow-default: 0 0 2px 1px rgba(0, 0, 0, .08);--xy-edge-label-background-color-default: #141414;--xy-edge-label-color-default: #f8f8f8}.react-flow__background{background-color:var(--xy-background-color-props, var(--xy-background-color, var(--xy-background-color-default)));pointer-events:none;z-index:-1}.react-flow__container{position:absolute;width:100%;height:100%;top:0;left:0}.react-flow__pane{z-index:1}.react-flow__pane.draggable{cursor:grab}.react-flow__pane.dragging{cursor:grabbing}.react-flow__pane.selection{cursor:pointer}.react-flow__viewport{transform-origin:0 0;z-index:2;pointer-events:none}.react-flow__renderer{z-index:4}.react-flow__selection{z-index:6}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible{outline:none}.react-flow__edge-path{stroke:var(--xy-edge-stroke, var(--xy-edge-stroke-default));stroke-width:var(--xy-edge-stroke-width, var(--xy-edge-stroke-width-default));fill:none}.react-flow__connection-path{stroke:var(--xy-connectionline-stroke, var(--xy-connectionline-stroke-default));stroke-width:var(--xy-connectionline-stroke-width, var(--xy-connectionline-stroke-width-default));fill:none}.react-flow .react-flow__edges{position:absolute}.react-flow .react-flow__edges svg{overflow:visible;position:absolute;pointer-events:none}.react-flow__edge{pointer-events:visibleStroke}.react-flow__edge.selectable{cursor:pointer}.react-flow__edge.animated path{stroke-dasharray:5;animation:dashdraw .5s linear infinite}.react-flow__edge.animated path.react-flow__edge-interaction{stroke-dasharray:none;animation:none}.react-flow__edge.inactive{pointer-events:none}.react-flow__edge.selected,.react-flow__edge:focus,.react-flow__edge:focus-visible{outline:none}.react-flow__edge.selected .react-flow__edge-path,.react-flow__edge.selectable:focus .react-flow__edge-path,.react-flow__edge.selectable:focus-visible .react-flow__edge-path{stroke:var(--xy-edge-stroke-selected, var(--xy-edge-stroke-selected-default))}.react-flow__edge-textwrapper{pointer-events:all}.react-flow__edge .react-flow__edge-text{pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__arrowhead polyline{stroke:var(--xy-edge-stroke, var(--xy-edge-stroke-default))}.react-flow__arrowhead polyline.arrowclosed{fill:var(--xy-edge-stroke, var(--xy-edge-stroke-default))}.react-flow__connection{pointer-events:none}.react-flow__connection .animated{stroke-dasharray:5;animation:dashdraw .5s linear infinite}svg.react-flow__connectionline{z-index:1001;overflow:visible;position:absolute}.react-flow__nodes{pointer-events:none;transform-origin:0 0}.react-flow__node{position:absolute;-webkit-user-select:none;-moz-user-select:none;user-select:none;pointer-events:all;transform-origin:0 0;box-sizing:border-box;cursor:default}.react-flow__node.selectable{cursor:pointer}.react-flow__node.draggable{cursor:grab;pointer-events:all}.react-flow__node.draggable.dragging{cursor:grabbing}.react-flow__nodesselection{z-index:3;transform-origin:left top;pointer-events:none}.react-flow__nodesselection-rect{position:absolute;pointer-events:all;cursor:grab}.react-flow__handle{position:absolute;pointer-events:none;min-width:5px;min-height:5px;width:6px;height:6px;background-color:var(--xy-handle-background-color, var(--xy-handle-background-color-default));border:1px solid var(--xy-handle-border-color, var(--xy-handle-border-color-default));border-radius:100%}.react-flow__handle.connectingfrom{pointer-events:all}.react-flow__handle.connectionindicator{pointer-events:all;cursor:crosshair}.react-flow__handle-bottom{top:auto;left:50%;bottom:0;transform:translate(-50%,50%)}.react-flow__handle-top{top:0;left:50%;transform:translate(-50%,-50%)}.react-flow__handle-left{top:50%;left:0;transform:translate(-50%,-50%)}.react-flow__handle-right{top:50%;right:0;transform:translate(50%,-50%)}.react-flow__edgeupdater{cursor:move;pointer-events:all}.react-flow__pane.selection .react-flow__panel{pointer-events:none}.react-flow__panel{position:absolute;z-index:5;margin:15px}.react-flow__panel.top{top:0}.react-flow__panel.bottom{bottom:0}.react-flow__panel.top.center,.react-flow__panel.bottom.center{left:50%;transform:translate(-15px) translate(-50%)}.react-flow__panel.left{left:0}.react-flow__panel.right{right:0}.react-flow__panel.left.center,.react-flow__panel.right.center{top:50%;transform:translateY(-15px) translateY(-50%)}.react-flow__attribution{font-size:10px;background:var(--xy-attribution-background-color, var(--xy-attribution-background-color-default));padding:2px 3px;margin:0}.react-flow__attribution a{text-decoration:none;color:#999}@keyframes dashdraw{0%{stroke-dashoffset:10}}.react-flow__edgelabel-renderer{position:absolute;width:100%;height:100%;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none;left:0;top:0}.react-flow__viewport-portal{position:absolute;width:100%;height:100%;left:0;top:0;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__minimap{background:var( --xy-minimap-background-color-props, var(--xy-minimap-background-color, var(--xy-minimap-background-color-default)) )}.react-flow__minimap-svg{display:block}.react-flow__minimap-mask{fill:var( --xy-minimap-mask-background-color-props, var(--xy-minimap-mask-background-color, var(--xy-minimap-mask-background-color-default)) );stroke:var( --xy-minimap-mask-stroke-color-props, var(--xy-minimap-mask-stroke-color, var(--xy-minimap-mask-stroke-color-default)) );stroke-width:var( --xy-minimap-mask-stroke-width-props, var(--xy-minimap-mask-stroke-width, var(--xy-minimap-mask-stroke-width-default)) )}.react-flow__minimap-node{fill:var( --xy-minimap-node-background-color-props, var(--xy-minimap-node-background-color, var(--xy-minimap-node-background-color-default)) );stroke:var( --xy-minimap-node-stroke-color-props, var(--xy-minimap-node-stroke-color, var(--xy-minimap-node-stroke-color-default)) );stroke-width:var( --xy-minimap-node-stroke-width-props, var(--xy-minimap-node-stroke-width, var(--xy-minimap-node-stroke-width-default)) )}.react-flow__background-pattern.dots{fill:var( --xy-background-pattern-color-props, var(--xy-background-pattern-color, var(--xy-background-pattern-dots-color-default)) )}.react-flow__background-pattern.lines{stroke:var( --xy-background-pattern-color-props, var(--xy-background-pattern-color, var(--xy-background-pattern-lines-color-default)) )}.react-flow__background-pattern.cross{stroke:var( --xy-background-pattern-color-props, var(--xy-background-pattern-color, var(--xy-background-pattern-cross-color-default)) )}.react-flow__controls{display:flex;flex-direction:column;box-shadow:var(--xy-controls-box-shadow, var(--xy-controls-box-shadow-default))}.react-flow__controls.horizontal{flex-direction:row}.react-flow__controls-button{display:flex;justify-content:center;align-items:center;height:26px;width:26px;padding:4px;border:none;background:var(--xy-controls-button-background-color, var(--xy-controls-button-background-color-default));border-bottom:1px solid var( --xy-controls-button-border-color-props, var(--xy-controls-button-border-color, var(--xy-controls-button-border-color-default)) );color:var( --xy-controls-button-color-props, var(--xy-controls-button-color, var(--xy-controls-button-color-default)) );cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__controls-button svg{width:100%;max-width:12px;max-height:12px;fill:currentColor}.react-flow__edge.updating .react-flow__edge-path{stroke:#777}.react-flow__edge-text{font-size:10px}.react-flow__node.selectable:focus,.react-flow__node.selectable:focus-visible{outline:none}.react-flow__node-input,.react-flow__node-default,.react-flow__node-output,.react-flow__node-group{padding:10px;border-radius:var(--xy-node-border-radius, var(--xy-node-border-radius-default));width:150px;font-size:12px;color:var(--xy-node-color, var(--xy-node-color-default));text-align:center;border:var(--xy-node-border, var(--xy-node-border-default));background-color:var(--xy-node-background-color, var(--xy-node-background-color-default))}.react-flow__node-input.selectable:hover,.react-flow__node-default.selectable:hover,.react-flow__node-output.selectable:hover,.react-flow__node-group.selectable:hover{box-shadow:var(--xy-node-boxshadow-hover, var(--xy-node-boxshadow-hover-default))}.react-flow__node-input.selectable.selected,.react-flow__node-input.selectable:focus,.react-flow__node-input.selectable:focus-visible,.react-flow__node-default.selectable.selected,.react-flow__node-default.selectable:focus,.react-flow__node-default.selectable:focus-visible,.react-flow__node-output.selectable.selected,.react-flow__node-output.selectable:focus,.react-flow__node-output.selectable:focus-visible,.react-flow__node-group.selectable.selected,.react-flow__node-group.selectable:focus,.react-flow__node-group.selectable:focus-visible{box-shadow:var(--xy-node-boxshadow-selected, var(--xy-node-boxshadow-selected-default))}.react-flow__node-group{background-color:var(--xy-node-group-background-color, var(--xy-node-group-background-color-default))}.react-flow__nodesselection-rect,.react-flow__selection{background:var(--xy-selection-background-color, var(--xy-selection-background-color-default));border:var(--xy-selection-border, var(--xy-selection-border-default))}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible,.react-flow__selection:focus,.react-flow__selection:focus-visible{outline:none}.react-flow__controls-button:hover{background:var( --xy-controls-button-background-color-hover-props, var(--xy-controls-button-background-color-hover, var(--xy-controls-button-background-color-hover-default)) );color:var( --xy-controls-button-color-hover-props, var(--xy-controls-button-color-hover, var(--xy-controls-button-color-hover-default)) )}.react-flow__controls-button:disabled{pointer-events:none}.react-flow__controls-button:disabled svg{fill-opacity:.4}.react-flow__controls-button:last-child{border-bottom:none}.react-flow__controls.horizontal .react-flow__controls-button{border-bottom:none;border-right:1px solid var( --xy-controls-button-border-color-props, var(--xy-controls-button-border-color, var(--xy-controls-button-border-color-default)) )}.react-flow__controls.horizontal .react-flow__controls-button:last-child{border-right:none}.react-flow__resize-control{position:absolute}.react-flow__resize-control.left,.react-flow__resize-control.right{cursor:ew-resize}.react-flow__resize-control.top,.react-flow__resize-control.bottom{cursor:ns-resize}.react-flow__resize-control.top.left,.react-flow__resize-control.bottom.right{cursor:nwse-resize}.react-flow__resize-control.bottom.left,.react-flow__resize-control.top.right{cursor:nesw-resize}.react-flow__resize-control.handle{width:5px;height:5px;border:1px solid #fff;border-radius:1px;background-color:var(--xy-resize-background-color, var(--xy-resize-background-color-default));translate:-50% -50%}.react-flow__resize-control.handle.left{left:0;top:50%}.react-flow__resize-control.handle.right{left:100%;top:50%}.react-flow__resize-control.handle.top{left:50%;top:0}.react-flow__resize-control.handle.bottom{left:50%;top:100%}.react-flow__resize-control.handle.top.left,.react-flow__resize-control.handle.bottom.left{left:0}.react-flow__resize-control.handle.top.right,.react-flow__resize-control.handle.bottom.right{left:100%}.react-flow__resize-control.line{border-color:var(--xy-resize-background-color, var(--xy-resize-background-color-default));border-width:0;border-style:solid}.react-flow__resize-control.line.left,.react-flow__resize-control.line.right{width:1px;transform:translate(-50%);top:0;height:100%}.react-flow__resize-control.line.left{left:0;border-left-width:1px}.react-flow__resize-control.line.right{left:100%;border-right-width:1px}.react-flow__resize-control.line.top,.react-flow__resize-control.line.bottom{height:1px;transform:translateY(-50%);left:0;width:100%}.react-flow__resize-control.line.top{top:0;border-top-width:1px}.react-flow__resize-control.line.bottom{border-bottom-width:1px;top:100%}.react-flow__edge-textbg{fill:var(--xy-edge-label-background-color, var(--xy-edge-label-background-color-default))}.react-flow__edge-text{fill:var(--xy-edge-label-color, var(--xy-edge-label-color-default))}.kekslabmap-root .map-view{height:100%;display:flex;flex-direction:column;position:relative;animation:fadeIn var(--duration-normal) var(--ease)}.kekslabmap-root .map-header{display:flex;align-items:center;justify-content:space-between;padding:14px 24px;border-bottom:1px solid var(--border-subtle);background:var(--bg-1);flex-shrink:0}.kekslabmap-root .map-header h2{font-size:15px;font-weight:600;color:var(--text-1)}.kekslabmap-root .node-count{font-size:11px;color:var(--text-3);padding:2px 8px;background:var(--bg-3);border:1px solid var(--border-subtle);border-radius:20px}.kekslabmap-root .flow-container{flex:1;position:relative}.kekslabmap-root .map-loading{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-3)}.kekslabmap-root .map-node{background:var(--bg-2);border:1px solid var(--border-subtle);border-radius:10px;padding:10px 14px;min-width:150px;transition:background var(--duration-fast) var(--ease),border-color var(--duration-fast) var(--ease),box-shadow var(--duration-fast) var(--ease);cursor:pointer;box-shadow:0 2px 8px #0006}.kekslabmap-root .map-node:hover{background:var(--bg-3);border-color:var(--border-muted);box-shadow:0 4px 16px #00000080}.kekslabmap-root .map-node.selected{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-glow),0 4px 16px #00000080}.kekslabmap-root .map-node .node-content{display:flex;align-items:center;gap:10px}.kekslabmap-root .map-node .node-icon-wrapper{display:flex;align-items:center;justify-content:center;padding:8px;border-radius:8px;flex-shrink:0}.kekslabmap-root .map-node .node-info{flex:1;min-width:0}.kekslabmap-root .map-node .node-name{font-size:12px;font-weight:600;color:var(--text-1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.kekslabmap-root .map-node .node-ip{font-size:10px;color:var(--text-3);font-family:var(--font-mono);margin-top:2px}.kekslabmap-root .map-node .node-status-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.kekslabmap-root .map-node .node-status-dot.online{background:var(--status-online);animation:pulseDot 2.5s var(--ease) infinite}.kekslabmap-root .map-node .node-status-dot.offline{background:var(--status-offline)}.kekslabmap-root .map-node .node-status-dot.unknown{background:var(--status-unknown)}.kekslabmap-root .map-node .node-handle{width:14px!important;height:14px!important;background:var(--accent)!important;border:2px solid var(--bg-2)!important}.kekslabmap-root .network-areas-overlay{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:10}.kekslabmap-root .network-area-wrapper{position:absolute;pointer-events:none;z-index:1}.kekslabmap-root .network-area{position:absolute;top:0;left:0;width:100%;height:100%;border:1px dashed var(--border-muted);border-radius:12px;background:#ffffff04;pointer-events:none;cursor:pointer;transition:background var(--duration-fast) var(--ease)}.kekslabmap-root .network-area:hover{background:#ffffff08}.kekslabmap-root .network-area-wrapper.selected .network-area{border-color:var(--accent);border-width:1px;box-shadow:0 0 0 1px var(--accent-glow)}.kekslabmap-root .network-area-header{position:absolute;top:-24px;left:0;display:flex;align-items:center;gap:6px;padding:3px 10px;background:var(--bg-2);border:1px solid var(--border-subtle);border-radius:5px;font-size:11px;pointer-events:auto;cursor:pointer;white-space:nowrap;z-index:2;transition:background var(--duration-fast) var(--ease),border-color var(--duration-fast) var(--ease)}.kekslabmap-root .network-area-header:hover{background:var(--bg-3);border-color:var(--border-muted)}.kekslabmap-root .network-area-name{font-weight:600;color:var(--text-1)}.kekslabmap-root .network-area-cidr{color:var(--text-3);font-family:var(--font-mono)}.kekslabmap-root .inspector-sidebar{position:absolute;top:70px;right:16px;width:340px;max-height:calc(100vh - 110px);display:flex;flex-direction:column;background:#161616eb;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border-subtle);border-radius:10px;box-shadow:0 8px 32px #00000080;z-index:100;overflow:hidden;animation:fadeIn var(--duration-normal) var(--ease)}.kekslabmap-root .inspector-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border-subtle)}.kekslabmap-root .inspector-header h3{font-size:13px;font-weight:600;margin:0;color:var(--text-1)}.kekslabmap-root .inspector-close{display:flex;align-items:center;justify-content:center;width:26px;height:26px;background:transparent;border:none;border-radius:5px;color:var(--text-3);cursor:pointer;transition:background var(--duration-fast) var(--ease),color var(--duration-fast) var(--ease)}.kekslabmap-root .inspector-close:hover{background:var(--bg-3);color:var(--text-1)}.kekslabmap-root .inspector-tabs{display:flex;gap:4px;padding:10px 12px;border-bottom:1px solid var(--border-subtle);overflow-x:auto;flex-shrink:0}.kekslabmap-root .inspector-tab{display:flex;align-items:center;gap:5px;padding:5px 10px;background:transparent;border:1px solid transparent;border-radius:20px;color:var(--text-3);font-size:11px;font-weight:500;cursor:pointer;transition:background var(--duration-fast) var(--ease),border-color var(--duration-fast) var(--ease),color var(--duration-fast) var(--ease);white-space:nowrap}.kekslabmap-root .inspector-tab:hover{background:var(--bg-3);color:var(--text-2)}.kekslabmap-root .inspector-tab.active{background:var(--bg-3);border-color:var(--border-muted);color:var(--text-1)}.kekslabmap-root .tab-content{padding:0}.kekslabmap-root .inspector-content{padding:18px;overflow-y:auto}.kekslabmap-root .inspector-section{margin-bottom:16px}.kekslabmap-root .inspector-section label{display:block;font-size:11px;font-weight:500;color:var(--text-3);letter-spacing:.02em;margin-bottom:7px}.kekslabmap-root .inspector-section input[type=text],.kekslabmap-root .inspector-section input[type=number],.kekslabmap-root .inspector-section select{width:100%;padding:8px 11px;background:var(--bg-0);border:1px solid var(--border-subtle);border-radius:6px;color:var(--text-1);font-size:13px;transition:border-color var(--duration-fast) var(--ease),box-shadow var(--duration-fast) var(--ease)}.kekslabmap-root .inspector-section input:focus,.kekslabmap-root .inspector-section select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.kekslabmap-root .inspector-section input[type=color]{width:100%;height:34px;padding:2px 4px;background:var(--bg-0);border:1px solid var(--border-subtle);border-radius:6px;cursor:pointer}.kekslabmap-root .inspector-section input[type=range]{width:100%;margin-bottom:4px;accent-color:var(--accent)}.kekslabmap-root .inspector-section input[type=checkbox]{margin-right:8px;accent-color:var(--accent)}.kekslabmap-root .inspector-section .range-value{font-size:11px;color:var(--text-3)}.kekslabmap-root .inspector-actions{display:flex;flex-direction:column;gap:8px;margin-top:20px;padding-top:16px;border-top:1px solid var(--border-subtle)}.kekslabmap-root .icon-picker-section{display:flex;align-items:center;gap:10px}.kekslabmap-root .current-icon-preview{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:7px;background:var(--bg-3);border:1px solid var(--border-subtle)}.kekslabmap-root .change-icon{padding:6px 12px;font-size:12px}.kekslabmap-root .dialog-overlay{position:fixed;inset:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn var(--duration-fast) var(--ease)}.kekslabmap-root .dialog-content{background:var(--bg-2);border:1px solid var(--border-subtle);border-radius:12px;width:460px;max-width:90vw;max-height:90vh;overflow:hidden;box-shadow:0 16px 64px #0009;animation:fadeIn var(--duration-normal) var(--ease)}.kekslabmap-root .dialog-header{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--border-subtle)}.kekslabmap-root .dialog-header h3{font-size:15px;font-weight:600;margin:0}.kekslabmap-root .dialog-close{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:transparent;border:none;border-radius:6px;color:var(--text-3);cursor:pointer;transition:background var(--duration-fast) var(--ease),color var(--duration-fast) var(--ease)}.kekslabmap-root .dialog-close:hover{background:var(--bg-3);color:var(--text-1)}.kekslabmap-root .dialog-body{padding:22px;max-height:60vh;overflow-y:auto}.kekslabmap-root .dialog-footer{display:flex;justify-content:flex-end;gap:10px;padding:16px 22px;border-top:1px solid var(--border-subtle);background:var(--bg-1)}.kekslabmap-root .form-section{margin-bottom:18px}.kekslabmap-root .form-section:last-child{margin-bottom:0}.kekslabmap-root .form-section label{display:block;font-size:11px;font-weight:500;color:var(--text-3);margin-bottom:7px}.kekslabmap-root .form-section input[type=text]{width:100%;padding:10px 12px;background:var(--bg-0);border:1px solid var(--border-subtle);border-radius:6px;color:var(--text-1);font-size:13px;transition:border-color var(--duration-fast) var(--ease),box-shadow var(--duration-fast) var(--ease)}.kekslabmap-root .form-section input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.kekslabmap-root .type-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.kekslabmap-root .type-btn{display:flex;flex-direction:column;align-items:center;gap:7px;padding:14px 10px;background:var(--bg-3);border:1px solid var(--border-subtle);border-radius:8px;color:var(--text-3);cursor:pointer;transition:background var(--duration-fast) var(--ease),border-color var(--duration-fast) var(--ease),color var(--duration-fast) var(--ease)}.kekslabmap-root .type-btn:hover{background:var(--bg-4);border-color:var(--border-muted);color:var(--text-2)}.kekslabmap-root .type-btn.selected{background:var(--accent-glow);border-color:var(--accent);color:var(--accent)}.kekslabmap-root .type-btn span{font-size:11px;font-weight:500}.kekslabmap-root .btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:9px 18px;background:var(--accent);border:1px solid var(--accent);border-radius:7px;color:#fff;font-size:13px;font-weight:500;cursor:pointer;transition:background var(--duration-fast) var(--ease),box-shadow var(--duration-fast) var(--ease)}.kekslabmap-root .btn-primary:hover{background:var(--accent-dim);border-color:var(--accent-dim);box-shadow:0 0 0 3px var(--accent-glow)}.kekslabmap-root .btn-secondary{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:9px 18px;background:transparent;border:1px solid var(--border-subtle);border-radius:7px;color:var(--text-2);font-size:13px;font-weight:500;cursor:pointer;transition:background var(--duration-fast) var(--ease),border-color var(--duration-fast) var(--ease),color var(--duration-fast) var(--ease)}.kekslabmap-root .btn-secondary:hover{background:var(--bg-3);border-color:var(--border-muted);color:var(--text-1)}.kekslabmap-root .btn-secondary.active{background:var(--accent-glow);border-color:var(--accent);color:var(--accent)}.kekslabmap-root .btn-danger{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:9px 18px;background:transparent;border:1px solid rgba(239,68,68,.3);border-radius:7px;color:var(--status-offline);font-size:13px;font-weight:500;cursor:pointer;transition:background var(--duration-fast) var(--ease),border-color var(--duration-fast) var(--ease)}.kekslabmap-root .btn-danger:hover{background:#ef44441a;border-color:var(--status-offline)}.kekslabmap-root .icon-picker-panel{position:absolute;inset:0;background:#161616f7;border-radius:10px;display:flex;flex-direction:column;z-index:10;animation:fadeIn var(--duration-fast) var(--ease)}.kekslabmap-root .icon-picker-header{display:flex;align-items:center;justify-content:space-between;padding:13px 18px;border-bottom:1px solid var(--border-subtle);gap:12px}.kekslabmap-root .icon-picker-header h3{margin:0;color:var(--text-1);font-size:14px;flex-shrink:0}.kekslabmap-root .icon-picker-current-inline{display:flex;align-items:center;gap:8px;flex:1}.kekslabmap-root .icon-picker-back{background:transparent;border:none;color:var(--text-3);cursor:pointer;padding:4px;border-radius:5px;display:flex;align-items:center;transition:background var(--duration-fast) var(--ease),color var(--duration-fast) var(--ease);flex-shrink:0}.kekslabmap-root .icon-picker-back:hover{background:var(--bg-3);color:var(--text-1)}.kekslabmap-root .icon-picker-close{background:transparent;border:none;color:var(--text-3);cursor:pointer;padding:4px;border-radius:5px;transition:background var(--duration-fast) var(--ease),color var(--duration-fast) var(--ease);flex-shrink:0}.kekslabmap-root .icon-picker-close:hover{background:var(--bg-3);color:var(--text-1)}.kekslabmap-root .icon-picker-current{display:flex;align-items:center;gap:10px;padding:10px 18px;background:var(--bg-3);border-bottom:1px solid var(--border-subtle)}.kekslabmap-root .current-label{font-size:11px;color:var(--text-3)}.kekslabmap-root .current-preview{display:flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:5px;background:var(--bg-2);border:1px solid var(--border-subtle)}.kekslabmap-root .icon-picker-tabs{display:flex;gap:4px;padding:8px 14px;border-bottom:1px solid var(--border-subtle);flex-shrink:0}.kekslabmap-root .tab-btn{display:flex;align-items:center;gap:5px;padding:5px 10px;background:transparent;border:1px solid transparent;border-radius:20px;color:var(--text-3);font-size:12px;cursor:pointer;transition:background var(--duration-fast) var(--ease),border-color var(--duration-fast) var(--ease),color var(--duration-fast) var(--ease)}.kekslabmap-root .tab-btn:hover{background:var(--bg-3);color:var(--text-2)}.kekslabmap-root .tab-btn.active{background:var(--bg-3);border-color:var(--border-muted);color:var(--text-1)}.kekslabmap-root .icon-picker-search{display:flex;align-items:center;gap:8px;padding:8px 14px;border-bottom:1px solid var(--border-subtle);flex-shrink:0}.kekslabmap-root .icon-picker-search input{flex:1;padding:6px 10px;background:var(--bg-0);border:1px solid var(--border-subtle);border-radius:5px;color:var(--text-1);font-size:12px;transition:border-color var(--duration-fast) var(--ease),box-shadow var(--duration-fast) var(--ease)}.kekslabmap-root .icon-picker-search input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.kekslabmap-root .search-clear{background:transparent;border:none;color:var(--text-3);cursor:pointer;padding:2px;display:flex;align-items:center;border-radius:4px;transition:background var(--duration-fast) var(--ease),color var(--duration-fast) var(--ease)}.kekslabmap-root .search-clear:hover{color:var(--text-1);background:var(--bg-3)}.kekslabmap-root .icon-picker-content{flex:1;overflow-y:auto;padding:14px}.kekslabmap-root .upload-tab{display:flex;flex-direction:column;align-items:center;gap:18px;padding-top:18px}.kekslabmap-root .upload-area{display:flex;flex-direction:column;align-items:center;gap:10px;padding:36px;border:1px dashed var(--border-muted);border-radius:8px;cursor:pointer;transition:border-color var(--duration-fast) var(--ease),background var(--duration-fast) var(--ease);width:100%;box-sizing:border-box;color:var(--text-3)}.kekslabmap-root .upload-area:hover{border-color:var(--accent);background:var(--accent-glow)}.kekslabmap-root .upload-area small{font-size:11px;color:var(--text-3)}.kekslabmap-root .upload-preview{position:relative;display:flex;align-items:center;justify-content:center;padding:18px;border:1px solid var(--border-subtle);border-radius:8px;background:var(--bg-0)}.kekslabmap-root .upload-preview img{max-width:100px;max-height:100px;-o-object-fit:contain;object-fit:contain}.kekslabmap-root .remove-upload{position:absolute;top:7px;right:7px;background:#ef4444d9;border:none;border-radius:50%;width:22px;height:22px;display:flex;align-items:center;justify-content:center;color:#fff;cursor:pointer;transition:background var(--duration-fast) var(--ease)}.kekslabmap-root .remove-upload:hover{background:var(--status-offline)}.kekslabmap-root .confirm-upload{width:100%}.kekslabmap-root .emoji-tab{display:flex;justify-content:center}.kekslabmap-root .icons-tab{display:flex;flex-direction:column;gap:18px}.kekslabmap-root .icon-section{display:flex;flex-direction:column;gap:8px}.kekslabmap-root .icon-section-title{font-size:10px;font-weight:600;color:var(--text-3);margin:0;text-transform:uppercase;letter-spacing:.08em}.kekslabmap-root .icon-count{font-weight:400;color:var(--text-3);text-transform:none;letter-spacing:0}.kekslabmap-root .icon-grid{display:flex;flex-wrap:wrap;gap:5px}.kekslabmap-root .icon-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;width:58px;min-height:52px;padding:5px 3px;border:1px solid var(--border-subtle);border-radius:7px;background:var(--bg-3);cursor:pointer;transition:background var(--duration-fast) var(--ease),border-color var(--duration-fast) var(--ease);overflow:hidden}.kekslabmap-root .icon-item:hover{border-color:var(--accent);background:var(--accent-glow)}.kekslabmap-root .icon-label{font-size:9px;color:var(--text-3);text-align:center;word-break:break-all;max-width:52px;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;line-height:1.2}.kekslabmap-root .icon-more{font-size:11px;color:var(--text-3);padding:8px;text-align:center;width:100%;font-style:italic}.kekslabmap-root .no-results{font-size:13px;color:var(--text-3);text-align:center;padding:40px 20px}.kekslabmap-root .react-flow__edge-path{stroke-linecap:round}.kekslabmap-root .react-flow__edge.selected .react-flow__edge-path{stroke-width:3px}.kekslabmap-root .react-flow__handle{cursor:crosshair}.kekslabmap-root .catalog-view{height:100%;display:flex;flex-direction:column;overflow:hidden;animation:fadeIn var(--duration-normal) var(--ease)}.kekslabmap-root .catalog-header{display:flex;align-items:center;justify-content:space-between;padding:14px 24px;border-bottom:1px solid var(--border-subtle);background:var(--bg-1);flex-shrink:0}.kekslabmap-root .catalog-header h2{font-size:15px;font-weight:600;color:var(--text-1)}.kekslabmap-root .catalog-header .node-count{font-size:11px;color:var(--text-3);padding:2px 8px;background:var(--bg-3);border:1px solid var(--border-subtle);border-radius:20px}.kekslabmap-root .catalog-content{flex:1;overflow-y:auto;padding:20px 24px}.kekslabmap-root .catalog-loading{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-3)}.kekslabmap-root .catalog-section{margin-bottom:20px}.kekslabmap-root .catalog-section .section-header{display:flex;align-items:center;gap:10px;width:100%;padding:9px 12px;background:transparent;border:none;cursor:pointer;transition:color var(--duration-fast) var(--ease);text-align:left;border-radius:6px}.kekslabmap-root .catalog-section .section-header:hover{background:var(--bg-2)}.kekslabmap-root .section-icon{display:flex;align-items:center;justify-content:center}.kekslabmap-root .section-title{flex:1;font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text-3)}.kekslabmap-root .section-count{font-size:11px;font-weight:500;color:var(--text-3);padding:1px 7px;background:var(--bg-3);border:1px solid var(--border-subtle);border-radius:10px}.kekslabmap-root .section-content{padding:10px 0 4px;animation:fadeIn var(--duration-normal) var(--ease)}.kekslabmap-root .nodes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}.kekslabmap-root .node-card{background:var(--bg-2);border:1px solid var(--border-subtle);border-radius:9px;padding:14px;cursor:pointer;transition:background var(--duration-fast) var(--ease),border-color var(--duration-fast) var(--ease),box-shadow var(--duration-fast) var(--ease)}.kekslabmap-root .node-card:hover{background:var(--bg-3);border-color:var(--border-muted);box-shadow:0 4px 16px #0006}.kekslabmap-root .node-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.kekslabmap-root .node-card-header .node-icon-wrapper{display:flex;align-items:center;justify-content:center;padding:8px;border-radius:8px}.kekslabmap-root .node-card-header .status-badge{display:inline-flex;align-items:center;gap:5px;font-size:10px;font-weight:500}.kekslabmap-root .node-card-header .status-badge .status-dot{width:5px;height:5px;border-radius:50%}.kekslabmap-root .node-card-header .status-badge.online{color:var(--status-online)}.kekslabmap-root .node-card-header .status-badge.online .status-dot{background:var(--status-online);animation:pulseDot 2.5s var(--ease) infinite}.kekslabmap-root .node-card-header .status-badge.offline{color:var(--status-offline)}.kekslabmap-root .node-card-header .status-badge.offline .status-dot{background:var(--status-offline)}.kekslabmap-root .node-card-header .status-badge.unknown{color:var(--text-3)}.kekslabmap-root .node-card-header .status-badge.unknown .status-dot{background:var(--status-unknown)}.kekslabmap-root .node-card-body .node-name{font-size:13px;font-weight:600;color:var(--text-1);margin-bottom:3px}.kekslabmap-root .node-card-body .node-ip{font-size:11px;font-family:var(--font-mono);color:var(--text-3);margin-bottom:2px}.kekslabmap-root .node-card-body .node-network{font-size:11px;color:var(--text-3)}.kekslabmap-root .catalog-view .empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:360px;color:var(--text-3)}.kekslabmap-root .catalog-view .empty-state svg{margin-bottom:14px;opacity:.25}.kekslabmap-root .tree-editor{height:100%;display:flex;flex-direction:column;animation:fadeIn var(--duration-normal) var(--ease)}.kekslabmap-root .editor-header{display:flex;align-items:center;justify-content:space-between;padding:14px 24px;border-bottom:1px solid var(--border-subtle);background:var(--bg-1);flex-shrink:0}.kekslabmap-root .header-left{display:flex;align-items:center;gap:10px}.kekslabmap-root .header-icon{color:var(--text-3)}.kekslabmap-root .editor-header h2{font-size:15px;font-weight:600;color:var(--text-1)}.kekslabmap-root .editor-header button{display:flex;align-items:center;gap:6px}.kekslabmap-root .editor-content{flex:1;display:flex;overflow:hidden}.kekslabmap-root .editor-loading{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-3)}.kekslabmap-root .tree-panel{flex:1;overflow-y:auto;padding:20px}.kekslabmap-root .tree-panel.with-panel{flex:0 0 60%}.kekslabmap-root .network-group{margin-bottom:20px}.kekslabmap-root .network-header{display:flex;align-items:center;gap:8px;padding:6px 10px;margin-bottom:6px}.kekslabmap-root .network-name{font-size:11px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--text-3)}.kekslabmap-root .network-cidr{font-size:11px;color:var(--text-3);font-family:var(--font-mono)}.kekslabmap-root .tree-item{width:100%}.kekslabmap-root .tree-item-row{display:flex;align-items:center;gap:4px;padding:7px 10px;border-radius:6px;cursor:pointer;transition:background var(--duration-fast) var(--ease),border-color var(--duration-fast) var(--ease)}.kekslabmap-root .tree-item-row:hover{background:var(--bg-2)}.kekslabmap-root .tree-item-row.selected{background:var(--bg-3);outline:1px solid var(--accent);outline-offset:-1px}.kekslabmap-root .expand-btn{display:flex;align-items:center;justify-content:center;width:18px;height:18px;background:transparent;border:none;color:var(--text-3);cursor:pointer;padding:0;flex-shrink:0;transition:color var(--duration-fast) var(--ease)}.kekslabmap-root .expand-btn:hover{color:var(--text-1);background:transparent;border:none}.kekslabmap-root .tree-item-content{display:flex;align-items:center;gap:9px;flex:1;min-width:0}.kekslabmap-root .tree-item-icon{display:flex;align-items:center;justify-content:center;padding:5px;border-radius:5px;flex-shrink:0}.kekslabmap-root .tree-item-name{font-size:13px;font-weight:500;color:var(--text-1)}.kekslabmap-root .tree-item-type{font-size:10px;font-weight:500;padding:2px 6px;background:var(--bg-3);border:1px solid var(--border-subtle);border-radius:4px;color:var(--text-3)}.kekslabmap-root .tree-item-ip{font-size:11px;font-family:var(--font-mono);color:var(--text-3)}.kekslabmap-root .tree-item-actions{display:flex;gap:4px;opacity:0;transition:opacity var(--duration-fast) var(--ease)}.kekslabmap-root .tree-item-row:hover .tree-item-actions{opacity:1}.kekslabmap-root .action-btn{display:flex;align-items:center;justify-content:center;width:26px;height:26px;background:transparent;border:1px solid transparent;border-radius:5px;color:var(--text-3);cursor:pointer;padding:0;transition:background var(--duration-fast) var(--ease),border-color var(--duration-fast) var(--ease),color var(--duration-fast) var(--ease)}.kekslabmap-root .action-btn:hover{background:var(--bg-3);border-color:var(--border-subtle);color:var(--text-1)}.kekslabmap-root .action-btn.danger:hover{background:#ef44441a;border-color:#ef44444d;color:var(--status-offline)}.kekslabmap-root .tree-children{margin-left:10px;padding-left:10px;border-left:1px solid var(--border-subtle)}.kekslabmap-root .edit-panel{width:380px;background:var(--bg-1);border-left:1px solid var(--border-subtle);display:flex;flex-direction:column;animation:fadeIn var(--duration-normal) var(--ease)}.kekslabmap-root .panel-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border-subtle);flex-shrink:0}.kekslabmap-root .panel-header h3{font-size:13px;font-weight:600;display:flex;align-items:center;gap:7px;color:var(--text-1)}.kekslabmap-root .panel-header h3 svg{color:var(--accent)}.kekslabmap-root .close-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:transparent;border:none;color:var(--text-3);cursor:pointer;padding:0;border-radius:5px;transition:background var(--duration-fast) var(--ease),color var(--duration-fast) var(--ease)}.kekslabmap-root .close-btn:hover{background:var(--bg-3);color:var(--text-1);box-shadow:none}.kekslabmap-root .edit-panel-tabs{display:flex;gap:4px;padding:10px 12px;border-bottom:1px solid var(--border-subtle);background:var(--bg-1);flex-shrink:0}.kekslabmap-root .edit-tab-btn{display:flex;align-items:center;gap:5px;padding:5px 10px;background:transparent;border:1px solid transparent;border-radius:20px;color:var(--text-3);font-size:12px;font-weight:500;cursor:pointer;transition:background var(--duration-fast) var(--ease),border-color var(--duration-fast) var(--ease),color var(--duration-fast) var(--ease);white-space:nowrap}.kekslabmap-root .edit-tab-btn:hover{background:var(--bg-3);color:var(--text-2)}.kekslabmap-root .edit-tab-btn.active{background:var(--bg-3);border-color:var(--border-muted);color:var(--text-1)}.kekslabmap-root .panel-content{padding:18px;overflow-y:auto;flex:1}.kekslabmap-root .panel-actions{display:flex;gap:10px;margin-top:20px;padding-top:16px;border-top:1px solid var(--border-subtle)}.kekslabmap-root .panel-actions button{flex:1;display:flex;align-items:center;justify-content:center;gap:6px}.kekslabmap-root .form-group{margin-bottom:14px}.kekslabmap-root .form-group label{font-size:11px;font-weight:500;color:var(--text-3);letter-spacing:.02em;margin-bottom:6px;display:block}.kekslabmap-root .form-group input[type=text],.kekslabmap-root .form-group input[type=number],.kekslabmap-root .form-group select,.kekslabmap-root .form-group textarea{width:100%;padding:8px 11px;background:var(--bg-0);border:1px solid var(--border-subtle);border-radius:6px;color:var(--text-1);font-size:13px;transition:border-color var(--duration-fast) var(--ease),box-shadow var(--duration-fast) var(--ease);box-sizing:border-box}.kekslabmap-root .form-group input:focus,.kekslabmap-root .form-group select:focus,.kekslabmap-root .form-group textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.kekslabmap-root .form-group input[type=color]{height:34px;padding:2px 4px;cursor:pointer;background:var(--bg-0)}.kekslabmap-root .form-group textarea{resize:vertical}.kekslabmap-root .modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn var(--duration-fast) var(--ease)}.kekslabmap-root .modal{background:var(--bg-2);border:1px solid var(--border-subtle);border-radius:12px;width:100%;max-width:460px;animation:fadeIn var(--duration-normal) var(--ease)}.kekslabmap-root .modal-header{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid var(--border-subtle)}.kekslabmap-root .modal-header h3{font-size:15px;font-weight:600}.kekslabmap-root .modal-content{padding:20px}.kekslabmap-root .modal-actions{margin-top:20px}.kekslabmap-root .modal-actions button{width:100%;justify-content:center}.kekslabmap-root .loading,.kekslabmap-root .error{padding:40px;text-align:center;color:var(--text-2)}.kekslabmap-root .error{color:var(--status-offline)}.kekslabmap-root .details-page{padding:28px 32px;overflow-y:auto;height:100%;animation:fadeIn var(--duration-normal) var(--ease)}.kekslabmap-root .details-header{display:flex;align-items:center;gap:16px;margin-bottom:28px;flex-wrap:wrap}.kekslabmap-root .back-btn{display:inline-flex;align-items:center;gap:6px;background:transparent;border:none;padding:0;color:var(--text-3);font-size:13px;font-weight:500;transition:color var(--duration-fast) var(--ease)}.kekslabmap-root .back-btn:hover{background:transparent;border-color:transparent;color:var(--text-1)}.kekslabmap-root .header-title{display:flex;align-items:center;gap:14px;flex:1}.kekslabmap-root .header-icon-wrapper{display:flex;align-items:center;justify-content:center;padding:10px;border-radius:10px;flex-shrink:0}.kekslabmap-root .header-title h1{font-size:20px;font-weight:600}.kekslabmap-root .header-actions{display:flex;gap:8px}.kekslabmap-root .header-actions button{display:flex;align-items:center;gap:6px}.kekslabmap-root .detail-card{background:var(--bg-2);border:1px solid var(--border-subtle);border-radius:10px;padding:24px;margin-bottom:20px}.kekslabmap-root .detail-meta{display:flex;align-items:center;gap:10px;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--border-subtle)}.kekslabmap-root .network-badge{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:5px;font-size:11px;font-weight:500;border:1px solid var(--border-subtle);color:var(--text-2);background:var(--bg-3)}.kekslabmap-root .detail-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:20px}.kekslabmap-root .detail-item{display:flex;flex-direction:column;gap:5px}.kekslabmap-root .detail-label{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--text-3);letter-spacing:.02em}.kekslabmap-root .detail-value{color:var(--text-1);font-size:13px;font-weight:500}.kekslabmap-root .detail-value.mono{font-family:var(--font-mono);font-size:12px;color:var(--text-2)}.kekslabmap-root .detail-value.link{color:var(--accent);cursor:pointer}.kekslabmap-root .detail-value.link:hover{text-decoration:underline}.kekslabmap-root .tags-section{margin-top:20px;padding-top:16px;border-top:1px solid var(--border-subtle)}.kekslabmap-root .tags-list{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}.kekslabmap-root .notes-section{margin-top:20px;padding-top:16px;border-top:1px solid var(--border-subtle)}.kekslabmap-root .notes-text{color:var(--text-2);margin-top:10px;line-height:1.65;font-size:13px}.kekslabmap-root .children-section{background:var(--bg-2);border:1px solid var(--border-subtle);border-radius:10px;padding:24px}.kekslabmap-root .children-section h3{display:flex;align-items:center;gap:8px;margin-bottom:14px;color:var(--text-2);font-size:12px;font-weight:500;letter-spacing:.04em;text-transform:uppercase}.kekslabmap-root .children-list{display:flex;flex-direction:column;gap:6px}.kekslabmap-root .child-item{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--bg-3);border:1px solid var(--border-subtle);border-radius:7px;cursor:pointer;transition:background var(--duration-fast) var(--ease),border-color var(--duration-fast) var(--ease)}.kekslabmap-root .child-item:hover{background:var(--bg-4);border-color:var(--border-muted)}.kekslabmap-root .child-icon{display:flex;align-items:center;justify-content:center;padding:7px;border-radius:7px;flex-shrink:0}.kekslabmap-root .child-name{flex:1;font-weight:500;font-size:13px;color:var(--text-1)}.kekslabmap-root .child-ip{color:var(--text-3);font-size:11px;font-family:var(--font-mono)}.kekslabmap-root .status-badge.small{padding:2px 6px;font-size:10px}.kekslabmap-root .edit-form{background:var(--bg-2);border:1px solid var(--border-subtle);border-radius:10px;padding:24px}.kekslabmap-root .form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.kekslabmap-root .form-group{display:flex;flex-direction:column;gap:6px}.kekslabmap-root .form-group label{font-size:11px;font-weight:500;color:var(--text-3);letter-spacing:.02em}.kekslabmap-root .form-group.full-width{grid-column:1 / -1}.kekslabmap-root .form-group input,.kekslabmap-root .form-group select,.kekslabmap-root .form-group textarea{width:100%}.kekslabmap-root .form-group textarea{min-height:100px;resize:vertical}.toast-container{position:fixed;top:20px;right:20px;z-index:1000;display:flex;flex-direction:column;gap:12px;max-width:420px;width:100%;pointer-events:none}.toast-container>*{pointer-events:auto}.toast{background:linear-gradient(135deg,#221a15,#2a201b);border:1px solid #3a2d24;border-radius:12px;box-shadow:0 8px 32px #00000080;overflow:hidden;min-width:320px;max-width:100%;opacity:0;transform:translate(100%) scale(.8);transition:all .3s cubic-bezier(.4,0,.2,1);position:relative}.toast-visible{opacity:1;transform:translate(0) scale(1)}.toast-content{display:flex;align-items:flex-start;gap:12px;padding:16px;position:relative}.toast-icon{flex-shrink:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:50%;margin-top:1px}.toast-error .toast-icon{background-color:#d9534f33;color:#d9534f}.toast-success .toast-icon{background-color:#5cb85c33;color:#5cb85c}.toast-warning .toast-icon{background-color:#f0ad4e33;color:#f0ad4e}.toast-info .toast-icon{background-color:#4a90e233;color:#4a90e2}.toast-text{flex:1;min-width:0}.toast-title{font-size:14px;font-weight:600;color:#f3cf98;margin-bottom:2px;line-height:1.4}.toast-message{font-size:13px;color:#b9a796;line-height:1.4;word-wrap:break-word}.toast-action{background:none;border:1px solid rgba(243,207,152,.3);color:#d6a77a;padding:6px 12px;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap;flex-shrink:0}.toast-action:hover{background-color:#f3cf981a;border-color:#d6a77a;color:#f3cf98}.toast-close{background:none;border:none;color:#b9a796;cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0;margin-left:8px}.toast-close:hover{background-color:#b9a7961a;color:#f3cf98}.toast-close svg{width:14px;height:14px}.toast-progress{position:absolute;bottom:0;left:0;height:3px;background:linear-gradient(90deg,#f3cf98,#d6a77a);transition:width .1s linear}.toast-error .toast-progress{background:linear-gradient(90deg,#d9534f,#c9302c)}.toast-success .toast-progress{background:linear-gradient(90deg,#5cb85c,#4cae4c)}.toast-warning .toast-progress{background:linear-gradient(90deg,#f0ad4e,#ec971f)}.toast-info .toast-progress{background:linear-gradient(90deg,#4a90e2,#357abd)}@keyframes toast-slide-in{0%{opacity:0;transform:translate(100%) scale(.8)}to{opacity:1;transform:translate(0) scale(1)}}@keyframes toast-slide-out{0%{opacity:1;transform:translate(0) scale(1)}to{opacity:0;transform:translate(100%) scale(.8)}}.toast-visible{animation:toast-slide-in .3s cubic-bezier(.4,0,.2,1)}.toast:not(.toast-visible){animation:toast-slide-out .3s cubic-bezier(.4,0,.2,1)}.toast:hover{transform:translateY(-2px);box-shadow:0 12px 40px #0009}.toast-visible:hover{transform:translate(0) scale(1) translateY(-2px)}.toast:focus-within{box-shadow:0 8px 32px #00000080,0 0 0 3px #f3cf984d}@media(max-width:768px){.toast-container{top:16px;right:16px;left:16px;max-width:none}.toast{min-width:auto;width:100%}.toast-content{padding:14px;gap:10px}.toast-title{font-size:13px}.toast-message{font-size:12px}.toast-action{padding:5px 10px;font-size:11px}}@media(max-width:480px){.toast-container{top:12px;right:12px;left:12px}.toast-content{padding:12px;gap:8px}.toast-title{font-size:12px}.toast-message{font-size:11px}.toast-action{display:none}.toast-icon{width:18px;height:18px}.toast-icon svg{width:16px;height:16px}}@media(prefers-reduced-motion:reduce){.toast,.toast-visible,.toast:not(.toast-visible),.toast-progress{animation:none;transition:none}.toast-visible{opacity:1;transform:translate(0) scale(1)}}@media(prefers-contrast:high){.toast{border-width:2px}.toast-title{font-weight:700}.toast-action{border-width:2px}}:root{--toast-bg: linear-gradient(135deg, #221a15 0%, #2a201b 100%);--toast-border: #3a2d24;--toast-shadow: rgba(0,0,0,.5)}@media(prefers-color-scheme:light){.toast{background:linear-gradient(135deg,#fff,#f8f9fa);border-color:#dee2e6;color:#212529}.toast-title{color:#495057}.toast-message{color:#6c757d}.toast-progress{background:linear-gradient(90deg,#007bff,#0056b3)}}@layer properties{@supports ((-webkit-hyphens:none) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-animation-delay:0s;--tw-animation-direction:normal;--tw-animation-duration:initial;--tw-animation-fill-mode:none;--tw-animation-iteration-count:1;--tw-enter-blur:0;--tw-enter-opacity:1;--tw-enter-rotate:0;--tw-enter-scale:1;--tw-enter-translate-x:0;--tw-enter-translate-y:0;--tw-exit-blur:0;--tw-exit-opacity:1;--tw-exit-rotate:0;--tw-exit-scale:1;--tw-exit-translate-x:0;--tw-exit-translate-y:0;--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial}}}@property --tw-animation-delay{syntax:"*";inherits:false;initial-value:0s}@property --tw-animation-direction{syntax:"*";inherits:false;initial-value:normal}@property --tw-animation-duration{syntax:"*";inherits:false}@property --tw-animation-fill-mode{syntax:"*";inherits:false;initial-value:none}@property --tw-animation-iteration-count{syntax:"*";inherits:false;initial-value:1}@property --tw-enter-blur{syntax:"*";inherits:false;initial-value:0}@property --tw-enter-opacity{syntax:"*";inherits:false;initial-value:1}@property --tw-enter-rotate{syntax:"*";inherits:false;initial-value:0}@property --tw-enter-scale{syntax:"*";inherits:false;initial-value:1}@property --tw-enter-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-enter-translate-y{syntax:"*";inherits:false;initial-value:0}@property --tw-exit-blur{syntax:"*";inherits:false;initial-value:0}@property --tw-exit-opacity{syntax:"*";inherits:false;initial-value:1}@property --tw-exit-rotate{syntax:"*";inherits:false;initial-value:0}@property --tw-exit-scale{syntax:"*";inherits:false;initial-value:1}@property --tw-exit-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-exit-translate-y{syntax:"*";inherits:false;initial-value:0}*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;line-height:1.5}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-feature-settings:normal;font-variation-settings:normal;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::-moz-placeholder{opacity:1}::placeholder{opacity:1}@supports (not (-webkit-appearance:-apple-pay-button)) or (contain-intrinsic-size:1px){::-moz-placeholder{color:currentColor}::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::-moz-placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){-webkit-appearance:button;-moz-appearance:button;appearance:button}::file-selector-button{-webkit-appearance:button;-moz-appearance:button;appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}.invisible{visibility:hidden}.visible{visibility:visible}.absolute{position:absolute}.fixed{position:fixed}.container{width:100%}.flex{display:flex}.hidden{display:none}.table{display:table}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.resize{resize:both}.border{border-style:var(--tw-border-style);border-width:1px}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.running{animation-play-state:running}:root{--cookie-bg:#1b1410;--cookie-surface:#2a201b;--cookie-surface-2:#33261f;--cookie-accent:#d6a77a;--cookie-accent-2:#f3cf98;--cookie-text:#f1e6d8;--cookie-muted:#b9a796;--cookie-border:#3a2d24;--cookie-success:#88c07a;--cookie-danger:#d96b6b;--cookie-input-border:#3a2d24;--cookie-border-hover:#4f3c2b;--cookie-border-primary:#33261f;--cookie-card-border:#3a2d24;--cookie-button-border:#3a2d24;--cookie-border-danger:#d96b6b;--radius:.625rem;color-scheme:dark;color:var(--cookie-text);background-color:var(--cookie-bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;font-weight:400;line-height:1.5}a{color:var(--cookie-accent-2);font-weight:500;text-decoration:none}a:hover{color:var(--cookie-accent)}html,body,#root{width:100%;height:100%}body{background:radial-gradient(1200px 800px at 10% 10%,#d3a77a0f,transparent 60%),radial-gradient(1000px 700px at 80% 20%,#f3cf980d,transparent 60%),linear-gradient(180deg,var(--cookie-surface-2),var(--cookie-bg));min-height:100vh;margin:0}h1{font-size:3.2em;line-height:1.1}button{background-color:var(--cookie-surface);color:var(--cookie-text);cursor:pointer;border:1px solid #0000;border-radius:8px;padding:5px;font-family:inherit;font-size:1em;font-weight:500;transition:border-color .25s,background-color .2s,color .2s}button:hover{border-color:var(--cookie-button-border)}button:focus,button:focus-visible{outline:4px auto var(--cookie-border-primary)}@layer base{*{border-color:var(--cookie-border);outline-color:var(--cookie-accent)}@supports (color:color-mix(in lab,red,red)){*{outline-color:color-mix(in oklab,var(--cookie-accent) 50%,transparent)}}body{background-color:var(--cookie-bg);color:var(--cookie-text)}}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}
