/* refactored with chatGPT - 20 May 2026, UK time */
.map-selector-page #uiPanel .panel-main > .panel-row:nth-child(1),
.map-selector-page #uiPanel .panel-main > .panel-row:nth-child(2),
.map-selector-page .map-selector-style-panel,
.map-selector-page .preview-history-panel,
.map-selector-page #uiPanel .panel-section,
.map-selector-page #featureVisibilityControl,
.map-selector-page .panel-footer,
.map-selector-page .action-row,
.map-selector-page #priceRow,
.map-selector-page #pdfReadyRow,
.map-selector-page #pdfLinkRow,
.map-selector-page #debugProductionRow,
.map-selector-page #buyRow,
.map-selector-page #generateBtn,
.map-selector-page #pdfLoading,
.map-selector-page #colorPicker {
    display: none !important;
}

.map-selector-page #mobilePanelToggle {
    font-size: 0;
}

.map-selector-page #mobilePanelToggle::after {
    content: "Selector";
    font-size: 14px;
}

.map-selector-page #uiPanel {
    max-width: 220px;
}

.map-selector-page #logoBox {
    margin-bottom: 12px;
}

.map-selector-page .area-actions {
    gap: 10px;
}

.map-selector-page .sample-maps-row {
    display: block;
    margin-top: 10px;
}

.map-selector-page .sample-maps-btn {
    width: 100%;
    min-height: 40px;
    border: 1px solid rgba(31, 122, 104, 0.28);
    border-radius: 8px;
    background: #ffffff;
    color: #176454;
    font-size: 13px;
    font-weight: 700;
    cursor: pointer;
    box-shadow: 0 8px 20px rgba(15, 23, 42, 0.08);
}

.map-selector-page .sample-maps-btn:hover,
.map-selector-page .sample-maps-btn:focus-visible {
    border-color: rgba(31, 122, 104, 0.55);
    background: #effaf7;
    outline: none;
}

.map-selector-page #selectAreaBtn,
.map-selector-page #resetAreaBtn {
    width: 100%;
    min-height: 44px;
}

.map-selector-page #panelPreviewBtn {
    width: 100%;
    min-height: 58px;
    border-radius: 8px;
    font-size: 20px;
    font-weight: 800;
    letter-spacing: 0;
}

.map-selector-page #panelPreviewBtn:disabled {
    opacity: 0.55;
}

.map-selector-page #previewStatus {
    line-height: 1.35;
}

.map-selector-page .panel-search {
    max-width: 360px;
}

.map-selector-page .spinner-overlay {
    z-index: 10000;
}

.map-selector-page {
    --selector-bg: #d8dde3;
    --selector-panel-bg: #f7f8fa;
    --selector-panel-strong: #ffffff;
    --selector-ink: #20252d;
    --selector-muted: #68717d;
    --selector-line: #d9dee5;
    --selector-line-strong: #c6cdd6;
    --selector-accent: #1f7a68;
    --selector-accent-dark: #176454;
    --selector-accent-soft: #e3f3ef;
}

