:root{ --bg:#f6f5fb; --panel:#ffffff; --text:#211a32; --muted:#7b728d; --dark:#1d1730; --dark2:#261f3d; --accent:#ec4899; --accent2:#8b5cf6; --soft:#f0eafe; --line:#ebe7f2; --green:#10b981; --red:#ef4444; --blue:#3b82f6; --shadow:0 20px 45px rgba(39,30,64,.10); } *{box-sizing:border-box} body{margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif;background:linear-gradient(135deg,#f8f5ff 0%,#fff 45%,#fff3f8 100%);color:var(--text)} .hidden{display:none!important}.app{display:grid;grid-template-columns:260px minmax(0,1fr)310px;min-height:100vh;gap:20px;padding:18px}.sidebar{background:linear-gradient(180deg,#1d1730,#241b3a);border-radius:28px;color:white;padding:22px;display:flex;flex-direction:column;box-shadow:var(--shadow)}.logo-row{display:flex;align-items:center;gap:12px;margin-bottom:28px}.logo-mark,.brand-badge{width:44px;height:44px;border-radius:16px;background:linear-gradient(135deg,var(--accent),var(--accent2));display:grid;place-items:center;color:white;font-weight:900;box-shadow:0 12px 25px rgba(236,72,153,.35)}.logo-title{font-weight:850;font-size:22px}.logo-subtitle{font-size:12px;color:#c8bddb}.sidebar nav{display:flex;flex-direction:column;gap:8px}.nav-item{border:0;background:transparent;color:#d9d1e9;padding:13px 14px;border-radius:16px;text-align:left;font-weight:700;cursor:pointer;display:flex;justify-content:space-between;align-items:center}.nav-item:hover,.nav-item.active{background:rgba(255,255,255,.10);color:white}.nav-item em{font-style:normal;background:var(--accent);color:white;border-radius:999px;padding:2px 8px;font-size:12px}.sidebar-footer{margin-top:auto;border-top:1px solid rgba(255,255,255,.10);padding-top:18px}.current-user{font-size:13px;color:#e8ddf9;margin-bottom:10px}.main{min-width:0}.topbar{display:flex;gap:12px;align-items:center;margin-bottom:18px}.searchbox{flex:1;background:white;border:1px solid var(--line);border-radius:20px;height:54px;padding:0 16px;display:flex;align-items:center;gap:10px;box-shadow:0 10px 25px rgba(30,20,55,.05)}.searchbox input{border:0;outline:0;width:100%;font-size:15px;background:transparent}.filters{display:flex;gap:8px}.filters.compact input,.filters.compact select{max-width:145px}.topbar input,.topbar select,input,select{border:1px solid var(--line);border-radius:14px;padding:11px 12px;background:#fff;color:var(--text);outline:none}.primary-btn,.soft-btn,.ghost-btn,.danger-btn{border:0;border-radius:15px;padding:12px 16px;font-weight:800;cursor:pointer}.primary-btn{color:white;background:linear-gradient(135deg,var(--accent),var(--accent2));box-shadow:0 12px 25px rgba(139,92,246,.22)}.soft-btn{background:var(--soft);color:#6d3bd2}.ghost-btn{background:rgba(255,255,255,.08);color:inherit;border:1px solid rgba(255,255,255,.14)}.danger-btn{background:#fee2e2;color:#b91c1c}.stats-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-bottom:20px}.stat-card{background:white;border:1px solid var(--line);border-radius:24px;padding:18px;box-shadow:0 12px 30px rgba(33,26,50,.05)}.stat-card span{display:block;color:var(--muted);font-size:13px;font-weight:750}.stat-card strong{display:block;font-size:30px;margin:6px 0 2px}.stat-card small{color:var(--muted)}.section-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-end;margin:14px 0 16px}.section-head h2{margin:0;font-size:30px}.section-head p{margin:5px 0 0;color:var(--muted)}.action-row{display:flex;gap:8px}.view{display:none}.active-view{display:block}.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(185px,1fr));gap:16px}.photo-card{background:white;border:1px solid var(--line);border-radius:24px;overflow:hidden;box-shadow:0 10px 30px rgba(33,26,50,.06);cursor:pointer;transition:.15s transform,.15s box-shadow}.photo-card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}.photo-thumb{height:155px;background:#ebe7f2;position:relative;display:grid;place-items:center;overflow:hidden}.photo-thumb img{width:100%;height:100%;object-fit:cover}.video-badge,.status-badge{position:absolute;top:10px;right:10px;background:rgba(29,23,48,.82);color:white;border-radius:999px;padding:5px 9px;font-size:12px;font-weight:800}.status-badge.pending{left:10px;right:auto;background:#f59e0b}.photo-body{padding:12px}.photo-title{font-weight:850;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.photo-path{font-size:12px;color:var(--muted);margin:4px 0 8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.photo-tags{display:flex;gap:5px;flex-wrap:wrap}.tag-pill{border-radius:999px;color:white;font-size:11px;font-weight:850;padding:4px 8px}.rightbar{display:flex;flex-direction:column;gap:16px}.side-card,.panel-card{background:rgba(255,255,255,.82);backdrop-filter:blur(14px);border:1px solid var(--line);border-radius:26px;padding:18px;box-shadow:0 12px 30px rgba(33,26,50,.06)}.side-card h3{margin:0 0 12px}.mini-tree,.folder-tree{font-size:14px}.folder-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:9px 10px;border-radius:14px;cursor:pointer}.folder-row:hover,.folder-row.selected{background:var(--soft)}.folder-row small{color:var(--muted)}.folder-indent{padding-left:18px}.quick-tags,.tag-cloud{display:flex;flex-wrap:wrap;gap:8px}.quick-tags button,.tag-cloud button{border:0;color:white;border-radius:999px;padding:7px 11px;font-weight:800;cursor:pointer}.login-shell{min-height:100vh;display:grid;place-items:center;padding:20px;background:radial-gradient(circle at 20% 20%,#ffe3f2,transparent 30%),radial-gradient(circle at 90% 30%,#e8ddff,transparent 33%),#faf8ff}.login-card{width:min(430px,100%);background:white;border:1px solid var(--line);border-radius:32px;padding:34px;box-shadow:var(--shadow)}.login-card h1{margin:18px 0 4px;font-size:38px}.login-card p{color:var(--muted);margin:0 0 22px}.login-card form{display:flex;flex-direction:column;gap:10px}.login-card label,.modal label{font-weight:800;font-size:13px;color:#4b405f}.login-card button{margin-top:8px}.error-line{color:#b91c1c;font-weight:800;font-size:13px;min-height:18px}.modal{border:0;border-radius:26px;padding:0;box-shadow:var(--shadow);max-width:520px;width:calc(100% - 32px)}.modal::backdrop{background:rgba(20,16,35,.45);backdrop-filter:blur(4px)}.modal form,.photo-detail{padding:24px}.modal h3{margin:0 0 18px}.modal form{display:flex;flex-direction:column;gap:10px}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:14px}.modal .ghost-btn{color:var(--text);background:#f5f2fa;border:1px solid var(--line)}.check{display:flex;align-items:center;gap:10px}.hint{font-size:13px;color:var(--muted);font-weight:700}.wide-modal{max-width:960px}.photo-detail{display:grid;grid-template-columns:minmax(0,1.3fr)320px;gap:22px}.photo-preview-wrap{background:#100d1c;border-radius:22px;display:grid;place-items:center;min-height:420px;overflow:hidden}.photo-preview-wrap img{max-width:100%;max-height:70vh}.photo-info p{color:var(--muted);line-height:1.5}.stack-actions{flex-direction:column}.table-wrap table{width:100%;border-collapse:collapse}.table-wrap th,.table-wrap td{padding:12px;border-bottom:1px solid var(--line);text-align:left;font-size:14px}.role-badge{border-radius:999px;padding:4px 8px;font-weight:850;font-size:12px;background:var(--soft);color:#6d3bd2}.logs-list{display:flex;flex-direction:column;gap:10px}.log-item{padding:12px;border-radius:16px;background:#faf8ff;border:1px solid var(--line)}.log-item strong{display:block}.log-item small{color:var(--muted)}.empty{color:var(--muted);font-weight:700;padding:20px;text-align:center}.admin-only.hidden-role{display:none!important}@media(max-width:1180px){.app{grid-template-columns:230px minmax(0,1fr)}.rightbar{display:none}.stats-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:820px){.app{grid-template-columns:1fr;padding:10px}.sidebar{position:static;border-radius:22px}.topbar{flex-direction:column;align-items:stretch}.filters{flex-wrap:wrap}.stats-grid{grid-template-columns:1fr}.photo-detail{grid-template-columns:1fr}.photo-preview-wrap{min-height:260px}}