/* =============================================================================
   Strefa Rodzica — style frontendu
   Zaprojektowane jako "neutralne", dziedziczą czcionkę z motywu strony.
   Wszystkie selektory pod prefixem .strefa-rodzica- aby uniknąć kolizji.
   ========================================================================== */

.strefa-rodzica {
	max-width: 720px;
	margin: 2.5rem auto;
	font-family: inherit;
	color: #222;
	line-height: 1.55;
}

.strefa-rodzica * { box-sizing: border-box; }

/* Karty (boxy panelu) */
.strefa-rodzica-card {
	background: #fff;
	border: 1px solid #e6e6e6;
	border-radius: 12px;
	box-shadow: 0 2px 14px rgba(0,0,0,.04);
	padding: 2rem 2rem 1.5rem;
}

.strefa-rodzica-title {
	margin: 0 0 .25rem;
	font-size: 1.6rem;
	font-weight: 700;
	letter-spacing: -0.01em;
}

.strefa-rodzica-lead {
	margin: 0 0 1.5rem;
	color: #555;
	font-size: 0.97rem;
}

.strefa-rodzica-section-title {
	margin: 1.5rem 0 1rem;
	font-size: 1.15rem;
	font-weight: 700;
}

/* Powiadomienia */
.strefa-rodzica-notice {
	padding: .75rem 1rem;
	border-radius: 8px;
	margin: 0 0 1rem;
	font-size: .95rem;
	border: 1px solid transparent;
}
.strefa-rodzica-notice--error   { background: #fdecea; border-color: #f5c2c0; color: #8a1d18; }
.strefa-rodzica-notice--success { background: #e8f5e9; border-color: #b6dfba; color: #1b5e20; }
.strefa-rodzica-notice--info    { background: #e3f2fd; border-color: #b3dcf6; color: #0d47a1; }

/* Formularze */
.strefa-rodzica-form { display: flex; flex-direction: column; gap: 0.25rem; }

.strefa-rodzica-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 1rem;
}

@media (max-width: 540px) {
	.strefa-rodzica-row { grid-template-columns: 1fr; gap: .25rem; }
	.strefa-rodzica-card { padding: 1.5rem 1.25rem; }
}

.strefa-rodzica-field {
	display: flex;
	flex-direction: column;
	margin: 0 0 .9rem;
}

.strefa-rodzica-field label {
	font-size: .87rem;
	font-weight: 600;
	margin-bottom: .35rem;
	color: #333;
}

.strefa-rodzica-field input[type="text"],
.strefa-rodzica-field input[type="email"],
.strefa-rodzica-field input[type="password"],
.strefa-rodzica-field input[type="date"] {
	font: inherit;
	font-size: 1rem;
	padding: .65rem .85rem;
	border: 1px solid #cfcfcf;
	border-radius: 8px;
	background: #fafafa;
	transition: border-color .15s, background .15s, box-shadow .15s;
	width: 100%;
}

.strefa-rodzica-field input:focus {
	outline: none;
	border-color: #5a5cd6;
	background: #fff;
	box-shadow: 0 0 0 3px rgba(90, 92, 214, 0.15);
}

.strefa-rodzica-field--inline { flex-direction: row; align-items: center; gap: .5rem; }
.strefa-rodzica-field--inline label { display: flex; align-items: center; gap: .5rem; font-weight: 500; margin: 0; }

.strefa-rodzica-fieldset {
	border: 1px dashed #d8d8d8;
	border-radius: 8px;
	padding: 1rem 1rem .25rem;
	margin: .5rem 0 1rem;
}
.strefa-rodzica-fieldset legend { padding: 0 .5rem; font-weight: 600; color: #555; font-size: .9rem; }

/* Przyciski */
.strefa-rodzica-actions { margin: .5rem 0 0; }
.strefa-rodzica-btn {
	display: inline-block;
	background: #1f2150;
	color: #fff;
	border: none;
	border-radius: 8px;
	padding: .8rem 1.6rem;
	font: inherit;
	font-weight: 600;
	font-size: 1rem;
	cursor: pointer;
	transition: background .15s, transform .05s;
}
.strefa-rodzica-btn:hover  { background: #2a2d7a; }
.strefa-rodzica-btn:active { transform: translateY(1px); }

.strefa-rodzica-btn--ghost {
	background: transparent;
	color: #1f2150;
	border: 1px solid #1f2150;
}
.strefa-rodzica-btn--ghost:hover { background: rgba(31,33,80,0.06); }

.strefa-rodzica-switch {
	margin: 1rem 0 0;
	font-size: .9rem;
	color: #555;
}
.strefa-rodzica-switch a {
	color: #1f2150;
	font-weight: 600;
	text-decoration: underline;
}

/* Nagłówek panelu zalogowanego rodzica */
.strefa-rodzica-header {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	gap: 1rem;
	margin-bottom: 1rem;
	padding-bottom: 1rem;
	border-bottom: 1px solid #efefef;
}
.strefa-rodzica-child { margin: .25rem 0 0; color: #555; }

.strefa-rodzica-logout { margin: 0; }

/* Lista wydarzeń */
.strefa-rodzica-events { margin-top: 0.5rem; }
.strefa-rodzica-list-title { margin: .5rem 0 .75rem; font-size: 1rem; font-weight: 700; color: #444; }
.strefa-rodzica-empty { color: #777; margin: .5rem 0 1rem; font-style: italic; }

.strefa-rodzica-event-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: .6rem;
}

.strefa-rodzica-event {
	display: grid;
	grid-template-columns: 64px 1fr;
	gap: 1rem;
	padding: .9rem 1rem;
	border: 1px solid #eee;
	border-left: 4px solid #5a5cd6;
	border-radius: 8px;
	background: #fafafa;
	align-items: start;
}
.strefa-rodzica-event.is-past {
	opacity: .65;
	border-left-color: #bbb;
}

.strefa-rodzica-event-date {
	background: #fff;
	border: 1px solid #eee;
	border-radius: 6px;
	padding: .35rem .25rem;
	text-align: center;
	min-width: 56px;
}
.strefa-rodzica-event-day {
	display: block;
	font-size: 1.4rem;
	font-weight: 700;
	line-height: 1;
	color: #1f2150;
}
.strefa-rodzica-event-month {
	display: block;
	font-size: .7rem;
	text-transform: uppercase;
	letter-spacing: .04em;
	color: #777;
	margin-top: 2px;
}

.strefa-rodzica-event-title {
	margin: 0 0 .25rem;
	font-size: 1rem;
	font-weight: 700;
	color: #1f2150;
}
.strefa-rodzica-event-time {
	margin: 0 0 .15rem;
	color: #444;
	font-size: .9rem;
}
.strefa-rodzica-event-location,
.strefa-rodzica-event-desc {
	margin: .15rem 0 0;
	font-size: .85rem;
	color: #666;
}
.strefa-rodzica-pin { margin-right: .15rem; }

.strefa-rodzica-past {
	margin-top: 1.25rem;
	background: #f6f6f6;
	border: 1px solid #ececec;
	border-radius: 8px;
	padding: .25rem .75rem;
}
.strefa-rodzica-past summary {
	cursor: pointer;
	font-weight: 600;
	padding: .5rem 0;
	color: #555;
}
.strefa-rodzica-past[open] summary { margin-bottom: .5rem; }

/* Badge świeżości danych */
.strefa-rodzica-badge {
	display: inline-block;
	padding: .35rem .8rem;
	border-radius: 999px;
	font-size: .82rem;
	font-weight: 600;
	margin: 0 0 1.25rem;
}
.strefa-rodzica-badge--fresh { background: #e8f5e9; color: #1b5e20; border: 1px solid #b6dfba; }
.strefa-rodzica-badge--warn  { background: #fff3e0; color: #8a4400; border: 1px solid #ffcc80; }
.strefa-rodzica-badge--stale {
	background: #fdecea; color: #8a1d18; border: 1px solid #f5c2c0;
	animation: sr-pulse 1.6s ease-in-out infinite;
}
@keyframes sr-pulse {
	0%,100% { box-shadow: 0 0 0 0 rgba(183,28,28,0.25); }
	50%     { box-shadow: 0 0 0 6px rgba(183,28,28,0);    }
}

/* Podsumowanie ucznia */
.strefa-rodzica-summary {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
	gap: .75rem 1.25rem;
	background: #f7f7fc;
	border: 1px solid #ececf5;
	border-radius: 8px;
	padding: 1rem 1.25rem;
	margin-bottom: 1.25rem;
}
.strefa-rodzica-summary-item { display: flex; flex-direction: column; gap: .15rem; }
.strefa-rodzica-summary-label { font-size: .8rem; color: #666; text-transform: uppercase; letter-spacing: .03em; }
.strefa-rodzica-summary-item strong { font-size: 1rem; color: #1f2150; }

/* Tagi (Planowane / Nieobecność) */
.strefa-rodzica-event-tag {
	display: inline-block;
	font-size: .75rem;
	font-weight: 700;
	letter-spacing: .04em;
	text-transform: uppercase;
	padding: .15rem .55rem;
	border-radius: 4px;
	margin: .35rem 0 0;
}
.strefa-rodzica-event-tag--absent    { background: #fdecea; color: #8a1d18; }
.strefa-rodzica-event-tag--projected { background: #e3f2fd; color: #0d47a1; }

.strefa-rodzica-event.is-projected { border-left-color: #2196f3; background: #f4faff; }
.strefa-rodzica-event.is-absent    { border-left-color: #c62828; opacity: .8; }

.strefa-rodzica-hint {
	margin: .5rem 0 1rem;
	color: #777;
	font-size: .82rem;
	font-style: italic;
}