.selector-account-control {
    position: fixed;
    top: 18px;
    right: 72px;
    z-index: 8500;
    font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

.selector-login-button,
.selector-account-menu > summary {
    display: inline-flex;
    align-items: center;
    gap: 9px;
    min-height: 42px;
    padding: 0 15px;
    border: 1px solid rgba(198, 205, 214, 0.95);
    border-radius: 8px;
    background: #ffffff;
    box-shadow: 0 10px 26px rgba(28, 35, 45, 0.15);
    color: #1e2732;
    font-size: 14px;
    font-weight: 800;
    letter-spacing: 0;
    text-decoration: none;
    cursor: pointer;
}

.selector-login-button:hover,
.selector-account-menu > summary:hover {
    border-color: #9fb4d3;
    color: #1b5faa;
}

.selector-account-menu {
    position: relative;
}

.selector-account-menu > summary {
    list-style: none;
}

.selector-account-menu > summary::-webkit-details-marker {
    display: none;
}

.selector-account-avatar {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 26px;
    height: 26px;
    border-radius: 50%;
    background: #1b5faa;
    color: #ffffff;
    font-size: 13px;
    font-weight: 900;
}

.selector-account-email {
    max-width: min(230px, 45vw);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.selector-account-menu__panel {
    position: absolute;
    top: calc(100% + 8px);
    right: 0;
    min-width: 238px;
    padding: 10px;
    border: 1px solid rgba(198, 205, 214, 0.95);
    border-radius: 12px;
    background: #ffffff;
    box-shadow: 0 18px 40px rgba(28, 35, 45, 0.18);
}

.selector-account-menu__panel a,
.selector-account-menu__panel button {
    display: block;
    width: 100%;
    padding: 12px 13px;
    border: 0;
    border-radius: 9px;
    background: transparent;
    color: #26313f;
    font: inherit;
    font-size: 14px;
    font-weight: 750;
    text-align: left;
    text-decoration: none;
    cursor: pointer;
}

.selector-account-menu__panel a:hover,
.selector-account-menu__panel button:hover {
    background: #eef5ff;
    color: #1b5faa;
}

.selector-account-menu__panel form {
    margin: 0;
}

.selector-account-page-overlay {
    position: fixed;
    inset: 0;
    z-index: 9750;
    display: block;
    padding: 0;
    background: rgba(18, 25, 34, 0.5);
    backdrop-filter: blur(8px);
}

.selector-account-page-overlay[hidden] {
    display: none;
}

.selector-account-page-dialog {
    position: relative;
    width: 100%;
    height: 100%;
    overflow: hidden;
    background: transparent;
}

.selector-account-page-frame-wrap,
.selector-account-page-frame-wrap iframe {
    width: 100%;
    height: 100%;
}

.selector-account-page-frame-wrap iframe {
    display: block;
    border: 0;
    background: transparent;
}

.selector-account-page-title {
    position: absolute;
    width: 1px;
    height: 1px;
    margin: -1px;
    overflow: hidden;
    clip: rect(0 0 0 0);
}

.account-auth-overlay {
    position: fixed;
    inset: 0;
    z-index: 9800;
    display: grid;
    place-items: center;
    padding: 20px;
    background: rgba(18, 25, 34, 0.48);
    backdrop-filter: blur(8px);
    font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

.account-auth-overlay[hidden] {
    display: none;
}

.account-auth-dialog {
    position: relative;
    width: min(100%, 440px);
    max-height: min(720px, calc(100vh - 40px));
    overflow: auto;
    padding: 24px;
    border: 1px solid rgba(148, 163, 184, 0.36);
    border-radius: 12px;
    background: #ffffff;
    box-shadow: 0 28px 76px rgba(15, 23, 42, 0.28);
}

.account-auth-close {
    position: absolute;
    top: 20px;
    right: 20px;
    display: grid;
    place-items: center;
    width: 44px;
    height: 44px;
    border: 1px solid var(--selector-line);
    border-radius: 50%;
    background: #ffffff;
    color: #637083;
    font-size: 0;
    line-height: 1;
    box-shadow: 0 8px 20px rgba(16, 24, 40, 0.08);
    cursor: pointer;
}

.account-auth-close:hover {
    border-color: #2563eb;
    color: #1747b8;
}

.account-auth-close::before,
.account-auth-close::after {
    position: absolute;
    width: 16px;
    height: 2px;
    border-radius: 999px;
    background: currentColor;
    content: "";
}

.account-auth-close::before {
    transform: rotate(45deg);
}

.account-auth-close::after {
    transform: rotate(-45deg);
}

.account-auth-header {
    display: grid;
    gap: 8px;
    margin-bottom: 18px;
    padding-right: 38px;
}

.account-auth-badge {
    color: var(--selector-accent-dark);
    font-size: 12px;
    font-weight: 900;
}

.account-auth-header h2 {
    margin: 0;
    color: var(--selector-ink);
    font-size: 25px;
    line-height: 1.15;
}

.account-auth-header p,
.account-auth-confirm-text {
    margin: 0;
    color: var(--selector-muted);
    font-size: 14px;
    line-height: 1.45;
}

.account-auth-message {
    margin-bottom: 14px;
    padding: 11px 12px;
    border-radius: 8px;
    background: #edf4ff;
    color: #1747b8;
    font-size: 13px;
    font-weight: 800;
    line-height: 1.45;
}

.account-auth-message.is-error {
    background: #fff0ee;
    color: #b42318;
}

.account-auth-message.is-success {
    background: #ebf8f4;
    color: #0f6f5f;
}

.account-auth-form {
    display: none;
    gap: 13px;
}

.account-auth-form.is-active {
    display: grid;
}

.account-auth-form label {
    display: grid;
    gap: 7px;
}

.account-auth-form label > span {
    color: var(--selector-ink);
    font-size: 13px;
    font-weight: 850;
}

.account-auth-form em,
.account-auth-form small {
    color: var(--selector-muted);
    font-style: normal;
    font-size: 12px;
    font-weight: 700;
}

.account-auth-form input {
    width: 100%;
    min-height: 40px;
    padding: 0 11px;
    border: 1px solid var(--selector-line);
    border-radius: 8px;
    background: #ffffff;
    color: var(--selector-ink);
    font: inherit;
}

.account-auth-form input:focus {
    border-color: var(--selector-accent);
    outline: 3px solid rgba(31, 122, 104, 0.16);
}

.account-auth-form .primary-button {
    min-height: 42px;
    border: 1px solid #1c56d8;
    border-radius: 8px;
    background: #2563eb;
    color: #ffffff;
    font: inherit;
    font-weight: 850;
    cursor: pointer;
}

.account-auth-form .primary-button:disabled {
    opacity: 0.72;
    cursor: wait;
}

.account-auth-links {
    display: flex;
    flex-wrap: wrap;
    gap: 8px 14px;
    padding-top: 4px;
}

.account-auth-links button {
    padding: 0;
    border: 0;
    background: transparent;
    color: #1b5faa;
    font: inherit;
    font-size: 12px;
    font-weight: 850;
    cursor: pointer;
}

.account-auth-links button:hover {
    text-decoration: underline;
}

.map-selector-page #map {
    background: var(--selector-bg);
}

.map-selector-page .panel-stack {
    height: 100vh;
}

.map-selector-page #uiPanel {
    width: 220px;
    max-width: 220px;
    min-width: 220px;
    padding: 16px 14px 22px;
    border: 0;
    border-right: 1px solid var(--selector-line);
    border-radius: 0;
    background: var(--selector-panel-bg);
    box-shadow: 7px 0 22px rgba(28, 35, 45, 0.13);
    color: var(--selector-ink);
}

.map-selector-page #logoBox {
    margin: 0 0 14px;
    padding: 0 0 14px;
    border-bottom: 1px solid var(--selector-line);
}

.map-selector-page #flag {
    display: block;
    width: 100%;
    max-width: 192px;
    height: auto;
    filter: drop-shadow(0 2px 4px rgba(28, 35, 45, 0.12));
}

.map-selector-page .panel-main {
    gap: 10px;
}

.map-selector-page .map-selector-style-panel {
    display: grid;
    gap: 10px;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--selector-line);
}

.map-selector-page .selector-basemap-toggle {
    display: grid;
    gap: 6px;
}

.map-selector-page .selector-basemap-toggle__label {
    color: #303842;
    font-size: 12px;
    font-weight: 800;
}

.map-selector-page .selector-basemap-toggle__buttons {
    display: grid;
    grid-template-columns: 1fr 1fr;
    overflow: hidden;
    border: 1px solid var(--selector-line-strong);
    border-radius: 8px;
    background: var(--selector-panel-strong);
}

