/* RSD PWA — dedykowany ekran aplikacji (wersja B). */
* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }

body.rsd-pwa-app {
	background: var(--rsd-pwa-bg, #1B2633);
	color: var(--rsd-pwa-surface, #F4F1E8);
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
	min-height: 100vh;
	padding-bottom: env(safe-area-inset-bottom);
}

.rsd-pwa-app-header {
	background: var(--rsd-pwa-primary, #2E4738);
	color: var(--rsd-pwa-surface, #F4F1E8);
	display: flex;
	align-items: center;
	gap: 12px;
	padding: calc(14px + env(safe-area-inset-top)) 16px 14px;
}
.rsd-pwa-app-logo {
	width: 40px;
	height: 40px;
	border-radius: 10px;
	object-fit: cover;
	background: #fff;
}
.rsd-pwa-app-title { font-size: 18px; margin: 0; font-weight: 600; }

.rsd-pwa-account-btn {
	margin-left: auto;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	border-radius: 50%;
	border: 1px solid rgba(255,255,255,.25);
	background: rgba(255,255,255,.10);
	color: var(--rsd-pwa-surface, #F4F1E8);
	cursor: pointer;
	flex: 0 0 auto;
}
.rsd-pwa-account-btn:active { background: rgba(255,255,255,.20); }

.rsd-pwa-account-body { padding: 8px 0 16px; }
.rsd-pwa-account-hint {
	margin: 0;
	padding: 12px 18px;
	color: var(--rsd-pwa-muted, #70757D);
	font-size: 14px;
}
.rsd-pwa-account-link {
	display: block;
	padding: 14px 18px;
	text-decoration: none;
	color: #1d2327;
	border-bottom: 1px solid var(--rsd-pwa-border, #D9D9D4);
	font-size: 15px;
	font-weight: 500;
}
.rsd-pwa-account-link:active { background: rgba(0,0,0,.05); }
.rsd-pwa-account-link.is-primary {
	color: #fff;
	background: var(--rsd-pwa-cta, #D96B27);
	margin: 10px 16px;
	border-radius: 10px;
	text-align: center;
	border-bottom: none;
	font-weight: 600;
}
.rsd-pwa-account-link.is-logout { color: var(--rsd-pwa-cta, #D96B27); font-weight: 600; }

.rsd-pwa-app-main { padding: 16px; max-width: 720px; margin: 0 auto; }

.rsd-pwa-row { display: flex; gap: 12px; margin-bottom: 12px; }
.rsd-pwa-col { flex: 1 1 0; min-width: 0; display: flex; flex-direction: column; gap: 12px; }

.rsd-pwa-button {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	text-align: center;
	text-decoration: none;
	background: var(--rsd-pwa-primary, #2E4738);
	color: var(--rsd-pwa-surface, #F4F1E8);
	border: 1px solid rgba(255,255,255,.06);
	border-radius: 16px;
	padding: 22px 12px;
	min-height: 96px;
	font-size: 15px;
	font-weight: 600;
	line-height: 1.25;
	box-shadow: 0 2px 6px rgba(0,0,0,.25);
	transition: transform .08s ease, filter .08s ease;
}
.rsd-pwa-button:active { transform: scale(.97); filter: brightness(1.08); }
.rsd-pwa-button-icon { font-size: 30px; margin-bottom: 8px; line-height: 1; }
.rsd-pwa-button-icon-img { width: 40px; height: 40px; object-fit: contain; margin-bottom: 8px; }

/* Komponent: tekst */
.rsd-pwa-text {
	background: rgba(255,255,255,.04);
	border: 1px solid var(--rsd-pwa-border, #D9D9D4);
	border-radius: 16px;
	padding: 16px;
	color: var(--rsd-pwa-surface, #F4F1E8);
}
.rsd-pwa-text-icon { display: block; font-size: 30px; line-height: 1; margin-bottom: 8px; }
.rsd-pwa-text-icon-img { width: 40px; height: 40px; object-fit: contain; margin-bottom: 8px; }
.rsd-pwa-text-title { margin: 0 0 6px; font-size: 17px; font-weight: 600; }
.rsd-pwa-text-body { font-size: 15px; line-height: 1.5; }
.rsd-pwa-text-body p { margin: 0 0 8px; }
.rsd-pwa-text-body a { color: var(--rsd-pwa-cta, #D96B27); }

/* Komponent: grafika */
.rsd-pwa-image { line-height: 0; }
.rsd-pwa-image-img {
	width: 100%;
	height: auto;
	display: block;
	border-radius: 16px;
}

/* Wariant CTA — wyróżniony przycisk (klasa do użycia w przyszłości). */
.rsd-pwa-button.is-cta { background: var(--rsd-pwa-cta, #D96B27); }

.rsd-pwa-empty { text-align: center; color: var(--rsd-pwa-muted, #70757D); margin-top: 60px; }

/* Podmenu jako wysuwany panel */
.rsd-pwa-submenu {
	position: fixed;
	inset: 0;
	background: rgba(0,0,0,.35);
	display: flex;
	align-items: flex-end;
	z-index: 9999;
}
.rsd-pwa-submenu[hidden] { display: none; }
.rsd-pwa-submenu-panel {
	background: var(--rsd-pwa-surface, #F4F1E8);
	color: #1d2327;
	width: 100%;
	max-width: 720px;
	margin: 0 auto;
	border-radius: 18px 18px 0 0;
	max-height: 80vh;
	overflow: auto;
	padding-bottom: env(safe-area-inset-bottom);
	animation: rsd-pwa-up .18s ease;
}
@keyframes rsd-pwa-up { from { transform: translateY(100%); } to { transform: translateY(0); } }

.rsd-pwa-submenu-head {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 14px 16px;
	border-bottom: 1px solid var(--rsd-pwa-border, #D9D9D4);
	position: sticky;
	top: 0;
	background: var(--rsd-pwa-surface, #F4F1E8);
}
.rsd-pwa-submenu-back {
	border: none;
	background: none;
	font-size: 26px;
	line-height: 1;
	cursor: pointer;
	color: var(--rsd-pwa-primary, #2E4738);
}
.rsd-pwa-submenu-title { font-weight: 600; font-size: 16px; }

.rsd-pwa-submenu-items { padding: 8px 0; }
.rsd-pwa-submenu-link {
	display: block;
	padding: 14px 18px;
	text-decoration: none;
	color: #1d2327;
	border-bottom: 1px solid var(--rsd-pwa-border, #D9D9D4);
	font-size: 15px;
}
.rsd-pwa-submenu-link:active { background: rgba(0,0,0,.05); }

/* ── Dolny pasek menu ─────────────────────────────────────────────────────── */
body.rsd-pwa-has-bar .rsd-pwa-app-main {
	padding-bottom: calc(72px + env(safe-area-inset-bottom));
}
.rsd-pwa-bottombar {
	position: fixed;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 30;
	display: flex;
	justify-content: space-around;
	align-items: stretch;
	gap: 2px;
	background: var(--rsd-pwa-primary, #2E4738);
	border-top: 1px solid rgba(255,255,255,.12);
	padding-bottom: env(safe-area-inset-bottom);
	box-shadow: 0 -2px 12px rgba(0,0,0,.25);
}
.rsd-pwa-bar-item {
	flex: 1 1 0;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 3px;
	padding: 9px 4px 8px;
	min-width: 0;
	text-decoration: none;
	color: rgba(255,255,255,.82);
	font-size: 11px;
	line-height: 1.1;
	-webkit-tap-highlight-color: transparent;
}
.rsd-pwa-bar-item:active { color: #fff; background: rgba(255,255,255,.08); }
.rsd-pwa-bar-ico { display: flex; align-items: center; justify-content: center; height: 24px; }
.rsd-pwa-bar-ico .rsd-pwa-bar-icon { font-size: 20px; line-height: 1; }
.rsd-pwa-bar-ico .rsd-pwa-bar-icon-img { width: 22px; height: 22px; object-fit: contain; display: block; }
.rsd-pwa-bar-label {
	max-width: 100%;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

/* Panel ustawień korzysta ze stylów panelu konta. */
.rsd-pwa-settings-body { padding: 12px 16px 20px; }

/* ── Kontrolka GPS w panelu ustawień ──────────────────────────────────────── */
.rsd-pwa-gps { margin-top: 8px; }
.rsd-pwa-gps-btn { text-align: center; cursor: pointer; border: none; width: 100%; font: inherit; }
.rsd-pwa-gps-btn:disabled { opacity: .6; cursor: default; }
.rsd-pwa-gps-status {
	margin: 8px 18px 0;
	font-size: 13px;
	color: var(--rsd-pwa-muted, #70757D);
	line-height: 1.4;
}
.rsd-pwa-gps-status strong { color: inherit; }
.rsd-pwa-gps-status a { color: var(--rsd-pwa-cta, #D96B27); }

/* ── Ekran „Konto” jako kafelki ───────────────────────────────────────────── */
.rsd-pwa-app-main-account { padding-top: 8px; }
.rsd-pwa-account-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 12px;
}
.rsd-pwa-account-grid .rsd-pwa-tile {
	min-height: 110px;
	padding: 18px 12px;
}
.rsd-pwa-tile .rsd-pwa-button-icon {
	width: 30px;
	height: 30px;
	margin-bottom: 10px;
}
.rsd-pwa-tile .rsd-pwa-button-label { display: block; line-height: 1.2; }
.rsd-pwa-tile-logout {
	background: var(--rsd-pwa-cta, #D96B27);
	grid-column: 1 / -1;
	min-height: 64px;
	flex-direction: row;
	gap: 10px;
}
.rsd-pwa-tile-logout .rsd-pwa-button-icon { margin-bottom: 0; }

/* ── Pod-widoki konta WooCommerce w ramie aplikacji ───────────────────────── */
.rsd-pwa-app-main-endpoint { color: var(--rsd-pwa-surface, #F4F1E8); }
.rsd-pwa-wc { font-size: 15px; line-height: 1.5; }
.rsd-pwa-wc a { color: var(--rsd-pwa-cta, #D96B27); }
.rsd-pwa-wc h2, .rsd-pwa-wc h3 { margin: 0 0 12px; font-size: 18px; }
.rsd-pwa-wc p { margin: 0 0 12px; }
.rsd-pwa-wc mark { background: transparent; color: var(--rsd-pwa-cta, #D96B27); font-weight: 600; }

/* Komunikaty WooCommerce. */
.rsd-pwa-wc .woocommerce-message,
.rsd-pwa-wc .woocommerce-info,
.rsd-pwa-wc .woocommerce-error,
.rsd-pwa-wc .woocommerce-notice {
	list-style: none;
	margin: 0 0 14px;
	padding: 12px 14px;
	border-radius: 12px;
	border: 1px solid rgba(255,255,255,.12);
	background: rgba(255,255,255,.06);
	font-size: 14px;
}
.rsd-pwa-wc .woocommerce-error { border-color: var(--rsd-pwa-cta, #D96B27); }
.rsd-pwa-wc .woocommerce-message { border-color: rgba(120,200,120,.5); }
.rsd-pwa-wc .woocommerce-error li { list-style: none; }

/* Tabele (zamówienia, pobrania) jako karty. */
.rsd-pwa-wc table.shop_table,
.rsd-pwa-wc table.woocommerce-table,
.rsd-pwa-wc table.woocommerce-orders-table {
	width: 100%;
	border-collapse: collapse;
	margin: 0 0 14px;
}
.rsd-pwa-wc table th { text-align: left; font-weight: 600; }
.rsd-pwa-wc table td,
.rsd-pwa-wc table th { padding: 10px 8px; }
.rsd-pwa-wc .button,
.rsd-pwa-wc .woocommerce-button,
.rsd-pwa-wc button[type="submit"],
.rsd-pwa-wc input[type="submit"] {
	display: inline-block;
	background: var(--rsd-pwa-cta, #D96B27);
	color: #fff;
	border: none;
	border-radius: 10px;
	padding: 9px 16px;
	font-size: 14px;
	font-weight: 600;
	text-decoration: none;
	cursor: pointer;
	line-height: 1.3;
}
.rsd-pwa-wc .button + .button { margin-left: 6px; }

/* Telefon: nagłówki tabel chowamy, wiersze stają się kartami. */
@media (max-width: 600px) {
	.rsd-pwa-wc table.shop_table thead { display: none; }
	.rsd-pwa-wc table.shop_table tr {
		display: block;
		background: rgba(255,255,255,.04);
		border: 1px solid rgba(255,255,255,.12);
		border-radius: 14px;
		padding: 6px 12px;
		margin-bottom: 12px;
	}
	.rsd-pwa-wc table.shop_table td {
		display: flex;
		justify-content: space-between;
		gap: 12px;
		text-align: right;
		padding: 8px 0;
		border-bottom: 1px solid rgba(255,255,255,.08);
	}
	.rsd-pwa-wc table.shop_table td:last-child { border-bottom: none; }
	.rsd-pwa-wc table.shop_table td::before {
		content: attr(data-title);
		font-weight: 600;
		text-align: left;
		color: var(--rsd-pwa-muted, #9aa0a6);
	}
	.rsd-pwa-wc table.shop_table td.woocommerce-orders-table__cell-order-actions::before { content: ""; }
}

/* Adresy. */
.rsd-pwa-wc .woocommerce-Addresses,
.rsd-pwa-wc .u-columns {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
	gap: 12px;
	margin: 0;
}
.rsd-pwa-wc .woocommerce-Address,
.rsd-pwa-wc .col-1,
.rsd-pwa-wc .col-2 {
	background: rgba(255,255,255,.04);
	border: 1px solid rgba(255,255,255,.12);
	border-radius: 14px;
	padding: 14px;
}
.rsd-pwa-wc .woocommerce-Address-title { display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.rsd-pwa-wc address { font-style: normal; line-height: 1.6; }

/* Formularze (szczegóły konta, edycja adresu). */
.rsd-pwa-wc .woocommerce-form-row,
.rsd-pwa-wc p.form-row { margin: 0 0 14px; display: flex; flex-direction: column; }
.rsd-pwa-wc label { font-size: 13px; font-weight: 600; margin-bottom: 5px; }
.rsd-pwa-wc input[type="text"],
.rsd-pwa-wc input[type="email"],
.rsd-pwa-wc input[type="tel"],
.rsd-pwa-wc input[type="password"],
.rsd-pwa-wc input[type="number"],
.rsd-pwa-wc select,
.rsd-pwa-wc textarea {
	width: 100%;
	box-sizing: border-box;
	background: #fff;
	color: #1d2327;
	border: 1px solid var(--rsd-pwa-border, #D9D9D4);
	border-radius: 10px;
	padding: 11px 12px;
	font-size: 15px;
}
.rsd-pwa-wc fieldset {
	border: 1px solid rgba(255,255,255,.12);
	border-radius: 14px;
	padding: 14px;
	margin: 0 0 14px;
}
.rsd-pwa-wc legend { padding: 0 6px; font-weight: 600; }
.rsd-pwa-wc .woocommerce-pagination { margin-top: 8px; }
.rsd-pwa-wc .woocommerce-pagination ul {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	list-style: none;
	margin: 0;
	padding: 0;
}
.rsd-pwa-wc .woocommerce-pagination a,
.rsd-pwa-wc .woocommerce-pagination span {
	display: inline-block;
	padding: 8px 12px;
	border-radius: 10px;
	border: 1px solid rgba(255,255,255,.14);
	text-decoration: none;
}
