﻿/* =============================================
   EN FORÊT Hair Therapy — Main Stylesheet
   (라이트/다크 모드, 레이아웃, 컴포넌트)
============================================= */

/* =============================================
     EN FORÊT — Original Light Design
     Font: Plus Jakarta Sans (고딕) + Cormorant Garamond (로고 전용)
     Dark / Light 모드 지원
  ============================================= */

/* ── 라이트 모드 기본값 ───────────────────── */
:root {
	--forest: #1a2e1e;
	--forest-mid: #2d4a32;
	--forest-light: #3d6642;
	--sage: #7a9e7e;
	--sage-light: #a8c5a8;
	--cream: #f5f0e8;
	--cream-dark: #ede6d4;
	--gold: #c9a84c;
	--gold-light: #e8c97a;
	--silver: #8fa8b8;
	--vip: #8b3a6b;
	--text-dark: #1a1a1a;
	--text-mid: #4a4a4a;
	--text-light: #7a7a7a;
	--white: #ffffff;
	--danger: #c0392b;
	--success: #27ae60;
	--border: rgba(26,46,30,0.12);
	--shadow: 0 4px 24px rgba(26,46,30,0.12);
	--shadow-lg: 0 12px 48px rgba(26,46,30,0.18);
}

/* ── 다크 모드 오버라이드 ──────────────────── */
[data-theme="dark"] {
	--forest: #4d9458;
	--forest-mid: #3d7a48;
	--forest-light: #5aaa66;
	--sage: #7aaa80;
	--sage-light: #9dc4a0;
	--cream: #1e1c18;
	--cream-dark: #2a2720;
	--gold: #d4aa4e;
	--gold-light: #e8c97a;
	--silver: #8fa8b8;
	--vip: #c084b8;
	--text-dark: #f0ece4;
	--text-mid: #c8bfac;
	--text-light: #8a8070;
	--white: #252018;
	--danger: #f87171;
	--success: #4ade80;
	--border: rgba(255,255,255,0.1);
	--shadow: 0 4px 24px rgba(0,0,0,0.4);
	--shadow-lg: 0 12px 48px rgba(0,0,0,0.6);
}

	[data-theme="dark"] body {
		background: #141210;
	}

	[data-theme="dark"] .sidebar {
		background: #0e0c0a;
		border-right: 1px solid rgba(255,255,255,0.07);
	}

	[data-theme="dark"] .topbar {
		background: #1a1714;
		border-bottom: 1px solid rgba(255,255,255,0.07);
	}

	[data-theme="dark"] .week-grid,
	[data-theme="dark"] .week-body,
	[data-theme="dark"] .week-header {
		background: var(--white);
	}

	[data-theme="dark"] .week-day-header {
		background: var(--cream);
	}

		[data-theme="dark"] .week-day-header.today {
			background: var(--forest);
		}

	[data-theme="dark"] .time-col {
		background: var(--cream);
	}

	[data-theme="dark"] .modal {
		background: var(--white);
	}

	[data-theme="dark"] .modal-header {
		background: var(--cream);
	}

	[data-theme="dark"] .panel {
		background: var(--white);
	}

	[data-theme="dark"] .stat-card {
		background: var(--white);
	}

	[data-theme="dark"] .member-card {
		background: var(--white);
	}

	[data-theme="dark"] .report-card {
		background: var(--white);
	}

	[data-theme="dark"] .settings-nav,
	[data-theme="dark"] .settings-content {
		background: var(--white);
	}

	[data-theme="dark"] .form-input,
	[data-theme="dark"] .form-select {
		background: var(--cream);
		color: var(--text-dark);
		border-color: var(--border);
	}

		[data-theme="dark"] .form-select option {
			background: var(--cream);
			color: var(--text-dark);
		}

	[data-theme="dark"] .mobile-nav {
		background: #0e0c0a;
		border-top: 1px solid rgba(255,255,255,0.07);
	}

	[data-theme="dark"] .view-tabs {
		background: var(--cream);
	}

	[data-theme="dark"] .pay-method {
		background: var(--cream);
	}

	[data-theme="dark"] .tip-btn {
		background: var(--cream);
	}

	[data-theme="dark"] .client-dropdown-item:hover {
		background: var(--cream-dark);
	}

	[data-theme="dark"] .appt-list-item:hover {
		background: var(--cream);
	}

	[data-theme="dark"] .hardware-card {
		background: var(--cream);
	}

	[data-theme="dark"] .appt-service-row {
		background: var(--cream);
	}

/* ── 다크모드 토글 버튼 ────────────────────── */
.theme-toggle {
	width: 40px;
	height: 22px;
	border-radius: 11px;
	background: var(--cream-dark);
	border: 1.5px solid var(--border);
	cursor: pointer;
	position: relative;
	transition: background 0.25s;
	flex-shrink: 0;
}

	.theme-toggle::after {
		content: '';
		width: 16px;
		height: 16px;
		border-radius: 50%;
		background: var(--forest);
		position: absolute;
		top: 1px;
		left: 1px;
		transition: left 0.25s, background 0.25s;
		box-shadow: 0 1px 4px rgba(0,0,0,0.2);
	}

[data-theme="dark"] .theme-toggle {
	background: rgba(77,148,88,0.25);
	border-color: var(--forest);
}

	[data-theme="dark"] .theme-toggle::after {
		left: 19px;
		background: var(--forest);
	}

.theme-toggle-wrap {
	display: flex;
	align-items: center;
	gap: 6px;
	font-size: 12px;
	color: var(--text-light);
	user-select: none;
}

.theme-toggle-icon {
	font-size: 14px;
	line-height: 1;
}

/* ── 전역 리셋 ─────────────────────────────── */
* {
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}

body > form {
	display: flex;
	flex: 1;
	width: 100%;
	height: 100vh;
	overflow: hidden;
}

* {
	font-family: inherit;
}

body {
	font-family: 'Plus Jakarta Sans', 'Segoe UI Emoji', 'Apple Color Emoji', 'Noto Color Emoji', sans-serif;
	background: var(--cream);
	color: var(--text-dark);
	min-height: 100vh;
	display: flex;
	overflow: hidden;
	height: 100vh;
	transition: background 0.25s, color 0.25s;
}

/* ── SIDEBAR ────────────────────────────────── */
.sidebar {
	width: 220px;
	min-width: 220px;
	background: var(--forest);
	display: flex;
	flex-direction: column;
	height: 100vh;
	position: relative;
	z-index: 100;
	transition: background 0.25s;
}

.logo {
	padding: 28px 20px 24px;
	border-bottom: 1px solid rgba(255,255,255,0.08);
}

.logo-sub {
	font-family: 'Cormorant Garamond',serif;
	font-size: 12px;
	letter-spacing: 3px;
	color: var(--sage-light);
	text-transform: uppercase;
	margin-bottom: 4px;
}

.logo-main {
	font-family: 'Cormorant Garamond',serif;
	font-size: 24px;
	color: #fff;
	font-weight: 600;
	line-height: 1.1;
}

.logo-tag {
	font-size: 11px;
	letter-spacing: 2px;
	color: var(--sage);
	text-transform: uppercase;
	margin-top: 3px;
	font-family: 'Plus Jakarta Sans',sans-serif;
}

.nav {
	padding: 16px 0;
	flex: 1;
	overflow-y: auto;
}

