:root{
	--bg:#0e1114;
	--panel:#0b0d10;
	--muted:#98a0aa;
	--text:#e6eef8;
	--accent:#5865f2;
	--accent-2:#1f8efd;
	--success:#2ecc71;
	--danger:#ff6b6b;
	--surface-border:rgba(255,255,255,0.03);
}

/* Desktop override: ensure controls and pager stay horizontal on wider viewports */
@media (min-width:641px) {
	/* Desktop: stack the toolbar vertically so the left-buttons group sits above the sort/pager */
	.controls{display:flex;flex-direction:row;align-items:stretch;gap:14px}
	.controls .left-controls{display:flex;flex-direction:row;gap:10px}
	.controls .left-controls .btn{margin-right:0}
	.right-controls{display:flex;align-items:center;gap:12px;align-self:flex-end}
	.pager{display:flex;align-items:center;gap:10px}
	.pager #pageInfo{background:linear-gradient(180deg, rgba(255,255,255,0.01), transparent);padding:6px 12px;border-radius:10px;border:1px solid rgba(255,255,255,0.02);color:var(--muted);font-weight:600;display:inline-block}
}
.base-font{font-family:Inter,ui-sans-serif,system-ui,-apple-system,'Segoe UI',Roboto,'Helvetica Neue',Arial}
.base-font{font-family: 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif}
html{font-size:18px}
body{height:100%;margin:0;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;line-height:1.6;font-family:'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif}
.ui-shell{max-width:1300px;margin:24px auto;padding:28px}
.ui-header{display:flex;align-items:center;gap:16px;margin-bottom:14px}
.brand .logo{font-weight:800;font-size:22px;letter-spacing:0.2px}
.brand .subtitle{font-size:14px;color:var(--muted)}
.card{background:var(--panel);border:1px solid var(--surface-border);padding:16px;border-radius:10px;margin-bottom:14px;box-shadow:0 2px 8px rgba(3,4,6,0.6)}
.card{background:var(--panel);border:1px solid var(--surface-border);padding:20px;border-radius:12px;margin-bottom:18px;box-shadow:0 6px 18px rgba(3,4,6,0.6)}
.card-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.card-head h3{margin:0;font-size:18px}
.small{font-size:13px}
.muted{color:var(--muted);line-height:1.5}
.constrained{max-width:1300px;margin-left:auto;margin-right:auto}

/* Inputs and buttons */
.textInput, textarea{width:100%;box-sizing:border-box;padding:12px;border-radius:10px;border:1px solid rgba(255,255,255,0.04);background:transparent;color:var(--text);font-size:15px}
textarea{min-height:100px}
.btn{background:linear-gradient(180deg,var(--accent),var(--accent-2));color:white;border:none;padding:10px 16px;border-radius:12px;cursor:pointer;font-weight:700;display:inline-flex;align-items:center;gap:8px;box-shadow:0 6px 18px rgba(5,6,8,0.6);transition:transform .08s ease,box-shadow .12s ease,opacity .12s ease}
.btn:hover{transform:translateY(-1px);box-shadow:0 10px 26px rgba(5,6,8,0.65)}
.btn:active{transform:translateY(0);box-shadow:0 4px 10px rgba(5,6,8,0.5)}
.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}
.btn.small{padding:6px 10px;font-size:14px;border-radius:10px}
.btn.warn{background:linear-gradient(180deg,#ff7b5a,#ff6b6b)}
.btn.ghost{background:transparent;border:1px solid rgba(255,255,255,0.06);color:var(--text);box-shadow:none}

/* Controls: select and pager styling */
.selectWrap{display:inline-flex;align-items:center;gap:8px;background:transparent}
.selectWrap select, #sortSelect, #sortOrder{appearance:none;-webkit-appearance:none;border:1px solid rgba(255,255,255,0.06);background:var(--panel);color:var(--text);padding:8px 12px;border-radius:10px;font-size:14px;min-width:110px}
.selectWrap select option, #sortSelect option, #sortOrder option{background:var(--panel);color:var(--text)}
.selectWrap select:focus, #sortSelect:focus, #sortOrder:focus{outline:none;box-shadow:0 0 0 4px rgba(88,101,242,0.12)}

.pager{display:flex;align-items:center;gap:10px}
.pager button{min-width:36px;height:36px;padding:0;border-radius:10px;background:linear-gradient(180deg, rgba(255,255,255,0.02), transparent);border:1px solid rgba(255,255,255,0.03);display:inline-flex;align-items:center;justify-content:center}
.pager button svg{width:18px;height:18px}
.pager .pageInfo{background:linear-gradient(180deg, rgba(255,255,255,0.01), transparent);padding:6px 12px;border-radius:10px;border:1px solid rgba(255,255,255,0.02);color:var(--muted);font-weight:600}

.file-grid{display:flex;flex-wrap:wrap;gap:12px}
.file{background:linear-gradient(180deg,rgba(255,255,255,0.02),transparent);padding:12px;border-radius:12px;border:1px solid rgba(255,255,255,0.03);min-width:150px}

/* Uploaded file card */
.file-card{display:flex;gap:14px;align-items:flex-start;padding:12px;background:transparent;border-radius:8px}
.file-card .thumb{width:96px;height:96px;border-radius:8px;object-fit:cover;flex:0 0 96px;border:1px solid rgba(255,255,255,0.03);background:linear-gradient(180deg,rgba(255,255,255,0.02),transparent)}
.file-card .file-meta{flex:1}
.file-card .file-title{font-weight:700;margin-bottom:6px}
.file-card .file-submeta{color:var(--muted);font-size:13px;margin-bottom:8px}
.file-card .file-actions{display:flex;flex-direction:column;gap:8px}
.file-card .file-actions .btn{padding:6px 10px;font-size:13px}
.file-card .file-actions{display:flex;flex-direction:column;gap:10px;align-items:flex-start}
.file-card .file-actions .btn{padding:6px 12px;font-size:13px;border-radius:999px;background:linear-gradient(180deg,var(--accent),var(--accent-2));box-shadow:0 6px 18px rgba(5,6,8,0.45)}
.file-card .file-actions a.btn{display:inline-flex;align-items:center;gap:8px;color:white;text-decoration:none}
.file-card .file-actions button.btn{border:none}
.file-card .file-actions button.btn.warn{background:linear-gradient(180deg,#ff7b5a,#ff6b6b)}
.file-card .file-actions a.btn:visited{color:white}
.file-card .file-actions .btn.small{padding:5px 10px}

/* Trash list rows */
.fileRow.trash{display:flex;gap:10px;align-items:center;padding:8px 0;border-bottom:1px dashed rgba(255,255,255,0.02)}
.fileRow.trash .btn{margin-left:8px}

.result{white-space:pre-wrap;background:#081018;padding:14px;border-radius:12px;border:1px solid rgba(255,255,255,0.03);font-size:14px;width:100%;box-sizing:border-box}
.result pre, .result pre.code{white-space:pre;overflow:auto;max-width:100%;box-sizing:border-box}
.mono{font-family:Menlo,Monaco,monospace}

/* Code blocks and Prism helpers */
pre[class*="language-"]{background:linear-gradient(180deg, rgba(11,13,16,0.96), rgba(6,8,10,0.96));padding:18px;border-radius:10px;overflow:auto;border:1px solid rgba(255,255,255,0.04);color:var(--text);box-shadow:inset 0 1px 0 rgba(255,255,255,0.02)}
code[class*="language-"]{font-family:Consolas,Menlo,Monaco,monospace;font-size:14px;color:var(--text)}

/* Prism token color overrides to better match the demo dark theme */
.token.comment, .token.prolog, .token.doctype, .token.cdata { color: var(--muted); font-style: italic; }
.token.punctuation { color: rgba(255,255,255,0.6); }
.token.namespace { opacity: .7; }
.token.property, .token.tag, .token.constant, .token.symbol, .token.deleted { color: var(--accent-2); }
.token.boolean, .token.number { color: #f6c177; }
.token.selector, .token.attr-name, .token.string, .token.char, .token.builtin, .token.inserted { color: var(--success); }
.token.operator, .token.entity, .token.url, .language-css .token.string, .style .token.string { color: #9fe6a0; }
.token.atrule, .token.attr-value, .token.keyword { color: var(--accent); font-weight:700; }
.token.function { color: #8ad1ff; }
.token.regex, .token.important { color: #ffd580; }
.token.variable { color: #ffd580; }

code.inline, :not(pre) > code { background: rgba(255,255,255,0.02); padding:2px 6px; border-radius:6px; font-size:0.95em }

pre[class*="language-"], pre.code, pre[class*="language-"] code, pre.code code {
	white-space: pre;
	tab-size: 4;
	-moz-tab-size: 4;
	-o-tab-size: 4;
}
code[class*="language-"], pre[class*="language-"] code {
	display: block;
	font-family: Menlo, Monaco, Consolas, 'Courier New', monospace;
	line-height: 1.5;
}

/* Layout helpers */
.playgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.controls{display:flex;justify-content:space-between;align-items:center;gap:14px;margin-top:12px}

/* file drop */
.fileDrop{border:1px dashed rgba(255,255,255,0.04);border-radius:12px;padding:22px 18px;text-align:center;color:var(--muted);min-height:86px;display:flex;align-items:center;justify-content:center}
.fileDrop-inner{font-size:14px}

/* file input and choose label */
.fileInput{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0;padding:0}
.fileDrop label.linkish{display:inline-block;padding:8px 12px;margin-left:8px;background:linear-gradient(180deg,var(--accent),var(--accent-2));color:#fff;border-radius:10px;cursor:pointer;font-weight:700}

/* footer */
.ui-footer{margin-top:8px;color:var(--muted);font-size:13px;text-align:center}

/* Tables inside docs */
.card .acc-body table{width:100%;border-collapse:collapse;margin-top:10px}
.card .acc-body th, .card .acc-body td{padding:10px 12px;text-align:left;border-bottom:1px solid rgba(255,255,255,0.03);vertical-align:top;font-size:14px}
.card .acc-body thead th{color:var(--muted);font-weight:700}
.card .acc-body tbody tr:nth-child(odd){background:transparent}

details.acc{background:linear-gradient(180deg,rgba(255,255,255,0.01),transparent);border:1px solid rgba(255,255,255,0.03);border-radius:10px;padding:8px;margin:8px 0}
details.acc[open]{box-shadow:0 8px 24px rgba(0,0,0,0.6)}
details.acc summary{list-style:none;cursor:pointer;padding:8px 10px;border-radius:8px;display:flex;align-items:center;gap:12px;font-weight:700}
details.acc summary::-webkit-details-marker{display:none}
details.acc summary:before{content:'▸';display:inline-block;transform:rotate(0);transition:transform .18s ease;margin-right:6px;color:var(--accent)}
details.acc[open] summary:before{transform:rotate(90deg)}
.acc-body{padding:12px 10px;border-top:1px solid rgba(255,255,255,0.02);margin-top:8px}

@media(max-width:900px){.playgrid{grid-template-columns:1fr}.ui-shell{padding:16px}}

@media(max-width:900px){.playgrid{grid-template-columns:1fr}.ui-shell{padding:12px}}

/* Mobile specific fixes */
@media (max-width:640px) {
	:root{--panel:#0b0d10}
	html{font-size:16px}
	.ui-shell{max-width:100%;margin:0px auto;padding:8px}
	.card{padding:12px;border-radius:8px}

	.card-head h3{font-size:16px}
	.card .acc-body{padding:8px 0}
	.card .acc-body table{display:block;width:auto;overflow:auto;-webkit-overflow-scrolling:touch;margin-top:8px}
	.card .acc-body th, .card .acc-body td{padding:6px 8px;font-size:13px;white-space:normal;word-break:break-word}
	.card .acc-body thead{display:table-header-group}
	.card .acc-body tbody{display:table-row-group}
	pre[class*="language-"]{padding:12px;font-size:13px;border-radius:8px}
	code[class*="language-"]{font-size:13px}

	pre[class*="language-"], pre.code { max-width:100%; box-sizing:border-box; overflow:auto; }
	pre[class*="language-"] code, pre.code code { box-sizing:border-box; display:block; }
	.controls{gap:8px}
	.right-controls{display:flex;gap:8px;width:100%;justify-content:center;}
	.playgrid{grid-template-columns:1fr;gap:10px}
	.fileDrop{padding:14px}

	.docs-card, .card.docs-card { max-width:640px; margin-left:auto; margin-right:auto }
	.docs-card .acc-body, .docs-card details.acc { margin-left:0; margin-right:0; padding: 5px; }
	.docs-card pre[class*="language-"]{ margin:0px }

	.card .acc-body table{width:auto}
	.card .acc-body th:nth-child(1), .card .acc-body td:nth-child(1){min-width:120px}
	.card .acc-body th:nth-child(2), .card .acc-body td:nth-child(2){min-width:90px}
	.card .acc-body th:nth-child(3), .card .acc-body td:nth-child(3){min-width:90px}
	.card .acc-body th:last-child, .card .acc-body td:last-child{min-width:160px}

	.controls{flex-direction:column;align-items:flex-start;gap:10px;justify-content:center;width:100%;}
	.controls .left-controls{width:100%;display:flex;flex-wrap:wrap;gap:8px;justify-content:center;}
	.controls .left-controls .btn{margin-right:0}

	.btn{padding:8px 12px;font-size:14px}
	.pager button{min-width:32px;height:32px}
	.selectWrap select, #sortSelect, #sortOrder{min-width:90px}

	.result {padding: 5px;}

}

	.upload-button-wrap { display:flex;justify-content:flex-end;align-items:center;gap:10px; width:100%; margin:10px 0 }