:root {
	--bg0: #070a12;
	--bg1: #0a1020;
	--surface: rgba(255, 255, 255, 0.06);
	--surface2: rgba(255, 255, 255, 0.09);
	--stroke: rgba(255, 255, 255, 0.12);
	--text: rgba(255, 255, 255, 0.92);
	--muted: rgba(255, 255, 255, 0.68);
	--muted2: rgba(255, 255, 255, 0.52);
	--shadow: 0 18px 55px rgba(0, 0, 0, 0.45);
	--radius: 18px;
	--radius-sm: 12px;

	--a: #7c3aed;
	--b: #06b6d4;
	--c: #22c55e;
	--d: #f59e0b;
	--e: #fb7185;

	--focus: rgba(124, 58, 237, 0.6);
}

* {
	box-sizing: border-box;
}

html,
body {
	height: 100%;
}

body {
	margin: 0;
	color: var(--text);
	font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica,
		Arial, "Apple Color Emoji", "Segoe UI Emoji";
	background:
		radial-gradient(1200px 700px at 20% -10%, rgba(124, 58, 237, 0.35), transparent 55%),
		radial-gradient(900px 600px at 90% 10%, rgba(6, 182, 212, 0.25), transparent 50%),
		radial-gradient(900px 600px at 70% 120%, rgba(34, 197, 94, 0.18), transparent 52%),
		linear-gradient(180deg, var(--bg0), var(--bg1));
}

a {
	color: inherit;
	text-decoration: none;
}

.app {
	min-height: 100vh;
	display: grid;
	grid-template-columns: 280px 1fr;
}

.sidebar {
	position: sticky;
	top: 0;
	height: 100vh;
	padding: 18px;
	border-right: 1px solid var(--stroke);
	backdrop-filter: blur(14px);
	background: rgba(8, 12, 24, 0.45);
	overflow-y: auto;
}

.brand {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 10px 10px 14px;
}

.brand-mark {
	width: 42px;
	height: 42px;
	border-radius: 14px;
	background: rgba(255, 255, 255, 0.06);
	border: 1px solid rgba(255, 255, 255, 0.14);
	box-shadow: 0 10px 35px rgba(0, 0, 0, 0.35);
	display: grid;
	place-items: center;
	overflow: hidden;
}

.brand-mark svg {
	width: 22px;
	height: 22px;
}

.brand-mark img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	filter: drop-shadow(0 8px 18px rgba(0, 0, 0, 0.18));
}

.brand-title {
	display: grid;
	gap: 2px;
}

.brand-title strong {
	font-size: 14px;
	letter-spacing: 0.2px;
}

.brand-title span {
	font-size: 12px;
	color: var(--muted);
}

.nav {
	margin-top: 8px;
	display: grid;
	gap: 6px;
}

.nav a {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 10px 12px;
	border-radius: 14px;
	border: 1px solid transparent;
	color: var(--muted);
}

.nav a:hover {
	color: var(--text);
	background: rgba(255, 255, 255, 0.05);
	border-color: rgba(255, 255, 255, 0.08);
}

.nav a[aria-current="page"] {
	color: var(--text);
	background: linear-gradient(135deg, rgba(124, 58, 237, 0.2), rgba(6, 182, 212, 0.12));
	border-color: rgba(124, 58, 237, 0.32);
}

.nav .icon {
	width: 18px;
	height: 18px;
	color: rgba(255, 255, 255, 0.86);
}

.sidebar-footer {
	margin-top: 18px;
	padding-top: 14px;
	border-top: 1px solid var(--stroke);
	display: grid;
	gap: 10px;
}

.pill {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 8px 10px;
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.06);
	border: 1px solid rgba(255, 255, 255, 0.09);
	color: var(--muted);
	font-size: 12px;
}

.pill b {
	color: var(--text);
	font-weight: 600;
}

.content {
	padding: 24px;
}

.topbar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 14px;
	margin-bottom: 16px;
}

.topbar-left {
	display: flex;
	align-items: center;
	gap: 12px;
}

.mobile-menu {
	display: none;
	width: 42px;
	height: 42px;
	border-radius: 14px;
	border: 1px solid rgba(255, 255, 255, 0.12);
	background: rgba(255, 255, 255, 0.05);
	color: var(--text);
}

.mobile-menu:hover {
	background: rgba(255, 255, 255, 0.08);
}

.page-title {
	display: grid;
	gap: 2px;
}

.page-title h1 {
	margin: 0;
	font-size: 18px;
	letter-spacing: -0.01em;
}

.page-title p {
	margin: 0;
	color: var(--muted);
	font-size: 13px;
}