.map-selector-page .selector-basemap-toggle button {
    min-width: 0;
    min-height: 34px;
    border: 0;
    border-radius: 0;
    background: transparent;
    color: var(--selector-muted);
    font-size: 12px;
    font-weight: 850;
    letter-spacing: 0;
    cursor: pointer;
}

.map-selector-page .selector-basemap-toggle button + button {
    border-left: 1px solid var(--selector-line);
}

.map-selector-page .selector-basemap-toggle button.is-active {
    background: var(--selector-accent);
    color: #ffffff;
}

.map-selector-page .selector-basemap-toggle button:focus-visible {
    outline: 2px solid var(--selector-accent-dark);
    outline-offset: -2px;
}

.map-selector-page .map-selector-style-title {
    color: #303842;
    font-size: 13px;
    font-weight: 800;
}

.map-selector-page .sidebar-map-style-list {
    display: grid;
    gap: 9px;
}

.map-selector-page .sidebar-map-style-list .map-style-card {
    position: relative;
    min-height: 82px;
    overflow: hidden;
    border: 3px solid transparent;
    border-radius: 8px;
    background: var(--selector-panel-strong);
    box-shadow: 0 1px 0 rgba(255, 255, 255, 0.75), 0 5px 15px rgba(28, 35, 45, 0.09);
    cursor: pointer;
    transition: border-color 140ms ease, box-shadow 140ms ease, transform 140ms ease;
}

.map-selector-page .sidebar-map-style-list .map-style-card img {
    display: block;
    width: 100%;
    height: 82px;
    object-fit: cover;
}

.map-selector-page .sidebar-map-style-list .map-style-card__label {
    position: absolute;
    left: 10px;
    right: 42px;
    bottom: 8px;
    z-index: 3;
    min-width: 0;
    overflow: hidden;
    color: #101820;
    font-size: 12px;
    font-weight: 850;
    line-height: 1.15;
    text-overflow: ellipsis;
    text-shadow: 0 1px 3px rgba(255, 255, 255, 0.82);
    white-space: nowrap;
}

.map-selector-page .sidebar-map-style-list .map-style-card__overlay {
    position: absolute;
    inset: 0;
    z-index: 2;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 12px;
    background: rgba(20, 25, 32, 0.72);
    color: #ffffff;
    opacity: 0;
    text-align: center;
    transition: opacity 140ms ease;
}

.map-selector-page .sidebar-map-style-list .map-style-card__title {
    font-size: 14px;
    font-weight: 850;
    line-height: 1.15;
}

.map-selector-page .sidebar-map-style-list .map-style-card__desc {
    margin-top: 4px;
    font-size: 11px;
    line-height: 1.25;
    opacity: 0.9;
}

.map-selector-page .sidebar-map-style-list .map-style-card.is-hover {
    transform: translateY(-1px);
    box-shadow: 0 9px 22px rgba(28, 35, 45, 0.16);
}

.map-selector-page .sidebar-map-style-list .map-style-card.is-hover .map-style-card__overlay {
    opacity: 1;
}

.map-selector-page .sidebar-map-style-list .map-style-card.is-hover .map-style-card__label {
    color: #ffffff;
    text-shadow: 0 2px 5px rgba(0, 0, 0, 0.5);
}

.map-selector-page .sidebar-map-style-list .map-style-card.is-selected {
    border-color: var(--selector-accent);
    box-shadow: none;
}

.map-selector-page .sidebar-map-style-list .map-style-card.is-selected .map-style-card__overlay {
    opacity: 0;
}

.map-selector-page .sidebar-map-style-list .map-style-card.is-selected .map-style-card__label {
    color: #101820;
    text-shadow: 0 1px 3px rgba(255, 255, 255, 0.82);
}

.map-selector-page .sidebar-map-style-list .map-style-card__check {
    position: absolute;
    top: 8px;
    right: 8px;
    z-index: 4;
    display: none;
    align-items: center;
    justify-content: center;
    width: 23px;
    height: 23px;
    border-radius: 50%;
    background: var(--selector-accent);
    color: #ffffff;
    font-size: 14px;
    font-weight: 900;
}

.map-selector-page .sidebar-map-style-list .map-style-card.is-selected .map-style-card__check {
    display: flex;
}

.map-selector-page .sidebar-map-style-list .map-style-card__badge {
    position: absolute;
    top: 8px;
    left: 8px;
    z-index: 4;
    display: none;
    padding: 4px 6px;
    border-radius: 999px;
    background: rgba(227, 243, 239, 0.94);
    color: var(--selector-accent-dark);
    font-size: 9px;
    font-weight: 900;
    letter-spacing: 0;
    text-transform: uppercase;
}

.map-selector-page .sidebar-map-style-list .map-style-card.is-custom .map-style-card__badge {
    display: inline-flex;
}

.map-selector-page .sidebar-map-style-list .map-style-card:focus-visible {
    outline: 2px solid rgba(31, 122, 104, 0.42);
    outline-offset: 2px;
}

.map-selector-page .preview-history-panel {
    display: grid;
    gap: 8px;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--selector-line);
}

.map-selector-page .preview-history-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}

.map-selector-page .preview-history-title {
    color: #303842;
    font-size: 13px;
    font-weight: 800;
}

.map-selector-page .preview-history-count {
    color: var(--selector-muted);
    font-size: 11px;
    font-weight: 800;
}

.map-selector-page .preview-history-list {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 7px;
    min-height: 42px;
}

.map-selector-page .preview-history-chip {
    position: relative;
    display: grid;
    place-items: center;
    width: 100%;
    aspect-ratio: 1 / 1;
    min-height: 40px;
    padding: 0;
    border: 3px solid transparent;
    border-radius: 8px;
    color: #ffffff;
    font-size: 13px;
    font-weight: 900;
    letter-spacing: 0;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.32);
    box-shadow: none;
    cursor: pointer;
}