.nav-section {
	padding: 8px 20px 4px;
	font-size: 10px;
	letter-spacing: 2px;
	text-transform: uppercase;
	color: var(--sage);
	font-weight: 700;
}

.nav-item {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 10px 20px;
	color: rgba(255,255,255,0.65);
	cursor: pointer;
	font-size: 14px;
	font-weight: 500;
	transition: all 0.2s;
	border-left: 3px solid transparent;
	user-select: none;
}

	.nav-item:hover {
		color: #fff;
		background: rgba(255,255,255,0.06);
	}

	.nav-item.active {
		color: #fff;
		background: rgba(122,158,126,0.2);
		border-left-color: var(--sage);
	}

	.nav-item .icon {
		width: 16px;
		text-align: center;
		font-size: 16px;
	}

.sidebar-footer {
	padding: 16px 20px;
	border-top: 1px solid rgba(255,255,255,0.08);
}

.staff-avatar {
	display: flex;
	align-items: center;
	gap: 10px;
	width: 100%;
}

.logout-btn {
	margin-left: auto;
	flex-shrink: 0;
	width: 30px;
	height: 30px;
	border-radius: 7px;
	border: 1px solid rgba(255,255,255,0.12);
	background: transparent;
	color: rgba(255,255,255,0.4);
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: all 0.2s;
}

	.logout-btn:hover {
		background: rgba(248,113,113,0.15);
		border-color: rgba(248,113,113,0.4);
		color: #f87171;
	}

.avatar-circle {
	width: 34px;
	height: 34px;
	border-radius: 50%;
	background: linear-gradient(135deg, var(--gold), var(--forest-light));
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 15px;
	font-weight: 700;
	color: #fff;
	flex-shrink: 0;
}

.staff-info {
	line-height: 1.3;
}

.staff-name {
	font-size: 14px;
	font-weight: 600;
	color: #fff;
}

.staff-role {
	font-size: 11px;
	color: var(--sage);
}

/* ── MAIN / TOPBAR ──────────────────────────── */
.main {
	flex: 1;
	display: flex;
	flex-direction: column;
	height: 100vh;
	overflow: hidden;
}

.topbar {
	background: var(--white);
	border-bottom: 1px solid var(--border);
	padding: 0 28px;
	height: 60px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-shrink: 0;
	transition: background 0.25s, border-color 0.25s;
}

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

.page-title {
	font-size: 21px;
	font-weight: 800;
	color: var(--forest);
	letter-spacing: -0.03em;
}

.date-badge {
	font-size: 13px;
	color: var(--text-light);
	background: var(--cream);
	padding: 4px 10px;
	border-radius: 20px;
	font-weight: 500;
}

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

/* ── 버튼 ───────────────────────────────────── */
.btn {
	padding: 8px 18px;
	border-radius: 8px;
	font-size: 14px;
	font-weight: 600;
	cursor: pointer;
	border: none;
	transition: all 0.2s;
	font-family: 'Plus Jakarta Sans',sans-serif;
}

.btn-primary {
	background: var(--forest);
	color: #fff;
}

	.btn-primary:hover {
		background: var(--forest-mid);
		transform: translateY(-1px);
	}

.btn-outline {
	background: transparent;
	border: 1.5px solid var(--forest);
	color: var(--forest);
}

	.btn-outline:hover {
		background: var(--forest);
		color: #fff;
	}

.btn-gold {
	background: var(--gold);
	color: #fff;
}

	.btn-gold:hover {
		background: #b8943e;
	}

.btn-sm {
	padding: 5px 12px;
	font-size: 13px;
}

.btn-danger {
	background: var(--danger);
	color: #fff;
}

.notif-btn {
	width: 36px;
	height: 36px;
	border-radius: 50%;
	background: var(--cream);
	border: none;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 18px;
	position: relative;
	transition: background 0.2s;
}

	.notif-btn:hover {
		background: var(--cream-dark);
	}

.notif-dot {
	width: 8px;
	height: 8px;
	background: var(--danger);
	border-radius: 50%;
	position: absolute;
	top: 6px;
	right: 6px;
}

/* ── CONTENT ────────────────────────────────── */
.content {
	flex: 1;
	overflow-y: auto;
	padding: 24px 28px;
}

/* ── VIEW TABS ──────────────────────────────── */
.view-tabs {
	display: flex;
	background: var(--cream-dark);
	border-radius: 8px;
	padding: 3px;
}

.view-tab {
	padding: 6px 16px;
	border-radius: 6px;
	font-size: 13px;
	font-weight: 600;
	cursor: pointer;
	color: var(--text-mid);
	transition: all 0.2s;
	user-select: none;
}

	.view-tab.active {
		background: var(--white);
		color: var(--forest);
		box-shadow: 0 1px 4px rgba(0,0,0,0.1);
	}

/* ── CALENDAR ───────────────────────────────── */
.calendar-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: 20px;
}

.cal-nav {
	display: flex;
	align-items: center;
	gap: 12px;
}

.cal-nav-btn {
	width: 32px;
	height: 32px;
	border-radius: 50%;
	background: var(--white);
	border: 1.5px solid var(--border);
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 16px;
	transition: all 0.2s;
}

	.cal-nav-btn:hover {
		background: var(--forest);
		color: #fff;
		border-color: var(--forest);
	}

.cal-month {
	font-size: 19px;
	font-weight: 800;
	color: var(--forest);
	min-width: 160px;
	text-align: center;
	letter-spacing: -0.02em;
}

.week-grid {
	background: var(--white);
	border-radius: 12px;
	box-shadow: var(--shadow);
	overflow: hidden;
	border: 1px solid var(--border);
	transition: background 0.25s;
}

.week-header {
	display: grid;
	grid-template-columns: 64px repeat(7,1fr);
	border-bottom: 2px solid var(--cream-dark);
}

.week-header-time {
	background: var(--cream);
}

.week-day-header {
	padding: 12px 8px;
	text-align: center;
	border-left: 1px solid var(--border);
	background: var(--cream);
}

	.week-day-header.today {
		background: var(--forest);
		color: #fff;
	}

.week-day-name {
	font-size: 11px;
	text-transform: uppercase;
	letter-spacing: 1.5px;
	color: var(--text-light);
	font-weight: 700;
}

.week-day-header.today .week-day-name {
	color: rgba(255,255,255,0.7);
}

.week-day-num {
	font-size: 22px;
	font-weight: 800;
	color: var(--forest);
	margin-top: 2px;
	letter-spacing: -0.03em;
}

.week-day-header.today .week-day-num {
	color: #fff;
}

.week-body {
	display: grid;
	grid-template-columns: 64px repeat(7,1fr);
	min-height: 200px;
	overflow-y: auto;
	position: relative;
}

.time-col {
	background: var(--cream);
}

.time-slot {
	height: 60px;
	display: flex;
	align-items: flex-start;
	justify-content: center;
	padding-top: 4px;
	font-size: 11px;
	color: var(--text-light);
	border-bottom: 1px solid var(--cream-dark);
	font-weight: 600;
}

.day-col {
	border-left: 1px solid var(--border);
	position: relative;
}

.day-cell {
	height: 60px;
	border-bottom: 1px solid rgba(0,0,0,0.04);
	cursor: pointer;
	transition: background 0.1s;
}

	.day-cell:hover {
		background: rgba(122,158,126,0.06);
	}