.actions {
	display: flex;
	align-items: center;
	gap: 10px;
}

.btn {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	padding: 10px 12px;
	border-radius: 14px;
	border: 1px solid rgba(255, 255, 255, 0.12);
	background: rgba(255, 255, 255, 0.06);
	color: var(--text);
	cursor: pointer;
	user-select: none;
}

.btn:hover {
	background: rgba(255, 255, 255, 0.09);
}

.btn:focus {
	outline: 3px solid var(--focus);
	outline-offset: 1px;
}

.btn.primary {
	border-color: rgba(124, 58, 237, 0.3);
	background: linear-gradient(135deg, rgba(124, 58, 237, 0.9), rgba(6, 182, 212, 0.65));
	box-shadow: 0 16px 40px rgba(124, 58, 237, 0.2);
}

.btn.primary:hover {
	filter: brightness(1.05);
}

.btn .icon {
	width: 18px;
	height: 18px;
}

.grid {
	display: grid;
	grid-template-columns: 1.4fr 0.9fr;
	gap: 16px;
}

.weekly {
	display: grid;
	grid-template-columns: repeat(7, minmax(140px, 1fr));
	gap: 10px;
}

.day {
	border-radius: 18px;
	border: 1px solid rgba(255, 255, 255, 0.12);
	background: rgba(255, 255, 255, 0.035);
	padding: 10px;
	min-height: 140px;
	display: grid;
	gap: 8px;
	align-content: start;
}

.day-header {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	gap: 10px;
}

.day-header b {
	font-size: 12px;
	letter-spacing: 0.02em;
}

.day-header span {
	font-size: 11px;
	color: var(--muted2);
}

.block {
	border-radius: 16px;
	border: 1px solid rgba(255, 255, 255, 0.12);
	background: rgba(255, 255, 255, 0.05);
	padding: 10px;
	display: grid;
	gap: 6px;
	cursor: pointer;
}

.block:hover {
	background: rgba(255, 255, 255, 0.08);
}

.block .meta {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 10px;
	font-size: 11px;
	color: var(--muted);
}

.block .title {
	font-size: 13px;
	font-weight: 650;
	letter-spacing: -0.01em;
}

.block[data-type="project"] {
	border-color: rgba(124, 58, 237, 0.35);
	background: linear-gradient(135deg, rgba(124, 58, 237, 0.16), rgba(6, 182, 212, 0.06));
}

.block[data-type="habit"] {
	border-color: rgba(34, 197, 94, 0.25);
}

.block[data-type="custom"] {
	border-color: rgba(245, 158, 11, 0.22);
}

.block[data-type="task"] {
	border-color: rgba(6, 182, 212, 0.28);
}

.drag-shelf {
	display: flex;
	gap: 10px;
	flex-wrap: wrap;
}

.drag-chip {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 10px 12px;
	border-radius: 999px;
	border: 1px solid rgba(255, 255, 255, 0.12);
	background: rgba(255, 255, 255, 0.05);
	color: rgba(255, 255, 255, 0.92);
	cursor: grab;
	user-select: none;
}

.drag-chip:active {
	cursor: grabbing;
}

.drag-chip .tag {
	font-size: 11px;
	color: rgba(255, 255, 255, 0.72);
	padding: 4px 8px;
	border-radius: 999px;
	border: 1px solid rgba(255, 255, 255, 0.12);
	background: rgba(0, 0, 0, 0.2);
}

.day[data-drop="1"] {
	outline: 3px solid rgba(124, 58, 237, 0.35);
	outline-offset: 2px;
}

.card {
	border-radius: var(--radius);
	background: rgba(255, 255, 255, 0.06);
	border: 1px solid rgba(255, 255, 255, 0.11);
	box-shadow: var(--shadow);
	overflow: hidden;
}

.card-header {
	padding: 14px 16px;
	border-bottom: 1px solid rgba(255, 255, 255, 0.09);
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 10px;
}

.card-header h2 {
	margin: 0;
	font-size: 14px;
	letter-spacing: -0.01em;
}

.card-header small {
	color: var(--muted2);
}

.card-body {
	padding: 16px;
}

.input {
	width: 100%;
	padding: 12px 12px;
	border-radius: 14px;
	border: 1px solid rgba(255, 255, 255, 0.12);
	background: rgba(10, 16, 32, 0.35);
	color: var(--text);
	font-size: 14px;
}

.input::placeholder {
	color: rgba(255, 255, 255, 0.42);
}

.input:focus {
	outline: 3px solid var(--focus);
	outline-offset: 1px;
}

