/* Yrityksen Ajopäiväkirja – käyttöliittymä v0.6.0 */
.yap-wrap,
.yap-admin-wrap {
	--yap-primary: #126241;
	--yap-primary-dark: #0c4b31;
	--yap-primary-soft: #e7f3ed;
	--yap-text: #17251f;
	--yap-muted: #5f6c67;
	--yap-border: #dde5e1;
	--yap-surface: #ffffff;
	--yap-bg: #f5f8f6;
	--yap-danger: #b42318;
	--yap-shadow: 0 1px 2px rgba(16, 24, 20, .04), 0 10px 26px rgba(16, 24, 20, .045);
	box-sizing: border-box;
	color: var(--yap-text);
	max-width: 1120px;
}

.yap-wrap *,
.yap-admin-wrap * {
	box-sizing: border-box;
}

.yap-app {
	font-size: 16px;
	margin: 0 auto;
}

.yap-panel {
	background: var(--yap-surface, #fff);
	border: 1px solid var(--yap-border, #dcdcde);
	border-radius: 16px;
	box-shadow: var(--yap-shadow, none);
	margin: 1rem 0;
	padding: clamp(1rem, 2.5vw, 1.55rem);
}

.yap-app-header {
	align-items: flex-start;
	background: linear-gradient(120deg, #0e5336, #16724d);
	border-radius: 20px;
	color: #fff;
	display: flex;
	gap: 1.25rem;
	justify-content: space-between;
	margin: 1rem 0;
	padding: clamp(1.2rem, 3.5vw, 2rem);
}

.yap-app-heading h2 {
	color: #fff;
	font-size: clamp(1.65rem, 3vw, 2.25rem);
	line-height: 1.1;
	margin: .2rem 0 .45rem;
}

.yap-app-heading p:last-child {
	color: rgba(255,255,255,.86);
	margin: 0;
}

.yap-eyebrow {
	color: #4c8a6d;
	font-size: .76rem;
	font-weight: 700;
	letter-spacing: .09em;
	margin: 0 0 .35rem;
	text-transform: uppercase;
}

.yap-app-header .yap-eyebrow {
	color: #bce4cd;
}

.yap-user-actions {
	align-items: center;
	display: flex;
	gap: .75rem;
}

.yap-today {
	color: rgba(255,255,255,.84);
	font-size: .93rem;
	white-space: nowrap;
}

.yap-button {
	background: var(--yap-primary, #2271b1);
	border: 1px solid var(--yap-primary, #2271b1);
	border-radius: 10px;
	color: #fff !important;
	cursor: pointer;
	display: inline-flex;
	font: inherit;
	font-weight: 650;
	justify-content: center;
	line-height: 1.2;
	padding: .72rem 1rem;
	text-decoration: none !important;
	transition: background-color .14s ease, border-color .14s ease, transform .14s ease;
}

.yap-button:hover,
.yap-button:focus {
	background: var(--yap-primary-dark, #135e96);
	border-color: var(--yap-primary-dark, #135e96);
	color: #fff !important;
}

.yap-button:disabled {
	cursor: wait;
	opacity: .65;
}

.yap-button.yap-secondary {
	background: #fff;
	border-color: var(--yap-border, #dcdcde);
	color: var(--yap-text, #1d2327) !important;
}

.yap-button.yap-secondary:hover,
.yap-button.yap-secondary:focus {
	background: #f3f7f5;
	border-color: #becbc5;
}

.yap-app-header .yap-secondary {
	background: rgba(255,255,255,.12);
	border-color: rgba(255,255,255,.32);
	color: #fff !important;
}

.yap-app-header .yap-secondary:hover,
.yap-app-header .yap-secondary:focus {
	background: rgba(255,255,255,.22);
	border-color: rgba(255,255,255,.48);
}

.yap-stat-grid {
	display: grid;
	gap: .8rem;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	margin: 1rem 0;
}

.yap-stat-card {
	background: #fff;
	border: 1px solid var(--yap-border);
	border-radius: 14px;
	padding: .9rem 1rem;
}

.yap-stat-card span {
	color: var(--yap-muted);
	display: block;
	font-size: .84rem;
	margin-bottom: .3rem;
}

.yap-stat-card strong {
	color: var(--yap-text);
	display: block;
	font-size: clamp(1.05rem, 2vw, 1.35rem);
	line-height: 1.25;
}

.yap-stat-card small {
	color: var(--yap-muted);
	font-size: .8em;
	font-weight: 500;
}

.yap-page-nav {
	display: flex;
	gap: .55rem;
	margin: 1.1rem 0;
}

.yap-page-nav a {
	border: 1px solid var(--yap-border);
	border-radius: 999px;
	color: var(--yap-text);
	font-weight: 600;
	padding: .5rem .95rem;
	text-decoration: none;
}

.yap-page-nav .yap-page-nav-primary {
	background: var(--yap-primary-soft);
	border-color: #c7dfd2;
	color: var(--yap-primary-dark);
}

.yap-section-heading {
	align-items: center;
	border-bottom: 1px solid var(--yap-border);
	display: flex;
	gap: 1rem;
	justify-content: space-between;
	margin: 0 0 1.2rem;
	padding-bottom: 1rem;
}

.yap-section-heading h3 {
	color: var(--yap-text);
	font-size: clamp(1.22rem, 2vw, 1.42rem);
	margin: 0;
}

.yap-section-heading > p {
	color: var(--yap-muted);
	font-size: .88rem;
	margin: 0;
}

.yap-ride-steps {
	display: grid;
	gap: 1rem;
}

.yap-step {
	border: 1px solid var(--yap-border);
	border-radius: 13px;
	margin: 0;
	padding: 1rem;
}

.yap-step legend {
	align-items: center;
	color: var(--yap-text);
	display: flex;
	font-size: 1.05rem;
	font-weight: 700;
	gap: .55rem;
	padding: 0 .4rem 0 0;
}

.yap-step legend small {
	color: var(--yap-muted);
	font-size: .82rem;
	font-weight: 450;
}

.yap-step-number {
	align-items: center;
	background: var(--yap-primary-soft);
	border-radius: 999px;
	color: var(--yap-primary-dark);
	display: inline-flex;
	font-size: .84rem;
	height: 1.55rem;
	justify-content: center;
	width: 1.55rem;
}

.yap-form-grid,
.yap-grid {
	display: grid;
	gap: .9rem;
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.yap-form-grid label,
.yap-grid label,
.yap-filter label,
.yap-month-filter label,
.yap-settings-field {
	display: flex;
	flex-direction: column;
	font-weight: 600;
	gap: .38rem;
}

.yap-form-grid .yap-wide,
.yap-grid .yap-wide {
	grid-column: 1 / -1;
}

.yap-form-grid input,
.yap-form-grid select,
.yap-form-grid textarea,
.yap-grid input,
.yap-grid select,
.yap-grid textarea,
.yap-filter input,
.yap-filter select,
.yap-month-filter input,
.yap-settings-field input,
.yap-settings-field select,
.yap-settings-field textarea {
	background: #fff;
	border: 1px solid #bdc9c3;
	border-radius: 9px;
	font: inherit;
	max-width: 100%;
	padding: .7rem .75rem;
	width: 100%;
}

.yap-form-grid input:focus,
.yap-form-grid select:focus,
.yap-form-grid textarea:focus,
.yap-month-filter input:focus {
	border-color: var(--yap-primary);
	box-shadow: 0 0 0 3px rgba(18, 98, 65, .13);
	outline: none;
}

.yap-form-grid textarea,
.yap-grid textarea {
	resize: vertical;
}

.yap-origin-preview {
	color: var(--yap-muted);
	font-size: .82rem;
	font-weight: 450;
}

.yap-route-card {
	align-items: center;
	background: var(--yap-bg);
	border: 1px solid var(--yap-border);
	border-radius: 12px;
	display: grid;
	gap: .8rem;
	grid-template-columns: minmax(160px, 1.15fr) auto minmax(115px, 140px);
	margin-top: 1rem;
	padding: .9rem;
}

.yap-route-copy {
	display: flex;
	flex-direction: column;
	gap: .2rem;
}

.yap-route-copy span {
	color: var(--yap-muted);
	font-size: .86rem;
}

.yap-distance-label span {
	color: var(--yap-muted);
	display: block;
	font-size: .8rem;
	font-weight: 600;
	margin-bottom: .25rem;
}

.yap-distance {
	background: #fff !important;
	color: var(--yap-primary-dark);
	font-size: 1.25rem !important;
	font-weight: 700 !important;
	text-align: center;
}

.yap-route-message {
	color: var(--yap-muted);
	font-size: .87rem;
	grid-column: 1 / -1;
	margin: 0;
}

.yap-route-card.is-ready {
	background: #f0faf5;
	border-color: #b9dfcb;
}

.yap-route-card.is-error {
	background: #fff4f3;
	border-color: #f2c6c2;
}

.yap-route-error {
	color: var(--yap-danger);
	font-weight: 650;
}

.yap-savebar {
	align-items: center;
	background: var(--yap-bg);
	border-radius: 12px;
	display: flex;
	gap: .75rem;
	margin-top: 1.1rem;
	padding: .8rem;
}

.yap-savebar span {
	color: var(--yap-muted);
	font-size: .86rem;
}

.yap-save-button {
	min-width: 145px;
}

.yap-history-heading {
	align-items: flex-end;
}

.yap-month-filter {
	align-items: flex-end;
	display: flex;
	gap: .55rem;
}

.yap-month-filter span {
	color: var(--yap-muted);
	font-size: .82rem;
}

.yap-ride-cards {
	display: grid;
	gap: .8rem;
}

.yap-ride-card {
	border: 1px solid var(--yap-border);
	border-radius: 13px;
	padding: .95rem;
}

.yap-ride-card header {
	align-items: flex-start;
	display: flex;
	gap: 1rem;
	justify-content: space-between;
	margin-bottom: .75rem;
}

.yap-ride-card time {
	display: block;
	font-size: 1.05rem;
	font-weight: 700;
}

.yap-card-type {
	color: var(--yap-muted);
	font-size: .86rem;
}

.yap-tag {
	background: #eef1f0;
	border-radius: 999px;
	color: #58645f;
	display: inline-block;
	font-size: .78rem;
	font-weight: 650;
	padding: .24rem .65rem;
	white-space: nowrap;
}

.yap-tag.yap-open {
	background: var(--yap-primary-soft);
	color: var(--yap-primary-dark);
}

.yap-card-route {
	align-items: center;
	background: var(--yap-bg);
	border-radius: 9px;
	display: flex;
	flex-wrap: wrap;
	gap: .45rem;
	margin-bottom: .8rem;
	padding: .62rem .72rem;
}

.yap-card-route span:last-child {
	color: var(--yap-muted);
}

.yap-card-values {
	display: grid;
	gap: .65rem;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	margin: 0;
}

.yap-card-values div {
	min-width: 0;
}

.yap-card-values dt {
	color: var(--yap-muted);
	font-size: .77rem;
	margin-bottom: .18rem;
}

.yap-card-values dd {
	font-size: .93rem;
	font-weight: 650;
	margin: 0;
	overflow-wrap: anywhere;
}

.yap-card-values dd small {
	color: var(--yap-muted);
	display: block;
	font-size: .82rem;
	font-weight: 450;
}

.yap-card-notes {
	border-top: 1px dashed var(--yap-border);
	color: var(--yap-muted);
	font-size: .88rem;
	margin: .75rem 0 0;
	padding-top: .65rem;
}

.yap-card-actions {
	border-top: 1px solid var(--yap-border);
	display: flex;
	gap: .9rem;
	margin-top: .8rem;
	padding-top: .7rem;
}

.yap-card-actions a {
	color: var(--yap-primary);
	font-weight: 600;
	text-decoration: none;
}

.yap-empty-state {
	align-items: center;
	background: var(--yap-bg);
	border-radius: 12px;
	color: var(--yap-muted);
	display: flex;
	flex-direction: column;
	gap: .25rem;
	justify-content: center;
	padding: 2.2rem 1rem;
	text-align: center;
}

.yap-empty-state strong {
	color: var(--yap-text);
}

/* Viestit */
.yap-notice {
	border: 1px solid;
	border-radius: 10px;
	margin: 1rem 0;
	padding: .8rem 1rem;
}

.yap-success {
	background: #edf9f2;
	border-color: #b6dcc8;
	color: #0c5837;
}

.yap-error {
	background: #fff1f0;
	border-color: #f0c0bc;
	color: #8c1d14;
}

.yap-info {
	background: #eef6ff;
	border-color: #c2daf8;
}

/* Kirjautuminen */
.yap-auth-wrap {
	margin: 2rem auto;
	max-width: 490px;
}

.yap-auth-header {
	margin: 0 auto 1.15rem;
	text-align: center;
}

.yap-auth-header h2 {
	color: var(--yap-text);
	font-size: clamp(1.7rem, 3vw, 2.15rem);
	margin: 0 0 .35rem;
}

.yap-auth-header p {
	color: var(--yap-muted);
	margin: 0;
}

.yap-auth-primary {
	padding: clamp(1.15rem, 4vw, 1.7rem);
}

.yap-auth-primary h3 {
	margin: 0 0 1rem;
	text-align: center;
}

.yap-login-form label,
.yap-access-request label {
	display: flex;
	flex-direction: column;
	font-weight: 600;
	gap: .38rem;
	margin-bottom: .85rem;
}

.yap-login-form input[type="text"],
.yap-login-form input[type="password"],
.yap-access-request input[type="text"],
.yap-access-request input[type="email"],
.yap-access-request input[type="tel"],
.yap-access-request textarea {
	border: 1px solid #bdc9c3;
	border-radius: 9px;
	font: inherit;
	padding: .75rem;
	width: 100%;
}

.yap-login-form .yap-checkbox {
	align-items: center;
	display: flex;
	flex-direction: row;
	font-weight: 450;
	gap: .45rem;
	margin: .2rem 0 1rem;
}

.yap-login-form .yap-checkbox input {
	margin: 0;
	width: auto;
}

.yap-login-submit,
.yap-request-submit {
	width: 100%;
}

.yap-login-links {
	margin: 1rem 0;
	text-align: center;
}

.yap-access-details {
	border-top: 1px solid var(--yap-border);
	margin-top: 1.1rem;
	padding-top: 1rem;
}

.yap-access-details summary {
	color: var(--yap-primary);
	cursor: pointer;
	font-weight: 650;
	text-align: center;
}

.yap-access-details-body {
	margin-top: 1rem;
}

.yap-access-details-body > p {
	color: var(--yap-muted);
	font-size: .92rem;
}

.yap-honeypot {
	height: 0;
	left: -10000px;
	overflow: hidden;
	position: absolute;
	width: 0;
}

/* Hallintapaneeli */
.yap-admin-wrap .yap-panel {
	border-radius: 8px;
	box-shadow: none;
}

.yap-filter {
	align-items: flex-end;
	display: flex;
	flex-wrap: wrap;
	gap: .65rem;
	margin: .75rem 0;
}

.yap-settings-field {
	gap: .35rem;
	margin: .75rem 0;
	max-width: 700px;
}

.yap-settings-field small,
.yap-muted {
	color: var(--yap-muted);
	font-size: .88rem;
	font-weight: 450;
}

.yap-summary {
	font-size: 1.1rem;
	margin: 1rem 0 0;
}

.yap-table-scroll {
	overflow-x: auto;
	width: 100%;
}

.yap-table {
	border-collapse: collapse;
	font-size: .94rem;
	min-width: 780px;
	width: 100%;
}

.yap-table th,
.yap-table td {
	border-bottom: 1px solid var(--yap-border);
	padding: .6rem .5rem;
	text-align: left;
	vertical-align: top;
}

.yap-table th {
	font-weight: 700;
}

.yap-notes-row td {
	background: var(--yap-bg);
	font-size: .9rem;
}

.yap-row-actions {
	white-space: nowrap;
}

.yap-row-actions form,
.yap-card-actions form {
	display: inline;
	margin-left: .45rem;
}

.yap-link-button {
	background: transparent;
	border: 0;
	color: #b32d2e;
	cursor: pointer;
	font: inherit;
	padding: 0;
	text-decoration: underline;
}

@media (max-width: 800px) {
	.yap-app-header {
		flex-direction: column;
	}

	.yap-stat-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.yap-route-card {
		grid-template-columns: 1fr auto;
	}

	.yap-route-copy,
	.yap-route-message {
		grid-column: 1 / -1;
	}

	.yap-distance-label {
		grid-column: 1 / -1;
	}
}

@media (max-width: 640px) {
	.yap-panel {
		border-radius: 13px;
		padding: .9rem;
	}

	.yap-form-grid,
	.yap-grid {
		grid-template-columns: 1fr;
	}

	.yap-stat-card {
		padding: .72rem;
	}

	.yap-page-nav {
		position: sticky;
		top: .5rem;
		z-index: 2;
	}

	.yap-page-nav a {
		background: #fff;
		flex: 1;
		text-align: center;
	}

	.yap-route-card {
		grid-template-columns: 1fr;
	}

	.yap-calculate-route {
		width: 100%;
	}

	.yap-savebar {
		align-items: stretch;
		flex-direction: column;
	}

	.yap-save-button {
		width: 100%;
	}

	.yap-history-heading,
	.yap-month-filter {
		align-items: stretch;
		flex-direction: column;
	}

	.yap-month-filter .yap-button {
		width: 100%;
	}

	.yap-card-values {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.yap-user-actions {
		width: 100%;
		justify-content: space-between;
	}
}
