/* Import cute fonts */
@import url('https://fonts.googleapis.com/css2?family=Nunito:wght@400;600;700;800&family=Fredoka+One&display=swap');

/* Nyaoshi Website - Cute Pastel Cat Theme */

:root {
	/* Pastel Color Palette */
	--pink-light: #fce4ec;
	--pink-medium: #f8bbd9;
	--pink-dark: #f48fb1;

	--purple-light: #ede7f6;
	--purple-medium: #d1c4e9;
	--purple-dark: #b39ddb;

	--cyan-light: #e0f7fa;
	--cyan-medium: #b2ebf2;
	--cyan-dark: #80deea;

	--lavender-light: #f3e5f5;
	--lavender-medium: #e1bee7;
	--lavender-dark: #ce93d8;

	--white: #ffffff;
	--off-white: #fafafe;

	/* Semantic Colors */
	--bg-primary: var(--off-white);
	--bg-secondary: var(--white);
	--bg-accent: var(--purple-light);

	--text-primary: #4a4458;
	--text-secondary: #7e7591;
	--text-accent: #9c64a6;

	--border-color: var(--purple-medium);
	--shadow-color: rgba(156, 100, 166, 0.15);

	/* Status Colors */
	--success: var(--cyan-medium);
	--warning: var(--pink-medium);
	--error: #ffcdd2;
	--info: var(--lavender-medium);

	/* Spacing */
	--spacing-xs: 4px;
	--spacing-sm: 8px;
	--spacing-md: 16px;
	--spacing-lg: 24px;
	--spacing-xl: 32px;

	/* Border Radius */
	--radius-sm: 8px;
	--radius-md: 12px;
	--radius-lg: 20px;
	--radius-round: 50%;

	/* Fonts */
	--font-primary: 'Nunito', 'Quicksand', system-ui, sans-serif;
	--font-display: 'Fredoka One', 'Nunito', sans-serif;

	/* Transitions */
	--transition-fast: 150ms ease;
	--transition-normal: 250ms ease;
	--transition-bounce: 300ms cubic-bezier(0.68, -0.55, 0.265, 1.55);
}

/* Reset */
*, *::before, *::after {
	box-sizing: border-box;
	margin: 0;
	padding: 0;
}

html {
	scroll-behavior: smooth;
}

body {
	font-family: var(--font-primary);
	background: var(--bg-primary);
	color: var(--text-primary);
	line-height: 1.6;
	min-height: 100vh;
	background:
		radial-gradient(circle at 20% 80%, var(--pink-light) 0%, transparent 25%),
		radial-gradient(circle at 80% 20%, var(--purple-light) 0%, transparent 25%),
		radial-gradient(circle at 40% 40%, var(--cyan-light) 0%, transparent 20%),
		var(--bg-primary);
	background-attachment: fixed;
}

/* Typography */
h1, h2, h3, h4 {
	font-family: var(--font-display);
	color: var(--text-accent);
	line-height: 1.3;
}

h1 { font-size: 2.5rem; }
h2 { font-size: 1.75rem; }
h3 { font-size: 1.25rem; }
h4 { font-size: 1rem; }

p { margin-bottom: 0.75rem; }
p:last-child { margin-bottom: 0; }

a {
	color: var(--text-accent);
	text-decoration: none;
	transition: color var(--transition-fast);
}

a:hover {
	color: var(--purple-dark);
	text-decoration: underline;
}

/* =============================================
   NAVIGATION
   ============================================= */

.site-nav {
	position: sticky;
	top: 0;
	z-index: 100;
	background: rgba(255, 255, 255, 0.75);
	backdrop-filter: blur(16px);
	-webkit-backdrop-filter: blur(16px);
	border-bottom: 2px solid var(--purple-medium);
	padding: var(--spacing-sm) var(--spacing-lg);
}

.nav-inner {
	max-width: 1100px;
	margin: 0 auto;
	display: flex;
	align-items: center;
	justify-content: space-between;
}

.nav-brand {
	display: flex;
	align-items: center;
	gap: var(--spacing-sm);
	text-decoration: none;
	color: var(--text-accent);
}

.nav-brand:hover { text-decoration: none; }

.nav-brand img {
	width: 36px;
	height: 36px;
	object-fit: contain;
}

.nav-brand span {
	font-family: var(--font-display);
	font-size: 1.3rem;
}

.nav-links {
	display: flex;
	align-items: center;
	gap: var(--spacing-md);
	list-style: none;
}

.nav-links a {
	font-weight: 600;
	color: var(--text-secondary);
	padding: var(--spacing-xs) var(--spacing-sm);
	border-radius: var(--radius-sm);
	transition: all var(--transition-fast);
}

.nav-links a:hover {
	color: var(--text-accent);
	text-decoration: none;
	background: var(--purple-light);
}

.nav-links a.active {
	color: var(--text-accent);
	background: var(--purple-light);
}

.nav-download {
	background: linear-gradient(135deg, var(--purple-medium), var(--purple-dark)) !important;
	color: white !important;
	padding: var(--spacing-xs) var(--spacing-md) !important;
}

.nav-download:hover {
	background: linear-gradient(135deg, var(--purple-dark), var(--lavender-dark)) !important;
	transform: translateY(-1px);
}

.hamburger {
	display: none;
	background: none;
	border: none;
	cursor: pointer;
	padding: var(--spacing-xs);
	color: var(--text-accent);
	font-size: 1.5rem;
}