.quick-add {
	display: grid;
	grid-template-columns: 1fr auto;
	gap: 10px;
	margin-bottom: 12px;
}

.list {
	display: grid;
	gap: 10px;
}

.item {
	display: grid;
	grid-template-columns: 1fr auto;
	gap: 12px;
	padding: 12px;
	border-radius: 16px;
	border: 1px solid rgba(255, 255, 255, 0.1);
	background: rgba(255, 255, 255, 0.04);
}

.item[data-selected="1"] {
	border-color: rgba(124, 58, 237, 0.45);
	background: linear-gradient(135deg, rgba(124, 58, 237, 0.14), rgba(6, 182, 212, 0.06));
}

.select-cell {
	display: none;
	align-items: center;
	gap: 10px;
}

.select-cell input[type="checkbox"] {
	width: 18px;
	height: 18px;
	accent-color: var(--a);
}

.select-mode .select-cell {
	display: inline-flex;
}

.select-mode .item-title strong {
	cursor: pointer;
}

.bulk-bar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 10px;
	padding: 10px 12px;
	border-radius: 16px;
	border: 1px solid rgba(255, 255, 255, 0.12);
	background: rgba(255, 255, 255, 0.04);
	margin-bottom: 12px;
}

.bulk-actions {
	display: flex;
	gap: 10px;
	align-items: center;
	flex-wrap: wrap;
}

.item:hover {
	background: rgba(255, 255, 255, 0.06);
	border-color: rgba(255, 255, 255, 0.14);
}

.item-title {
	display: flex;
	align-items: center;
	gap: 10px;
	min-width: 0;
}

.badge {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 6px 8px;
	border-radius: 999px;
	font-size: 12px;
	color: rgba(255, 255, 255, 0.82);
	border: 1px solid rgba(255, 255, 255, 0.12);
	background: rgba(255, 255, 255, 0.06);
	white-space: nowrap;
}

.badge .dot {
	width: 8px;
	height: 8px;
	border-radius: 999px;
	background: var(--b);
}

.item-title strong {
	font-size: 14px;
	font-weight: 650;
	letter-spacing: -0.01em;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.item p {
	margin: 6px 0 0 0;
	color: var(--muted);
	font-size: 12px;
	line-height: 1.35;
}

.item-actions {
	display: flex;
	align-items: center;
	gap: 8px;
}

.icon-btn {
	width: 38px;
	height: 38px;
	border-radius: 14px;
	border: 1px solid rgba(255, 255, 255, 0.12);
	background: rgba(255, 255, 255, 0.05);
	color: rgba(255, 255, 255, 0.9);
	cursor: pointer;
}

.icon-btn:hover {
	background: rgba(255, 255, 255, 0.08);
}

.icon-btn .icon {
	width: 18px;
	height: 18px;
}

.hint {
	margin-top: 12px;
	color: var(--muted2);
	font-size: 12px;
}

.stat {
	display: grid;
	gap: 8px;
}

.stat-row {
	display: grid;
	grid-template-columns: 1fr auto;
	gap: 10px;
	align-items: center;
	padding: 10px 12px;
	border-radius: 16px;
	border: 1px solid rgba(255, 255, 255, 0.1);
	background: rgba(255, 255, 255, 0.04);
}

.stat-row b {
	font-size: 13px;
	font-weight: 650;
}

.stat-row span {
	color: var(--muted);
	font-size: 12px;
}

.stat-row a {
	color: rgba(255, 255, 255, 0.9);
	text-decoration: underline;
	text-decoration-color: rgba(255, 255, 255, 0.25);
	text-underline-offset: 3px;
}

.stat-row a:hover {
	text-decoration-color: rgba(255, 255, 255, 0.55);
}

.kpi {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 8px 10px;
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.06);
	border: 1px solid rgba(255, 255, 255, 0.1);
	font-size: 12px;
	color: var(--muted);
}

.kpi .dot {
	width: 10px;
	height: 10px;
	border-radius: 999px;
	background: var(--c);
}

.modal-backdrop {
	position: fixed;
	inset: 0;
	background: rgba(0, 0, 0, 0.5);
	backdrop-filter: blur(10px);
	display: none;
	align-items: center;
	justify-content: center;
	padding: 18px;
	z-index: 50;
}

.modal-backdrop[data-open="1"] {
	display: flex;
}

.modal {
	width: min(720px, 100%);
	border-radius: 22px;
	background: rgba(12, 16, 32, 0.84);
	border: 1px solid rgba(255, 255, 255, 0.14);
	box-shadow: 0 40px 90px rgba(0, 0, 0, 0.55);
	overflow: hidden;
}

