:root {
	--bg: #0b1020;
	--panel: #0f172a;
	--text: #e2e8f0;
	--muted: #94a3b8;
	--primary: #0ea5e9;
	--danger: #ef4444;
}

* { box-sizing: border-box; }

html, body {
	height: 100%;
}

body {
	margin: 0;
	font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji", "Segoe UI Emoji";
	color: var(--text);
	background: radial-gradient(1000px 1000px at 50% -200px, #0a1628 0%, var(--bg) 60%);
}

.container {
	max-width: 720px;
	margin: 0 auto;
	padding: env(safe-area-inset-top) 16px env(safe-area-inset-bottom);
}

.toolbar {
	display: flex;
	justify-content: space-between;
	margin-top: 20px;
	gap: 12px;
}

.list { margin-top: 16px; display: grid; gap: 12px; }

.row {
	background: var(--panel);
	border: 1px solid #1f2937;
	border-radius: 12px;
	padding: 10px;
	display: grid;
	grid-template-columns: 180px 1fr auto auto;
	gap: 10px;
	align-items: center;
	cursor: grab;
	transition: transform 0.2s, box-shadow 0.2s;
}

.row.summary-row {
	background: color-mix(in oklab, var(--panel), var(--primary) 15%);
	border-color: var(--primary);
}

.row:active { cursor: grabbing; }

.row.dragging {
	opacity: 0.5;
	transform: rotate(2deg);
	box-shadow: 0 8px 32px rgba(0, 0, 0, 0.3);
}

@media (max-width: 560px) {
	.row { grid-template-columns: 1fr; align-items: stretch; }
	.row .actions { justify-content: flex-end; }
	.toolbar { flex-direction: column; }
}

.time {
	font-variant-numeric: tabular-nums;
	font-size: 28px;
	line-height: 1;
	letter-spacing: 1px;
	padding: 10px 12px;
	border: 1px solid #1f2937;
	border-radius: 8px;
	background: #0b1222;
}

.input {
	width: 100%;
	padding: 10px 12px;
	border-radius: 8px;
	border: 1px solid #1f2937;
	background: #0b1222;
	color: var(--text);
}

.actions { display: flex; gap: 8px; }

.btn {
	appearance: none;
	border: 1px solid #1f2937;
	background: #0b1222;
	color: var(--text);
	padding: 10px 12px;
	border-radius: 8px;
	cursor: pointer;
	font-weight: 600;
	font-size: 16px;
	line-height: 1;
	min-width: 44px;
	display: flex;
	align-items: center;
	justify-content: center;
	-webkit-tap-highlight-color: transparent;
	touch-action: manipulation;
}

.btn.primary { border-color: color-mix(in oklab, var(--primary), #000 60%); background: color-mix(in oklab, var(--primary), #000 85%); }
.btn.primary:active { transform: translateY(1px); }

.btn.danger { border-color: color-mix(in oklab, var(--danger), #000 60%); background: color-mix(in oklab, var(--danger), #000 85%); }

/* Mobile touch improvements */
@media (hover: none) and (pointer: coarse) {
	.btn {
		min-height: 44px;
		padding: 12px 16px;
	}
	
	.input {
		min-height: 44px;
		font-size: 16px; /* Prevents zoom on iOS */
	}
}

.label-row {
	margin-top: 14px;
	display: grid;
	grid-template-columns: 72px 1fr;
	gap: 10px;
	align-items: center;
}

.label { color: var(--muted); }

.text {
	width: 100%;
	padding: 10px 12px;
	border-radius: 8px;
	border: 1px solid #1f2937;
	background: #0b1222;
	color: var(--text);
}

@media (max-width: 420px) {
	.time { font-size: 24px; }
} 