.day-col.today-col {
	background: rgba(26,46,30,0.02);
}

.appt-block {
	position: absolute;
	left: 4px;
	right: 4px;
	border-radius: 6px;
	padding: 6px 8px;
	cursor: pointer;
	font-size: 12px;
	font-weight: 600;
	transition: transform 0.15s, box-shadow 0.15s;
	overflow: hidden;
	border-left: 3px solid;
	line-height: 1.3;
}

	.appt-block:hover {
		transform: translateX(2px);
		box-shadow: 0 4px 12px rgba(0,0,0,0.15);
		z-index: 10;
	}

	.appt-block.type-color {
		background: rgba(61,102,66,0.12);
		border-color: var(--forest-light);
		color: var(--forest);
	}

	.appt-block.type-gold {
		background: rgba(201,168,76,0.15);
		border-color: var(--gold);
		color: #7a5c1a;
	}

	.appt-block.type-vip {
		background: rgba(139,58,107,0.12);
		border-color: var(--vip);
		color: var(--vip);
	}

	.appt-block.type-silver {
		background: rgba(143,168,184,0.2);
		border-color: var(--silver);
		color: #3a5a6b;
	}

.appt-time {
	font-size: 11px;
	opacity: 0.75;
	font-weight: 500;
}

.appt-name {
	font-weight: 700;
}

.appt-service {
	font-size: 11px;
	opacity: 0.8;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

/* ── STAT CARDS ─────────────────────────────── */
.stats-row {
	display: grid;
	grid-template-columns: repeat(4,1fr);
	gap: 16px;
	margin-bottom: 24px;
}

.stat-card {
	background: var(--white);
	border-radius: 10px;
	padding: 18px 20px;
	border: 1px solid var(--border);
	box-shadow: var(--shadow);
	transition: transform 0.2s, background 0.25s;
}

	.stat-card:hover {
		transform: translateY(-2px);
	}

.stat-label {
	font-size: 11px;
	color: var(--text-light);
	text-transform: uppercase;
	letter-spacing: 1.5px;
	font-weight: 700;
	margin-bottom: 6px;
}

.stat-value {
	font-size: 34px;
	font-weight: 800;
	color: var(--forest);
	line-height: 1;
	letter-spacing: -0.04em;
}

.stat-sub {
	font-size: 12px;
	color: var(--text-light);
	margin-top: 4px;
	font-weight: 500;
}

.stat-badge {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	font-size: 12px;
	font-weight: 700;
	padding: 2px 8px;
	border-radius: 20px;
	margin-top: 6px;
}

.badge-up {
	background: rgba(39,174,96,0.1);
	color: var(--success);
}

.badge-down {
	background: rgba(192,57,43,0.1);
	color: var(--danger);
}

/* ── PANELS ─────────────────────────────────── */
.two-col {
	display: grid;
	grid-template-columns: 1fr 380px;
	gap: 20px;
	margin-top: 20px;
}

.panel {
	background: var(--white);
	border-radius: 12px;
	border: 1px solid var(--border);
	box-shadow: var(--shadow);
	overflow: hidden;
	transition: background 0.25s;
}

.panel-header {
	padding: 16px 20px;
	border-bottom: 1px solid var(--border);
	display: flex;
	align-items: center;
	justify-content: space-between;
}

.panel-title {
	font-size: 17px;
	font-weight: 800;
	color: var(--forest);
	letter-spacing: -0.02em;
}

.panel-body {
	padding: 20px;
}

/* ── APPOINTMENT LIST ───────────────────────── */
.appt-list-item {
	display: flex;
	align-items: center;
	gap: 14px;
	border-bottom: 1px solid var(--border);
	cursor: pointer;
	transition: background 0.15s;
	border-radius: 6px;
	padding: 10px 8px;
	margin: 0 -8px;
}

	.appt-list-item:hover {
		background: var(--cream);
	}

	.appt-list-item:last-child {
		border-bottom: none;
	}

.appt-color-dot {
	width: 10px;
	height: 10px;
	border-radius: 50%;
	flex-shrink: 0;
}

.appt-list-info {
	flex: 1;
}

.appt-list-name {
	font-size: 14px;
	font-weight: 700;
	color: var(--text-dark);
}

.appt-list-detail {
	font-size: 12px;
	color: var(--text-light);
	margin-top: 2px;
	font-weight: 500;
}

.appt-list-time {
	font-size: 13px;
	color: var(--text-mid);
	font-weight: 600;
	text-align: right;
}

.appt-list-price {
	font-size: 15px;
	font-weight: 800;
	color: var(--forest);
	letter-spacing: -0.02em;
}

.member-badge {
	font-size: 10px;
	font-weight: 800;
	letter-spacing: 1px;
	text-transform: uppercase;
	padding: 2px 7px;
	border-radius: 10px;
	display: inline-block;
	margin-left: 6px;
}

.badge-gold {
	background: rgba(201,168,76,0.15);
	color: #8a6418;
}

.badge-vip {
	background: rgba(139,58,107,0.1);
	color: var(--vip);
}

.badge-silver {
	background: rgba(143,168,184,0.15);
	color: #3a5a6b;
}

/* ── POS PANEL ──────────────────────────────── */
.pos-panel {
	display: flex;
	flex-direction: column;
	height: 100%;
}

.pos-items {
	flex: 1;
	padding: 16px 20px;
	max-height: 280px;
	overflow-y: auto;
}

.pos-item {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 10px 0;
	border-bottom: 1px solid var(--border);
}

.pos-item-name {
	font-size: 14px;
	font-weight: 700;
}

.pos-item-sub {
	font-size: 12px;
	color: var(--text-light);
	font-weight: 500;
}

.pos-item-price {
	font-size: 15px;
	font-weight: 800;
	color: var(--forest);
	text-align: right;
	letter-spacing: -0.02em;
}

.pos-item-remove {
	width: 24px;
	height: 24px;
	border: none;
	background: none;
	cursor: pointer;
	color: var(--text-light);
	font-size: 18px;
	transition: color 0.15s;
}

	.pos-item-remove:hover {
		color: var(--danger);
	}

.qty-ctrl {
	display: flex;
	align-items: center;
}

.qty-btn {
	width: 24px;
	height: 24px;
	border-radius: 4px;
	border: 1.5px solid var(--border);
	background: var(--white);
	cursor: pointer;
	font-size: 15px;
	font-weight: 600;
	color: var(--forest);
	display: flex;
	align-items: center;
	justify-content: center;
	line-height: 1;
	transition: all 0.15s;
	padding: 0;
	flex-shrink: 0;
}

	.qty-btn:hover {
		border-color: var(--forest);
		background: var(--forest);
		color: var(--white);
	}

.qty-num {
	font-family: 'Barlow',sans-serif;
	font-size: 14px;
	font-weight: 700;
	color: var(--text-dark);
	min-width: 26px;
	text-align: center;
	user-select: none;
}

.pos-summary {
	padding: 16px 20px;
	border-top: 2px solid var(--border);
	background: var(--cream);
}

.pos-row {
	display: flex;
	justify-content: space-between;
	font-size: 14px;
	margin-bottom: 6px;
	color: var(--text-mid);
}

	.pos-row.total {
		font-size: 18px;
		font-weight: 800;
		color: var(--forest);
		margin-top: 8px;
		padding-top: 8px;
		border-top: 1px solid var(--border);
		letter-spacing: -0.02em;
	}

.pos-discount {
	font-size: 12px;
	color: var(--success);
	font-weight: 600;
}

.pos-actions {
	padding: 16px 20px;
	display: flex;
	gap: 10px;
}

	.pos-actions .btn {
		flex: 1;
		text-align: center;
	}

/* ── MODALS ─────────────────────────────────── */
.modal-overlay {
	position: fixed;
	inset: 0;
	background: rgba(0,0,0,0.5);
	z-index: 1000;
	display: flex;
	align-items: center;
	justify-content: center;
	opacity: 0;
	pointer-events: none;
	transition: opacity 0.2s;
}

	.modal-overlay.open {
		opacity: 1;
		pointer-events: all;
	}

.modal {
	background: var(--white);
	border-radius: 16px;
	width: 480px;
	max-height: 90vh;
	overflow-y: auto;
	box-shadow: var(--shadow-lg);
	transform: translateY(20px);
	transition: transform 0.2s, background 0.25s;
}

.modal-overlay.open .modal {
	transform: translateY(0);
}

.modal-header {
	padding: 24px;
	border-bottom: 1px solid var(--border);
	display: flex;
	align-items: center;
	justify-content: space-between;
}

.modal-title {
	font-size: 22px;
	font-weight: 800;
	color: var(--forest);
	letter-spacing: -0.03em;
}

.modal-close {
	background: none;
	border: none;
	font-size: 24px;
	cursor: pointer;
	color: var(--text-light);
}

.modal-body {
	padding: 24px;
}

.modal-footer {
	padding: 20px 24px;
	border-top: 1px solid var(--border);
	display: flex;
	gap: 12px;
}

/* ── FORMS ──────────────────────────────────── */
.form-group {
	margin-bottom: 18px;
}

.form-label {
	font-size: 11px;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: 1.5px;
	color: var(--text-mid);
	margin-bottom: 6px;
	display: block;
}

.form-input, .form-select {
	width: 100%;
	padding: 10px 14px;
	border-radius: 8px;
	border: 1.5px solid var(--border);
	font-family: 'Plus Jakarta Sans',sans-serif;
	font-size: 14px;
	color: var(--text-dark);
	background: var(--white);
	transition: border-color 0.2s;
	outline: none;
	font-weight: 500;
}

	.form-input:focus, .form-select:focus {
		border-color: var(--forest);
	}

textarea.form-input {
	resize: vertical;
	min-height: 80px;
	line-height: 1.6;
	padding-top: 10px;
}

/* ── PAYMENT / TIP ──────────────────────────── */
.payment-method-grid {
	display: grid;
	grid-template-columns: repeat(3,1fr);
	gap: 10px;
	margin-bottom: 20px;
}

.pay-method {
	padding: 14px 10px;
	border-radius: 10px;
	text-align: center;
	border: 2px solid var(--border);
	cursor: pointer;
	transition: all 0.2s;
	font-size: 13px;
	font-weight: 700;
	color: var(--text-mid);
	background: var(--white);
}

	.pay-method:hover {
		border-color: var(--forest);
		color: var(--forest);
	}

	.pay-method.selected {
		border-color: var(--forest);
		background: rgba(26,46,30,0.05);
		color: var(--forest);
	}

	.pay-method .pay-icon {
		font-size: 24px;
		margin-bottom: 6px;
	}

.tip-grid {
	display: grid;
	grid-template-columns: repeat(4,1fr);
	gap: 8px;
	margin-bottom: 16px;
}

.tip-btn {
	padding: 10px;
	border-radius: 8px;
	border: 1.5px solid var(--border);
	cursor: pointer;
	text-align: center;
	font-size: 14px;
	font-weight: 700;
	color: var(--text-mid);
	transition: all 0.2s;
	background: var(--white);
}

	.tip-btn:hover, .tip-btn.selected {
		border-color: var(--gold);
		background: rgba(201,168,76,0.08);
		color: var(--gold);
	}

.amount-display {
	background: var(--forest);
	color: #fff;
	border-radius: 10px;
	padding: 20px;
	text-align: center;
	margin-bottom: 20px;
}

.amount-label {
	font-size: 11px;
	text-transform: uppercase;
	letter-spacing: 2px;
	opacity: 0.7;
	margin-bottom: 6px;
	font-weight: 700;
}

.amount-total {
	font-size: 50px;
	font-weight: 800;
	letter-spacing: -0.05em;
}

.amount-sub {
	font-size: 13px;
	opacity: 0.7;
	margin-top: 4px;
	font-weight: 500;
}

/* ── PAGE TABS ──────────────────────────────── */
.page-tabs {
	display: none;
	flex-direction: column;
}

	.page-tabs.active {
		display: flex;
	}

/* ── MEMBERS ────────────────────────────────── */
.members-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill,minmax(260px,1fr));
	gap: 16px;
}