.map-selector-page .preview-history-chip.is-loading {
    color: transparent;
    text-shadow: none;
}

.map-selector-page .preview-history-chip.is-loading::after {
    content: "";
    width: 20px;
    height: 20px;
    border: 3px solid rgba(255, 255, 255, 0.45);
    border-top-color: #ffffff;
    border-radius: 50%;
    animation: selectorPreviewSpin 0.75s linear infinite;
}

.map-selector-page .preview-history-chip.is-selected {
    border-color: #101820;
    box-shadow: none;
}

.map-selector-page .preview-history-chip:focus-visible {
    outline: 2px solid rgba(31, 122, 104, 0.42);
    outline-offset: 2px;
}

.map-selector-page .preview-history-loading-overlay {
    position: absolute;
    inset: 0;
    z-index: 1200;
    display: none;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    gap: 12px;
    pointer-events: none;
    background: rgba(248, 250, 252, 0.3);
    backdrop-filter: blur(1px);
}

.map-selector-page #map.is-preview-history-loading .preview-history-loading-overlay {
    display: flex;
}

.map-selector-page .preview-history-loading-spinner {
    width: 56px;
    height: 56px;
    border: 5px solid rgba(37, 99, 235, 0.18);
    border-top-color: #2563eb;
    border-radius: 50%;
    animation: selectorPreviewSpin 0.75s linear infinite;
}

.map-selector-page .preview-history-loading-text {
    padding: 8px 12px;
    border-radius: 7px;
    background: rgba(255, 255, 255, 0.92);
    color: #1f2937;
    font-size: 13px;
    font-weight: 800;
    box-shadow: 0 8px 24px rgba(15, 23, 42, 0.14);
}

@keyframes selectorPreviewSpin {
    to {
        transform: rotate(360deg);
    }
}

.map-selector-page #uiPanel .area-actions {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    align-items: stretch;
    gap: 8px;
    margin: 0;
    padding-top: 2px;
}

.map-selector-page #uiPanel .area-actions #selectAreaBtn,
.map-selector-page #uiPanel .area-actions #resetAreaBtn {
    width: 100%;
    flex: 0 0 auto;
}

.map-selector-page #selectAreaBtn,
.map-selector-page #resetAreaBtn,
.map-selector-page #panelPreviewBtn,
.map-selector-page #postcodeSearchGo {
    border-radius: 7px;
    font-weight: 800;
    letter-spacing: 0;
}

.map-selector-page #selectAreaBtn {
    border-color: var(--selector-accent-dark);
    background: var(--selector-accent);
    color: #ffffff;
    box-shadow: 0 9px 20px rgba(31, 122, 104, 0.22);
}

.map-selector-page #resetAreaBtn {
    width: 100%;
    flex: 0 0 auto;
    border: 1px solid var(--selector-line);
    background: var(--selector-panel-strong);
    color: var(--selector-ink);
    box-shadow: none;
}

.map-selector-page #panelPreviewBtn {
    min-height: 46px;
    border: 1px solid #b9c5ce;
    background: var(--selector-panel-strong);
    color: var(--selector-ink);
    box-shadow: none;
    font-size: 15px;
}

.map-selector-page #panelPreviewBtn:not(:disabled) {
    border-color: var(--selector-accent-dark);
    background: var(--selector-accent);
    color: #ffffff;
}

.map-selector-page #previewStatus {
    min-height: 36px;
    margin: 0;
    padding: 9px 10px;
    border: 1px solid var(--selector-line);
    border-radius: 7px;
    background: var(--selector-panel-strong);
    color: var(--selector-muted);
    font-size: 12px;
    font-weight: 700;
}

.map-selector-page .panel.panel-search {
    top: 18px;
    left: 238px;
    width: min(360px, calc(100vw - 262px));
    max-width: 360px;
    min-width: 280px;
    padding: 9px;
    border: 1px solid var(--selector-line);
    border-radius: 8px;
    background: rgba(250, 251, 252, 0.96);
    box-shadow: 0 8px 24px rgba(28, 35, 45, 0.12);
    backdrop-filter: blur(12px);
}

.map-selector-page .panel.panel-search .search-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 8px;
}

.map-selector-page .panel.panel-search .search-row input[type="text"] {
    width: 100%;
    height: 38px;
    padding: 0 11px;
    border: 1px solid var(--selector-line);
    border-radius: 7px;
    background: #ffffff;
    color: var(--selector-ink);
    font-size: 13px;
    font-weight: 650;
}

.map-selector-page .panel.panel-search .search-row input[type="text"]:focus {
    outline: 2px solid rgba(31, 122, 104, 0.22);
    border-color: var(--selector-accent);
}

.map-selector-page #postcodeSearchGo {
    min-width: 46px;
    height: 38px;
    padding: 0 12px;
    border: 1px solid var(--selector-accent-dark);
    background: var(--selector-accent);
    color: #ffffff;
}

.map-selector-page .panel-search-block .search-actions .paper-fit,
.map-selector-page .postcode-search-status {
    color: var(--selector-muted);
}

.map-selector-page .postcode-search-choices {
    border-color: var(--selector-line);
    background: #ffffff;
    box-shadow: 0 8px 24px rgba(28, 35, 45, 0.12);
}

.map-selector-page .postcode-search-choice {
    color: var(--selector-ink);
    border-bottom-color: var(--selector-line);
}

.map-selector-page .postcode-search-choice:hover {
    background: var(--selector-accent-soft);
}

.map-selector-page .postcode-search-choice__label {
    display: grid;
    gap: 2px;
    min-width: 0;
}

.map-selector-page .postcode-search-choice__label small {
    display: block;
    overflow: hidden;
    color: var(--selector-muted);
    font-size: 11px;
    font-weight: 600;
    line-height: 1.2;
    text-overflow: ellipsis;
    white-space: nowrap;
}

