:root{color:#172026;background:#f5f7f8;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{margin:0}button,input,select{font:inherit}button{border:0;border-radius:6px;background:#146c5f;color:#fff;cursor:pointer;min-height:38px;padding:0 14px}button:disabled,.button-link[aria-disabled=true]{cursor:not-allowed;opacity:.55}.button-link{align-items:center;background:#146c5f;border-radius:6px;color:#fff;display:inline-flex;min-height:38px;padding:0 14px;text-decoration:none}input,select{border:1px solid #c8d0d5;border-radius:6px;min-height:38px;padding:8px 10px}.center,.auth-shell{align-items:center;display:flex;min-height:100vh;justify-content:center;padding:24px}.auth-panel,.modal{background:#fff;border:1px solid #dce2e6;border-radius:8px;box-shadow:0 18px 60px #1927341f}.auth-panel{display:grid;gap:18px;max-width:380px;padding:28px;width:100%}.auth-panel h1,.topbar h1,.player-header h1{letter-spacing:0;margin:0}label{display:grid;gap:6px}.app-shell{margin:0 auto;max-width:1120px;padding:28px}.topbar{align-items:center;display:flex;justify-content:space-between;gap:18px;margin-bottom:24px}.topbar p,.player-header p,.modal p{color:#5d6a72;margin:6px 0 0}.link-button{background:transparent;color:#146c5f;min-height:auto;padding:0 0 0 12px}.link-button:hover{text-decoration:underline}.secondary{background:#41525d}.danger{background:#a93434}.toolbar,.table-wrap{background:#fff;border:1px solid #dce2e6;border-radius:8px;margin-bottom:18px;padding:16px}.upload-form{align-items:center;display:grid;gap:12px;grid-template-columns:1fr auto auto}.dropzone{align-items:center;border:1px dashed #9cabb4;border-radius:8px;cursor:pointer;display:flex;justify-content:space-between;min-height:72px;padding:14px 16px;transition:background .14s ease,border-color .14s ease}.dropzone small{color:#5d6a72}.dropzone.is-dragging{background:#edf6f3;border-color:#146c5f}.file-input{display:none}.progress{align-items:center;background:#e8edef;border-radius:999px;display:grid;height:18px;margin-top:12px;overflow:hidden;position:relative}.progress div{background:#146c5f;height:100%;transition:width .12s ease}.progress span{color:#172026;font-size:12px;font-weight:650;left:50%;position:absolute;transform:translate(-50%)}.error{color:#a93434;margin:8px 0 0}table{border-collapse:collapse;table-layout:fixed;width:100%}th,td{border-bottom:1px solid #e4e9ec;padding:12px 10px;text-align:left;vertical-align:middle}th{color:#41525d;font-size:13px;font-weight:650}.actions{display:flex;gap:8px;min-width:132px}.actions button{flex:0 0 auto;white-space:nowrap}.filename-cell{line-height:1.35;max-height:42px;max-width:360px;overflow:hidden;word-break:break-all}.owner-cell{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.time-cell{width:170px}th:nth-last-child(1),td:nth-last-child(1){width:150px}th:nth-last-child(2),td:nth-last-child(2){width:170px}th:nth-last-child(3),td:nth-last-child(3),th:nth-last-child(4),td:nth-last-child(4){width:88px}.empty{color:#5d6a72;text-align:center}.user-form{display:grid;gap:10px;grid-template-columns:1fr 1fr 160px auto;margin:12px 0 18px}.modal-backdrop{align-items:center;background:#1018206b;display:flex;top:0;right:0;bottom:0;left:0;justify-content:center;padding:24px;position:fixed}.modal{display:grid;gap:14px;max-width:420px;padding:22px;width:100%}.modal h2{margin:0}.muted{color:#5d6a72}.segmented{background:#eef2f4;border-radius:8px;display:grid;gap:4px;grid-template-columns:repeat(3,1fr);padding:4px}.segmented button{background:transparent;color:#41525d}.segmented button.active{background:#146c5f;color:#fff}.modal-actions{display:flex;gap:10px;justify-content:flex-end}.qr-preview{border:1px solid #dce2e6;border-radius:6px;height:min(320px,70vw);width:min(320px,70vw)}.player-shell{align-items:center;background:#000;display:flex;height:100dvh;justify-content:center;margin:0;overflow:hidden;position:fixed;top:0;right:0;bottom:0;left:0;width:100vw}.player-meta{background:#0000006b;border-radius:6px;color:#ffffffbd;font-size:13px;left:14px;line-height:1.4;max-width:min(420px,calc(100vw - 28px));overflow:hidden;padding:6px 8px;position:absolute;text-overflow:ellipsis;top:12px;white-space:nowrap;z-index:1}.player-message{color:#ffffffd1;margin:0}.video-player{background:#000;height:100dvh;object-fit:contain;width:100%}@media(max-width:720px){.app-shell{padding:16px}.topbar,.upload-form,.user-form{align-items:stretch;grid-template-columns:1fr}.dropzone{align-items:flex-start;flex-direction:column}.table-wrap{overflow-x:auto}table{min-width:760px}}