.member-card {
	background: var(--white);
	border-radius: 12px;
	border: 1px solid var(--border);
	padding: 20px;
	box-shadow: var(--shadow);
	transition: transform 0.2s, background 0.25s;
	cursor: pointer;
}

	.member-card:hover {
		transform: translateY(-3px);
	}

.member-card-top {
	display: flex;
	align-items: center;
	gap: 14px;
	margin-bottom: 14px;
}

.member-avatar {
	width: 48px;
	height: 48px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 20px;
	font-weight: 800;
	flex-shrink: 0;
}

.avatar-gold {
	background: rgba(201,168,76,0.15);
	color: var(--gold);
}

.avatar-silver {
	background: rgba(143,168,184,0.15);
	color: var(--silver);
}

.avatar-vip {
	background: rgba(139,58,107,0.1);
	color: var(--vip);
}

.avatar-regular {
	background: var(--cream-dark);
	color: var(--forest);
}

.member-meta .name {
	font-size: 16px;
	font-weight: 800;
	color: var(--text-dark);
	letter-spacing: -0.02em;
}

.member-meta .email {
	font-size: 12px;
	color: var(--text-light);
	margin-top: 2px;
	font-weight: 500;
}

.member-stats {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 10px;
}

.member-stat {
	background: var(--cream);
	border-radius: 8px;
	padding: 10px;
}

	.member-stat .ms-label {
		font-size: 10px;
		color: var(--text-light);
		text-transform: uppercase;
		letter-spacing: 1.5px;
		font-weight: 700;
	}

	.member-stat .ms-val {
		font-size: 18px;
		font-weight: 800;
		color: var(--forest);
		margin-top: 2px;
		letter-spacing: -0.03em;
	}

/* ── REPORTS ────────────────────────────────── */
.report-grid {
	display: grid;
	grid-template-columns: repeat(3,1fr);
	gap: 16px;
	margin-bottom: 24px;
}

.report-card {
	background: var(--white);
	border-radius: 12px;
	border: 1px solid var(--border);
	padding: 20px;
	box-shadow: var(--shadow);
	transition: background 0.25s;
}

.rc-title {
	font-size: 11px;
	text-transform: uppercase;
	letter-spacing: 1.5px;
	color: var(--text-light);
	margin-bottom: 12px;
	font-weight: 800;
}

.staff-row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 10px 0;
	border-bottom: 1px solid var(--border);
}

	.staff-row:last-child {
		border-bottom: none;
	}

.staff-row-left {
	display: flex;
	align-items: center;
	gap: 10px;
}