@media (max-width: 900px) {
    .map-selector-page #uiPanel {
        width: 100%;
        min-width: 100%;
        max-width: 100%;
        padding: 16px;
        border-right: 0;
        border-radius: 14px 14px 0 0;
    }

    .map-selector-page .panel.panel-search {
        top: 66px;
        left: 12px;
        right: 12px;
        width: auto;
        min-width: 0;
        max-width: none;
    }

    .map-selector-page .sidebar-map-style-list {
        grid-template-columns: 1fr 1fr;
    }

    .map-selector-page .sidebar-map-style-list .map-style-card img {
        height: 76px;
    }
}

@media (max-width: 520px) {
    .map-selector-page .sidebar-map-style-list {
        grid-template-columns: 1fr;
    }
}

/* Premium floating selector panel layout */
.map-selector-page .panel-stack {
    position: fixed;
    top: 24px;
    left: 24px;
    z-index: 1120;
    height: auto;
    pointer-events: none;
}

.map-selector-page #uiPanel {
    position: relative;
    top: auto;
    left: auto;
    width: 304px;
    min-width: 304px;
    max-width: 304px;
    height: auto;
    max-height: calc(100vh - 48px);
    overflow-y: auto;
    overflow-x: hidden;
    padding: 20px;
    border: 1px solid rgba(148, 163, 184, 0.32);
    border-radius: 20px;
    background: rgba(255, 255, 255, 0.96);
    box-shadow: 0 22px 56px rgba(15, 23, 42, 0.18), 0 2px 10px rgba(15, 23, 42, 0.08);
    color: var(--selector-ink);
    backdrop-filter: blur(14px);
    pointer-events: auto;
}

.map-selector-page #logoBox {
    margin: 0 0 14px;
    padding: 0 0 14px;
    border-bottom: 1px solid rgba(226, 232, 240, 0.9);
}

.map-selector-page #flag {
    width: 100%;
    max-width: 190px;
    filter: none;
}

.map-selector-page .selector-panel-intro {
    margin: 0 0 16px;
}

.map-selector-page .selector-panel-intro h1 {
    margin: 0;
    color: #111827;
    font-size: 21px;
    font-weight: 850;
    line-height: 1.15;
    letter-spacing: 0;
}

.map-selector-page .selector-panel-intro p {
    margin: 7px 0 0;
    color: #667085;
    font-size: 13px;
    font-weight: 600;
    line-height: 1.35;
}

/* Search is now embedded in the floating panel while keeping legacy IDs. */
.map-selector-page .panel.panel-search {
    position: static;
    inset: auto;
    width: 100%;
    min-width: 0;
    max-width: none;
    margin: 0 0 14px;
    padding: 0;
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
    backdrop-filter: none;
}

.map-selector-page .panel.panel-search .panel-search-block {
    margin: 0;
    padding: 0;
    border: 0;
}

.map-selector-page .panel.panel-search .search-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 52px;
    gap: 8px;
}

.map-selector-page .panel.panel-search .search-row input[type="text"] {
    height: 42px;
    border-color: #d0d5dd;
    border-radius: 10px;
    background: #ffffff;
    box-shadow: 0 1px 2px rgba(16, 24, 40, 0.04);
    font-size: 13px;
}

.map-selector-page #postcodeSearchGo {
    height: 42px;
    min-width: 0;
    border-radius: 10px;
    border-color: #0f6f5f;
    background: #137a68;
}

.map-selector-page .panel-search-block .search-actions {
    margin-top: 8px;
}

.map-selector-page #postcodeSearchStatus {
    display: block;
    min-height: 0;
    margin-top: 8px;
}

/* Compact premium action area */
.map-selector-page .panel-main {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.map-selector-page #uiPanel .area-actions {
    gap: 8px;
    padding-top: 0;
}

.map-selector-page #selectAreaBtn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 9px;
    min-height: 42px;
    padding: 0 14px;
    border: 1px solid #cfd9e5;
    border-radius: 12px;
    background: #ffffff;
    color: #1f3447;
    box-shadow: 0 1px 2px rgba(16, 24, 40, 0.05);
    font-size: 13px;
    font-weight: 800;
    text-shadow: none;
}

.map-selector-page #selectAreaBtn .select-area-icon {
    width: 22px;
    height: 22px;
    flex: 0 0 auto;
    display: block;
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
}

.map-selector-page #selectAreaBtn:hover {
    background: #f8fbff;
    border-color: #9fc2e8;
    color: #1e77d1;
}

.map-selector-page #uiPanel.selection-active #selectAreaBtn {
    background: #ffffff;
    border-color: #cfd9e5;
    color: #1f3447;
}

.map-selector-page #resetAreaBtn {
    width: auto;
    min-height: 30px;
    margin: 0 auto;
    padding: 0 8px;
    border: 0;
    background: transparent;
    color: #667085;
    font-size: 12px;
    font-weight: 800;
    text-decoration: underline;
    text-underline-offset: 3px;
}

.map-selector-page #uiPanel.selection-active #resetAreaBtn,
.map-selector-page #resetAreaBtn:hover {
    background: transparent;
    border: 0;
    color: #137a68;
    box-shadow: none;
}

.map-selector-page #panelPreviewBtn {
    min-height: 50px;
    border: 1px solid #0f6f5f;
    border-radius: 12px;
    background: #137a68;
    color: #ffffff;
    box-shadow: 0 12px 24px rgba(19, 122, 104, 0.24);
    font-size: 16px;
    font-weight: 850;
}

.map-selector-page #panelPreviewBtn:not(:disabled),
.map-selector-page #panelPreviewBtn:not(:disabled):hover {
    border-color: #0f6f5f;
    background: #137a68;
    color: #ffffff;
}

.map-selector-page #panelPreviewBtn:disabled {
    border-color: #d0d5dd;
    background: #eef2f6;
    color: #98a2b3;
    box-shadow: none;
    opacity: 1;
}