.modal-header {
	padding: 14px 16px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

.modal-header h3 {
	margin: 0;
	font-size: 14px;
	letter-spacing: -0.01em;
}

.steps {
	display: flex;
	gap: 10px;
	align-items: center;
	flex-wrap: wrap;
	color: var(--muted);
	font-size: 12px;
}

.steps .step {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 8px 10px;
	border-radius: 999px;
	border: 1px solid rgba(255, 255, 255, 0.12);
	background: rgba(255, 255, 255, 0.05);
}

.steps .step[data-active="1"] {
	color: rgba(255, 255, 255, 0.92);
	border-color: rgba(124, 58, 237, 0.34);
	background: linear-gradient(135deg, rgba(124, 58, 237, 0.22), rgba(6, 182, 212, 0.12));
}

.modal-body {
	padding: 16px;
	display: grid;
	gap: 12px;
}

.edit-form {
	display: grid;
	gap: 8px;
	padding: 12px;
	border-radius: 18px;
	border: 1px solid rgba(255, 255, 255, 0.1);
	background: rgba(255, 255, 255, 0.04);
}

.edit-label {
	font-size: 12px;
	color: var(--muted);
	margin-top: 4px;
}

.textarea {
	min-height: 88px;
	resize: vertical;
	line-height: 1.45;
}

.edit-actions {
	display: flex;
	align-items: center;
	gap: 10px;
	flex-wrap: wrap;
	margin-top: 6px;
}

.weekly-focus-form {
	display: grid;
	gap: 10px;
}

.weekly-focus-grid {
	display: grid;
	grid-template-columns: 1fr 1fr auto;
	gap: 12px;
	align-items: end;
}

.projects-focus {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 12px;
}

.focus-card {
	border-radius: 18px;
	border: 1px solid rgba(255, 255, 255, 0.12);
	background: rgba(255, 255, 255, 0.04);
	padding: 14px;
	display: grid;
	gap: 10px;
	min-height: 112px;
}

.focus-card[data-kind="primary"] {
	border-color: rgba(124, 58, 237, 0.35);
	background: linear-gradient(135deg, rgba(124, 58, 237, 0.18), rgba(6, 182, 212, 0.06));
}

.focus-card[data-kind="secondary"] {
	border-color: rgba(6, 182, 212, 0.28);
	background: linear-gradient(135deg, rgba(6, 182, 212, 0.14), rgba(34, 197, 94, 0.06));
}

.focus-card .title-row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 10px;
}

