*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}
:root{
  --hd:#4e4c4a;--hd2:#3a3836;--ho:#e57746;--hoh:#d4663a;--hodim:rgba(229,119,70,0.1);
  --bg:#f5f4f2;--sur:#ffffff;--bdr:rgba(78,76,74,0.12);--bdr2:rgba(78,76,74,0.06);
  --tx:#2c2a28;--tx2:#8a8784;--tx3:#b8b6b3;
  --sw:232px;--tbh:54px;--bnh:58px;
  --r:2px;
  --font:-apple-system,'Pretendard','Noto Sans KR',sans-serif;
  --shadow:0 1px 4px rgba(78,76,74,0.06),0 2px 12px rgba(78,76,74,0.04);
  --shadow-md:0 4px 16px rgba(78,76,74,0.1),0 1px 4px rgba(78,76,74,0.06);
}
body{font-family:var(--font);background:var(--bg);color:var(--tx);min-height:100vh;overflow-x:hidden;font-size:13px;line-height:1.5}
.hidden{display:none!important}

/* ── SCROLLBAR ── */
::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(78,76,74,0.2);border-radius:2px}
::-webkit-scrollbar-thumb:hover{background:rgba(78,76,74,0.35)}

/* ── AUTH ── */
.auth-scr{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:var(--bg)}
.auth-card{background:var(--sur);border-radius:4px;padding:44px 40px;width:100%;max-width:360px;border:1px solid var(--bdr);box-shadow:var(--shadow-md)}
.auth-brand{display:flex;align-items:center;gap:10px;margin-bottom:32px}
.auth-brand-mark{width:36px;height:36px;background:var(--hd);border-radius:var(--r);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.auth-brand-mark svg{width:18px;height:18px}
.auth-brand-text{line-height:1}
.auth-brand-name{font-size:14px;font-weight:700;color:var(--hd);letter-spacing:-.01em}
.auth-brand-sub{font-size:10px;color:var(--tx3);margin-top:2px;letter-spacing:.02em}
.auth-title{font-size:22px;font-weight:700;color:var(--tx);margin-bottom:4px;letter-spacing:-.02em}
.auth-desc{font-size:12px;color:var(--tx2);margin-bottom:28px}
.f-group{margin-bottom:14px}
.f-label{display:block;font-size:11px;font-weight:600;color:var(--tx2);margin-bottom:5px;letter-spacing:.03em;text-transform:uppercase}
.f-input{width:100%;padding:10px 12px;border:1.5px solid var(--bdr);border-radius:var(--r);font-size:13px;font-family:var(--font);background:var(--bg);color:var(--tx);outline:none;transition:border-color .15s,background .15s}
.f-input:focus{border-color:var(--ho);background:#fff}
.f-input::placeholder{color:var(--tx3)}
.btn-submit{width:100%;padding:11px;background:var(--ho);color:#fff;border:none;border-radius:var(--r);font-size:13px;font-weight:600;font-family:var(--font);cursor:pointer;transition:background .15s;margin-top:6px;letter-spacing:.01em}
.btn-submit:hover{background:var(--hoh)}
.btn-submit:disabled{opacity:.5;cursor:not-allowed}
.auth-err{background:#fff2f2;border:1px solid rgba(220,38,38,.2);color:#c12020;border-radius:var(--r);padding:10px 12px;font-size:12px;margin-bottom:14px;line-height:1.5}

/* ── APP LAYOUT ── */
.app{display:flex;height:100vh;overflow:hidden}

/* ── SIDEBAR ── */
.sidebar{width:var(--sw);background:var(--hd2);display:flex;flex-direction:column;flex-shrink:0;z-index:10;position:relative;border-right:1px solid rgba(0,0,0,.12)}
.sb-brand{padding:16px 14px;border-bottom:1px solid rgba(255,255,255,.06);display:flex;align-items:center;gap:9px;flex-shrink:0}
.sb-brand-mark{width:28px;height:28px;background:var(--ho);border-radius:var(--r);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.sb-brand-mark svg{width:14px;height:14px}
.sb-brand-name{font-size:13px;font-weight:600;color:#fff;line-height:1.2;letter-spacing:-.01em}
.sb-brand-eng{font-size:9px;color:rgba(255,255,255,.3);letter-spacing:.05em;margin-top:1px}

/* Sidebar section label */
.sb-sec-label{font-size:9px;font-weight:700;color:rgba(255,255,255,.25);padding:14px 14px 4px;letter-spacing:.08em;text-transform:uppercase;flex-shrink:0}

/* Tree */
.sb-tree{flex:1;overflow-y:auto;padding:0 6px 6px}
.tree-new-btn{display:flex;align-items:center;gap:6px;padding:8px 10px;margin:6px 0;background:rgba(255,255,255,.06);border:1px dashed rgba(255,255,255,.14);color:rgba(255,255,255,.5);border-radius:var(--r);font-size:11px;font-weight:500;cursor:pointer;font-family:var(--font);transition:all .15s;width:100%}
.tree-new-btn:hover{background:rgba(255,255,255,.1);color:rgba(255,255,255,.8);border-color:rgba(255,255,255,.25)}
.tree-new-btn svg{width:12px;height:12px;flex-shrink:0}
.tree-item{display:flex;align-items:center;padding:6px 8px;border-radius:var(--r);cursor:pointer;font-size:12px;color:rgba(255,255,255,.5);user-select:none;transition:background .1s,color .1s;min-height:30px}
.tree-item:hover{background:rgba(255,255,255,.07);color:rgba(255,255,255,.8)}
.tree-item.active{background:rgba(229,119,70,.18);color:var(--ho);font-weight:500}
.tree-item.drag-over{background:rgba(229,119,70,.25)!important}
.tree-toggle{width:14px;height:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0;opacity:.4;transition:opacity .15s,transform .15s;cursor:pointer}
.tree-toggle:hover{opacity:.8}
.tree-toggle.open svg{transform:rotate(90deg)}
.tree-toggle svg{transition:transform .15s}
.tree-fdr-icon{color:rgba(255,255,255,.4);flex-shrink:0;margin-right:5px;width:13px;height:13px}
.tree-item.active .tree-fdr-icon{color:rgba(229,119,70,.9)}
.tree-label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:12px}

/* Sidebar divider */
.sb-divider{height:1px;background:rgba(255,255,255,.06);margin:6px 0;flex-shrink:0}

/* User section */
.sb-user{padding:8px 6px;border-top:1px solid rgba(255,255,255,.06);flex-shrink:0;position:relative}
.sb-user-btn{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:var(--r);background:transparent;border:none;cursor:pointer;width:100%;transition:background .15s;color:rgba(255,255,255,.7)}
.sb-user-btn:hover{background:rgba(255,255,255,.07)}
.sb-avatar{width:28px;height:28px;background:var(--ho);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:11px;font-weight:700;flex-shrink:0}
.sb-uname{font-size:12px;color:rgba(255,255,255,.75);font-weight:500;flex:1;text-align:left;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sb-urole{font-size:9px;background:rgba(229,119,70,.15);color:rgba(229,119,70,.8);padding:2px 6px;border-radius:10px;flex-shrink:0;font-weight:600}
.sb-caret{font-size:9px;color:rgba(255,255,255,.25)}

/* User popup */
.user-menu{position:absolute;bottom:calc(100% + 4px);left:6px;right:6px;background:#fff;border-radius:4px;box-shadow:var(--shadow-md);border:1px solid var(--bdr);z-index:200;overflow:hidden;display:none}
.user-menu.show{display:block}
.um-item{display:flex;align-items:center;gap:8px;padding:10px 14px;font-size:12px;cursor:pointer;color:var(--tx);transition:background .1s}
.um-item:hover{background:var(--bg)}
.um-item svg{width:13px;height:13px;flex-shrink:0;color:var(--tx2)}
.um-item.danger{color:#dc2626}
.um-item.danger svg{color:#dc2626}
.um-sep{height:1px;background:var(--bdr2)}

/* ── MAIN ── */
.main-area{flex:1;display:flex;flex-direction:column;min-width:0;overflow:hidden}

/* Topbar */
.topbar{height:var(--tbh);display:flex;align-items:center;padding:0 18px;border-bottom:1px solid var(--bdr);background:var(--sur);gap:10px;flex-shrink:0}
.tb-left{display:flex;align-items:center;gap:8px;flex:1;min-width:0}
.tb-title{font-size:14px;font-weight:600;color:var(--tx);flex-shrink:0;letter-spacing:-.01em}
.tb-sep{color:var(--tx3);font-size:12px;flex-shrink:0}
.tb-bc{font-size:12px;color:var(--tx2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.tb-bc span{color:var(--ho);font-weight:500}
.tb-right{display:flex;align-items:center;gap:6px;flex-shrink:0}
.btn-icon{width:30px;height:30px;border:1px solid var(--bdr);border-radius:var(--r);background:transparent;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--tx2);transition:all .15s}
.btn-icon:hover{background:var(--bg);color:var(--tx);border-color:rgba(78,76,74,.2)}
.btn-icon svg{width:14px;height:14px}
.btn-primary-sm{display:flex;align-items:center;gap:5px;background:var(--ho);color:#fff;border:none;padding:7px 13px;border-radius:var(--r);font-size:12px;font-weight:600;font-family:var(--font);cursor:pointer;transition:background .15s;white-space:nowrap;letter-spacing:.01em}
.btn-primary-sm:hover{background:var(--hoh)}
.btn-primary-sm svg{width:13px;height:13px}

/* ── CONTENT ── */
.content-body{flex:1;display:flex;overflow:hidden}

/* ── FILE MAIN ── */
.file-main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}

/* Toolbar */
.file-toolbar{display:flex;align-items:center;padding:8px 16px;border-bottom:1px solid var(--bdr2);gap:6px;background:var(--sur);flex-shrink:0;flex-wrap:wrap}
.toolbar-group{display:flex;align-items:center;gap:4px}
.toolbar-sep{width:1px;height:18px;background:var(--bdr);margin:0 4px;flex-shrink:0}
.sel-label{font-size:11px;color:var(--tx2)}
.sel-label strong{color:var(--ho);font-weight:600}
.sort-btn{padding:4px 8px;border:1px solid var(--bdr);border-radius:var(--r);font-size:11px;font-family:var(--font);background:var(--sur);color:var(--tx2);cursor:pointer;transition:all .15s;font-weight:500}
.sort-btn:hover{border-color:var(--ho);color:var(--ho)}
.sort-btn.active{background:var(--ho);color:#fff;border-color:var(--ho)}
.search-wrap{position:relative;flex:1;max-width:240px}
.search-wrap input{width:100%;padding:5px 10px 5px 28px;border:1px solid var(--bdr);border-radius:var(--r);font-size:12px;font-family:var(--font);background:var(--sur);color:var(--tx);outline:none;transition:border-color .15s}
.search-wrap input:focus{border-color:var(--ho);background:#fff}
.search-wrap input::placeholder{color:var(--tx3)}
.search-wrap svg{position:absolute;left:8px;top:50%;transform:translateY(-50%);color:var(--tx3);width:12px;height:12px;pointer-events:none}
.btn-action{display:flex;align-items:center;gap:4px;border:1px solid;border-radius:var(--r);padding:5px 10px;font-size:11px;font-family:var(--font);cursor:pointer;transition:all .15s;white-space:nowrap;font-weight:500}
.btn-action svg{width:11px;height:11px}
.btn-action-danger{background:rgba(220,38,38,.06);border-color:rgba(220,38,38,.2);color:#dc2626}
.btn-action-danger:hover{background:rgba(220,38,38,.12)}
.btn-action-blue{background:rgba(59,130,246,.06);border-color:rgba(59,130,246,.2);color:#3b82f6}
.btn-action-blue:hover{background:rgba(59,130,246,.12)}

/* File grid */
.file-grid-wrap{flex:1;overflow-y:auto;padding:14px}
.file-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(128px,1fr));gap:8px}
.file-card{background:var(--sur);border:1px solid var(--bdr);border-radius:var(--r);overflow:hidden;cursor:pointer;transition:border-color .15s,box-shadow .15s;position:relative;user-select:none}
.file-card:hover{border-color:rgba(229,119,70,.35);box-shadow:0 2px 8px rgba(229,119,70,.08)}
.file-card.chk{border-color:var(--ho);box-shadow:0 0 0 2px rgba(229,119,70,.15)}
.file-card.drag-over{border-color:var(--ho);background:rgba(229,119,70,.05)}
.fc-thumb{width:100%;aspect-ratio:1;background:var(--bg);display:flex;align-items:center;justify-content:center;overflow:hidden;border-bottom:1px solid var(--bdr2)}
.fc-thumb img{width:100%;height:100%;object-fit:cover}
.fc-icon{font-size:26px;color:var(--tx3)}
.fc-info{padding:6px 8px}
.fc-name{font-size:11px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--tx);line-height:1.3}
.fc-meta{font-size:10px;color:var(--tx3);margin-top:1px}
.fc-cb{position:absolute;top:6px;right:6px}
.fc-num{position:absolute;top:6px;left:6px;min-width:18px;height:18px;background:var(--ho);color:#fff;border-radius:var(--r);font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 4px}
.cb{width:14px;height:14px;border:1.5px solid rgba(78,76,74,.25);border-radius:2px;flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all .12s;background:#fff}
.cb.on{background:var(--ho);border-color:var(--ho)}
.cb.on::after{content:'';display:block;width:7px;height:5px;border-left:1.5px solid #fff;border-bottom:1.5px solid #fff;transform:rotate(-45deg) translate(0.5px,-1px)}
.empty-state{text-align:center;padding:60px 20px;color:var(--tx3);grid-column:1/-1}
.empty-state svg{width:36px;height:36px;margin:0 auto 12px;display:block;opacity:.3}
.empty-state p{font-size:12px;line-height:1.7}

/* ── HTML PANEL ── */
.html-panel{width:268px;border-left:1px solid var(--bdr);background:var(--sur);display:flex;flex-direction:column;flex-shrink:0;transition:width .2s ease,border .2s ease}
.html-panel.collapsed{width:0;border-left:none;overflow:hidden}
.html-panel.panel-hidden{display:none!important}
.hp-hdr{padding:12px 14px;border-bottom:1px solid var(--bdr2);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.hp-hdr-title{font-size:11px;font-weight:700;color:var(--tx2);text-transform:uppercase;letter-spacing:.05em}
.hp-body{flex:1;overflow-y:auto;padding:10px}
.sel-file-item{display:flex;align-items:center;gap:7px;padding:7px;background:var(--bg);border-radius:var(--r);margin-bottom:5px;border:1px solid var(--bdr2)}
.sfi-num{width:18px;height:18px;background:var(--ho);color:#fff;border-radius:var(--r);font-size:9px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.sfi-thumb{width:32px;height:32px;border-radius:var(--r);background:var(--hodim);overflow:hidden;flex-shrink:0}
.sfi-thumb img{width:100%;height:100%;object-fit:cover}
.sfi-info{flex:1;min-width:0}
.sfi-name{font-size:11px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--tx)}
.sfi-alt{font-size:10px;color:var(--tx2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px}
.html-code-block{background:var(--bg);border-radius:var(--r);padding:10px;font-family:'Menlo','Monaco',monospace;font-size:10px;color:var(--hd);line-height:1.8;margin-top:10px;border:1px solid var(--bdr);word-break:break-all;white-space:pre-wrap}
.hp-footer{padding:10px;border-top:1px solid var(--bdr2);display:flex;flex-direction:column;gap:5px;flex-shrink:0}
.btn-outline{display:flex;align-items:center;gap:5px;background:#fff;border:1px solid var(--bdr);border-radius:var(--r);padding:7px 12px;font-size:12px;font-family:var(--font);cursor:pointer;color:var(--tx);transition:all .15s;white-space:nowrap;justify-content:center}
.btn-outline:hover{border-color:var(--ho);color:var(--ho)}
.btn-outline svg{width:12px;height:12px}
.btn-cafe24{display:flex;align-items:center;gap:5px;background:var(--hodim);border:1px solid rgba(229,119,70,.25);border-radius:var(--r);padding:7px 12px;font-size:12px;font-family:var(--font);cursor:pointer;color:var(--ho);font-weight:600;transition:all .15s;justify-content:center}
.btn-cafe24:hover{background:rgba(229,119,70,.18)}
.btn-cafe24 svg{width:12px;height:12px}
.hp-empty{text-align:center;padding:28px 12px;color:var(--tx3);font-size:12px;line-height:1.7}

/* ── MODALS ── */
.modal-ov{position:fixed;inset:0;background:rgba(44,42,40,.45);z-index:100;display:flex;align-items:center;justify-content:center;padding:20px;backdrop-filter:blur(2px)}
.modal{background:var(--sur);border-radius:4px;width:100%;max-width:460px;overflow:hidden;box-shadow:var(--shadow-md);border:1px solid var(--bdr)}
.modal-hdr{padding:16px 20px;border-bottom:1px solid var(--bdr2);display:flex;align-items:center;justify-content:space-between}
.modal-title{font-size:14px;font-weight:600;color:var(--tx);letter-spacing:-.01em}
.modal-close{width:26px;height:26px;background:var(--bg);border:none;border-radius:var(--r);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--tx2);font-size:16px;line-height:1;transition:background .15s}
.modal-close:hover{background:var(--bdr)}
.modal-body{padding:20px}
.drop-zone{border:1.5px dashed rgba(229,119,70,.3);border-radius:var(--r);padding:32px 20px;text-align:center;cursor:pointer;transition:all .15s;background:var(--bg)}
.drop-zone:hover,.drop-zone.drag-over{border-color:var(--ho);background:rgba(229,119,70,.05)}
.drop-zone svg{width:28px;height:28px;color:var(--ho);margin:0 auto 10px;display:block}
.drop-zone p{font-size:12px;color:var(--tx2);line-height:1.7}
.drop-zone strong{color:var(--ho)}
.up-prog{margin-top:14px}
.up-item{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.up-name{font-size:11px;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--tx)}
.pb-track{height:3px;background:var(--bg);border-radius:2px;flex:1}
.pb-fill{height:100%;background:var(--ho);border-radius:2px;transition:width .3s}
.up-status{font-size:11px;color:var(--tx2);min-width:30px;text-align:right}
.modal-field{margin-bottom:14px}
.modal-label{font-size:11px;font-weight:600;display:block;margin-bottom:5px;color:var(--tx2);text-transform:uppercase;letter-spacing:.03em}
.modal-input{width:100%;padding:9px 11px;border:1.5px solid var(--bdr);border-radius:var(--r);font-size:13px;font-family:var(--font);background:var(--bg);color:var(--tx);outline:none;transition:border-color .15s,background .15s}
.modal-input:focus{border-color:var(--ho);background:#fff}
.modal-input::placeholder{color:var(--tx3)}
.modal-select{width:100%;padding:9px 11px;border:1.5px solid var(--bdr);border-radius:var(--r);font-size:13px;font-family:var(--font);background:var(--bg);color:var(--tx);outline:none}
.modal-select:focus{border-color:var(--ho)}
.invite-result-info{display:flex;flex-direction:column;align-items:center;gap:8px;padding:14px 0 18px;text-align:center}
.invite-result-info p{font-size:13px;color:var(--tx);line-height:1.7}
.temp-info{font-size:13px;color:var(--tx);padding:9px 11px;background:var(--bg);border:1px solid var(--bdr);border-radius:var(--r);word-break:break-all}
.temp-pw-wrap{display:flex;gap:8px;align-items:center}
.temp-pw{flex:1;font-size:15px;font-weight:700;letter-spacing:.08em;color:var(--ho);background:var(--bg);border:1px solid var(--bdr);border-radius:var(--r);padding:9px 11px;font-family:monospace}
.btn-copy-pw{flex-shrink:0;padding:8px 14px;background:var(--hd);color:#fff;border:none;border-radius:var(--r);font-size:12px;font-weight:600;cursor:pointer;transition:background .15s;white-space:nowrap}
.btn-copy-pw:hover{background:var(--hd2)}

/* ── ADMIN ── */
.admin-pg{flex:1;overflow-y:auto;padding:18px}
.admin-card{background:var(--sur);border-radius:var(--r);border:1px solid var(--bdr);overflow:hidden;margin-bottom:14px}
.admin-card-hdr{padding:12px 16px;border-bottom:1px solid var(--bdr2);display:flex;align-items:center;justify-content:space-between}
.admin-card-title{font-size:12px;font-weight:700;color:var(--tx);text-transform:uppercase;letter-spacing:.04em}
.dtbl{width:100%;border-collapse:collapse}
.dtbl th{text-align:left;font-size:10px;font-weight:700;color:var(--tx3);padding:9px 16px;border-bottom:1px solid var(--bdr2);background:var(--bg);text-transform:uppercase;letter-spacing:.04em}
.dtbl td{padding:11px 16px;font-size:12px;border-bottom:1px solid var(--bdr2)}
.dtbl tr:last-child td{border-bottom:none}
.dtbl tr:hover td{background:rgba(245,244,242,.5)}
.rbadge{display:inline-flex;align-items:center;padding:2px 7px;border-radius:var(--r);font-size:10px;font-weight:700;letter-spacing:.02em}
.r-관리자,.r-admin{background:rgba(229,119,70,.1);color:var(--ho)}
.r-매니저,.r-upload{background:rgba(78,76,74,.08);color:var(--hd)}
.r-게스트,.r-readonly{background:var(--bg);color:var(--tx3)}

/* ── TOAST ── */
.toast{position:fixed;bottom:22px;left:50%;transform:translateX(-50%);background:var(--hd2);color:#fff;padding:9px 18px;border-radius:var(--r);font-size:12px;font-weight:500;z-index:9999;opacity:0;transition:opacity .25s;pointer-events:none;white-space:nowrap;box-shadow:var(--shadow-md)}
.toast.show{opacity:1}

/* ── PREVIEW LIGHTBOX ── */
.preview-modal{position:fixed;inset:0;background:rgba(0,0,0,.9);z-index:2000;display:flex;align-items:center;justify-content:center;padding:24px;animation:fadeIn .15s ease}
.preview-modal.hidden{display:none!important}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.preview-inner{position:relative;display:flex;flex-direction:column;align-items:center;max-width:min(90vw,1200px);max-height:90vh}
.preview-inner img{max-width:100%;max-height:80vh;object-fit:contain;border-radius:2px;box-shadow:0 16px 64px rgba(0,0,0,.7);display:block}
.preview-close{position:absolute;top:-40px;right:0;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);color:#fff;width:30px;height:30px;border-radius:var(--r);font-size:18px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}
.preview-close:hover{background:rgba(255,255,255,.2)}
.preview-name{margin-top:10px;color:rgba(255,255,255,.5);font-size:11px;font-family:var(--font)}


/* ── SPINNER ── */
.spinner{width:18px;height:18px;border:2px solid rgba(229,119,70,.15);border-top-color:var(--ho);border-radius:50%;animation:spin .65s linear infinite;display:inline-block}
@keyframes spin{to{transform:rotate(360deg)}}
.pg-load{flex:1;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:10px}
.pg-load p{font-size:12px;color:var(--tx2)}

/* ── CONTEXT MENU ── */
#ctxMenu{display:none;position:fixed;z-index:500;background:#fff;border:1px solid var(--bdr);border-radius:4px;box-shadow:var(--shadow-md);min-width:148px;overflow:hidden}
.ctx-item{display:flex;align-items:center;gap:8px;padding:9px 13px;font-size:12px;cursor:pointer;color:var(--tx);transition:background .1s}
.ctx-item:hover{background:var(--bg)}
.ctx-item.danger{color:#dc2626}
.ctx-item.danger:hover{background:#fef5f5}
.ctx-item svg{width:13px;height:13px;flex-shrink:0}
.ctx-sep{height:1px;background:var(--bdr2);margin:0 8px}

/* ── STATS BAR ── */
.stats-bar{display:flex;align-items:center;gap:16px;padding:0 18px;height:34px;background:var(--bg);border-bottom:1px solid var(--bdr2);flex-shrink:0}
.stat-item{display:flex;align-items:center;gap:4px;font-size:10px;color:var(--tx3)}
.stat-item strong{color:var(--tx2);font-weight:600}
.stat-dot{width:4px;height:4px;border-radius:50%;background:var(--bdr)}

/* ── DASHBOARD ── */
.dash-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;padding:20px 18px 0}
.dash-card{background:var(--sur);border:1px solid var(--bdr);border-radius:6px;padding:22px 20px;display:flex;align-items:center;gap:16px;transition:box-shadow .15s,border-color .15s;position:relative}
.dash-card:hover{box-shadow:var(--shadow-md);border-color:var(--bdr)}
.dash-card-accent{border-left:3px solid var(--ho)}
.dash-card-accent:hover{border-color:var(--ho)}
.dash-card-icon{width:48px;height:48px;border-radius:10px;background:var(--bg);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--ho)}
.dash-card-info{flex:1;min-width:0}
.dash-card-value{font-size:26px;font-weight:700;color:var(--tx);line-height:1.1;letter-spacing:-.02em}
.dash-card-label{font-size:11px;color:var(--tx2);margin-top:4px;font-weight:500}
.dash-card-sub{font-size:10px;color:var(--tx3);margin-top:2px}
.dash-card-arrow{font-size:18px;color:var(--ho);font-weight:700;flex-shrink:0}

/* Dashboard Activity */
.dash-activity-item{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--bdr2)}
.dash-activity-item:last-child{border-bottom:none}
.dash-act-icon{width:32px;height:32px;border-radius:8px;background:var(--bg);display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}
.dash-act-info{flex:1;min-width:0;display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.dash-act-user{font-size:12px;font-weight:600;color:var(--tx)}
.dash-act-action{font-size:10px;background:var(--hodim);color:var(--ho);padding:2px 7px;border-radius:var(--r);font-weight:700}
.dash-act-target{font-size:11px;color:var(--tx3);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:180px}
.dash-act-time{font-size:10px;color:var(--tx3);flex-shrink:0;white-space:nowrap}

/* Traffic Table */
.traffic-url{color:var(--ho);text-decoration:none;font-size:11px;word-break:break-all}
.traffic-url:hover{text-decoration:underline}
.traffic-bar-track{height:16px;background:var(--bg);border-radius:3px;overflow:hidden;min-width:80px}
.traffic-bar-fill{height:100%;background:linear-gradient(90deg,var(--ho),#f59e0b);border-radius:3px;transition:width .3s ease}

/* ── MOBILE ── */
@media(max-width:768px){
  .sidebar{display:none}
  .html-panel{display:none}
  .app{flex-direction:column}
  .main-area{padding-bottom:var(--bnh)}
  .bnav{display:flex;position:fixed;bottom:0;left:0;right:0;height:var(--bnh);background:var(--hd2);border-top:1px solid rgba(255,255,255,.06);z-index:50}
  .bn-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;cursor:pointer;color:rgba(255,255,255,.35);font-size:9px;font-weight:500;transition:color .15s;user-select:none;letter-spacing:.02em}
  .bn-item.active{color:var(--ho)}
  .bn-item svg{width:20px;height:20px}
  .file-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:7px}
  .topbar{padding:0 12px}
  .mob-sel{display:flex;align-items:center;justify-content:space-between;padding:8px 14px;background:var(--hd);color:#fff;font-size:12px;flex-shrink:0}
  .mob-sel.hide{display:none}
  .file-toolbar{padding:7px 10px;gap:5px}
  .stats-bar{display:none}
}
@media(min-width:769px){
  .bnav{display:none}
  .mob-sel{display:none}
}