.map-selector-page #previewStatus {
    min-height: 0;
    padding: 10px 12px;
    border-color: #eaecf0;
    border-radius: 12px;
    background: #f8fafc;
    color: #1e77d1;
    font-size: 12px;
    font-weight: 750;
}

/* refactored with chatGPT - 15 May 2026, UK time */
.map-selector-page .print-size-recommendation {
    display: block;
    box-sizing: border-box;
    width: auto;
    max-width: 100%;
    min-height: 0;
    padding: 0;
    border: 0;
    border-radius: 0;
    background: transparent;
    color: #071a33;
    box-shadow: none;
    font-size: 13px;
    font-weight: 600;
    line-height: 1.35;
    overflow-wrap: anywhere;
}

.map-selector-page .print-size-recommendation.is-empty {
    padding: 10px 12px;
    border: 1px solid #d9dee6;
    border-radius: 8px;
    background: #fffdf8;
    color: #5c6778;
    box-shadow: none;
}

.map-selector-page .print-rec-empty {
    font-size: 12px;
    font-weight: 700;
    line-height: 1.35;
}

.map-selector-page .print-rec-selected {
    display: grid;
    grid-template-columns: 32px minmax(0, 1fr);
    gap: 10px;
    align-items: center;
    padding: 10px 11px;
    border: 1px solid #d9dee6;
    border-radius: 8px;
    background: #fffdf8;
}

.map-selector-page .print-rec-selected > div:last-child,
.map-selector-page .print-rec-main > div:last-child {
    min-width: 0;
}

.map-selector-page .print-rec-icon {
    width: 28px;
    height: 28px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
}

.map-selector-page .print-rec-icon svg,
.map-selector-page .print-rec-info-icon svg,
.map-selector-page .print-rec-details-toggle svg {
    display: block;
    width: 100%;
    height: 100%;
}

.map-selector-page .print-rec-icon-selection {
    color: #1f66c2;
}

.map-selector-page .print-rec-selected-title {
    color: #071a33;
    font-size: 14px;
    font-weight: 850;
    letter-spacing: 0;
}

.map-selector-page .print-rec-selected-value {
    margin-top: 2px;
    color: #0d1b31;
    font-size: 12px;
    font-weight: 650;
}

.map-selector-page .print-rec-divider {
    height: 1px;
    margin: 9px 0;
    background: #e1e5eb;
}

.map-selector-page .print-rec-main {
    display: grid;
    grid-template-columns: 32px minmax(0, 1fr);
    gap: 10px;
    align-items: start;
    padding: 11px;
    border: 1px solid #afd7b8;
    border-radius: 8px;
    background: #f1faf2;
}

.map-selector-page .print-rec-icon-printer {
    color: #137a3d;
}

.map-selector-page .print-rec-label {
    color: #0f6735;
    font-size: 12px;
    font-weight: 850;
}

.map-selector-page .print-rec-size {
    margin-top: 2px;
    color: #07552b;
    font-size: 20px;
    font-weight: 900;
    letter-spacing: 0;
    line-height: 1.08;
}

.map-selector-page .print-rec-note {
    margin-top: 6px;
    color: #0d1b31;
    font-size: 11px;
    font-weight: 600;
    line-height: 1.45;
}

.map-selector-page .print-rec-info {
    display: grid;
    grid-template-columns: 20px minmax(0, 1fr);
    gap: 8px;
    align-items: start;
    margin-top: 9px;
    padding: 9px 10px;
    border-radius: 8px;
    background: #eef5ff;
    color: #0d1b31;
    font-size: 11px;
    font-weight: 600;
    line-height: 1.45;
}

.map-selector-page .print-rec-info-icon {
    width: 17px;
    height: 17px;
    color: #2d72d6;
}

.map-selector-page .print-rec-details-toggle {
    display: flex;
    width: fit-content;
    align-items: center;
    justify-content: center;
    gap: 7px;
    margin: 8px auto 0;
    padding: 0;
    border: 0;
    background: transparent;
    color: #145fc0;
    font-size: 12px;
    font-weight: 850;
    cursor: pointer;
}

.map-selector-page .print-rec-details-toggle svg {
    width: 14px;
    height: 14px;
    transition: transform 160ms ease;
}

.map-selector-page .print-size-recommendation.is-details-open .print-rec-details-toggle svg {
    transform: rotate(180deg);
}

.map-selector-page .print-rec-details {
    display: none;
    margin-top: 8px;
    padding: 8px 10px 0;
    border-top: 1px dashed #d7dee8;
    color: #667085;
    font-size: 11px;
    font-weight: 650;
    line-height: 1.45;
}

.map-selector-page .print-size-recommendation.is-details-open .print-rec-details {
    display: block;
}

.map-selector-page .print-rec-actions {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    margin-top: 10px;
}

.map-selector-page .print-rec-actions .print-rec-details-toggle,
.map-selector-page .print-rec-actions .print-rec-help-button {
    display: inline-flex;
    width: auto;
    min-height: 34px;
    align-items: center;
    justify-content: center;
    gap: 7px;
    margin: 0;
    padding: 0 13px;
    border: 1px solid #cfd9e5;
    border-radius: 9px;
    background: #ffffff;
    color: #1f3447;
    box-shadow: 0 6px 16px rgba(15, 23, 42, 0.06);
    font-size: 12px;
    font-weight: 850;
    text-decoration: none;
    cursor: pointer;
}

.map-selector-page .print-rec-actions .print-rec-details-toggle:hover,
.map-selector-page .print-rec-actions .print-rec-help-button:hover {
    border-color: #9fc2e8;
    color: #145fc0;
    transform: translateY(-1px);
}

.map-selector-page .print-rec-help-button img {
    width: 20px;
    height: 20px;
}