.focus-card .title-row strong {
	font-size: 14px;
	font-weight: 750;
	letter-spacing: -0.01em;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.focus-card .meta {
	display: flex;
	align-items: center;
	gap: 10px;
	flex-wrap: wrap;
	color: var(--muted);
	font-size: 12px;
}

.focus-empty {
	border-radius: 18px;
	border: 1px dashed rgba(255, 255, 255, 0.18);
	background: rgba(255, 255, 255, 0.02);
	padding: 14px;
	display: grid;
	gap: 6px;
	min-height: 112px;
	color: var(--muted);
}

.proj-section {
	margin-top: 10px;
	border-radius: 18px;
	border: 1px solid rgba(255, 255, 255, 0.1);
	background: rgba(255, 255, 255, 0.03);
	padding: 12px;
}

.proj-section:first-child {
	margin-top: 0;
}

.proj-section summary {
	list-style: none;
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	gap: 12px;
	cursor: pointer;
}

.proj-section summary::-webkit-details-marker {
	display: none;
}

.proj-section[open] summary {
	margin-bottom: 10px;
}

.proj-summary {
	display: inline-flex;
	align-items: center;
	gap: 10px;
}

.proj-section summary .hint {
	margin-top: 0;
}

.check-row {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	padding: 10px 12px;
	border-radius: 16px;
	border: 1px solid rgba(255, 255, 255, 0.12);
	background: rgba(255, 255, 255, 0.04);
	color: rgba(255, 255, 255, 0.85);
	font-size: 13px;
	user-select: none;
	cursor: pointer;
}

.check-row input {
	width: 18px;
	height: 18px;
	accent-color: var(--a);
}

.tabs {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	flex-wrap: wrap;
}

.tab {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 8px 12px;
	border-radius: 999px;
	border: 1px solid rgba(255, 255, 255, 0.12);
	background: rgba(255, 255, 255, 0.05);
	color: var(--muted);
	font-size: 12px;
}

.tab[data-active="1"] {
	color: var(--text);
	border-color: rgba(124, 58, 237, 0.4);
	background: linear-gradient(135deg, rgba(124, 58, 237, 0.2), rgba(6, 182, 212, 0.12));
}

.tab span:last-child {
	padding: 4px 8px;
	border-radius: 999px;
	border: 1px solid rgba(255, 255, 255, 0.12);
	background: rgba(0, 0, 0, 0.2);
	color: rgba(255, 255, 255, 0.85);
	font-size: 11px;
}

.banner {
	padding: 10px 12px;
	border-radius: 14px;
	border: 1px solid rgba(245, 158, 11, 0.35);
	background: rgba(245, 158, 11, 0.12);
	color: rgba(255, 255, 255, 0.9);
	font-size: 12px;
	margin-bottom: 12px;
}

.task-meta {
	display: flex;
	gap: 8px;
	flex-wrap: wrap;
	font-size: 12px;
	color: var(--muted2);
	margin-top: 6px;
}

.next-action {
	display: grid;
	gap: 10px;
	padding: 14px;
	border-radius: 18px;
	border: 1px solid rgba(124, 58, 237, 0.32);
	background: linear-gradient(135deg, rgba(124, 58, 237, 0.18), rgba(6, 182, 212, 0.08));
	margin-bottom: 12px;
}

.next-action .next-title {
	font-size: 14px;
	font-weight: 700;
	letter-spacing: -0.01em;
}

.next-action .next-actions {
	display: flex;
	gap: 10px;
	flex-wrap: wrap;
	align-items: center;
}

.next-action .next-actions input {
	min-width: 160px;
}

.badge.ghost {
	border-style: dashed;
	color: rgba(255, 255, 255, 0.8);
}

.day-select {
	display: grid;
	grid-template-columns: repeat(7, minmax(0, 1fr));
	gap: 6px;
	margin-top: 10px;
}

.day-select label {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
	padding: 6px 8px;
	border-radius: 12px;
	border: 1px solid rgba(255, 255, 255, 0.12);
	background: rgba(255, 255, 255, 0.05);
	font-size: 11px;
	color: rgba(255, 255, 255, 0.85);
	cursor: pointer;
	user-select: none;
}

.day-select input {
	accent-color: var(--a);
}

.choices {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 10px;
}

.choice {
	text-align: left;
	padding: 12px;
	border-radius: 18px;
	border: 1px solid rgba(255, 255, 255, 0.12);
	background: rgba(255, 255, 255, 0.05);
	cursor: pointer;
}

.choice:hover {
	background: rgba(255, 255, 255, 0.08);
}

.choice b {
	display: block;
	font-size: 13px;
	font-weight: 650;
	margin-bottom: 4px;
}

.choice span {
	font-size: 12px;
	color: var(--muted);
}

.modal-footer {
	padding: 14px 16px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 10px;
	border-top: 1px solid rgba(255, 255, 255, 0.1);
}

.toast {
	position: fixed;
	left: 16px;
	bottom: 16px;
	padding: 10px 12px;
	border-radius: 14px;
	background: rgba(8, 12, 24, 0.75);
	border: 1px solid rgba(255, 255, 255, 0.12);
	color: rgba(255, 255, 255, 0.9);
	font-size: 12px;
	backdrop-filter: blur(12px);
	display: none;
	z-index: 60;
}

.toast-inner {
	display: flex;
	align-items: center;
	gap: 10px;
}

.toast .toast-text {
	white-space: nowrap;
}

.toast .toast-action {
	padding: 8px 10px;
	border-radius: 12px;
	border: 1px solid rgba(255, 255, 255, 0.14);
	background: rgba(255, 255, 255, 0.06);
	color: rgba(255, 255, 255, 0.92);
	cursor: pointer;
}

.toast .toast-action:hover {
	background: rgba(255, 255, 255, 0.1);
}

.toast[data-open="1"] {
	display: block;
}

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

	.sidebar {
		position: fixed;
		left: 0;
		top: 0;
		transform: translateX(-102%);
		transition: transform 200ms ease;
		z-index: 40;
		width: min(320px, 86vw);
	}

	.sidebar[data-open="1"] {
		transform: translateX(0);
	}

	.mobile-menu {
		display: inline-flex;
		align-items: center;
		justify-content: center;
	}

	.grid {
		grid-template-columns: 1fr;
	}

	.choices {
		grid-template-columns: 1fr;
	}

	.projects-focus {
		grid-template-columns: 1fr;
	}

	.day-select {
		grid-template-columns: repeat(4, minmax(0, 1fr));
	}

	.weekly {
		grid-template-columns: 1fr;
	}

	.weekly-focus-grid {
		grid-template-columns: 1fr;
	}
}
