/*
 * Fitviki Plan – Frontend stylesheet
 * Version: 0.0.1
 *
 * Layout: responsive card grid, brand colours from fitviki.cz
 *   Primary:    #4054B2  (modrofialová)
 *   Active:     #F25E38  (oranžovo-cihlová)
 *   Background: #F7F7F7  (světlé pozadí)
 *   Green:      #54b240  (zelená)
 *
 * Typography:
 *   Primary (headings):  Roboto 600
 *   Secondary:           Roboto Slab 400
 *   Text / body:         Roboto 400
 *   Accent:              Roboto 500
 */

@import url('https://fonts.googleapis.com/css2?family=Roboto:ital,wght@0,100;0,300;0,400;0,500;0,600;0,700;1,100;1,400&family=Roboto+Slab:wght@400;600&display=swap');

/* ── Container ─────────────────────────────────────────────────────────────── */

.fitviki-plan-container {
	max-width: 1200px;
	margin: 0 auto;
	padding: 20px 16px;
	font-family: 'Roboto', sans-serif;
	font-weight: 400;
}

/* ── Week group (details/summary accordion) ─────────────────────────────────── */

.fitviki-plan-week {
	margin-bottom: 48px;
	border: none;
}

.fitviki-plan-week-title {
	font-size: 1.4rem;
	font-family: 'Roboto Slab', serif;
	font-weight: 600;
	color: #F25E38;
	border-bottom: 3px solid #F25E38;
	padding: 10px 4px 10px 4px;
	margin: 0 0 20px 0;
	cursor: pointer;
	list-style: none;  /* hide default marker in some browsers */
	display: flex;
	align-items: center;
	gap: 8px;
}

/* Custom marker icon instead of the browser default triangle */
.fitviki-plan-week-title::before {
	content: '▶';
	font-size: 0.7em;
	transition: transform 0.2s ease;
	display: inline-block;
}

.fitviki-plan-week[open] > .fitviki-plan-week-title::before {
	transform: rotate(90deg);
}

.fitviki-plan-week-entries {
	/* Inner padding so cards don't touch the summary border */
	padding-top: 4px;
}

/* ── Prev / Next navigation ──────────────────────────────────────────────────── */

.fitviki-plan-navigation {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	margin-bottom: 24px;
	padding: 10px 16px;
	background: #fff;
	border: 1px solid #e0e0e0;
	border-radius: 10px;
}

.fitviki-plan-nav-btn {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 8px 18px;
	background: #4054B2;
	color: #fff;
	text-decoration: none;
	border-radius: 6px;
	font-family: 'Roboto', sans-serif;
	font-size: 0.88rem;
	font-weight: 500;
	transition: background 0.15s ease;
}

.fitviki-plan-nav-btn:hover {
	background: #2e3d8a;
	color: #fff;
	text-decoration: none;
}

.fitviki-plan-nav-current {
	font-size: 0.9rem;
	font-weight: 600;
	color: #333;
}

@media (max-width: 480px) {
	.fitviki-plan-navigation {
		flex-direction: column;
		gap: 8px;
	}
}

/* ── Day card ───────────────────────────────────────────────────────────────── */

