:root{--bg:#f6f8fa;--card:#fff;--border:#e5e7eb;--text:#0f172a;--muted:#334155;--brand:#0d47a1;--danger:#c62828}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:Inter,system-ui,Segoe UI,Roboto,Arial,sans-serif;background:var(--bg);color:var(--text)}a{color:inherit;text-decoration:none}.app{display:flex;min-height:100vh}.sidebar{width:260px;background:#fff;border-right:1px solid var(--border);padding:16px;position:relative;transition:transform .2s ease;transform:translate(0)}.sidebar.open{transform:translate(0)}.sidebar .brand{display:flex;align-items:center;justify-content:center;margin-bottom:16px;position:relative;padding-top:4px;padding-bottom:4px}.sidebar .brand img{height:120px;width:auto;object-fit:contain}.sidebar .brand .brand-small{font-weight:700;color:#64748b}.sidebar .closebtn{position:absolute;right:10px;top:8px;border:0;background:transparent;font-size:22px;display:none}.nav{display:flex;flex-direction:column;gap:8px;margin-top:8px}.nav a{padding:10px 12px;border-radius:12px;border:1px solid transparent;text-align:left}.nav a.active{background:#eef2ff;border-color:#d0d7de;font-weight:700;color:#0d47a1}.pushbottom{position:absolute;left:16px;right:16px;bottom:16px;display:flex;flex-direction:column;gap:8px}.logout{display:block;text-align:center;padding:10px 14px;border-radius:12px;background:var(--danger);color:#fff}.powered{font-size:12px;color:#64748b;text-align:center}.backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0003;opacity:0;pointer-events:none;transition:.2s}.backdrop.show{opacity:1;pointer-events:auto}.hamburger{position:fixed;left:16px;top:14px;z-index:1000;border:1px solid var(--border);background:#fff;border-radius:12px;padding:8px 10px}@media (max-width: 960px){.sidebar{position:fixed;left:0;top:0;bottom:0;transform:translate(-100%);z-index:1010}.sidebar.open{transform:translate(0)}}.content{flex:1;padding:24px}.cards{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}.card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;padding:18px;box-shadow:0 2px 6px #0000000a;display:flex;flex-direction:column;transition:.12s ease;opacity:1!important}.card:hover{transform:translateY(-2px);box-shadow:0 6px 16px #0000000f;border-color:#d0d7de}.card-title{color:#334155;font-weight:600;font-size:14px}.card-value{font-size:32px;font-weight:800;margin:8px 0 6px;color:#0f172a}.card-link{margin-top:auto;font-weight:600;color:#0d47a1}.brand-logo{height:40px;width:auto}.main{flex:1;display:flex;flex-direction:column;min-width:0}.topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;gap:12px;background:#fff;border-bottom:1px solid var(--border);padding:10px 16px}.hamburger{display:none}.topbar-left{display:flex;align-items:center;gap:10px}.topbar-right{margin-left:auto;display:flex;gap:10px}.brand-logo{height:32px;width:auto}.content{padding:16px}@media (max-width: 1024px){.hamburger{display:block;border:1px solid var(--border);background:#fff;border-radius:12px;padding:6px 10px}}.login-page{min-height:100vh;display:grid;place-items:center;background:var(--bg)}.login-card{width:100%;max-width:360px;background:#fff;border:1px solid var(--border);border-radius:16px;padding:24px;text-align:center}.login-logo{height:40px;width:auto;display:block;margin:0 auto 8px}.login-title{font-size:18px;margin:6px 0 20px;color:#0f172a}.login-form{display:flex;flex-direction:column;gap:10px;text-align:left}.input{border:1px solid var(--border);border-radius:12px;padding:10px 12px;background:#fff}.login-form .btn.primary{align-self:center;min-width:140px}.alert{background:#fee2e2;border:1px solid #fecaca;color:#991b1b;border-radius:12px;padding:8px 12px}.btn{border:1px solid var(--border);border-radius:10px;padding:8px 16px;font-weight:600;cursor:pointer;background:#fff;color:#0f172a;transition:all .15s ease}.btn:hover{background:#f1f5f9}.btn.primary{background:#0d47a1;color:#fff;border-color:#0d47a1;box-shadow:0 2px 6px #0d47a133}.btn.primary:hover{background:#1565c0;border-color:#1565c0;box-shadow:0 4px 10px #1565c04d}.btn.ghost{background:transparent;border:1px solid var(--border);color:#0d47a1}.btn.ghost:hover{background:#e3f2fd}.toolbar{display:flex;justify-content:space-between;gap:12px;align-items:center;margin-bottom:12px}.toolbar .left,.toolbar .right{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.input{padding:10px 12px;border:1px solid var(--border);border-radius:10px;background:#fff;min-width:240px}.select{padding:10px 12px;border:1px solid var(--border);border-radius:10px;background:#fff}.segmented{display:inline-flex;border:1px solid var(--border);border-radius:10px;overflow:hidden}.segmented button{background:#fff;padding:8px 12px;border:0}.segmented button+button{border-left:1px solid var(--border)}.segmented .on{background:#eef2ff;color:#0d47a1;font-weight:700}.bulkbar{background:#fff;border:1px solid var(--border);border-radius:12px;padding:10px 12px;display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.bulkbar .actions{display:flex;gap:8px}.media-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}@media (max-width: 1200px){.media-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width: 900px){.media-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 600px){.media-grid{grid-template-columns:1fr}}.media-card{background:#fff;border:1px solid var(--border);border-radius:14px;overflow:hidden;display:flex;flex-direction:column;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease}.media-card:hover{transform:translateY(-2px);box-shadow:0 6px 16px #0000000f}.media-card.sel{outline:2px solid #0d47a1}.media-card .thumb{position:relative;aspect-ratio:16 / 9;background:#f1f5f9;display:grid;place-items:center;overflow:hidden}.media-card .thumb img,.media-card .thumb video{width:100%;height:100%;object-fit:cover}.media-card .thumb .other{font-weight:700;color:#64748b}.badge{position:absolute;left:8px;top:8px;font-size:12px;background:#e5e7eb;padding:4px 8px;border-radius:999px}.badge.ready{background:#e8f5e9;color:#2e7d32}.badge.processing{background:#fff8e1;color:#ef6c00}.badge.error{background:#ffebee;color:#c62828}.media-card .meta{padding:10px 12px}.media-card .meta .name{font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.media-card .meta .sub{color:#64748b;font-size:12px;margin-top:4px}.table-wrap{background:#fff;border:1px solid var(--border);border-radius:12px;overflow:auto}.media-table{width:100%;border-collapse:separate;border-spacing:0}.media-table th,.media-table td{padding:10px 12px;border-bottom:1px solid #f1f5f9;text-align:left}.media-table thead th{position:sticky;top:0;background:#fff;z-index:1}.media-table tr.sel{background:#eef2ff}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;display:grid;place-items:center;z-index:2000}.modal{width:min(560px,92vw);background:#fff;border:1px solid var(--border);border-radius:16px;padding:18px;box-shadow:0 10px 30px #0003}.modal h3{margin:0 0 10px}.form-row{display:flex;flex-direction:column;gap:6px;margin-bottom:10px}.form-row label{font-weight:600;color:#334155}.form-row .hint{color:#64748b}.error{background:#ffebee;color:#c62828;border:1px solid #ffcdd2;border-radius:10px;padding:8px 10px;margin:8px 0}.modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:12px}.media-thumb,.media-thumb-video{width:100%;height:120px;border-radius:10px;object-fit:cover;background:#0f172a0d;display:block}.media-preview-img,.media-preview-video{max-width:100%;max-height:60vh;border-radius:12px;background:#0f172a0d;display:block;margin:0 auto}video::-webkit-media-controls{display:none!important}video::-webkit-media-controls-enclosure{display:none!important}video::-webkit-media-controls-panel{display:none!important}video::-webkit-media-controls-play-button{display:none!important}video::-webkit-media-controls-start-playback-button{display:none!important;-webkit-appearance:none}video::-webkit-media-controls-overlay-play-button{display:none!important}@media (min-width: 1025px){.topbar-left .brand-logo{display:none!important}}@media (max-width: 1024px){.topbar-left .brand-logo{display:block!important}}