.map-selector-page .selector-help-overlay {
    position: fixed;
    inset: 0;
    z-index: 9900;
    display: block;
    padding: 0;
    background: rgba(18, 25, 34, 0.5);
    backdrop-filter: blur(8px);
}

.map-selector-page .selector-help-overlay[hidden] {
    display: none;
}

.map-selector-page .selector-help-dialog {
    position: relative;
    width: 100%;
    height: 100%;
    overflow: hidden;
    background: transparent;
}

.map-selector-page .selector-help-frame-wrap,
.map-selector-page .selector-help-frame-wrap iframe {
    width: 100%;
    height: 100%;
}

.map-selector-page .selector-help-frame-wrap iframe {
    display: block;
    border: 0;
    background: transparent;
}

.map-selector-page .selector-help-title {
    position: absolute;
    width: 1px;
    height: 1px;
    margin: -1px;
    overflow: hidden;
    clip: rect(0 0 0 0);
}

.map-selector-page #resetAreaBtn {
    display: inline-flex;
    width: auto;
    min-height: 34px;
    align-items: center;
    justify-content: center;
    gap: 7px;
    margin: 2px auto 0;
    padding: 0 13px;
    border: 1px solid #cfd9e5;
    border-radius: 9px;
    background: #ffffff;
    color: #1f3447;
    box-shadow: 0 6px 16px rgba(15, 23, 42, 0.06);
    font-size: 12px;
    font-weight: 850;
    text-decoration: none;
    text-underline-offset: 0;
    cursor: pointer;
}

.map-selector-page #resetAreaBtn img {
    display: block;
    width: 18px;
    height: 18px;
    object-fit: contain;
}

.map-selector-page #uiPanel.selection-active #resetAreaBtn,
.map-selector-page #resetAreaBtn:hover {
    border: 1px solid #9fc2e8;
    background: #ffffff;
    color: #137a68;
    box-shadow: 0 8px 18px rgba(15, 23, 42, 0.08);
}

.map-selector-page .account-auth-overlay {
    z-index: 9800;
    background: rgba(18, 25, 34, 0.48);
    backdrop-filter: blur(8px);
}

.map-selector-page .account-auth-dialog {
    width: min(100%, 640px);
    max-height: min(720px, calc(100vh - 40px));
    box-sizing: border-box;
    overflow-x: hidden;
    overflow-y: auto;
    padding: 34px;
    border-radius: 18px;
    box-shadow: 0 30px 90px rgba(15, 23, 42, 0.34);
}

.map-selector-page .account-auth-dialog *,
.map-selector-page .account-auth-dialog *::before,
.map-selector-page .account-auth-dialog *::after {
    box-sizing: border-box;
}

.map-selector-page .account-auth-dialog[data-account-view="logout"] {
    width: min(100%, 590px);
}

.map-selector-page .account-auth-close {
    top: 24px;
    right: 24px;
    width: 52px;
    height: 52px;
    border: 1px solid var(--selector-line);
    border-radius: 50%;
    background: #ffffff;
    color: #637083;
}

.map-selector-page .account-auth-close::before,
.map-selector-page .account-auth-close::after,
.map-selector-page .account-auth-hero-icon::before,
.map-selector-page .account-auth-hero-icon::after,
.map-selector-page .account-auth-field-icon::before,
.map-selector-page .account-auth-field-icon::after,
.map-selector-page .account-auth-field-ok::before,
.map-selector-page .account-auth-field-ok::after,
.map-selector-page .account-auth-field-eye::before,
.map-selector-page .account-auth-field-eye::after,
.map-selector-page .account-auth-button-icon::before,
.map-selector-page .account-auth-button-icon::after,
.map-selector-page .account-auth-confirm-text span::before,
.map-selector-page .account-auth-links button::before {
    display: none !important;
    content: none !important;
}

.map-selector-page .account-auth-close img {
    display: block;
    width: 20px;
    height: 20px;
}

.map-selector-page .account-auth-header {
    display: grid;
    grid-template-columns: 112px minmax(0, 1fr);
    align-items: center;
    gap: 26px;
    margin-bottom: 30px;
    padding-right: 54px;
}

.map-selector-page .account-auth-hero-icon {
    display: grid;
    place-items: center;
    position: relative;
    width: 112px;
    height: 112px;
    overflow: hidden;
    border-radius: 50%;
    background:
        radial-gradient(circle at 35% 25%, rgba(255, 255, 255, 0.82), rgba(255, 255, 255, 0) 38%),
        #dfeee8;
    color: #08725d;
}

.map-selector-page .account-auth-hero-icon img {
    display: block;
    width: 78px;
    height: 78px;
    object-fit: contain;
}

.map-selector-page .account-auth-hero-logout {
    display: none !important;
}

.map-selector-page .account-auth-dialog[data-account-view="logout"] .account-auth-hero-login {
    display: none !important;
}

.map-selector-page .account-auth-dialog[data-account-view="logout"] .account-auth-hero-logout {
    display: block !important;
}

.map-selector-page .account-auth-header h2 {
    margin: 0;
    color: var(--selector-ink);
    font-size: clamp(34px, 4.6vw, 44px);
    line-height: 1.04;
    font-weight: 900;
}

.map-selector-page .account-auth-header p {
    margin: 12px 0 0;
    color: var(--selector-muted);
    font-size: 18px;
    line-height: 1.45;
    max-width: 380px;
}

.map-selector-page .account-auth-form {
    gap: 20px;
}

.map-selector-page .account-auth-form label {
    gap: 9px;
}

.map-selector-page .account-auth-form label > span {
    color: var(--selector-ink);
    font-size: 16px;
    font-weight: 850;
}

.map-selector-page .account-auth-form input {
    min-height: 54px;
    padding: 0 14px;
    border-radius: 9px;
    font-size: 18px;
}

.map-selector-page .account-auth-field {
    position: relative;
    display: block;
    width: 100%;
    max-width: 100%;
    color: inherit;
    font-size: inherit;
    font-weight: inherit;
}

