:root {
	--bg: #0f1115;
	--panel: #151922;
	--panel-2: #1b2130;
	--text: #e6e8ee;
	--muted: #9aa3b2;
	--primary: #7c4dff;
	--accent: #00e676;
	--danger: #ff5252;
	--border: #222738;
	--shadow: 0 10px 30px rgba(0, 0, 0, 0.35);
}

* { box-sizing: border-box; }
html, body { height: 100%; }
body {
	margin: 0;
	background: radial-gradient(1200px 600px at 80% -10%, #192036, rgba(25, 32, 54, 0) 60%) no-repeat, var(--bg);
	color: var(--text);
	font-family: "Mulish", ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Cantarell, Noto Sans, Helvetica Neue, Arial, Apple Color Emoji, Segoe UI Emoji, Segoe UI Symbol;
}

.brand-text h1,
h1, h2, h3, h4, h5, h6 {
	font-family: "Stolzl", "Mulish", ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Cantarell, Noto Sans, Helvetica Neue, Arial, Apple Color Emoji, Segoe UI Emoji, Segoe UI Symbol;
}

.app-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 16px 24px;
	border-bottom: 1px solid var(--border);
	background: rgba(15, 17, 21, 0.8);
	backdrop-filter: blur(6px);
	position: sticky;
	top: 0;
	z-index: 10;
}
.brand { display: flex; align-items: center; gap: 12px; }
.brand-mark { font-size: 28px; }
.brand-text h1 { margin: 0; font-size: 20px; }
.brand-text .subtitle { margin: 0; margin-top: 2px; color: var(--muted); font-size: 12px; }
.userbox { display: flex; align-items: center; gap: 8px; color: var(--muted); }

.layout {
	display: grid;
	grid-template-columns: 300px 1fr;
	gap: 16px;
	padding: 16px;
}

.sidebar {
	background: var(--panel);
	border: 1px solid var(--border);
	border-radius: 12px;
	padding: 16px;
	box-shadow: var(--shadow);
}
.sidebar h3 { margin-top: 0; }
.sidebar ol { margin: 0; padding-left: 20px; }
.sidebar li { margin-bottom: 8px; }
.sidebar li strong { color: var(--accent); }

.content { display: flex; flex-direction: column; gap: 16px; }
.card {
	background: var(--panel);
	border: 1px solid var(--border);
	border-radius: 12px;
	padding: 16px;
	box-shadow: var(--shadow);
}
.controls .row, .bug-form .row { display: flex; align-items: center; gap: 12px; }
.controls .row, .bug-form .row { gap: 14px; }
.current-url { margin-left: 8px; display: inline-flex; align-items: center; gap: 8px; }
.current-url a { color: var(--text); text-decoration: none; }
.steps h4 { margin-bottom: 8px; }
.steps ol { margin: 0; padding-left: 20px; color: var(--muted); }
.hint { display: block; color: var(--muted); font-size: 12px; }
.bookmarklet { margin-top: 12px; }
.bookmarklet-btn {
	display: inline-block;
	background: var(--panel-2);
	color: var(--text);
	border: 1px dashed var(--accent);
	border-radius: 8px;
	padding: 8px 10px;
	text-decoration: none;
	font-size: 13px;
}
/* Global link color to white */
a { color: var(--text); }
a:visited { color: var(--text); }
a:hover { color: var(--text); text-decoration: underline; }

.admin-toggle { display: flex; justify-content: flex-end; }
.admin-panel { margin-top: 8px; padding-top: 8px; border-top: 1px solid var(--border); }
.muted { color: var(--muted); }

.form-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(200px, 1fr));
	gap: 16px;
}
/* Make the Submit a Bug form more spacious */
.bug-form .form-grid {
	gap: 20px;
	margin-top: 8px;
	margin-bottom: 16px;
}
.bug-form label {
	gap: 10px;
}
.bug-form textarea {
	min-height: 140px;
}
.bug-form .row {
	margin-top: 12px;
	gap: 16px;
}
.required {
	color: var(--danger);
	font-size: 0.9em;
}
label { display: flex; flex-direction: column; gap: 8px; font-size: 14px; }
label span { color: var(--muted); }
label.full { grid-column: 1 / -1; }
input[type="text"], select, textarea {
	background: var(--panel-2);
	border: 1px solid var(--border);
	border-radius: 8px;
	padding: 14px 16px;
	color: var(--text);
	outline: none;
	line-height: 1.4;
}
/* Style file inputs (admin CSV uploader) */
input[type="file"] {
	background: var(--panel-2);
	border: 1px solid var(--border);
	border-radius: 8px;
	padding: 10px 12px;
	color: var(--text);
}
input[type="file"]::file-selector-button {
	background: var(--panel-2);
	border: 1px solid var(--border);
	color: var(--text);
	padding: 10px 12px;
	margin-right: 10px;
	border-radius: 8px;
	cursor: pointer;
}
input[type="file"]::file-selector-button:hover {
	border-color: #2b2f42;
}
textarea { resize: vertical; }

button {
	background: var(--panel-2);
	border: 1px solid var(--border);
	border-radius: 8px;
	padding: 12px 16px;
	color: var(--text);
	cursor: pointer;
	transition: transform 0.05s ease, border-color 0.2s ease, background-color 0.2s ease;
}
button:hover { border-color: #2b2f42; }
button:active { transform: translateY(1px); }
button.primary { background: linear-gradient(90deg, #6a4cff, var(--primary)); border-color: #6a4cff; }
button.accent { background: linear-gradient(90deg, #00e676, #00c853); border-color: #00e676; color: #0b1a13; font-weight: 700; }
button.ghost { background: transparent; }

.shake {
	animation: shake 0.6s ease-in-out infinite;
}
@keyframes shake {
	0% { transform: translateX(0); }
	20% { transform: translateX(-2px); }
	40% { transform: translateX(2px); }
	60% { transform: translateX(-2px); }
	80% { transform: translateX(2px); }
	100% { transform: translateX(0); }
}

.modal-backdrop {
	position: fixed;
	inset: 0;
	background: rgba(0,0,0,0.65);
	display: flex;
	align-items: center;
	justify-content: center;
	z-index: 20;
}
.modal {
	background: var(--panel);
	border: 1px solid var(--border);
	border-radius: 12px;
	padding: 20px;
	width: 90%;
	max-width: 420px;
	box-shadow: var(--shadow);
}
.form-row { display: flex; gap: 8px; }
.form-row input { flex: 1; }
.hidden { display: none !important; }

#confetti {
	position: fixed;
	inset: 0;
	pointer-events: none;
	z-index: 30;
}

.app-footer {
	position: fixed;
	right: 16px;
	bottom: 12px;
	z-index: 5;
	opacity: 0.5;
}
.app-footer .footer-logo {
	height: 20px;
	width: auto;
	display: block;
	filter: drop-shadow(0 2px 4px rgba(0,0,0,0.4));
}

@media (max-width: 900px) {
	.layout { grid-template-columns: 1fr; }
}


