@import url('https://fonts.googleapis.com/css2?family=Fira+Code:wght@300;400;500;600&family=Noto+Sans+KR:wght@300;400;500;600&display=swap');

:root,[data-theme="dark"]{
  --bg0:#06080e;--bg1:#0c0f1a;--bg2:#121626;--bg3:#1a1f30;--bg4:#222840;
  --border:rgba(255,255,255,0.07);--border2:rgba(255,255,255,0.13);
  --text0:#edf0ff;--text1:#c0c6e0;--text2:#6e7898;--text3:#3a4060;
  --sb-track:#0c0f1a;--sb-thumb:#2a3050;--sb-hover:#7c3aed;
  --login-bg:#06080e;--login-box:#0c0f1a;--login-inp:#121626;--login-bd:rgba(255,255,255,0.08);
  --ac:#7c3aed;--ac2:#a78bfa;
  --green:#10b981;--green2:#34d399;
  --amber:#f59e0b;--amber2:#fbbf24;
  --red:#ef4444;--red2:#f87171;
  --blue:#3b82f6;--blue2:#60a5fa;
  --cyan:#06b6d4;--pink:#ec4899;
  --mono:'Fira Code',monospace;--sans:'Noto Sans KR',sans-serif;
}
[data-theme="light"]{
  --bg0:#f1f3fa;--bg1:#ffffff;--bg2:#f5f7fc;--bg3:#e8ecf6;--bg4:#d5daea;
  --border:rgba(0,0,0,0.07);--border2:rgba(0,0,0,0.13);
  --text0:#111827;--text1:#374151;--text2:#6b7280;--text3:#9ca3af;
  --sb-track:#f1f3fa;--sb-thumb:#c5cde0;--sb-hover:#7c3aed;
  --login-bg:#e8ecf6;--login-box:#ffffff;--login-inp:#f5f7fc;--login-bd:rgba(0,0,0,0.1);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{width:100%;height:100%;overflow:hidden;background:var(--bg0);color:var(--text0);font-family:var(--sans);font-size:13px;transition:background .2s,color .2s}
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:var(--sb-track)}
::-webkit-scrollbar-thumb{background:var(--sb-thumb);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--sb-hover)}
.lov{position:fixed;inset:0;z-index:9999;background:var(--login-bg);display:flex;align-items:center;justify-content:center;transition:background .2s}
.lbox{width:400px;background:var(--login-box);border:1px solid var(--login-bd);border-radius:12px;padding:44px 40px 36px;transition:background .2s}
.llogo{font-family:var(--mono);font-size:22px;font-weight:600;color:var(--text0);text-align:center;margin-bottom:4px}
.llogo em{color:var(--ac2);font-style:normal}
.lsub{text-align:center;font-size:12px;color:var(--text2);margin-bottom:32px}
.lf{margin-bottom:14px}
.lf label{display:block;font-size:11px;font-weight:500;color:var(--text2);text-transform:uppercase;letter-spacing:.6px;margin-bottom:6px}
.lf input{width:100%;background:var(--login-inp);border:1px solid var(--login-bd);border-radius:6px;padding:10px 13px;font-family:var(--mono);font-size:13px;color:var(--text0);outline:none;transition:border-color .2s}
.lf input:focus{border-color:var(--ac)}
.lf input::placeholder{color:var(--text3)}
.lbtn{width:100%;margin-top:8px;padding:12px;background:var(--ac);border:none;border-radius:6px;color:#fff;font-family:var(--mono);font-size:13px;font-weight:500;cursor:pointer;transition:background .2s}
.lbtn:hover{background:#6d28d9}
.lerr{margin-top:10px;font-size:11px;color:var(--red2);text-align:center;min-height:18px;font-family:var(--mono)}
.lfooter{margin-top:24px;text-align:center;font-size:11px;color:var(--text3)}
@keyframes shake{0%,100%{transform:translateX(0)}20%,60%{transform:translateX(-8px)}40%,80%{transform:translateX(8px)}}
.shell{display:grid;grid-template-rows:50px 38px 1fr;height:100vh;width:100vw}
.topbar{display:flex;align-items:center;justify-content:space-between;padding:0 18px;background:var(--bg1);border-bottom:1px solid var(--border);gap:12px}
.brand{font-family:var(--mono);font-size:15px;font-weight:600;color:var(--text0);white-space:nowrap}
.brand em{color:var(--ac2);font-style:normal}
.top-kpis{display:flex;gap:0;flex:1;justify-content:center}
.tkpi{display:flex;align-items:center;gap:8px;padding:0 14px;border-right:1px solid var(--border)}
.tkpi:first-child{border-left:1px solid var(--border)}
.tklbl{font-size:10px;color:var(--text2);text-transform:uppercase;letter-spacing:.5px}
.tkval{font-family:var(--mono);font-size:18px;font-weight:600;line-height:1;color:var(--text0)}
.tkval.warn{color:var(--amber)}.tkval.danger{color:var(--red);animation:pr .8s infinite}
@keyframes pr{0%,100%{opacity:1}50%{opacity:.5}}
.tkunit{font-size:10px;color:var(--text2);margin-left:2px}
.tkd{font-family:var(--mono);font-size:10px;color:var(--text2)}
.tkd.up{color:var(--red2)}.tkd.dn{color:var(--green2)}
.tr{display:flex;align-items:center;gap:8px;white-space:nowrap}
.sysbadge{display:flex;align-items:center;gap:5px;padding:4px 10px;border-radius:4px;font-size:11px;background:rgba(16,185,129,.12);color:var(--green2);border:1px solid rgba(16,185,129,.25)}
.sysbadge.offline{background:rgba(239,68,68,.12);color:var(--red2);border-color:rgba(239,68,68,.25)}
.sysbadge.warning{background:rgba(245,158,11,.12);color:var(--amber2);border-color:rgba(245,158,11,.25)}
.led{width:6px;height:6px;border-radius:50%;background:var(--green2);box-shadow:0 0 6px var(--green2);animation:blink 2s infinite}
.sysbadge.offline .led{background:var(--red2);box-shadow:0 0 6px var(--red2)}
.sysbadge.warning .led{background:var(--amber);box-shadow:0 0 6px var(--amber)}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.2}}
.clk{font-family:var(--mono);font-size:11px;color:var(--text2);letter-spacing:1px}
.tbtn{font-family:var(--sans);font-size:11px;padding:4px 11px;border-radius:4px;border:1px solid var(--border2);background:transparent;color:var(--text1);cursor:pointer;transition:all .15s}
.tbtn:hover{background:var(--bg3);color:var(--text0)}
.tbtn.on{background:rgba(124,58,237,.2);border-color:var(--ac);color:var(--ac2)}
.etabs{display:flex;align-items:center;padding:0 18px;background:var(--bg1);border-bottom:1px solid var(--border);overflow-x:auto}
.etab{display:flex;align-items:center;gap:6px;padding:0 16px;height:38px;font-size:12px;color:var(--text2);cursor:pointer;border-bottom:2px solid transparent;transition:all .15s;white-space:nowrap}
.etab:hover{color:var(--text1)}.etab.active{color:var(--ac2);border-bottom-color:var(--ac2)}
.etab .eico{font-size:13px}
.etab-ip{font-family:var(--mono);font-size:10px;color:var(--text3);margin-left:3px}
.led2{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.led2.ok{background:var(--green2);box-shadow:0 0 4px var(--green2)}
.led2.warn{background:var(--amber);box-shadow:0 0 4px var(--amber)}
.led2.off{background:var(--red2);box-shadow:0 0 4px var(--red2)}
.etab-info{margin-left:auto;font-size:10px;color:var(--text3);font-family:var(--mono)}
.main{display:grid;grid-template-columns:240px 1fr minmax(0,270px);grid-template-rows:1fr 1fr;gap:1px;background:var(--border);overflow:hidden;min-height:0}
.panel{background:var(--bg1);display:flex;flex-direction:column;overflow:hidden;min-height:0}
.panel.span2{grid-row:span 2}
.ph{display:flex;align-items:center;justify-content:space-between;padding:9px 12px 7px;border-bottom:1px solid var(--border);flex-shrink:0}
.pt{font-size:11px;font-weight:600;color:var(--text1);text-transform:uppercase;letter-spacing:.5px}
.pb{font-family:var(--mono);font-size:10px;padding:2px 7px;border-radius:3px}
.pb-ok{background:rgba(16,185,129,.15);color:var(--green2);border:1px solid rgba(16,185,129,.2)}
.pb-warn{background:rgba(245,158,11,.15);color:var(--amber2);border:1px solid rgba(245,158,11,.2)}
.pb-err{background:rgba(239,68,68,.15);color:var(--red2);border:1px solid rgba(239,68,68,.2)}
.pb-php{background:rgba(124,58,237,.15);color:var(--ac2);border:1px solid rgba(124,58,237,.2)}
.wgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(14px,1fr));gap:3px;padding:8px 12px;flex:1;align-content:start;overflow:hidden}
.wk{width:14px;height:14px;border-radius:3px;transition:background .3s}
.wk.idle{background:var(--bg4)}.wk.active{background:var(--ac)}.wk.slow{background:var(--amber)}.wk.waiting{background:var(--bg3);border:1px solid var(--border2)}
.wleg-row{display:flex;gap:10px;padding:4px 12px 8px;flex-shrink:0}
.wleg{display:flex;align-items:center;gap:4px;font-size:10px;color:var(--text2)}
.wdot{width:10px;height:10px;border-radius:2px}
.oc-wrap{display:flex;align-items:center;gap:14px;padding:8px 14px;flex-shrink:0}
.donut-wrap{position:relative;width:72px;height:72px;flex-shrink:0}
.donut-inner{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.donut-num{font-family:var(--mono);font-size:15px;font-weight:600;color:var(--text0)}
.donut-sub{font-size:9px;color:var(--text2)}
.ocstats{flex:1;display:flex;flex-direction:column;gap:4px}
.ocrow{display:flex;align-items:center;gap:6px}
.oclbl{font-size:11px;color:var(--text1);width:76px;flex-shrink:0}
.octrack{flex:1;height:7px;background:var(--bg3);border-radius:3px;overflow:hidden;min-width:0}
.ocfill{height:100%;border-radius:3px;transition:width .5s}
.ocval{font-family:var(--mono);font-size:11px;color:var(--text0);width:40px;text-align:right;flex-shrink:0;font-weight:500}
.req-wrap{overflow-y:auto;flex:1;min-height:0}
.rtbl{width:100%;border-collapse:collapse;font-size:12px;table-layout:fixed}
.rtbl th{padding:5px 8px 6px;color:var(--text1);font-weight:500;text-align:left;border-bottom:1px solid var(--border);font-family:var(--mono);font-size:11px;position:sticky;top:0;background:var(--bg1);z-index:1;overflow:hidden}
.rtbl td{padding:5px 8px;border-bottom:1px solid var(--border);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.rtbl tr:hover td{background:var(--bg2)}
.mget{color:var(--green2);font-family:var(--mono);font-size:10px;font-weight:600}
.mpost{color:var(--amber2);font-family:var(--mono);font-size:10px;font-weight:600}
.urlc{font-family:var(--mono);color:var(--text1);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:block;font-size:11px}
.pb-row{display:flex;align-items:center;gap:8px;margin-bottom:6px}
.pb-lbl{font-size:12px;color:var(--text1);width:80px;flex-shrink:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pb-track{flex:1;height:9px;background:var(--bg3);border-radius:3px;overflow:hidden;min-width:0}
.pb-fill{height:100%;border-radius:3px;transition:width .5s}
.pb-val{font-family:var(--mono);font-size:12px;font-weight:500;color:var(--text0);width:52px;text-align:right;flex-shrink:0}
.turl-list{display:flex;flex-direction:column;gap:6px;padding:8px 12px;flex:1;overflow-y:auto}
.turow{display:flex;align-items:center;gap:6px}
.turank{font-family:var(--mono);font-size:11px;color:var(--text2);width:16px;flex-shrink:0}
.tuname{font-family:var(--mono);font-size:11px;color:var(--text1);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.tubarbg{width:55px;height:6px;background:var(--bg3);border-radius:2px;overflow:hidden;flex-shrink:0}
.tubarfill{height:100%;border-radius:2px;transition:width .4s}
.turps{font-family:var(--mono);font-size:11px;color:var(--text1);width:34px;text-align:right;flex-shrink:0}
.turt{font-family:var(--mono);font-size:11px;width:44px;text-align:right;flex-shrink:0}
.slog-wrap{overflow-y:auto;flex:1;min-height:0}
.stbl{width:100%;border-collapse:collapse;font-size:12px;table-layout:fixed}
.stbl th{padding:5px 8px 6px;color:var(--text1);font-weight:500;text-align:left;border-bottom:1px solid var(--border);font-family:var(--mono);font-size:11px;position:sticky;top:0;background:var(--bg1);z-index:1}
.stbl td{padding:5px 8px;border-bottom:1px solid var(--border);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.stbl tr:hover td{background:var(--bg2)}
.smgrid{display:grid;grid-template-columns:1fr 1fr;gap:5px;padding:6px 10px;flex-shrink:0}
.smcard{background:var(--bg2);border-radius:5px;padding:7px 9px;border:1px solid var(--border)}
.smlbl{font-size:10px;color:var(--text2);margin-bottom:3px}
.smval{font-family:var(--mono);font-size:15px;font-weight:600;color:var(--text0);line-height:1}
.smval.warn{color:var(--amber)}.smval.danger{color:var(--red2)}
.smsub{font-size:10px;color:var(--text2);margin-top:2px}
.evbadge{font-size:10px;padding:2px 8px;border-radius:3px;font-family:var(--mono);font-weight:500}
.eb-a{background:rgba(239,68,68,.15);color:#f87171;border:1px solid rgba(239,68,68,.2)}
.eb-f{background:rgba(124,58,237,.15);color:var(--ac2);border:1px solid rgba(124,58,237,.2)}
.eb-l{background:rgba(236,72,153,.15);color:#f9a8d4;border:1px solid rgba(236,72,153,.2)}
.eb-w{background:rgba(59,130,246,.15);color:var(--blue2);border:1px solid rgba(59,130,246,.2)}
.alertbar{position:absolute;bottom:0;left:0;right:0;background:rgba(239,68,68,.12);border-top:1px solid rgba(239,68,68,.3);padding:5px 14px;font-size:11px;color:var(--red2);display:none;align-items:center;gap:8px;font-family:var(--mono);z-index:50;animation:sau .3s ease}
@keyframes sau{from{transform:translateY(100%)}to{transform:translateY(0)}}
.alertbar.show{display:flex}
.chwrap{flex:1;position:relative;min-height:0;overflow:hidden}
.chabs{position:absolute;inset:6px 10px}
/* Env tab + button */
.etab-add{display:flex;align-items:center;justify-content:center;width:28px;height:28px;margin:0 4px;border-radius:5px;font-size:16px;color:var(--text2);cursor:pointer;border:1px dashed var(--border2);transition:all .15s;flex-shrink:0}
.etab-add:hover{color:var(--ac2);border-color:var(--ac);background:rgba(124,58,237,.08)}
.etab-edit{font-size:10px;color:var(--text3);margin-left:2px;cursor:pointer;opacity:0;transition:opacity .15s}
.etab:hover .etab-edit{opacity:1}
.etab-edit:hover{color:var(--ac2)}
/* Env Modal */
.env-modal-overlay{position:fixed;inset:0;z-index:9000;background:rgba(0,0,0,.55);display:none;align-items:center;justify-content:center;backdrop-filter:blur(2px)}
.env-modal-overlay.show{display:flex}
.env-modal{width:440px;background:var(--bg1);border:1px solid var(--border2);border-radius:10px;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.5)}
.env-modal-hd{display:flex;align-items:center;justify-content:space-between;padding:16px 20px 14px;border-bottom:1px solid var(--border)}
.env-modal-title{font-size:14px;font-weight:600;color:var(--text0)}
.env-modal-close{font-size:20px;color:var(--text2);cursor:pointer;line-height:1}
.env-modal-close:hover{color:var(--text0)}
.env-modal-body{padding:18px 20px;display:flex;flex-direction:column;gap:14px}
.em-field{display:flex;flex-direction:column;gap:5px}
.em-field label{font-size:11px;font-weight:500;color:var(--text2);text-transform:uppercase;letter-spacing:.5px}
.em-field input,.em-field select{background:var(--bg2);border:1px solid var(--border2);border-radius:5px;padding:8px 11px;font-family:var(--mono);font-size:12px;color:var(--text0);outline:none;transition:border-color .15s}
.em-field input:focus,.em-field select:focus{border-color:var(--ac)}
.em-field select{cursor:pointer}
.em-row2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.em-token-box{display:flex;align-items:center;gap:8px;background:var(--bg2);border:1px solid var(--border2);border-radius:5px;padding:6px 10px}
.em-token-box code{font-family:var(--mono);font-size:11px;color:var(--ac2);flex:1;word-break:break-all;user-select:all}
.em-token-copy{font-size:10px;padding:3px 8px;background:var(--ac);color:#fff;border:none;border-radius:3px;cursor:pointer;font-family:var(--sans);white-space:nowrap}
.em-token-copy:hover{background:#6d28d9}
.env-modal-ft{display:flex;align-items:center;gap:8px;padding:12px 20px 16px;border-top:1px solid var(--border)}
.em-btn{font-family:var(--sans);font-size:12px;padding:7px 16px;border-radius:5px;border:none;cursor:pointer;font-weight:500;transition:all .15s}
.em-btn-save{background:var(--ac);color:#fff}.em-btn-save:hover{background:#6d28d9}
.em-btn-cancel{background:transparent;color:var(--text2);border:1px solid var(--border2)}.em-btn-cancel:hover{color:var(--text0);border-color:var(--text2)}
.em-btn-del{background:rgba(239,68,68,.12);color:var(--red2);border:1px solid rgba(239,68,68,.2)}.em-btn-del:hover{background:rgba(239,68,68,.25)}
@media(max-width:1400px){.main{grid-template-columns:210px 1fr minmax(0,250px)}.tkpi{padding:0 11px}}
@media(max-width:1200px){.main{grid-template-columns:190px 1fr minmax(0,230px)}}
