/* ── Seminar Note — Frontend Styles ── */

@import url('https://fonts.googleapis.com/css2?family=DM+Serif+Display:ital@0;1&family=DM+Sans:wght@300;400;500;600&display=swap');

.sp-note-wrap {
	--ink:     #0f0f0f;
	--paper:   #f5f0e8;
	--cream:   #ede8dc;
	--accent:  #c8391a;
	--blue:    #1a5fc8;
	--green:   #1a7a3c;
	--amber:   #c87a1a;
	--shadow:  3px 3px 0 #0f0f0f;

	font-family: 'DM Sans', sans-serif;
	color: var(--ink);
	width: 100%;
}

/* ── Card ── */

.sp-note-wrap .sp-card {
	max-width: 420px;
	margin: 32px auto;
	background: #fff;
	border: 2px solid var(--ink);
	box-shadow: var(--shadow);
	animation: sp-up .3s ease;
}

.sp-note-wrap .sp-card__header {
	background: var(--ink);
	color: var(--paper);
	padding: 20px 24px;
	text-align: center;
}

.sp-note-wrap .sp-card__header h2 {
	font-family: 'DM Serif Display', serif;
	font-style: italic;
	font-size: 22px;
	margin: 0 0 4px;
}

.sp-note-wrap .sp-card__header p {
	font-size: 12px;
	opacity: .6;
	margin: 0;
}

.sp-note-wrap .sp-card__body {
	padding: 28px 24px;
	display: flex;
	flex-direction: column;
	gap: 18px;
}

/* ── Results ── */

.sp-note-results {
	max-width: 640px;
	margin: 0 auto 32px;
	animation: sp-up .4s ease;
}

.sp-note-profile {
	background: #fff;
	border: 2px solid var(--ink);
	box-shadow: var(--shadow);
	margin-bottom: 20px;
}

.sp-note-profile__header {
	background: var(--blue);
	color: #fff;
	padding: 18px 24px;
	text-align: center;
}

.sp-note-profile__header h3 {
	font-family: 'DM Serif Display', serif;
	font-size: 20px;
	margin: 0 0 4px;
}

.sp-note-profile__header p {
	font-size: 12px;
	opacity: .8;
	margin: 0;
}

.sp-note-profile__body {
	padding: 20px 24px;
}

.sp-note-stats {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 12px;
	margin-bottom: 20px;
}

.sp-note-stat {
	background: var(--paper);
	border: 2px solid var(--ink);
	text-align: center;
	padding: 14px 8px;
}

.sp-note-stat__n {
	font-size: 22px;
	font-weight: 600;
	margin: 0 0 4px;
}

.sp-note-stat__l {
	font-size: 10px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: .08em;
	color: #555;
}

/* ── Grades Table ── */

.sp-note-table-wrap {
	margin-bottom: 16px;
}

.sp-note-table-wrap h4 {
	font-size: 13px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: .08em;
	margin: 0 0 10px;
	padding-bottom: 8px;
	border-bottom: 2px solid var(--ink);
}

.sp-note-table {
	width: 100%;
	border-collapse: collapse;
	font-size: 14px;
}

.sp-note-table th,
.sp-note-table td {
	padding: 10px 12px;
	text-align: left;
	border-bottom: 1px solid #ddd;
}

.sp-note-table th {
	font-size: 11px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: .05em;
	color: #555;
	background: var(--cream);
}

.sp-note-table td:last-child {
	text-align: right;
	font-weight: 600;
}

.sp-note-table tr:last-child td {
	border-bottom: 2px solid var(--ink);
}

.sp-note-grade {
	display: inline-block;
	min-width: 28px;
	text-align: center;
	padding: 3px 8px;
	font-size: 13px;
	font-weight: 600;
	border: 2px solid var(--ink);
}

.sp-note-grade--ok {
	background: #e0f5e8;
	color: var(--green);
}

.sp-note-grade--warn {
	background: #fff3e0;
	color: var(--amber);
}

.sp-note-grade--empty {
	background: #f5f5f5;
	color: #999;
	border-color: #ccc;
}

/* ── Final Grade ── */

.sp-note-final {
	background: var(--ink);
	color: var(--paper);
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 16px 24px;
}

.sp-note-final__label {
	font-size: 13px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: .05em;
}

.sp-note-final__value {
	font-family: 'DM Serif Display', serif;
	font-size: 28px;
}

/* ── Prezențe Toggle ── */

.sp-note-prezente-toggle {
	background: none;
	border: 2px solid var(--ink);
	padding: 8px 16px;
	font-family: 'DM Sans', sans-serif;
	font-size: 12px;
	font-weight: 600;
	cursor: pointer;
	letter-spacing: .05em;
	text-transform: uppercase;
	margin-bottom: 12px;
	transition: all .15s;
}

.sp-note-prezente-toggle:hover {
	background: var(--ink);
	color: var(--paper);
}

.sp-note-prezente-list {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(110px, 1fr));
	gap: 8px;
	margin-top: 12px;
}

.sp-note-prezenta-item {
	font-size: 12px;
	padding: 6px 8px;
	border: 1.5px solid #ccc;
	text-align: center;
}

.sp-note-prezenta-item--ok {
	background: #e0f5e8;
	border-color: var(--green);
	color: var(--green);
}

.sp-note-prezenta-item--no {
	background: #f5f5f5;
	border-color: #ddd;
	color: #999;
}

/* ── Back Button ── */

.sp-note-back {
	background: transparent;
	border: 2px solid var(--ink);
	padding: 10px 24px;
	font-family: 'DM Sans', sans-serif;
	font-size: 13px;
	font-weight: 600;
	cursor: pointer;
	letter-spacing: .05em;
	transition: all .15s;
	margin-top: 16px;
}

.sp-note-back:hover {
	background: var(--ink);
	color: var(--paper);
}

/* ── Animation ── */

@keyframes sp-up {
	from { opacity: 0; transform: translateY(20px); }
	to   { opacity: 1; transform: translateY(0); }
}

/* ── Mobile ── */

@media (max-width: 480px) {
	.sp-note-wrap .sp-card { margin: 16px auto; }
	.sp-note-wrap .sp-card__body { padding: 20px 16px; }
	.sp-note-stats { grid-template-columns: 1fr 1fr; }
	.sp-note-profile__body { padding: 16px; }
	.sp-note-table th,
	.sp-note-table td { padding: 8px; font-size: 13px; }
}