.map-selector-page .account-auth-field input {
    display: block;
    width: 100%;
    max-width: 100%;
    padding-left: 52px;
    padding-right: 52px;
}

.map-selector-page .account-auth-field-icon,
.map-selector-page .account-auth-field-ok,
.map-selector-page .account-auth-field-eye {
    position: absolute;
    top: 50%;
    display: grid;
    place-items: center;
    transform: translateY(-50%);
    pointer-events: none;
}

.map-selector-page .account-auth-field-icon {
    left: 18px;
    width: 24px;
    height: 24px;
}

.map-selector-page .account-auth-field-ok {
    right: 19px;
    width: 24px;
    height: 24px;
}

.map-selector-page .account-auth-field-eye {
    right: 17px;
    width: 28px;
    height: 28px;
}

.map-selector-page .account-auth-field-icon img,
.map-selector-page .account-auth-field-ok img,
.map-selector-page .account-auth-field-eye img {
    display: block;
    max-width: 100%;
    max-height: 100%;
}

.map-selector-page .account-auth-options {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
}

.map-selector-page .account-auth-options button {
    padding: 0;
    border: 0;
    background: transparent;
    color: #08725d;
    font: inherit;
    font-weight: 850;
    cursor: pointer;
}

.map-selector-page .account-auth-checkbox {
    display: inline-flex !important;
    grid-template-columns: none !important;
    align-items: center;
    gap: 10px !important;
    color: var(--selector-ink);
    font-size: 16px;
    font-weight: 700;
}

.map-selector-page .account-auth-checkbox input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.map-selector-page .account-auth-checkbox img {
    flex: 0 0 auto;
    width: 24px;
    height: 24px;
}

.map-selector-page .account-auth-checkbox input:not(:checked) + img {
    opacity: 0.28;
    filter: grayscale(1);
}

.map-selector-page .account-auth-form .primary-button {
    min-height: 58px;
    border: 0;
    border-radius: 8px;
    background: linear-gradient(135deg, #08725d, #00684f);
    color: #ffffff;
    box-shadow: 0 16px 28px rgba(0, 104, 79, 0.22);
    font-size: 18px;
    font-weight: 900;
}

.map-selector-page .account-auth-submit {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
}

.map-selector-page .account-auth-button-icon {
    display: grid;
    place-items: center;
    position: static;
    width: 28px;
    height: 28px;
    transform: none;
}

.map-selector-page .account-auth-button-icon img {
    display: block;
    width: 28px;
    height: 28px;
}

.map-selector-page .account-auth-confirm-text {
    display: grid;
    grid-template-columns: 34px 1fr;
    align-items: center;
    gap: 16px;
    padding: 22px;
    border: 1px solid #b8d9d0;
    border-radius: 9px;
    background: #eff8f5;
    color: var(--selector-ink);
    font-size: 17px;
    line-height: 1.6;
}

.map-selector-page .account-auth-confirm-text span,
.map-selector-page .account-auth-confirm-text span img {
    display: block;
    width: 34px;
    height: 34px;
}

.map-selector-page .account-auth-actions {
    display: grid;
    grid-template-columns: 1fr 1.5fr;
    gap: 28px;
    padding-top: 24px;
    border-top: 1px solid #d8dee8;
}

.map-selector-page .account-auth-secondary {
    min-height: 58px;
    border: 1px solid #bfc9d8;
    border-radius: 8px;
    background: #ffffff;
    color: var(--selector-ink);
    font: inherit;
    font-size: 18px;
    font-weight: 900;
    cursor: pointer;
}

.map-selector-page .account-auth-links {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    margin-top: 10px;
    padding-top: 22px;
    border-top: 1px solid #d8dee8;
}

.map-selector-page .account-auth-links button {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: #08725d;
    font-size: 16px;
    font-weight: 850;
    text-decoration: none;
}

.map-selector-page .account-auth-links img {
    width: 28px;
    height: 28px;
}

@media (max-width: 640px) {
    .map-selector-page .account-auth-dialog {
        padding: 28px 20px;
    }

    .map-selector-page .account-auth-header {
        grid-template-columns: 78px 1fr;
        gap: 16px;
        margin-bottom: 22px;
        padding-right: 44px;
    }

    .map-selector-page .account-auth-hero-icon {
        width: 78px;
        height: 78px;
    }

    .map-selector-page .account-auth-hero-icon img {
        width: 54px;
        height: 54px;
    }

    .map-selector-page .account-auth-header h2 {
        font-size: 30px;
    }

    .map-selector-page .account-auth-header p {
        font-size: 15px;
    }

    .map-selector-page .account-auth-options,
    .map-selector-page .account-auth-links {
        align-items: flex-start;
        flex-direction: column;
    }

    .map-selector-page .account-auth-actions {
        grid-template-columns: 1fr;
        gap: 12px;
    }
}

/* Mobile bottom sheet treatment for the same controls. */
@media (max-width: 900px) {
    .map-selector-page .panel-stack {
        top: auto;
        left: 0;
        right: 0;
        bottom: 0;
        z-index: 1250;
    }

    .map-selector-page #uiPanel {
        width: auto;
        min-width: 0;
        max-width: none;
        max-height: 76vh;
        margin: 0;
        padding: 18px 18px 20px;
        border-right: 0;
        border-radius: 22px 22px 0 0;
        transform: translateY(100%);
        transition: transform 0.25s ease;
    }

    body.mobile-panel-open.map-selector-page #uiPanel {
        transform: translateY(0);
    }

    .map-selector-page #logoBox {
        display: block;
    }

    .map-selector-page #flag {
        max-width: 168px;
    }

    .map-selector-page .selector-panel-intro h1 {
        font-size: 19px;
    }

    .map-selector-page .panel.panel-search {
        position: static;
        width: 100%;
        min-width: 0;
        max-width: none;
    }
}