/* =============================================
   LAYOUT
   ============================================= */

.container {
	max-width: 1100px;
	margin: 0 auto;
	padding: var(--spacing-lg);
}

.container-wide {
	max-width: 1600px;
}

.page-header {
	text-align: center;
	padding: var(--spacing-xl) 0;
}

.page-header h1 {
	margin-bottom: var(--spacing-sm);
}

.page-header p {
	color: var(--text-secondary);
	font-size: 1.1rem;
}

/* =============================================
   BUTTONS
   ============================================= */

button, .btn {
	font-family: var(--font-primary);
	font-weight: 600;
	padding: var(--spacing-sm) var(--spacing-md);
	border: 2px solid transparent;
	border-radius: var(--radius-md);
	cursor: pointer;
	transition: all var(--transition-bounce);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--spacing-xs);
	font-size: 0.95rem;
	text-decoration: none;
}

button:hover, .btn:hover {
	transform: translateY(-2px);
	box-shadow: 0 4px 12px var(--shadow-color);
	text-decoration: none;
}

button:active, .btn:active {
	transform: translateY(0) scale(0.98);
}

.btn-primary {
	background: linear-gradient(135deg, var(--purple-medium), var(--purple-dark));
	color: white;
	border-color: var(--purple-dark);
}

.btn-secondary {
	background: var(--white);
	color: var(--text-accent);
	border-color: var(--border-color);
}

.btn-success {
	background: linear-gradient(135deg, var(--cyan-medium), var(--cyan-dark));
	color: #2a6f7a;
	border-color: var(--cyan-dark);
}