.staff-mini-avatar {
	width: 32px;
	height: 32px;
	border-radius: 50%;
	background: var(--forest-mid);
	color: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 13px;
	font-weight: 800;
}

.staff-row-name {
	font-size: 14px;
	font-weight: 700;
}

.staff-row-sales {
	font-size: 12px;
	color: var(--text-light);
	font-weight: 500;
}

.staff-row-tip {
	font-size: 14px;
	font-weight: 800;
	color: var(--gold);
	letter-spacing: -0.02em;
}

.bar-chart {
	margin-top: 10px;
}

.bar-row {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-bottom: 8px;
}

.bar-label {
	font-size: 12px;
	color: var(--text-mid);
	width: 70px;
	text-align: right;
	font-weight: 600;
}

.bar-track {
	flex: 1;
	height: 8px;
	background: var(--cream-dark);
	border-radius: 4px;
	overflow: hidden;
}

.bar-fill {
	height: 100%;
	border-radius: 4px;
	background: linear-gradient(90deg,var(--forest),var(--sage));
	transition: width 0.6s ease;
}

.bar-val {
	font-size: 12px;
	font-weight: 800;
	color: var(--forest);
	min-width: 52px;
	letter-spacing: -0.02em;
}

/* ── SETTINGS ───────────────────────────────── */
.settings-layout {
	display: grid;
	grid-template-columns: 200px 1fr;
	gap: 24px;
}

.settings-nav {
	background: var(--white);
	border-radius: 12px;
	border: 1px solid var(--border);
	padding: 12px 0;
	height: fit-content;
	transition: background 0.25s;
}

.settings-nav-item {
	padding: 10px 18px;
	font-size: 14px;
	cursor: pointer;
	transition: background 0.15s;
	color: var(--text-mid);
	display: flex;
	align-items: center;
	gap: 8px;
	font-weight: 500;
	font-family: 'Plus Jakarta Sans', 'Segoe UI Emoji', 'Apple Color Emoji', sans-serif;
}

	.settings-nav-item:hover {
		background: var(--cream);
		color: var(--forest);
	}

	.settings-nav-item.active {
		background: rgba(26,46,30,0.06);
		color: var(--forest);
		font-weight: 700;
	}

.settings-content {
	background: var(--white);
	border-radius: 12px;
	border: 1px solid var(--border);
	padding: 28px;
	transition: background 0.25s;
}

.settings-section {
	margin-bottom: 32px;
}

.settings-section-title {
	font-size: 19px;
	font-weight: 800;
	color: var(--forest);
	margin-bottom: 16px;
	padding-bottom: 10px;
	border-bottom: 1px solid var(--border);
	letter-spacing: -0.02em;
}

.two-input {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 14px;
}

.toggle-row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 12px 0;
	border-bottom: 1px solid var(--border);
}

	.toggle-row:last-child {
		border-bottom: none;
	}

.toggle-info .toggle-name {
	font-size: 14px;
	font-weight: 700;
}

.toggle-info .toggle-desc {
	font-size: 12px;
	color: var(--text-light);
	margin-top: 2px;
	font-weight: 500;
}

.toggle {
	width: 44px;
	height: 24px;
	border-radius: 12px;
	background: var(--cream-dark);
	border: none;
	cursor: pointer;
	position: relative;
	transition: background 0.2s;
}

	.toggle.on {
		background: var(--forest);
	}

	.toggle::after {
		content: '';
		width: 18px;
		height: 18px;
		background: #fff;
		border-radius: 50%;
		position: absolute;
		top: 3px;
		left: 3px;
		transition: left 0.2s;
		box-shadow: 0 1px 3px rgba(0,0,0,0.2);
	}

	.toggle.on::after {
		left: 23px;
	}

.hardware-card {
	border: 1.5px solid var(--border);
	border-radius: 10px;
	padding: 16px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: 12px;
}

.hw-left {
	display: flex;
	align-items: center;
	gap: 14px;
}

.hw-icon {
	width: 44px;
	height: 44px;
	border-radius: 10px;
	background: var(--cream);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 24px;
}

.hw-name {
	font-size: 14px;
	font-weight: 800;
}

.hw-model {
	font-size: 12px;
	color: var(--text-light);
	margin-top: 2px;
	font-weight: 500;
}

.hw-status {
	font-size: 12px;
	font-weight: 700;
	padding: 3px 10px;
	border-radius: 10px;
}

.hw-connected {
	background: rgba(39,174,96,0.1);
	color: var(--success);
}

.hw-disconnected {
	background: rgba(192,57,43,0.1);
	color: var(--danger);
}

/* ── POS / SERVICE LAYOUT ───────────────────── */
.pos-layout {
	display: grid;
	grid-template-columns: 1fr 400px;
	gap: 20px;
	align-items: start;
}

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

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

		.pos-layout .panel.pos-panel {
			order: -1;
		}
}

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

@media (max-width:767px) {
	.service-grid {
		grid-template-columns: repeat(2,1fr);
		gap: 10px;
	}
}

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

/* ── DRAG & DROP ────────────────────────────── */
[data-draggable="true"] {
	cursor: grab;
}

	[data-draggable="true"]:active {
		cursor: grabbing;
	}

.day-col.drag-over {
	background: rgba(122,158,126,0.1) !important;
	outline: 2px dashed var(--sage) !important;
}

body.dragging {
	user-select: none;
	-webkit-user-select: none;
}

/* ── NEW APPOINTMENT ────────────────────────── */
.appt-service-row {
	display: grid;
	grid-template-columns: 1fr 1fr auto;
	gap: 10px;
	align-items: start;
	background: var(--cream);
	border-radius: 10px;
	padding: 12px;
	margin-bottom: 10px;
	border: 1.5px solid var(--border);
	transition: border-color 0.2s;
	position: relative;
}

	.appt-service-row:hover {
		border-color: var(--sage);
	}

.appt-service-row-num {
	position: absolute;
	top: -8px;
	left: 12px;
	background: var(--forest);
	color: #fff;
	font-size: 10px;
	font-weight: 800;
	padding: 1px 7px;
	border-radius: 8px;
	letter-spacing: 0.5px;
}

.appt-row-remove {
	width: 30px;
	height: 30px;
	border-radius: 50%;
	background: rgba(192,57,43,0.1);
	border: none;
	color: var(--danger);
	font-size: 18px;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: background 0.2s;
	margin-top: 4px;
	flex-shrink: 0;
}

	.appt-row-remove:hover {
		background: rgba(192,57,43,0.2);
	}

.stylist-chips {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	margin-top: 4px;
}

.stylist-chip {
	display: flex;
	align-items: center;
	gap: 5px;
	padding: 5px 10px 5px 6px;
	border-radius: 20px;
	border: 1.5px solid var(--border);
	cursor: pointer;
	font-size: 12px;
	font-weight: 600;
	transition: all 0.15s;
	user-select: none;
	background: var(--white);
	color: var(--text-mid);
}

	.stylist-chip:hover {
		border-color: var(--forest);
		color: var(--forest);
	}

	.stylist-chip.selected {
		background: var(--forest);
		border-color: var(--forest);
		color: #fff;
	}

.stylist-chip-avatar {
	width: 20px;
	height: 20px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 9px;
	font-weight: 800;
	background: rgba(255,255,255,0.2);
	flex-shrink: 0;
}