.fitviki-plan-day {
	background: #ffffff;
	border-radius: 14px;
	box-shadow: 0 2px 12px rgba(0, 0, 0, 0.09);
	margin-bottom: 24px;
	overflow: hidden;
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.fitviki-plan-day:hover {
	transform: translateY(-3px);
	box-shadow: 0 6px 24px rgba(0, 0, 0, 0.14);
}

/* ── Day header ─────────────────────────────────────────────────────────────── */

.fitviki-plan-day-header {
	padding: 16px 22px;
	background: #4054B2;
	color: #ffffff;
}

.fitviki-plan-day-title {
	margin: 0;
	font-size: 1rem;
	font-family: 'Roboto', sans-serif;
	font-weight: 600;
	line-height: 1.3;
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 8px;
}

/* Day name badge */
.fitviki-plan-day-name {
	background: #54b240;
	color: #fff;
	font-size: 1rem;
	font-weight: 700;
	padding: 3px 14px;
	border-radius: 20px;
}

.fitviki-plan-day-date {
	background: #54b240;
	color: #fff;
	font-size: 0.72rem;
	font-weight: 600;
	padding: 2px 9px;
	border-radius: 20px;
}

/* "Today" badge */
.fitviki-plan-today-badge {
	background: #6ec1e4;
	color: #fff;
	font-size: 0.7rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	padding: 2px 8px;
	border-radius: 20px;
}

/* Weekend colour variant */
.fitviki-plan-day--saturday .fitviki-plan-day-header,
.fitviki-plan-day--sunday   .fitviki-plan-day-header {
	background: #2e3d8a;
}

/* Today header – lighter shade */
.fitviki-plan-day--today .fitviki-plan-day-header {
	background: #5c6ec0;
}

/* "Today" ring */
.fitviki-plan-day--today {
	box-shadow: 0 0 0 3px #6ec1e4, 0 4px 16px rgba(110, 193, 228, 0.25);
}

/* ── Hero image ─────────────────────────────────────────────────────────────── */

.fitviki-plan-image img {
	width: 100%;
	height: 200px;
	object-fit: cover;
	display: block;
}

/* ── Body grid ──────────────────────────────────────────────────────────────── */

.fitviki-plan-body {
	padding: 20px;
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 16px;
}

/* ── Sections ───────────────────────────────────────────────────────────────── */

.fitviki-plan-section {
	background: #F7F7F7;
	border-radius: 10px;
	padding: 14px 16px;
}

.fitviki-plan-section-title {
	margin: 0 0 10px 0;
	font-size: 0.95rem;
	font-family: 'Roboto Slab', serif;
	font-weight: 400;
	color: #333;
	padding-bottom: 8px;
	border-bottom: 1px solid #e0e0e0;
}

/* ── Workout ─────────────────────────────────────────────────────────────────── */

.fitviki-plan-workout-item {
	margin: 8px 0;
	font-size: 0.88rem;
	line-height: 1.5;
	display: flex;
	align-items: baseline;
	gap: 6px;
}

.fitviki-plan-level-badge {
	display: inline-block;
	font-size: 0.7rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	padding: 2px 7px;
	border-radius: 20px;
	white-space: nowrap;
	flex-shrink: 0;
}

.fitviki-plan-level--beginner {
	background: #eaf5e8;
	color: #54b240;
}

.fitviki-plan-level--advanced {
	background: #fbe9e7;
	color: #bf360c;
}

/* ── Meal ────────────────────────────────────────────────────────────────────── */

.fitviki-plan-meal-item {
	margin: 6px 0;
	font-size: 0.88rem;
	line-height: 1.5;
}

/* ── Note ────────────────────────────────────────────────────────────────────── */

.fitviki-plan-note p,
.fitviki-plan-note a {
	font-size: 0.88rem;
	color: #555;
	font-style: italic;
	line-height: 1.6;
	margin: 0;
}

/* ── Tracker (user workout log) ──────────────────────────────────────────────── */

.fitviki-plan-tracker {
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.fitviki-tracker-row {
	display: flex;
	align-items: center;
	gap: 8px;
	flex-wrap: wrap;
}

/* Completed */
.fitviki-tracker-completed-label {
	display: inline-flex;
	align-items: center;
	gap: 7px;
	font-size: 0.88rem;
	font-family: 'Roboto', sans-serif;
	font-weight: 500;
	color: #333;
	cursor: pointer;
	user-select: none;
}

.fitviki-tracker-completed-input {
	width: 17px;
	height: 17px;
	cursor: pointer;
	accent-color: #54b240;
	flex-shrink: 0;
}

/* Rating label */
.fitviki-tracker-rating-label {
	font-size: 0.82rem;
	color: #666;
	white-space: nowrap;
}

/* Smileys */
.fitviki-tracker-smileys {
	display: inline-flex;
	gap: 3px;
}

.fitviki-tracker-smiley {
	background: none;
	border: 2px solid transparent;
	border-radius: 50%;
	cursor: pointer;
	font-size: 1.45rem;
	padding: 3px;
	line-height: 1;
	opacity: 0.3;
	transition: opacity 0.15s ease, transform 0.15s ease, border-color 0.15s ease, background 0.15s ease;
}

/* Per-value colour tokens (active border + tinted background) */
.fitviki-tracker-smiley[data-value="1"] { --sc: #e53935; }
.fitviki-tracker-smiley[data-value="2"] { --sc: #ff7043; }
.fitviki-tracker-smiley[data-value="3"] { --sc: #ffc107; }
.fitviki-tracker-smiley[data-value="4"] { --sc: #8bc34a; }
.fitviki-tracker-smiley[data-value="5"] { --sc: #54b240; }

.fitviki-tracker-smiley:hover,
.fitviki-tracker-smiley--hover {
	opacity: 1;
	transform: scale(1.3);
}

.fitviki-tracker-smiley--active {
	opacity: 1;
	transform: scale(1.15);
	border-color: var(--sc);
	background: color-mix(in srgb, var(--sc) 14%, transparent);
}

/* Fallback for browsers without color-mix (Firefox <113, Safari <16.2) */
@supports not (color: color-mix(in srgb, red, transparent)) {
	.fitviki-tracker-smiley--active {
		background: rgba(0, 0, 0, 0.06);
	}
}

/* Clear rating button */
.fitviki-tracker-smiley-clear {
	background: none;
	border: none;
	cursor: pointer;
	font-size: 0.72rem;
	color: #bbb;
	padding: 0 2px;
	line-height: 1;
	transition: color 0.15s ease;
}

.fitviki-tracker-smiley-clear:hover {
	color: #F25E38;
}

/* Status indicator */
.fitviki-tracker-status {
	font-size: 0.76rem;
	min-height: 1em;
	transition: opacity 0.3s ease;
}

.fitviki-tracker-status.is-saving { color: #888; }
.fitviki-tracker-status.is-saved  { color: #54b240; }
.fitviki-tracker-status.is-error  { color: #e53935; }

/* ── Review widget (──────────────────────────────────────────────────────────────────── */

.fitviki-review-container {
	max-width: 1200px;
	margin: 0 auto 28px;
	background: #fff;
	border-radius: 14px;
	box-shadow: 0 2px 12px rgba(0,0,0,0.09);
	padding: 22px 24px 18px;
	font-family: 'Roboto', sans-serif;
	font-weight: 400;
}

.fitviki-review-container--guest {
	text-align: center;
	color: #888;
	font-style: italic;
	padding: 40px 24px;
}

.fitviki-review-title {
	margin: 0 0 16px;
	font-size: 1.1rem;
	font-family: 'Roboto Slab', serif;
	font-weight: 600;
	color: #1d2327;
	display: flex;
	align-items: center;
	gap: 8px;
}

/* Stats boxes */
.fitviki-review-stats {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-bottom: 20px;
}

.fitviki-review-stat {
	background: #F7F7F7;
	border-top: 3px solid #e0e0e0;
	border-radius: 10px;
	padding: 10px 18px;
	display: flex;
	flex-direction: column;
	align-items: center;
	min-width: 74px;
}

.fitviki-review-stat--green { border-top-color: #54b240; }
.fitviki-review-stat--amber { border-top-color: #f9a825; }
.fitviki-review-stat--red   { border-top-color: #e53935; }

.fitviki-review-stat-val {
	font-size: 1.5rem;
	font-family: 'Roboto', sans-serif;
	font-weight: 600;
	color: #1d2327;
	line-height: 1.1;
}

.fitviki-review-stat--green .fitviki-review-stat-val { color: #54b240; }
.fitviki-review-stat--amber .fitviki-review-stat-val { color: #f9a825; }
.fitviki-review-stat--red   .fitviki-review-stat-val { color: #e53935; }

.fitviki-review-stat-lbl {
	font-size: 0.68rem;
	color: #999;
	margin-top: 3px;
	text-align: center;
}

/* Bar chart */
.fitviki-review-chart {
	display: flex;
	align-items: stretch;
	gap: 4px;
	overflow-x: auto;
}

.fitviki-review-yaxis {
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	height: 100px;
	width: 16px;
	flex-shrink: 0;
	font-size: 0.62rem;
	color: #c8c8c8;
	text-align: right;
	padding-right: 3px;
}

.fitviki-review-chart-body {
	flex: 1;
	position: relative;
	min-width: 0;
}

.fitviki-review-grid-lines {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 100px;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	pointer-events: none;
	z-index: 0;
}

.fitviki-review-grid-lines > div {
	border-top: 1px dashed #f0f0f0;
	width: 100%;
}

.fitviki-review-bars {
	display: flex;
	gap: 4px;
	align-items: flex-end;
	height: 100px;
	position: relative;
	z-index: 1;
}

.fitviki-review-col {
	flex: 1;
	min-width: 32px;
	max-width: 80px;
}

.fitviki-review-col--today .fitviki-review-bar-wrap {
	outline: 2px solid #F25E38;
	outline-offset: 1px;
	border-radius: 4px;
}

.fitviki-review-bar-wrap {
	width: 100%;
	height: 100px;
	background: #f5f5f5;
	border-radius: 4px 4px 0 0;
	display: flex;
	align-items: flex-end;
	overflow: hidden;
}

.fitviki-review-bar {
	width: 100%;
	border-radius: 4px 4px 0 0;
	transition: height 0.5s cubic-bezier(.22,.61,.36,1);
}

.fitviki-review-col-smiley {
	font-size: 0.95rem;
	line-height: 1.5;
	min-height: 1.4rem;
}

.fitviki-review-col-smiley--empty {
	color: #ddd;
	font-size: 0.75rem;
}

.fitviki-review-col-check {
	font-size: 0.78rem;
	font-weight: 700;
	line-height: 1.3;
}

.fitviki-review-col-check--done { color: #54b240; }
.fitviki-review-col-check--miss { color: #e53935; }
.fitviki-review-col-check--none { color: #ddd; }

/* Labels row below the chart */
.fitviki-review-col-labels {
	display: flex;
	gap: 4px;
	margin-top: 6px;
}

.fitviki-review-col-label {
	flex: 1;
	min-width: 32px;
	max-width: 80px;
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	line-height: 1.25;
}

.fitviki-review-col-label strong {
	font-size: 0.75rem;
	color: #444;
}

.fitviki-review-col-label small {
	font-size: 0.62rem;
	color: #aaa;
}

.fitviki-review-no-data {
	text-align: center;
	color: #bbb;
	font-style: italic;
	font-size: 0.85rem;
	padding: 12px 0 0;
}

/* ── Links ───────────────────────────────────────────────────────────────────── */

.fitviki-plan-container a {
	color: #4054B2;
	text-decoration: none;
}

.fitviki-plan-container a:hover {
	text-decoration: underline;
	color: #2e3d8a;
}

/* ── Empty state ─────────────────────────────────────────────────────────────── */

.fitviki-plan-empty {
	padding: 30px;
	text-align: center;
	color: #888;
	font-style: italic;
}

/* ── Responsive ──────────────────────────────────────────────────────────────── */

@media (max-width: 640px) {
	.fitviki-plan-body {
		grid-template-columns: 1fr;
		padding: 14px;
	}

	.fitviki-plan-container {
		padding: 10px 8px;
	}

	.fitviki-plan-day-title {
		font-size: 1.1rem;
	}

	.fitviki-plan-image img {
		height: 160px;
	}

	/* Review: hide smiley + date sub-label when very tight */
	.fitviki-review-container {
		padding: 14px 12px 12px;
	}

	.fitviki-review-col-smiley,
	.fitviki-review-col-label small {
		display: none;
	}
}