.btn-danger {
	background: linear-gradient(135deg, #ffcdd2, #ef9a9a);
	color: #c62828;
	border-color: #ef9a9a;
}

.btn-lg {
	padding: var(--spacing-md) var(--spacing-xl);
	font-size: 1.1rem;
	border-radius: var(--radius-lg);
}

/* =============================================
   CARDS
   ============================================= */

.card {
	background: var(--bg-secondary);
	border: 2px solid var(--border-color);
	border-radius: var(--radius-lg);
	padding: var(--spacing-lg);
	box-shadow: 0 4px 16px var(--shadow-color);
}

.card h2, .card h3 {
	margin-bottom: var(--spacing-md);
}

/* =============================================
   FORMS
   ============================================= */

input, select, textarea {
	font-family: var(--font-primary);
	font-size: 1rem;
	padding: var(--spacing-sm) var(--spacing-md);
	border: 2px solid var(--border-color);
	border-radius: var(--radius-md);
	background: var(--white);
	color: var(--text-primary);
	transition: all var(--transition-fast);
	width: 100%;
}

input:focus, select:focus, textarea:focus {
	outline: none;
	border-color: var(--pink-dark);
	box-shadow: 0 0 0 3px var(--pink-light);
}

textarea {
	resize: vertical;
	min-height: 120px;
	font-family: 'Fira Code', 'Cascadia Code', 'Consolas', monospace;
	font-size: 0.85rem;
	line-height: 1.5;
}

/* =============================================
   BADGES
   ============================================= */

.badge {
	display: inline-flex;
	align-items: center;
	gap: var(--spacing-xs);
	padding: var(--spacing-xs) var(--spacing-sm);
	border-radius: var(--radius-lg);
	font-size: 0.85rem;
	font-weight: 600;
}

.badge-success { background: var(--success); color: #2d6a4f; }
.badge-warning { background: var(--warning); color: #9c4221; }
.badge-error { background: var(--error); color: #9c2121; }
.badge-info { background: var(--info); color: #5a4a7c; }

.badge-live {
	font-size: 0.65rem;
	font-weight: 700;
	color: white;
	background: #ef5350;
	padding: 2px 8px;
	border-radius: var(--radius-sm);
	animation: pulse 1.5s ease-in-out infinite;
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

.badge-soon {
	font-size: 0.65rem;
	font-weight: 700;
	color: #5d4037;
	background: #ffb74d;
	padding: 2px 8px;
	border-radius: var(--radius-sm);
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

/* =============================================
   ANIMATIONS
   ============================================= */

@keyframes wiggle {
	0%, 100% { transform: rotate(0deg); }
	25% { transform: rotate(-5deg); }
	75% { transform: rotate(5deg); }
}

@keyframes wiggle-slow {
	0%, 100% { transform: rotate(-3deg); }
	50% { transform: rotate(3deg); }
}

@keyframes bounce {
	0%, 100% { transform: translateY(0); }
	50% { transform: translateY(-10px); }
}

@keyframes sparkle {
	0%, 100% { opacity: 1; transform: scale(1); }
	50% { opacity: 0.6; transform: scale(1.1); }
}

@keyframes pulse {
	0%, 100% { opacity: 1; }
	50% { opacity: 0.7; }
}

@keyframes fadeIn {
	from { opacity: 0; transform: translateY(10px); }
	to { opacity: 1; transform: translateY(0); }
}

.wiggle { animation: wiggle 0.3s ease-in-out; }
.wiggle-slow { animation: wiggle-slow 2s ease-in-out infinite; }
.bounce { animation: bounce 0.6s ease-in-out infinite; }
.fade-in { animation: fadeIn 0.4s ease-out; }

/* =============================================
   HERO SECTION
   ============================================= */

.hero {
	text-align: center;
	padding: 4rem 0 3rem;
}

.hero-mascot {
	width: 140px;
	height: 140px;
	margin: 0 auto 1.5rem;
	cursor: pointer;
	animation: wiggle-slow 2s ease-in-out infinite;
	transition: transform var(--transition-bounce);
}

.hero-mascot:hover {
	animation: none;
	transform: scale(1.05);
}

.hero-mascot:active {
	transform: scale(0.95);
}

.hero-mascot img {
	width: 100%;
	height: 100%;
	object-fit: contain;
}

.hero h1 {
	font-size: 3.5rem;
	color: var(--text-accent);
	margin-bottom: 0.5rem;
}

.hero .tagline {
	font-size: 1.25rem;
	color: var(--text-secondary);
	margin-bottom: 2rem;
}

.hero .tagline a {
	color: var(--purple-dark);
	font-weight: 700;
}

.hero-actions {
	display: flex;
	gap: var(--spacing-md);
	justify-content: center;
	flex-wrap: wrap;
}

/* =============================================
   FEATURES GRID
   ============================================= */

.features-section {
	padding: var(--spacing-xl) 0;
}

.features-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	gap: var(--spacing-lg);
	margin-top: var(--spacing-lg);
}

.feature-card {
	background: var(--bg-secondary);
	border: 2px solid var(--border-color);
	border-radius: var(--radius-lg);
	padding: var(--spacing-lg);
	text-align: center;
	transition: all var(--transition-normal);
}

.feature-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 8px 24px var(--shadow-color);
	border-color: var(--purple-dark);
}

.feature-icon {
	font-size: 2.5rem;
	margin-bottom: var(--spacing-sm);
}

.feature-card h3 {
	margin-bottom: var(--spacing-xs);
}

.feature-card p {
	color: var(--text-secondary);
	font-size: 0.95rem;
}

/* =============================================
   HOW IT WORKS
   ============================================= */

.steps-section {
	padding: var(--spacing-xl) 0;
}

.steps-list {
	counter-reset: steps;
	list-style: none;
	max-width: 700px;
	margin: var(--spacing-lg) auto 0;
}

.steps-list li {
	counter-increment: steps;
	padding: 1rem 0 1rem 3.5rem;
	position: relative;
	border-bottom: 2px dashed var(--purple-light);
	font-size: 1.05rem;
}

.steps-list li:last-child {
	border-bottom: none;
}

.steps-list li::before {
	content: counter(steps);
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
	width: 2.5rem;
	height: 2.5rem;
	background: linear-gradient(135deg, var(--purple-medium), var(--purple-dark));
	color: white;
	font-weight: 700;
	font-family: var(--font-display);
	border-radius: var(--radius-round);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1.1rem;
}

/* =============================================
   DOWNLOAD CTA
   ============================================= */

.download-cta {
	text-align: center;
	padding: 3rem 0;
}

.download-cta .mascot-small {
	width: 80px;
	height: 80px;
	margin: 0 auto var(--spacing-md);
}

.download-cta .mascot-small img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	opacity: 0.7;
}

.download-cta h2 {
	margin-bottom: var(--spacing-md);
}

/* =============================================
   TIMELINE (Patch Notes & Events)
   ============================================= */

.timeline {
	max-width: 800px;
	margin: 0 auto;
	position: relative;
	padding-left: 2rem;
}

.timeline::before {
	content: '';
	position: absolute;
	left: 0;
	top: 0;
	bottom: 0;
	width: 3px;
	background: linear-gradient(180deg, var(--purple-dark), var(--lavender-medium), transparent);
	border-radius: 2px;
}

.timeline-group {
	margin-bottom: var(--spacing-xl);
	animation: fadeIn 0.4s ease-out;
}

.timeline-group-label {
	font-family: var(--font-display);
	font-size: 1.1rem;
	color: var(--text-accent);
	margin-bottom: var(--spacing-md);
	position: relative;
}

.timeline-group-label::before {
	content: '';
	position: absolute;
	left: -2rem;
	top: 50%;
	transform: translate(-50%, -50%);
	width: 12px;
	height: 12px;
	background: var(--purple-dark);
	border: 3px solid var(--white);
	border-radius: var(--radius-round);
	box-shadow: 0 0 0 2px var(--purple-dark);
}

/* Version entry (patch notes) */
.version-entry {
	margin-bottom: var(--spacing-xl);
	position: relative;
}

.version-entry::before {
	content: '';
	position: absolute;
	left: -2rem;
	top: 8px;
	transform: translateX(-50%);
	width: 14px;
	height: 14px;
	background: var(--purple-dark);
	border: 3px solid var(--white);
	border-radius: var(--radius-round);
	box-shadow: 0 0 0 2px var(--purple-dark);
}

.version-header {
	display: flex;
	align-items: center;
	gap: var(--spacing-md);
	margin-bottom: var(--spacing-md);
	flex-wrap: wrap;
}

.version-number {
	font-family: var(--font-display);
	font-size: 1.5rem;
	color: var(--text-accent);
}

.version-date {
	font-size: 0.9rem;
	color: var(--text-secondary);
	background: var(--purple-light);
	padding: var(--spacing-xs) var(--spacing-sm);
	border-radius: var(--radius-sm);
}

.version-body {
	background: var(--bg-secondary);
	border: 2px solid var(--border-color);
	border-radius: var(--radius-lg);
	padding: var(--spacing-lg);
}

.version-body h3 {
	font-size: 1rem;
	margin-bottom: var(--spacing-sm);
	color: var(--text-accent);
}

.version-body ul {
	list-style: none;
	padding: 0;
	margin-bottom: var(--spacing-md);
}

.version-body ul:last-child {
	margin-bottom: 0;
}

.version-body li {
	padding: var(--spacing-xs) 0;
	padding-left: 1.5rem;
	position: relative;
	color: var(--text-primary);
}

.version-body li::before {
	content: '~';
	position: absolute;
	left: 0;
	color: var(--purple-dark);
	font-weight: 700;
}

/* =============================================
   EVENT CARDS
   ============================================= */

.event-row {
	display: flex;
	align-items: center;
	gap: var(--spacing-md);
	background: var(--bg-secondary);
	border: 2px solid var(--border-color);
	border-radius: var(--radius-md);
	padding: var(--spacing-sm) var(--spacing-md);
	width: 100%;
	text-align: left;
	cursor: pointer;
	transition: all var(--transition-fast);
	font-family: var(--font-primary);
	color: var(--text-primary);
	margin-bottom: var(--spacing-sm);
}

.event-row:hover {
	border-color: var(--purple-dark);
	transform: translateX(4px);
	box-shadow: 0 4px 12px var(--shadow-color);
}

.event-row.live {
	border-color: #ef5350;
	background: linear-gradient(90deg, rgba(239, 83, 80, 0.1) 0%, var(--bg-secondary) 30%);
}

.event-row.soon {
	border-color: #ffb74d;
	background: linear-gradient(90deg, rgba(255, 183, 77, 0.1) 0%, var(--bg-secondary) 30%);
}

.event-time-col {
	min-width: 70px;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 2px;
}

.event-time {
	font-family: var(--font-display);
	font-size: 1rem;
	color: var(--text-accent);
	white-space: nowrap;
}

.event-date-small {
	font-size: 0.7rem;
	color: var(--text-secondary);
	white-space: nowrap;
}

.event-thumbnail {
	width: 64px;
	height: 64px;
	border-radius: var(--radius-sm);
	overflow: hidden;
	flex-shrink: 0;
	background: var(--bg-accent);
}

.event-thumbnail img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.event-thumbnail.placeholder {
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1.5rem;
}

.event-info {
	flex: 1;
	min-width: 0;
}

.event-title {
	font-size: 1rem;
	font-family: var(--font-primary);
	font-weight: 700;
	color: var(--text-primary);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	margin: 0;
}

.event-description {
	margin: 4px 0 0;
	font-size: 0.8rem;
	color: var(--text-secondary);
	display: -webkit-box;
	-webkit-line-clamp: 1;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.event-arrow {
	color: var(--text-secondary);
	font-size: 1.2rem;
	transition: transform var(--transition-fast);
	flex-shrink: 0;
}

.event-row:hover .event-arrow {
	transform: translateX(4px);
	color: var(--text-accent);
}

/* =============================================
   LOGIN / AUTH SECTION
   ============================================= */

.auth-section {
	max-width: 600px;
	margin: 0 auto var(--spacing-xl);
}

.auth-card {
	background: var(--bg-secondary);
	border: 2px solid var(--border-color);
	border-radius: var(--radius-lg);
	padding: var(--spacing-xl);
	text-align: center;
}

.auth-card h2 {
	margin-bottom: var(--spacing-md);
}

.auth-steps {
	text-align: left;
	margin-bottom: var(--spacing-lg);
}

.auth-step {
	display: flex;
	align-items: flex-start;
	gap: var(--spacing-md);
	padding: var(--spacing-sm) 0;
}

.auth-step-number {
	width: 2rem;
	height: 2rem;
	background: linear-gradient(135deg, var(--purple-medium), var(--purple-dark));
	color: white;
	font-weight: 700;
	font-family: var(--font-display);
	border-radius: var(--radius-round);
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	font-size: 0.9rem;
}

.auth-step-text {
	padding-top: 3px;
}

.auth-step-text a {
	font-weight: 600;
}

.auth-input-group {
	display: flex;
	gap: var(--spacing-sm);
	margin-top: var(--spacing-md);
}

.auth-input-group input {
	flex: 1;
}

.auth-status {
	margin-top: var(--spacing-md);
	padding: var(--spacing-sm) var(--spacing-md);
	border-radius: var(--radius-md);
	font-weight: 600;
}

.auth-status.success {
	background: var(--cyan-light);
	color: #2a6f7a;
}

.auth-status.error {
	background: var(--error);
	color: #9c2121;
}

.auth-status.loading {
	background: var(--lavender-light);
	color: var(--text-accent);
}

/* Logged-in toolbar */
.user-toolbar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--spacing-md);
	padding: var(--spacing-md);
	background: var(--bg-secondary);
	border: 2px solid var(--border-color);
	border-radius: var(--radius-lg);
	margin-bottom: var(--spacing-lg);
	flex-wrap: wrap;
}

.user-info {
	display: flex;
	align-items: center;
	gap: var(--spacing-sm);
}

.user-avatar {
	width: 36px;
	height: 36px;
	border-radius: var(--radius-round);
	background: linear-gradient(135deg, var(--purple-medium), var(--purple-dark));
	overflow: hidden;
}

.user-avatar img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.user-name {
	font-weight: 700;
	color: var(--text-primary);
}

.toolbar-actions {
	display: flex;
	gap: var(--spacing-sm);
}

/* =============================================
   CORS FALLBACK
   ============================================= */

.cors-fallback {
	text-align: center;
	padding: var(--spacing-xl);
	max-width: 500px;
	margin: 0 auto;
}

.cors-fallback h3 {
	margin-bottom: var(--spacing-md);
}

.cors-fallback p {
	color: var(--text-secondary);
	margin-bottom: var(--spacing-lg);
}

/* =============================================
   PROFILE EDITOR
   ============================================= */

.profile-editor {
	display: flex;
	flex-direction: column;
	min-height: 600px;
}

.editor-toolbar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--spacing-md);
	padding: var(--spacing-sm) var(--spacing-md);
	background: var(--bg-secondary);
	border: 2px solid var(--border-color);
	border-radius: var(--radius-md);
	margin-bottom: var(--spacing-md);
	flex-wrap: wrap;
}

.toolbar-left {
	display: flex;
	align-items: center;
	gap: var(--spacing-sm);
	flex: 1;
	min-width: 200px;
}

.toolbar-label {
	font-size: 0.85rem;
	font-weight: 600;
	color: var(--text-secondary);
	white-space: nowrap;
}

.toolbar-input {
	flex: 1;
	padding: var(--spacing-xs) var(--spacing-sm) !important;
	background: var(--bg-accent) !important;
	border: 1px solid var(--border-color) !important;
	border-radius: var(--radius-sm) !important;
	font-size: 0.85rem !important;
	font-family: monospace !important;
}

.toolbar-right {
	display: flex;
	gap: var(--spacing-sm);
	flex-wrap: wrap;
}

.toolbar-btn {
	padding: var(--spacing-xs) var(--spacing-md);
	background: var(--purple-medium);
	color: var(--text-primary);
	border: none;
	border-radius: var(--radius-sm);
	font-size: 0.85rem;
	font-weight: 600;
	cursor: pointer;
	transition: all var(--transition-fast);
}

.toolbar-btn:hover {
	background: var(--purple-dark);
	color: white;
	transform: none;
	box-shadow: none;
}

.toolbar-btn.myoshi-btn {
	background: var(--pink-medium);
	color: white;
}

.toolbar-btn.myoshi-btn:hover {
	background: var(--pink-dark);
	color: white;
}

.toolbar-btn.save-btn {
	background: #81c784;
	color: white;
}

.toolbar-btn.save-btn:hover {
	background: #66bb6a;
	color: white;
}

.toolbar-btn.copied {
	background: #81c784;
	color: white;
}

.toolbar-btn:disabled {
	opacity: 0.6;
	cursor: not-allowed;
}

.status-message {
	font-size: 0.8rem;
	font-weight: 600;
	padding: var(--spacing-xs) var(--spacing-sm);
	border-radius: var(--radius-sm);
	white-space: nowrap;
	display: flex;
	align-items: center;
}

.status-message.success { color: #43a047; }
.status-message.error { color: #e53935; }

/* View tabs */
.view-tabs {
	display: flex;
	gap: var(--spacing-xs);
	margin-bottom: -2px;
	position: relative;
	z-index: 1;
}

.view-tab {
	padding: var(--spacing-sm) var(--spacing-lg);
	background: var(--bg-secondary);
	border: 2px solid var(--border-color);
	border-bottom: 2px solid var(--border-color);
	border-radius: var(--radius-md) var(--radius-md) 0 0;
	font-family: var(--font-primary);
	font-weight: 700;
	font-size: 0.95rem;
	color: var(--text-secondary);
	cursor: pointer;
	transition: all var(--transition-fast);
}

.view-tab:hover {
	color: var(--text-accent);
	background: var(--purple-light);
	transform: none;
	box-shadow: none;
}

.view-tab.active {
	color: var(--text-accent);
	background: var(--bg-secondary);
	border-color: var(--purple-dark);
	border-bottom-color: var(--bg-secondary);
}

.tab-panel {
	flex: 1;
	min-height: 500px;
	border: 2px solid var(--purple-dark);
	border-radius: 0 var(--radius-lg) var(--radius-lg) var(--radius-lg);
	background: var(--bg-secondary);
	padding: var(--spacing-lg);
}

.editors-panel {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-md);
	min-height: 0;
}

.editor-section {
	flex: 1;
	display: flex;
	flex-direction: column;
	background: var(--bg-secondary);
	border: 2px solid var(--border-color);
	border-radius: var(--radius-md);
	overflow: hidden;
	min-height: 0;
}

.editor-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: var(--spacing-sm) var(--spacing-md);
	background: var(--bg-accent);
	border-bottom: 1px solid var(--border-color);
}

.editor-header h3 {
	margin: 0;
	font-size: 0.8rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: var(--text-secondary);
}

.editor-textarea {
	flex: 1;
	width: 100%;
	background: var(--bg-secondary);
	color: var(--text-primary);
	border: none;
	padding: var(--spacing-md);
	font-family: 'Fira Code', 'Cascadia Code', 'Consolas', monospace;
	font-size: 0.8rem;
	line-height: 1.5;
	resize: none;
	outline: none;
	min-height: 200px;
}

.editor-textarea::placeholder {
	color: var(--text-secondary);
	opacity: 0.6;
}

/* Preview panel */
.preview-panel {
	background: var(--bg-accent);
	border: 2px solid var(--border-color);
	border-radius: var(--radius-md);
	overflow: auto;
	padding: var(--spacing-md);
}

/* =============================================
   MYOSHI PROFILE PREVIEW STYLES
   ============================================= */

.preview-panel .profile-page {
	max-width: 100%;
	min-height: 100%;
	background-color: #e8e8e8;
	background-size: cover;
	background-position: center top;
	background-attachment: scroll;
	background-repeat: no-repeat;
	font-family: Verdana, Geneva, sans-serif;
	font-size: 14px;
	color: #333;
	line-height: 1.4;
	border-radius: var(--radius-sm);
}

.preview-panel .profile-page .container {
	max-width: 1000px;
	margin: 0 auto;
	padding: 16px;
}

.preview-panel .profile-page .profile-top-bar {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 12px;
	font-size: 13px;
	background: #fff;
	padding: 8px 12px;
	border-radius: 4px;
}

.preview-panel .profile-page .profile-breadcrumb a { color: #369; }
.preview-panel .profile-page .profile-breadcrumb strong { color: #333; }

.preview-panel .profile-page .profile-top-actions a {
	color: #707070;
	font-size: 12px;
	margin-left: 12px;
}

.preview-panel .profile-page .profile-layout {
	display: grid;
	grid-template-columns: 320px 1fr;
	gap: 12px;
}

.preview-panel .profile-page .profile-left,
.preview-panel .profile-page .profile-right {
	display: flex;
	flex-direction: column;
	gap: 0;
}

.preview-panel .profile-page .card {
	overflow: hidden;
	border: none;
	border-radius: 0;
	padding: 0;
	box-shadow: none;
}

.preview-panel .profile-page .card-header {
	padding: 8px 12px;
	font-weight: 600;
	font-size: 12px;
	display: flex;
	justify-content: space-between;
	align-items: center;
	color: #fff;
}

.preview-panel .profile-page .card-header.starred { background: #369; }
.preview-panel .profile-page .card-header.starred::before { content: "\2605"; margin-right: 6px; color: #fff; }
.preview-panel .profile-page .card-header.hearted { background: #369; }
.preview-panel .profile-page .card-header.hearted::before { content: "\2665"; margin-right: 6px; color: #fff; }
.preview-panel .profile-page .card-header span { color: #fff; }

.preview-panel .profile-page .card-header a {
	font-size: 11px;
	color: rgba(255,255,255,0.8);
	font-weight: normal;
}

.preview-panel .profile-page .card-body {
	padding: 16px;
	background: #f5f5f5;
	color: #333;
}

.preview-panel .profile-page .profile-main-card .card-body {
	text-align: center;
	padding: 20px 16px;
}

.preview-panel .profile-page .user-avatar.profile-avatar {
	width: 120px;
	height: 120px;
	border-radius: 8px;
	margin: 0 auto 16px auto;
	display: flex;
	align-items: center;
	justify-content: center;
	background: linear-gradient(135deg, #369, #036);
	color: white;
	font-weight: bold;
	font-size: 48px;
	overflow: hidden;
}

.preview-panel .profile-page .user-avatar.profile-avatar img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.preview-panel .profile-page .profile-display-name {
	font-size: 20px;
	font-weight: 700;
	color: #333;
	margin-bottom: 4px;
}

.preview-panel .profile-page .profile-username {
	font-size: 13px;
	color: #666;
	margin-bottom: 6px;
}

.preview-panel .profile-page .profile-online-status {
	font-size: 12px;
	color: #2d7d2d;
	margin-bottom: 14px;
}

.preview-panel .profile-page .profile-actions {
	display: flex;
	gap: 8px;
	flex-wrap: wrap;
	justify-content: center;
	margin-bottom: 12px;
}

.preview-panel .profile-page .action-btn {
	display: inline-block;
	padding: 6px 14px;
	background: transparent;
	color: #666;
	border: 1px solid #ccc;
	border-radius: 4px;
	font-size: 12px;
	cursor: pointer;
	text-decoration: none;
	font-family: Verdana, Geneva, sans-serif;
}

.preview-panel .profile-page .action-btn:hover {
	border-color: #999;
	color: #333;
	transform: none;
	box-shadow: none;
}

.preview-panel .profile-page .action-btn.primary {
	background: #f60;
	border: none;
	color: #fff;
}

.preview-panel .profile-page .profile-url-box {
	background: #f0c040;
	padding: 10px 16px;
	border-radius: 6px;
	margin-top: 12px;
}

.preview-panel .profile-page .profile-url-box code {
	color: #333;
	font-family: monospace;
	font-size: 12px;
}

.preview-panel .profile-page .friends-grid {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
}

.preview-panel .profile-page .friend-item {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-decoration: none;
	gap: 6px;
	width: 50px;
}

.preview-panel .profile-page .friend-avatar {
	width: 50px;
	height: 50px;
	border-radius: 6px;
	background: linear-gradient(135deg, #ccc, #999);
}

.preview-panel .profile-page .friend-name {
	font-size: 10px;
	color: #666;
	text-align: center;
	max-width: 100%;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.preview-panel .profile-page .stats-table {
	width: 100%;
	font-size: 13px;
	border-collapse: collapse;
}

.preview-panel .profile-page .stats-table td { padding: 5px 0; }
.preview-panel .profile-page .stats-table td:first-child { color: #666; }
.preview-panel .profile-page .stats-table td:last-child { text-align: right; color: #333; }
.preview-panel .profile-page .stats-table a { color: #369; }

.preview-panel .profile-page .add-comment { padding: 16px; }

.preview-panel .profile-page .add-comment textarea {
	width: 100%;
	background: #fff;
	border: 1px solid #ccc;
	border-radius: 4px;
	padding: 10px;
	color: #333;
	font-size: 13px;
	resize: vertical;
	min-height: 60px;
	margin-bottom: 10px;
	font-family: inherit;
}

.preview-panel .profile-page .add-comment textarea::placeholder { color: #999; }

.preview-panel .profile-page .profile-comment {
	display: flex;
	gap: 12px;
	padding: 14px 16px;
}

.preview-panel .profile-page .comment-avatar {
	width: 50px;
	height: 50px;
	border-radius: 6px;
	background: linear-gradient(135deg, #ccc, #999);
	flex-shrink: 0;
}

.preview-panel .profile-page .comment-content { flex: 1; min-width: 0; }
.preview-panel .profile-page .comment-meta { margin-bottom: 4px; }

.preview-panel .profile-page .comment-author-name {
	font-weight: 600;
	color: #369;
	text-decoration: none;
	font-size: 13px;
}

.preview-panel .profile-page .comment-time { color: #999; font-size: 11px; }
.preview-panel .profile-page .comment-body { color: #555; font-size: 13px; line-height: 1.5; }

.preview-panel .profile-page .empty-state {
	padding: 30px;
	text-align: center;
	color: #888;
	font-size: 13px;
}

.preview-panel .profile-page p,
.preview-panel .profile-page span { color: #555; }
.preview-panel .profile-page a { color: #369; text-decoration: none; }

.preview-panel .profile-page .custom-about-me { margin-bottom: 12px; }

.preview-panel .profile-page .custom-about-me .about-header {
	text-align: center;
	margin-bottom: 8px;
}

.preview-panel .profile-page .custom-about-me .about-header span {
	font-weight: 600;
	font-size: 12px;
	color: #555;
}

.preview-panel .profile-page .custom-about-me .about-content {
	color: #555;
	font-size: 13px;
	line-height: 1.5;
}

.preview-panel .profile-page .custom-about-me p { margin: 8px 0; }

/* =============================================
   HORIZONTAL TIMELINE (Nyaoshi themed)
   ============================================= */

.htl-wrapper {
	position: relative;
	overflow-x: auto;
	overflow-y: hidden;
	background: var(--bg-secondary);
	border: 2px solid var(--border-color);
	border-radius: var(--radius-lg);
	min-height: 300px;
	box-shadow: 0 4px 16px var(--shadow-color);
}

.htl-scroll {
	position: relative;
	min-height: 280px;
}

/* Hour markers along the top */
.htl-header {
	position: sticky;
	top: 0;
	z-index: 10;
	display: flex;
	height: 36px;
	border-bottom: 2px solid var(--purple-light);
	background: var(--bg-accent);
}

.htl-hour {
	position: absolute;
	top: 0;
	height: 100%;
	display: flex;
	align-items: center;
	font-family: var(--font-primary);
	font-size: 0.75rem;
	font-weight: 600;
	color: var(--text-secondary);
	padding-left: 8px;
	border-left: 1px solid var(--purple-light);
	white-space: nowrap;
	box-sizing: border-box;
}

.htl-hour.htl-hour-day {
	color: var(--text-accent);
	font-weight: 700;
	font-size: 0.85rem;
}

/* Day label markers */
.htl-day-label {
	position: absolute;
	top: 0;
	height: 100%;
	display: flex;
	align-items: center;
	padding-left: 10px;
	font-family: var(--font-display);
	font-size: 0.9rem;
	color: var(--text-accent);
	z-index: 2;
	pointer-events: none;
	white-space: nowrap;
}

/* Now line — positioned in .htl-scroll to span full height */
.htl-now-line {
	position: absolute;
	top: 0;
	bottom: 0;
	width: 2px;
	background: var(--pink-dark);
	z-index: 20;
	pointer-events: none;
}

.htl-now-line::before {
	content: 'NOW';
	position: absolute;
	top: 42px;
	left: 50%;
	transform: translateX(-50%);
	font-family: var(--font-display);
	font-size: 0.6rem;
	color: var(--pink-dark);
	letter-spacing: 0.05em;
	white-space: nowrap;
	background: var(--bg-secondary);
	padding: 1px 4px;
	border-radius: 3px;
}

/* Hour grid lines — positioned in .htl-scroll to span full height */
.htl-grid-line {
	position: absolute;
	top: 0;
	bottom: 0;
	width: 1px;
	background: var(--purple-light);
	pointer-events: none;
	z-index: 1;
}

/* Event lanes area */
.htl-lanes {
	position: relative;
	padding-top: 4px;
}

/* Event bars */
.htl-event {
	position: absolute;
	height: 56px;
	border-radius: var(--radius-md);
	background: var(--purple-light);
	border: 2px solid var(--purple-medium);
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 0 10px;
	cursor: pointer;
	transition: all var(--transition-fast);
	overflow: hidden;
	text-decoration: none;
	color: var(--text-primary);
	box-sizing: border-box;
}

.htl-event:hover {
	background: var(--lavender-light);
	border-color: var(--purple-dark);
	text-decoration: none;
	color: var(--text-primary);
	transform: none;
	box-shadow: 0 4px 16px var(--shadow-color);
}

.htl-event.htl-event-live {
	border-color: #ef5350;
	background: linear-gradient(90deg, rgba(239, 83, 80, 0.15) 0%, var(--purple-light) 40%);
}

.htl-event.htl-event-live:hover {
	background: linear-gradient(90deg, rgba(239, 83, 80, 0.25) 0%, var(--lavender-light) 40%);
}

.htl-event.htl-event-soon {
	border-color: #ffb74d;
	background: linear-gradient(90deg, rgba(255, 183, 77, 0.15) 0%, var(--purple-light) 40%);
}

.htl-event.htl-event-past {
	opacity: 0.45;
}

.htl-event-thumb {
	width: 36px;
	height: 36px;
	border-radius: var(--radius-sm);
	overflow: hidden;
	flex-shrink: 0;
	background: var(--purple-medium);
}

.htl-event-thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.htl-event-thumb.placeholder {
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1.1rem;
}

.htl-event-text {
	flex: 1;
	min-width: 0;
}

.htl-event-name {
	font-weight: 700;
	font-size: 0.85rem;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	color: var(--text-primary);
}

.htl-event-time {
	font-size: 0.7rem;
	color: var(--text-secondary);
	white-space: nowrap;
}

.htl-event-badge {
	flex-shrink: 0;
}

.htl-event-source {
	display: inline-block;
	font-size: 0.6rem;
	font-weight: 700;
	color: var(--text-accent);
	background: var(--purple-light);
	padding: 0 4px;
	border-radius: 3px;
	margin-left: 4px;
	vertical-align: middle;
}

.htl-event-dj {
	display: inline;
	font-size: 0.65rem;
	color: var(--text-accent);
	margin-left: 6px;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.htl-dj-icon {
	font-size: 0.6rem;
}

.htl-dj-label {
	font-weight: 600;
	opacity: 0.7;
}

/* Empty state for timeline */
.htl-empty {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 200px;
	color: var(--text-secondary);
	font-size: 1rem;
	font-family: var(--font-primary);
}

/* =============================================
   EMPTY STATES
   ============================================= */

.empty-state {
	text-align: center;
	padding: var(--spacing-xl);
	color: var(--text-secondary);
}

.empty-state-icon {
	font-size: 3rem;
	margin-bottom: var(--spacing-md);
	opacity: 0.5;
}

.loading-mascot {
	width: 64px;
	height: 64px;
	object-fit: contain;
}

/* =============================================
   FOOTER
   ============================================= */

.site-footer {
	text-align: center;
	padding: var(--spacing-xl) var(--spacing-lg);
	color: var(--text-secondary);
	font-size: 0.9rem;
	border-top: 2px solid var(--purple-light);
	margin-top: var(--spacing-xl);
}

.footer-inner {
	max-width: 1100px;
	margin: 0 auto;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--spacing-md);
}

.footer-links {
	display: flex;
	gap: var(--spacing-lg);
	flex-wrap: wrap;
	justify-content: center;
}

.footer-links a {
	color: var(--text-secondary);
	font-weight: 600;
}

.footer-links a:hover { color: var(--text-accent); }

.kofi-btn {
	display: inline-flex;
	align-items: center;
	gap: var(--spacing-xs);
	background: #ff5e5b;
	color: white !important;
	padding: var(--spacing-xs) var(--spacing-md);
	border-radius: var(--radius-lg);
	font-weight: 700;
	font-size: 0.85rem;
	transition: all var(--transition-fast);
}

.kofi-btn:hover {
	background: #e04542;
	text-decoration: none;
	transform: translateY(-1px);
}

/* =============================================
   SCROLLBAR
   ============================================= */

::-webkit-scrollbar { width: 10px; }

::-webkit-scrollbar-track {
	background: var(--bg-accent);
	border-radius: var(--radius-lg);
}

::-webkit-scrollbar-thumb {
	background: var(--purple-medium);
	border-radius: var(--radius-lg);
	border: 2px solid var(--bg-accent);
}

::-webkit-scrollbar-thumb:hover {
	background: var(--purple-dark);
}

/* =============================================
   RESPONSIVE
   ============================================= */

@media (max-width: 768px) {
	.hamburger { display: block; }

	.nav-links {
		display: none;
		position: absolute;
		top: 100%;
		left: 0;
		right: 0;
		background: rgba(255, 255, 255, 0.95);
		backdrop-filter: blur(16px);
		-webkit-backdrop-filter: blur(16px);
		flex-direction: column;
		padding: var(--spacing-md);
		border-bottom: 2px solid var(--purple-medium);
		gap: var(--spacing-xs);
	}

	.nav-links.open { display: flex; }

	.nav-links a {
		padding: var(--spacing-sm) var(--spacing-md);
		width: 100%;
	}

	.hero h1 { font-size: 2.5rem; }
	.hero-mascot { width: 100px; height: 100px; }

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

	.preview-panel .profile-page .profile-layout {
		grid-template-columns: 1fr;
	}

	.user-toolbar {
		flex-direction: column;
		align-items: stretch;
	}

	.toolbar-actions {
		justify-content: center;
	}

	.editor-toolbar {
		flex-direction: column;
	}

	.toolbar-left, .toolbar-right {
		width: 100%;
		justify-content: center;
	}

	.auth-input-group {
		flex-direction: column;
	}
}

@media (max-width: 480px) {
	.container { padding: var(--spacing-md); }
	h1 { font-size: 2rem; }
	.hero h1 { font-size: 2rem; }
	.hero { padding: 2rem 0 1.5rem; }
}