.stylist-chip:not(.selected) .stylist-chip-avatar {
	background: var(--cream-dark);
	color: var(--text-mid);
}

.service-select-wrap {
	position: relative;
}

.service-price-badge {
	position: absolute;
	right: 36px;
	top: 50%;
	transform: translateY(-50%);
	font-size: 12px;
	font-weight: 800;
	color: var(--forest);
	pointer-events: none;
	opacity: 0.7;
}

.client-dropdown-item {
	padding: 10px 14px;
	cursor: pointer;
	display: flex;
	align-items: center;
	gap: 10px;
	transition: background 0.15s;
	font-size: 13px;
	font-weight: 500;
}

	.client-dropdown-item:hover {
		background: var(--cream);
	}

	.client-dropdown-item .cd-avatar {
		width: 30px;
		height: 30px;
		border-radius: 50%;
		display: flex;
		align-items: center;
		justify-content: center;
		font-size: 11px;
		font-weight: 800;
		flex-shrink: 0;
	}

@media (max-width:767px) {
	.appt-service-row {
		grid-template-columns: 1fr;
	}

	.stylist-chips {
		gap: 4px;
	}

	.stylist-chip {
		font-size: 11px;
		padding: 4px 8px 4px 5px;
	}
}

/* ── 폰트 일관성 (고딕 전체 적용) ─────────────── */
body, .btn, .form-input, .form-select, .panel-title,
.modal-title, .page-title, .stat-value, .stat-label,
.amount-total, .pos-item-price, .pos-row, .appt-list-price,
.ms-val, .staff-row-tip, .bar-val, .week-day-num, .time-slot,
.appt-time, .date-badge, table td, table th, .tip-btn,
.settings-section-title, .hw-name, .hw-model, .rc-title,
.staff-row-name, .staff-row-sales, .member-meta .name,
.member-meta .email, .cal-month, .view-tab {
	font-family: 'Plus Jakarta Sans', sans-serif !important;
}

.logo-sub, .logo-main {
	font-family: 'Cormorant Garamond', serif !important;
}

/* 숫자 강조 */
.stat-value, .amount-total, .pos-item-price, .appt-list-price,
.ms-val, .staff-row-tip, .bar-val, .week-day-num,
.pos-row.total span {
	font-weight: 800;
	letter-spacing: -0.04em;
}

/* ── SCROLLBAR ──────────────────────────────── */
::-webkit-scrollbar {
	width: 4px;
	height: 4px;
}

::-webkit-scrollbar-track {
	background: transparent;
}

::-webkit-scrollbar-thumb {
	background: var(--sage-light);
	border-radius: 2px;
}

/* ── 애니메이션 ─────────────────────────────── */
@keyframes fadeIn {
	from {
		opacity: 0;
		transform: translateY(8px)
	}

	to {
		opacity: 1;
		transform: translateY(0)
	}
}

.page-tabs.active {
	animation: fadeIn 0.25s ease;
}

/* ── MOBILE BOTTOM NAV ──────────────────────── */
.mobile-nav {
	display: none;
	position: fixed;
	bottom: 0;
	left: 0;
	right: 0;
	background: var(--forest);
	height: 64px;
	z-index: 200;
	border-top: 1px solid rgba(255,255,255,0.1);
	padding: 0 4px;
	padding-bottom: env(safe-area-inset-bottom);
	transition: background 0.25s;
}

.mobile-nav-inner {
	display: flex;
	height: 100%;
	align-items: stretch;
}

.mobile-nav-item {
	flex: 1;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 3px;
	cursor: pointer;
	color: rgba(255,255,255,0.5);
	font-size: 9px;
	font-weight: 700;
	letter-spacing: 0.3px;
	transition: color 0.2s;
	padding: 8px 4px;
	border-radius: 8px;
	user-select: none;
	-webkit-tap-highlight-color: transparent;
	font-family: 'Plus Jakarta Sans',sans-serif;
}

	.mobile-nav-item .mnav-icon {
		font-size: 20px;
		line-height: 1;
	}

	.mobile-nav-item.active {
		color: var(--sage-light);
	}

		.mobile-nav-item.active .mnav-icon {
			transform: scale(1.1);
		}

.mobile-menu-btn {
	display: none;
	width: 40px;
	height: 40px;
	border-radius: 8px;
	background: var(--cream);
	border: none;
	cursor: pointer;
	align-items: center;
	justify-content: center;
	font-size: 20px;
	flex-shrink: 0;
}

.sidebar-overlay {
	display: none;
	position: fixed;
	inset: 0;
	background: rgba(0,0,0,0.5);
	z-index: 150;
	opacity: 0;
	transition: opacity 0.25s;
}

	.sidebar-overlay.open {
		opacity: 1;
	}

/* ── TABLET (768–1100px) ────────────────────── */
@media (max-width:1100px) {
	.sidebar {
		width: 200px;
		min-width: 200px;
	}

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

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

	.stats-row {
		grid-template-columns: repeat(2,1fr);
	}

	.content {
		padding: 16px 18px;
	}

	.topbar {
		padding: 0 18px;
	}
}

/* ── MOBILE (≤767px) ────────────────────────── */
@media (max-width:767px) {
	body {
		overflow: auto;
		height: auto;
		flex-direction: column;
	}

	.main {
		height: auto;
		overflow: visible;
	}

	.sidebar {
		position: fixed;
		top: 0;
		left: 0;
		height: 100vh;
		z-index: 160;
		transform: translateX(-100%);
		transition: transform 0.3s cubic-bezier(0.4,0,0.2,1);
		width: 260px;
		min-width: 260px;
	}

		.sidebar.open {
			transform: translateX(0);
		}

	.sidebar-overlay {
		display: block;
		pointer-events: none;
	}

		.sidebar-overlay.open {
			pointer-events: all;
		}

	.mobile-menu-btn {
		display: flex;
	}

	.mobile-nav {
		display: block;
	}

	.topbar {
		padding: 0 16px;
		height: 56px;
		position: sticky;
		top: 0;
		z-index: 100;
	}

	.topbar-left {
		gap: 10px;
	}

	.page-title {
		font-size: 17px;
	}

	.date-badge {
		display: none;
	}

	.topbar-right .btn {
		display: none;
	}

	.topbar-right {
		gap: 8px;
	}

	.content {
		padding: 14px 14px 84px;
		overflow: visible;
		flex: none;
	}

	.stats-row {
		grid-template-columns: repeat(2,1fr);
		gap: 10px;
		margin-bottom: 16px;
	}

	.stat-card {
		padding: 14px;
	}

	.stat-value {
		font-size: 26px;
	}

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

	.report-grid {
		grid-template-columns: 1fr;
		gap: 12px;
	}

	.settings-layout {
		grid-template-columns: 1fr;
		gap: 14px;
	}

	.settings-nav {
		display: flex;
		overflow-x: auto;
		padding: 8px;
		gap: 4px;
		border-radius: 10px;
		-webkit-overflow-scrolling: touch;
	}

	.settings-nav-item {
		white-space: nowrap;
		padding: 8px 14px;
		border-radius: 8px;
		font-size: 13px;
	}

	.settings-content {
		padding: 18px;
	}

	.two-input {
		grid-template-columns: 1fr;
		gap: 10px;
	}

	.modal {
		width: calc(100vw - 24px) !important;
		margin: 12px;
		max-height: 92vh;
	}

	.modal-overlay {
		align-items: flex-end;
		padding-bottom: env(safe-area-inset-bottom);
	}

		.modal-overlay.open .modal {
			border-radius: 16px 16px 12px 12px;
		}

	.hardware-card {
		flex-wrap: wrap;
		gap: 10px;
	}

		.hardware-card .btn-sm {
			width: 100%;
			text-align: center;
		}

	.panel.pos-panel {
		position: relative;
	}

	.panel-body table {
		min-width: 560px;
	}

	.panel-body:has(table) {
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
		padding: 0;
	}

	.settings-content [style*="grid-template-columns:repeat(2"] {
		grid-template-columns: 1fr !important;
	}

	.modal-body [style*="grid-template-columns:repeat(4"] {
		grid-template-columns: repeat(2,1fr) !important;
	}

	.modal-body [style*="grid-template-columns:1fr 1fr"] {
		grid-template-columns: 1fr !important;
	}

	.amount-total {
		font-size: 40px;
	}

	.tip-grid {
		grid-template-columns: repeat(4,1fr);
		gap: 6px;
	}

	.tip-btn {
		padding: 8px 4px;
		font-size: 13px;
	}

	.payment-method-grid {
		grid-template-columns: repeat(3,1fr);
		gap: 8px;
	}

	.pay-method {
		padding: 12px 6px;
		font-size: 12px;
	}

	#page-inventory .btn {
		width: 100%;
	}

	.mobile-fab {
		display: flex !important;
	}

	.theme-toggle-wrap span:not(.theme-toggle-icon) {
		display: none;
	}
}

