@font-face{font-family:TheSans;font-weight:300;font-style:normal;src:url(/fonts/TheSans/TheSansB_300_.woff2) format("woff2")}@font-face{font-family:TheSans;font-weight:400;font-style:normal;src:url(/fonts/TheSans/TheSansB_400_.woff2) format("woff2")}@font-face{font-family:TheSans;font-weight:500;font-style:normal;src:url(/fonts/TheSans/TheSansB_500_.woff2) format("woff2")}@font-face{font-family:TheSans;font-weight:600;font-style:normal;src:url(/fonts/TheSans/TheSansB_600_.woff2) format("woff2")}@font-face{font-family:TheSans;font-weight:700;font-style:normal;src:url(/fonts/TheSans/TheSansB_700_.woff2) format("woff2")}:root{--font: "TheSans", -apple-system, BlinkMacSystemFont, sans-serif;--navy: #001155;--navy-dark: #040D33;--navy-light: #263A73;--blue: #0445C8;--blue-hover: #0036A7;--blue-light: #E8F1FF;--blue-100: #DDEBFF;--white: #ffffff;--gray-50: #F6F6F9;--gray-100: #F2F1F8;--gray-200: #DBDAE1;--gray-300: #CECDD3;--gray-400: #B7B6BC;--gray-500: #8F8E94;--gray-600: #717177;--gray-700: #55545B;--gray-800: #3B3A3F;--gray-900: #222126;--green: #1B8712;--green-light: #D7FFD2;--orange: #CF4A0C;--orange-light: #FCECE5;--yellow: #F1BF00;--yellow-light: #FFF7C9;--red: #EB0505;--sp-1: 4px;--sp-2: 8px;--sp-3: 16px;--sp-4: 24px;--sp-5: 32px;--sp-6: 40px;--sp-7: 48px;--sp-8: 64px;--radius-s: 4px;--radius-m: 8px;--radius-l: 16px;--radius-xl: 24px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .06);--shadow-md: 0 4px 12px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .1);--shadow-xl: 0 16px 48px rgba(0, 0, 0, .12)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-y:scroll}body{font-family:var(--font);font-weight:400;color:var(--gray-900);background:var(--white);line-height:1.5}h1,h2,h3,h4{color:var(--navy);font-weight:700;line-height:1.25}.app-layout{min-height:100vh;display:flex;flex-direction:column}.main-content{flex:1;padding:var(--sp-6) var(--sp-5);max-width:1600px;margin:0 auto;width:100%}.header{background:var(--white);border-bottom:1px solid var(--gray-200);position:sticky;top:0;z-index:100}.header-inner{max-width:1600px;margin:0 auto;padding:0 var(--sp-5);height:72px;display:flex;align-items:center;gap:var(--sp-6)}.header-left{flex-shrink:0}.header-logo{display:flex;align-items:center;gap:var(--sp-2);text-decoration:none}.header-logo-img{height:32px;width:auto;border-radius:var(--radius-s)}.header-title{font-size:20px;font-weight:700;color:var(--navy)}.header-nav{flex:1;display:flex;gap:var(--sp-1)}.header-nav-link{padding:var(--sp-2) var(--sp-3);border-radius:var(--radius-m);font-size:15px;font-weight:500;color:var(--gray-700);text-decoration:none;transition:background .15s,color .15s}.header-nav-link:hover{background:var(--gray-50);color:var(--navy)}.header-nav-link.active{background:var(--blue-light);color:var(--blue)}.header-right{display:flex;align-items:center;gap:var(--sp-3)}.header-user{display:flex;flex-direction:column;text-align:right}.header-user-name{font-size:14px;font-weight:600;color:var(--gray-800)}.header-user-role{font-size:12px;color:var(--gray-500);text-transform:capitalize}.header-logout{padding:var(--sp-2) var(--sp-3);background:none;border:1px solid var(--gray-300);border-radius:var(--radius-m);font-size:14px;font-weight:500;color:var(--gray-700);cursor:pointer;font-family:var(--font);transition:background .15s,border-color .15s}.header-logout:hover{background:var(--gray-50);border-color:var(--gray-400)}.header-swisscom-logo{height:24px;width:auto;margin-left:var(--sp-2)}.footer{background:var(--gray-50);border-top:1px solid var(--gray-200);padding:var(--sp-4) var(--sp-5)}.footer-inner{max-width:1600px;margin:0 auto;display:flex;align-items:center;gap:var(--sp-2);font-size:13px;color:var(--gray-500)}.footer-separator{color:var(--gray-300)}.footer-link{color:var(--gray-500);text-decoration:none;transition:color .15s}.footer-link:hover{color:var(--blue)}.login-dark{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--gray-50);position:relative}.login-swisscom-logo{position:absolute;top:var(--sp-4);right:var(--sp-4);height:32px;width:auto}.login-box{text-align:center;width:100%;max-width:540px;padding:var(--sp-6);background:var(--white);border-radius:var(--radius-l);box-shadow:var(--shadow-lg)}.login-logo{width:240px;margin-bottom:var(--sp-5)}.login-box h2{color:var(--navy);font-size:22px;font-weight:600;margin-bottom:var(--sp-2)}.login-notice{color:var(--gray-500);font-size:13px;margin-bottom:var(--sp-5);line-height:1.5}.login-box form{display:flex;flex-direction:column;gap:var(--sp-3)}.login-box input{width:100%;padding:14px var(--sp-3);border:1px solid var(--gray-200);border-radius:var(--radius-m);font-size:15px;font-family:var(--font);color:var(--gray-900);background:var(--white);transition:border-color .2s,box-shadow .2s}.login-box input::placeholder{color:var(--gray-400)}.login-box input:hover{border-color:var(--gray-400)}.login-box input:focus{outline:none;border-color:var(--navy);box-shadow:0 0 0 3px #00115514}.login-box button[type=submit]{width:100%;padding:14px;border:none;border-radius:var(--radius-m);background:var(--navy);color:var(--white);font-size:16px;font-weight:600;font-family:var(--font);cursor:pointer;transition:background .15s;margin-top:var(--sp-2)}.login-box button[type=submit]:hover:not(:disabled){background:var(--navy-light)}.login-box button[type=submit]:disabled{opacity:.5;cursor:not-allowed}.login-box-secondary{width:100%;padding:14px;border:1px solid var(--gray-300);border-radius:var(--radius-m);background:none;color:var(--gray-700);font-size:15px;font-weight:500;font-family:var(--font);cursor:pointer;transition:border-color .15s,color .15s}.login-box-secondary:hover{border-color:var(--gray-500);color:var(--navy)}.login-box .alert,.login-form{text-align:left}.page-header{margin-bottom:var(--sp-6)}.page-header h1{font-size:32px;letter-spacing:-.5px;margin-bottom:var(--sp-1)}.page-subtitle{color:var(--gray-600);font-size:16px}.section{margin-bottom:var(--sp-7)}.section-title{font-size:18px;font-weight:600;color:var(--gray-800);margin-bottom:var(--sp-3)}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--sp-3)}.card{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-l);padding:var(--sp-4);display:flex;align-items:center;gap:var(--sp-3);cursor:pointer;transition:box-shadow .2s,border-color .2s,transform .15s;text-align:left;width:100%;font-family:var(--font)}.card:hover{box-shadow:var(--shadow-md);border-color:var(--gray-300);transform:translateY(-1px)}.card:active{transform:translateY(0)}.card-icon{font-size:32px;width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:var(--gray-50);border-radius:var(--radius-m);flex-shrink:0}.card-body{flex:1;min-width:0}.card-title{font-size:16px;font-weight:600;color:var(--navy);margin-bottom:2px}.card-text{font-size:14px;color:var(--gray-600);line-height:1.4}.card-arrow{color:var(--gray-400);font-size:18px;transition:color .15s,transform .15s}.card:hover .card-arrow{color:var(--blue);transform:translate(2px)}.input-field{margin-bottom:var(--sp-3)}.input-field label{display:block;margin-bottom:6px;font-weight:600;font-size:14px;color:var(--gray-800)}.input-field input,.input-field select{width:100%;padding:11px var(--sp-3);border:1px solid var(--gray-300);border-radius:var(--radius-m);font-size:16px;font-family:var(--font);color:var(--gray-900);background:var(--white);transition:border-color .15s,box-shadow .15s;height:46px}.input-field input::placeholder{color:var(--gray-400)}.input-field input:hover{border-color:var(--gray-500)}.input-field input:focus,.input-field select:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px #0445c81a}.form-group{margin-bottom:var(--sp-3)}.form-group label{display:block;margin-bottom:6px;font-weight:600;font-size:14px;color:var(--gray-800)}.form-group input,.form-group select{width:100%;padding:11px var(--sp-3);border:1px solid var(--gray-300);border-radius:var(--radius-m);font-size:16px;font-family:var(--font);color:var(--gray-900);background:var(--white);transition:border-color .15s,box-shadow .15s;height:46px}.form-group input::placeholder{color:var(--gray-400)}.form-group input:hover{border-color:var(--gray-500)}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px #0445c81a}.form-row{display:flex;gap:var(--sp-3);align-items:flex-end;flex-wrap:wrap}.form-row>.form-group,.form-row>.form-group-grow{margin-bottom:0}.form-row>.btn{height:46px;flex-shrink:0}.form-group-grow{flex:1}.btn{display:inline-flex;align-items:center;justify-content:center;padding:0 var(--sp-4);height:46px;border:none;border-radius:var(--radius-m);font-size:16px;font-weight:600;font-family:var(--font);cursor:pointer;transition:background .15s,box-shadow .15s,transform .1s;text-decoration:none;white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--blue);color:var(--white)}.btn-primary:hover:not(:disabled){background:var(--blue-hover);box-shadow:var(--shadow-sm)}.btn-secondary{background:var(--white);color:var(--gray-700);border:1px solid var(--gray-300)}.btn-secondary:hover:not(:disabled){background:var(--gray-50);border-color:var(--gray-400)}.btn-danger{background:var(--red);color:var(--white)}.btn-danger:hover:not(:disabled){background:#be0000}.btn-full,.btn-block{width:100%}.btn-small{padding:8px 14px;font-size:13px;height:34px;border-radius:var(--radius-s)}.alert{padding:var(--sp-2) var(--sp-3);border-radius:var(--radius-m);margin-bottom:var(--sp-3);font-size:14px}.alert-error{background:var(--orange-light);color:var(--orange)}.alert-delete{background:#eb050514;color:var(--red)}.alert-success{background:var(--green-light);color:var(--green)}.alert-warning{background:var(--yellow-light);color:#8f7000}.admin-page .page-header,.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--sp-5)}.admin-header h2{font-size:28px;letter-spacing:-.5px}.user-form{background:var(--white);padding:var(--sp-4);border-radius:var(--radius-l);border:1px solid var(--gray-200);margin-bottom:var(--sp-4)}.user-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}.user-form-actions{display:flex;gap:8px}.password-strength{display:flex;align-items:center;gap:10px;margin-top:6px}.password-strength-bar{flex:1;height:6px;background:var(--gray-200);border-radius:3px;overflow:hidden}.password-strength-fill{height:100%;border-radius:3px;transition:width .3s,background .3s}.password-strength-label{font-size:12px;font-weight:600;min-width:50px}.form-hint{font-size:12px;color:var(--gray-500);margin-top:4px}@media (max-width: 600px){.user-form-grid{grid-template-columns:1fr}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:var(--white);padding:var(--sp-5);border-radius:var(--radius-l);box-shadow:var(--shadow-xl);width:100%;max-width:480px}.modal-content h3{margin-bottom:var(--sp-3)}.user-table-container{overflow-x:auto;border-radius:var(--radius-l);border:1px solid var(--gray-200)}.user-table{width:100%;border-collapse:collapse;background:var(--white)}.user-table th,.user-table td{padding:var(--sp-3);text-align:left;border-bottom:1px solid var(--gray-200);font-size:14px}.user-table th{background:var(--gray-50);color:var(--gray-700);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.5px}.user-table tbody tr:hover{background:var(--gray-50)}.user-table .actions{display:flex;gap:var(--sp-2)}.action-btn{width:34px;height:34px;display:flex;align-items:center;justify-content:center;border:none;background:var(--gray-50);border-radius:var(--radius-m);color:var(--gray-600);cursor:pointer;transition:background .15s,color .15s}.action-btn:hover{background:var(--gray-100);color:var(--navy)}.action-btn--danger:hover{background:var(--orange-light);color:var(--orange)}.action-btn--primary{background:var(--blue);color:var(--white)}.action-btn--primary:hover{background:var(--blue-hover);color:var(--white)}.action-btn--primary:disabled{background:var(--gray-200);color:var(--gray-500)}.badge{display:inline-block;padding:2px 10px;border-radius:100px;font-size:12px;font-weight:600;text-transform:uppercase}.badge-admin{background:var(--blue-light);color:var(--blue)}.badge-user{background:var(--gray-100);color:var(--gray-700)}.tool-page h2{font-size:28px;letter-spacing:-.5px;margin-bottom:var(--sp-4)}.tool-form{background:var(--white);padding:var(--sp-4);border-radius:var(--radius-l);border:1px solid var(--gray-200);margin-bottom:var(--sp-4)}.tool-result{border:1px solid var(--gray-200);border-radius:var(--radius-l);overflow:hidden}.tool-result pre{padding:var(--sp-4);font-family:SF Mono,Fira Code,Consolas,monospace;font-size:13px;line-height:1.7;white-space:pre-wrap;word-break:break-all;background:var(--navy-dark);color:#cdd6f4;margin:0}.port-table{width:100%;border-collapse:collapse}.port-table th,.port-table td{padding:var(--sp-3);text-align:left;border-bottom:1px solid var(--gray-200)}.port-table th{background:var(--gray-50);font-size:12px;font-weight:600;text-transform:uppercase;color:var(--gray-700)}.port-open td{background:var(--green-light)}.port-closed td{background:var(--white)}.page-loading{display:flex;align-items:center;justify-content:center;padding:var(--sp-8)}.spinner{width:32px;height:32px;border:3px solid var(--gray-200);border-top-color:var(--blue);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading{text-align:center;padding:var(--sp-8);color:var(--gray-500)}.empty-state{text-align:center;padding:var(--sp-8)}.empty-state-icon{font-size:48px;margin-bottom:var(--sp-3)}.empty-state h3{font-size:20px;margin-bottom:var(--sp-2);color:var(--gray-800)}.empty-state p{color:var(--gray-500);font-size:15px}.error-page{text-align:center;padding:var(--sp-8);color:var(--orange)}@media (max-width: 768px){.header-inner{padding:0 var(--sp-3);gap:var(--sp-3)}.header-nav,.header-user{display:none}.main-content{padding:var(--sp-4) var(--sp-3)}.card-grid{grid-template-columns:1fr}.form-row{flex-direction:column}.admin-header{flex-direction:column;gap:var(--sp-3);align-items:stretch}.page-header h1{font-size:24px}}.sql-page{display:flex;gap:0;min-height:calc(100vh - 200px)}.sql-sidebar{width:220px;flex-shrink:0;border-right:1px solid var(--gray-200);padding-right:var(--sp-3);margin-right:var(--sp-4)}.sql-sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-2) var(--sp-2);margin-bottom:var(--sp-2)}.sql-sidebar-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--gray-500)}.sql-sidebar-header-actions{display:flex;gap:4px}.sql-sidebar-edit-toggle{width:24px;height:24px;display:flex;align-items:center;justify-content:center;border:none;background:var(--gray-100);border-radius:var(--radius-s);font-size:13px;color:var(--gray-600);cursor:pointer;font-family:var(--font);transition:background .15s,color .15s}.sql-sidebar-edit-toggle:hover{background:var(--blue-light);color:var(--blue)}.sql-sidebar-edit-toggle.active{background:var(--blue);color:var(--white)}.sql-sidebar-add{width:24px;height:24px;display:flex;align-items:center;justify-content:center;border:none;background:var(--gray-100);border-radius:var(--radius-s);font-size:16px;color:var(--gray-600);cursor:pointer;font-family:var(--font);transition:background .15s}.sql-sidebar-add:hover{background:var(--blue-light);color:var(--blue)}.sql-cat-form{display:flex;gap:4px;margin-bottom:var(--sp-2);padding:0 var(--sp-1)}.sql-cat-form input{flex:1;padding:6px 8px;border:1px solid var(--gray-300);border-radius:var(--radius-s);font-size:13px;font-family:var(--font);min-width:0}.sql-cat-form input:focus{outline:none;border-color:var(--blue)}.sql-cat-form-btn{width:26px;height:26px;display:flex;align-items:center;justify-content:center;border:none;background:var(--gray-100);border-radius:var(--radius-s);font-size:12px;cursor:pointer;color:var(--gray-700)}.sql-cat-form-btn:hover{background:var(--blue-light);color:var(--blue)}.sql-sidebar-list{display:flex;flex-direction:column;gap:2px}.sql-sidebar-item-wrapper{position:relative}.sql-sidebar-item-row{display:flex;align-items:center;gap:2px}.sql-sidebar-tab{display:flex;align-items:center;justify-content:space-between;width:100%;padding:9px var(--sp-2);border:none;background:none;border-radius:var(--radius-m);font-size:14px;font-family:var(--font);font-weight:500;color:var(--gray-700);cursor:pointer;transition:background .15s,color .15s;text-align:left}.sql-sidebar-tab:hover{background:var(--gray-50);color:var(--navy)}.sql-sidebar-tab.active{background:var(--blue-light);color:var(--blue);font-weight:600}.sql-sidebar-tab-name{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sql-sidebar-tab-count{font-size:11px;font-weight:600;background:var(--gray-200);color:var(--gray-700);padding:1px 6px;border-radius:100px;min-width:20px;text-align:center}.sql-sidebar-tab.active .sql-sidebar-tab-count{background:#0445c826;color:var(--blue)}.sql-sidebar-actions{display:flex;gap:2px;flex-shrink:0}.sql-sidebar-action{width:22px;height:22px;display:flex;align-items:center;justify-content:center;border:none;background:none;border-radius:var(--radius-s);font-size:12px;color:var(--gray-500);cursor:pointer}.sql-sidebar-action:hover{background:var(--gray-100);color:var(--navy)}.sql-sidebar-action--danger:hover{background:var(--orange-light);color:var(--orange)}.sql-main{flex:1;min-width:0}.sql-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--sp-4)}.sql-header h1{font-size:28px;letter-spacing:-.5px;margin-bottom:2px}.sql-header-count{font-size:14px;color:var(--gray-500)}.sql-search{margin-bottom:var(--sp-4)}.sql-search input{width:100%;padding:11px var(--sp-3);border:1px solid var(--gray-300);border-radius:var(--radius-m);font-size:15px;font-family:var(--font);height:46px;transition:border-color .15s,box-shadow .15s}.sql-search input:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px #0445c81a}.sql-form-card{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-l);padding:var(--sp-4);margin-bottom:var(--sp-4)}.sql-form-card h3{font-size:18px;margin-bottom:var(--sp-3)}.sql-form-row{display:flex;gap:var(--sp-3)}.sql-textarea{width:100%;padding:var(--sp-3);border:1px solid var(--gray-300);border-radius:var(--radius-m);font-size:14px;font-family:SF Mono,Fira Code,Consolas,monospace;line-height:1.6;resize:vertical;min-height:180px;color:var(--gray-900);background:var(--gray-50);transition:border-color .15s,box-shadow .15s}.sql-textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px #0445c81a;background:var(--white)}.sql-form-actions{display:flex;gap:var(--sp-2);margin-top:var(--sp-3)}.sql-list{display:flex;flex-direction:column;gap:var(--sp-2)}.sql-item{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-l);overflow:hidden;transition:border-color .15s}.sql-item:hover{border-color:var(--gray-300)}.sql-item--expanded{border-color:var(--blue-100)}.sql-item-header{padding:var(--sp-3) var(--sp-4);display:flex;align-items:center;gap:var(--sp-3);cursor:pointer}.sql-item-info{flex:1;min-width:0}.sql-item-title{font-size:15px;font-weight:600;color:var(--navy);margin-bottom:2px}.sql-item-desc{font-size:13px;color:var(--gray-600);margin-bottom:4px}.sql-item-meta{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--gray-500);flex-wrap:wrap}.sql-tag{display:inline-block;padding:1px 8px;background:var(--blue-light);color:var(--blue);border-radius:100px;font-size:11px;font-weight:600}.sql-item-chevron{font-size:20px;color:var(--gray-400);transition:transform .2s;flex-shrink:0}.sql-item-chevron.open{transform:rotate(90deg)}.sql-item-body{border-top:1px solid var(--gray-200)}.sql-code-wrapper{position:relative}.sql-code-wrapper pre{padding:var(--sp-3) var(--sp-4);padding-bottom:var(--sp-7);background:var(--navy-dark);color:#cdd6f4;font-family:SF Mono,Fira Code,Consolas,monospace;font-size:13px;line-height:1.7;overflow-x:auto;white-space:pre-wrap;word-break:break-all;margin:0}.sql-code-actions{position:absolute;bottom:var(--sp-2);right:var(--sp-3);display:flex;gap:var(--sp-1)}.sql-empty{text-align:center;padding:var(--sp-7);color:var(--gray-500)}@media (max-width: 768px){.sql-page{flex-direction:column}.sql-sidebar{width:100%;border-right:none;border-bottom:1px solid var(--gray-200);padding-right:0;padding-bottom:var(--sp-3);margin-right:0;margin-bottom:var(--sp-3)}.sql-sidebar-list{flex-direction:row;flex-wrap:wrap;gap:var(--sp-1)}.sql-sidebar-tab{width:auto;padding:6px 12px}.sql-sidebar-actions{display:none}.sql-form-row{flex-direction:column}}.login-back-link{display:block;margin-top:var(--sp-4);font-size:14px;color:var(--blue);text-decoration:none;transition:color .15s}.login-back-link:hover{color:var(--blue-hover);text-decoration:underline}.pending-section{margin-bottom:var(--sp-4);padding:var(--sp-4);background:var(--yellow-light);border-radius:var(--radius-l);border:1px solid #F1BF00}.pending-title{font-size:16px;font-weight:600;color:var(--gray-900);margin-bottom:var(--sp-3)}.pending-list{display:flex;flex-direction:column;gap:var(--sp-2)}.pending-card{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-2) var(--sp-3);background:var(--white);border-radius:var(--radius-m);gap:var(--sp-3)}.pending-info{display:flex;align-items:center;gap:var(--sp-2);flex-wrap:wrap}.pending-name{font-weight:600;font-size:14px;color:var(--gray-900)}.pending-username{font-size:13px;color:var(--gray-500)}.pending-date{font-size:12px;color:var(--gray-400)}.pending-actions{display:flex;gap:var(--sp-1);flex-shrink:0}.pw-requirements{display:flex;flex-direction:column;gap:4px;padding:var(--sp-2) var(--sp-3);background:var(--gray-50);border-radius:var(--radius-m);font-size:12px}.pw-ok{color:var(--green)}.pw-fail{color:var(--gray-400)}.firmware-upload-form{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-l);padding:var(--sp-4);margin-bottom:var(--sp-4)}.firmware-upload-drop{margin-bottom:var(--sp-3)}.firmware-upload-drop input[type=file]{display:none}.firmware-upload-label{display:flex;align-items:center;justify-content:center;padding:var(--sp-5) var(--sp-4);border:2px dashed var(--gray-300);border-radius:var(--radius-m);color:var(--gray-500);font-size:15px;cursor:pointer;transition:border-color .15s,background .15s}.firmware-upload-label:hover{border-color:var(--blue);background:var(--blue-light);color:var(--blue)}.firmware-list{display:flex;flex-direction:column;gap:var(--sp-2)}.firmware-item{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-3) var(--sp-4);background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-l);transition:border-color .15s}.firmware-item:hover{border-color:var(--gray-300)}.firmware-item-icon{color:var(--blue);flex-shrink:0}.firmware-folder-item{background:var(--gray-50);border:1px dashed var(--gray-300)}.firmware-folder-item:hover{background:var(--blue-light, rgba(76, 147, 255, .08));border-color:var(--blue)}.firmware-folder-item .firmware-item-icon{color:var(--navy)}.firmware-item-info{flex:1;min-width:0}.firmware-item-name{font-size:15px;font-weight:600;color:var(--navy);margin-bottom:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.firmware-item-meta{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--gray-500)}.firmware-item-desc{font-size:13px;color:var(--gray-600);margin-top:4px}.firmware-item-actions{display:flex;gap:var(--sp-1);flex-shrink:0}.transfer-breadcrumb{display:flex;align-items:center;gap:6px;margin-bottom:var(--sp-4);font-size:14px;color:var(--gray-500)}.transfer-breadcrumb button{background:none;border:none;color:var(--blue);font-family:var(--font);font-size:14px;cursor:pointer;padding:0}.transfer-breadcrumb button:hover{text-decoration:underline}.transfer-breadcrumb .current{color:var(--gray-800);font-weight:600}.transfer-toolbar{display:flex;gap:var(--sp-2);margin-bottom:var(--sp-4)}.transfer-toolbar .btn{height:42px;padding:0 var(--sp-3);font-size:14px}.transfer-list{display:flex;flex-direction:column;gap:var(--sp-1)}.transfer-item{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-2) var(--sp-3);background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-m);transition:border-color .15s}.transfer-item:hover{border-color:var(--gray-300)}.transfer-item-icon{color:var(--blue);flex-shrink:0}.transfer-item-folder .transfer-item-icon{color:var(--navy)}.transfer-item-name{flex:1;font-size:14px;font-weight:500;color:var(--gray-900);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.transfer-item-folder .transfer-item-name{cursor:pointer;color:var(--navy);font-weight:600}.transfer-item-folder .transfer-item-name:hover{color:var(--blue)}.transfer-item-meta{font-size:12px;color:var(--gray-500);display:flex;gap:var(--sp-2)}.transfer-item-actions{display:flex;gap:var(--sp-1);flex-shrink:0}.transfer-new-folder{display:flex;gap:var(--sp-2);margin-bottom:var(--sp-4)}.transfer-new-folder input{padding:8px var(--sp-3);border:1px solid var(--gray-300);border-radius:var(--radius-m);font-size:14px;font-family:var(--font);width:250px}.transfer-new-folder input:focus{outline:none;border-color:var(--blue)}.apps-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--sp-3)}.app-card{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-3) var(--sp-4);background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-l);text-decoration:none;transition:border-color .15s,box-shadow .15s,transform .15s}.app-card:hover{border-color:var(--gray-300);box-shadow:var(--shadow-md);transform:translateY(-1px)}.app-card-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--blue-light);border-radius:var(--radius-m);color:var(--blue);flex-shrink:0}.app-card-info{flex:1;min-width:0}.app-card-info h4{font-size:15px;font-weight:600;color:var(--navy);margin-bottom:2px}.app-card-info p{font-size:13px;color:var(--gray-500);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.app-card-actions{display:flex;gap:4px;flex-shrink:0}.apps-letter-section{margin-bottom:var(--sp-4)}.apps-letter-header{font-size:13px;font-weight:700;color:var(--gray-400);text-transform:uppercase;padding-bottom:var(--sp-2);margin-bottom:var(--sp-2);border-bottom:1px solid var(--gray-200)}.firmware-file-list{display:flex;flex-wrap:wrap;gap:6px;margin:var(--sp-2) 0 var(--sp-3)}.firmware-file-tag{display:inline-block;padding:3px 10px;background:var(--blue-light);color:var(--blue);border-radius:100px;font-size:12px;font-weight:500}.upload-progress{margin-top:var(--sp-3);display:flex;align-items:center;gap:var(--sp-3)}.upload-progress-bar{flex:1;height:6px;background:var(--gray-200);border-radius:3px;overflow:hidden}.upload-progress-fill{height:100%;background:var(--blue);border-radius:3px;transition:width .3s ease}.upload-progress-text{font-size:13px;color:var(--gray-600);white-space:nowrap}.testline-form-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--sp-2) var(--sp-3);margin-bottom:var(--sp-3)}.testline-toggle{display:flex;align-items:center;gap:var(--sp-2);cursor:pointer;font-size:14px}.testline-toggle input[type=checkbox]{width:18px;height:18px;cursor:pointer}.testline-table-wrap{overflow-x:auto;border:1px solid var(--gray-200);border-radius:var(--radius-l);margin-left:calc(-1 * var(--sp-5));margin-right:calc(-1 * var(--sp-5));width:calc(100% + 2 * var(--sp-5))}.testline-table{width:100%;border-collapse:collapse;background:var(--white);font-size:13px}.testline-table th,.testline-table td{padding:8px 10px;text-align:left;border-bottom:1px solid var(--gray-200);white-space:nowrap}.testline-table th{background:var(--gray-50);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.3px;color:var(--gray-600);position:sticky;top:0}.testline-table tbody tr:hover{background:var(--gray-50)}.testline-table .testline-actions{position:sticky;right:0;background:var(--white);border-left:1px solid var(--gray-200)}.testline-table thead .testline-actions-header{position:sticky;right:0;background:var(--gray-50);border-left:1px solid var(--gray-200)}.testline-table tbody tr:hover .testline-actions{background:var(--gray-50)}.testline-status{font-size:14px}.testline-status.live{color:var(--green)}.testline-status.down{color:var(--red, #e00)}.testline-info-cell{max-width:200px;overflow:hidden;text-overflow:ellipsis}.testline-copyable{cursor:pointer;color:var(--blue);-webkit-user-select:none;user-select:none}.testline-copyable:hover{text-decoration:underline}.testline-filters{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-bottom:var(--sp-3)}.testline-filters select{padding:6px 10px;border:1px solid var(--gray-200);border-radius:var(--radius-m);font-size:13px;background:var(--white)}.testline-actions{display:flex;gap:4px}.testline-options-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:var(--sp-3)}.testline-options-group h4{font-size:13px;font-weight:600;color:var(--gray-700);margin-bottom:var(--sp-2)}.testline-options-tags{display:flex;flex-wrap:wrap;gap:6px}.testline-option-tag{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;background:var(--gray-100);border-radius:100px;font-size:13px;color:var(--gray-800)}.testline-option-tag button{background:none;border:none;font-size:16px;color:var(--gray-400);cursor:pointer;padding:0;line-height:1}.testline-option-tag button:hover{color:var(--orange)}.header-theme-toggle{background:none;border:1px solid var(--gray-300);border-radius:var(--radius-m);padding:6px 10px;font-size:16px;cursor:pointer;transition:background .15s}.header-theme-toggle:hover{background:var(--gray-50)}.toast-container{position:fixed;bottom:24px;right:24px;display:flex;flex-direction:column;gap:8px;z-index:9999}.toast{padding:12px 20px;border-radius:var(--radius-m);font-size:14px;font-weight:500;color:var(--white);box-shadow:var(--shadow-md);animation:toastIn .3s ease;max-width:360px}.toast-success{background:#1b8712}.toast-error{background:#eb0505}.toast-info{background:#0445c8}@keyframes toastIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}[data-theme=dark]{--white: #1a1a2e;--gray-50: #16213e;--gray-100: #1a1a2e;--gray-200: #2a2a4a;--gray-300: #3a3a5a;--gray-400: #6a6a8a;--gray-500: #8a8a9a;--gray-600: #a0a0b0;--gray-700: #c0c0d0;--gray-800: #d0d0e0;--gray-900: #e8e8f0;--navy: #7AAFFF;--navy-dark: #0f0f1a;--navy-light: #4C93FF;--blue: #4C93FF;--blue-hover: #7AAFFF;--blue-light: rgba(76, 147, 255, .15);--blue-100: rgba(76, 147, 255, .1);--green: #5BBF53;--green-light: rgba(91, 191, 83, .15);--orange: #FF855A;--orange-light: rgba(255, 133, 90, .15);--yellow-light: rgba(241, 191, 0, .15);--red: #FF544E;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .5)}[data-theme=dark] body{background:var(--navy-dark)}[data-theme=dark] .header{background:#1a1a2e;border-color:var(--gray-200)}[data-theme=dark] .login-dark{background:var(--navy-dark)}[data-theme=dark] .login-box{background:#1a1a2e;border:1px solid var(--gray-200)}[data-theme=dark] .card-icon{background:#4c93ff1f;color:#7aafff}[data-theme=dark] .card-icon img{filter:brightness(1.3)}[data-theme=dark] .action-btn{background:var(--gray-200);color:var(--gray-700)}[data-theme=dark] .header-stats svg{color:var(--gray-600)}[data-theme=dark] .sql-search input,[data-theme=dark] .form-group input,[data-theme=dark] .form-group select,[data-theme=dark] .input-field input,[data-theme=dark] .sql-textarea,[data-theme=dark] .query-search input{background:var(--gray-50);border-color:var(--gray-200);color:var(--gray-900)}.search-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:9998;display:flex;align-items:flex-start;justify-content:center;padding-top:120px}.search-modal{background:var(--white);border-radius:var(--radius-l);box-shadow:var(--shadow-xl);width:100%;max-width:600px;max-height:70vh;overflow:hidden;display:flex;flex-direction:column}.search-input{padding:16px 20px;border:none;border-bottom:1px solid var(--gray-200);font-size:16px;font-family:var(--font);outline:none;width:100%}.search-results{overflow-y:auto;padding:8px}.search-group-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--gray-500);padding:8px 12px 4px}.search-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--radius-m);cursor:pointer;text-decoration:none;color:var(--gray-900)}.search-item:hover{background:var(--gray-50)}.search-item-title{font-size:14px;font-weight:500}.search-item-subtitle{font-size:12px;color:var(--gray-500)}.search-hint{font-size:12px;color:var(--gray-400);padding:12px;text-align:center}.card--editing{position:relative;cursor:grab;animation:wiggle .3s ease infinite alternate;border-style:dashed}.card--editing:active{cursor:grabbing;opacity:.7;animation:none}.card-delete-btn{position:absolute;top:-8px;right:-8px;width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:var(--red);color:#fff;border:2px solid var(--white);border-radius:50%;cursor:pointer;z-index:10}.card-delete-btn:hover{transform:scale(1.15)}@keyframes wiggle{0%{transform:rotate(-.5deg)}to{transform:rotate(.5deg)}}.dashboard-widgets{display:flex;gap:var(--sp-3);margin-bottom:var(--sp-5);flex-wrap:wrap}.widget{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-l);padding:var(--sp-3) var(--sp-4);min-width:140px;text-align:center}.widget-value{font-size:28px;font-weight:700;color:var(--navy);line-height:1.2}.widget-label{font-size:12px;color:var(--gray-500);margin-top:4px;text-transform:uppercase;letter-spacing:.3px}.widget--alert{border-color:var(--orange);background:var(--orange-light)}.widget--alert .widget-value{color:var(--orange)}.header-stats{display:flex;align-items:center;gap:var(--sp-3);padding-right:var(--sp-3);border-right:1px solid var(--gray-200);margin-right:var(--sp-2)}.header-stat{font-size:12px;color:var(--gray-500);display:flex;align-items:center;gap:4px;white-space:nowrap}.header-stat-dot{width:6px;height:6px;background:var(--green);border-radius:50%}.header-stat--healthy{color:var(--green)}.header-stat--degraded{color:var(--orange)}.header-stat--down{color:var(--red)}.notif-wrapper{position:relative}.notif-bell{background:none;border:none;cursor:pointer;position:relative;padding:6px;color:var(--gray-600)}.notif-bell:hover{color:var(--navy)}.notif-badge{position:absolute;top:0;right:0;background:var(--red);color:#fff;font-size:10px;font-weight:700;width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center}.notif-dropdown{position:absolute;top:100%;right:0;margin-top:8px;background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-l);box-shadow:var(--shadow-lg);width:320px;max-height:400px;overflow:hidden;z-index:999}.notif-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid var(--gray-200);font-size:13px;font-weight:600}.notif-header button{background:none;border:none;color:var(--blue);font-size:12px;cursor:pointer;font-family:var(--font)}.notif-list{overflow-y:auto;max-height:340px}.notif-item{padding:12px 16px;border-bottom:1px solid var(--gray-100);cursor:pointer;transition:background .15s}.notif-item:hover{background:var(--gray-50)}.notif-message{font-size:13px;color:var(--gray-900);margin-bottom:4px}.notif-meta{font-size:11px;color:var(--gray-400)}.notif-empty{padding:24px;text-align:center;color:var(--gray-400);font-size:13px}.changelog-page{max-width:800px}.changelog-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--sp-5)}.changelog-header h1{font-size:32px;letter-spacing:-.5px;margin-bottom:var(--sp-1)}.changelog-form{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-l);padding:var(--sp-4);margin-bottom:var(--sp-5)}.changelog-form h3{font-size:18px;margin-bottom:var(--sp-3)}.changelog-list{display:flex;flex-direction:column;gap:var(--sp-4)}.changelog-entry{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-l);padding:var(--sp-4)}.changelog-entry-header{margin-bottom:var(--sp-3)}.changelog-entry-title-row{display:flex;align-items:center;gap:var(--sp-2);margin-bottom:4px}.changelog-version{display:inline-block;padding:2px 10px;background:var(--blue-light);color:var(--blue);border-radius:100px;font-size:12px;font-weight:600}.changelog-entry-title{font-size:18px;font-weight:600;color:var(--navy)}.changelog-entry-meta{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--gray-500)}.changelog-entry-content{font-size:14px;line-height:1.7;color:var(--gray-800)}.header-hamburger{display:none;background:none;border:none;cursor:pointer;padding:6px;color:var(--gray-700)}@media (max-width: 768px){.header-hamburger{display:flex}.header-nav{display:none;position:absolute;top:72px;left:0;right:0;background:var(--white);border-bottom:1px solid var(--gray-200);padding:var(--sp-3);flex-direction:column;box-shadow:var(--shadow-md);z-index:99}.header-nav--open{display:flex}.header-nav-link{padding:12px var(--sp-3);border-radius:var(--radius-m)}}.shortcuts-modal{background:var(--white);border-radius:var(--radius-l);box-shadow:var(--shadow-xl);padding:var(--sp-4);width:100%;max-width:400px}.shortcuts-modal h3{font-size:18px;margin-bottom:var(--sp-3);color:var(--navy)}.shortcuts-list{display:flex;flex-direction:column;gap:12px}.shortcut-item{display:flex;justify-content:space-between;align-items:center;font-size:14px;color:var(--gray-700)}.shortcut-keys{display:flex;gap:4px}.shortcut-keys kbd{background:var(--gray-100);border:1px solid var(--gray-200);border-radius:4px;padding:2px 8px;font-size:12px;font-family:var(--font)}.breadcrumb{display:flex;align-items:center;gap:6px;font-size:13px;margin-bottom:var(--sp-3);color:var(--gray-400)}.breadcrumb a{color:var(--blue);text-decoration:none}.breadcrumb a:hover{text-decoration:underline}.breadcrumb-sep{color:var(--gray-300)}.breadcrumb-current{color:var(--gray-600)}.recently-viewed{display:flex;align-items:center;gap:var(--sp-2);margin-bottom:var(--sp-4);flex-wrap:wrap}.recently-viewed-label{font-size:12px;color:var(--gray-400)}.recently-viewed-link{font-size:12px;padding:4px 10px;background:var(--gray-50);border:1px solid var(--gray-200);border-radius:100px;color:var(--gray-700);text-decoration:none;transition:background .15s}.recently-viewed-link:hover{background:var(--blue-light);color:var(--blue);border-color:var(--blue-light)}.skeleton{background:linear-gradient(90deg,var(--gray-100) 25%,var(--gray-50) 50%,var(--gray-100) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-m)}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-card{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-4);background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-l)}.skeleton-icon{width:56px;height:56px;flex-shrink:0}.skeleton-body{flex:1}.skeleton-title{height:16px;width:60%;margin-bottom:8px}.skeleton-text{height:12px;width:40%}.skeleton-row{display:flex;gap:var(--sp-3);padding:12px 0;border-bottom:1px solid var(--gray-100)}.skeleton-cell{height:14px}.skeleton-table{padding:var(--sp-3)}.drop-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0445c814;border:2px dashed var(--blue);border-radius:var(--radius-l);display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:600;color:var(--blue);z-index:10;pointer-events:none}@media print{.header,.footer,.sql-search,.page-header>div:last-child,.breadcrumb{display:none!important}.main-content{padding:0!important;max-width:none!important}.testline-table-wrap{border:none;overflow:visible}.testline-table{font-size:10px}.testline-table th,.testline-table td{padding:4px 6px}.testline-actions{display:none}}.transfer-tabs{display:flex;gap:0;margin-bottom:var(--sp-4);border-bottom:2px solid var(--gray-200)}.transfer-tab{padding:10px 20px;border:none;background:none;font-family:var(--font);font-size:14px;font-weight:500;color:var(--gray-500);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .15s}.transfer-tab:hover{color:var(--gray-800)}.transfer-tab.active{color:var(--blue);border-bottom-color:var(--blue)}.transfer-checkbox{width:16px;height:16px;cursor:pointer;flex-shrink:0}.transfer-item--selected{background:var(--blue-light)!important;border-color:var(--blue)!important}.tool-result-header{display:flex;justify-content:flex-end;padding:8px 16px;border-bottom:1px solid var(--gray-200);background:var(--gray-50)}.health-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-left:6px}.health-ok{background:var(--green)}.health-fail{background:var(--red)}