@media (max-width:380px) {
	.stats-row {
		grid-template-columns: 1fr 1fr;
		gap: 8px;
	}

	.stat-value {
		font-size: 22px;
	}

	.view-tab {
		font-size: 11px;
		padding: 5px 6px;
	}
}

/* ── FAB ────────────────────────────────────── */
.mobile-fab {
	display: none;
	position: fixed;
	bottom: 80px;
	right: 18px;
	z-index: 199;
	gap: 10px;
	flex-direction: column;
	align-items: flex-end;
}

.fab-btn {
	width: 52px;
	height: 52px;
	border-radius: 50%;
	background: var(--gold);
	color: #fff;
	border: none;
	cursor: pointer;
	font-size: 22px;
	box-shadow: 0 4px 16px rgba(201,168,76,0.5);
	display: flex;
	align-items: center;
	justify-content: center;
	transition: transform 0.2s, box-shadow 0.2s;
	-webkit-tap-highlight-color: transparent;
}

	.fab-btn:active {
		transform: scale(0.93);
	}

	.fab-btn.fab-main {
		width: 58px;
		height: 58px;
		background: var(--forest);
		box-shadow: 0 4px 20px rgba(26,46,30,0.4);
		font-size: 26px;
	}

/* ══════════ VIRTUAL KEYBOARD ══════════ */
#vk-overlay {
	position: fixed;
	bottom: 0;
	left: 50%;
	transform: translateX(-50%) translateY(100%);
	width: 100%;
	max-width: 640px;
	z-index: 99999;
	background: #1c1c1e;
	border-radius: 20px 20px 0 0;
	box-shadow: 0 -6px 40px rgba(0,0,0,0.45);
	padding: 0 6px 20px;
	transition: transform 0.28s cubic-bezier(0.4,0,0.2,1);
	user-select: none;
	-webkit-user-select: none;
}

	#vk-overlay.vk-open {
		transform: translateX(-50%) translateY(0);
	}

#vk-handle {
	width: 36px;
	height: 4px;
	background: rgba(255,255,255,0.2);
	border-radius: 2px;
	margin: 10px auto 0;
}

#vk-topbar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 8px 8px 6px;
}

#vk-preview-wrap {
	flex: 1;
	background: rgba(255,255,255,0.07);
	border-radius: 8px;
	padding: 6px 12px;
	margin-right: 10px;
	min-height: 34px;
	display: flex;
	align-items: center;
	overflow: hidden;
}

#vk-preview {
	font-size: 14px;
	color: rgba(255,255,255,0.85);
	font-family: 'DM Sans', sans-serif;
	font-weight: 400;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	max-width: 100%;
}

	#vk-preview::after {
		content: '|';
		animation: vk-blink 1s step-end infinite;
		color: var(--gold);
		margin-left: 1px;
	}

@keyframes vk-blink {
	0%,100% {
		opacity: 1
	}

	50% {
		opacity: 0
	}
}

#vk-done-btn {
	background: var(--forest);
	color: #fff;
	border: none;
	border-radius: 10px;
	padding: 8px 18px;
	font-size: 14px;
	font-weight: 700;
	cursor: pointer;
	font-family: 'DM Sans', sans-serif;
	white-space: nowrap;
	transition: background 0.15s;
}

	#vk-done-btn:active {
		background: var(--forest-mid);
	}

/* Key base */
.vk-row {
	display: flex;
	justify-content: center;
	gap: 5px;
	margin-bottom: 5px;
}

.vk-key {
	height: 46px;
	min-width: 32px;
	flex: 1;
	background: #3a3a3c;
	color: #fff;
	border: none;
	border-radius: 10px;
	font-size: 17px;
	font-weight: 500;
	cursor: pointer;
	font-family: 'DM Sans', sans-serif;
	display: flex;
	align-items: center;
	justify-content: center;
	-webkit-tap-highlight-color: transparent;
	transition: background 0.08s, transform 0.08s;
	position: relative;
}

	.vk-key:active {
		background: #636366;
		transform: scale(0.93);
	}

	.vk-key.vk-special {
		background: #1c1c1e;
		border: 1px solid #3a3a3c;
		font-size: 14px;
		flex: 1.5;
	}

	.vk-key.vk-space {
		background: #3a3a3c;
		flex: 4;
		font-size: 13px;
		color: rgba(255,255,255,0.7);
	}

	.vk-key.vk-action {
		background: var(--forest);
		flex: 2;
		font-size: 13px;
		font-weight: 700;
	}

		.vk-key.vk-action:active {
			background: var(--forest-mid);
		}

	.vk-key.vk-backspace {
		font-size: 20px;
		flex: 1.5;
	}

	.vk-key.vk-shift-on {
		background: var(--sage);
		color: var(--text-dark);
	}

	.vk-key.vk-caps-on {
		background: var(--gold);
		color: #fff;
	}

	.vk-key.vk-email-key {
		background: #2c3e50;
		border: 1px solid #4a6278;
		font-size: 13px;
		font-weight: 700;
	}

	.vk-key.vk-at-key {
		background: var(--gold);
		color: #1a1a1a;
		font-size: 18px;
		font-weight: 800;
		flex: 1.2;
	}

/* Numpad */
#vk-numpad {
	padding: 4px 0;
}

.vk-numpad-grid {
	display: grid;
	grid-template-columns: repeat(3,1fr);
	gap: 8px;
	max-width: 360px;
	margin: 0 auto;
}

	.vk-numpad-grid .vk-key {
		height: 60px;
		font-size: 22px;
		font-weight: 600;
		border-radius: 12px;
		flex: none;
	}

		.vk-numpad-grid .vk-key.vk-num-0 {
			grid-column: span 2;
		}

		.vk-numpad-grid .vk-key.vk-done-num {
			background: var(--forest);
			font-size: 14px;
			font-weight: 700;
			grid-column: span 3;
			height: 50px;
		}

/* ── SERVICE MANAGEMENT ─────────────────────────────── */
/* Category panel items */
.svc-cat-item {
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 9px 16px;
	cursor: pointer;
	border-left: 3px solid transparent;
	transition: all 0.15s;
	font-size: 14px;
	color: var(--text-mid);
	border-radius: 0;
	position: relative;
}

	.svc-cat-item:hover {
		background: var(--cream);
		color: var(--text-dark);
	}

	.svc-cat-item.active {
		background: rgba(26,46,30,0.06);
		color: var(--forest);
		border-left-color: var(--forest);
		font-weight: 600;
	}

.svc-cat-icon {
	font-size: 16px;
	flex-shrink: 0;
}

.svc-cat-name {
	flex: 1;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.svc-cat-count {
	font-size: 11px;
	font-weight: 700;
	background: var(--cream-dark);
	color: var(--text-light);
	padding: 1px 7px;
	border-radius: 10px;
	flex-shrink: 0;
}

.svc-cat-actions {
	display: none;
	gap: 2px;
	margin-left: 4px;
}

.svc-cat-item:hover .svc-cat-actions {
	display: flex;
}

.svc-cat-actions button {
	background: none;
	border: none;
	cursor: pointer;
	font-size: 13px;
	padding: 2px 4px;
	border-radius: 4px;
}

	.svc-cat-actions button:hover {
		background: var(--cream-dark);
	}

/* Service card rows */
.svc-card-row {
	display: flex;
	align-items: center;
	gap: 14px;
	background: var(--white);
	border: 1px solid var(--border);
	border-radius: 12px;
	padding: 14px 16px;
	margin-bottom: 10px;
	transition: box-shadow 0.15s, border-color 0.15s;
}

	.svc-card-row:hover {
		border-color: var(--sage);
		box-shadow: var(--shadow);
	}

	.svc-card-row.svc-inactive {
		opacity: 0.5;
	}

.svc-card-icon {
	font-size: 28px;
	flex-shrink: 0;
	width: 40px;
	text-align: center;
}

.svc-card-body {
	flex: 1;
	min-width: 0;
}

.svc-card-name {
	font-size: 15px;
	font-weight: 700;
	color: var(--text-dark);
	margin-bottom: 3px;
}

.svc-card-meta {
	font-size: 13px;
	color: var(--text-light);
	display: flex;
	align-items: center;
	gap: 6px;
	flex-wrap: wrap;
}

.svc-meta-dot {
	color: var(--border);
}

.svc-staff-row {
	display: flex;
	flex-wrap: wrap;
	gap: 5px;
	margin-top: 7px;
}

.svc-staff-chip {
	font-size: 11px;
	font-weight: 700;
	padding: 2px 8px;
	border-radius: 20px;
}

.svc-card-actions {
	display: flex;
	align-items: center;
	gap: 8px;
	flex-shrink: 0;
}

.svc-act-btn {
	padding: 5px 11px;
	border-radius: 7px;
	border: 1.5px solid var(--border);
	background: var(--white);
	font-size: 12px;
	font-weight: 600;
	color: var(--text-mid);
	cursor: pointer;
	transition: all 0.15s;
	white-space: nowrap;
}

	.svc-act-btn:hover {
		border-color: var(--forest);
		color: var(--forest);
		background: rgba(26,46,30,0.04);
	}

.svc-act-del:hover {
	border-color: var(--danger);
	color: var(--danger);
	background: rgba(192,57,43,0.05);
}

/* Active toggle pill */
.svc-toggle-wrap {
	cursor: pointer;
}

.svc-toggle-pill {
	display: inline-block;
	width: 36px;
	height: 20px;
	border-radius: 10px;
	background: var(--cream-dark);
	border: 1.5px solid var(--border);
	position: relative;
	transition: background 0.2s;
}

	.svc-toggle-pill::after {
		content: '';
		width: 14px;
		height: 14px;
		border-radius: 50%;
		background: var(--text-light);
		position: absolute;
		top: 1px;
		left: 1px;
		transition: left 0.2s, background 0.2s;
	}

	.svc-toggle-pill.on {
		background: rgba(26,46,30,0.15);
		border-color: var(--forest);
	}

		.svc-toggle-pill.on::after {
			left: 17px;
			background: var(--forest);
		}

/* Staff selector chips in modal */
.svc-staff-sel-chip {
	padding: 6px 14px;
	border-radius: 20px;
	font-size: 13px;
	font-weight: 600;
	border: 1.5px solid var(--border);
	background: var(--white);
	color: var(--text-mid);
	cursor: pointer;
	transition: all 0.15s;
	user-select: none;
}

	.svc-staff-sel-chip:hover {
		border-color: var(--sage);
	}

	.svc-staff-sel-chip.selected {
		font-weight: 700;
	}

/* Dark mode */
[data-theme="dark"] .svc-card-row {
	background: var(--white);
}

[data-theme="dark"] .svc-cat-item:hover {
	background: var(--cream-dark);
}

[data-theme="dark"] .svc-cat-item.active {
	background: rgba(77,148,88,0.1);
}

[data-theme="dark"] .svc-staff-sel-chip {
	background: var(--cream);
}

[data-theme="dark"] .svc-act-btn {
	background: var(--cream);
}

.vk-numpad-grid .vk-key.vk-special {
	border: 1px solid #3a3a3c;
}

/* ── STAFF MANAGEMENT ───────────────────────────────── */
.staff-mgmt-card {
	display: flex;
	align-items: center;
	gap: 14px;
	background: var(--white);
	border: 1px solid var(--border);
	border-radius: 12px;
	padding: 14px 16px;
	margin-bottom: 10px;
	transition: box-shadow 0.15s, border-color 0.15s;
}

	.staff-mgmt-card:hover {
		border-color: var(--sage);
		box-shadow: var(--shadow);
	}

	.staff-mgmt-card.staff-inactive {
		opacity: 0.5;
	}

.staff-mgmt-avatar {
	width: 44px;
	height: 44px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 15px;
	font-weight: 800;
	flex-shrink: 0;
}

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

.staff-mgmt-name {
	font-size: 15px;
	font-weight: 700;
	color: var(--text-dark);
	margin-bottom: 3px;
}

.staff-mgmt-meta {
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: 13px;
}

.staff-mgmt-role {
	padding: 2px 8px;
	border-radius: 20px;
	font-size: 11px;
	font-weight: 700;
	background: var(--cream-dark);
	color: var(--text-mid);
}

.staff-mgmt-actions {
	display: flex;
	align-items: center;
	gap: 8px;
	flex-shrink: 0;
}

/* Color chips in staff modal */
.staff-color-chip {
	width: 30px;
	height: 30px;
	border-radius: 50%;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 13px;
	color: #fff;
	font-weight: 700;
	border: 3px solid transparent;
	transition: border-color 0.15s, transform 0.1s;
}

	.staff-color-chip:hover {
		transform: scale(1.15);
	}

	.staff-color-chip.selected {
		border-color: var(--text-dark);
		transform: scale(1.15);
	}

[data-theme="dark"] .staff-mgmt-card {
	background: var(--white);
}

[data-theme="dark"] .staff-mgmt-role {
	background: var(--cream-dark);
}
